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: lui    $9, 17767      # encoding: [0xa9,0x41,0x67,0x45]
27# CHECK-EL: and    $9, $6, $7     # encoding: [0xe6,0x00,0x50,0x4a]
28# CHECK-EL: andi   $9, $6, 17767  # encoding: [0x26,0xd1,0x67,0x45]
29# CHECK-EL: andi   $9, $6, 17767  # encoding: [0x26,0xd1,0x67,0x45]
30# CHECK-EL: or     $3, $4, $5     # encoding: [0xa4,0x00,0x90,0x1a]
31# CHECK-EL: ori    $9, $6, 17767  # encoding: [0x26,0x51,0x67,0x45]
32# CHECK-EL: xor    $3, $3, $5     # encoding: [0xa3,0x00,0x10,0x1b]
33# CHECK-EL: xori   $9, $6, 17767  # encoding: [0x26,0x71,0x67,0x45]
34# CHECK-EL: xori   $9, $6, 17767  # encoding: [0x26,0x71,0x67,0x45]
35# CHECK-EL: nor    $9, $6, $7     # encoding: [0xe6,0x00,0xd0,0x4a]
36# CHECK-EL: not    $7, $8         # encoding: [0x08,0x00,0xd0,0x3a]
37# CHECK-EL: mul    $9, $6, $7     # encoding: [0xe6,0x00,0x10,0x4a]
38# CHECK-EL: mult   $9, $7         # encoding: [0xe9,0x00,0x3c,0x8b]
39# CHECK-EL: multu  $9, $7         # encoding: [0xe9,0x00,0x3c,0x9b]
40# CHECK-EL: div    $zero, $9, $7  # encoding: [0xe9,0x00,0x3c,0xab]
41# CHECK-EL: divu   $zero, $9, $7  # encoding: [0xe9,0x00,0x3c,0xbb]
42#------------------------------------------------------------------------------
43# Big endian
44#------------------------------------------------------------------------------
45# CHECK-EB: add $9, $6, $7        # encoding: [0x00,0xe6,0x49,0x10]
46# CHECK-EB: addi  $9, $6, 17767   # encoding: [0x11,0x26,0x45,0x67]
47# CHECK-EB: addiu $9, $6, -15001  # encoding: [0x31,0x26,0xc5,0x67]
48# CHECK-EB: addi  $9, $6, 17767   # encoding: [0x11,0x26,0x45,0x67]
49# CHECK-EB: addiu $9, $6, -15001  # encoding: [0x31,0x26,0xc5,0x67]
50# CHECK-EB: addu  $9, $6, $7      # encoding: [0x00,0xe6,0x49,0x50]
51# CHECK-EB: sub $9, $6, $7        # encoding: [0x00,0xe6,0x49,0x90]
52# CHECK-EB: subu  $4, $3, $5      # encoding: [0x00,0xa3,0x21,0xd0]
53# CHECK-EB: neg $6, $7            # encoding: [0x00,0xe0,0x31,0x90]
54# CHECK-EB: negu  $6, $7          # encoding: [0x00,0xe0,0x31,0xd0]
55# CHECK-EB: move  $7, $8          # encoding: [0x00,0x08,0x39,0x50]
56# CHECK-EB: slt $3, $3, $5        # encoding: [0x00,0xa3,0x1b,0x50]
57# CHECK-EB: slti  $3, $3, 103     # encoding: [0x90,0x63,0x00,0x67]
58# CHECK-EB: slti  $3, $3, 103     # encoding: [0x90,0x63,0x00,0x67]
59# CHECK-EB: sltiu $3, $3, 103     # encoding: [0xb0,0x63,0x00,0x67]
60# CHECK-EB: sltu  $3, $3, $5      # encoding: [0x00,0xa3,0x1b,0x90]
61# CHECK-EB: lui $9, 17767         # encoding: [0x41,0xa9,0x45,0x67]
62# CHECK-EB: and $9, $6, $7        # encoding: [0x00,0xe6,0x4a,0x50]
63# CHECK-EB:  andi  $9, $6, 17767  # encoding: [0xd1,0x26,0x45,0x67]
64# CHECK-EB:  andi  $9, $6, 17767  # encoding: [0xd1,0x26,0x45,0x67]
65# CHECK-EB:  or  $3, $4, $5       # encoding: [0x00,0xa4,0x1a,0x90]
66# CHECK-EB:  ori $9, $6, 17767    # encoding: [0x51,0x26,0x45,0x67]
67# CHECK-EB:  xor $3, $3, $5       # encoding: [0x00,0xa3,0x1b,0x10]
68# CHECK-EB:  xori  $9, $6, 17767  # encoding: [0x71,0x26,0x45,0x67]
69# CHECK-EB:  xori  $9, $6, 17767  # encoding: [0x71,0x26,0x45,0x67]
70# CHECK-EB:  nor $9, $6, $7       # encoding: [0x00,0xe6,0x4a,0xd0]
71# CHECK-EB:  not $7, $8           # encoding: [0x00,0x08,0x3a,0xd0]
72# CHECK-EB:  mul $9, $6, $7       # encoding: [0x00,0xe6,0x4a,0x10]
73# CHECK-EB:  mult  $9, $7         # encoding: [0x00,0xe9,0x8b,0x3c]
74# CHECK-EB:  multu $9, $7         # encoding: [0x00,0xe9,0x9b,0x3c]
75# CHECK-EB: div  $zero, $9, $7    # encoding: [0x00,0xe9,0xab,0x3c]
76# CHECK-EB: divu $zero, $9, $7    # encoding: [0x00,0xe9,0xbb,0x3c]
77    add    $9, $6, $7
78    add    $9, $6, 17767
79    addu   $9, $6, -15001
80    addi   $9, $6, 17767
81    addiu  $9, $6,-15001
82    addu   $9, $6, $7
83    sub    $9, $6, $7
84    subu   $4, $3, $5
85    neg    $6, $7
86    negu   $6, $7
87    move   $7, $8
88    slt    $3, $3, $5
89    slt    $3, $3, 103
90    slti   $3, $3, 103
91    sltiu  $3, $3, 103
92    sltu   $3, $3, $5
93    lui    $9, 17767
94    and    $9, $6, $7
95    and    $9, $6, 17767
96    andi   $9, $6, 17767
97    or     $3, $4, $5
98    ori    $9, $6, 17767
99    xor    $3, $3, $5
100    xor    $9, $6, 17767
101    xori   $9, $6, 17767
102    nor    $9, $6, $7
103    nor    $7, $8, $zero
104    mul    $9, $6, $7
105    mult   $9, $7
106    multu  $9, $7
107    div    $0, $9, $7
108    divu   $0, $9, $7
109