about summary refs log tree commit diff stats
path: root/test/arch/mips32/arch.py
blob: 0509f033f5e4344d366e7836d323fd760c9f08e4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
from __future__ import print_function
import time
from pdb import pm

from miasm.core.utils import decode_hex, encode_hex
from miasm.core.locationdb import LocationDB
from miasm.arch.mips32.arch import *

loc_db = LocationDB()

reg_tests_mips32 = [
    ("004496D8    ADDU       GP, GP, T9",
     "0399E021"),
    ("004496DC    ADDIU      SP, SP, 0xFFFFFDA0",
     "27BDFDA0"),
    ("0449724     NOP        ",
     "00000000"),
    ('00449734    ADDIU      A0, ZERO, 0xA',
     "2404000A"),
    ('00400320    LUI        V1, 0x7FF0',
     "3C037FF0"),
    ('00400350    ORI        V1, V1, 0x1',
     "34630001"),
    ('00400304    SUBU       A0, ZERO, T1',
     "00092023"),
    ("0040031C    OR         A0, A0, T2",
     "008A2025"),
    ("00400344    AND        A1, A2, A1",
     "00C52824"),
    ("00400348    SRL        V0, V0, 0x1F",
     "000217C2"),
    ("00400354    SLTU       V0, V0, V1",
     "0043102B"),
    ("00400374    SRA        V0, T3, 0x1E",
     "000B1783"),
    ("004002F0    SW         RA, 0x1C(SP)",
     "AFBF001C"),
    ("XXXXXXXX    SW         RA, (SP)",
     "AFBF0000"),
    ("004002FC    MFC1       T1, F14",
     "44097000"),
    ("00400324    MOV.D      F0, F12",
     "46206006"),
    ("00400334    BNE        A0, ZERO, 0x2C",
     "1480000A"),
    ("00400360    B          0x33C",
     "100000CE"),
    ("00400378    LW         T9, 0xFFFF9C90(GP)",
     "8F999C90"),
    ("00400384    JR         T9",
     "03200008"),
    ("0040038C    ANDI       V0, V0, 0x2",
     "30420002"),
    ("00400364    ADD.D      F0, F0, F14",
     "462E0000"),
    ("004003A4    BEQ        S0, V0, 0x124",
     "12020048"),
    ("004003A8    SLTI       V0, S0, 0x3",
     "2A020003"),
    ("004005A4    BGEZ       T3, 0x24",
     "05610008"),
    ("00400428    LWC1       F0, 0x4344(V0)",
     "C4404344"),
    ("004005D0    JALR       T9, RA",
     "0320F809"),
    ("00400500    MTC1       ZERO, F0",
     "44800000"),
    ("004005D4    DIV.D      F12, F0, F14",
     "462E0303"),
    ("0040062C    XOR        V0, A2, A0",
     "00C41026"),
    ("00400684    SUB.D      F0, F12, F0",
     "46206001"),
    ("00400148    LBU        V0, 0xFFFF8880(S1)",
     "92228880"),
    ("004001C4    SB         V0, 0xFFFF8880(S1)",
     "A2228880"),
    ("00400274    BAL        0x8",
     "04110001"),
    ("0040073C    C.LT.D     FCC0, F0, F12",
     "462C003C"),
    ("00400744    BC1F       FCC0, 0x24",
     "45000008"),
    ("00403A80    BC1T       FCC0, 0xB8",
     "4501002D"),
    ("00400764    MUL.D      F12, F0, F0",
     "46200302"),
    ("004007C8    SLL        V1, A2, 0x3",
     "000618C0"),
    ("00400E28    SWC1       F26, 0x5C(SP)",
     "E7BA005C"),
    ("00400EA8    SLT        V0, V1, S2",
     "0072102A"),
    ("00400F30    SUBU       V0, V0, V1",
     "00431023"),
    ("00400F34    SRLV       V1, A1, V0",
     "00451806"),
    ("00400F38    SLLV       V0, V1, V0",
     "00431004"),
    ("00400F60    SRAV       V1, S3, V0",
     "00531807"),
    ("00401040    BLTZ       S6, 0x5C",
     "06C00016"),
    ("00400D18    BLEZ       V1, 0x80",
     "1860001F"),
    ("00401200    BGTZ       S4, 0x14",
     "1E800004"),
    ("004014A4    CVT.D.W    F8, F0",
     "46800221"),
    ("00400864    CVT.W.D    F0, F2",
     "46201024"),
    ("00401748    NOR        A3, ZERO, A3",
     "00073827"),
    ("00403E6C    BREAK      0x1C00",
     "0007000D"),
    ("00405744    SYSCALL    0x0",
     "0000000C"),
    ("004095A4    LH         V0, (V0)",
     "84420000"),
    ("0040ACBC    LB         V0, 0x1(A1)",
     "80A20001"),
    ("00412A34    DIV        A0, V1",
     "0083001A"),
    ("00419ED8    LWL        T0, (A1)",
     "88A80000"),
    ("00419FA4    LWL        T0, (A1)",
     "88A80000"),
    ("0041A024    SWL        A1, (A0)",
     "A8850000"),
    ("0044E194    SWR        V0, 0x3(A0)",
     "B8820003"),
    ("00433974    CVT.S.D    F0, F0",
     "46200020"),


    ("0044A120    MULT       V1, V0",
     "00620018"),
    ("00404194    MULTU      A1, V1",
     "00A30019"),
    ("00403E68    DIVU       V0, T1",
     "0049001B"),
    ("00403E70    MFLO       T4",
     "00006012"),
    ("004040CC    MFHI       A0",
     "00002010"),

    ("00401748    NOR        A3, ZERO, A3",
     "00073827"),

    ("8BA1025C    MTC0       T0, WATCHHI",
     "40889800"),
    ("8BA10260    MTC0       ZERO, WATCHHI",
     "40809800"),
    ("8BA10264    MTC0       ZERO, CAUSE",
     "40806800"),
    ("8BA0FD68    MTC0       V0, ENTRYLO0",
     "40821000"),
    ("8BA0FD70    MTC0       V0, ENTRYLO1",
     "40821800"),
    ("8BA0FD78    MTC0       V0, PAGEMASK",
     "40822800"),
    ("8BA0FD94    MTC0       V1, ENTRYHI",
     "40835000"),


    ("8BA0FDA8    MFC0       V0, INDEX",
     "40020000"),
    ("8BA10268    MFC0       T0, CONFIG",
     "40088000"),
    ("8BA0FBD4    MFC0       V0, COUNT",
     "40024800"),
    ("800001F8    EXT        V0, V1, 0x10, 0x3",
     "7C621400 "),

    ("80000318    J          0x1E0",
     "08000078"),

    ("8BA0F0C0    LHU        V1, 0x20(SP)",
     "97A30020"),

    ("8BA0F168    MUL        V0, V1, S0",
     "70701002"),
    ("8BA0F288    MOVN       A2, T0, V0",
     "0102300B"),

    ("8BA0F32C    XORI       V1, V1, 0x11",
     "38630011"),
    ("8BA0F37C    SEB        S6, V0",
     "7C02B420"),
    ("XXXXXXXX    SEH        V0, A3",
     "7c071620"),
    ("8BA0F468    DI         ZERO",
     "41606000"),
    ("XXXXXXXX    EI         ZERO",
     "41606020"),
    ("8BA0F78C    WSBH       V1, V1",
     "7C0318A0"),
    ("8BA0F790    ROTR       V1, V1, 0x10",
     "00231C02"),

    ("8BA0F794    SLTIU      V0, V1, 0x5",
     "2C620005"),
    ("8BA0FDA0    TLBP       ",
     "42000008"),
    ("8BA0FDC0    TLBWI      ",
     "42000002"),
    ("8BA10124    INS        A0, A1, 0x0, 0x8",
     "7CA43804"),

    ("XXXXXXXX    MOVZ       S0, T1, A2",
     "0126800a"),
    ("XXXXXXXX    JAL        0x7C0B0AC",
     "0df02c2b"),

    ("XXXXXXXX    LDC1       F22, 0xFFFF9148(V0)",
     "D4569148"),

    ("XXXXXXXX    BEQL       S0, V0, 0x124",
     "52020048"),
    ("XXXXXXXX    BGEZL      T3, 0x24",
     "05630008"),
    ("XXXXXXXX    BNEL       A0, ZERO, 0x2C",
     "5480000A"),
    ("XXXXXXXX    BLTZL      S6, 0x5C",
     "06C20016"),
    ("XXXXXXXX    BLEZL      V1, 0x80",
     "5860001F"),
    ("XXXXXXXX    BGTZL      S4, 0x14",
     "5E800004"),
    ("XXXXXXXX    BC1FL      FCC0, 0x24",
     "45020008"),
    ("XXXXXXXX    BC1TL      FCC0, 0xB8",
     "4503002D"),

    ("XXXXXXXX    CLZ        K0, K1",
     "737AD020"),

    ("XXXXXXXX    LL         A0, 0x123(A1)",
     "C0A40123"),
    ("XXXXXXXX    SC         A1, 0x123(A0)",
     "E0850123"),

    ("XXXXXXXX    SYNC       0x19",
     "0000064F"),
    ("XXXXXXXX    TLBR       ",
     "42000001"),

    ("XXXXXXXX    ERET       ",
     "42000018"),

    ("XXXXXXXX    MTHI       A0",
     "00800011"),
    ("XXXXXXXX    MTLO       A1",
     "00A00013")
]


ts = time.time()
def h2i(s):
    return decode_hex(s.replace(' ', ''))

for s, l in reg_tests_mips32:
    print("-" * 80)
    s = s[12:]
    b = h2i((l))
    mn = mn_mips32.dis(b, 'b')
    print([str(x) for x in mn.args])
    print(s)
    print(mn)
    assert(str(mn) == s)
    l = mn_mips32.fromstring(s, loc_db, 'b')
    assert(str(l) == s)
    a = mn_mips32.asm(l, 'b')
    print([x for x in a])
    print(repr(b))
    assert(b in a)
    print(l.to_html())