qemu/include/qemu/module.h
<<
>>
Prefs
   1/*
   2 * QEMU Module Infrastructure
   3 *
   4 * Copyright IBM, Corp. 2009
   5 *
   6 * Authors:
   7 *  Anthony Liguori   <aliguori@us.ibm.com>
   8 *
   9 * This work is licensed under the terms of the GNU GPL, version 2.  See
  10 * the COPYING file in the top-level directory.
  11 *
  12 */
  13
  14#ifndef QEMU_MODULE_H
  15#define QEMU_MODULE_H
  16
  17
  18#define DSO_STAMP_FUN         glue(qemu_stamp, CONFIG_STAMP)
  19#define DSO_STAMP_FUN_STR     stringify(DSO_STAMP_FUN)
  20
  21#ifdef BUILD_DSO
  22void 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 */
  26void qemu_module_dummy(void);
  27
  28#define module_init(function, type)                                         \
  29static void __attribute__((constructor)) do_qemu_init_ ## function(void)    \
  30{                                                                           \
  31    register_dso_module_init(function, type);                               \
  32}
  33#else
  34/* This should not be used directly.  Use block_init etc. instead.  */
  35#define module_init(function, type)                                         \
  36static void __attribute__((constructor)) do_qemu_init_ ## function(void)    \
  37{                                                                           \
  38    register_module_init(function, type);                                   \
  39}
  40#endif
  41
  42typedef enum {
  43    MODULE_INIT_MIGRATION,
  44    MODULE_INIT_BLOCK,
  45    MODULE_INIT_OPTS,
  46    MODULE_INIT_QOM,
  47    MODULE_INIT_TRACE,
  48    MODULE_INIT_XEN_BACKEND,
  49    MODULE_INIT_LIBQOS,
  50    MODULE_INIT_FUZZ_TARGET,
  51    MODULE_INIT_MAX
  52} module_init_type;
  53
  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_one(lib) module_load_one("block-", lib, false)
  65#define ui_module_load_one(lib) module_load_one("ui-", lib, false)
  66#define audio_module_load_one(lib) module_load_one("audio-", lib, false)
  67
  68void register_module_init(void (*fn)(void), module_init_type type);
  69void register_dso_module_init(void (*fn)(void), module_init_type type);
  70
  71void module_call_init(module_init_type type);
  72bool module_load_one(const char *prefix, const char *lib_name, bool mayfail);
  73void module_load_qom_one(const char *type);
  74void module_load_qom_all(void);
  75void module_allow_arch(const char *arch);
  76
  77/**
  78 * DOC: module info annotation macros
  79 *
  80 * ``scripts/modinfo-collect.py`` will collect module info,
  81 * using the preprocessor and -DQEMU_MODINFO.
  82 *
  83 * ``scripts/modinfo-generate.py`` will create a module meta-data database
  84 * from the collected information so qemu knows about module
  85 * dependencies and QOM objects implemented by modules.
  86 *
  87 * See ``*.modinfo`` and ``modinfo.c`` in the build directory to check the
  88 * script results.
  89 */
  90#ifdef QEMU_MODINFO
  91# define modinfo(kind, value) \
  92    MODINFO_START kind value MODINFO_END
  93#else
  94# define modinfo(kind, value)
  95#endif
  96
  97/**
  98 * module_obj
  99 *
 100 * @name: QOM type.
 101 *
 102 * This module implements QOM type @name.
 103 */
 104#define module_obj(name) modinfo(obj, name)
 105
 106/**
 107 * module_dep
 108 *
 109 * @name: module name
 110 *
 111 * This module depends on module @name.
 112 */
 113#define module_dep(name) modinfo(dep, name)
 114
 115/**
 116 * module_arch
 117 *
 118 * @name: target architecture
 119 *
 120 * This module is for target architecture @arch.
 121 *
 122 * Note that target-dependent modules are tagged automatically, so
 123 * this is only needed in case target-independent modules should be
 124 * restricted.  Use case example: the ccw bus is implemented by s390x
 125 * only.
 126 */
 127#define module_arch(name) modinfo(arch, name)
 128
 129/**
 130 * module_opts
 131 *
 132 * @name: QemuOpts name
 133 *
 134 * This module registers QemuOpts @name.
 135 */
 136#define module_opts(name) modinfo(opts, name)
 137
 138/*
 139 * module info database
 140 *
 141 * scripts/modinfo-generate.c will build this using the data collected
 142 * by scripts/modinfo-collect.py
 143 */
 144typedef struct QemuModinfo QemuModinfo;
 145struct QemuModinfo {
 146    const char *name;
 147    const char *arch;
 148    const char **objs;
 149    const char **deps;
 150    const char **opts;
 151};
 152extern const QemuModinfo qemu_modinfo[];
 153void module_init_info(const QemuModinfo *info);
 154
 155#endif
 156