This should always be signed chars, so use int8_t. This fixes a miscompile when
[llvm/stm8.git] / test / CodeGen / X86 / apm.ll
blobb514cf6427d5332c5a16b2c4684cf96cddd5a17f
1 ; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s
2 ; RUN: llc < %s -mtriple=x86_64-win32 | FileCheck %s -check-prefix=WIN64
3 ; PR8573
5 ; CHECK: foo:
6 ; CHECK: leaq    (%rdi), %rax
7 ; CHECK-NEXT: movl    %esi, %ecx
8 ; CHECK-NEXT: monitor
9 ; WIN64: foo:
10 ; WIN64:      leaq    (%rcx), %rax
11 ; WIN64-NEXT: movl    %edx, %ecx
12 ; WIN64-NEXT: movl    %r8d, %edx
13 ; WIN64-NEXT: monitor
14 define void @foo(i8* %P, i32 %E, i32 %H) nounwind {
15 entry:
16   tail call void @llvm.x86.sse3.monitor(i8* %P, i32 %E, i32 %H)
17   ret void
20 declare void @llvm.x86.sse3.monitor(i8*, i32, i32) nounwind
22 ; CHECK: bar:
23 ; CHECK: movl    %edi, %ecx
24 ; CHECK-NEXT: movl    %esi, %eax
25 ; CHECK-NEXT: mwait
26 ; WIN64: bar:
27 ; WIN64:      movl    %edx, %eax
28 ; WIN64-NEXT: mwait
29 define void @bar(i32 %E, i32 %H) nounwind {
30 entry:
31   tail call void @llvm.x86.sse3.mwait(i32 %E, i32 %H)
32   ret void
35 declare void @llvm.x86.sse3.mwait(i32, i32) nounwind