1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin | FileCheck -check-prefix=CHECK-NO-FP %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin -disable-fp-elim | FileCheck -check-prefix=CHECK-FP %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-linux-gnu | FileCheck -check-prefix=LINUX-NO-FP %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-linux-gnu -disable-fp-elim | FileCheck -check-prefix=LINUX-FP %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Workerdefine void @func() { 7*9880d681SAndroid Build Coastguard Workerentry: 8*9880d681SAndroid Build Coastguard Worker unreachable 9*9880d681SAndroid Build Coastguard Worker} 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; MachO cannot handle an empty function. 12*9880d681SAndroid Build Coastguard Worker; CHECK-NO-FP: _func: 13*9880d681SAndroid Build Coastguard Worker; CHECK-NO-FP-NEXT: .cfi_startproc 14*9880d681SAndroid Build Coastguard Worker; CHECK-NO-FP: nop 15*9880d681SAndroid Build Coastguard Worker; CHECK-NO-FP-NEXT: .cfi_endproc 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker; CHECK-FP: _func: 18*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: .cfi_startproc 19*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: : 20*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: pushq %rbp 21*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: : 22*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: .cfi_def_cfa_offset 16 23*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: : 24*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: .cfi_offset %rbp, -16 25*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: movq %rsp, %rbp 26*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: : 27*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: .cfi_def_cfa_register %rbp 28*9880d681SAndroid Build Coastguard Worker; CHECK-FP-NEXT: .cfi_endproc 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker; An empty function is perfectly fine on ELF. 31*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP: func: 32*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP-NEXT: .cfi_startproc 33*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP-NEXT: {{^}}# 34*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP-NEXT: {{^}}.L{{.*}}:{{$}} 35*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP-NEXT: .size func, .L{{.*}}-func 36*9880d681SAndroid Build Coastguard Worker; LINUX-NO-FP-NEXT: .cfi_endproc 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker; A cfi directive can point to the end of a function. It (and in fact the 39*9880d681SAndroid Build Coastguard Worker; entire body) could be optimized out because of the unreachable, but we 40*9880d681SAndroid Build Coastguard Worker; don't do it right now. 41*9880d681SAndroid Build Coastguard Worker; LINUX-FP: func: 42*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .cfi_startproc 43*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: {{^}}# 44*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: pushq %rbp 45*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: {{^}}.L{{.*}}:{{$}} 46*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .cfi_def_cfa_offset 16 47*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: {{^}}.L{{.*}}:{{$}} 48*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .cfi_offset %rbp, -16 49*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: movq %rsp, %rbp 50*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT:{{^}}.L{{.*}}:{{$}} 51*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .cfi_def_cfa_register %rbp 52*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT:{{^}}.L{{.*}}:{{$}} 53*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .size func, .Lfunc_end0-func 54*9880d681SAndroid Build Coastguard Worker; LINUX-FP-NEXT: .cfi_endproc 55