blob: c6be026fcff077026a3828b375f261a3af46c15d [file] [log] [blame]
; Error cases for invalid operands.
; { dg-do assemble { target cris-*-* } }
.text
start:
add.w r3,r4,r5 ; { dg-error "(Illegal|Invalid) operands" }
add.w 42,r4,r5 ; { dg-error "(Illegal|Invalid) operands" }
add.w [r3],r4,r5 ; Not an error: [r3] implies [r3+0].
add.w r3,[r3],r4 ; { dg-error "(Illegal|Invalid) operands" }
add.w r3,[r3] ; { dg-error "(Illegal|Invalid) operands" }
test.w [r3],r4,r5 ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3],r4 ; { dg-error "(Illegal|Invalid) operands" }
move.d [r3],r4,r5 ; { dg-error "(Illegal|Invalid) operands" }
; These two *might* be useful in extreme cases, so maybe the following
; should not be considered an error in the first place.
test.d whatever ; { dg-error "(Illegal|Invalid) operands" "" { xfail *-*-* } }
test.d 42 ; { dg-error "(Illegal|Invalid) operands" "" { xfail *-*-* } }
clear.d whatever ; { dg-error "(Illegal|Invalid) operands" }
clear.d 42 ; { dg-error "(Illegal|Invalid) operands" }
addi r5,r3 ; { dg-error "(Illegal|Invalid) operands" }
ba [external_symbol] ; Not an error, just obscure and generally useless.
ba [r3] ; Not an error, just obscure and generally useless.
lsl r3,r5 ; { dg-error "(Illegal|Invalid) operands" }
xor.d r5,r6 ; { dg-error "(Illegal|Invalid) operands" }
; Addressing modes
test.d [r3+r4] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=r2+[r4]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=r2+[r4].w ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=r2] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=r2+] ; { dg-error "(Illegal|Invalid) operands|(B|b)ad expression" }
test.d [r3++] ; { dg-error "(Illegal|Invalid) operands|(B|b)ad expression" }
; I think these should be valid; a dip with "postincrement" on
; the insn that follows.
test.d [r3=external_symbol] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=[r4]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=[r4+]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [[r3+r4.b]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=external+[r5]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3=[r5]+external] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3+[r3+r5.d]] ; { dg-error "(Illegal|Invalid) operands" }
test.d [r3+[r3+external]] ; { dg-error "(Illegal|Invalid) operands" }