Index: lib/Target/AMDGPU/AMDGPUInstrInfo.h =================================================================== --- lib/Target/AMDGPU/AMDGPUInstrInfo.h +++ lib/Target/AMDGPU/AMDGPUInstrInfo.h @@ -61,13 +61,13 @@ uint8_t RsrcArg; bool IsImage; }; -const RsrcIntrinsic *lookupRsrcIntrinsicByIntr(unsigned Intr); +const RsrcIntrinsic *lookupRsrcIntrinsic(unsigned Intr); struct D16ImageDimIntrinsic { unsigned Intr; unsigned D16HelperIntr; }; -const D16ImageDimIntrinsic *lookupD16ImageDimIntrinsicByIntr(unsigned Intr); +const D16ImageDimIntrinsic *lookupD16ImageDimIntrinsic(unsigned Intr); } // end AMDGPU namespace } // End llvm namespace Index: lib/Target/AMDGPU/AMDGPUInstrInfo.cpp =================================================================== --- lib/Target/AMDGPU/AMDGPUInstrInfo.cpp +++ lib/Target/AMDGPU/AMDGPUInstrInfo.cpp @@ -28,10 +28,10 @@ namespace llvm { namespace AMDGPU { -#define GET_RSRCINTRINSIC_IMPL +#define GET_RsrcIntrinsics_IMPL #include "AMDGPUGenSearchableTables.inc" -#define GET_D16IMAGEDIMINTRINSIC_IMPL +#define GET_D16ImageDimIntrinsics_IMPL #include "AMDGPUGenSearchableTables.inc" } } Index: lib/Target/AMDGPU/AMDGPUSearchableTables.td =================================================================== --- lib/Target/AMDGPU/AMDGPUSearchableTables.td +++ lib/Target/AMDGPU/AMDGPUSearchableTables.td @@ -13,15 +13,20 @@ // Resource intrinsics table. //===----------------------------------------------------------------------===// -class RsrcIntrinsic : SearchableTable { - let SearchableFields = ["Intr"]; - let EnumNameField = ?; - +class RsrcIntrinsic { Intrinsic Intr = !cast(intr); bits<8> RsrcArg = intr.RsrcArg; bit IsImage = intr.IsImage; } +def RsrcIntrinsics : GenericTable { + let FilterClass = "RsrcIntrinsic"; + let Fields = ["Intr", "RsrcArg", "IsImage"]; + + let PrimaryKey = ["Intr"]; + let PrimaryKeyName = "lookupRsrcIntrinsic"; +} + foreach intr = !listconcat(AMDGPUBufferIntrinsics, AMDGPUImageIntrinsics, AMDGPUImageDimIntrinsics, @@ -31,13 +36,18 @@ def : RsrcIntrinsic(intr)>; } -class SourceOfDivergence : SearchableTable { - let SearchableFields = ["Intr"]; - let EnumNameField = ?; - +class SourceOfDivergence { Intrinsic Intr = intr; } +def SourcesOfDivergence : GenericTable { + let FilterClass = "SourceOfDivergence"; + let Fields = ["Intr"]; + + let PrimaryKey = ["Intr"]; + let PrimaryKeyName = "lookupSourceOfDivergence"; +} + def : SourceOfDivergence; def : SourceOfDivergence; def : SourceOfDivergence; @@ -84,15 +94,20 @@ foreach intr = AMDGPUImageDimAtomicIntrinsics in def : SourceOfDivergence; -class D16ImageDimIntrinsic : SearchableTable { - let SearchableFields = ["Intr"]; - let EnumNameField = ?; - +class D16ImageDimIntrinsic { Intrinsic Intr = intr; code D16HelperIntr = !cast("AMDGPUIntrinsic::SI_image_d16helper_" # intr.P.OpMod # intr.P.Dim.Name); } +def D16ImageDimIntrinsics : GenericTable { + let FilterClass = "D16ImageDimIntrinsic"; + let Fields = ["Intr", "D16HelperIntr"]; + + let PrimaryKey = ["Intr"]; + let PrimaryKeyName = "lookupD16ImageDimIntrinsic"; +} + foreach intr = !listconcat(AMDGPUImageDimIntrinsics, AMDGPUImageDimGatherIntrinsics) in { def : D16ImageDimIntrinsic; Index: lib/Target/AMDGPU/SIISelLowering.cpp =================================================================== --- lib/Target/AMDGPU/SIISelLowering.cpp +++ lib/Target/AMDGPU/SIISelLowering.cpp @@ -649,7 +649,7 @@ MachineFunction &MF, unsigned IntrID) const { if (const AMDGPU::RsrcIntrinsic *RsrcIntr = - AMDGPU::lookupRsrcIntrinsicByIntr(IntrID)) { + AMDGPU::lookupRsrcIntrinsic(IntrID)) { AttributeList Attr = Intrinsic::getAttributes(CI.getContext(), (Intrinsic::ID)IntrID); if (Attr.hasFnAttribute(Attribute::ReadNone)) @@ -5138,7 +5138,7 @@ Op.getValueType().isVector() && Op.getValueType().getScalarSizeInBits() == 16) { if (const AMDGPU::D16ImageDimIntrinsic *D16ImageDimIntr = - AMDGPU::lookupD16ImageDimIntrinsicByIntr(IntrID)) { + AMDGPU::lookupD16ImageDimIntrinsic(IntrID)) { return adjustLoadValueType(D16ImageDimIntr->D16HelperIntr, cast(Op), DAG, true); } @@ -5393,7 +5393,7 @@ } default: { const AMDGPU::D16ImageDimIntrinsic *D16ImageDimIntr = - AMDGPU::lookupD16ImageDimIntrinsicByIntr(IntrinsicID); + AMDGPU::lookupD16ImageDimIntrinsic(IntrinsicID); if (D16ImageDimIntr) { SDValue VData = Op.getOperand(2); EVT StoreVT = VData.getValueType(); Index: lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp =================================================================== --- lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp +++ lib/Target/AMDGPU/Utils/AMDGPUBaseInfo.cpp @@ -951,15 +951,15 @@ struct SourceOfDivergence { unsigned Intr; }; -const SourceOfDivergence *lookupSourceOfDivergenceByIntr(unsigned Intr); +const SourceOfDivergence *lookupSourceOfDivergence(unsigned Intr); -#define GET_SOURCEOFDIVERGENCE_IMPL +#define GET_SourcesOfDivergence_IMPL #include "AMDGPUGenSearchableTables.inc" } // end anonymous namespace bool isIntrinsicSourceOfDivergence(unsigned IntrID) { - return lookupSourceOfDivergenceByIntr(IntrID); + return lookupSourceOfDivergence(IntrID); } } // namespace AMDGPU } // namespace llvm