;RUN: llc < %s -march=amdgcn -mtriple=amdgcn---amdgiz -verify-machineinstrs | FileCheck -check-prefixes=CHECK,GCN %s ;RUN: llc < %s -march=r600 -mtriple=r600---amdgiz -verify-machineinstrs | FileCheck -check-prefixes=CHECK,R600 %s %struct.S = type { i32 addrspace(5)*, i32 addrspace(1)*, i32 addrspace(4)*, i32 addrspace(3)*, i32*, i32 addrspace(2)*} ; CHECK-LABEL: nullptr_priv: ; CHECK-NEXT: .long 0 @nullptr_priv = global i32 addrspace(5)* addrspacecast (i32* null to i32 addrspace(5)*) ; CHECK-LABEL: nullptr_glob: ; GCN-NEXT: .quad 0 ; R600-NEXT: .long 0 @nullptr_glob = global i32 addrspace(1)* addrspacecast (i32* null to i32 addrspace(1)*) ; CHECK-LABEL: nullptr_const: ; GCN-NEXT: .quad 0 ; R600-NEXT: .long 0 @nullptr_const = global i32 addrspace(4)* addrspacecast (i32* null to i32 addrspace(4)*) ; CHECK-LABEL: nullptr_local: ; CHECK-NEXT: .long -1 @nullptr_local = global i32 addrspace(3)* addrspacecast (i32* null to i32 addrspace(3)*) ; CHECK-LABEL: nullptr_region: ; CHECK-NEXT: .long -1 @nullptr_region = global i32 addrspace(2)* addrspacecast (i32* null to i32 addrspace(2)*) ; CHECK-LABEL: nullptr6: ; R600-NEXT: .long 0 @nullptr6 = global i32 addrspace(6)* addrspacecast (i32* null to i32 addrspace(6)*) ; CHECK-LABEL: nullptr7: ; R600-NEXT: .long 0 @nullptr7 = global i32 addrspace(7)* addrspacecast (i32* null to i32 addrspace(7)*) ; CHECK-LABEL: nullptr8: ; R600-NEXT: .long 0 @nullptr8 = global i32 addrspace(8)* addrspacecast (i32* null to i32 addrspace(8)*) ; CHECK-LABEL: nullptr9: ; R600-NEXT: .long 0 @nullptr9 = global i32 addrspace(9)* addrspacecast (i32* null to i32 addrspace(9)*) ; CHECK-LABEL: nullptr10: ; R600-NEXT: .long 0 @nullptr10 = global i32 addrspace(10)* addrspacecast (i32* null to i32 addrspace(10)*) ; CHECK-LABEL: nullptr11: ; R600-NEXT: .long 0 @nullptr11 = global i32 addrspace(11)* addrspacecast (i32* null to i32 addrspace(11)*) ; CHECK-LABEL: nullptr12: ; R600-NEXT: .long 0 @nullptr12 = global i32 addrspace(12)* addrspacecast (i32* null to i32 addrspace(12)*) ; CHECK-LABEL: nullptr13: ; R600-NEXT: .long 0 @nullptr13 = global i32 addrspace(13)* addrspacecast (i32* null to i32 addrspace(13)*) ; CHECK-LABEL: nullptr14: ; R600-NEXT: .long 0 @nullptr14 = global i32 addrspace(14)* addrspacecast (i32* null to i32 addrspace(14)*) ; CHECK-LABEL: nullptr15: ; R600-NEXT: .long 0 @nullptr15 = global i32 addrspace(15)* addrspacecast (i32* null to i32 addrspace(15)*) ; CHECK-LABEL: nullptr16: ; R600-NEXT: .long 0 @nullptr16 = global i32 addrspace(16)* addrspacecast (i32* null to i32 addrspace(16)*) ; CHECK-LABEL: nullptr17: ; R600-NEXT: .long 0 @nullptr17 = global i32 addrspace(17)* addrspacecast (i32* null to i32 addrspace(17)*) ; CHECK-LABEL: nullptr18: ; R600-NEXT: .long 0 @nullptr18 = global i32 addrspace(18)* addrspacecast (i32* null to i32 addrspace(18)*) ; CHECK-LABEL: nullptr19: ; R600-NEXT: .long 0 @nullptr19 = global i32 addrspace(19)* addrspacecast (i32* null to i32 addrspace(19)*) ; CHECK-LABEL: nullptr20: ; R600-NEXT: .long 0 @nullptr20 = global i32 addrspace(20)* addrspacecast (i32* null to i32 addrspace(20)*) ; CHECK-LABEL: nullptr21: ; R600-NEXT: .long 0 @nullptr21 = global i32 addrspace(21)* addrspacecast (i32* null to i32 addrspace(21)*) ; CHECK-LABEL: nullptr22: ; R600-NEXT: .long 0 @nullptr22 = global i32 addrspace(22)* addrspacecast (i32* null to i32 addrspace(22)*) ; CHECK-LABEL: nullptr23: ; R600-NEXT: .long 0 @nullptr23 = global i32 addrspace(23)* addrspacecast (i32* null to i32 addrspace(23)*) ; CHECK-LABEL: structWithPointers: ; CHECK-NEXT: .long 0 ; GCN-NEXT: .zero 4 ; GCN-NEXT: .quad 0 ; R600-NEXT: .long 0 ; GCN-NEXT: .quad 0 ; R600-NEXT: .long 0 ; CHECK-NEXT: .long -1 ; GCN-NEXT: .zero 4 ; GCN-NEXT: .quad 0 ; R600-NEXT: .long 0 ; CHECK-NEXT: .long -1 ; GCN-NEXT: .zero 4 @structWithPointers = addrspace(1) global %struct.S { i32 addrspace(5)* addrspacecast (i32* null to i32 addrspace(5)*), i32 addrspace(1)* addrspacecast (i32* null to i32 addrspace(1)*), i32 addrspace(4)* addrspacecast (i32* null to i32 addrspace(4)*), i32 addrspace(3)* addrspacecast (i32* null to i32 addrspace(3)*), i32* null, i32 addrspace(2)* addrspacecast (i32* null to i32 addrspace(2)*)}, align 4