diff --git a/llvm/lib/Target/AMDGPU/SMInstructions.td b/llvm/lib/Target/AMDGPU/SMInstructions.td --- a/llvm/lib/Target/AMDGPU/SMInstructions.td +++ b/llvm/lib/Target/AMDGPU/SMInstructions.td @@ -119,13 +119,19 @@ let PseudoInstr = opName # variant; } -class SM_Load_Pseudo pattern=[]> - : SM_Pseudo { - RegisterClass BaseClass; +class SM_Load_Pseudo + : SM_Pseudo { + RegisterClass BaseClass = baseClass; let mayLoad = 1; let mayStore = 0; let has_glc = 1; let has_dlc = 1; + let has_offset = offsets.HasOffset; + let has_soffset = offsets.HasSOffset; + let PseudoInstr = opName # offsets.Variant; } class SM_Store_Pseudo { - def _IMM : SM_Load_Pseudo { - let has_offset = 1; - let BaseClass = baseClass; - let PseudoInstr = opName # "_IMM"; - let has_glc = 1; - let has_dlc = 1; - } - - def _SGPR : SM_Load_Pseudo { - let has_soffset = 1; - let BaseClass = baseClass; - let PseudoInstr = opName # "_SGPR"; - let has_glc = 1; - let has_dlc = 1; - } - - def _SGPR_IMM : SM_Load_Pseudo { - let has_offset = 1; - let has_soffset = 1; - let BaseClass = baseClass; - let PseudoInstr = opName # "_SGPR_IMM"; - let has_glc = 1; - let has_dlc = 1; - } + def _IMM : SM_Load_Pseudo ; + def _SGPR : SM_Load_Pseudo ; + def _SGPR_IMM : SM_Load_Pseudo ; } multiclass SM_Pseudo_Stores op, string ps, dag offsets> - : SMEM_Real_vi(ps)> { - RegisterClass BaseClass = !cast(ps).BaseClass; - let InOperandList = !con((ins BaseClass:$sbase), offsets, (ins CPol:$cpol)); +class SMEM_Real_Load_vi op, string ps, OffsetMode offsets> + : SMEM_Real_vi(ps # offsets.Variant)> { + RegisterClass BaseClass = !cast(ps # offsets.Variant).BaseClass; + let InOperandList = !con((ins BaseClass:$sbase), offsets.Ins, (ins CPol:$cpol)); } // The alternative GFX9 SGPR encoding using soffset to encode the @@ -614,14 +589,12 @@ } multiclass SM_Real_Loads_vi op, string ps> { - def _IMM_vi : SMEM_Real_Load_vi ; - def _SGPR_vi : SMEM_Real_Load_vi ; - def _SGPR_alt_gfx9 : SMEM_Real_Load_vi , + def _IMM_vi : SMEM_Real_Load_vi ; + def _SGPR_vi : SMEM_Real_Load_vi ; + def _SGPR_alt_gfx9 : SMEM_Real_Load_vi , SMEM_Real_SGPR_alt_gfx9; let IsGFX9SpecificEncoding = true in - def _SGPR_IMM_gfx9 : SMEM_Real_Load_vi < - op, ps#"_SGPR_IMM", (ins SReg_32:$soffset, smem_offset_mod:$offset)>; + def _SGPR_IMM_gfx9 : SMEM_Real_Load_vi ; } class SMEM_Real_Store_Base_vi op, SM_Pseudo ps> : SMEM_Real_vi { @@ -1029,19 +1002,16 @@ let Inst{16} = !if(ps.has_glc, cpol{CPolBit.GLC}, ?); } -multiclass SM_Real_Loads_gfx10 op, string ps, - SM_Load_Pseudo immPs = !cast(ps#_IMM), - SM_Load_Pseudo sgprPs = !cast(ps#_SGPR)> { - def _IMM_gfx10 : SMEM_Real_gfx10 { - let InOperandList = (ins immPs.BaseClass:$sbase, smem_offset:$offset, CPol:$cpol); - } - def _SGPR_gfx10 : SMEM_Real_gfx10 { - let InOperandList = (ins sgprPs.BaseClass:$sbase, SReg_32:$soffset, CPol:$cpol); - } - def _SGPR_IMM_gfx10 : SMEM_Real_gfx10(ps#_SGPR_IMM)> { - let InOperandList = (ins sgprPs.BaseClass:$sbase, SReg_32:$soffset, - smem_offset_mod:$offset, CPol:$cpol); - } +class SMEM_Real_Load_gfx10 op, string ps, OffsetMode offsets> + : SMEM_Real_gfx10(ps # offsets.Variant)> { + RegisterClass BaseClass = !cast(ps # offsets.Variant).BaseClass; + let InOperandList = !con((ins BaseClass:$sbase), offsets.Ins, (ins CPol:$cpol)); +} + +multiclass SM_Real_Loads_gfx10 op, string ps> { + def _IMM_gfx10 : SMEM_Real_Load_gfx10; + def _SGPR_gfx10 : SMEM_Real_Load_gfx10; + def _SGPR_IMM_gfx10 : SMEM_Real_Load_gfx10; } class SMEM_Real_Store_gfx10 op, SM_Pseudo ps> : SMEM_Real_gfx10 { @@ -1235,17 +1205,16 @@ let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, 0); } -class SMEM_Real_Load_gfx11 op, string ps, string opName, dag offsets> : - SMEM_Real_gfx11(ps), opName> { - RegisterClass BaseClass = !cast(ps).BaseClass; - let InOperandList = !con((ins BaseClass:$sbase), offsets, (ins CPol:$cpol)); +class SMEM_Real_Load_gfx11 op, string ps, string opName, OffsetMode offsets> : + SMEM_Real_gfx11(ps # offsets.Variant), opName> { + RegisterClass BaseClass = !cast(ps # offsets.Variant).BaseClass; + let InOperandList = !con((ins BaseClass:$sbase), offsets.Ins, (ins CPol:$cpol)); } multiclass SM_Real_Loads_gfx11 op, string ps, string opName> { - def _IMM_gfx11 : SMEM_Real_Load_gfx11; - def _SGPR_gfx11 : SMEM_Real_Load_gfx11; - def _SGPR_IMM_gfx11 : SMEM_Real_Load_gfx11< - op, ps#"_SGPR_IMM", opName, (ins SReg_32:$soffset, smem_offset_mod:$offset)>; + def _IMM_gfx11 : SMEM_Real_Load_gfx11; + def _SGPR_gfx11 : SMEM_Real_Load_gfx11; + def _SGPR_IMM_gfx11 : SMEM_Real_Load_gfx11; def : MnemonicAlias(ps#"_IMM").Mnemonic, opName>, Requires<[isGFX11Plus]>; }