From ffcb1030f72af757fc03aa395e19b976d6405126 Mon Sep 17 00:00:00 2001 From: Yong He Date: Tue, 3 Dec 2024 15:52:02 -0800 Subject: Add intrinsics for aligned load/store. (#5736) * Add intrinsics for aligned load/store. * Fix. * Update comment. * Implement aligned load/store as intrinsic_op. * Fix. * Add proposal doc. * fix typo. --- source/slang/slang-emit-spirv.cpp | 30 ++++++++++++++++++++++-------- 1 file changed, 22 insertions(+), 8 deletions(-) (limited to 'source/slang/slang-emit-spirv.cpp') diff --git a/source/slang/slang-emit-spirv.cpp b/source/slang/slang-emit-spirv.cpp index 90d0db5d7..b0da7e4a6 100644 --- a/source/slang/slang-emit-spirv.cpp +++ b/source/slang/slang-emit-spirv.cpp @@ -5975,10 +5975,17 @@ struct SPIRVEmitContext : public SourceEmitterBase, public SPIRVEmitSharedContex SpvStorageClassPhysicalStorageBuffer) { IRSizeAndAlignment sizeAndAlignment; - getNaturalSizeAndAlignment( - m_targetProgram->getOptionSet(), - ptrType->getValueType(), - &sizeAndAlignment); + if (auto alignedAttr = inst->findAttr()) + { + sizeAndAlignment.alignment = (int)getIntVal(alignedAttr->getAlignment()); + } + else + { + getNaturalSizeAndAlignment( + m_targetProgram->getOptionSet(), + ptrType->getValueType(), + &sizeAndAlignment); + } return emitOpLoadAligned( parent, inst, @@ -5999,10 +6006,17 @@ struct SPIRVEmitContext : public SourceEmitterBase, public SPIRVEmitSharedContex SpvStorageClassPhysicalStorageBuffer) { IRSizeAndAlignment sizeAndAlignment; - getNaturalSizeAndAlignment( - m_targetProgram->getOptionSet(), - ptrType->getValueType(), - &sizeAndAlignment); + if (auto alignedAttr = inst->findAttr()) + { + sizeAndAlignment.alignment = (int)getIntVal(alignedAttr->getAlignment()); + } + else + { + getNaturalSizeAndAlignment( + m_targetProgram->getOptionSet(), + ptrType->getValueType(), + &sizeAndAlignment); + } return emitOpStoreAligned( parent, inst, -- cgit v1.2.3