[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / Mips / micromips-eva.s
blobd856ec1ba10b8a63bb4ec0aea4bf2449dbf1db2b
1 # RUN: llvm-mc %s -triple=mipsel -show-encoding -show-inst -mcpu=mips32r2 \
2 # RUN: -mattr=+micromips,+eva | FileCheck -check-prefix=CHECK-EL %s
3 # RUN: llvm-mc %s -triple=mips -show-encoding -show-inst -mcpu=mips32r2 \
4 # RUN: -mattr=+micromips,+eva | FileCheck -check-prefix=CHECK-EB %s
5 # Check that the assembler can handle the documented syntax
6 # for EVA instructions.
7 #------------------------------------------------------------------------------
8 # microMIPS EVA Instructions
9 #------------------------------------------------------------------------------
10 # Little endian
11 #------------------------------------------------------------------------------
12 # CHECK-EL: prefe 1, 8($5) # encoding: [0x25,0x60,0x08,0xa4]
13 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} PREFE_MM
14 # CHECK-EL: cachee 1, 8($5) # encoding: [0x25,0x60,0x08,0xa6]
15 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} CACHEE_MM
16 # CHECK-EL: lle $2, 8($4) # encoding: [0x44,0x60,0x08,0x6c]
17 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LLE_MM
18 # CHECK-EL: sce $2, 8($4) # encoding: [0x44,0x60,0x08,0xac]
19 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SCE_MM
20 # CHECK-EL: swre $24, 5($3) # encoding: [0x03,0x63,0x05,0xa2]
21 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SWRE_MM
22 # CHECK-EL: swle $24, 5($3) # encoding: [0x03,0x63,0x05,0xa0]
23 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SWLE_MM
24 # CHECK-EL: lwre $24, 5($3) # encoding: [0x03,0x63,0x05,0x66]
25 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LWRE_MM
26 # CHECK-EL: lwle $24, 2($4) # encoding: [0x04,0x63,0x02,0x64]
27 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LWLE_MM
28 # CHECK-EL: lhue $4, 8($2) # encoding: [0x82,0x60,0x08,0x62]
29 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LHuE_M
30 # CHECK-EL: lbe $4, 8($2) # encoding: [0x82,0x60,0x08,0x68]
31 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LBE_MM
32 # CHECK-EL: lbue $4, 8($2) # encoding: [0x82,0x60,0x08,0x60]
33 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LBuE_MM
34 # CHECK-EL: lhe $4, 8($2) # encoding: [0x82,0x60,0x08,0x6a]
35 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LHE_MM
36 # CHECK-EL: lwe $4, 8($2) # encoding: [0x82,0x60,0x08,0x6e]
37 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} LWE_MM
38 # CHECK-EL: sbe $5, 8($4) # encoding: [0xa4,0x60,0x08,0xa8]
39 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SBE_MM
40 # CHECK-EL: she $5, 8($4) # encoding: [0xa4,0x60,0x08,0xaa]
41 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SHE_MM
42 # CHECK-EL: swe $5, 8($4) # encoding: [0xa4,0x60,0x08,0xae]
43 # CHECK-EL-NEXT: # <MCInst #{{[0-9]+}} SWE_MM
44 #------------------------------------------------------------------------------
45 # Big endian
46 #------------------------------------------------------------------------------
47 # CHECK-EB: prefe 1, 8($5) # encoding: [0x60,0x25,0xa4,0x08]
48 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} PREFE_MM
49 # CHECK-EB: cachee 1, 8($5) # encoding: [0x60,0x25,0xa6,0x08]
50 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} CACHEE_MM
51 # CHECK-EB: lle $2, 8($4) # encoding: [0x60,0x44,0x6c,0x08]
52 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LLE_MM
53 # CHECK-EB: sce $2, 8($4) # encoding: [0x60,0x44,0xac,0x08]
54 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SCE_MM
55 # CHECK-EB: swre $24, 5($3) # encoding: [0x63,0x03,0xa2,0x05]
56 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SWRE_MM
57 # CHECK-EB: swle $24, 5($3) # encoding: [0x63,0x03,0xa0,0x05]
58 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SWLE_MM
59 # CHECK-EB: lwre $24, 5($3) # encoding: [0x63,0x03,0x66,0x05]
60 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LWRE_MM
61 # CHECK-EB: lwle $24, 2($4) # encoding: [0x63,0x04,0x64,0x02]
62 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LWLE_MM
63 # CHECK-EB: lhue $4, 8($2) # encoding: [0x60,0x82,0x62,0x08]
64 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LHuE_MM
65 # CHECK-EB: lbe $4, 8($2) # encoding: [0x60,0x82,0x68,0x08]
66 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LBE_MM
67 # CHECK-EB: lbue $4, 8($2) # encoding: [0x60,0x82,0x60,0x08]
68 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LBuE_MM
69 # CHECK-EB: lhe $4, 8($2) # encoding: [0x60,0x82,0x6a,0x08]
70 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LHE_MM
71 # CHECK-EB: lwe $4, 8($2) # encoding: [0x60,0x82,0x6e,0x08]
72 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} LWE_MM
73 # CHECK-EB: sbe $5, 8($4) # encoding: [0x60,0xa4,0xa8,0x08]
74 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SBE_MM
75 # CHECK-EB: she $5, 8($4) # encoding: [0x60,0xa4,0xaa,0x08]
76 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SHE_MM
77 # CHECK-EB: swe $5, 8($4) # encoding: [0x60,0xa4,0xae,0x08]
78 # CHECK-EB-NEXT: # <MCInst #{{[0-9]+}} SWE_MM
80 prefe 1, 8($5)
81 cachee 1, 8($5)
82 lle $2, 8($4)
83 sce $2, 8($4)
84 swre $24, 5($3)
85 swle $24, 5($3)
86 lwre $24, 5($3)
87 lwle $24, 2($4)
88 lhue $4, 8($2)
89 lbe $4, 8($2)
90 lbue $4, 8($2)
91 lhe $4, 8($2)
92 lwe $4, 8($2)
93 sbe $5, 8($4)
94 she $5, 8($4)
95 swe $5, 8($4)