Skip to content

Commit

Permalink
[SPIR-V 1.1/1.2] SPIRVReader: Add SubgroupsPerWorkgroup(Id) (KhronosG…
Browse files Browse the repository at this point in the history
…roup#2916)

Add support for consuming the SubgroupsPerWorkgroup (SPIR-V 1.1) and
SubgroupsPerWorkgroupId (SPIR-V 1.2) execution modes.  Map both of
these to `spirv.ExecutionMode` named metadata.
  • Loading branch information
svenvh authored Dec 11, 2024
1 parent eb4cdb2 commit 98cd3e4
Show file tree
Hide file tree
Showing 4 changed files with 72 additions and 0 deletions.
19 changes: 19 additions & 0 deletions lib/SPIRV/SPIRVReader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4616,6 +4616,25 @@ bool SPIRVToLLVM::transMetadata() {
auto *SizeMD = ConstantAsMetadata::get(getInt32(M, -1));
F->setMetadata(kSPIR2MD::SubgroupSize, MDNode::get(*Context, SizeMD));
}
// Generate metadata for SubgroupsPerWorkgroup/SubgroupsPerWorkgroupId.
auto EmitSubgroupsPerWorkgroupMD = [this, F](SPIRVExecutionModeKind EMK,
uint64_t Value) {
NamedMDNode *ExecModeMD =
M->getOrInsertNamedMetadata(kSPIRVMD::ExecutionMode);
SmallVector<Metadata *, 2> OperandVec;
OperandVec.push_back(ConstantAsMetadata::get(F));
OperandVec.push_back(ConstantAsMetadata::get(getUInt32(M, EMK)));
OperandVec.push_back(ConstantAsMetadata::get(getUInt32(M, Value)));
ExecModeMD->addOperand(MDNode::get(*Context, OperandVec));
};
if (auto *EM = BF->getExecutionMode(ExecutionModeSubgroupsPerWorkgroup)) {
EmitSubgroupsPerWorkgroupMD(EM->getExecutionMode(), EM->getLiterals()[0]);
} else if (auto *EM = BF->getExecutionModeId(
ExecutionModeSubgroupsPerWorkgroupId)) {
if (auto Val = transIdAsConstant(EM->getLiterals()[0])) {
EmitSubgroupsPerWorkgroupMD(EM->getExecutionMode(), *Val);
}
}
// Generate metadata for max_work_group_size
if (auto *EM = BF->getExecutionMode(ExecutionModeMaxWorkgroupSizeINTEL)) {
F->setMetadata(kSPIR2MD::MaxWGSize,
Expand Down
2 changes: 2 additions & 0 deletions lib/SPIRV/libSPIRV/SPIRVEntry.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -677,6 +677,8 @@ void SPIRVExecutionMode::decode(std::istream &I) {
case ExecutionModeSharedLocalMemorySizeINTEL:
case ExecutionModeNamedBarrierCountINTEL:
case ExecutionModeSubgroupSize:
case ExecutionModeSubgroupsPerWorkgroup:
case ExecutionModeSubgroupsPerWorkgroupId:
case ExecutionModeMaxWorkDimINTEL:
case ExecutionModeNumSIMDWorkitemsINTEL:
case ExecutionModeSchedulerTargetFmaxMhzINTEL:
Expand Down
24 changes: 24 additions & 0 deletions test/SubgroupsPerWorkgroup.spvasm
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
; REQUIRES: spirv-as

; RUN: spirv-as %s --target-env spv1.2 -o %t.spv
; RUN: spirv-val %t.spv
; RUN: llvm-spirv -r -o %t.rev.bc %t.spv
; RUN: llvm-dis %t.rev.bc -o - | FileCheck %s

OpCapability Addresses
OpCapability Linkage
OpCapability Kernel
OpCapability SubgroupDispatch
OpMemoryModel Physical64 OpenCL
OpEntryPoint Kernel %fn "testSubgroupsPerWorkgroup"
OpExecutionMode %fn SubgroupsPerWorkgroup 8
%void = OpTypeVoid
%fnTy = OpTypeFunction %void

; CHECK: !spirv.ExecutionMode = !{![[MD:[0-9]+]]}
; CHECK: ![[MD]] = !{ptr @testSubgroupsPerWorkgroup, i32 36, i32 8}

%fn = OpFunction %void None %fnTy
%entry = OpLabel
OpReturn
OpFunctionEnd
27 changes: 27 additions & 0 deletions test/SubgroupsPerWorkgroupId.spvasm
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
; REQUIRES: spirv-as

; RUN: spirv-as %s --target-env spv1.2 -o %t.spv
; RUN: spirv-val %t.spv
; RUN: llvm-spirv -r -o %t.rev.bc %t.spv
; RUN: llvm-dis %t.rev.bc -o - | FileCheck %s

OpCapability Addresses
OpCapability Linkage
OpCapability Kernel
OpCapability SubgroupDispatch
OpMemoryModel Physical64 OpenCL
OpEntryPoint Kernel %fn "testSubgroupsPerWorkgroupId"
OpExecutionModeId %fn SubgroupsPerWorkgroupId %uint_8
%void = OpTypeVoid
%uint = OpTypeInt 32 0
%uint_4 = OpConstant %uint 4
%uint_8 = OpSpecConstantOp %uint IAdd %uint_4 %uint_4
%fnTy = OpTypeFunction %void

; CHECK: !spirv.ExecutionMode = !{![[MD:[0-9]+]]}
; CHECK: ![[MD]] = !{ptr @testSubgroupsPerWorkgroupId, i32 37, i32 8}

%fn = OpFunction %void None %fnTy
%entry = OpLabel
OpReturn
OpFunctionEnd

0 comments on commit 98cd3e4

Please sign in to comment.