[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / Assembler / 2007-12-11-AddressSpaces.ll
blob5155c6b8188a8e6cd3253f1e559e42d654936cc9
1 ; RUN: llvm-as < %s | llvm-dis | grep "addrspace(33)" | count 7
2 ; RUN: llvm-as < %s | llvm-dis | grep "addrspace(42)" | count 2
3 ; RUN: llvm-as < %s | llvm-dis | grep "addrspace(66)" | count 2
4 ; RUN: llvm-as < %s | llvm-dis | grep "addrspace(11)" | count 6
5 ; RUN: llvm-as < %s | llvm-dis | grep "addrspace(22)" | count 5
6 ; RUN: verify-uselistorder %s
8         %struct.mystruct = type { i32, i32 addrspace(33)*, i32, i32 addrspace(33)* }
9 @input = weak addrspace(42) global %struct.mystruct zeroinitializer             ; <%struct.mystruct addrspace(42)*> [#uses=1]
10 @output = addrspace(66) global %struct.mystruct zeroinitializer                 ; <%struct.mystruct addrspace(66)*> [#uses=1]
11 @y = external addrspace(33) global i32 addrspace(11)* addrspace(22)*            ; <i32 addrspace(11)* addrspace(22)* addrspace(33)*> [#uses=1]
13 define void @foo() {
14 entry:
15         %tmp1 = load i32 addrspace(33)*, i32 addrspace(33)* addrspace(42)* getelementptr (%struct.mystruct, %struct.mystruct addrspace(42)* @input, i32 0, i32 3), align 4              ; <i32 addrspace(33)*> [#uses=1]
16         store i32 addrspace(33)* %tmp1, i32 addrspace(33)* addrspace(66)* getelementptr (%struct.mystruct, %struct.mystruct addrspace(66)* @output, i32 0, i32 1), align 4
17         ret void
20 define i32 addrspace(11)* @bar(i32 addrspace(11)* addrspace(22)* addrspace(33)* %x) {
21 entry:
22         %tmp1 = load i32 addrspace(11)* addrspace(22)*, i32 addrspace(11)* addrspace(22)* addrspace(33)* @y, align 4            ; <i32 addrspace(11)* addrspace(22)*> [#uses=2]
23         store i32 addrspace(11)* addrspace(22)* %tmp1, i32 addrspace(11)* addrspace(22)* addrspace(33)* %x, align 4
24         %tmp5 = load i32 addrspace(11)*, i32 addrspace(11)* addrspace(22)* %tmp1, align 4               ; <i32 addrspace(11)*> [#uses=1]
25         ret i32 addrspace(11)* %tmp5