xref: /aosp_15_r20/external/clang/test/CodeGen/mozilla-ms-inline-asm.c (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // REQUIRES: x86-registered-target
2*67e74705SXin Li // RUN: %clang_cc1 %s -triple i386-apple-darwin10 -fasm-blocks -emit-llvm -o - | opt -strip -S | FileCheck %s
3*67e74705SXin Li 
4*67e74705SXin Li // Some test cases for MS inline asm support from Mozilla code base.
5*67e74705SXin Li 
invoke_copy_to_stack()6*67e74705SXin Li void invoke_copy_to_stack() {}
7*67e74705SXin Li 
invoke(void * that,unsigned methodIndex,unsigned paramCount,void * params)8*67e74705SXin Li void invoke(void* that, unsigned methodIndex,
9*67e74705SXin Li             unsigned paramCount, void* params)
10*67e74705SXin Li {
11*67e74705SXin Li // CHECK: @invoke
12*67e74705SXin Li // CHECK: %5 = alloca i8*, align 4
13*67e74705SXin Li // CHECK: %6 = alloca i32, align 4
14*67e74705SXin Li // CHECK: %7 = alloca i32, align 4
15*67e74705SXin Li // CHECK: %8 = alloca i8*, align 4
16*67e74705SXin Li // CHECK: store i8* %0, i8** %5, align 4
17*67e74705SXin Li // CHECK: store i32 %1, i32* %6, align 4
18*67e74705SXin Li // CHECK: store i32 %2, i32* %7, align 4
19*67e74705SXin Li // CHECK: store i8* %3, i8** %8, align 4
20*67e74705SXin Li // CHECK: call void asm sideeffect inteldialect
21*67e74705SXin Li // CHECK: mov edx,dword ptr $1
22*67e74705SXin Li // CHECK: test edx,edx
23*67e74705SXin Li // CHECK: jz {{[^_]*}}__MSASMLABEL_.0__noparams
24*67e74705SXin Li //             ^ Can't use {{.*}} here because the matching is greedy.
25*67e74705SXin Li // CHECK: mov eax,edx
26*67e74705SXin Li // CHECK: shl eax,$$3
27*67e74705SXin Li // CHECK: sub esp,eax
28*67e74705SXin Li // CHECK: mov ecx,esp
29*67e74705SXin Li // CHECK: push dword ptr $0
30*67e74705SXin Li // CHECK: call dword ptr $2
31*67e74705SXin Li // CHECK: {{.*}}__MSASMLABEL_.0__noparams:
32*67e74705SXin Li // CHECK: mov ecx,dword ptr $3
33*67e74705SXin Li // CHECK: push ecx
34*67e74705SXin Li // CHECK: mov edx,[ecx]
35*67e74705SXin Li // CHECK: mov eax,dword ptr $4
36*67e74705SXin Li // CHECK: call dword ptr[edx+eax*$$4]
37*67e74705SXin Li // CHECK: mov esp,ebp
38*67e74705SXin Li // CHECK: pop ebp
39*67e74705SXin Li // CHECK: ret
40*67e74705SXin Li // CHECK: "=*m,*m,*m,*m,*m,~{eax},~{ebp},~{ecx},~{edx},~{flags},~{esp},~{dirflag},~{fpsr},~{flags}"
41*67e74705SXin Li // CHECK: (i8** %8, i32* %7, void (...)* bitcast (void ()* @invoke_copy_to_stack to void (...)*), i8** %5, i32* %6)
42*67e74705SXin Li // CHECK: ret void
43*67e74705SXin Li     __asm {
44*67e74705SXin Li         mov     edx,paramCount
45*67e74705SXin Li         test    edx,edx
46*67e74705SXin Li         jz      noparams
47*67e74705SXin Li         mov     eax,edx
48*67e74705SXin Li         shl     eax,3
49*67e74705SXin Li         sub     esp,eax
50*67e74705SXin Li         mov     ecx,esp
51*67e74705SXin Li         push    params
52*67e74705SXin Li         call    invoke_copy_to_stack
53*67e74705SXin Li noparams:
54*67e74705SXin Li         mov     ecx,that
55*67e74705SXin Li         push    ecx
56*67e74705SXin Li         mov     edx,[ecx]
57*67e74705SXin Li         mov     eax,methodIndex
58*67e74705SXin Li         call    dword ptr[edx+eax*4]
59*67e74705SXin Li         mov     esp,ebp
60*67e74705SXin Li         pop     ebp
61*67e74705SXin Li         ret
62*67e74705SXin Li     }
63*67e74705SXin Li }
64*67e74705SXin Li 
65