forked from OSchip/llvm-project
54 lines
1.3 KiB
LLVM
54 lines
1.3 KiB
LLVM
; RUN: llc < %s -mtriple=i686-- -asm-verbose=false | FileCheck %s -check-prefixes=FP-ELIM,ANY
|
|
; RUN: llc < %s -mtriple=i686-- -asm-verbose=false -frame-pointer=all | FileCheck %s -check-prefixes=NO-ELIM,ANY
|
|
|
|
; Implement -momit-leaf-frame-pointer
|
|
; rdar://7886181
|
|
|
|
define i32 @t1() nounwind readnone {
|
|
entry:
|
|
; FP-ELIM-LABEL: t1:
|
|
; FP-ELIM-NEXT: movl
|
|
; FP-ELIM-NEXT: ret
|
|
|
|
; NO-ELIM-LABEL: t1:
|
|
; NO-ELIM-NEXT: pushl %ebp
|
|
; NO-ELIM: popl %ebp
|
|
; NO-ELIM-NEXT: ret
|
|
ret i32 10
|
|
}
|
|
|
|
define void @t2() nounwind {
|
|
entry:
|
|
; FP-ELIM-LABEL: t2:
|
|
; FP-ELIM-NOT: pushl %ebp
|
|
; FP-ELIM: ret
|
|
|
|
; NO-ELIM-LABEL: t2:
|
|
; NO-ELIM-NEXT: pushl %ebp
|
|
; NO-ELIM: popl %ebp
|
|
; NO-ELIM-NEXT: ret
|
|
tail call void @foo(i32 0) nounwind
|
|
ret void
|
|
}
|
|
|
|
; The local non-leaf attribute takes precendece over the command line flag.
|
|
define i32 @t3() "frame-pointer"="non-leaf" nounwind readnone {
|
|
entry:
|
|
; ANY-ELIM-LABEL: t3:
|
|
; ANY-ELIM-NEXT: movl
|
|
; ANY-ELIM-NEXT: ret
|
|
ret i32 10
|
|
}
|
|
|
|
define void @t4() "frame-pointer"="non-leaf" nounwind {
|
|
entry:
|
|
; ANY-ELIM-LABEL: t4:
|
|
; ANY-ELIM-NEXT: pushl %ebp
|
|
; ANY-ELIM: popl %ebp
|
|
; ANY-ELIM-NEXT: ret
|
|
tail call void @foo(i32 0) nounwind
|
|
ret void
|
|
}
|
|
|
|
declare void @foo(i32)
|