X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=KernelLand%2FKernel%2Fmodules.c;h=cbcf859b3dacee167704b997cf3bda34e0671543;hb=9eadc33399e705035c33e8434a9644d91e44ed44;hp=b5e917c3f17c8a156a144a6658f43803fcab9d44;hpb=54fb220aa8587313d1e104673162c1f2e6989469;p=tpg%2Facess2.git diff --git a/KernelLand/Kernel/modules.c b/KernelLand/Kernel/modules.c index b5e917c3..cbcf859b 100644 --- a/KernelLand/Kernel/modules.c +++ b/KernelLand/Kernel/modules.c @@ -12,6 +12,7 @@ // === PROTOTYPES === int Module_int_Initialise(tModule *Module, const char *ArgString); +size_t Modules_int_PopulateBuiltins(tModule **Array); void Modules_int_GetBuiltinArray(void); void Modules_LoadBuiltins(void); void Modules_SetBuiltinParams(const char *Name, char *ArgString); @@ -202,59 +203,51 @@ int Module_int_Initialise(tModule *Module, const char *ArgString) LEAVE_RET('i', 0); } -/** - * \brief Scans the builtin modules and creates an array of them - */ -void Modules_int_GetBuiltinArray(void) +size_t Modules_int_PopulateBuiltins(tModule **Array) { - int i; - tModule *module; - - // Count - module = &gKernelModules; - i = 0; - while( (tVAddr)module < (tVAddr)&gKernelModulesEnd ) + size_t count = 0; + for( tModule *module = &gKernelModules; module < (tModule*)&gKernelModulesEnd; ) { if(module->Magic == MODULE_MAGIC) { - i ++; + if( Array ) { + Array[count] = module; + } + count ++; module ++; } - else + else { module = (void*)( (tVAddr)module + 4 ); + } } - - // Create - giNumBuiltinModules = i; - gasBuiltinModuleArgs = calloc( giNumBuiltinModules, sizeof(char*) ); - gapBuiltinModules = malloc( giNumBuiltinModules * sizeof(tModule*) ); - - - // Fill - module = &gKernelModules; - i = 0; - while( (tVAddr)module < (tVAddr)&gKernelModulesEnd ) + return count; +} + +/** + * \brief Scans the builtin modules and creates an array of them + */ +void Modules_int_GetBuiltinArray(void) +{ + if( !gapBuiltinModules ) { - if(module->Magic == MODULE_MAGIC) { - gapBuiltinModules[i] = module; - i ++; - module ++; - } - else - module = (void*)( (tVAddr)module + 4 ); + // Count + giNumBuiltinModules = Modules_int_PopulateBuiltins(NULL); + + // Create + gasBuiltinModuleArgs = calloc( giNumBuiltinModules, sizeof(char*) ); + gapBuiltinModules = malloc( giNumBuiltinModules * sizeof(tModule*) ); + + // Fill + Modules_int_PopulateBuiltins(gapBuiltinModules); } } /** * \brief Initialises builtin modules */ -void Modules_LoadBuiltins() +void Modules_LoadBuiltins(void) { - int i; - - if( !gapBuiltinModules ) - Modules_int_GetBuiltinArray(); - - for( i = 0; i < giNumBuiltinModules; i++ ) + Modules_int_GetBuiltinArray(); + for( int i = 0; i < giNumBuiltinModules; i++ ) { Module_int_Initialise( gapBuiltinModules[i], @@ -390,7 +383,7 @@ int Module_LoadFile(const char *Path, const char *ArgString) if( loader ) { - if( loader->Loader(base) ) + if( loader->Loader(base, ArgString) ) { Binary_Unload(base); return EINVAL;