mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-21 06:30:16 +00:00
Handle AddrMode6 (for NEON load/stores) in Thumb2's rewriteT2FrameIndex.
Radar 7614112. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95456 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d450e5b886
commit
e6373eb826
@ -382,8 +382,8 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
MI.getOperand(FrameRegIdx+1).ChangeToImmediate(ThisImmVal);
|
||||
} else {
|
||||
|
||||
// AddrMode4 cannot handle any offset.
|
||||
if (AddrMode == ARMII::AddrMode4)
|
||||
// AddrMode4 and AddrMode6 cannot handle any offset.
|
||||
if (AddrMode == ARMII::AddrMode4 || AddrMode == ARMII::AddrMode6)
|
||||
return false;
|
||||
|
||||
// AddrModeT2_so cannot handle any offset. If there is no offset
|
||||
@ -418,15 +418,12 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
NewOpc = positiveOffsetOpcode(Opcode);
|
||||
NumBits = 12;
|
||||
}
|
||||
} else {
|
||||
// VFP and NEON address modes.
|
||||
int InstrOffs = 0;
|
||||
if (AddrMode == ARMII::AddrMode5) {
|
||||
const MachineOperand &OffOp = MI.getOperand(FrameRegIdx+1);
|
||||
InstrOffs = ARM_AM::getAM5Offset(OffOp.getImm());
|
||||
if (ARM_AM::getAM5Op(OffOp.getImm()) == ARM_AM::sub)
|
||||
InstrOffs *= -1;
|
||||
}
|
||||
} else if (AddrMode == ARMII::AddrMode5) {
|
||||
// VFP address mode.
|
||||
const MachineOperand &OffOp = MI.getOperand(FrameRegIdx+1);
|
||||
int InstrOffs = ARM_AM::getAM5Offset(OffOp.getImm());
|
||||
if (ARM_AM::getAM5Op(OffOp.getImm()) == ARM_AM::sub)
|
||||
InstrOffs *= -1;
|
||||
NumBits = 8;
|
||||
Scale = 4;
|
||||
Offset += InstrOffs * 4;
|
||||
@ -435,6 +432,8 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
Offset = -Offset;
|
||||
isSub = true;
|
||||
}
|
||||
} else {
|
||||
llvm_unreachable("Unsupported addressing mode!");
|
||||
}
|
||||
|
||||
if (NewOpc != Opcode)
|
||||
|
@ -12,8 +12,8 @@ declare <4 x float> @llvm.arm.neon.vld1.v4f32(i8*) nounwind readonly
|
||||
define arm_apcscc void @aaa(%quuz* %this, i8* %block) {
|
||||
; CHECK: aaa:
|
||||
; CHECK: bic r4, r4, #15
|
||||
; CHECK: vst1.64 {{.*}}sp, :128
|
||||
; CHECK: vld1.64 {{.*}}sp, :128
|
||||
; CHECK: vst1.64 {{.*}}[r{{.*}}, :128]
|
||||
; CHECK: vld1.64 {{.*}}[r{{.*}}, :128]
|
||||
entry:
|
||||
%0 = call <4 x float> @llvm.arm.neon.vld1.v4f32(i8* undef) nounwind ; <<4 x float>> [#uses=1]
|
||||
store float 6.300000e+01, float* undef, align 4
|
||||
|
Loading…
x
Reference in New Issue
Block a user