mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-11 21:05:28 +00:00
331 lines
6.9 KiB
NASM
331 lines
6.9 KiB
NASM
|
; Date : 27-1-1989
|
|||
|
; Ver : 1.04
|
|||
|
; Program : Kill the Brain Virus
|
|||
|
Cseg Segment Para Public 'MyCode'
|
|||
|
Assume cs:Cseg,ds:Cseg
|
|||
|
Org 100h
|
|||
|
Start: Mov dx,offset CRight ;print copyright notice
|
|||
|
Call DispStr
|
|||
|
Mov ah,19h ;get current drive
|
|||
|
Int 21h
|
|||
|
Mov Drive,al ;save it
|
|||
|
Call GetDrive ;Get drive if possible
|
|||
|
Jc Exit
|
|||
|
Call ChVirus ;virus present?
|
|||
|
Jc Exit ;exit if not
|
|||
|
Call FindBoot ;Find correct boot sector
|
|||
|
Mov dx,offset VirusKill
|
|||
|
Call DispStr
|
|||
|
Call ReadFats ;Read the FAT tables
|
|||
|
Jc Exit
|
|||
|
Call CheckBad
|
|||
|
Exit: Mov ax,4C00h
|
|||
|
Int 21h
|
|||
|
FindBoot Proc
|
|||
|
Mov dl,[si+6]
|
|||
|
Mov ax,18 ;9 sectors/track * 2 sides
|
|||
|
Mov cl,[si+8]
|
|||
|
Mul cl
|
|||
|
Or dl,dl
|
|||
|
Jz Fb1
|
|||
|
Add ax,10 ;Move to the next side
|
|||
|
Fb1: Mov dx,ax ;read this sector
|
|||
|
Mov cx,1 ;Read one sector
|
|||
|
Mov bx,offset PrgEnd ;Read it here
|
|||
|
Mov al,Drive ;Get drive number
|
|||
|
Int 25h ;Read interrupt
|
|||
|
Jnc Fb2
|
|||
|
Add sp,2
|
|||
|
Mov dx,offset MesOh1
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
Fb2: Add sp,2
|
|||
|
Xor dx,dx ;Write at boot
|
|||
|
Mov cx,1 ;Write one sector
|
|||
|
Mov bx,offset PrgEnd ;Write from here
|
|||
|
Mov al,Drive ;Get drive number
|
|||
|
Int 26h ;Write interrupt
|
|||
|
Jnc Fb3
|
|||
|
Add sp,2
|
|||
|
Mov dx,offset MesOh2 ;Print message
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
Fb3: Add sp,2
|
|||
|
Clc
|
|||
|
Ret
|
|||
|
FindBoot Endp
|
|||
|
PointTo Proc
|
|||
|
Push bx
|
|||
|
Mov dx,ax
|
|||
|
Add ax,ax
|
|||
|
Add ax,dx
|
|||
|
Mov dx,ax
|
|||
|
Shr ax,1 ;Cluster * 1.5
|
|||
|
Mov bx,offset PrgEnd
|
|||
|
Add bx,ax
|
|||
|
Mov ax,ds:[bx] ;Get entry
|
|||
|
Test dx,1
|
|||
|
Jnz Point1
|
|||
|
And ax,0FFFh
|
|||
|
Jmp short Point0
|
|||
|
Point1: Shr ax,1
|
|||
|
Shr ax,1
|
|||
|
Shr ax,1
|
|||
|
Shr ax,1
|
|||
|
Point0: Pop bx
|
|||
|
Ret
|
|||
|
PointTo Endp
|
|||
|
ReadFats Proc
|
|||
|
Mov bx,offset PrgEnd
|
|||
|
Mov al,Drive
|
|||
|
Mov cx,4 ;read FAT1 and FAT2
|
|||
|
Mov dx,1 ;FAT sectors
|
|||
|
Int 25h ;Read FAT tables
|
|||
|
Jnc Rf1
|
|||
|
Add sp,2
|
|||
|
Mov dx,offset FatError
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
Rf1: Add sp,2
|
|||
|
Clc
|
|||
|
Ret
|
|||
|
ReadFats Endp
|
|||
|
|
|||
|
CheckBad Proc
|
|||
|
Call FindBad ;Find real boot sector
|
|||
|
Call WriteFats
|
|||
|
Exit1: Ret
|
|||
|
CheckBad Endp
|
|||
|
FindBad Proc
|
|||
|
Mov cx,354 ;Check 354 clusters
|
|||
|
Mov ax,2 ;start with cluster 2
|
|||
|
Mov bx,ax
|
|||
|
FM: Call PointTo ;Find where it points
|
|||
|
Cmp ax,0FF7h ;Is it bad?
|
|||
|
Jz ChkBd ;Check if realy bad
|
|||
|
FindMore1: Inc bx
|
|||
|
Mov ax,bx
|
|||
|
Loop FM
|
|||
|
Ret
|
|||
|
ChkBd: Push ax
|
|||
|
Call CheckCluster ;bx=cluster number, try to read
|
|||
|
Pop ax
|
|||
|
Jmp short FindMore1
|
|||
|
FindBad Endp
|
|||
|
WriteFats Proc
|
|||
|
Mov bx,offset PrgEnd
|
|||
|
Mov al,Drive
|
|||
|
Mov cx,4 ;FAT1 and FAT2
|
|||
|
Mov dx,1 ;Start of FAT sectors
|
|||
|
Int 26h ;Write FAT tables
|
|||
|
Jnc Wf1 ;Jump if not fail
|
|||
|
Add sp,2
|
|||
|
Mov dx,offset MesOh3 ;Write error
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
Wf1: Add sp,2
|
|||
|
Clc
|
|||
|
Ret
|
|||
|
WriteFats Endp
|
|||
|
CheckCluster Proc
|
|||
|
Push bx
|
|||
|
Push cx
|
|||
|
Sub bx,2
|
|||
|
Sal bx,1
|
|||
|
Add bx,12 ;bx=sector number
|
|||
|
Mov dx,bx ;sector
|
|||
|
Mov cx,2 ;2 sectors
|
|||
|
Mov bx,offset PrgEnd+205
|
|||
|
Mov al,Drive
|
|||
|
Int 25h ;Read sectors
|
|||
|
Jnc QRc1
|
|||
|
Add sp,2
|
|||
|
Mov al,2 ;err 2=try more
|
|||
|
Pop cx
|
|||
|
Pop bx
|
|||
|
Ret
|
|||
|
QRc1: Add sp,2
|
|||
|
Pop cx
|
|||
|
Pop bx ;Mark cluster bx as not bad
|
|||
|
Mov ax,bx
|
|||
|
Push bx
|
|||
|
Mov dx,ax
|
|||
|
Add ax,ax
|
|||
|
Add ax,dx
|
|||
|
Mov dx,ax
|
|||
|
Shr ax,1 ;Cluster * 1.5
|
|||
|
Mov bx,offset PrgEnd
|
|||
|
Add bx,ax
|
|||
|
Mov ax,ds:[bx] ;Get entry
|
|||
|
Test dx,1
|
|||
|
Jnz QPo1
|
|||
|
And ax,0F000h
|
|||
|
Jmp short QPo2
|
|||
|
QPo1: And ax,000Fh
|
|||
|
QPo2: Mov ds:[bx],ax ;Write entry to FAT1
|
|||
|
Mov ds:[bx+1024],ax ;Write entry to FAT2
|
|||
|
Pop bx
|
|||
|
Ret
|
|||
|
CheckCluster Endp
|
|||
|
|
|||
|
ChVirus Proc
|
|||
|
Call ReadBoot ;Read the boot sector
|
|||
|
Jnc ChVirus1
|
|||
|
Ret
|
|||
|
ChVirus1: Mov si,offset PrgEnd
|
|||
|
Mov dx,offset MesBad ;Assume bad news
|
|||
|
Cmp word ptr [si+4],1234h
|
|||
|
Jz InThere
|
|||
|
Mov dx,offset MesGood ;Assume all OK
|
|||
|
Mov di,436 ;Vector of interrupt 13h
|
|||
|
Push es
|
|||
|
Xor ax,ax
|
|||
|
Mov es,ax
|
|||
|
Mov ax,es:[di+2] ;get segment of the interrupt
|
|||
|
Pop es
|
|||
|
Cmp ax,0C800h
|
|||
|
Jb InThere
|
|||
|
Mov dx,offset MesBad1 ;active now!
|
|||
|
Call DispStr
|
|||
|
Mov bx,offset PrgEnd
|
|||
|
Mov ah,2 ;Read
|
|||
|
Mov al,1 ;1 sector
|
|||
|
Mov dl,Drive
|
|||
|
Xor dh,dh ;head number
|
|||
|
Xor ch,ch ;track number
|
|||
|
Mov cl,1 ;sector 1
|
|||
|
Int 6Dh ;Virus uses interrupt 6Dh
|
|||
|
Mov si,offset PrgEnd
|
|||
|
Mov dx,offset MesBad
|
|||
|
Cmp word ptr [si+4],1234h
|
|||
|
Jz InThere1
|
|||
|
Mov dx,offset MesGood
|
|||
|
Call DispStr
|
|||
|
Stc ;No need to do more.
|
|||
|
Ret
|
|||
|
InThere: Call DispStr
|
|||
|
Clc ;Do more
|
|||
|
Ret
|
|||
|
InThere1: Call DispStr ;write bad news
|
|||
|
Mov dx,offset MesBad2 ;No lasting effect
|
|||
|
Jmp short InThere
|
|||
|
ChVirus Endp
|
|||
|
ReadBoot Proc
|
|||
|
Mov bx,offset PrgEnd ;Put it here
|
|||
|
Mov al,Drive ;Drive to use
|
|||
|
Mov cx,1 ;One sector
|
|||
|
Xor dx,dx ;Boot sector
|
|||
|
Int 25h ;Read it
|
|||
|
Jnc P0
|
|||
|
Add sp,2
|
|||
|
Mov dx,offset MesBoot
|
|||
|
Cmp ah,80h ;Time-out?
|
|||
|
Jz P1
|
|||
|
Mov dx,offset MesBoot1
|
|||
|
P1: Call DispStr
|
|||
|
Stc ;Error
|
|||
|
Ret ;Go
|
|||
|
P0: Add sp,2
|
|||
|
Clc ;No error
|
|||
|
Ret ;Go
|
|||
|
ReadBoot Endp
|
|||
|
GetDrive Proc
|
|||
|
Mov si,80h
|
|||
|
Mov cl,[si] ;Get length of command tail
|
|||
|
Xor ch,ch
|
|||
|
Or cx,cx
|
|||
|
Jnz Lab1
|
|||
|
Cmp byte ptr Drive,2
|
|||
|
Jae DriveError1
|
|||
|
Clc
|
|||
|
Ret
|
|||
|
Lab1: Add si,cx
|
|||
|
Inc si
|
|||
|
Mov byte ptr [si],0 ;Command ends with 0
|
|||
|
Mov si,81h
|
|||
|
Cld
|
|||
|
SpOut: Lodsb
|
|||
|
Cmp al,32
|
|||
|
Jz SpOut ;Skip blanks
|
|||
|
Or al,al
|
|||
|
Jnz Stan1
|
|||
|
Ret
|
|||
|
|
|||
|
Stan1: Lodsb
|
|||
|
Or al,al
|
|||
|
Jnz Check1
|
|||
|
Ret
|
|||
|
Check1: Cmp al,':'
|
|||
|
Jnz Stan1
|
|||
|
Cmp si,84h
|
|||
|
DriveCheck: Jb DriveError
|
|||
|
Mov al,[si-2]
|
|||
|
And al,223 ;Convert to upper case
|
|||
|
Cmp al,'A'
|
|||
|
Jb DriveError1
|
|||
|
Cmp al,'B'
|
|||
|
Ja DriveError1
|
|||
|
Sub al,65 ;Convert drive to 0 or 1
|
|||
|
Mov Drive,al
|
|||
|
Clc
|
|||
|
Ret
|
|||
|
DriveError: Mov dx,offset Err8 ;Drive expected
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
DriveError1: Mov dx,offset Err9 ;Invalid drive
|
|||
|
Call DispStr
|
|||
|
Stc
|
|||
|
Ret
|
|||
|
GetDrive Endp
|
|||
|
DispStr Proc
|
|||
|
Mov ah,9
|
|||
|
Int 21h
|
|||
|
Ret
|
|||
|
DispStr Endp
|
|||
|
|
|||
|
CRight db 13,10
|
|||
|
db 'Kill the <Brain> virus Ver 1.04, 27-1-1989',13,10
|
|||
|
db '(C) Fragakis Stelios 1988,1989',13,10,13,10,'$'
|
|||
|
|
|||
|
|
|||
|
Err8 db 'Error 8 : Drive expected.$'
|
|||
|
Err9 db 'Error 9 : Invalid drive specified. Must be A or B.$'
|
|||
|
MesBoot db 13,10
|
|||
|
db 'Program execution aborted. Door open?',13,10,'$'
|
|||
|
MesBoot1 db 13,10
|
|||
|
db 'I can not read the boot sector.',13,10
|
|||
|
db 'Disk can not contain the virus <Brain>.',13,10,'$'
|
|||
|
FatError db 13,10
|
|||
|
db 'Sorry, I can not read the FAT tables.',13,10
|
|||
|
db 'FAT corrections not written to disk.',13,10,'$'
|
|||
|
VirusKill db 'Virus <Brain> was successfully killed.',13,10,'$'
|
|||
|
MesOh1 db 'DISK ERROR : I can not read the correct boot sector.'
|
|||
|
db 13,10,'$'
|
|||
|
MesOh2 db 'Failed to write correct boot sector in boot area.'
|
|||
|
db 13,10,'$'
|
|||
|
MesOh3 db 'Failed to write FAT tables. Corrections lost.'
|
|||
|
db 13,10,'$'
|
|||
|
MesGood db 'Good News : The disk is not <Brain> contaminated.'
|
|||
|
db 13,10,'$'
|
|||
|
MesBad db 'Bad News : The disk is <Brain> contaminated.'
|
|||
|
db 13,10,'$'
|
|||
|
|
|||
|
MesBad1 db '* WARNING *',13,10
|
|||
|
db 'Virus <Brain> is active right now !',13,10,'$'
|
|||
|
|
|||
|
MesBad2 db 13,10
|
|||
|
db 'Remove the disk after the virus is killed',13,10
|
|||
|
db 'to avoid the risk of contamination.',13,10,13,10,'$'
|
|||
|
|
|||
|
Count db 0 ;Count 0..58
|
|||
|
Drive db 0 ;Current drive
|
|||
|
|
|||
|
PrgEnd:
|
|||
|
Cseg Ends
|
|||
|
End Start
|
|||
|
|