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