mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 21:35:07 +00:00
generalize this code so that fast isel handles integer truncates to i1, which
codegen to the same thing as integer truncates to i8 (the top bits are just undefined). This implements rdar://6667338 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66902 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a14b1ded69
commit
44ceb8a341
@ -1002,7 +1002,9 @@ bool X86FastISel::X86SelectTrunc(Instruction *I) {
|
|||||||
return false;
|
return false;
|
||||||
MVT SrcVT = TLI.getValueType(I->getOperand(0)->getType());
|
MVT SrcVT = TLI.getValueType(I->getOperand(0)->getType());
|
||||||
MVT DstVT = TLI.getValueType(I->getType());
|
MVT DstVT = TLI.getValueType(I->getType());
|
||||||
if (DstVT != MVT::i8)
|
|
||||||
|
// This code only handles truncation to byte right now.
|
||||||
|
if (DstVT != MVT::i8 && DstVT != MVT::i1)
|
||||||
// All other cases should be handled by the tblgen generated code.
|
// All other cases should be handled by the tblgen generated code.
|
||||||
return false;
|
return false;
|
||||||
if (SrcVT != MVT::i16 && SrcVT != MVT::i32)
|
if (SrcVT != MVT::i16 && SrcVT != MVT::i32)
|
||||||
@ -1022,7 +1024,7 @@ bool X86FastISel::X86SelectTrunc(Instruction *I) {
|
|||||||
BuildMI(MBB, DL, TII.get(CopyOpc), CopyReg).addReg(InputReg);
|
BuildMI(MBB, DL, TII.get(CopyOpc), CopyReg).addReg(InputReg);
|
||||||
|
|
||||||
// Then issue an extract_subreg.
|
// Then issue an extract_subreg.
|
||||||
unsigned ResultReg = FastEmitInst_extractsubreg(DstVT.getSimpleVT(),
|
unsigned ResultReg = FastEmitInst_extractsubreg(MVT::i8,
|
||||||
CopyReg, X86::SUBREG_8BIT);
|
CopyReg, X86::SUBREG_8BIT);
|
||||||
if (!ResultReg)
|
if (!ResultReg)
|
||||||
return false;
|
return false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user