diff options
| author | Craig Topper <craig.topper@intel.com> | 2019-11-19 15:51:19 -0800 | 
|---|---|---|
| committer | Craig Topper <craig.topper@intel.com> | 2019-11-19 16:05:22 -0800 | 
| commit | 85589f8077a229a6fbc7c245ae28bec06b88c5fb (patch) | |
| tree | 97fbb8bce948b509390f86824c3fbc955f46a82c /llvm/lib/ExecutionEngine/MCJIT/MCJIT.cpp | |
| parent | 72fac0663a3305e66be4c63d1089ea8a85270c9b (diff) | |
| download | bcm5719-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/ExecutionEngine/MCJIT/MCJIT.cpp')
0 files changed, 0 insertions, 0 deletions

