Fix for PR18921, "vmov" part.
Added support for bytes replication feature, so it could be GAS compatible.
E.g. instructions below:
"vmov.i32 d0, 0xffffffff"
"vmvn.i32 d0, 0xabababab"
"vmov.i32 d0, 0xabababab"
"vmov.i16 d0, 0xabab"
are incorrect, but we could deal with such cases.
For first one we should emit:
"vmov.i8 d0, 0xff"
For second one ("vmvn"):
"vmov.i8 d0, 0x54"
For last two instructions it should emit:
"vmov.i8 d0, 0xab"
P.S.: In ARMAsmParser.cpp I have also fixed few nearby style issues in old code.
Just for keeping method bodies in harmony with themselves.
llvm-svn: 207080
2014-04-24 14:03:01 +08:00
|
|
|
@ RUN: not llvm-mc -triple=armv7-linux-gnueabi %s 2>&1 | FileCheck %s
|
|
|
|
.text
|
|
|
|
|
2017-10-10 20:35:09 +08:00
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmov.i32 d2, #0xffffffab
|
|
|
|
@ CHECK: note: operand must be a register in range [d0, d31]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmov.i32 q2, #0xffffffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmov.i16 q2, #0xffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmov.i16 q2, #0xffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
Fix for PR18921, "vmov" part.
Added support for bytes replication feature, so it could be GAS compatible.
E.g. instructions below:
"vmov.i32 d0, 0xffffffff"
"vmvn.i32 d0, 0xabababab"
"vmov.i32 d0, 0xabababab"
"vmov.i16 d0, 0xabab"
are incorrect, but we could deal with such cases.
For first one we should emit:
"vmov.i8 d0, 0xff"
For second one ("vmvn"):
"vmov.i8 d0, 0x54"
For last two instructions it should emit:
"vmov.i8 d0, 0xab"
P.S.: In ARMAsmParser.cpp I have also fixed few nearby style issues in old code.
Just for keeping method bodies in harmony with themselves.
llvm-svn: 207080
2014-04-24 14:03:01 +08:00
|
|
|
|
2017-10-10 20:35:09 +08:00
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmvn.i32 d2, #0xffffffab
|
|
|
|
@ CHECK: note: operand must be a register in range [d0, d31]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmvn.i32 q2, #0xffffffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmvn.i16 q2, #0xffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
|
|
@ CHECK-NEXT: vmvn.i16 q2, #0xffab
|
|
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
|
|
@ CHECK: note: invalid operand for instruction
|
Fix for PR18921, "vmov" part.
Added support for bytes replication feature, so it could be GAS compatible.
E.g. instructions below:
"vmov.i32 d0, 0xffffffff"
"vmvn.i32 d0, 0xabababab"
"vmov.i32 d0, 0xabababab"
"vmov.i16 d0, 0xabab"
are incorrect, but we could deal with such cases.
For first one we should emit:
"vmov.i8 d0, 0xff"
For second one ("vmvn"):
"vmov.i8 d0, 0x54"
For last two instructions it should emit:
"vmov.i8 d0, 0xab"
P.S.: In ARMAsmParser.cpp I have also fixed few nearby style issues in old code.
Just for keeping method bodies in harmony with themselves.
llvm-svn: 207080
2014-04-24 14:03:01 +08:00
|
|
|
|
|
|
|
vmov.i32 d2, #0xffffffab
|
|
|
|
vmov.i32 q2, #0xffffffab
|
|
|
|
vmov.i16 q2, #0xffab
|
|
|
|
vmov.i16 q2, #0xffab
|
|
|
|
|
|
|
|
vmvn.i32 d2, #0xffffffab
|
|
|
|
vmvn.i32 q2, #0xffffffab
|
|
|
|
vmvn.i16 q2, #0xffab
|
|
|
|
vmvn.i16 q2, #0xffab
|