summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2019-11-19 15:51:19 -0800
committerCraig Topper <craig.topper@intel.com>2019-11-19 16:05:22 -0800
commit85589f8077a229a6fbc7c245ae28bec06b88c5fb (patch)
tree97fbb8bce948b509390f86824c3fbc955f46a82c /llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
parent72fac0663a3305e66be4c63d1089ea8a85270c9b (diff)
downloadbcm5719-llvm-85589f8077a229a6fbc7c245ae28bec06b88c5fb.tar.gz
bcm5719-llvm-85589f8077a229a6fbc7c245ae28bec06b88c5fb.zip
[X86] Add custom type legalization and lowering for scalar STRICT_FP_TO_SINT/UINT
This is a first pass at Custom lowering for these operations. I also updated some of the vector code where it was obviously easy and straightforward. More work needed in follow up. This enables these operations to be handled with X87 where special rounding control adjustments are needed to perform a truncate. Still need to fix Promotion in the target independent code in LegalizeDAG. llrint/llround split into separate test file because we can't make a strict libcall properly yet either and we need to do that when i64 isn't a legal type. This does not include any isel support. So we still rely on the mutation in SelectionDAGIsel to remove the strict from this stuff later. Except for the X87 stuff which goes through custom nodes that already had chains. Differential Revision: https://reviews.llvm.org/D70214
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud