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