2018-09-19 23:19:03 +00:00
|
|
|
#pragma option OST
|
|
|
|
#pragma option ON
|
|
|
|
#pragma option cri-
|
|
|
|
#pragma option -CPA
|
|
|
|
#initallvar 0
|
|
|
|
#jumptomain FALSE
|
|
|
|
|
|
|
|
#startaddress 0x0000
|
|
|
|
|
|
|
|
#code32 TRUE
|
|
|
|
|
|
|
|
char os_name[8] = {'M','E','N','U','E','T','0','1'};
|
|
|
|
dword os_version = 0x00000001;
|
|
|
|
dword start_addr = #main;
|
|
|
|
dword final_addr = #______STOP______+32;
|
|
|
|
dword alloc_mem = 20000;
|
|
|
|
dword x86esp_reg = 20000;
|
|
|
|
dword I_Param = #param;
|
|
|
|
dword I_Path = #program_path;
|
|
|
|
char param[4096] ={0};
|
|
|
|
char program_path[4096] = {0};
|
|
|
|
|
|
|
|
|
|
|
|
:dword mallocSystem(dword size)
|
|
|
|
{
|
|
|
|
$push ebx
|
|
|
|
$push ecx
|
|
|
|
|
|
|
|
$mov eax, 68
|
|
|
|
$mov ebx, 12
|
|
|
|
$mov ecx, size
|
|
|
|
$int 0x40
|
|
|
|
|
|
|
|
$pop ecx
|
|
|
|
$pop ebx
|
|
|
|
return EAX;
|
|
|
|
}
|
|
|
|
|
2018-09-21 09:20:49 +00:00
|
|
|
:dword __offsetAllocData = 0;
|
|
|
|
:dword __limitAllocSize = 0;
|
|
|
|
:dword __sizeFullAllocMemory = 0;
|
2018-09-19 23:19:03 +00:00
|
|
|
:dword malloc(dword size)
|
|
|
|
{
|
|
|
|
dword orderSize = 1;
|
|
|
|
dword order = 0;
|
|
|
|
dword stackAlloc = 0;
|
|
|
|
dword stackKey = 0;
|
|
|
|
dword result = 0;
|
2018-09-21 09:20:49 +00:00
|
|
|
IF(!__offsetAllocData) __offsetAllocData = mallocSystem(4*40);
|
2018-09-19 23:19:03 +00:00
|
|
|
size+=4;
|
2018-09-21 09:20:49 +00:00
|
|
|
order = __offsetAllocData;
|
2018-09-19 23:19:03 +00:00
|
|
|
WHILE(orderSize<size)
|
|
|
|
{
|
|
|
|
orderSize<<=1;
|
2018-09-21 09:20:49 +00:00
|
|
|
order+=4;
|
2018-09-19 23:19:03 +00:00
|
|
|
}
|
2018-09-21 09:20:49 +00:00
|
|
|
__sizeFullAllocMemory += orderSize;
|
2018-09-19 23:19:03 +00:00
|
|
|
IF(!DSDWORD[order])
|
|
|
|
{
|
|
|
|
stackAlloc = mallocSystem(4*50);
|
|
|
|
DSDWORD[order] = stackAlloc;
|
|
|
|
DSDWORD[stackAlloc] = stackAlloc;
|
|
|
|
}
|
|
|
|
ELSE stackAlloc = DSDWORD[order];
|
|
|
|
|
|
|
|
stackKey = DSDWORD[stackAlloc];
|
|
|
|
IF(stackKey == stackAlloc)
|
|
|
|
{
|
|
|
|
result = mallocSystem(orderSize);
|
|
|
|
DSDWORD[result] = orderSize;
|
|
|
|
return result+4;
|
|
|
|
}
|
|
|
|
ELSE
|
|
|
|
{
|
|
|
|
result = DSDWORD[stackKey];
|
|
|
|
DSDWORD[stackAlloc] = stackKey-4;
|
|
|
|
return result+4;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
:dword free(dword ptr)
|
|
|
|
{
|
|
|
|
dword array = 0;
|
|
|
|
dword orderSize = 1;
|
|
|
|
dword order = 0;
|
|
|
|
dword stackAlloc = 0;
|
|
|
|
dword stackKey = 0;
|
|
|
|
dword result = 0;
|
|
|
|
dword size = 0;
|
2018-09-21 09:20:49 +00:00
|
|
|
IF(!__offsetAllocData) return 0;
|
2018-09-19 23:19:03 +00:00
|
|
|
size = DSDWORD[ptr-4];
|
2018-09-21 09:20:49 +00:00
|
|
|
order = __offsetAllocData;
|
2018-09-19 23:19:03 +00:00
|
|
|
WHILE(orderSize!=size)
|
|
|
|
{
|
|
|
|
orderSize<<=1;
|
2018-09-21 09:20:49 +00:00
|
|
|
order+=4;
|
2018-09-19 23:19:03 +00:00
|
|
|
}
|
|
|
|
stackAlloc = DSDWORD[order];
|
|
|
|
DSDWORD[stackAlloc] += 4;
|
|
|
|
stackKey = DSDWORD[stackAlloc];
|
|
|
|
DSDWORD[stackKey] = ptr-4;
|
|
|
|
}
|
|
|
|
|
2018-09-21 09:20:49 +00:00
|
|
|
:dword realloc(dword oldMem,size)
|
2018-09-19 23:19:03 +00:00
|
|
|
{
|
|
|
|
dword newMem = 0;
|
|
|
|
dword oldSize = 0;
|
|
|
|
dword ptr1 = 0;
|
|
|
|
dword ptr2 = 0;
|
2018-09-21 09:20:49 +00:00
|
|
|
IF(!oldMem) RETURN malloc(size);
|
2018-09-19 23:19:03 +00:00
|
|
|
newMem = malloc(size);
|
2018-09-21 09:20:49 +00:00
|
|
|
oldSize = DSDWORD[oldMem-4] - 4;
|
|
|
|
ptr1 = oldMem;
|
2018-09-19 23:19:03 +00:00
|
|
|
ptr2 = newMem;
|
|
|
|
WHILE(oldSize)
|
|
|
|
{
|
|
|
|
DSBYTE[ptr2] = DSBYTE[ptr1];
|
|
|
|
ptr1++;
|
|
|
|
ptr2++;
|
|
|
|
oldSize--;
|
|
|
|
}
|
2018-09-21 09:20:49 +00:00
|
|
|
free(oldMem);
|
2018-09-19 23:19:03 +00:00
|
|
|
RETURN newMem;
|
|
|
|
}
|
|
|
|
|
|
|
|
void main()
|
|
|
|
{
|
|
|
|
dword o1 = 0;
|
|
|
|
dword o2 = 0;
|
|
|
|
dword o3 = 0;
|
|
|
|
while(1)
|
|
|
|
{
|
|
|
|
o1 = malloc(1000);
|
|
|
|
o2 = malloc(10000);
|
|
|
|
o3 = malloc(1000);
|
|
|
|
o1 = realloc(o3,2000);
|
|
|
|
free(o2);
|
|
|
|
free(o1);
|
|
|
|
free(o3);
|
|
|
|
}
|
|
|
|
|
|
|
|
EAX = -1;
|
|
|
|
$int 0x40;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
______STOP______:
|