Add workaround for Cortex-M3 errata 602117 by replacing ldrd x, y, [x] with ldm or...
[oota-llvm.git] / test / Assembler / 2007-12-11-AddressSpaces.ll
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
7         %struct.mystruct = type { i32, i32 addrspace(33)*, i32, i32 addrspace(33)* }
8 @input = weak addrspace(42) global %struct.mystruct zeroinitializer             ; <%struct.mystruct addrspace(42)*> [#uses=1]
9 @output = addrspace(66) global %struct.mystruct zeroinitializer                 ; <%struct.mystruct addrspace(66)*> [#uses=1]
10 @y = external addrspace(33) global i32 addrspace(11)* addrspace(22)*            ; <i32 addrspace(11)* addrspace(22)* addrspace(33)*> [#uses=1]
11
12 define void @foo() {
13 entry:
14         %tmp1 = load i32 addrspace(33)* addrspace(42)* getelementptr (%struct.mystruct addrspace(42)* @input, i32 0, i32 3), align 4            ; <i32 addrspace(33)*> [#uses=1]
15         store i32 addrspace(33)* %tmp1, i32 addrspace(33)* addrspace(66)* getelementptr (%struct.mystruct addrspace(66)* @output, i32 0, i32 1), align 4
16         ret void
17 }
18
19 define i32 addrspace(11)* @bar(i32 addrspace(11)* addrspace(22)* addrspace(33)* %x) {
20 entry:
21         %tmp1 = load i32 addrspace(11)* addrspace(22)* addrspace(33)* @y, align 4               ; <i32 addrspace(11)* addrspace(22)*> [#uses=2]
22         store i32 addrspace(11)* addrspace(22)* %tmp1, i32 addrspace(11)* addrspace(22)* addrspace(33)* %x, align 4
23         %tmp5 = load i32 addrspace(11)* addrspace(22)* %tmp1, align 4           ; <i32 addrspace(11)*> [#uses=1]
24         ret i32 addrspace(11)* %tmp5
25 }