From: Paolo Bonzini <pbonzini@redhat.com>
To: Akihiko Odaki <akihiko.odaki@gmail.com>
Cc: "Peter Maydell" <peter.maydell@linaro.org>,
"Jason Wang" <jasowang@redhat.com>,
qemu-devel@nongnu.org, Programmingkid <programmingkidx@gmail.com>,
"Philippe Mathieu-Daudé" <f4bug@amsat.org>,
"Gerd Hoffmann" <kraxel@redhat.com>,
"Daniel P . Berrangé" <berrange@redhat.com>,
"Alex Bennée" <alex.bennee@linaro.org>,
"Thomas Huth" <thuth@redhat.com>, "John Snow" <jsnow@redhat.com>,
"Cleber Rosa" <crosa@redhat.com>, "Stefan Weil" <sw@weilnetz.de>
Subject: Re: [PATCH v10 0/4] cutils: Introduce bundle mechanism
Date: Mon, 11 Jul 2022 17:42:19 +0200 [thread overview]
Message-ID: <55b05cb0-edb8-0911-777a-fe6a19fb4549@redhat.com> (raw)
In-Reply-To: <20220627035744.23218-1-akihiko.odaki@gmail.com>
On 6/27/22 05:57, Akihiko Odaki wrote:
> Developers often run QEMU without installing. The bundle mechanism
> allows to look up files which should be present in installation even in
> such a situation.
>
> It is a general mechanism and can find any files located relative
> to the installation tree. The build tree must have a new directory,
> qemu-bundle, to represent what files the installation tree would
> have for reference by the executables.
>
> Note that this abandons compatibility with Windows older than 8 to use
> PathCchSkipRoot(). The extended support for the prior version, 7 ended
> more than 2 years ago, and it is unlikely that anyone would like to run
> the latest QEMU on such an old system.
Thanks, merged.
However there were a couple issues:
- the bashism in patch 4, replaced by
+meson_option_build_array() {
+ printf '['
+ (if test "$targetos" == windows; then
+ IFS=\;
+ else
+ IFS=:
+ fi
+ for e in $1; do
+ e=${e/'\'/'\\'}
+ e=${e/\"/'\"'}
+ printf '"""%s""",' "$e"
+ done)
+ printf ']\n'
+}
+
- oss-fuzz didn't work, it has a syntax error and also can be simplified
to use qemu-bundle as well, like
-# Copy over the datadir
-cp -r ../pc-bios/ "$DEST_DIR/pc-bios"
+# Prepare a preinstalled tree
+make install DESTDIR=$DEST_DIR/qemu-bundle
Paolo
> v10:
> * Update destdir_join() in scripts/symlink-install-tree.py with the
> latest implementation from Meson:
> https://github.com/mesonbuild/meson/pull/10531
>
> v9:
> * Update _WIN32_WINNT in include/qemu/osdep.h (Thomas Huth)
>
> v8:
> * Pass absolute paths to get_relocated_path() (Paolo Bonzini)
> * Use meson introspection (Paolo Bonzini)
> * Drop "qga: Relocate a path emitted in the help text" as it is no longer
> relevant for the bundle mechanism.
>
> v7: Properly fix --firmwarepath (Daniel P. Berrangé)
>
> v6: Reuse get_relocated_path() in find_bundle() (Paolo Bonzini)
>
> v5:
> * Prefer qemu-bundle if it exists. (Daniel P. Berrangé)
> * Check install_blobs option before installing BIOSes (Paolo Bonzini)
> * Add common code to set up qemu-bundle to the top level meson.build
> (Paolo Bonzini)
>
> v4:
> * Add Daniel P. Berrangé to CC. Hopefully this helps merging his patch:
> https://mail.gnu.org/archive/html/qemu-devel/2022-06/msg02276.html
> * Rebased to the latest QEMU.
>
> v3:
> * Note that the bundle mechanism is for any files located relative to the
> installation tree including but not limited to datadir. (Peter Maydell)
> * Fix "bridge" typo (Philippe Mathieu-Daudé)
>
> v2: Rebased to the latest QEMU.
>
> Akihiko Odaki (3):
> cutils: Introduce bundle mechanism
> datadir: Use bundle mechanism
> module: Use bundle mechanism
>
> Paolo Bonzini (1):
> tests/vm: do not specify -bios option
>
> .travis.yml | 2 +-
> docs/about/build-platforms.rst | 2 +-
> include/qemu/cutils.h | 18 +++++++--
> include/qemu/osdep.h | 2 +-
> meson.build | 4 ++
> pc-bios/keymaps/meson.build | 21 +++-------
> pc-bios/meson.build | 13 ++-----
> scripts/oss-fuzz/build.sh | 2 +-
> scripts/symlink-install-tree.py | 34 +++++++++++++++++
> softmmu/datadir.c | 22 +----------
> tests/qtest/fuzz/fuzz.c | 15 --------
> tests/vm/fedora | 1 -
> tests/vm/freebsd | 1 -
> tests/vm/netbsd | 1 -
> tests/vm/openbsd | 1 -
> util/cutils.c | 68 +++++++++++++++++++++++----------
> util/meson.build | 1 +
> util/module.c | 1 -
> 18 files changed, 115 insertions(+), 94 deletions(-)
> create mode 100755 scripts/symlink-install-tree.py
>
next prev parent reply other threads:[~2022-07-11 15:45 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-27 3:57 [PATCH v10 0/4] cutils: Introduce bundle mechanism Akihiko Odaki
2022-06-27 3:57 ` [PATCH v10 1/4] tests/vm: do not specify -bios option Akihiko Odaki
2022-06-27 3:57 ` [PATCH v10 2/4] cutils: Introduce bundle mechanism Akihiko Odaki
2022-06-27 3:57 ` [PATCH v10 3/4] datadir: Use " Akihiko Odaki
2022-06-27 3:57 ` [PATCH v10 4/4] module: " Akihiko Odaki
2022-07-11 15:42 ` Paolo Bonzini [this message]
2022-10-29 8:51 ` [PATCH v10 0/4] cutils: Introduce " Stefan Weil via
2022-10-29 19:45 ` Paolo Bonzini
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=55b05cb0-edb8-0911-777a-fe6a19fb4549@redhat.com \
--to=pbonzini@redhat.com \
--cc=akihiko.odaki@gmail.com \
--cc=alex.bennee@linaro.org \
--cc=berrange@redhat.com \
--cc=crosa@redhat.com \
--cc=f4bug@amsat.org \
--cc=jasowang@redhat.com \
--cc=jsnow@redhat.com \
--cc=kraxel@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=programmingkidx@gmail.com \
--cc=qemu-devel@nongnu.org \
--cc=sw@weilnetz.de \
--cc=thuth@redhat.com \
/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).