[all-commits] [llvm/llvm-project] 136f98: [x86] adjust cost model values for minnum/maxnum w...

RotateRight via All-commits all-commits at lists.llvm.org
Tue Dec 1 07:47:19 PST 2020


  Branch: refs/heads/master
  Home:   https://github.com/llvm/llvm-project
  Commit: 136f98e5236522f55693b8b2d23e87692987f734
      https://github.com/llvm/llvm-project/commit/136f98e5236522f55693b8b2d23e87692987f734
  Author: Sanjay Patel <spatel at rotateright.com>
  Date:   2020-12-01 (Tue, 01 Dec 2020)

  Changed paths:
    M llvm/lib/Target/X86/X86TargetTransformInfo.cpp
    M llvm/test/Analysis/CostModel/X86/fmaxnum.ll
    M llvm/test/Analysis/CostModel/X86/fminnum.ll

  Log Message:
  -----------
  [x86] adjust cost model values for minnum/maxnum with fast-math-flags

Without FMF, we lower these intrinsics into something like this:

vmaxsd	%xmm0, %xmm1, %xmm2
vcmpunordsd	%xmm0, %xmm0, %xmm0
vblendvpd	%xmm0, %xmm1, %xmm2, %xmm0

But if we can ignore NANs, the single min/max instruction is enough
because there is no need to fix up the x86 logic that corresponds to
X > Y ? X : Y.

We probably want to make other adjustments for FP intrinsics with FMF
to account for specialized codegen (for example, FSQRT).

Differential Revision: https://reviews.llvm.org/D92337




More information about the All-commits mailing list