mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
d5b8ea6c58
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. llvm-svn: 181603
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 .vsave directive
|
|
|
|
@ .vsave directive should always come after .fnstart directive
|
|
@ and before .handlerdata directive.
|
|
|
|
.syntax unified
|
|
.text
|
|
|
|
@-------------------------------------------------------------------------------
|
|
@ TEST1: .vsave before .fnstart
|
|
@-------------------------------------------------------------------------------
|
|
.globl func1
|
|
.align 2
|
|
.type func1,%function
|
|
.vsave {d0, d1, d2, d3}
|
|
@ CHECK: error: .fnstart must precede .save or .vsave directives
|
|
@ CHECK: .vsave {d0, d1, d2, d3}
|
|
@ CHECK: ^
|
|
.fnstart
|
|
func1:
|
|
.fnend
|
|
|
|
|
|
|
|
@-------------------------------------------------------------------------------
|
|
@ TEST2: .vsave after .handlerdata
|
|
@-------------------------------------------------------------------------------
|
|
.globl func2
|
|
.align 2
|
|
.type func2,%function
|
|
.fnstart
|
|
func2:
|
|
.handlerdata
|
|
.vsave {d0, d1, d2, d3}
|
|
@ CHECK: error: .save or .vsave must precede .handlerdata directive
|
|
@ CHECK: .vsave {d0, d1, d2, d3}
|
|
@ CHECK: ^
|
|
.fnend
|