2020-04-28 14:43:07 +02:00
# include "ModuleDataPersistence.h"
# include "DynamicLinkingHelper.h"
2020-04-29 12:05:39 +02:00
# include "../../source/common/module_defines.h"
2020-04-29 12:35:13 +02:00
# include "../../source/module/ModuleData.h"
# include "../../source/module/RelocationData.h"
2020-04-28 14:43:07 +02:00
# include <coreinit/cache.h>
2020-05-17 19:05:51 +02:00
std : : vector < ModuleData > ModuleDataPersistence : : loadModuleData ( module_information_t * moduleInformation ) {
2020-05-17 13:11:52 +02:00
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 ] ) ;
2020-05-17 13:11:52 +02:00
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
2020-05-29 17:30:10 +02:00
moduleData . setExportName ( module_data - > module_export_name ) ;
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 ;
}
2020-05-17 13:11:52 +02:00
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 ;
}