diff options
Diffstat (limited to 'llvm/lib/Target/R600/AMDGPUTargetMachine.cpp')
| -rw-r--r-- | llvm/lib/Target/R600/AMDGPUTargetMachine.cpp | 11 | 
1 files changed, 11 insertions, 0 deletions
| diff --git a/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp b/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp index c95a9410ff6..1b4fe832f20 100644 --- a/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp +++ b/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp @@ -148,6 +148,17 @@ bool AMDGPUPassConfig::addPreRegAlloc() {      // SIFixSGPRCopies can generate a lot of duplicate instructions,      // so we need to run MachineCSE afterwards.      addPass(&MachineCSEID); + +    if (getOptLevel() > CodeGenOpt::None && ST.loadStoreOptEnabled()) { +      // Don't do this with no optimizations since it throws away debug info by +      // merging nonadjacent loads. + +      // This should be run after scheduling, but before register allocation. It +      // also need extra copies to the address operand to be eliminated. +      initializeSILoadStoreOptimizerPass(*PassRegistry::getPassRegistry()); +      insertPass(&MachineSchedulerID, &SILoadStoreOptimizerID); +    } +      addPass(createSIShrinkInstructionsPass());      addPass(createSIFixSGPRLiveRangesPass());    } | 

