]> granicus.if.org Git - llvm/commit
Reapply "[CodeGen][X86] Expand USUBSAT to UMAX+SUB, also for vectors"
authorNikita Popov <nikita.ppv@gmail.com>
Tue, 15 Jan 2019 18:43:41 +0000 (18:43 +0000)
committerNikita Popov <nikita.ppv@gmail.com>
Tue, 15 Jan 2019 18:43:41 +0000 (18:43 +0000)
commitb96b37dc8fb417dc4123246d7bfd910789de810a
tree2cbeb95db17139bd86f0289c9a442376200f29ca
parentbb3d0e960a93c1b140b7322a306bb5b908a3650e
Reapply "[CodeGen][X86] Expand USUBSAT to UMAX+SUB, also for vectors"

Related to https://bugs.llvm.org/show_bug.cgi?id=40123.

Rather than scalarizing, expand a vector USUBSAT into UMAX+SUB,
which produces much better code for X86.

Reapplying with updated SLPVectorizer tests.

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

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@351219 91177308-0d34-0410-b5e6-96231b3b80d8
lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp
lib/CodeGen/SelectionDAG/TargetLowering.cpp
lib/Target/X86/X86TargetTransformInfo.cpp
test/Analysis/CostModel/X86/arith-usat.ll
test/CodeGen/X86/usub_sat.ll
test/CodeGen/X86/usub_sat_vec.ll
test/Transforms/SLPVectorizer/X86/arith-sub-usat.ll