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 /module.h | |
parent | 4af396115a1722dfaf8f7d4ecee59202dd7d5ea8 (diff) | |
download | qemu-f7897430950ee94fb2dc4d6a5ca658d4909d9d85.zip qemu-f7897430950ee94fb2dc4d6a5ca658d4909d9d85.tar.gz qemu-f7897430950ee94fb2dc4d6a5ca658d4909d9d85.tar.bz2 |
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>
Diffstat (limited to 'module.h')
-rw-r--r-- | module.h | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -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) |