diff options
author | Anthony Liguori <aliguori@us.ibm.com> | 2009-05-14 17:57:31 -0500 |
---|---|---|
committer | Anthony Liguori <aliguori@us.ibm.com> | 2009-05-14 18:06:49 -0500 |
commit | f7897430950ee94fb2dc4d6a5ca658d4909d9d85 (patch) | |
tree | 9d94be3c723a473f529074becb19cad654664ca7 | |
parent | 4af396115a1722dfaf8f7d4ecee59202dd7d5ea8 (diff) |
Fix module initialization when more than 1 class is in use
Now that we're using enums for module types, it makes no sense to bother keeping
a list of module types when we know exactly how many they are.
Switching to an array simplifies the code and eliminates the aforementioned bug.
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
-rw-r--r-- | module.c | 57 | ||||
-rw-r--r-- | module.h | 5 |
2 files changed, 26 insertions, 36 deletions
@@ -22,44 +22,36 @@ typedef struct ModuleEntry TAILQ_ENTRY(ModuleEntry) node; } ModuleEntry; -typedef struct ModuleTypeList -{ - module_init_type type; - TAILQ_HEAD(, ModuleEntry) entry_list; - TAILQ_ENTRY(ModuleTypeList) node; -} ModuleTypeList; +typedef TAILQ_HEAD(, ModuleEntry) ModuleTypeList; -static TAILQ_HEAD(, ModuleTypeList) init_type_list; +static ModuleTypeList init_type_list[MODULE_INIT_MAX]; -static ModuleTypeList *find_type_or_alloc(module_init_type type, int alloc) +static void init_types(void) { - ModuleTypeList *n; + static int inited; + int i; - TAILQ_FOREACH(n, &init_type_list, node) { - if (type >= n->type) - break; + if (inited) { + return; } - if (!n || n->type != type) { - ModuleTypeList *o; + for (i = 0; i < MODULE_INIT_MAX; i++) { + TAILQ_INIT(&init_type_list[i]); + } - if (!alloc) - return NULL; + inited = 1; +} - o = qemu_mallocz(sizeof(*o)); - o->type = type; - TAILQ_INIT(&o->entry_list); - if (n) { - TAILQ_INSERT_AFTER(&init_type_list, n, o, node); - } else { - TAILQ_INSERT_HEAD(&init_type_list, o, node); - } +static ModuleTypeList *find_type(module_init_type type) +{ + ModuleTypeList *l; - n = o; - } + init_types(); + + l = &init_type_list[type]; - return n; + return l; } void register_module_init(void (*fn)(void), module_init_type type) @@ -70,9 +62,9 @@ void register_module_init(void (*fn)(void), module_init_type type) e = qemu_mallocz(sizeof(*e)); e->init = fn; - l = find_type_or_alloc(type, 1); + l = find_type(type); - TAILQ_INSERT_TAIL(&l->entry_list, e, node); + TAILQ_INSERT_TAIL(l, e, node); } void module_call_init(module_init_type type) @@ -80,12 +72,9 @@ void module_call_init(module_init_type type) ModuleTypeList *l; ModuleEntry *e; - l = find_type_or_alloc(type, 0); - if (!l) { - return; - } + l = find_type(type); - TAILQ_FOREACH(e, &l->entry_list, node) { + TAILQ_FOREACH(e, l, node) { e->init(); } } @@ -17,12 +17,13 @@ /* This should not be used directly. Use block_init etc. instead. */ #define module_init(function, type) \ static void __attribute__((constructor)) do_qemu_init_ ## function(void) { \ - register_module_init(function, type); \ + register_module_init(function, type); \ } typedef enum { MODULE_INIT_BLOCK, - MODULE_INIT_DEVICE + MODULE_INIT_DEVICE, + MODULE_INIT_MAX } module_init_type; #define block_init(function) module_init(function, MODULE_INIT_BLOCK) |