mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Default-addressspace null pointers don't alias anything. This allows
GVN to be more aggressive. Patch by Hans Wennborg! (with a comment added by me) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@86582 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
980d494ab6
commit
f75ef668a7
@ -646,6 +646,15 @@ BasicAliasAnalysis::aliasCheck(const Value *V1, unsigned V1Size,
|
|||||||
const Value *O1 = V1->getUnderlyingObject();
|
const Value *O1 = V1->getUnderlyingObject();
|
||||||
const Value *O2 = V2->getUnderlyingObject();
|
const Value *O2 = V2->getUnderlyingObject();
|
||||||
|
|
||||||
|
// Null values in the default address space don't point to any object, so they
|
||||||
|
// don't alias any other pointer.
|
||||||
|
if (const ConstantPointerNull *CPN = dyn_cast<ConstantPointerNull>(O1))
|
||||||
|
if (CPN->getType()->getAddressSpace() == 0)
|
||||||
|
return NoAlias;
|
||||||
|
if (const ConstantPointerNull *CPN = dyn_cast<ConstantPointerNull>(O2))
|
||||||
|
if (CPN->getType()->getAddressSpace() == 0)
|
||||||
|
return NoAlias;
|
||||||
|
|
||||||
if (O1 != O2) {
|
if (O1 != O2) {
|
||||||
// If V1/V2 point to two different objects we know that we have no alias.
|
// If V1/V2 point to two different objects we know that we have no alias.
|
||||||
if (isIdentifiedObject(O1) && isIdentifiedObject(O2))
|
if (isIdentifiedObject(O1) && isIdentifiedObject(O2))
|
||||||
|
20
test/Transforms/GVN/null-aliases-nothing.ll
Normal file
20
test/Transforms/GVN/null-aliases-nothing.ll
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
; RUN: opt %s -gvn -S | FileCheck %s
|
||||||
|
|
||||||
|
%t = type { i32 }
|
||||||
|
declare void @test1f(i8*)
|
||||||
|
|
||||||
|
define void @test1(%t* noalias %stuff ) {
|
||||||
|
%p = getelementptr inbounds %t* %stuff, i32 0, i32 0
|
||||||
|
%before = load i32* %p
|
||||||
|
|
||||||
|
call void @test1f(i8* null)
|
||||||
|
|
||||||
|
%after = load i32* %p ; <--- This should be a dead load
|
||||||
|
%sum = add i32 %before, %after;
|
||||||
|
|
||||||
|
store i32 %sum, i32* %p
|
||||||
|
ret void
|
||||||
|
; CHECK: load
|
||||||
|
; CHECK-NOT: load
|
||||||
|
; CHECK: ret void
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user