summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@apple.com>2010-07-31 05:57:44 +0000
committerBob Wilson <bob.wilson@apple.com>2010-07-31 05:57:44 +0000
commitcd5fc7bef1f07e10a67427265f551ac35104c775 (patch)
treeeba6fcd34f4d6bb1a8d10bbe43256e3a21a5ba3b
parentd21139a34f5115b8cb95949194cfb40809bd0d17 (diff)
downloadbcm5719-llvm-cd5fc7bef1f07e10a67427265f551ac35104c775.tar.gz
bcm5719-llvm-cd5fc7bef1f07e10a67427265f551ac35104c775.zip
Add support for disassembling VMVN (immediate) instructions. PR7747.
llvm-svn: 109946
-rw-r--r--llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp4
-rw-r--r--llvm/test/MC/Disassembler/neon-tests.txt3
2 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp
index e48accc7b7f..d2fd8bde801 100644
--- a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp
+++ b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp
@@ -2431,10 +2431,14 @@ static bool DisassembleN1RegModImmFrm(MCInst &MI, unsigned Opcode,
break;
case ARM::VMOVv4i16:
case ARM::VMOVv8i16:
+ case ARM::VMVNv4i16:
+ case ARM::VMVNv8i16:
esize = ESize16;
break;
case ARM::VMOVv2i32:
case ARM::VMOVv4i32:
+ case ARM::VMVNv2i32:
+ case ARM::VMVNv4i32:
esize = ESize32;
break;
case ARM::VMOVv1i64:
diff --git a/llvm/test/MC/Disassembler/neon-tests.txt b/llvm/test/MC/Disassembler/neon-tests.txt
index 51b31e7c1a6..826ff2272ef 100644
--- a/llvm/test/MC/Disassembler/neon-tests.txt
+++ b/llvm/test/MC/Disassembler/neon-tests.txt
@@ -25,6 +25,9 @@
# CHECK: vmov.i64 q6, #0xFF00FF00FF
0x75 0xce 0x81 0xf2
+# CHECK: vmvn.i32 d0, #0x0
+0x30 0x00 0x80 0xf2
+
# CHECK: vmul.f32 d0, d0, d6
0x16 0x0d 0x00 0xf3
OpenPOWER on IntegriCloud