Skip to content

Commit

Permalink
[NFC] Optimize adding of decorations (#1233)
Browse files Browse the repository at this point in the history
* [NFC] Optimize adding of decorations

Use std::undordered_set instead of std::multiset with custom comparator.
It is a bit unclear why std::multiset was required since there is no
order requirement for OpDecorate instructions in SPIR-V spec, in addition old
data structure was highly inefficient.
  • Loading branch information
Fznamznon authored and MrSidims committed Mar 29, 2023
1 parent 1afe9ba commit f3c9bb5
Show file tree
Hide file tree
Showing 20 changed files with 132 additions and 214 deletions.
57 changes: 2 additions & 55 deletions lib/SPIRV/libSPIRV/SPIRVDecorate.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,8 @@
#include "SPIRVValue.h"

namespace SPIRV {
template <class T, class B>
spv_ostream &operator<<(spv_ostream &O, const std::multiset<T *, B> &V) {
template <class T>
spv_ostream &operator<<(spv_ostream &O, const std::vector<T *> &V) {
for (auto &I : V)
O << *I;
return O;
Expand Down Expand Up @@ -250,57 +250,4 @@ void SPIRVGroupMemberDecorate::decorateTargets() {
}
}
}

bool SPIRVDecorateGeneric::Comparator::
operator()(const SPIRVDecorateGeneric *A, const SPIRVDecorateGeneric *B) const {
auto Action = [=]() {
if (A->getOpCode() < B->getOpCode())
return true;
if (A->getOpCode() > B->getOpCode())
return false;
if (A->getDecorateKind() < B->getDecorateKind())
return true;
if (A->getDecorateKind() > B->getDecorateKind())
return false;
if (A->getLiteralCount() < B->getLiteralCount())
return true;
if (A->getLiteralCount() > B->getLiteralCount())
return false;
for (size_t I = 0, E = A->getLiteralCount(); I != E; ++I) {
auto EA = A->getLiteral(I);
auto EB = B->getLiteral(I);
if (EA < EB)
return true;
if (EA > EB)
return false;
}
return false;
};
auto Res = Action();
return Res;
}

bool operator==(const SPIRVDecorateGeneric &A, const SPIRVDecorateGeneric &B) {
if (A.getTargetId() != B.getTargetId())
return false;
if (A.getOpCode() != B.getOpCode())
return false;
if (B.isMemberDecorate()) {
auto &MDA = static_cast<SPIRVMemberDecorate const &>(A);
auto &MDB = static_cast<SPIRVMemberDecorate const &>(B);
if (MDA.getMemberNumber() != MDB.getMemberNumber())
return false;
}
if (A.getDecorateKind() != B.getDecorateKind())
return false;
if (A.getLiteralCount() != B.getLiteralCount())
return false;
for (size_t I = 0, E = A.getLiteralCount(); I != E; ++I) {
auto EA = A.getLiteral(I);
auto EB = B.getLiteral(I);
if (EA != EB)
return false;
}
return true;
}
} // namespace SPIRV
36 changes: 4 additions & 32 deletions lib/SPIRV/libSPIRV/SPIRVDecorate.h
Original file line number Diff line number Diff line change
Expand Up @@ -67,15 +67,6 @@ class SPIRVDecorateGeneric : public SPIRVAnnotationGeneric {
std::vector<SPIRVWord> getVecLiteral() const;
Decoration getDecorateKind() const;
size_t getLiteralCount() const;
/// Compare for kind and literal only.
struct Comparator {
bool operator()(const SPIRVDecorateGeneric *A,
const SPIRVDecorateGeneric *B) const;
};
/// Compare kind, literals and target.
friend bool operator==(const SPIRVDecorateGeneric &A,
const SPIRVDecorateGeneric &B);

SPIRVDecorationGroup *getOwner() const { return Owner; }

void setOwner(SPIRVDecorationGroup *Owner) { this->Owner = Owner; }
Expand Down Expand Up @@ -106,26 +97,7 @@ class SPIRVDecorateGeneric : public SPIRVAnnotationGeneric {
SPIRVDecorationGroup *Owner; // Owning decorate group
};

class SPIRVDecorateSet
: public std::multiset<SPIRVDecorateGeneric *,
SPIRVDecorateGeneric::Comparator> {
public:
typedef std::multiset<SPIRVDecorateGeneric *,
SPIRVDecorateGeneric::Comparator>
BaseType;
iterator insert(value_type &Dec) {
auto ER = BaseType::equal_range(Dec);
for (auto I = ER.first, E = ER.second; I != E; ++I) {
SPIRVDBG(spvdbgs() << "[compare decorate] " << *Dec << " vs " << **I
<< " : ");
if (**I == *Dec)
return I;
SPIRVDBG(spvdbgs() << " diff\n");
}
SPIRVDBG(spvdbgs() << "[add decorate] " << *Dec << '\n');
return BaseType::insert(Dec);
}
};
typedef std::vector<SPIRVDecorateGeneric *> SPIRVDecorateVec;

class SPIRVDecorate : public SPIRVDecorateGeneric {
public:
Expand Down Expand Up @@ -336,17 +308,17 @@ class SPIRVDecorationGroup : public SPIRVEntry {
void encodeAll(spv_ostream &O) const override;
_SPIRV_DCL_ENCDEC
// Move the given decorates to the decoration group
void takeDecorates(SPIRVDecorateSet &Decs) {
void takeDecorates(SPIRVDecorateVec &Decs) {
Decorations = std::move(Decs);
for (auto &I : Decorations)
const_cast<SPIRVDecorateGeneric *>(I)->setOwner(this);
Decs.clear();
}

SPIRVDecorateSet &getDecorations() { return Decorations; }
SPIRVDecorateVec &getDecorations() { return Decorations; }

protected:
SPIRVDecorateSet Decorations;
SPIRVDecorateVec Decorations;
void validate() const override {
assert(OpCode == OC);
assert(WordCount == WC);
Expand Down
16 changes: 8 additions & 8 deletions lib/SPIRV/libSPIRV/SPIRVModule.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -489,7 +489,7 @@ class SPIRVModuleImpl : public SPIRVModule {
SPIRVStringVec StringVec;
SPIRVMemberNameVec MemberNameVec;
std::shared_ptr<const SPIRVLine> CurrentLine;
SPIRVDecorateSet DecorateSet;
SPIRVDecorateVec DecorateVec;
SPIRVDecGroupVec DecGroupVec;
SPIRVGroupDecVec GroupDecVec;
SPIRVAsmTargetVector AsmTargetVec;
Expand Down Expand Up @@ -970,7 +970,7 @@ SPIRVModuleImpl::addDecorate(SPIRVDecorateGeneric *Dec) {
(void)Found;
assert(Found && "Decorate target does not exist");
if (!Dec->getOwner())
DecorateSet.insert(Dec);
DecorateVec.push_back(Dec);
addCapabilities(Dec->getRequiredCapability());
return Dec;
}
Expand Down Expand Up @@ -1533,8 +1533,8 @@ spv_ostream &operator<<(spv_ostream &O, const std::vector<T *> &V) {
return O;
}

template <class T, class B>
spv_ostream &operator<<(spv_ostream &O, const std::multiset<T *, B> &V) {
template <class T, class B = std::less<T>>
spv_ostream &operator<<(spv_ostream &O, const std::unordered_set<T *, B> &V) {
for (auto &I : V)
O << *I;
return O;
Expand Down Expand Up @@ -1689,7 +1689,7 @@ spv_ostream &operator<<(spv_ostream &O, SPIRVModule &M) {
}

O << MI.MemberNameVec << MI.ModuleProcessedVec << MI.DecGroupVec
<< MI.DecorateSet << MI.GroupDecVec << MI.ForwardPointerVec
<< MI.DecorateVec << MI.GroupDecVec << MI.ForwardPointerVec
<< TopologicalSort(MI.TypeVec, MI.ConstVec, MI.VariableVec,
MI.ForwardPointerVec);

Expand All @@ -1716,11 +1716,11 @@ SPIRVDecorationGroup *SPIRVModuleImpl::addDecorationGroup() {
SPIRVDecorationGroup *
SPIRVModuleImpl::addDecorationGroup(SPIRVDecorationGroup *Group) {
add(Group);
Group->takeDecorates(DecorateSet);
Group->takeDecorates(DecorateVec);
DecGroupVec.push_back(Group);
SPIRVDBG(spvdbgs() << "[addDecorationGroup] {" << *Group << "}\n";
spvdbgs() << " Remaining DecorateSet: {" << DecorateSet << "}\n");
assert(DecorateSet.empty());
spvdbgs() << " Remaining DecorateVec: {" << DecorateVec << "}\n");
assert(DecorateVec.empty());
return Group;
}

Expand Down
4 changes: 2 additions & 2 deletions test/LinkOnceODR.ll
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@

; CHECK-SPIRV: Capability Linkage
; CHECK-SPIRV: Extension "SPV_KHR_linkonce_odr"
; CHECK-SPIRV: Decorate {{[0-9]+}} LinkageAttributes "GV" LinkOnceODR
; CHECK-SPIRV: Decorate {{[0-9]+}} LinkageAttributes "square" LinkOnceODR
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} LinkageAttributes "GV" LinkOnceODR
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} LinkageAttributes "square" LinkOnceODR

; CHECK-SPIRV-NOEXT-NOT: Extension "SPV_KHR_linkonce_odr"
; CHECK-SPIRV-NOEXT-NOT: Decorate {{[0-9]+}} LinkageAttributes "GV" LinkOnceODR
Expand Down
34 changes: 17 additions & 17 deletions test/builtin_vars-decorate.ll
Original file line number Diff line number Diff line change
Expand Up @@ -26,23 +26,23 @@ target triple = "spir-unknown-unknown"
; CHECK: {{[0-9]+}} Name [[SI:[0-9]+]] "__spirv_BuiltInSubgroupId"
; CHECK: {{[0-9]+}} Name [[SLII:[0-9]+]] "__spirv_BuiltInSubgroupLocalInvocationId"

; CHECK: 4 Decorate [[NW]] BuiltIn 24
; CHECK: 4 Decorate [[WS]] BuiltIn 25
; CHECK: 4 Decorate [[WI]] BuiltIn 26
; CHECK: 4 Decorate [[LLI]] BuiltIn 27
; CHECK: 4 Decorate [[GII]] BuiltIn 28
; CHECK: 4 Decorate [[LLII]] BuiltIn 29
; CHECK: 4 Decorate [[WD]] BuiltIn 30
; CHECK: 4 Decorate [[GS]] BuiltIn 31
; CHECK: 4 Decorate [[EWS]] BuiltIn 32
; CHECK: 4 Decorate [[GO]] BuiltIn 33
; CHECK: 4 Decorate [[GLI]] BuiltIn 34
; CHECK: 4 Decorate [[SS]] BuiltIn 36
; CHECK: 4 Decorate [[SMS]] BuiltIn 37
; CHECK: 4 Decorate [[NS]] BuiltIn 38
; CHECK: 4 Decorate [[NES]] BuiltIn 39
; CHECK: 4 Decorate [[SI]] BuiltIn 40
; CHECK: 4 Decorate [[SLII]] BuiltIn 41
; CHECK-DAG: 4 Decorate [[NW]] BuiltIn 24
; CHECK-DAG: 4 Decorate [[WS]] BuiltIn 25
; CHECK-DAG: 4 Decorate [[WI]] BuiltIn 26
; CHECK-DAG: 4 Decorate [[LLI]] BuiltIn 27
; CHECK-DAG: 4 Decorate [[GII]] BuiltIn 28
; CHECK-DAG: 4 Decorate [[LLII]] BuiltIn 29
; CHECK-DAG: 4 Decorate [[WD]] BuiltIn 30
; CHECK-DAG: 4 Decorate [[GS]] BuiltIn 31
; CHECK-DAG: 4 Decorate [[EWS]] BuiltIn 32
; CHECK-DAG: 4 Decorate [[GO]] BuiltIn 33
; CHECK-DAG: 4 Decorate [[GLI]] BuiltIn 34
; CHECK-DAG: 4 Decorate [[SS]] BuiltIn 36
; CHECK-DAG: 4 Decorate [[SMS]] BuiltIn 37
; CHECK-DAG: 4 Decorate [[NS]] BuiltIn 38
; CHECK-DAG: 4 Decorate [[NES]] BuiltIn 39
; CHECK-DAG: 4 Decorate [[SI]] BuiltIn 40
; CHECK-DAG: 4 Decorate [[SLII]] BuiltIn 41
@__spirv_BuiltInWorkDim = external addrspace(1) global i32
@__spirv_BuiltInGlobalSize = external addrspace(1) global <3 x i32>
@__spirv_BuiltInGlobalInvocationId = external addrspace(1) global <3 x i32>
Expand Down
36 changes: 18 additions & 18 deletions test/float-controls-decorations.ll
Original file line number Diff line number Diff line change
Expand Up @@ -23,24 +23,24 @@ entry:
; CHECK-LLVM: "VCFloatControl"="48"
; CHECK-SPIRV: 3 Name [[#FOO_ID:]] "foo"
; CHECK-SPIRV: 3 Name [[#BAR_ID:]] "bar"
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 16 0
; CHECK-SPIRV-NEXT: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 16 1
; CHECK-SPIRV-NEXT: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 32 0
; CHECK-SPIRV-NEXT: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 32 1
; CHECK-SPIRV-NEXT: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 64 0
; CHECK-SPIRV-NEXT: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 64 1
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 16 1
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 16 1
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 32 1
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 32 1
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 64 1
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 64 1
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 16 0
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 16 0
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 32 0
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 32 0
; CHECK-SPIRV: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 64 0
; CHECK-SPIRV: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 64 0
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 16 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 16 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 32 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 32 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionRoundingModeINTEL 64 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionRoundingModeINTEL 64 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 16 1
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 16 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 32 1
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 32 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionDenormModeINTEL 64 1
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionDenormModeINTEL 64 1
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 16 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 16 0
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 32 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 32 0
; CHECK-SPIRV-DAG: 5 Decorate [[#FOO_ID]] FunctionFloatingPointModeINTEL 64 0
; CHECK-SPIRV-DAG: 5 Decorate [[#BAR_ID]] FunctionFloatingPointModeINTEL 64 0

attributes #0 = { "VCFloatControl"="0" "VCFunction" }
attributes #1 = { "VCFloatControl"="48" "VCFunction" }
Expand Down
6 changes: 3 additions & 3 deletions test/spirv_param_decorations.ll
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ entry:
ret void
}

; CHECK-SPIRV: Decorate [[PId1:[0-9]+]] Restrict
; CHECK-SPIRV: Decorate [[PId2:[0-9]+]] Volatile
; CHECK-SPIRV: Decorate [[PId1]] FPRoundingMode 2
; CHECK-SPIRV-DAG: Decorate [[PId1:[0-9]+]] Restrict
; CHECK-SPIRV-DAG: Decorate [[PId2:[0-9]+]] Volatile
; CHECK-SPIRV-DAG: Decorate [[PId1]] FPRoundingMode 2
; CHECK-SPIRV: FunctionParameter {{[0-9]+}} [[PId1]]
; CHECK-SPIRV: FunctionParameter {{[0-9]+}} [[PId2]]

Expand Down
4 changes: 2 additions & 2 deletions test/transcoding/DecorationMaxByteOffset.ll
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@

; CHECK-SPIRV: 3 Name [[PTR_ID:[0-9]+]] "ptr"
; CHECK-SPIRV: 4 Name [[PTR2_ID:[0-9]+]] "ptr2"
; CHECK-SPIRV: 4 Decorate [[PTR_ID]] MaxByteOffset 12
; CHECK-SPIRV: 4 Decorate [[PTR2_ID]] MaxByteOffset 123
; CHECK-SPIRV-DAG: 4 Decorate [[PTR_ID]] MaxByteOffset 12
; CHECK-SPIRV-DAG: 4 Decorate [[PTR2_ID]] MaxByteOffset 123
; CHECK-SPIRV: 4 TypeInt [[CHAR_T:[0-9]+]] 8 0
; CHECK-SPIRV: 4 TypePointer [[CHAR_PTR_T:[0-9]+]] 4 [[CHAR_T]]
; CHECK-SPIRV: 3 FunctionParameter [[CHAR_PTR_T]] [[PTR_ID]]
Expand Down
24 changes: 12 additions & 12 deletions test/transcoding/IntelFPGAMemoryAttributes.ll
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,18 @@

; CHECK-SPIRV: Capability FPGAMemoryAttributesINTEL
; CHECK-SPIRV: Extension "SPV_INTEL_fpga_memory_attributes"
; CHECK-SPIRV: Decorate {{[0-9]+}} MemoryINTEL "DEFAULT"
; CHECK-SPIRV: Decorate {{[0-9]+}} RegisterINTEL
; CHECK-SPIRV: Decorate {{[0-9]+}} MemoryINTEL "BLOCK_RAM"
; CHECK-SPIRV: Decorate {{[0-9]+}} NumbanksINTEL 2
; CHECK-SPIRV: Decorate {{[0-9]+}} NumbanksINTEL 4
; CHECK-SPIRV: Decorate {{[0-9]+}} BankwidthINTEL 8
; CHECK-SPIRV: Decorate {{[0-9]+}} MaxPrivateCopiesINTEL 4
; CHECK-SPIRV: Decorate {{[0-9]+}} SinglepumpINTEL
; CHECK-SPIRV: Decorate {{[0-9]+}} DoublepumpINTEL
; CHECK-SPIRV: Decorate {{[0-9]+}} MaxReplicatesINTEL 2
; CHECK-SPIRV: Decorate {{[0-9]+}} SimpleDualPortINTEL
; CHECK-SPIRV: Decorate {{[0-9]+}} MergeINTEL "foo" "depth"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MemoryINTEL "DEFAULT"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} RegisterINTEL
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MemoryINTEL "BLOCK_RAM"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NumbanksINTEL 2
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NumbanksINTEL 4
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} BankwidthINTEL 8
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MaxPrivateCopiesINTEL 4
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} SinglepumpINTEL
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} DoublepumpINTEL
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MaxReplicatesINTEL 2
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} SimpleDualPortINTEL
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MergeINTEL "foo" "depth"

target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir64-unknown-linux"
Expand Down
8 changes: 4 additions & 4 deletions test/transcoding/IntelFPGAMemoryAttributesForStaticVar.ll
Original file line number Diff line number Diff line change
Expand Up @@ -37,10 +37,10 @@

; CHECK-SPIRV: Capability FPGAMemoryAttributesINTEL
; CHECK-SPIRV: Extension "SPV_INTEL_fpga_memory_attributes"
; CHECK-SPIRV: Decorate {{[0-9]+}} UserSemantic "foobarbaz"
; CHECK-SPIRV: Decorate {{[0-9]+}} MemoryINTEL "DEFAULT"
; CHECK-SPIRV: Decorate {{[0-9]+}} MemoryINTEL "MLAB"
; CHECK-SPIRV: Decorate {{[0-9]+}} NumbanksINTEL 2
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} UserSemantic "foobarbaz"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MemoryINTEL "DEFAULT"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} MemoryINTEL "MLAB"
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NumbanksINTEL 2

target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir64-unknown-linux-sycldevice"
Expand Down
24 changes: 12 additions & 12 deletions test/transcoding/IntelFPGAMemoryAttributesForStruct.ll
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,18 @@

; CHECK-SPIRV: Capability FPGAMemoryAttributesINTEL
; CHECK-SPIRV: Extension "SPV_INTEL_fpga_memory_attributes"
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 1 RegisterINTEL
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 0 MemoryINTEL "DEFAULT"
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 3 MemoryINTEL "DEFAULT"
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 2 MemoryINTEL "MLAB"
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 0 NumbanksINTEL 4
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 3 BankwidthINTEL 8
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 4 MaxPrivateCopiesINTEL 4
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 5 SinglepumpINTEL
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 6 DoublepumpINTEL
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 8 MaxReplicatesINTEL 4
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 9 SimpleDualPortINTEL
; CHECK-SPIRV: MemberDecorate {{[0-9]+}} 7 MergeINTEL "foobar" "width"
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 1 RegisterINTEL
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 0 MemoryINTEL "DEFAULT"
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 3 MemoryINTEL "DEFAULT"
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 2 MemoryINTEL "MLAB"
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 0 NumbanksINTEL 4
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 3 BankwidthINTEL 8
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 4 MaxPrivateCopiesINTEL 4
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 5 SinglepumpINTEL
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 6 DoublepumpINTEL
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 8 MaxReplicatesINTEL 4
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 9 SimpleDualPortINTEL
; CHECK-SPIRV-DAG: MemberDecorate {{[0-9]+}} 7 MergeINTEL "foobar" "width"

target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir64-unknown-linux"
Expand Down
4 changes: 2 additions & 2 deletions test/transcoding/NoSignedUnsignedWrap.ll
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,8 @@
; RUN: llvm-dis < %t.rev.bc | FileCheck %s --check-prefix=CHECK-LLVM-NOEXT

; CHECK-SPIRV: Extension "SPV_KHR_no_integer_wrap_decoration"
; CHECK-SPIRV: Decorate {{[0-9]+}} NoSignedWrap
; CHECK-SPIRV: Decorate {{[0-9]+}} NoUnsignedWrap
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NoSignedWrap
; CHECK-SPIRV-DAG: Decorate {{[0-9]+}} NoUnsignedWrap
;
; CHECK-SPIRV-NOEXT-NOT: Extension "SPV_KHR_no_integer_wrap_decoration"
; CHECK-SPIRV-NOEXT-NOT: Decorate {{[0-9]+}} NoSignedWrap
Expand Down
Loading

0 comments on commit f3c9bb5

Please sign in to comment.