forked from OSchip/llvm-project
74 lines
1.4 KiB
ArmAsm
74 lines
1.4 KiB
ArmAsm
|
// RUN: llvm-mc -triple x86_64-apple-darwin -filetype=obj %s -o - | macho-dump | FileCheck %s
|
||
|
|
||
|
// We were trying to generate compact unwind info for assembly like this.
|
||
|
// The .cfi_def_cfa directive, however, throws a wrench into that and was
|
||
|
// causing an llvm_unreachable() failure. Make sure the assembler can handle
|
||
|
// the input. The actual eh_frames created using these directives are checked
|
||
|
// elsewhere. This test is a simpler "does the code assemble" check.
|
||
|
|
||
|
// rdar://15406518
|
||
|
|
||
|
.macro SaveRegisters
|
||
|
|
||
|
push %rbp
|
||
|
.cfi_def_cfa_offset 16
|
||
|
.cfi_offset rbp, -16
|
||
|
|
||
|
mov %rsp, %rbp
|
||
|
.cfi_def_cfa_register rbp
|
||
|
|
||
|
sub $$0x80+8, %rsp
|
||
|
|
||
|
movdqa %xmm0, -0x80(%rbp)
|
||
|
push %rax
|
||
|
movdqa %xmm1, -0x70(%rbp)
|
||
|
push %rdi
|
||
|
movdqa %xmm2, -0x60(%rbp)
|
||
|
push %rsi
|
||
|
movdqa %xmm3, -0x50(%rbp)
|
||
|
push %rdx
|
||
|
movdqa %xmm4, -0x40(%rbp)
|
||
|
push %rcx
|
||
|
movdqa %xmm5, -0x30(%rbp)
|
||
|
push %r8
|
||
|
movdqa %xmm6, -0x20(%rbp)
|
||
|
push %r9
|
||
|
movdqa %xmm7, -0x10(%rbp)
|
||
|
|
||
|
.endmacro
|
||
|
.macro RestoreRegisters
|
||
|
|
||
|
movdqa -0x80(%rbp), %xmm0
|
||
|
pop %r9
|
||
|
movdqa -0x70(%rbp), %xmm1
|
||
|
pop %r8
|
||
|
movdqa -0x60(%rbp), %xmm2
|
||
|
pop %rcx
|
||
|
movdqa -0x50(%rbp), %xmm3
|
||
|
pop %rdx
|
||
|
movdqa -0x40(%rbp), %xmm4
|
||
|
pop %rsi
|
||
|
movdqa -0x30(%rbp), %xmm5
|
||
|
pop %rdi
|
||
|
movdqa -0x20(%rbp), %xmm6
|
||
|
pop %rax
|
||
|
movdqa -0x10(%rbp), %xmm7
|
||
|
|
||
|
leave
|
||
|
.cfi_def_cfa rsp, 8
|
||
|
.cfi_same_value rbp
|
||
|
|
||
|
.endmacro
|
||
|
|
||
|
_foo:
|
||
|
.cfi_startproc
|
||
|
SaveRegisters
|
||
|
|
||
|
RestoreRegisters
|
||
|
ret
|
||
|
.cfi_endproc
|
||
|
|
||
|
|
||
|
|
||
|
// CHECK: 'section_name', '__eh_frame\x00
|