1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -asm-verbose=false | FileCheck %s -check-prefix=FP-ELIM 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -asm-verbose=false -disable-fp-elim | FileCheck %s -check-prefix=NO-ELIM 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; Implement -momit-leaf-frame-pointer 5*9880d681SAndroid Build Coastguard Worker; rdar://7886181 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workerdefine i32 @t1() nounwind readnone { 8*9880d681SAndroid Build Coastguard Workerentry: 9*9880d681SAndroid Build Coastguard Worker; FP-ELIM-LABEL: t1: 10*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: movl 11*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: ret 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; NO-ELIM-LABEL: t1: 14*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: pushl %ebp 15*9880d681SAndroid Build Coastguard Worker; NO-ELIM: popl %ebp 16*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: ret 17*9880d681SAndroid Build Coastguard Worker ret i32 10 18*9880d681SAndroid Build Coastguard Worker} 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Workerdefine void @t2() nounwind { 21*9880d681SAndroid Build Coastguard Workerentry: 22*9880d681SAndroid Build Coastguard Worker; FP-ELIM-LABEL: t2: 23*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NOT: pushl %ebp 24*9880d681SAndroid Build Coastguard Worker; FP-ELIM: ret 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker; NO-ELIM-LABEL: t2: 27*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: pushl %ebp 28*9880d681SAndroid Build Coastguard Worker; NO-ELIM: popl %ebp 29*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: ret 30*9880d681SAndroid Build Coastguard Worker tail call void @foo(i32 0) nounwind 31*9880d681SAndroid Build Coastguard Worker ret void 32*9880d681SAndroid Build Coastguard Worker} 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Workerdefine i32 @t3() "no-frame-pointer-elim-non-leaf" nounwind readnone { 35*9880d681SAndroid Build Coastguard Workerentry: 36*9880d681SAndroid Build Coastguard Worker; FP-ELIM-LABEL: t3: 37*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: movl 38*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: ret 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Worker; NO-ELIM-LABEL: t3: 41*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: pushl %ebp 42*9880d681SAndroid Build Coastguard Worker; NO-ELIM: popl %ebp 43*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: ret 44*9880d681SAndroid Build Coastguard Worker ret i32 10 45*9880d681SAndroid Build Coastguard Worker} 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Workerdefine void @t4() "no-frame-pointer-elim-non-leaf" nounwind { 48*9880d681SAndroid Build Coastguard Workerentry: 49*9880d681SAndroid Build Coastguard Worker; FP-ELIM-LABEL: t4: 50*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: pushl %ebp 51*9880d681SAndroid Build Coastguard Worker; FP-ELIM: popl %ebp 52*9880d681SAndroid Build Coastguard Worker; FP-ELIM-NEXT: ret 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Worker; NO-ELIM-LABEL: t4: 55*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: pushl %ebp 56*9880d681SAndroid Build Coastguard Worker; NO-ELIM: popl %ebp 57*9880d681SAndroid Build Coastguard Worker; NO-ELIM-NEXT: ret 58*9880d681SAndroid Build Coastguard Worker tail call void @foo(i32 0) nounwind 59*9880d681SAndroid Build Coastguard Worker ret void 60*9880d681SAndroid Build Coastguard Worker} 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Workerdeclare void @foo(i32) 63