xref: /llvm-project/llvm/test/CodeGen/X86/ms-inline-asm-functions.ll (revision 6b996282cee3588e46b18c30957e71c964012e14)
1*6b996282SAlvin Wong;; Check that the generated memory references do not contain the `offset`
2*6b996282SAlvin Wong;; operator. Use `-no-integrated-as` to disable AsmParser formatting.
3*6b996282SAlvin Wong; RUN: llc -no-integrated-as -x86-asm-syntax=intel < %s | FileCheck %s
4*6b996282SAlvin Wong
5*6b996282SAlvin Wong;; This file was compiled from clang/test/CodeGen/ms-inline-asm-functions.c,
6*6b996282SAlvin Wong;; using the following command line:
7*6b996282SAlvin Wong;;
8*6b996282SAlvin Wong;; bin/clang -cc1 -internal-isystem lib/clang/17/include -nostdsysteminc \
9*6b996282SAlvin Wong;;           ../llvm-project/clang/test/CodeGen/ms-inline-asm-functions.c \
10*6b996282SAlvin Wong;;           -triple i386-pc-windows-msvc -fms-extensions -S -o out.ll
11*6b996282SAlvin Wong
12*6b996282SAlvin Wongsource_filename = "/llvm-project/clang/test/CodeGen/ms-inline-asm-functions.c"
13*6b996282SAlvin Wongtarget datalayout = "e-m:x-p:32:32-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32-a:0:32-S32"
14*6b996282SAlvin Wongtarget triple = "i386-pc-windows-msvc"
15*6b996282SAlvin Wong
16*6b996282SAlvin Wong@kptr = dso_local global ptr null, align 4
17*6b996282SAlvin Wong
18*6b996282SAlvin Wong; Function Attrs: noinline nounwind optnone
19*6b996282SAlvin Wongdefine dso_local i32 @foo() #0 {
20*6b996282SAlvin Wongentry:
21*6b996282SAlvin Wong  %r = alloca ptr, align 4
22*6b996282SAlvin Wong  %call = call ptr @gptr()
23*6b996282SAlvin Wong  store ptr %call, ptr %r, align 4
24*6b996282SAlvin Wong  %0 = call i32 asm sideeffect inteldialect "call ${1:P}\0A\09call $2\0A\09call ${3:P}\0A\09call $4", "={eax},*m,*m,*m,*m,~{dirflag},~{fpsr},~{flags}"(ptr elementtype(i32 (i32)) @k, ptr elementtype(ptr) %r, ptr elementtype(i32 (i32)) @kimport, ptr elementtype(ptr) @kptr) #3, !srcloc !4
25*6b996282SAlvin Wong  ; CHECK-LABEL: _foo:
26*6b996282SAlvin Wong  ; CHECK:      #APP
27*6b996282SAlvin Wong  ; CHECK-NEXT: .intel_syntax
28*6b996282SAlvin Wong  ; CHECK-NEXT: call _k
29*6b996282SAlvin Wong  ; CHECK-NEXT: call [e{{([a-z]{2})}}]
30*6b996282SAlvin Wong  ; CHECK-NEXT: call [e{{([a-z]{2})}}]
31*6b996282SAlvin Wong  ; CHECK-NEXT: call [_kptr]
32*6b996282SAlvin Wong  ; CHECK-NEXT: .att_syntax
33*6b996282SAlvin Wong  ; CHECK-NEXT: #NO_APP
34*6b996282SAlvin Wong  ret i32 %0
35*6b996282SAlvin Wong}
36*6b996282SAlvin Wong
37*6b996282SAlvin Wongdeclare dso_local ptr @gptr()
38*6b996282SAlvin Wong
39*6b996282SAlvin Wongdeclare dso_local i32 @k(i32 noundef)
40*6b996282SAlvin Wong
41*6b996282SAlvin Wongdeclare dllimport i32 @kimport(i32 noundef)
42*6b996282SAlvin Wong
43*6b996282SAlvin Wong; Function Attrs: noinline nounwind optnone
44*6b996282SAlvin Wongdefine dso_local i32 @bar() #0 {
45*6b996282SAlvin Wongentry:
46*6b996282SAlvin Wong  %0 = call i32 asm sideeffect inteldialect "jmp ${1:P}\0A\09ja ${2:P}\0A\09JAE ${3:P}\0A\09LOOP ${4:P}\0A\09loope ${5:P}\0A\09loopne ${6:P}", "={eax},*m,*m,*m,*m,*m,*m,~{dirflag},~{fpsr},~{flags}"(ptr elementtype(i32 (i32)) @k, ptr elementtype(i32 (i32)) @k, ptr elementtype(i32 (i32)) @k, ptr elementtype(i32 (i32)) @k, ptr elementtype(i32 (i32)) @k, ptr elementtype(i32 (i32)) @k) #3, !srcloc !5
47*6b996282SAlvin Wong  ; CHECK-LABEL: _bar:
48*6b996282SAlvin Wong  ; CHECK:      #APP
49*6b996282SAlvin Wong  ; CHECK-NEXT: .intel_syntax
50*6b996282SAlvin Wong  ; CHECK-NEXT: jmp _k
51*6b996282SAlvin Wong  ; CHECK-NEXT: ja [_k]
52*6b996282SAlvin Wong  ; CHECK-NEXT: JAE [_k]
53*6b996282SAlvin Wong  ; CHECK-NEXT: LOOP [_k]
54*6b996282SAlvin Wong  ; CHECK-NEXT: loope [_k]
55*6b996282SAlvin Wong  ; CHECK-NEXT: loopne [_k]
56*6b996282SAlvin Wong  ; CHECK-NEXT: .att_syntax
57*6b996282SAlvin Wong  ; CHECK-NEXT: #NO_APP
58*6b996282SAlvin Wong  ret i32 %0
59*6b996282SAlvin Wong}
60*6b996282SAlvin Wong
61*6b996282SAlvin Wong; Function Attrs: noinline nounwind optnone
62*6b996282SAlvin Wongdefine dso_local i32 @baz() #0 {
63*6b996282SAlvin Wongentry:
64*6b996282SAlvin Wong  %0 = call i32 asm sideeffect inteldialect "mov eax, $1\0A\09mov eax, $2", "=&{eax},*m,*m,~{dirflag},~{fpsr},~{flags}"(ptr elementtype(i32 (i32)) @k, ptr elementtype(ptr) @kptr) #3, !srcloc !6
65*6b996282SAlvin Wong  ; CHECK-LABEL: _baz:
66*6b996282SAlvin Wong  ; CHECK:      #APP
67*6b996282SAlvin Wong  ; CHECK-NEXT: .intel_syntax
68*6b996282SAlvin Wong  ; CHECK-NEXT: mov eax, [_k]
69*6b996282SAlvin Wong  ; CHECK-NEXT: mov eax, [_kptr]
70*6b996282SAlvin Wong  ; CHECK-NEXT: .att_syntax
71*6b996282SAlvin Wong  ; CHECK-NEXT: #NO_APP
72*6b996282SAlvin Wong  ret i32 %0
73*6b996282SAlvin Wong}
74*6b996282SAlvin Wong
75*6b996282SAlvin Wong; Function Attrs: naked noinline nounwind optnone
76*6b996282SAlvin Wongdefine dso_local void @naked() #2 {
77*6b996282SAlvin Wongentry:
78*6b996282SAlvin Wong  call void asm sideeffect inteldialect "pusha\0A\09call ${0:P}\0A\09popa\0A\09ret", "*m,~{eax},~{ebp},~{ebx},~{ecx},~{edi},~{edx},~{esi},~{esp},~{dirflag},~{fpsr},~{flags}"(ptr elementtype(i32 (i32)) @k) #3, !srcloc !7
79*6b996282SAlvin Wong  ; CHECK-LABEL: _naked:
80*6b996282SAlvin Wong  ; CHECK:      #APP
81*6b996282SAlvin Wong  ; CHECK-NEXT: .intel_syntax
82*6b996282SAlvin Wong  ; CHECK-NEXT: pusha
83*6b996282SAlvin Wong  ; CHECK-NEXT: call _k
84*6b996282SAlvin Wong  ; CHECK-NEXT: popa
85*6b996282SAlvin Wong  ; CHECK-NEXT: ret
86*6b996282SAlvin Wong  ; CHECK-NEXT: .att_syntax
87*6b996282SAlvin Wong  ; CHECK-NEXT: #NO_APP
88*6b996282SAlvin Wong  unreachable
89*6b996282SAlvin Wong}
90*6b996282SAlvin Wong
91*6b996282SAlvin Wongattributes #0 = { noinline nounwind optnone }
92*6b996282SAlvin Wongattributes #2 = { naked noinline nounwind optnone }
93*6b996282SAlvin Wongattributes #3 = { nounwind }
94*6b996282SAlvin Wong
95*6b996282SAlvin Wong!llvm.module.flags = !{!0, !1, !2}
96*6b996282SAlvin Wong!llvm.ident = !{!3}
97*6b996282SAlvin Wong
98*6b996282SAlvin Wong!0 = !{i32 1, !"NumRegisterParameters", i32 0}
99*6b996282SAlvin Wong!1 = !{i32 1, !"wchar_size", i32 2}
100*6b996282SAlvin Wong!2 = !{i32 1, !"MaxTLSAlign", i32 65536}
101*6b996282SAlvin Wong!3 = !{!"clang version 17.0.0"}
102*6b996282SAlvin Wong!4 = !{i64 528}
103*6b996282SAlvin Wong!5 = !{i64 892}
104*6b996282SAlvin Wong!6 = !{i64 1183}
105*6b996282SAlvin Wong!7 = !{i64 1451}
106