[micromips] Print instruction alias "not" if the last operand of a nor is zero.
[oota-llvm.git] / test / MC / Mips / micromips-alu-instructions.s
1 # RUN: llvm-mc %s -triple=mipsel -show-encoding -mattr=micromips | FileCheck -check-prefix=CHECK-EL %s
2 # RUN: llvm-mc %s -triple=mips -show-encoding -mattr=micromips | FileCheck -check-prefix=CHECK-EB %s
3 # Check that the assembler can handle the documented syntax
4 # for arithmetic and logical instructions.
5 #------------------------------------------------------------------------------
6 # Arithmetic and Logical Instructions
7 #------------------------------------------------------------------------------
8 # Little endian
9 #------------------------------------------------------------------------------
10 # CHECK-EL: add   $9, $6, $7      # encoding: [0xe6,0x00,0x10,0x49]
11 # CHECK-EL: addi  $9, $6, 17767   # encoding: [0x26,0x11,0x67,0x45]
12 # CHECK-EL: addiu $9, $6, -15001  # encoding: [0x26,0x31,0x67,0xc5]
13 # CHECK-EL: addi  $9, $6, 17767   # encoding: [0x26,0x11,0x67,0x45]
14 # CHECK-EL: addiu $9, $6, -15001  # encoding: [0x26,0x31,0x67,0xc5]
15 # CHECK-EL: addu  $9, $6, $7      # encoding: [0xe6,0x00,0x50,0x49]
16 # CHECK-EL: sub   $9, $6, $7      # encoding: [0xe6,0x00,0x90,0x49]
17 # CHECK-EL: subu  $4, $3, $5      # encoding: [0xa3,0x00,0xd0,0x21]
18 # CHECK-EL: neg   $6, $7          # encoding: [0xe0,0x00,0x90,0x31]
19 # CHECK-EL: negu  $6, $7          # encoding: [0xe0,0x00,0xd0,0x31]
20 # CHECK-EL: move  $7, $8          # encoding: [0x08,0x00,0x50,0x39]
21 # CHECK-EL: slt    $3, $3, $5     # encoding: [0xa3,0x00,0x50,0x1b]
22 # CHECK-EL: slti   $3, $3, 103    # encoding: [0x63,0x90,0x67,0x00]
23 # CHECK-EL: slti   $3, $3, 103    # encoding: [0x63,0x90,0x67,0x00]
24 # CHECK-EL: sltiu  $3, $3, 103    # encoding: [0x63,0xb0,0x67,0x00]
25 # CHECK-EL: sltu   $3, $3, $5     # encoding: [0xa3,0x00,0x90,0x1b]
26 # CHECK-EL: and    $9, $6, $7     # encoding: [0xe6,0x00,0x50,0x4a]
27 # CHECK-EL: andi   $9, $6, 17767  # encoding: [0x26,0xd1,0x67,0x45]
28 # CHECK-EL: andi   $9, $6, 17767  # encoding: [0x26,0xd1,0x67,0x45]
29 # CHECK-EL: or     $3, $4, $5     # encoding: [0xa4,0x00,0x90,0x1a]
30 # CHECK-EL: ori    $9, $6, 17767  # encoding: [0x26,0x51,0x67,0x45]
31 # CHECK-EL: xor    $3, $3, $5     # encoding: [0xa3,0x00,0x10,0x1b]
32 # CHECK-EL: xori   $9, $6, 17767  # encoding: [0x26,0x71,0x67,0x45]
33 # CHECK-EL: xori   $9, $6, 17767  # encoding: [0x26,0x71,0x67,0x45]
34 # CHECK-EL: nor    $9, $6, $7     # encoding: [0xe6,0x00,0xd0,0x4a]
35 # CHECK-EL: not    $7, $8         # encoding: [0x08,0x00,0xd0,0x3a]
36 # CHECK-EL: mul    $9, $6, $7     # encoding: [0xe6,0x00,0x10,0x4a]
37 # CHECK-EL: mult   $9, $7         # encoding: [0xe9,0x00,0x3c,0x8b]
38 # CHECK-EL: multu  $9, $7         # encoding: [0xe9,0x00,0x3c,0x9b]
39 #------------------------------------------------------------------------------
40 # Big endian
41 #------------------------------------------------------------------------------
42 # CHECK-EB: add $9, $6, $7        # encoding: [0x00,0xe6,0x49,0x10]
43 # CHECK-EB: addi  $9, $6, 17767   # encoding: [0x11,0x26,0x45,0x67]
44 # CHECK-EB: addiu $9, $6, -15001  # encoding: [0x31,0x26,0xc5,0x67]
45 # CHECK-EB: addi  $9, $6, 17767   # encoding: [0x11,0x26,0x45,0x67]
46 # CHECK-EB: addiu $9, $6, -15001  # encoding: [0x31,0x26,0xc5,0x67]
47 # CHECK-EB: addu  $9, $6, $7      # encoding: [0x00,0xe6,0x49,0x50]
48 # CHECK-EB: sub $9, $6, $7        # encoding: [0x00,0xe6,0x49,0x90]
49 # CHECK-EB: subu  $4, $3, $5      # encoding: [0x00,0xa3,0x21,0xd0]
50 # CHECK-EB: neg $6, $7            # encoding: [0x00,0xe0,0x31,0x90]
51 # CHECK-EB: negu  $6, $7          # encoding: [0x00,0xe0,0x31,0xd0]
52 # CHECK-EB: move  $7, $8          # encoding: [0x00,0x08,0x39,0x50]
53 # CHECK-EB: slt $3, $3, $5        # encoding: [0x00,0xa3,0x1b,0x50]
54 # CHECK-EB: slti  $3, $3, 103     # encoding: [0x90,0x63,0x00,0x67]
55 # CHECK-EB: slti  $3, $3, 103     # encoding: [0x90,0x63,0x00,0x67]
56 # CHECK-EB: sltiu $3, $3, 103     # encoding: [0xb0,0x63,0x00,0x67]
57 # CHECK-EB: sltu  $3, $3, $5      # encoding: [0x00,0xa3,0x1b,0x90]
58 # CHECK-EB: and $9, $6, $7        # encoding: [0x00,0xe6,0x4a,0x50]
59 # CHECK-EB:  andi  $9, $6, 17767  # encoding: [0xd1,0x26,0x45,0x67]
60 # CHECK-EB:  andi  $9, $6, 17767  # encoding: [0xd1,0x26,0x45,0x67]
61 # CHECK-EB:  or  $3, $4, $5       # encoding: [0x00,0xa4,0x1a,0x90]
62 # CHECK-EB:  ori $9, $6, 17767    # encoding: [0x51,0x26,0x45,0x67]
63 # CHECK-EB:  xor $3, $3, $5       # encoding: [0x00,0xa3,0x1b,0x10]
64 # CHECK-EB:  xori  $9, $6, 17767  # encoding: [0x71,0x26,0x45,0x67]
65 # CHECK-EB:  xori  $9, $6, 17767  # encoding: [0x71,0x26,0x45,0x67]
66 # CHECK-EB:  nor $9, $6, $7       # encoding: [0x00,0xe6,0x4a,0xd0]
67 # CHECK-EB:  not $7, $8           # encoding: [0x00,0x08,0x3a,0xd0]
68 # CHECK-EB:  mul $9, $6, $7       # encoding: [0x00,0xe6,0x4a,0x10]
69 # CHECK-EB:  mult  $9, $7         # encoding: [0x00,0xe9,0x8b,0x3c]
70 # CHECK-EB:  multu $9, $7         # encoding: [0x00,0xe9,0x9b,0x3c]
71     add    $9, $6, $7
72     add    $9, $6, 17767
73     addu   $9, $6, -15001
74     addi   $9, $6, 17767
75     addiu  $9, $6,-15001
76     addu   $9, $6, $7
77     sub    $9, $6, $7
78     subu   $4, $3, $5
79     neg    $6, $7
80     negu   $6, $7
81     move   $7, $8
82     slt    $3, $3, $5
83     slt    $3, $3, 103
84     slti   $3, $3, 103
85     sltiu  $3, $3, 103
86     sltu   $3, $3, $5
87     and    $9, $6, $7
88     and    $9, $6, 17767
89     andi   $9, $6, 17767
90     or     $3, $4, $5
91     ori    $9, $6, 17767
92     xor    $3, $3, $5
93     xor    $9, $6, 17767
94     xori   $9, $6, 17767
95     nor    $9, $6, $7
96     nor    $7, $8, $zero
97     mul    $9, $6, $7
98     mult   $9, $7
99     multu  $9, $7