blob: caf17f9dbf7da00aa00f45c2ca49f6339982e0c2 [file] [log] [blame]
Simon Atanasyan737bec32018-02-07 12:36:33 +00001; RUN: llc -march=mips -relocation-model=pic < %s \
2; RUN: | FileCheck --check-prefixes=CHECK,EB %s
3; RUN: llc -march=mipsel -relocation-model=pic < %s \
4; RUN: | FileCheck --check-prefixes=CHECK,EL %s
Akira Hatanaka4c406e72011-06-21 00:40:49 +00005
Jack Carterb04e3572013-04-09 23:19:50 +00006; Simple memory
Akira Hatanaka4c406e72011-06-21 00:40:49 +00007@g1 = external global i32
8
9define i32 @f1(i32 %x) nounwind {
10entry:
Toma Tabacua23f13c2014-12-17 10:56:16 +000011; CHECK-LABEL: f1:
Akira Hatanaka4c406e72011-06-21 00:40:49 +000012; CHECK: #APP
Daniel Sandersc676f2a2015-03-24 15:19:14 +000013; CHECK: sw $4, [[OFFSET:[0-9]+]]($sp)
Akira Hatanaka4c406e72011-06-21 00:40:49 +000014; CHECK: #NO_APP
Akira Hatanaka763ab852012-05-12 03:25:16 +000015; CHECK: lw $[[T1:[0-9]+]], %got(g1)
Daniel Sandersc676f2a2015-03-24 15:19:14 +000016; CHECK: #APP
17; CHECK: lw $[[T3:[0-9]+]], [[OFFSET]]($sp)
18; CHECK: #NO_APP
Akira Hatanaka4c406e72011-06-21 00:40:49 +000019; CHECK: sw $[[T3]], 0($[[T1]])
20
21 %l1 = alloca i32, align 4
22 call void asm "sw $1, $0", "=*m,r"(i32* %l1, i32 %x) nounwind
23 %0 = call i32 asm "lw $0, $1", "=r,*m"(i32* %l1) nounwind
24 store i32 %0, i32* @g1, align 4
25 ret i32 %0
26}
27
Toma Tabacua23f13c2014-12-17 10:56:16 +000028; CHECK-LABEL: main:
Toma Tabacu83cd33c2014-12-18 13:03:51 +000029; "D": Second word of a double word. This works for any memory element
Jack Carterb6bcdfd2013-04-10 22:02:32 +000030; double or single.
Jack Carterb04e3572013-04-09 23:19:50 +000031; CHECK: #APP
Daniel Sanders6b667922015-11-16 14:19:32 +000032; CHECK: lw ${{[0-9]+}}, 16(${{[0-9]+}})
Toma Tabacua23f13c2014-12-17 10:56:16 +000033; CHECK: #NO_APP
Jack Carterb04e3572013-04-09 23:19:50 +000034
Toma Tabacu83cd33c2014-12-18 13:03:51 +000035; No "D": First word of a double word. This works for any memory element
Jack Carterb6bcdfd2013-04-10 22:02:32 +000036; double or single.
37; CHECK: #APP
Daniel Sanders6b667922015-11-16 14:19:32 +000038; CHECK: lw ${{[0-9]+}}, 12(${{[0-9]+}})
Toma Tabacua23f13c2014-12-17 10:56:16 +000039; CHECK: #NO_APP
Jack Carterb6bcdfd2013-04-10 22:02:32 +000040
Simon Atanasyan737bec32018-02-07 12:36:33 +000041; "M": High-order word of a double word.
42; CHECK: #APP
43; EB: lw ${{[0-9]+}}, 12(${{[0-9]+}})
44; EL: lw ${{[0-9]+}}, 16(${{[0-9]+}})
45; CHECK: #NO_APP
46
47; "L": Low-order word of a double word.
48; CHECK: #APP
49; EB: lw ${{[0-9]+}}, 16(${{[0-9]+}})
50; EL: lw ${{[0-9]+}}, 12(${{[0-9]+}})
51; CHECK: #NO_APP
52
Jack Carterb04e3572013-04-09 23:19:50 +000053@b = common global [20 x i32] zeroinitializer, align 4
54
Jack Carterb6bcdfd2013-04-10 22:02:32 +000055define void @main() {
Jack Carterb04e3572013-04-09 23:19:50 +000056entry:
Toma Tabacu83cd33c2014-12-18 13:03:51 +000057; Second word:
Daniel Sanders6b667922015-11-16 14:19:32 +000058 tail call void asm sideeffect " lw $0, ${1:D}", "r,*m,~{$11}"(i32 undef, i32* getelementptr inbounds ([20 x i32], [20 x i32]* @b, i32 0, i32 3))
Toma Tabacu83cd33c2014-12-18 13:03:51 +000059; First word. Notice, no 'D':
Daniel Sanders6b667922015-11-16 14:19:32 +000060 tail call void asm sideeffect " lw $0, ${1}", "r,*m,~{$11}"(i32 undef, i32* getelementptr inbounds ([20 x i32], [20 x i32]* @b, i32 0, i32 3))
Simon Atanasyan737bec32018-02-07 12:36:33 +000061
62; High-order part.
63 tail call void asm sideeffect " lw $0, ${1:M}", "r,*m,~{$11}"(i32 undef, i32* getelementptr inbounds ([20 x i32], [20 x i32]* @b, i32 0, i32 3))
64; Low-order part.
65 tail call void asm sideeffect " lw $0, ${1:L}", "r,*m,~{$11}"(i32 undef, i32* getelementptr inbounds ([20 x i32], [20 x i32]* @b, i32 0, i32 3))
Jack Carterb04e3572013-04-09 23:19:50 +000066 ret void
67}