Skip to content

FusixGit/MemoryModule

 
 

Repository files navigation

MemoryModule

The Windows API functions such as LoadLibrary and LoadLibraryEx doesn't allow to load modules from memory. This project implements it.

The base project is located at: https://github.com/fancycode/MemoryModule

Currently there are changes in progress which would allow to start EXE files from memory.

Change log:

15.02.16 - Implemented command line arguments support before EntryPoint execution. The thread running inside MemoryModule is marked with custom ProcessParameters from _PEB. Hooks were implemented (using import method) to isolate important functions from the main process. !The module cannot be seen in the process module list!

16.02.16 - Some TLS fixes.

19.02.16 - TryFreeMem function was introduced along with bForceMemFree flag to force free memory which is already allocated. !Use this only if you don't need the functionality of the main process, because of possible errors!

Issues:

  1. When the .reloc table is missing and is impossible to allocate memory at ImageBase the module cannot be started.

По-русски:

Функции, которые используются для загрузки модулей (LoadLibrary, LoadLibraryEx) не поддерживают загрузку модулей из памяти. Данный модуль реализует эту функцию.

Основа была взята с репозитория: https://github.com/fancycode/MemoryModule

Вносятся правки которые позволяют полноценно запускать EXE из памяти.

История:

15.02.16 - Реализована возможность указания командной строки перед запуском EntryPoint. Поток, исполняющийся внутри MemoryModule маркируется изменением значения ProcessParameters в _PEB. Производится перехват (методом импорта) некоторых важных функций для изоляции от основного процесса. !Модуль не учитывается в списке модулей процесса!

16.02.16 - Некоторые фиксы в TLS.

19.02.16 - Введена функция TryFreeMem и флаг bForceMemFree для "насильного" освобождения памяти в случае её занятости. !Использовать, только если основной процесс больше не будет использоваться, иначе могут быть ошибки!

Проблемы:

  1. При отсутствии таблицы .reloc и невозможности выделить нужную память по ImageBase запуск модуля становится невозможным.

Usage sample / Пример запуска:

	wchar_t ModuleName[64+1];
	memset(ModuleName, 0x00, (64+1)*2);

	GetModuleFileNameW(NULL, ModuleName, 64);

	HMODULE hThisModule = GetModuleHandle(L"MyDllOrExe.dll");

	HRSRC hResInfo = FindResource(hThisModule, MAKEINTRESOURCE(IDR_EXE1), RT_RCDATA);
	HGLOBAL hRes = LoadResource(hThisModule, hResInfo);
	char *resData = (char*)LockResource(hRes);

	IMAGE_DOS_HEADER *hDOS = (IMAGE_DOS_HEADER*)resData;
	IMAGE_NT_HEADERS32 *hNT = (IMAGE_NT_HEADERS32*)(resData+hDOS->e_lfanew);

	HMEMORYMODULE hM = MemoryLoadLibrary(resData, hNT->OptionalHeader.SizeOfImage, true);
	hResInfo = FindResource(hThisModule, MAKEINTRESOURCE(IDR_PARAMS1), RT_RCDATA);
	hRes = LoadResource(hThisModule, hResInfo);
	wchar_t *CommandLine = (wchar_t*)LockResource(hRes);

	MEMORYMODULE_START_ARGS moduleStartArgs;	// Startup struct
	moduleStartArgs.EntryPoint = NULL;		// Start func address. If NULL - is EntryPoint
	moduleStartArgs.CommandLine = CommandLine;	// CommandLine
	moduleStartArgs.InThread = true;		// Run in new thread
	MemoryCallEntryPoint(hM, &moduleStartArgs);	// CALL

About

Library to load a DLL from memory.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 73.3%
  • C++ 20.1%
  • Makefile 3.4%
  • CMake 2.5%
  • Other 0.7%