forked from farbrausch/fr_public
-
Notifications
You must be signed in to change notification settings - Fork 2
/
depack2.asm
381 lines (305 loc) · 9.59 KB
/
depack2.asm
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
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
; dispack decoder
; ryg/farbrausch 2003
; I hereby place this code in the public domain.
bits 32
%define NBUFFERS 20
%define BUFFER dataArea.buffer
struc dataArea
.buffer resd NBUFFERS
.offset resd 1
.lastJump resd 1
.nextFunc resd 1
.jumpTable resd 1
.codebuf resb 1
.modrmbuf resb 1
._pad resb 2
.funcTable resd 256
.size:
endstruc
; ----------------------------------------------------------------------------
section .data
%define fNM 0x0
%define fAM 0x1
%define fMR 0x2
%define fMO 0x3
%define fMODE 0x3
%define fNI 0x0
%define fBI 0x4
%define fDI 0x8
%define fWI 0xc
%define fAD 0x0
%define fBR 0x4
%define fDR 0xc
%define fERR 0x0
; ----------------------------------------------------------------------------
DisUnfilter:
%if 1
push ebx
lodsd
push esi
add esi, eax
%endif
mov edi, 'DCOD'
mov ebx, edi
sub ebx, byte 4
mov [ebp+dataArea.offset], ebx
xor eax, eax
mov [ebp+dataArea.lastJump], eax
inc eax
mov [ebp+dataArea.nextFunc], eax
mov [ebp+dataArea.funcTable], eax
neg eax
mov [ebp+dataArea.jumpTable], eax
lea ebx, [esi+NBUFFERS*4]
xor ecx, ecx
.init lodsd
mov [ebp+BUFFER+ecx*4], ebx
add ebx, eax
inc ecx
cmp cl, NBUFFERS
jne .init
mov esi, [ebp+BUFFER+1*4]
xchg esi, [ebp+BUFFER]
.main cmp esi, [ebp+BUFFER]
%if 1
jne .chkjt ;.gotins
pop esi
pop ebx
pop eax
pop edi
;int3
stosd
push ebp
.imploop:
inc esi
lodsd
test eax, eax
jz .impend
xchg eax, edi
push esi
call [ebx]
test eax, eax
jz .imperr
xchg eax, ebp
.impfunc:
lodsb
test al, al
jnz .impfunc
cmp [esi], al
je .imploop
js .impord
push esi
.impget:
push ebp
call [ebx+4]
stosd
test eax, eax
jnz .impfunc
.imperr:
inc eax
pop ebx
pop ebx
ret
.impord:
inc esi
xor eax, eax
lodsw
push eax
jmp short .impget
.impend:
pop ebp
db 0xe9 ; jmp near
db 'ETRY'
%else
db 0x0f, 0x84 ; je near
db 'ETRY'
%endif
.chkjt cmp edi, [ebp+dataArea.jumpTable]
jb .gotins
jne .jtclr
xchg esi, [ebp+BUFFER+15*4]
lodsd
xchg eax, ecx
rep movsd
xchg esi, [ebp+BUFFER+15*4]
.jtclr or dword [ebp+dataArea.jumpTable], byte -1
jmp short .main
.gotins xor eax, eax
cmp [ebp+dataArea.nextFunc], eax
lodsb
je .testes
cmp al, 0xcc ; int3 (padding used by vc)
je .testes
lea ecx, [edi-4]
sub ecx, [ebp+dataArea.offset]
mov ebx, [ebp+dataArea.funcTable]
mov [ebp+dataArea.funcTable+ebx*4], ecx
.incm inc byte [ebp+dataArea.funcTable]
jz .incm
mov byte [ebp+dataArea.nextFunc], 0
.testes cmp al, 0xce ; escape
jne .noesc
movsb
jmp .main
.noesc stosb
xor edx, edx
cmp al, 0x66 ; operand size prefix
jne .nopfx
mov dh, 1
lodsb
stosb
.nopfx mov [ebp+dataArea.codebuf], al
mov bl, al
cmp bl, 0xcc
je .isret
sub bl, 0xc2
cmp bl, 1
ja .noret
.isret mov byte [ebp+dataArea.nextFunc], 1 ; inc?
.noret mov ebx, Tables + ('R'<<24) + ('P'<<16)
cmp al, 0x0f ; two-byte opcode
jne .notwo
lodsb
stosb
mov ah, 1
.notwo shr eax, 1 ; get flags
xlatb
jnc .flagok
shr al, 4
.flagok and al, 0xf
mov cl, al
test cl, fMR ; mod/rm follows?
jz near .nomdrm
lodsb
stosb
mov [ebp+dataArea.modrmbuf], al
mov ch, al
mov al, cl
and al, fMODE
cmp al, fMO
jne .noxtra
mov cl, fMR|fNI
test ch, 0x38
jnz .noxtra
mov bl, [edi-2]
test bl, 0x08
jnz .noxtra
add cl, fBI
test bl, 0x01
jz .noxtra
add cl, fDI-fBI
.noxtra and ch, 0xc7
cmp ch, 0xc4
je .nosib
mov al, ch
and al, 0x07
cmp al, 0x04
jne .nosib
xchg esi, [ebp+BUFFER+19*4]
movsb
xchg esi, [ebp+BUFFER+19*4]
.nosib mov dl, ch
and dl, 0xc0
cmp dl, 0x40
jne .nodis8
movzx ebx, ch
and bl, 0x07
xchg esi, [ebp+BUFFER+1*4+ebx*4]
movsb
xchg esi, [ebp+BUFFER+1*4+ebx*4]
.nodis8 cmp dl, 0x80
je .dis32
cmp ch, 0x05
je .dis32
test dl, dl
jnz .nomdrm
mov al, [edi-1]
and al, 0x07
cmp al, 0x05
jne .nomdrm
.dis32 xor ebx, ebx
cmp ch, 5
jne .nomr5
inc ebx
.nomr5 xchg esi, [ebp+BUFFER+13*4+ebx*4]
lodsd
xchg esi, [ebp+BUFFER+13*4+ebx*4]
bswap eax
stosd
cmp word [ebp+dataArea.codebuf], 0x24ff
jne .nomdrm
mov ebx, [ebp+dataArea.jumpTable]
cmp eax, ebx
jae .nomdrm
mov [ebp+dataArea.jumpTable], eax
.nomdrm mov al, cl
and al, fMODE
cmp al, fAM
jne near .noaddr
shr cl, 2
jnz .noad
xchg esi, [ebp+BUFFER+15*4]
movsd
xchg esi, [ebp+BUFFER+15*4]
jmp .main
.noad dec cl
jnz .dwdrl
xchg esi, [ebp+BUFFER+9*4]
movsb
xchg esi, [ebp+BUFFER+9*4]
jmp .main
.dwdrl xor ebx, ebx
cmp byte [edi-1], 0xe8
je .dwcal
xchg esi, [ebp+BUFFER+17*4]
lodsd
xchg esi, [ebp+BUFFER+17*4]
shr eax, 1
jnc .jmpnc
not eax
.jmpnc add eax, [ebp+dataArea.lastJump]
mov [ebp+dataArea.lastJump], eax
jmp short .storad
.dwcal xor eax, eax
xchg esi, [ebp+BUFFER+16*4]
lodsb
xchg esi, [ebp+BUFFER+16*4]
test al, al
jz .dcesc
mov eax, [ebp+dataArea.funcTable+eax*4]
jmp short .storad
.dcesc xchg esi, [ebp+BUFFER+18*4]
lodsd
xchg esi, [ebp+BUFFER+18*4]
mov ebx, [ebp+dataArea.funcTable]
mov [ebp+dataArea.funcTable+ebx*4], eax
.dcinc inc byte [ebp+dataArea.funcTable]
jz .dcinc
.storad sub eax, edi
add eax, [ebp+dataArea.offset]
stosd
jmp .main
.noaddr shr cl, 2
jz near .main
dec cl
jnz .dwow
xchg esi, [ebp+BUFFER+10*4]
movsb
xchg esi, [ebp+BUFFER+10*4]
jmp .main
.dwow dec cl
jnz .word
test dh, dh
jnz .word
xchg esi, [ebp+BUFFER+12*4]
movsd
xchg esi, [ebp+BUFFER+12*4]
jmp .main
.word xchg esi, [ebp+BUFFER+11*4]
movsw
xchg esi, [ebp+BUFFER+11*4]
jmp .main
Tables:
db "DEPACKTABLE"
times (256-($-Tables)) db 0
; the third table is implemented as code