summaryrefslogtreecommitdiff
path: root/test/MC/Mips/micromips-alu-instructions.s
diff options
context:
space:
mode:
authorJack Carter <jack.carter@imgtec.com>2013-08-08 23:30:40 +0000
committerJack Carter <jack.carter@imgtec.com>2013-08-08 23:30:40 +0000
commitd12fce1a27c30292dcd5f5bc10d4ba6e742888be (patch)
tree2067f8d9a65641e1d5fd5e9ecbb9d510c2190d49 /test/MC/Mips/micromips-alu-instructions.s
parent68554401fca3770583d21b8505553e914f9ee307 (diff)
downloadllvm-d12fce1a27c30292dcd5f5bc10d4ba6e742888be.tar.gz
llvm-d12fce1a27c30292dcd5f5bc10d4ba6e742888be.tar.bz2
llvm-d12fce1a27c30292dcd5f5bc10d4ba6e742888be.tar.xz
Mips ELF: MicroMips direct object Little endian support.
Test included. Patch by Zoran Jovanovich git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188024 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/MC/Mips/micromips-alu-instructions.s')
-rw-r--r--test/MC/Mips/micromips-alu-instructions.s95
1 files changed, 65 insertions, 30 deletions
diff --git a/test/MC/Mips/micromips-alu-instructions.s b/test/MC/Mips/micromips-alu-instructions.s
index c541e1ace5..3f6079cf67 100644
--- a/test/MC/Mips/micromips-alu-instructions.s
+++ b/test/MC/Mips/micromips-alu-instructions.s
@@ -1,38 +1,73 @@
-# RUN: llvm-mc %s -triple=mipsel -show-encoding -mattr=micromips | FileCheck %s
+# RUN: llvm-mc %s -triple=mipsel -show-encoding -mattr=micromips | FileCheck -check-prefix=CHECK-EL %s
+# RUN: llvm-mc %s -triple=mips -show-encoding -mattr=micromips | FileCheck -check-prefix=CHECK-EB %s
# Check that the assembler can handle the documented syntax
# for arithmetic and logical instructions.
#------------------------------------------------------------------------------
# Arithmetic and Logical Instructions
#------------------------------------------------------------------------------
-# CHECK: add $9, $6, $7 # encoding: [0x10,0x49,0xe6,0x00]
-# CHECK: addi $9, $6, 17767 # encoding: [0x67,0x45,0x26,0x11]
-# CHECK: addiu $9, $6, -15001 # encoding: [0x67,0xc5,0x26,0x31]
-# CHECK: addi $9, $6, 17767 # encoding: [0x67,0x45,0x26,0x11]
-# CHECK: addiu $9, $6, -15001 # encoding: [0x67,0xc5,0x26,0x31]
-# CHECK: addu $9, $6, $7 # encoding: [0x50,0x49,0xe6,0x00]
-# CHECK: sub $9, $6, $7 # encoding: [0x90,0x49,0xe6,0x00]
-# CHECK: subu $4, $3, $5 # encoding: [0xd0,0x21,0xa3,0x00]
-# CHECK: neg $6, $7 # encoding: [0x90,0x31,0xe0,0x00]
-# CHECK: negu $6, $7 # encoding: [0xd0,0x31,0xe0,0x00]
-# CHECK: move $7, $8 # encoding: [0x50,0x39,0x08,0x00]
-# CHECK: slt $3, $3, $5 # encoding: [0x50,0x1b,0xa3,0x00]
-# CHECK: slti $3, $3, 103 # encoding: [0x67,0x00,0x63,0x90]
-# CHECK: slti $3, $3, 103 # encoding: [0x67,0x00,0x63,0x90]
-# CHECK: sltiu $3, $3, 103 # encoding: [0x67,0x00,0x63,0xb0]
-# CHECK: sltu $3, $3, $5 # encoding: [0x90,0x1b,0xa3,0x00]
-# CHECK: and $9, $6, $7 # encoding: [0x50,0x4a,0xe6,0x00]
-# CHECK: andi $9, $6, 17767 # encoding: [0x67,0x45,0x26,0xd1]
-# CHECK: andi $9, $6, 17767 # encoding: [0x67,0x45,0x26,0xd1]
-# CHECK: or $3, $4, $5 # encoding: [0x90,0x1a,0xa4,0x00]
-# CHECK: ori $9, $6, 17767 # encoding: [0x67,0x45,0x26,0x51]
-# CHECK: xor $3, $3, $5 # encoding: [0x10,0x1b,0xa3,0x00]
-# CHECK: xori $9, $6, 17767 # encoding: [0x67,0x45,0x26,0x71]
-# CHECK: xori $9, $6, 17767 # encoding: [0x67,0x45,0x26,0x71]
-# CHECK: nor $9, $6, $7 # encoding: [0xd0,0x4a,0xe6,0x00]
-# CHECK: not $7, $8 # encoding: [0xd0,0x3a,0x08,0x00]
-# CHECK: mul $9, $6, $7 # encoding: [0x10,0x4a,0xe6,0x00]
-# CHECK: mult $9, $7 # encoding: [0x3c,0x8b,0xe9,0x00]
-# CHECK: multu $9, $7 # encoding: [0x3c,0x9b,0xe9,0x00]
+# Little endian
+#------------------------------------------------------------------------------
+# CHECK-EL: add $9, $6, $7 # encoding: [0xe6,0x00,0x10,0x49]
+# CHECK-EL: addi $9, $6, 17767 # encoding: [0x26,0x11,0x67,0x45]
+# CHECK-EL: addiu $9, $6, -15001 # encoding: [0x26,0x31,0x67,0xc5]
+# CHECK-EL: addi $9, $6, 17767 # encoding: [0x26,0x11,0x67,0x45]
+# CHECK-EL: addiu $9, $6, -15001 # encoding: [0x26,0x31,0x67,0xc5]
+# CHECK-EL: addu $9, $6, $7 # encoding: [0xe6,0x00,0x50,0x49]
+# CHECK-EL: sub $9, $6, $7 # encoding: [0xe6,0x00,0x90,0x49]
+# CHECK-EL: subu $4, $3, $5 # encoding: [0xa3,0x00,0xd0,0x21]
+# CHECK-EL: neg $6, $7 # encoding: [0xe0,0x00,0x90,0x31]
+# CHECK-EL: negu $6, $7 # encoding: [0xe0,0x00,0xd0,0x31]
+# CHECK-EL: move $7, $8 # encoding: [0x08,0x00,0x50,0x39]
+# CHECK-EL: slt $3, $3, $5 # encoding: [0xa3,0x00,0x50,0x1b]
+# CHECK-EL: slti $3, $3, 103 # encoding: [0x63,0x90,0x67,0x00]
+# CHECK-EL: slti $3, $3, 103 # encoding: [0x63,0x90,0x67,0x00]
+# CHECK-EL: sltiu $3, $3, 103 # encoding: [0x63,0xb0,0x67,0x00]
+# CHECK-EL: sltu $3, $3, $5 # encoding: [0xa3,0x00,0x90,0x1b]
+# CHECK-EL: and $9, $6, $7 # encoding: [0xe6,0x00,0x50,0x4a]
+# CHECK-EL: andi $9, $6, 17767 # encoding: [0x26,0xd1,0x67,0x45]
+# CHECK-EL: andi $9, $6, 17767 # encoding: [0x26,0xd1,0x67,0x45]
+# CHECK-EL: or $3, $4, $5 # encoding: [0xa4,0x00,0x90,0x1a]
+# CHECK-EL: ori $9, $6, 17767 # encoding: [0x26,0x51,0x67,0x45]
+# CHECK-EL: xor $3, $3, $5 # encoding: [0xa3,0x00,0x10,0x1b]
+# CHECK-EL: xori $9, $6, 17767 # encoding: [0x26,0x71,0x67,0x45]
+# CHECK-EL: xori $9, $6, 17767 # encoding: [0x26,0x71,0x67,0x45]
+# CHECK-EL: nor $9, $6, $7 # encoding: [0xe6,0x00,0xd0,0x4a]
+# CHECK-EL: not $7, $8 # encoding: [0x08,0x00,0xd0,0x3a]
+# CHECK-EL: mul $9, $6, $7 # encoding: [0xe6,0x00,0x10,0x4a]
+# CHECK-EL: mult $9, $7 # encoding: [0xe9,0x00,0x3c,0x8b]
+# CHECK-EL: multu $9, $7 # encoding: [0xe9,0x00,0x3c,0x9b]
+#------------------------------------------------------------------------------
+# Big endian
+#------------------------------------------------------------------------------
+# CHECK-EB: add $9, $6, $7 # encoding: [0x00,0xe6,0x49,0x10]
+# CHECK-EB: addi $9, $6, 17767 # encoding: [0x11,0x26,0x45,0x67]
+# CHECK-EB: addiu $9, $6, -15001 # encoding: [0x31,0x26,0xc5,0x67]
+# CHECK-EB: addi $9, $6, 17767 # encoding: [0x11,0x26,0x45,0x67]
+# CHECK-EB: addiu $9, $6, -15001 # encoding: [0x31,0x26,0xc5,0x67]
+# CHECK-EB: addu $9, $6, $7 # encoding: [0x00,0xe6,0x49,0x50]
+# CHECK-EB: sub $9, $6, $7 # encoding: [0x00,0xe6,0x49,0x90]
+# CHECK-EB: subu $4, $3, $5 # encoding: [0x00,0xa3,0x21,0xd0]
+# CHECK-EB: neg $6, $7 # encoding: [0x00,0xe0,0x31,0x90]
+# CHECK-EB: negu $6, $7 # encoding: [0x00,0xe0,0x31,0xd0]
+# CHECK-EB: move $7, $8 # encoding: [0x00,0x08,0x39,0x50]
+# CHECK-EB: slt $3, $3, $5 # encoding: [0x00,0xa3,0x1b,0x50]
+# CHECK-EB: slti $3, $3, 103 # encoding: [0x90,0x63,0x00,0x67]
+# CHECK-EB: slti $3, $3, 103 # encoding: [0x90,0x63,0x00,0x67]
+# CHECK-EB: sltiu $3, $3, 103 # encoding: [0xb0,0x63,0x00,0x67]
+# CHECK-EB: sltu $3, $3, $5 # encoding: [0x00,0xa3,0x1b,0x90]
+# CHECK-EB: and $9, $6, $7 # encoding: [0x00,0xe6,0x4a,0x50]
+# CHECK-EB: andi $9, $6, 17767 # encoding: [0xd1,0x26,0x45,0x67]
+# CHECK-EB: andi $9, $6, 17767 # encoding: [0xd1,0x26,0x45,0x67]
+# CHECK-EB: or $3, $4, $5 # encoding: [0x00,0xa4,0x1a,0x90]
+# CHECK-EB: ori $9, $6, 17767 # encoding: [0x51,0x26,0x45,0x67]
+# CHECK-EB: xor $3, $3, $5 # encoding: [0x00,0xa3,0x1b,0x10]
+# CHECK-EB: xori $9, $6, 17767 # encoding: [0x71,0x26,0x45,0x67]
+# CHECK-EB: xori $9, $6, 17767 # encoding: [0x71,0x26,0x45,0x67]
+# CHECK-EB: nor $9, $6, $7 # encoding: [0x00,0xe6,0x4a,0xd0]
+# CHECK-EB: not $7, $8 # encoding: [0x00,0x08,0x3a,0xd0]
+# CHECK-EB: mul $9, $6, $7 # encoding: [0x00,0xe6,0x4a,0x10]
+# CHECK-EB: mult $9, $7 # encoding: [0x00,0xe9,0x8b,0x3c]
+# CHECK-EB: multu $9, $7 # encoding: [0x00,0xe9,0x9b,0x3c]
add $9, $6, $7
add $9, $6, 17767
addu $9, $6, -15001