From daa4f8c748d290feba8a71e889743a8a3097ad7d Mon Sep 17 00:00:00 2001 From: Amlal Date: Wed, 25 Sep 2024 08:26:08 +0200 Subject: Refactor codebase: Move Objects to obj/, fix flags, remove .vscode, add syscalls - Refactored Objects directory to obj/ for better organization. - Fixed incorrect flags in the build process. - Removed .vscode folder to clean up unnecessary IDE settings. - Added syscall implementations for enhanced functionality. Signed-off-by: Amlal --- dev/base/RunDLL64/build.json | 2 +- dev/base/RunDLL64/src/LauncherMain.cxx | 22 ---------------------- dev/base/RunDLL64/src/dll.cxx | 22 ++++++++++++++++++++++ 3 files changed, 23 insertions(+), 23 deletions(-) delete mode 100644 dev/base/RunDLL64/src/LauncherMain.cxx create mode 100644 dev/base/RunDLL64/src/dll.cxx (limited to 'dev/base/RunDLL64') diff --git a/dev/base/RunDLL64/build.json b/dev/base/RunDLL64/build.json index a69dbb11..c53373a9 100644 --- a/dev/base/RunDLL64/build.json +++ b/dev/base/RunDLL64/build.json @@ -8,7 +8,7 @@ "-ffreestanding", "-fno-rtti", "-fno-exceptions", - " -Wl,--subsystem=17" + "-Wl,--subsystem=17" ], "cpp_macros": [ "__RUNDLL_AMD64__", diff --git a/dev/base/RunDLL64/src/LauncherMain.cxx b/dev/base/RunDLL64/src/LauncherMain.cxx deleted file mode 100644 index ed1ab65c..00000000 --- a/dev/base/RunDLL64/src/LauncherMain.cxx +++ /dev/null @@ -1,22 +0,0 @@ -#include - -typedef int (*MainKind)(int, char**); - -int WinMain(int argc, char* argv[]) -{ - if (argc < 3) - return -1; - - auto mainDll = LdrOpenDLL(argv[1], argv[2]); - - int (*entrypointOff)(int, char**) = (MainKind)LdrGetDLLProc(argv[3], mainDll); - - if (!entrypointOff) - return -1; - - int ret = entrypointOff(argc, argv); - - LdrCloseDLL(mainDll); - - return ret; -} diff --git a/dev/base/RunDLL64/src/dll.cxx b/dev/base/RunDLL64/src/dll.cxx new file mode 100644 index 00000000..560a404d --- /dev/null +++ b/dev/base/RunDLL64/src/dll.cxx @@ -0,0 +1,22 @@ +#include + +typedef int (*MainKind)(int, char**); + +int main(int argc, char* argv[]) +{ + if (argc < 3) + return -1; + + auto mainDll = LdrOpenDLL(argv[1], argv[2]); + + int (*entrypointOff)(int, char**) = (MainKind)LdrGetDLLProc(argv[3], mainDll); + + if (!entrypointOff) + return -1; + + int ret = entrypointOff(argc, argv); + + LdrCloseDLL(mainDll); + + return ret; +} -- cgit v1.2.3