@ RUN: not llvm-mc -triple=armv7-unknown-linux-gnueabi < %s 2> %t
@ RUN: FileCheck < %t %s
@ Check the diagnostics for .setfp directive.
.syntax unified
.text
@-------------------------------------------------------------------------------
@ TEST1: .setfp before .fnstart
@-------------------------------------------------------------------------------
.globl func1
.align 2
.type func1,%function
.setfp fp, sp, @ CHECK: error: .fnstart must precede .setfp directive
@ CHECK: .setfp fp, sp, @ CHECK: ^
.fnstart
func1:
.fnend
@-------------------------------------------------------------------------------
@ TEST2: .setfp after .handlerdata
@-------------------------------------------------------------------------------
.globl func2
.align 2
.type func2,%function
.fnstart
func2:
.handlerdata
.setfp fp, sp, @ CHECK: error: .setfp must precede .handlerdata directive
@ CHECK: .setfp fp, sp, @ CHECK: ^
.fnend
@-------------------------------------------------------------------------------
@ TEST3: .setfp with bad fp register
@-------------------------------------------------------------------------------
.globl func3
.align 2
.type func3,%function
.fnstart
func3:
.setfp 0, r0, @ CHECK: error: frame pointer register expected
@ CHECK: .setfp 0, r0, @ CHECK: ^
.fnend
@-------------------------------------------------------------------------------
@ TEST4: .setfp with bad sp register
@-------------------------------------------------------------------------------
.globl func4
.align 2
.type func4,%function
.fnstart
func4:
.setfp fp, 0, @ CHECK: error: stack pointer register expected
@ CHECK: .setfp fp, 0, @ CHECK: ^
.fnend
@-------------------------------------------------------------------------------
@ TEST5: .setfp with non-sp register as second operand
@-------------------------------------------------------------------------------
.globl func5
.align 2
.type func5,%function
.fnstart
func5:
.setfp fp, r0, @ CHECK: error: register should be either $sp or the latest fp register
@ CHECK: .setfp fp, r0, @ CHECK: ^
.fnend