2014-06-11 23:05:56 +08:00
|
|
|
# Instructions that are valid for the current ISA but should be rejected by the assembler (e.g.
|
|
|
|
# invalid set of operands or operand's restrictions not met).
|
|
|
|
|
|
|
|
# RUN: not llvm-mc %s -triple=mips-unknown-linux -mcpu=mips32r2 2>%t1
|
2015-11-27 00:35:41 +08:00
|
|
|
# RUN: FileCheck %s < %t1
|
2014-06-11 23:05:56 +08:00
|
|
|
|
|
|
|
.text
|
|
|
|
.set noreorder
|
2016-03-31 22:34:00 +08:00
|
|
|
addiu $2, $3, -32769 # CHECK: :[[@LINE]]:23: error: expected 16-bit signed immediate
|
|
|
|
addiu $2, $3, 65536 # CHECK: :[[@LINE]]:23: error: expected 16-bit signed immediate
|
2016-02-01 23:13:31 +08:00
|
|
|
andi $2, $3, -1 # CHECK: :[[@LINE]]:22: error: expected 16-bit unsigned immediate
|
|
|
|
andi $2, $3, 65536 # CHECK: :[[@LINE]]:22: error: expected 16-bit unsigned immediate
|
2015-11-27 00:35:41 +08:00
|
|
|
cache -1, 255($7) # CHECK: :[[@LINE]]:15: error: expected 5-bit unsigned immediate
|
|
|
|
cache 32, 255($7) # CHECK: :[[@LINE]]:15: error: expected 5-bit unsigned immediate
|
2015-12-21 21:08:58 +08:00
|
|
|
# FIXME: Check '0 < pos + size <= 32' constraint on ext
|
2015-12-08 21:49:19 +08:00
|
|
|
ext $2, $3, -1, 1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
ext $2, $3, 32, 1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
2015-12-21 21:08:58 +08:00
|
|
|
ext $2, $3, 1, 0 # CHECK: :[[@LINE]]:24: error: expected immediate in range 1 .. 32
|
|
|
|
ext $2, $3, 1, 33 # CHECK: :[[@LINE]]:24: error: expected immediate in range 1 .. 32
|
2015-12-08 21:49:19 +08:00
|
|
|
# FIXME: Check size on ins
|
|
|
|
ins $2, $3, -1, 1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
ins $2, $3, 32, 1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
2015-11-27 00:35:41 +08:00
|
|
|
jalr.hb $31 # CHECK: :[[@LINE]]:9: error: source and destination must be different
|
|
|
|
jalr.hb $31, $31 # CHECK: :[[@LINE]]:9: error: source and destination must be different
|
2016-03-31 22:34:00 +08:00
|
|
|
lwc2 $2, -32769($3) # CHECK: :[[@LINE]]:18: error: expected memory with 16-bit signed offset
|
|
|
|
lwc2 $2, 32768($3) # CHECK: :[[@LINE]]:18: error: expected memory with 16-bit signed offset
|
2016-02-01 23:13:31 +08:00
|
|
|
ori $2, $3, -1 # CHECK: :[[@LINE]]:21: error: expected 16-bit unsigned immediate
|
|
|
|
ori $2, $3, 65536 # CHECK: :[[@LINE]]:21: error: expected 16-bit unsigned immediate
|
2015-11-27 00:35:41 +08:00
|
|
|
pref -1, 255($7) # CHECK: :[[@LINE]]:14: error: expected 5-bit unsigned immediate
|
|
|
|
pref 32, 255($7) # CHECK: :[[@LINE]]:14: error: expected 5-bit unsigned immediate
|
2016-03-01 00:06:38 +08:00
|
|
|
sdbbp -1 # CHECK: :[[@LINE]]:15: error: expected 20-bit unsigned immediate
|
|
|
|
sdbbp 1048576 # CHECK: :[[@LINE]]:15: error: expected 20-bit unsigned immediate
|
2015-12-08 21:49:19 +08:00
|
|
|
sll $2, $3, -1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
sll $2, $3, 32 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
srl $2, $3, -1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
srl $2, $3, 32 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
sra $2, $3, -1 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
|
|
|
sra $2, $3, 32 # CHECK: :[[@LINE]]:21: error: expected 5-bit unsigned immediate
|
2016-04-11 23:20:40 +08:00
|
|
|
sync -1 # CHECK: :[[@LINE]]:14: error: expected 5-bit unsigned immediate
|
|
|
|
sync 32 # CHECK: :[[@LINE]]:14: error: expected 5-bit unsigned immediate
|
2016-03-01 00:06:38 +08:00
|
|
|
syscall -1 # CHECK: :[[@LINE]]:17: error: expected 20-bit unsigned immediate
|
|
|
|
syscall 1048576 # CHECK: :[[@LINE]]:17: error: expected 20-bit unsigned immediate
|
2015-12-08 21:49:19 +08:00
|
|
|
rotr $2, $3, -1 # CHECK: :[[@LINE]]:22: error: expected 5-bit unsigned immediate
|
|
|
|
rotr $2, $3, 32 # CHECK: :[[@LINE]]:22: error: expected 5-bit unsigned immediate
|
2016-02-01 23:13:31 +08:00
|
|
|
xori $2, $3, -1 # CHECK: :[[@LINE]]:22: error: expected 16-bit unsigned immediate
|
|
|
|
xori $2, $3, 65536 # CHECK: :[[@LINE]]:22: error: expected 16-bit unsigned immediate
|