During early boot, put_module_image() will no longer unload anything when

there is no boot device available - this will prevent modules from getting
lost.
Added a comment to open_module_list() about its limitations while booting.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@8170 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2004-06-26 01:40:46 +00:00
parent 00641fbdd8
commit a8441c4fd2

View File

@ -157,6 +157,8 @@ static const char * const sModulePaths[] = {
static hash_table *sModuleImagesHash; static hash_table *sModuleImagesHash;
static hash_table *sModulesHash; static hash_table *sModulesHash;
extern dev_t gBootDevice;
/** calculates hash for a module using its name */ /** calculates hash for a module using its name */
@ -336,7 +338,10 @@ put_module_image(module_image *image)
int32 refCount = atomic_add(&image->ref_count, -1); int32 refCount = atomic_add(&image->ref_count, -1);
ASSERT(refCount > 0); ASSERT(refCount > 0);
if (refCount == 1 && !image->keep_loaded) // Don't unload anything when there is no boot device yet
// (because chances are that we will never be able to access it again)
if (refCount == 1 && !image->keep_loaded && gBootDevice > 0)
unload_module_image(image, NULL); unload_module_image(image, NULL);
} }
@ -785,6 +790,7 @@ iterator_get_next_module(module_iterator *iterator, char *buffer, size_t *_buffe
for (i = iterator->module_offset; sBuiltInModules[i] != NULL; i++) { for (i = iterator->module_offset; sBuiltInModules[i] != NULL; i++) {
// the module name must fit the prefix // the module name must fit the prefix
dprintf(":: compare: \"%s\" <-> \"%s\" (%ld)\n", iterator->prefix, sBuiltInModules[i]->name, iterator->prefix_length);
if (strncmp(sBuiltInModules[i]->name, iterator->prefix, iterator->prefix_length)) if (strncmp(sBuiltInModules[i]->name, iterator->prefix, iterator->prefix_length))
continue; continue;
@ -1072,6 +1078,12 @@ module_init(kernel_args *args)
* contain all modules available under the prefix. * contain all modules available under the prefix.
* The structure is then used by read_next_module_name(), and * The structure is then used by read_next_module_name(), and
* must be freed by calling close_module_list(). * must be freed by calling close_module_list().
*
* During early boot, when there is no boot device accessible,
* it will only find built-in modules, not those that have
* been preloaded - use get_next_loaded_module_name() instead
* if you need to have a list of loaded modules.
* ToDo: this could be changed
*/ */
void * void *