mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-27 15:57:30 +00:00
Analogous fix to memset and memcpy rewriting. Don't have a test case
contrived for these yet, as I spotted them by inspection and the test cases are a bit more tricky to phrase. llvm-svn: 164691
This commit is contained in:
parent
8638d35784
commit
190685f078
@ -2064,6 +2064,15 @@ private:
|
||||
// pointer to the new alloca.
|
||||
if (!isa<Constant>(II.getLength())) {
|
||||
II.setDest(getAdjustedAllocaPtr(IRB, II.getRawDest()->getType()));
|
||||
|
||||
Type *CstTy = II.getAlignmentCst()->getType();
|
||||
if (!NewAI.getAlignment())
|
||||
II.setAlignment(ConstantInt::get(CstTy, 0));
|
||||
else
|
||||
II.setAlignment(
|
||||
ConstantInt::get(CstTy, MinAlign(NewAI.getAlignment(),
|
||||
BeginOffset - NewAllocaBeginOffset)));
|
||||
|
||||
deleteIfTriviallyDead(OldPtr);
|
||||
return false;
|
||||
}
|
||||
@ -2187,6 +2196,13 @@ private:
|
||||
else
|
||||
II.setSource(getAdjustedAllocaPtr(IRB, II.getRawSource()->getType()));
|
||||
|
||||
Type *CstTy = II.getAlignmentCst()->getType();
|
||||
if (II.getAlignment() > 1)
|
||||
II.setAlignment(ConstantInt::get(
|
||||
CstTy, MinAlign(II.getAlignment(),
|
||||
MinAlign(NewAI.getAlignment(),
|
||||
BeginOffset - NewAllocaBeginOffset))));
|
||||
|
||||
DEBUG(dbgs() << " to: " << II << "\n");
|
||||
deleteIfTriviallyDead(OldOp);
|
||||
return false;
|
||||
|
Loading…
x
Reference in New Issue
Block a user