mirror of
https://github.com/wiiu-env/WUMSLoader.git
synced 2025-01-26 15:05:35 +01:00
Reduce the amount for logs
This commit is contained in:
parent
4eff524ab3
commit
b560e1d2ba
1
.gitignore
vendored
1
.gitignore
vendored
@ -10,3 +10,4 @@ relocator.h
|
|||||||
.idea/
|
.idea/
|
||||||
cmake-build-debug/
|
cmake-build-debug/
|
||||||
*.txt
|
*.txt
|
||||||
|
build1/
|
||||||
|
@ -40,7 +40,7 @@ extern "C" int _start(int argc, char **argv) {
|
|||||||
|
|
||||||
doStart(argc, argv);
|
doStart(argc, argv);
|
||||||
|
|
||||||
DEBUG_FUNCTION_LINE("Call real one\n");
|
DEBUG_FUNCTION_LINE_VERBOSE("Call real one\n");
|
||||||
return ((int (*)(int, char **)) (*(unsigned int *) 0x1005E040))(argc, argv);
|
return ((int (*)(int, char **)) (*(unsigned int *) 0x1005E040))(argc, argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,7 +78,7 @@ bool doRelocation(std::vector<RelocationData> &relocData, relocation_trampolin_e
|
|||||||
if (moduleCache.count(rplName) == 0) {
|
if (moduleCache.count(rplName) == 0) {
|
||||||
OSDynLoad_Error err = OSDynLoad_IsModuleLoaded(rplName.c_str(), &rplHandle);
|
OSDynLoad_Error err = OSDynLoad_IsModuleLoaded(rplName.c_str(), &rplHandle);
|
||||||
if (err != OS_DYNLOAD_OK || rplHandle == nullptr) {
|
if (err != OS_DYNLOAD_OK || rplHandle == nullptr) {
|
||||||
DEBUG_FUNCTION_LINE("%s is not yet loaded\n", rplName.c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("%s is not yet loaded\n", rplName.c_str());
|
||||||
// only acquire if not already loaded.
|
// only acquire if not already loaded.
|
||||||
err = OSDynLoad_Acquire(rplName.c_str(), &rplHandle);
|
err = OSDynLoad_Acquire(rplName.c_str(), &rplHandle);
|
||||||
if (err != OS_DYNLOAD_OK) {
|
if (err != OS_DYNLOAD_OK) {
|
||||||
@ -111,7 +111,7 @@ bool ResolveRelocations(std::vector<ModuleData> &loadedModules, bool skipMemoryM
|
|||||||
bool wasSuccessful = true;
|
bool wasSuccessful = true;
|
||||||
|
|
||||||
for (auto &curModule : loadedModules) {
|
for (auto &curModule : loadedModules) {
|
||||||
DEBUG_FUNCTION_LINE("Let's do the relocations for %s\n", curModule.getExportName().c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("Let's do the relocations for %s\n", curModule.getExportName().c_str());
|
||||||
if (wasSuccessful) {
|
if (wasSuccessful) {
|
||||||
std::vector<RelocationData> relocData = curModule.getRelocationDataList();
|
std::vector<RelocationData> relocData = curModule.getRelocationDataList();
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ bool ResolveRelocations(std::vector<ModuleData> &loadedModules, bool skipMemoryM
|
|||||||
// to fully support our memory region, we have to run the FunctionPatcher and MemoryMapping
|
// to fully support our memory region, we have to run the FunctionPatcher and MemoryMapping
|
||||||
// once with the default heap. Afterwards we can just rely on the custom heap.
|
// once with the default heap. Afterwards we can just rely on the custom heap.
|
||||||
bool skipAllocFunction = skipMemoryMappingModule && (curModule.getExportName() == "homebrew_memorymapping" || curModule.getExportName() == "homebrew_functionpatcher");
|
bool skipAllocFunction = skipMemoryMappingModule && (curModule.getExportName() == "homebrew_memorymapping" || curModule.getExportName() == "homebrew_functionpatcher");
|
||||||
DEBUG_FUNCTION_LINE("Skip alloc replace? %d\n", skipAllocFunction);
|
DEBUG_FUNCTION_LINE_VERBOSE("Skip alloc replace? %d\n", skipAllocFunction);
|
||||||
if (!doRelocation(relocData, gModuleData->trampolines, DYN_LINK_TRAMPOLIN_LIST_LENGTH, skipAllocFunction)) {
|
if (!doRelocation(relocData, gModuleData->trampolines, DYN_LINK_TRAMPOLIN_LIST_LENGTH, skipAllocFunction)) {
|
||||||
DEBUG_FUNCTION_LINE("FAIL\n");
|
DEBUG_FUNCTION_LINE("FAIL\n");
|
||||||
wasSuccessful = false;
|
wasSuccessful = false;
|
||||||
@ -154,7 +154,7 @@ extern "C" void doStart(int argc, char **argv) {
|
|||||||
bool applicationEndHookLoaded = false;
|
bool applicationEndHookLoaded = false;
|
||||||
for (auto &curModule : loadedModules) {
|
for (auto &curModule : loadedModules) {
|
||||||
if (curModule.getExportName() == "homebrew_applicationendshook") {
|
if (curModule.getExportName() == "homebrew_applicationendshook") {
|
||||||
DEBUG_FUNCTION_LINE("We have ApplicationEndsHook Module!\n");
|
DEBUG_FUNCTION_LINE_VERBOSE("We have ApplicationEndsHook Module!\n");
|
||||||
applicationEndHookLoaded = true;
|
applicationEndHookLoaded = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -171,11 +171,11 @@ extern "C" void doStart(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_FUNCTION_LINE("Number of modules %d\n", gModuleData->number_used_modules);
|
DEBUG_FUNCTION_LINE_VERBOSE("Number of modules %d\n", gModuleData->number_used_modules);
|
||||||
if (!gInitCalled) {
|
if (!gInitCalled) {
|
||||||
gInitCalled = 1;
|
gInitCalled = 1;
|
||||||
|
|
||||||
DEBUG_FUNCTION_LINE("Resolve relocations without replacing alloc functions\n");
|
DEBUG_FUNCTION_LINE_VERBOSE("Resolve relocations without replacing alloc functions\n");
|
||||||
ResolveRelocations(loadedModules, true);
|
ResolveRelocations(loadedModules, true);
|
||||||
|
|
||||||
for (auto &curModule : loadedModules) {
|
for (auto &curModule : loadedModules) {
|
||||||
@ -186,15 +186,15 @@ extern "C" void doStart(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_FUNCTION_LINE("Relocations done\n");
|
DEBUG_FUNCTION_LINE_VERBOSE("Relocations done\n");
|
||||||
CallHook(loadedModules, WUMS_HOOK_RELOCATIONS_DONE);
|
CallHook(loadedModules, WUMS_HOOK_RELOCATIONS_DONE);
|
||||||
|
|
||||||
|
|
||||||
for (int i = 0; i < gModuleData->number_used_modules; i++) {
|
for (int i = 0; i < gModuleData->number_used_modules; i++) {
|
||||||
if (!gModuleData->module_data[i].skipEntrypoint) {
|
if (!gModuleData->module_data[i].skipEntrypoint) {
|
||||||
DEBUG_FUNCTION_LINE("About to call %08X\n", gModuleData->module_data[i].entrypoint);
|
DEBUG_FUNCTION_LINE_VERBOSE("About to call %08X\n", gModuleData->module_data[i].entrypoint);
|
||||||
int ret = ((int (*)(int, char **)) (gModuleData->module_data[i].entrypoint))(argc, argv);
|
int ret = ((int (*)(int, char **)) (gModuleData->module_data[i].entrypoint))(argc, argv);
|
||||||
DEBUG_FUNCTION_LINE("return code was %d\n", ret);
|
DEBUG_FUNCTION_LINE_VERBOSE("return code was %d\n", ret);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -206,7 +206,7 @@ extern "C" void doStart(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
DEBUG_FUNCTION_LINE("Resolve relocations and replace alloc functions\n");
|
DEBUG_FUNCTION_LINE_VERBOSE("Resolve relocations and replace alloc functions\n");
|
||||||
ResolveRelocations(loadedModules, false);
|
ResolveRelocations(loadedModules, false);
|
||||||
CallHook(loadedModules, WUMS_HOOK_RELOCATIONS_DONE);
|
CallHook(loadedModules, WUMS_HOOK_RELOCATIONS_DONE);
|
||||||
}
|
}
|
||||||
@ -229,7 +229,7 @@ std::vector<ModuleData> OrderModulesByDependencies(const std::vector<ModuleData>
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
canBreak = false;
|
canBreak = false;
|
||||||
DEBUG_FUNCTION_LINE("Check if we can load %s\n", curModule.getExportName().c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("Check if we can load %s\n", curModule.getExportName().c_str());
|
||||||
std::vector<std::string> importsFromOtherModules;
|
std::vector<std::string> importsFromOtherModules;
|
||||||
for (auto curReloc: curModule.getRelocationDataList()) {
|
for (auto curReloc: curModule.getRelocationDataList()) {
|
||||||
std::string curRPL = curReloc.getImportRPLInformation().getName();
|
std::string curRPL = curReloc.getImportRPLInformation().getName();
|
||||||
@ -237,7 +237,7 @@ std::vector<ModuleData> OrderModulesByDependencies(const std::vector<ModuleData>
|
|||||||
if (std::find(importsFromOtherModules.begin(), importsFromOtherModules.end(), curRPL) != importsFromOtherModules.end()) {
|
if (std::find(importsFromOtherModules.begin(), importsFromOtherModules.end(), curRPL) != importsFromOtherModules.end()) {
|
||||||
// is already in vector
|
// is already in vector
|
||||||
} else {
|
} else {
|
||||||
DEBUG_FUNCTION_LINE("%s is importing from %s\n", curModule.getExportName().c_str(), curRPL.c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("%s is importing from %s\n", curModule.getExportName().c_str(), curRPL.c_str());
|
||||||
importsFromOtherModules.push_back(curRPL);
|
importsFromOtherModules.push_back(curRPL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -247,14 +247,14 @@ std::vector<ModuleData> OrderModulesByDependencies(const std::vector<ModuleData>
|
|||||||
if (std::find(loadedModulesExportNames.begin(), loadedModulesExportNames.end(), curImportRPL) != loadedModulesExportNames.end()) {
|
if (std::find(loadedModulesExportNames.begin(), loadedModulesExportNames.end(), curImportRPL) != loadedModulesExportNames.end()) {
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
DEBUG_FUNCTION_LINE("We can't load the module, because %s is not loaded yet\n", curImportRPL.c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("We can't load the module, because %s is not loaded yet\n", curImportRPL.c_str());
|
||||||
canLoad = false;
|
canLoad = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (canLoad) {
|
if (canLoad) {
|
||||||
weDidSomething = true;
|
weDidSomething = true;
|
||||||
DEBUG_FUNCTION_LINE("We can load: %s\n", curModule.getExportName().c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("We can load: %s\n", curModule.getExportName().c_str());
|
||||||
finalOrder.push_back(curModule);
|
finalOrder.push_back(curModule);
|
||||||
loadedModulesExportNames.push_back(curModule.getExportName());
|
loadedModulesExportNames.push_back(curModule.getExportName());
|
||||||
loadedModulesEntrypoints.push_back(curModule.getEntrypoint());
|
loadedModulesEntrypoints.push_back(curModule.getEntrypoint());
|
||||||
|
@ -11,7 +11,7 @@ static const char **hook_names = (const char *[]) {
|
|||||||
"WUMS_HOOK_RELOCATIONS_DONE"};
|
"WUMS_HOOK_RELOCATIONS_DONE"};
|
||||||
|
|
||||||
void CallHook(const std::vector<ModuleData> &modules, wums_hook_type_t type) {
|
void CallHook(const std::vector<ModuleData> &modules, wums_hook_type_t type) {
|
||||||
DEBUG_FUNCTION_LINE("Calling hook of type %s [%d] for all modules\n", hook_names[type], type);
|
DEBUG_FUNCTION_LINE_VERBOSE("Calling hook of type %s [%d] for all modules\n", hook_names[type], type);
|
||||||
for (auto &curModule: modules) {
|
for (auto &curModule: modules) {
|
||||||
CallHook(curModule, type);
|
CallHook(curModule, type);
|
||||||
}
|
}
|
||||||
@ -24,7 +24,7 @@ void CallHook(const ModuleData &module, wums_hook_type_t type) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ((type == WUMS_HOOK_INIT_WUT || type == WUMS_HOOK_FINI_WUT) && module.isSkipWUTInit()) {
|
if ((type == WUMS_HOOK_INIT_WUT || type == WUMS_HOOK_FINI_WUT) && module.isSkipWUTInit()) {
|
||||||
DEBUG_FUNCTION_LINE("Skip WUMS_HOOK_INIT_WUT/WUMS_HOOK_FINI_WUT for %s\n", module.getExportName().c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("Skip WUMS_HOOK_INIT_WUT/WUMS_HOOK_FINI_WUT for %s\n", module.getExportName().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -40,12 +40,12 @@ void CallHook(const ModuleData &module, wums_hook_type_t type) {
|
|||||||
type == WUMS_HOOK_APPLICATION_ENDS ||
|
type == WUMS_HOOK_APPLICATION_ENDS ||
|
||||||
type == WUMS_HOOK_INIT_WUT ||
|
type == WUMS_HOOK_INIT_WUT ||
|
||||||
type == WUMS_HOOK_FINI_WUT)) {
|
type == WUMS_HOOK_FINI_WUT)) {
|
||||||
DEBUG_FUNCTION_LINE("Calling hook of type %s [%d] %d for %s \n", hook_names[type], type, curHook.getType(), module.getExportName().c_str());
|
DEBUG_FUNCTION_LINE_VERBOSE("Calling hook of type %s [%d] %d for %s \n", hook_names[type], type, curHook.getType(), module.getExportName().c_str());
|
||||||
((void (*)()) ((uint32_t *) func_ptr))();
|
((void (*)()) ((uint32_t *) func_ptr))();
|
||||||
break;
|
break;
|
||||||
} else if (type == WUMS_HOOK_INIT ||
|
} else if (type == WUMS_HOOK_INIT ||
|
||||||
type == WUMS_HOOK_RELOCATIONS_DONE) {
|
type == WUMS_HOOK_RELOCATIONS_DONE) {
|
||||||
DEBUG_FUNCTION_LINE("Calling hook of type %s [%d] %d for %s\n", hook_names[type], type, curHook.getType(), module.getExportName().c_str(), gModuleData);
|
DEBUG_FUNCTION_LINE_VERBOSE("Calling hook of type %s [%d] %d for %s\n", hook_names[type], type, curHook.getType(), module.getExportName().c_str(), gModuleData);
|
||||||
wums_app_init_args_t args;
|
wums_app_init_args_t args;
|
||||||
args.module_information = gModuleData;
|
args.module_information = gModuleData;
|
||||||
((void (*)(wums_app_init_args_t *)) ((uint32_t *) func_ptr))(&args);
|
((void (*)(wums_app_init_args_t *)) ((uint32_t *) func_ptr))(&args);
|
||||||
|
@ -33,6 +33,8 @@ void OSFatal_printf(const char *format, ...);
|
|||||||
log_printf("[%23s]%30s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
log_printf("[%23s]%30s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define DEBUG_FUNCTION_LINE_VERBOSE(FMT, ARGS...) while(0)
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user