mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-27 13:30:05 +00:00
c24a374331
This commit implements the AsmParser for fnstart, fnend, cantunwind, personality, handlerdata, pad, setfp, save, and vsave directives. This commit fixes some minor issue in the ARMELFStreamer: * The switch back to corresponding section after the .fnend directive. * Emit the unwind opcode while processing .fnend directive if there is no .handlerdata directive. * Emit the unwind opcode to .ARM.extab while processing .handlerdata even if .personality directive does not exist. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@181603 91177308-0d34-0410-b5e6-96231b3b80d8
42 lines
1.1 KiB
ArmAsm
42 lines
1.1 KiB
ArmAsm
@ RUN: not llvm-mc -triple=armv7-unknown-linux-gnueabi < %s 2> %t
|
|
@ RUN: FileCheck --check-prefix=CHECK < %t %s
|
|
|
|
@ Check the diagnostics for .save directive
|
|
|
|
@ .save directive should always come after .fnstart directive and
|
|
@ before .handlerdata directive.
|
|
|
|
.syntax unified
|
|
.text
|
|
|
|
@-------------------------------------------------------------------------------
|
|
@ TEST1: .save before .fnstart
|
|
@-------------------------------------------------------------------------------
|
|
.globl func1
|
|
.align 2
|
|
.type func1,%function
|
|
.save {r4, r5, r6, r7}
|
|
@ CHECK: error: .fnstart must precede .save or .vsave directives
|
|
@ CHECK: .save {r4, r5, r6, r7}
|
|
@ CHECK: ^
|
|
.fnstart
|
|
func1:
|
|
.fnend
|
|
|
|
|
|
|
|
@-------------------------------------------------------------------------------
|
|
@ TEST2: .save after .handlerdata
|
|
@-------------------------------------------------------------------------------
|
|
.globl func2
|
|
.align 2
|
|
.type func2,%function
|
|
.fnstart
|
|
func2:
|
|
.handlerdata
|
|
.save {r4, r5, r6, r7}
|
|
@ CHECK: error: .save or .vsave must precede .handlerdata directive
|
|
@ CHECK: .save {r4, r5, r6, r7}
|
|
@ CHECK: ^
|
|
.fnend
|