xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2009-12-01-EarlyClobberBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin -no-integrated-as | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; pr5391
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine void @t() nounwind ssp {
5*9880d681SAndroid Build Coastguard Workerentry:
6*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t:
7*9880d681SAndroid Build Coastguard Worker; CHECK: movl %ecx, %eax
8*9880d681SAndroid Build Coastguard Worker; CHECK: %eax = foo (%eax, %ecx)
9*9880d681SAndroid Build Coastguard Worker  %b = alloca i32                                 ; <i32*> [#uses=2]
10*9880d681SAndroid Build Coastguard Worker  %a = alloca i32                                 ; <i32*> [#uses=1]
11*9880d681SAndroid Build Coastguard Worker  %"alloca point" = bitcast i32 0 to i32          ; <i32> [#uses=0]
12*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %b, align 4                      ; <i32> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* %b, align 4                      ; <i32> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker  %asmtmp = call i32 asm "$0 = foo ($1, $2)", "=&{ax},%0,r,~{dirflag},~{fpsr},~{flags}"(i32 %0, i32 %1) nounwind ; <i32> [#uses=1]
15*9880d681SAndroid Build Coastguard Worker  store i32 %asmtmp, i32* %a
16*9880d681SAndroid Build Coastguard Worker  br label %return
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerreturn:                                           ; preds = %entry
19*9880d681SAndroid Build Coastguard Worker  ret void
20*9880d681SAndroid Build Coastguard Worker}
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard Workerdefine void @t2() nounwind ssp {
23*9880d681SAndroid Build Coastguard Workerentry:
24*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t2:
25*9880d681SAndroid Build Coastguard Worker; CHECK: movl
26*9880d681SAndroid Build Coastguard Worker; CHECK: [[D2:%e.x]] = foo
27*9880d681SAndroid Build Coastguard Worker; CHECK: ([[D2]],
28*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: [[D2]]
29*9880d681SAndroid Build Coastguard Worker; CHECK: )
30*9880d681SAndroid Build Coastguard Worker  %b = alloca i32                                 ; <i32*> [#uses=2]
31*9880d681SAndroid Build Coastguard Worker  %a = alloca i32                                 ; <i32*> [#uses=1]
32*9880d681SAndroid Build Coastguard Worker  %"alloca point" = bitcast i32 0 to i32          ; <i32> [#uses=0]
33*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %b, align 4                      ; <i32> [#uses=1]
34*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* %b, align 4                      ; <i32> [#uses=1]
35*9880d681SAndroid Build Coastguard Worker  %asmtmp = call i32 asm "$0 = foo ($1, $2)", "=&r,%0,r,~{dirflag},~{fpsr},~{flags}"(i32 %0, i32 %1) nounwind ; <i32> [#uses=1]
36*9880d681SAndroid Build Coastguard Worker  store i32 %asmtmp, i32* %a
37*9880d681SAndroid Build Coastguard Worker  br label %return
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workerreturn:                                           ; preds = %entry
40*9880d681SAndroid Build Coastguard Worker  ret void
41*9880d681SAndroid Build Coastguard Worker}
42