diff options
author | Farzon Lotfi <1802579+farzonl@users.noreply.github.com> | 2024-09-26 17:16:29 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-26 17:16:29 -0400 |
commit | 324bdd662dedfd03b884e082f577a8ad6dc1f8a6 (patch) | |
tree | 26423c8da1e9b293e2341d8b3fc4738e199cbcc5 /llvm/lib/Target/DirectX/DirectXTargetMachine.cpp | |
parent | d1297638a381c4c7da93af4cd48173f4cef4252d (diff) | |
download | llvm-324bdd662dedfd03b884e082f577a8ad6dc1f8a6.zip llvm-324bdd662dedfd03b884e082f577a8ad6dc1f8a6.tar.gz llvm-324bdd662dedfd03b884e082f577a8ad6dc1f8a6.tar.bz2 |
[DirectX] Data Scalarization of Vectors in Global Scope (#110029)
This change adds a pass to scalarize vectors in global scope into
arrays.
There are three distinct parts
1. find the globals that need to be updated and define what the new type
should be
2. initialize that new type and copy over all the right attributes over
from the old type.
3. Use the instruction visitor pattern to update the loads, stores, and
geps for the layout of the new data structure.
resolves https://github.com/llvm/llvm-project/issues/107920
Diffstat (limited to 'llvm/lib/Target/DirectX/DirectXTargetMachine.cpp')
-rw-r--r-- | llvm/lib/Target/DirectX/DirectXTargetMachine.cpp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/llvm/lib/Target/DirectX/DirectXTargetMachine.cpp b/llvm/lib/Target/DirectX/DirectXTargetMachine.cpp index 606022a9..f358215 100644 --- a/llvm/lib/Target/DirectX/DirectXTargetMachine.cpp +++ b/llvm/lib/Target/DirectX/DirectXTargetMachine.cpp @@ -46,6 +46,7 @@ extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeDirectXTarget() { RegisterTargetMachine<DirectXTargetMachine> X(getTheDirectXTarget()); auto *PR = PassRegistry::getPassRegistry(); initializeDXILIntrinsicExpansionLegacyPass(*PR); + initializeDXILDataScalarizationLegacyPass(*PR); initializeScalarizerLegacyPassPass(*PR); initializeDXILPrepareModulePass(*PR); initializeEmbedDXILPassPass(*PR); @@ -86,6 +87,7 @@ public: FunctionPass *createTargetRegisterAllocator(bool) override { return nullptr; } void addCodeGenPrepare() override { addPass(createDXILIntrinsicExpansionLegacyPass()); + addPass(createDXILDataScalarizationLegacyPass()); ScalarizerPassOptions DxilScalarOptions; DxilScalarOptions.ScalarizeLoadStore = true; addPass(createScalarizerPass(DxilScalarOptions)); |