mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-27 14:34:58 +00:00
Fix a few places that depended on the numeric value of subreg indices.
Add assertions in places that depend on consecutive indices. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104510 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
558661d271
commit
7bb31e3187
@ -1107,6 +1107,7 @@ SDNode *ARMDAGToDAGISel::SelectVLD(SDNode *N, unsigned NumVecs,
|
||||
RegSeq = SDValue(QuadDRegs(MVT::v4i64, V0, V1, V2, V3), 0);
|
||||
}
|
||||
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
for (unsigned Vec = 0; Vec < NumVecs; ++Vec) {
|
||||
SDValue D = CurDAG->getTargetExtractSubreg(ARM::dsub_0+Vec,
|
||||
dl, VT, RegSeq);
|
||||
@ -1187,6 +1188,7 @@ SDNode *ARMDAGToDAGISel::SelectVLD(SDNode *N, unsigned NumVecs,
|
||||
V4, V5, V6, V7), 0);
|
||||
|
||||
// Extract out the 3 / 4 Q registers.
|
||||
assert(ARM::qsub_3 == ARM::qsub_0+3 && "Unexpected subreg numbering");
|
||||
for (unsigned Vec = 0; Vec < NumVecs; ++Vec) {
|
||||
SDValue Q = CurDAG->getTargetExtractSubreg(ARM::qsub_0+Vec,
|
||||
dl, VT, RegSeq);
|
||||
@ -1345,6 +1347,7 @@ SDNode *ARMDAGToDAGISel::SelectVST(SDNode *N, unsigned NumVecs,
|
||||
V[4], V[5], V[6], V[7]), 0);
|
||||
|
||||
// Store the even D registers.
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
Ops.push_back(Reg0); // post-access address offset
|
||||
for (unsigned Vec = 0; Vec < NumVecs; ++Vec)
|
||||
Ops.push_back(CurDAG->getTargetExtractSubreg(ARM::dsub_0+Vec*2, dl,
|
||||
@ -1570,6 +1573,8 @@ SDNode *ARMDAGToDAGISel::SelectVLDSTLane(SDNode *N, bool IsLoad,
|
||||
V[4], V[5], V[6], V[7]), 0);
|
||||
}
|
||||
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
assert(ARM::qsub_3 == ARM::qsub_0+3 && "Unexpected subreg numbering");
|
||||
unsigned SubIdx = is64BitVector ? ARM::dsub_0 : ARM::qsub_0;
|
||||
for (unsigned Vec = 0; Vec < NumVecs; ++Vec)
|
||||
ReplaceUses(SDValue(N, Vec),
|
||||
|
@ -796,27 +796,32 @@ def VST4LNq32_UPD : VST4LNWB<0b1011, {?,1,?,?}, "32">;
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// Extract D sub-registers of Q registers.
|
||||
// (dsub_0 is 5; dsub_1 is 6)
|
||||
def DSubReg_i8_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(5 + N->getZExtValue() / 8, MVT::i32);
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/8, MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_i16_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(5 + N->getZExtValue() / 4, MVT::i32);
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/4, MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_i32_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(5 + N->getZExtValue() / 2, MVT::i32);
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue()/2, MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_f64_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(5 + N->getZExtValue(), MVT::i32);
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + N->getZExtValue(), MVT::i32);
|
||||
}]>;
|
||||
def DSubReg_f64_other_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(5 + (1 - N->getZExtValue()), MVT::i32);
|
||||
assert(ARM::dsub_7 == ARM::dsub_0+7 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::dsub_0 + (1 - N->getZExtValue()),
|
||||
MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Extract S sub-registers of Q/D registers.
|
||||
// (ssub_0 is 1; ssub_1 is 2; etc.)
|
||||
def SSubReg_f32_reg : SDNodeXForm<imm, [{
|
||||
return CurDAG->getTargetConstant(1 + N->getZExtValue(), MVT::i32);
|
||||
assert(ARM::ssub_3 == ARM::ssub_0+3 && "Unexpected subreg numbering");
|
||||
return CurDAG->getTargetConstant(ARM::ssub_0 + N->getZExtValue(), MVT::i32);
|
||||
}]>;
|
||||
|
||||
// Translate lane numbers from Q registers to D subregs.
|
||||
|
@ -446,6 +446,7 @@ def CCR : RegisterClass<"ARM", [i32], 32, [CPSR]>;
|
||||
// sub registers for each register.
|
||||
//
|
||||
let Namespace = "ARM" in {
|
||||
// Note: Code depends on these having consecutive numbers.
|
||||
def ssub_0 : SubRegIndex { let NumberHack = 1; }
|
||||
def ssub_1 : SubRegIndex { let NumberHack = 2; }
|
||||
def ssub_2 : SubRegIndex { let NumberHack = 3; }
|
||||
|
Loading…
x
Reference in New Issue
Block a user