; RUN: llc < %s -march=x86 -asm-verbose=false | FileCheck %s -check-prefix=FP-ELIM ; RUN: llc < %s -march=x86 -asm-verbose=false -disable-fp-elim | FileCheck %s -check-prefix=NO-ELIM ; RUN: llc < %s -march=x86 -asm-verbose=false -disable-non-leaf-fp-elim | FileCheck %s -check-prefix=NON-LEAF ; Implement -momit-leaf-frame-pointer ; rdar://7886181 define i32 @t1() nounwind readnone { entry: ; FP-ELIM: t1: ; FP-ELIM-NEXT: movl ; FP-ELIM-NEXT: ret ; NO-ELIM: t1: ; NO-ELIM-NEXT: pushl %ebp ; NO-ELIM: popl %ebp ; NO-ELIM-NEXT: ret ; NON-LEAF: t1: ; NON-LEAF-NEXT: movl ; NON-LEAF-NEXT: ret ret i32 10 } define void @t2() nounwind { entry: ; FP-ELIM: t2: ; FP-ELIM-NOT: pushl %ebp ; FP-ELIM: ret ; NO-ELIM: t2: ; NO-ELIM-NEXT: pushl %ebp ; NO-ELIM: popl %ebp ; NO-ELIM-NEXT: ret ; NON-LEAF: t2: ; NON-LEAF-NEXT: pushl %ebp ; NON-LEAF: popl %ebp ; NON-LEAF-NEXT: ret tail call void @foo(i32 0) nounwind ret void } declare void @foo(i32)