forked from OSchip/llvm-project
229 lines
8.4 KiB
ArmAsm
229 lines
8.4 KiB
ArmAsm
@ RUN: not llvm-mc -triple=armv7-apple-darwin < %s 2> %t
|
|
@ RUN: FileCheck --check-prefix=CHECK-ERRORS < %t %s
|
|
|
|
@ Check for various assembly diagnostic messages on invalid input.
|
|
|
|
@ 's' bit on an instruction that can't accept it.
|
|
mlss r1, r2, r3, r4
|
|
@ CHECK-ERRORS: error: instruction 'mls' can not set flags,
|
|
@ CHECK-ERRORS: but 's' suffix specified
|
|
|
|
|
|
@ Out of range shift immediate values.
|
|
adc r1, r2, r3, lsl #invalid
|
|
adc r4, r5, r6, lsl #-1
|
|
adc r4, r5, r6, lsl #32
|
|
adc r4, r5, r6, lsr #-1
|
|
adc r4, r5, r6, lsr #33
|
|
adc r4, r5, r6, asr #-1
|
|
adc r4, r5, r6, asr #33
|
|
adc r4, r5, r6, ror #-1
|
|
adc r4, r5, r6, ror #32
|
|
|
|
@ CHECK-ERRORS: error: invalid immediate shift value
|
|
@ CHECK-ERRORS: adc r1, r2, r3, lsl #invalid
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, lsl #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, lsl #32
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, lsr #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, lsr #33
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, asr #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, asr #33
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, ror #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate shift value out of range
|
|
@ CHECK-ERRORS: adc r4, r5, r6, ror #32
|
|
|
|
|
|
@ Out of range 16-bit immediate on BKPT
|
|
bkpt #65536
|
|
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
@ Out of range 4 and 3 bit immediates on CDP[2]
|
|
|
|
@ Out of range immediates for CDP/CDP2
|
|
cdp p7, #2, c1, c1, c1, #8
|
|
cdp p7, #1, c1, c1, c1, #8
|
|
cdp2 p7, #2, c1, c1, c1, #8
|
|
cdp2 p7, #1, c1, c1, c1, #8
|
|
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
@ Out of range immediates for DBG
|
|
dbg #-1
|
|
dbg #16
|
|
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ Double-check that we're synced up with the right diagnostics.
|
|
@ CHECK-ERRORS: dbg #16
|
|
|
|
@ Out of range immediate for MCR/MCR2/MCRR/MCRR2
|
|
mcr p7, #8, r5, c1, c1, #4
|
|
mcr p7, #2, r5, c1, c1, #8
|
|
mcr2 p7, #8, r5, c1, c1, #4
|
|
mcr2 p7, #1, r5, c1, c1, #8
|
|
mcrr p7, #16, r5, r4, c1
|
|
mcrr2 p7, #16, r5, r4, c1
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
|
|
@ Out of range immediate for MOV
|
|
movw r9, 0x10000
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
@ Invalid 's' bit usage for MOVW
|
|
movs r6, #0xffff
|
|
movwseq r9, #0xffff
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: instruction 'movw' can not set flags, but 's' suffix specified
|
|
|
|
@ Out of range immediate for MOVT
|
|
movt r9, 0x10000
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
@ Out of range immediates for MRC/MRC2/MRRC/MRRC2
|
|
mrc p14, #8, r1, c1, c2, #4
|
|
mrc p14, #1, r1, c1, c2, #8
|
|
mrc2 p14, #8, r1, c1, c2, #4
|
|
mrc2 p14, #0, r1, c1, c2, #9
|
|
mrrc p7, #16, r5, r4, c1
|
|
mrrc2 p7, #17, r5, r4, c1
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
|
|
@ Shifter operand validation for PKH instructions.
|
|
pkhbt r2, r2, r3, lsl #-1
|
|
pkhbt r2, r2, r3, lsl #32
|
|
pkhtb r2, r2, r3, asr #0
|
|
pkhtb r2, r2, r3, asr #33
|
|
pkhbt r2, r2, r3, asr #3
|
|
pkhtb r2, r2, r3, lsl #3
|
|
|
|
@ CHECK-ERRORS: error: immediate value out of range
|
|
@ CHECK-ERRORS: pkhbt r2, r2, r3, lsl #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate value out of range
|
|
@ CHECK-ERRORS: pkhbt r2, r2, r3, lsl #32
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate value out of range
|
|
@ CHECK-ERRORS: pkhtb r2, r2, r3, asr #0
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: immediate value out of range
|
|
@ CHECK-ERRORS: pkhtb r2, r2, r3, asr #33
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: lsl operand expected.
|
|
@ CHECK-ERRORS: pkhbt r2, r2, r3, asr #3
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: asr operand expected.
|
|
@ CHECK-ERRORS: pkhtb r2, r2, r3, lsl #3
|
|
@ CHECK-ERRORS: ^
|
|
|
|
|
|
@ bad values for SETEND
|
|
setendne be
|
|
setend me
|
|
setend 1
|
|
|
|
@ CHECK-ERRORS: error: instruction 'setend' is not predicable, but condition code specified
|
|
@ CHECK-ERRORS: setendne be
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'be' or 'le' operand expected
|
|
@ CHECK-ERRORS: setend me
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'be' or 'le' operand expected
|
|
@ CHECK-ERRORS: setend 1
|
|
@ CHECK-ERRORS: ^
|
|
|
|
|
|
@ Out of range immediates and bad shift types for SSAT
|
|
ssat r8, #0, r10, lsl #8
|
|
ssat r8, #33, r10, lsl #8
|
|
ssat r8, #1, r10, lsl #-1
|
|
ssat r8, #1, r10, lsl #32
|
|
ssat r8, #1, r10, asr #0
|
|
ssat r8, #1, r10, asr #33
|
|
ssat r8, #1, r10, lsr #5
|
|
ssat r8, #1, r10, lsl fred
|
|
ssat r8, #1, r10, lsl #fred
|
|
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: ssat r8, #0, r10, lsl #8
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: ssat r8, #33, r10, lsl #8
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'lsr' shift amount must be in range [0,31]
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, lsl #-1
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'lsr' shift amount must be in range [0,31]
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, lsl #32
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'asr' shift amount must be in range [1,32]
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, asr #0
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: 'asr' shift amount must be in range [1,32]
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, asr #33
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: shift operator 'asr' or 'lsl' expected
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, lsr #5
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: '#' expected
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, lsl fred
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: shift amount must be an immediate
|
|
@ CHECK-ERRORS: ssat r8, #1, r10, lsl #fred
|
|
@ CHECK-ERRORS: ^
|
|
|
|
@ Out of range immediates for SSAT16
|
|
ssat16 r2, #0, r7
|
|
ssat16 r3, #17, r5
|
|
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: ssat16 r2, #0, r7
|
|
@ CHECK-ERRORS: ^
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: ssat16 r3, #17, r5
|
|
@ CHECK-ERRORS: ^
|
|
|
|
|
|
@ Out of order STM registers
|
|
stmda sp!, {r5, r2}
|
|
|
|
@ CHECK-ERRORS: warning: register not in ascending order in register list
|
|
@ CHECK-ERRORS: stmda sp!, {r5, r2}
|
|
@ CHECK-ERRORS: ^
|
|
|
|
|
|
@ Out of range immediate on SVC
|
|
svc #0x1000000
|
|
@ CHECK-ERRORS: error: invalid operand for instruction
|
|
@ CHECK-ERRORS: svc #0x1000000
|
|
@ CHECK-ERRORS: ^
|