diff options
Diffstat (limited to 'llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp')
| -rw-r--r-- | llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp | 7 | 
1 files changed, 5 insertions, 2 deletions
| diff --git a/llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp b/llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp index 36dcc699d4e..e40f3955774 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUPromoteAlloca.cpp @@ -397,14 +397,17 @@ static Value* GEPToVectorIndex(GetElementPtrInst *GEP) {  // instructions.  static bool canVectorizeInst(Instruction *Inst, User *User) {    switch (Inst->getOpcode()) { -  case Instruction::Load: +  case Instruction::Load: { +    LoadInst *LI = cast<LoadInst>(Inst); +    return !LI->isVolatile(); +  }    case Instruction::BitCast:    case Instruction::AddrSpaceCast:      return true;    case Instruction::Store: {      // Must be the stored pointer operand, not a stored value.      StoreInst *SI = cast<StoreInst>(Inst); -    return SI->getPointerOperand() == User; +    return (SI->getPointerOperand() == User) && !SI->isVolatile();    }    default:      return false; | 

