 d7795d3cc5
			
		
	
	
		d7795d3cc5
		
	
	
	
	
		
			
			Add module_allow_arch() to set the target architecture. In case a module is limited to some arch verify arches match and ignore the module if not. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Reviewed-by: Jose R. Ziviani <jziviani@suse.de> Message-Id: <20210624103836.2382472-19-kraxel@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
		
			
				
	
	
		
			156 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * QEMU Module Infrastructure
 | |
|  *
 | |
|  * Copyright IBM, Corp. 2009
 | |
|  *
 | |
|  * Authors:
 | |
|  *  Anthony Liguori   <aliguori@us.ibm.com>
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2.  See
 | |
|  * the COPYING file in the top-level directory.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef QEMU_MODULE_H
 | |
| #define QEMU_MODULE_H
 | |
| 
 | |
| 
 | |
| #define DSO_STAMP_FUN         glue(qemu_stamp, CONFIG_STAMP)
 | |
| #define DSO_STAMP_FUN_STR     stringify(DSO_STAMP_FUN)
 | |
| 
 | |
| #ifdef BUILD_DSO
 | |
| void DSO_STAMP_FUN(void);
 | |
| /* This is a dummy symbol to identify a loaded DSO as a QEMU module, so we can
 | |
|  * distinguish "version mismatch" from "not a QEMU module", when the stamp
 | |
|  * check fails during module loading */
 | |
| void qemu_module_dummy(void);
 | |
| 
 | |
| #define module_init(function, type)                                         \
 | |
| static void __attribute__((constructor)) do_qemu_init_ ## function(void)    \
 | |
| {                                                                           \
 | |
|     register_dso_module_init(function, type);                               \
 | |
| }
 | |
| #else
 | |
| /* 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);                                   \
 | |
| }
 | |
| #endif
 | |
| 
 | |
| typedef enum {
 | |
|     MODULE_INIT_MIGRATION,
 | |
|     MODULE_INIT_BLOCK,
 | |
|     MODULE_INIT_OPTS,
 | |
|     MODULE_INIT_QOM,
 | |
|     MODULE_INIT_TRACE,
 | |
|     MODULE_INIT_XEN_BACKEND,
 | |
|     MODULE_INIT_LIBQOS,
 | |
|     MODULE_INIT_FUZZ_TARGET,
 | |
|     MODULE_INIT_MAX
 | |
| } module_init_type;
 | |
| 
 | |
| #define block_init(function) module_init(function, MODULE_INIT_BLOCK)
 | |
| #define opts_init(function) module_init(function, MODULE_INIT_OPTS)
 | |
| #define type_init(function) module_init(function, MODULE_INIT_QOM)
 | |
| #define trace_init(function) module_init(function, MODULE_INIT_TRACE)
 | |
| #define xen_backend_init(function) module_init(function, \
 | |
|                                                MODULE_INIT_XEN_BACKEND)
 | |
| #define libqos_init(function) module_init(function, MODULE_INIT_LIBQOS)
 | |
| #define fuzz_target_init(function) module_init(function, \
 | |
|                                                MODULE_INIT_FUZZ_TARGET)
 | |
| #define migration_init(function) module_init(function, MODULE_INIT_MIGRATION)
 | |
| #define block_module_load_one(lib) module_load_one("block-", lib, false)
 | |
| #define ui_module_load_one(lib) module_load_one("ui-", lib, false)
 | |
| #define audio_module_load_one(lib) module_load_one("audio-", lib, false)
 | |
| 
 | |
| void register_module_init(void (*fn)(void), module_init_type type);
 | |
| void register_dso_module_init(void (*fn)(void), module_init_type type);
 | |
| 
 | |
| void module_call_init(module_init_type type);
 | |
| bool module_load_one(const char *prefix, const char *lib_name, bool mayfail);
 | |
| void module_load_qom_one(const char *type);
 | |
| void module_load_qom_all(void);
 | |
| void module_allow_arch(const char *arch);
 | |
| 
 | |
| /**
 | |
|  * DOC: module info annotation macros
 | |
|  *
 | |
|  * `scripts/modinfo-collect.py` will collect module info,
 | |
|  * using the preprocessor and -DQEMU_MODINFO.
 | |
|  *
 | |
|  * `scripts/modinfo-generate.py` will create a module meta-data database
 | |
|  * from the collected information so qemu knows about module
 | |
|  * dependencies and QOM objects implemented by modules.
 | |
|  *
 | |
|  * See `*.modinfo` and `modinfo.c` in the build directory to check the
 | |
|  * script results.
 | |
|  */
 | |
| #ifdef QEMU_MODINFO
 | |
| # define modinfo(kind, value) \
 | |
|     MODINFO_START kind value MODINFO_END
 | |
| #else
 | |
| # define modinfo(kind, value)
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * module_obj
 | |
|  *
 | |
|  * @name: QOM type.
 | |
|  *
 | |
|  * This module implements QOM type @name.
 | |
|  */
 | |
| #define module_obj(name) modinfo(obj, name)
 | |
| 
 | |
| /**
 | |
|  * module_dep
 | |
|  *
 | |
|  * @name: module name
 | |
|  *
 | |
|  * This module depends on module @name.
 | |
|  */
 | |
| #define module_dep(name) modinfo(dep, name)
 | |
| 
 | |
| /**
 | |
|  * module_arch
 | |
|  *
 | |
|  * @name: target architecture
 | |
|  *
 | |
|  * This module is for target architecture @arch.
 | |
|  *
 | |
|  * Note that target-dependent modules are tagged automatically, so
 | |
|  * this is only needed in case target-independent modules should be
 | |
|  * restricted.  Use case example: the ccw bus is implemented by s390x
 | |
|  * only.
 | |
|  */
 | |
| #define module_arch(name) modinfo(arch, name)
 | |
| 
 | |
| /**
 | |
|  * module_opts
 | |
|  *
 | |
|  * @name: QemuOpts name
 | |
|  *
 | |
|  * This module registers QemuOpts @name.
 | |
|  */
 | |
| #define module_opts(name) modinfo(opts, name)
 | |
| 
 | |
| /*
 | |
|  * module info database
 | |
|  *
 | |
|  * scripts/modinfo-generate.c will build this using the data collected
 | |
|  * by scripts/modinfo-collect.py
 | |
|  */
 | |
| typedef struct QemuModinfo QemuModinfo;
 | |
| struct QemuModinfo {
 | |
|     const char *name;
 | |
|     const char *arch;
 | |
|     const char **objs;
 | |
|     const char **deps;
 | |
|     const char **opts;
 | |
| };
 | |
| extern const QemuModinfo qemu_modinfo[];
 | |
| void module_init_info(const QemuModinfo *info);
 | |
| 
 | |
| #endif
 |