2 * QEMU Module Infrastructure
4 * Copyright IBM, Corp. 2009
7 * Anthony Liguori <aliguori@us.ibm.com>
9 * This work is licensed under the terms of the GNU GPL, version 2. See
10 * the COPYING file in the top-level directory.
18 #define DSO_STAMP_FUN glue(qemu_stamp, CONFIG_STAMP)
19 #define DSO_STAMP_FUN_STR stringify(DSO_STAMP_FUN)
22 void DSO_STAMP_FUN(void);
23 /* This is a dummy symbol to identify a loaded DSO as a QEMU module, so we can
24 * distinguish "version mismatch" from "not a QEMU module", when the stamp
25 * check fails during module loading */
26 void qemu_module_dummy(void);
28 #define module_init(function, type) \
29 static void __attribute__((constructor)) do_qemu_init_ ## function(void) \
31 register_dso_module_init(function, type); \
34 /* This should not be used directly. Use block_init etc. instead. */
35 #define module_init(function, type) \
36 static void __attribute__((constructor)) do_qemu_init_ ## function(void) \
38 register_module_init(function, type); \
43 MODULE_INIT_MIGRATION
,
48 MODULE_INIT_XEN_BACKEND
,
50 MODULE_INIT_FUZZ_TARGET
,
54 #define block_init(function) module_init(function, MODULE_INIT_BLOCK)
55 #define opts_init(function) module_init(function, MODULE_INIT_OPTS)
56 #define type_init(function) module_init(function, MODULE_INIT_QOM)
57 #define trace_init(function) module_init(function, MODULE_INIT_TRACE)
58 #define xen_backend_init(function) module_init(function, \
59 MODULE_INIT_XEN_BACKEND)
60 #define libqos_init(function) module_init(function, MODULE_INIT_LIBQOS)
61 #define fuzz_target_init(function) module_init(function, \
62 MODULE_INIT_FUZZ_TARGET)
63 #define migration_init(function) module_init(function, MODULE_INIT_MIGRATION)
64 #define block_module_load(lib, errp) module_load("block-", lib, errp)
65 #define ui_module_load(lib, errp) module_load("ui-", lib, errp)
66 #define audio_module_load(lib, errp) module_load("audio-", lib, errp)
68 void register_module_init(void (*fn
)(void), module_init_type type
);
69 void register_dso_module_init(void (*fn
)(void), module_init_type type
);
71 void module_call_init(module_init_type type
);
74 * module_load: attempt to load a module from a set of directories
76 * directories searched are:
77 * - getenv("QEMU_MODULE_DIR")
78 * - get_relocated_path(CONFIG_QEMU_MODDIR);
79 * - /var/run/qemu/${version_dir}
81 * prefix: a subsystem prefix, or the empty string ("audio-", ..., "")
82 * name: name of the module
83 * errp: error to set in case the module is found, but load failed.
85 * Return value: -1 on error (errp set if not NULL).
86 * 0 if module or one of its dependencies are not installed,
87 * 1 if the module is found and loaded,
88 * 2 if the module is already loaded, or module is built-in.
90 int module_load(const char *prefix
, const char *name
, Error
**errp
);
93 * module_load_qom: attempt to load a module to provide a QOM type
95 * type: the type to be provided
98 * Return value: as per module_load.
100 int module_load_qom(const char *type
, Error
**errp
);
101 void module_load_qom_all(void);
102 void module_allow_arch(const char *arch
);
105 * DOC: module info annotation macros
107 * ``scripts/modinfo-collect.py`` will collect module info,
108 * using the preprocessor and -DQEMU_MODINFO.
110 * ``scripts/modinfo-generate.py`` will create a module meta-data database
111 * from the collected information so qemu knows about module
112 * dependencies and QOM objects implemented by modules.
114 * See ``*.modinfo`` and ``modinfo.c`` in the build directory to check the
118 # define modinfo(kind, value) \
119 MODINFO_START kind value MODINFO_END
121 # define modinfo(kind, value)
129 * This module implements QOM type @name.
131 #define module_obj(name) modinfo(obj, name)
138 * This module depends on module @name.
140 #define module_dep(name) modinfo(dep, name)
145 * @name: target architecture
147 * This module is for target architecture @arch.
149 * Note that target-dependent modules are tagged automatically, so
150 * this is only needed in case target-independent modules should be
151 * restricted. Use case example: the ccw bus is implemented by s390x
154 #define module_arch(name) modinfo(arch, name)
159 * @name: QemuOpts name
161 * This module registers QemuOpts @name.
163 #define module_opts(name) modinfo(opts, name)
168 * @name: Kconfig requirement necessary to load the module
170 * This module requires a core module that should be implemented and
171 * enabled in Kconfig.
173 #define module_kconfig(name) modinfo(kconfig, name)
176 * module info database
178 * scripts/modinfo-generate.c will build this using the data collected
179 * by scripts/modinfo-collect.py
181 typedef struct QemuModinfo QemuModinfo
;
189 extern const QemuModinfo qemu_modinfo
[];
190 void module_init_info(const QemuModinfo
*info
);