mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-06 06:33:24 +00:00
shrink 4-byte branches to 1-byte branches when lowering from
MachineInstr -> MCInst. This is what the assembler backend wants, it relaxes from smaller to larger things. This fixes rdar://7750815 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@98493 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ead138bc62
commit
166604e6ce
@ -303,6 +303,29 @@ void X86MCInstLower::Lower(const MachineInstr *MI, MCInst &OutMI) const {
|
||||
LowerSubReg32_Op0(OutMI, X86::MOV32r0); // MOV64r0 -> MOV32r0
|
||||
LowerUnaryToTwoAddr(OutMI, X86::XOR32rr); // MOV32r0 -> XOR32rr
|
||||
break;
|
||||
|
||||
|
||||
// The assembler backend wants to see branches in their small form and relax
|
||||
// them to their large form. The JIT can only handle the large form because
|
||||
// it does not do relaxation. For now, translation the large form to the
|
||||
// small one here.
|
||||
case X86::JMP_4: OutMI.setOpcode(X86::JMP_1); break;
|
||||
case X86::JO_4: OutMI.setOpcode(X86::JO_1); break;
|
||||
case X86::JNO_4: OutMI.setOpcode(X86::JNO_1); break;
|
||||
case X86::JB_4: OutMI.setOpcode(X86::JB_1); break;
|
||||
case X86::JAE_4: OutMI.setOpcode(X86::JAE_1); break;
|
||||
case X86::JE_4: OutMI.setOpcode(X86::JE_1); break;
|
||||
case X86::JNE_4: OutMI.setOpcode(X86::JNE_1); break;
|
||||
case X86::JBE_4: OutMI.setOpcode(X86::JBE_1); break;
|
||||
case X86::JA_4: OutMI.setOpcode(X86::JA_1); break;
|
||||
case X86::JS_4: OutMI.setOpcode(X86::JS_1); break;
|
||||
case X86::JNS_4: OutMI.setOpcode(X86::JNS_1); break;
|
||||
case X86::JP_4: OutMI.setOpcode(X86::JP_1); break;
|
||||
case X86::JNP_4: OutMI.setOpcode(X86::JNP_1); break;
|
||||
case X86::JL_4: OutMI.setOpcode(X86::JL_1); break;
|
||||
case X86::JGE_4: OutMI.setOpcode(X86::JGE_1); break;
|
||||
case X86::JLE_4: OutMI.setOpcode(X86::JLE_1); break;
|
||||
case X86::JG_4: OutMI.setOpcode(X86::JG_1); break;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user