From: Fam Zheng <famz@redhat.com>
To: qemu-devel@nongnu.org
Cc: peter.maydell@linaro.org, famz@redhat.com, mjt@tls.msk.ru,
alex@alex.org.uk, pbonzini@redhat.com, vilanova@ac.upc.edu,
rth@twiddle.net
Subject: [Qemu-devel] [PATCH v10 0/8] Shared Library Module Support
Date: Mon, 16 Sep 2013 14:50:19 +0800 [thread overview]
Message-ID: <1379314227-8855-1-git-send-email-famz@redhat.com> (raw)
This series implements feature of shared object building as described in:
http://wiki.qemu.org/Features/Modules
The main idea behind modules is to isolate dependencies on third party
libraries from qemu executables, such as libglusterfs or librbd, so that the
end users can install core qemu package with fewer dependencies. And only for
those who want to use particular modules, need they install qemu-foo
sub-package, which in turn requires libbar and libbiz packages.
It's implemented in three steps:
1. The first patches fix current build system to correctly handle nested
variables and object specific options:
[01/08] ui/Makefile.objs: delete unnecessary cocoa.o dependency
[02/08] make.rule: fix $(obj) to a real relative path
[03/08] rule.mak: allow per object cflags and libs
2. The Makefile changes adds necessary options and rules to build DSO objects:
[04/08] build-sys: introduce common-obj-m and block-obj-m for DSO
3. The next patch adds code to load modules from installed directory:
[05/08] module: implement module loading
A few more changes are following to complete it:
[06/08] Makefile: install modules with "make install"
[07/08] .gitignore: ignore module related files (dll, so, mo)
In the end of series, the block drivers are converted:
[08/08] block: convert block drivers linked with libs to modules
v10:
All modules in a single directory (moddir), with module type prefixed:
/usr/lib/qemu/block-{curl,iscsi,...}.so
The module names for user to list in module whitelist is consequently:
block-curl, block-iscsi, ui-*, etc.
In Makfile, the installed module filename is simply generated by:
$(subst /,-,%.so)
Which is also the rule for module names.
[05] Add #undef CONFIG_MODULE_WHITELIST in config-host.h.
Use static array for whitelist. (Richard)
v9: Address Daniel's comment with patch 05:
Drop readdir().
Squash module whitelist changes to module loading patch.
v8: This version introduces two runtime loading checks:
* Module init function no longer with __attribute__((constructor)), and
mangled with per configure fingerprint. See patch 05.
* Module whitelist as configure option.
[04] Link libqemustub.a to DSO. (iscsi needs qemu_get_vm_name).
Fix single object module link.
Fix extract-libs to also extract .o libs that'd be expanded later from
.mo.
[05] Add init function name mangling.
[06] New.
[07] Fix typo in "make install". [Daniel]
Fam Zheng (7):
make.rule: fix $(obj) to a real relative path
rule.mak: allow per object cflags and libs
build-sys: introduce common-obj-m and block-obj-m for DSO
module: implement module loading
Makefile: install modules with "make install"
.gitignore: ignore module related files (dll, so, mo)
block: convert block drivers linked with libs to modules
Peter Maydell (1):
ui/Makefile.objs: delete unnecessary cocoa.o dependency
.gitignore | 3 ++
Makefile | 30 +++++++++++++++++-
Makefile.objs | 19 ++----------
Makefile.target | 21 ++++++++++---
block.c | 1 +
block/Makefile.objs | 11 ++++++-
configure | 86 +++++++++++++++++++++++++++++++++++----------------
include/qemu/module.h | 23 ++++++++++++++
rules.mak | 84 +++++++++++++++++++++++++++++++++++++++++--------
scripts/create_config | 22 +++++++++++++
ui/Makefile.objs | 2 --
util/module.c | 81 ++++++++++++++++++++++++++++++++++++++++++++++++
vl.c | 2 ++
13 files changed, 322 insertions(+), 63 deletions(-)
--
1.8.3.1
next reply other threads:[~2013-09-16 6:50 UTC|newest]
Thread overview: 47+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-09-16 6:50 Fam Zheng [this message]
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 1/8] ui/Makefile.objs: delete unnecessary cocoa.o dependency Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 2/8] make.rule: fix $(obj) to a real relative path Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 3/8] rule.mak: allow per object cflags and libs Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 4/8] build-sys: introduce common-obj-m and block-obj-m for DSO Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 5/8] module: implement module loading Fam Zheng
2013-09-16 8:59 ` Daniel P. Berrange
2013-09-16 9:28 ` Fam Zheng
2013-09-16 22:16 ` Richard Henderson
2013-09-17 0:47 ` Fam Zheng
2013-09-16 9:44 ` Paolo Bonzini
2013-09-16 9:51 ` Fam Zheng
2013-09-16 10:09 ` Paolo Bonzini
2013-09-16 10:14 ` Daniel P. Berrange
2013-09-16 10:18 ` Paolo Bonzini
2013-09-16 10:21 ` Daniel P. Berrange
2013-09-16 10:30 ` Paolo Bonzini
2013-09-16 11:29 ` Fam Zheng
2013-09-16 11:33 ` Paolo Bonzini
2013-09-16 11:46 ` Fam Zheng
2013-09-16 22:31 ` Richard Henderson
2013-09-17 1:29 ` Fam Zheng
2013-09-17 5:40 ` Richard Henderson
2013-09-18 11:45 ` Paolo Bonzini
2013-09-18 14:44 ` Richard Henderson
2013-09-18 15:00 ` Paolo Bonzini
2013-09-17 8:50 ` Wenchao Xia
2013-09-16 10:57 ` Gerd Hoffmann
2013-09-16 11:00 ` Paolo Bonzini
2013-09-16 22:38 ` Richard Henderson
2013-09-16 10:24 ` Alex Bligh
2013-09-16 10:38 ` Paolo Bonzini
2013-09-16 11:00 ` Alex Bligh
2013-09-16 11:04 ` Daniel P. Berrange
2013-09-16 11:27 ` Alex Bligh
2013-09-16 11:08 ` Paolo Bonzini
2013-09-16 11:30 ` Alex Bligh
2013-09-17 8:26 ` Wenchao Xia
2013-09-16 10:43 ` Fam Zheng
2013-09-16 11:05 ` Daniel P. Berrange
2013-09-16 12:36 ` Gerd Hoffmann
2013-09-17 5:55 ` Fam Zheng
2013-09-17 6:33 ` Alex Bligh
2013-09-17 6:40 ` Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 6/8] Makefile: install modules with "make install" Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 7/8] .gitignore: ignore module related files (dll, so, mo) Fam Zheng
2013-09-16 6:50 ` [Qemu-devel] [PATCH v10 8/8] block: convert block drivers linked with libs to modules Fam Zheng
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1379314227-8855-1-git-send-email-famz@redhat.com \
--to=famz@redhat.com \
--cc=alex@alex.org.uk \
--cc=mjt@tls.msk.ru \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=rth@twiddle.net \
--cc=vilanova@ac.upc.edu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).