WUMSLoader/relocator/src/ModuleDataPersistence.cpp

79 lines
3.5 KiB
C++
Raw Normal View History

2020-04-28 14:43:07 +02:00
#include "ModuleDataPersistence.h"
#include "DynamicLinkingHelper.h"
#include "../../source/common/module_defines.h"
#include "../../source/module/ModuleData.h"
#include "../../source/module/RelocationData.h"
2020-04-28 14:43:07 +02:00
#include <coreinit/cache.h>
#include <wums.h>
2020-04-28 14:43:07 +02:00
2020-05-17 19:05:51 +02:00
std::vector<ModuleData> ModuleDataPersistence::loadModuleData(module_information_t *moduleInformation) {
std::vector<ModuleData> result;
2020-05-17 19:05:51 +02:00
if (moduleInformation == NULL) {
2020-04-28 14:43:07 +02:00
DEBUG_FUNCTION_LINE("moduleInformation == NULL\n");
return result;
}
2020-05-17 19:05:51 +02:00
DCFlushRange((void *) moduleInformation, sizeof(module_information_t));
ICInvalidateRange((void *) moduleInformation, sizeof(module_information_t));
2020-04-28 14:43:07 +02:00
int32_t module_count = moduleInformation->number_used_modules;
2020-05-17 19:05:51 +02:00
if (module_count > MAXIMUM_MODULES) {
DEBUG_FUNCTION_LINE("moduleInformation->module_count was bigger then allowed. %d > %d. Limiting to %d\n", module_count, MAXIMUM_MODULES, MAXIMUM_MODULES);
2020-04-28 14:43:07 +02:00
module_count = MAXIMUM_MODULES;
}
2020-05-17 19:05:51 +02:00
for (int32_t i = 0; i < module_count; i++) {
2020-04-28 14:43:07 +02:00
// Copy data from struct.
2020-05-17 19:05:51 +02:00
module_information_single_t *module_data = &(moduleInformation->module_data[i]);
ModuleData moduleData;
moduleData.setBSSLocation(module_data->bssAddr, module_data->bssSize);
moduleData.setSBSSLocation(module_data->sbssAddr, module_data->sbssSize);
moduleData.setEntrypoint(module_data->entrypoint);
moduleData.setStartAddress(module_data->startAddress);
moduleData.setEndAddress(module_data->endAddress);
2020-04-28 14:43:07 +02:00
moduleData.setExportName(module_data->module_export_name);
for (uint32_t j = 0; j < EXPORT_ENTRY_LIST_LENGTH; j++) {
export_data_t *export_entry = &(module_data->export_entries[j]);
if (export_entry->address == NULL) {
continue;
}
moduleData.addExportData(ExportData(static_cast<wums_entry_type_t>(export_entry->type), export_entry->name, reinterpret_cast<const void *>(export_entry->address)));
}
2020-05-17 19:05:51 +02:00
for (uint32_t j = 0; j < DYN_LINK_RELOCATION_LIST_LENGTH; j++) {
dyn_linking_relocation_entry_t *linking_entry = &(module_data->linking_entries[j]);
if (linking_entry->destination == NULL) {
2020-04-28 14:43:07 +02:00
break;
}
2020-05-17 19:05:51 +02:00
dyn_linking_import_t *importEntry = linking_entry->importEntry;
if (importEntry == NULL) {
2020-04-28 14:43:07 +02:00
DEBUG_FUNCTION_LINE("importEntry was NULL, skipping relocation entry\n");
continue;
}
2020-05-17 19:05:51 +02:00
if (importEntry->importName == NULL) {
2020-04-28 14:43:07 +02:00
DEBUG_FUNCTION_LINE("importEntry->importName was NULL, skipping relocation entry\n");
continue;
}
2020-05-17 19:05:51 +02:00
dyn_linking_function_t *functionEntry = linking_entry->functionEntry;
2020-04-28 14:43:07 +02:00
2020-05-17 19:05:51 +02:00
if (functionEntry == NULL) {
2020-04-28 14:43:07 +02:00
DEBUG_FUNCTION_LINE("functionEntry was NULL, skipping relocation entry\n");
continue;
}
2020-05-17 19:05:51 +02:00
if (functionEntry->functionName == NULL) {
2020-04-28 14:43:07 +02:00
DEBUG_FUNCTION_LINE("functionEntry->functionName was NULL, skipping relocation entry\n");
continue;
}
ImportRPLInformation rplInfo(importEntry->importName, importEntry->isData);
RelocationData reloc(linking_entry->type, linking_entry->offset, linking_entry->addend, linking_entry->destination, functionEntry->functionName, rplInfo);
moduleData.addRelocationData(reloc);
2020-04-28 14:43:07 +02:00
}
result.push_back(moduleData);
}
return result;
}