mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-02 13:21:43 +00:00
Fix to support properly cleaning up failed address sinking against constants
As it turns out the source of the sunkaddr can be a constant, in which case there is not an instruction to delete, causing the cleanup code introduced in r204833 to crash. This patch adds a dynamic check to ensure the deleted value is in fact an instruction and not a constant. Patch by Louis Gerbarg <lgg@apple.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@205941 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6472a514dc
commit
31689680ec
@ -2459,8 +2459,9 @@ bool CodeGenPrepare::OptimizeMemoryInst(Instruction *MemoryInst, Value *Addr,
|
||||
// the original IR value was tossed in favor of a constant back when
|
||||
// the AddrMode was created we need to bail out gracefully if widths
|
||||
// do not match instead of extending it.
|
||||
if (Result != AddrMode.BaseReg)
|
||||
cast<Instruction>(Result)->eraseFromParent();
|
||||
Instruction *I = dyn_cast<Instruction>(Result);
|
||||
if (I && (Result != AddrMode.BaseReg))
|
||||
I->eraseFromParent();
|
||||
return false;
|
||||
}
|
||||
if (AddrMode.Scale != 1)
|
||||
|
Loading…
x
Reference in New Issue
Block a user