diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2020-07-31 21:43:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2020-07-31 21:43:56 +0000 | 
| commit | 590d96feea75246dee213cb528930df8f6234b87 (patch) | |
| tree | f39c096d4be3f8a2f8ccefe3715fa7ed7eabc632 /contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp | |
| parent | 5ffd83dbcc34f10e07f6d3e968ae6365869615f4 (diff) | |
| parent | 2cedf089162d7ff08af2fb09e4adea44608e7233 (diff) | |
Notes
Diffstat (limited to 'contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp')
| -rw-r--r-- | contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp | 36 | 
1 files changed, 5 insertions, 31 deletions
| diff --git a/contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp b/contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp index 4a7c84562dee..8ce488f35dd3 100644 --- a/contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp +++ b/contrib/llvm-project/clang/lib/CodeGen/CodeGenFunction.cpp @@ -2154,39 +2154,13 @@ void CodeGenFunction::emitAlignmentAssumption(llvm::Value *PtrValue,                                                SourceLocation AssumptionLoc,                                                llvm::Value *Alignment,                                                llvm::Value *OffsetValue) { -  if (Alignment->getType() != IntPtrTy) -    Alignment = -        Builder.CreateIntCast(Alignment, IntPtrTy, false, "casted.align"); -  if (OffsetValue && OffsetValue->getType() != IntPtrTy) -    OffsetValue = -        Builder.CreateIntCast(OffsetValue, IntPtrTy, true, "casted.offset"); -  llvm::Value *TheCheck = nullptr; +  llvm::Value *TheCheck; +  llvm::Instruction *Assumption = Builder.CreateAlignmentAssumption( +      CGM.getDataLayout(), PtrValue, Alignment, OffsetValue, &TheCheck);    if (SanOpts.has(SanitizerKind::Alignment)) { -    llvm::Value *PtrIntValue = -        Builder.CreatePtrToInt(PtrValue, IntPtrTy, "ptrint"); - -    if (OffsetValue) { -      bool IsOffsetZero = false; -      if (const auto *CI = dyn_cast<llvm::ConstantInt>(OffsetValue)) -        IsOffsetZero = CI->isZero(); - -      if (!IsOffsetZero) -        PtrIntValue = Builder.CreateSub(PtrIntValue, OffsetValue, "offsetptr"); -    } - -    llvm::Value *Zero = llvm::ConstantInt::get(IntPtrTy, 0); -    llvm::Value *Mask = -        Builder.CreateSub(Alignment, llvm::ConstantInt::get(IntPtrTy, 1)); -    llvm::Value *MaskedPtr = Builder.CreateAnd(PtrIntValue, Mask, "maskedptr"); -    TheCheck = Builder.CreateICmpEQ(MaskedPtr, Zero, "maskcond"); +    emitAlignmentAssumptionCheck(PtrValue, Ty, Loc, AssumptionLoc, Alignment, +                                 OffsetValue, TheCheck, Assumption);    } -  llvm::Instruction *Assumption = Builder.CreateAlignmentAssumption( -      CGM.getDataLayout(), PtrValue, Alignment, OffsetValue); - -  if (!SanOpts.has(SanitizerKind::Alignment)) -    return; -  emitAlignmentAssumptionCheck(PtrValue, Ty, Loc, AssumptionLoc, Alignment, -                               OffsetValue, TheCheck, Assumption);  }  void CodeGenFunction::emitAlignmentAssumption(llvm::Value *PtrValue, | 
