mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 21:35:07 +00:00
R600/SI: Rewrite VOP1InstSI to contain a pseudo and _si opcode
What this does is that if you accidentally select these instructions on VI, the code generation will fail, because the pseudo -> _vi mapping will be undefined. The idea is to be able to catch possible future bugs easily. Tested-by: Michel Dänzer <michel.daenzer@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@228038 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e1a8ca95be
commit
f8cf57cb0c
@ -842,6 +842,15 @@ multiclass VOP1_m <vop1 op, dag outs, dag ins, string asm, list<dag> pattern,
|
|||||||
SIMCInstr <opName#"_e32", SISubtarget.VI>;
|
SIMCInstr <opName#"_e32", SISubtarget.VI>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
multiclass VOP1SI_m <vop1 op, dag outs, dag ins, string asm, list<dag> pattern,
|
||||||
|
string opName> {
|
||||||
|
def "" : VOP1_Pseudo <outs, ins, pattern, opName>;
|
||||||
|
|
||||||
|
def _si : VOP1<op.SI, outs, ins, asm, []>,
|
||||||
|
SIMCInstr <opName#"_e32", SISubtarget.SI>;
|
||||||
|
// No VI instruction. This class is for SI only.
|
||||||
|
}
|
||||||
|
|
||||||
class VOP2_Pseudo <dag outs, dag ins, list<dag> pattern, string opName> :
|
class VOP2_Pseudo <dag outs, dag ins, list<dag> pattern, string opName> :
|
||||||
VOP2Common <outs, ins, "", pattern>,
|
VOP2Common <outs, ins, "", pattern>,
|
||||||
VOP <opName>,
|
VOP <opName>,
|
||||||
@ -938,6 +947,16 @@ multiclass VOP3_1_m <vop op, dag outs, dag ins, string asm,
|
|||||||
VOP3DisableFields<0, 0, HasMods>;
|
VOP3DisableFields<0, 0, HasMods>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
multiclass VOP3SI_1_m <vop op, dag outs, dag ins, string asm,
|
||||||
|
list<dag> pattern, string opName, bit HasMods = 1> {
|
||||||
|
|
||||||
|
def "" : VOP3_Pseudo <outs, ins, pattern, opName>;
|
||||||
|
|
||||||
|
def _si : VOP3_Real_si <op.SI3, outs, ins, asm, opName>,
|
||||||
|
VOP3DisableFields<0, 0, HasMods>;
|
||||||
|
// No VI instruction. This class is for SI only.
|
||||||
|
}
|
||||||
|
|
||||||
multiclass VOP3_2_m <vop op, dag outs, dag ins, string asm,
|
multiclass VOP3_2_m <vop op, dag outs, dag ins, string asm,
|
||||||
list<dag> pattern, string opName, string revOp,
|
list<dag> pattern, string opName, string revOp,
|
||||||
bit HasMods = 1, bit UseFullOp = 0> {
|
bit HasMods = 1, bit UseFullOp = 0> {
|
||||||
@ -1045,17 +1064,14 @@ multiclass VOP1Inst <vop1 op, string opName, VOPProfile P,
|
|||||||
multiclass VOP1InstSI <vop1 op, string opName, VOPProfile P,
|
multiclass VOP1InstSI <vop1 op, string opName, VOPProfile P,
|
||||||
SDPatternOperator node = null_frag> {
|
SDPatternOperator node = null_frag> {
|
||||||
|
|
||||||
def _e32 : VOP1 <op.SI, P.Outs, P.Ins32, opName#P.Asm32, []>,
|
defm _e32 : VOP1SI_m <op, P.Outs, P.Ins32, opName#P.Asm32, [], opName>;
|
||||||
VOP <opName>;
|
|
||||||
|
|
||||||
def _e64 : VOP3Common <P.Outs, P.Ins64, opName#P.Asm64,
|
defm _e64 : VOP3SI_1_m <op, P.Outs, P.Ins64, opName#P.Asm64,
|
||||||
!if(P.HasModifiers,
|
!if(P.HasModifiers,
|
||||||
[(set P.DstVT:$dst, (node (P.Src0VT (VOP3Mods0 P.Src0VT:$src0,
|
[(set P.DstVT:$dst, (node (P.Src0VT (VOP3Mods0 P.Src0VT:$src0,
|
||||||
i32:$src0_modifiers, i1:$clamp, i32:$omod))))],
|
i32:$src0_modifiers, i1:$clamp, i32:$omod))))],
|
||||||
[(set P.DstVT:$dst, (node P.Src0VT:$src0))])>,
|
[(set P.DstVT:$dst, (node P.Src0VT:$src0))]),
|
||||||
VOP <opName>,
|
opName, P.HasModifiers>;
|
||||||
VOP3e <op.SI3>,
|
|
||||||
VOP3DisableFields<0, 0, P.HasModifiers>;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
multiclass VOP2_Helper <vop2 op, string opName, dag outs,
|
multiclass VOP2_Helper <vop2 op, string opName, dag outs,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user