diff --git a/llvm/lib/Transforms/Utils/GlobalStatus.cpp b/llvm/lib/Transforms/Utils/GlobalStatus.cpp --- a/llvm/lib/Transforms/Utils/GlobalStatus.cpp +++ b/llvm/lib/Transforms/Utils/GlobalStatus.cpp @@ -136,7 +136,8 @@ GS.StoredType = GlobalStatus::Stored; } } - } else if (isa(I) || isa(I)) { + } else if (isa(I) || isa(I) || + isa(I)) { // Skip over bitcasts and GEPs; we don't care about the type or offset // of the pointer. if (analyzeGlobalAux(I, GS, VisitedUsers)) diff --git a/llvm/test/Transforms/GlobalOpt/unnamed-addr.ll b/llvm/test/Transforms/GlobalOpt/unnamed-addr.ll --- a/llvm/test/Transforms/GlobalOpt/unnamed-addr.ll +++ b/llvm/test/Transforms/GlobalOpt/unnamed-addr.ll @@ -5,12 +5,14 @@ @c = internal global i32 0, align 4 @d = internal constant [4 x i8] c"foo\00", align 1 @e = linkonce_odr global i32 0 +@f = internal addrspace(3) global float undef, align 4 ; CHECK: @a = internal global i32 0, align 4 ; CHECK: @b = internal global i32 0, align 4 ; CHECK: @c = internal unnamed_addr global i32 0, align 4 ; CHECK: @d = internal unnamed_addr constant [4 x i8] c"foo\00", align 1 ; CHECK: @e = linkonce_odr local_unnamed_addr global i32 0 +; CHECK: @f = internal unnamed_addr addrspace(3) global float undef, align 4 ; CHECK: define internal fastcc void @used_internal() unnamed_addr { define internal void @used_internal() { @@ -72,3 +74,15 @@ %tmp1 = load i32, i32* @c, align 4 ret i32 %tmp1 } + +define float @use_addrspace_cast_for_load() { + %p = addrspacecast float addrspace(3)* @f to float* + %v = load float, float* %p + ret float %v +} + +define void @use_addrspace_cast_for_store(float %x) { + %p = addrspacecast float addrspace(3)* @f to float* + store float %x, float* %p + ret void +}