mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-28 06:32:09 +00:00
Tweak the ARM backend to use the RRX mnemonic instead of the 'mov a, b, rrx'
pseudonym. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116512 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a872a0f5f8
commit
792e9796b3
@ -645,7 +645,7 @@ void ARMCodeEmitter::emitPseudoMoveInstruction(const MachineInstr &MI) {
|
||||
// Encode the shift operation.
|
||||
switch (Opcode) {
|
||||
default: break;
|
||||
case ARM::MOVrx:
|
||||
case ARM::RRX:
|
||||
// rrx
|
||||
Binary |= 0x6 << 4;
|
||||
break;
|
||||
@ -748,7 +748,7 @@ void ARMCodeEmitter::emitPseudoInstruction(const MachineInstr &MI) {
|
||||
// Materialize jumptable address.
|
||||
emitLEApcrelJTInstruction(MI);
|
||||
break;
|
||||
case ARM::MOVrx:
|
||||
case ARM::RRX:
|
||||
case ARM::MOVsrl_flag:
|
||||
case ARM::MOVsra_flag:
|
||||
emitPseudoMoveInstruction(MI);
|
||||
|
@ -1686,9 +1686,9 @@ def : ARMPat<(or GPR:$src, 0xffff0000), (MOVTi16 GPR:$src, 0xffff)>,
|
||||
Requires<[IsARM, HasV6T2]>;
|
||||
|
||||
let Uses = [CPSR] in
|
||||
def MOVrx : AsI1<0b1101, (outs GPR:$dst), (ins GPR:$src), Pseudo, IIC_iMOVsi,
|
||||
"mov", "\t$dst, $src, rrx",
|
||||
[(set GPR:$dst, (ARMrrx GPR:$src))]>, UnaryDP;
|
||||
def RRX: AsI1<0b1101, (outs GPR:$Rd), (ins GPR:$Rm), Pseudo, IIC_iMOVsi,
|
||||
"rrx", "\t$Rd, $Rm",
|
||||
[(set GPR:$Rd, (ARMrrx GPR:$Rm))]>, UnaryDP;
|
||||
|
||||
// These aren't really mov instructions, but we have to define them this way
|
||||
// due to flag operands.
|
||||
|
@ -1598,7 +1598,7 @@ defm t2ASR : T2I_sh_ir<0b10, "asr", BinOpFrag<(sra node:$LHS, node:$RHS)>>;
|
||||
defm t2ROR : T2I_sh_ir<0b11, "ror", BinOpFrag<(rotr node:$LHS, node:$RHS)>>;
|
||||
|
||||
let Uses = [CPSR] in {
|
||||
def t2MOVrx : T2sI<(outs rGPR:$dst), (ins rGPR:$src), IIC_iMOVsi,
|
||||
def t2RRX : T2sI<(outs rGPR:$dst), (ins rGPR:$src), IIC_iMOVsi,
|
||||
"rrx", "\t$dst, $src",
|
||||
[(set rGPR:$dst, (ARMrrx rGPR:$src))]> {
|
||||
let Inst{31-27} = 0b11101;
|
||||
|
@ -3,7 +3,7 @@
|
||||
define i64 @f0(i64 %A, i64 %B) {
|
||||
; CHECK: f0
|
||||
; CHECK: movs r3, r3, lsr #1
|
||||
; CHECK-NEXT: mov r2, r2, rrx
|
||||
; CHECK-NEXT: rrx r2, r2
|
||||
; CHECK-NEXT: subs r0, r0, r2
|
||||
; CHECK-NEXT: sbc r1, r1, r3
|
||||
%tmp = bitcast i64 %A to i64
|
||||
|
Loading…
x
Reference in New Issue
Block a user