From mboxrd@z Thu Jan 1 00:00:00 1970 Delivery-date: Fri, 06 Aug 2021 09:00:38 +0200 Received: from metis.ext.pengutronix.de ([2001:67c:670:201:290:27ff:fe1d:cc33]) by lore.white.stw.pengutronix.de with esmtp (Exim 4.92) (envelope-from ) id 1mBtqQ-0007mG-II for lore@lore.pengutronix.de; Fri, 06 Aug 2021 09:00:38 +0200 Received: from localhost ([127.0.0.1] helo=metis.ext.pengutronix.de) by metis.ext.pengutronix.de with esmtp (Exim 4.92) (envelope-from ) id 1mBtqQ-0000Cc-An; Fri, 06 Aug 2021 09:00:38 +0200 Received: from ptx.hi.pengutronix.de ([2001:67c:670:100:1d::c0]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1mBtq9-0008WM-MN; Fri, 06 Aug 2021 09:00:21 +0200 Received: from mol by ptx.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1mBtq8-0006Pa-4A; Fri, 06 Aug 2021 09:00:20 +0200 Date: Fri, 6 Aug 2021 09:00:20 +0200 From: Michael Olbrich To: Christian Melki Message-ID: <20210806070020.GN21333@pengutronix.de> Mail-Followup-To: Christian Melki , ptxdist@pengutronix.de References: <20210716124423.30570-1-christian.melki@t2data.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20210716124423.30570-1-christian.melki@t2data.com> X-Sent-From: Pengutronix Hildesheim X-URL: http://www.pengutronix.de/ X-IRC: #ptxdist @freenode X-Accept-Language: de,en X-Accept-Content-Type: text/plain X-Uptime: 08:49:32 up 169 days, 10:13, 84 users, load average: 0.09, 0.13, 0.09 User-Agent: Mutt/1.10.1 (2018-07-13) Subject: Re: [ptxdist] [PATCH] rules/qemu: Add new package. X-BeenThere: ptxdist@pengutronix.de X-Mailman-Version: 2.1.29 Precedence: list List-Id: PTXdist Development Mailing List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: ptxdist@pengutronix.de Cc: ptxdist@pengutronix.de Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "ptxdist" X-SA-Exim-Connect-IP: 127.0.0.1 X-SA-Exim-Mail-From: ptxdist-bounces@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false On Fri, Jul 16, 2021 at 02:44:23PM +0200, Christian Melki wrote: > Work-in-progress. Add target-qemu package. > Usecases are among others: > Higher isolation (security) and target emulation (software longevity). > > Signed-off-by: Christian Melki > --- > rules/qemu.in | 51 +++++++++ > rules/qemu.make | 274 ++++++++++++++++++++++++++++++++++++++++++++++++ > 2 files changed, 325 insertions(+) > create mode 100644 rules/qemu.in > create mode 100644 rules/qemu.make > > diff --git a/rules/qemu.in b/rules/qemu.in > new file mode 100644 > index 000000000..d627f7a79 > --- /dev/null > +++ b/rules/qemu.in > @@ -0,0 +1,51 @@ > +## SECTION=emulators > + > +menuconfig QEMU > + tristate > + prompt "qemu " > + select HOST_MESON > + select HOST_NINJA > + select HOST_SYSTEM_PYTHON3 > + select GLIB > + select LIBCAP_NG > + select ZLIB > + select LIBUSB if QEMU_SYS > + select PIXMAN if QEMU_SYS > + help > + QEMU is a generic and open source machine emulator and > + virtualizer. Remove trailing whitespaces > + > +if QEMU > + > +config QEMU_TARGETS > + string intent with tab. > + prompt "QEMU targets" > + default "i386 x86_64 arm aarch64" > + help > + The list of QEMU user and system targets you want to build. > + Only use the prefixes. > + > +config QEMU_FDT > + bool > + prompt "Enable Device Tree generation." > + default y > + help > + Say y to let QEMU construct FDTs and pass them indention > + to the VMs. Why make this optional? I don't think the overhead is that big, so maybe just enable it unconditionally. > + > +config QEMU_TOOLS > + bool > + prompt "Enable tools" > + default y > + help > + Say y here to include tools. Hmmm, this is used for configure, but not in the targetinstall stage. That looks suspicious. > + > +config QEMU_SYS > + bool > + prompt "system emulation" > + > +config QEMU_USR > + bool > + prompt "user-space emulation" > + > +endif > diff --git a/rules/qemu.make b/rules/qemu.make > new file mode 100644 > index 000000000..0a276fbf6 > --- /dev/null > +++ b/rules/qemu.make > @@ -0,0 +1,274 @@ > +# -*-makefile-*- > +# > +# Copyright (C) 2021 by Christian Melki > +# > +# For further information about the PTXdist project and license conditions > +# see the README file. > +# > + > +# > +# We provide this package > +# > +PACKAGES-$(PTXCONF_QEMU) += qemu > + > +# > +# Paths and names > +# > +QEMU_VERSION := 6.0.0 > +QEMU_MD5 := cce185dc0119546e395909e8a71a75bb > +QEMU := qemu-$(QEMU_VERSION) > +QEMU_SUFFIX := tar.xz > +QEMU_URL := https://download.qemu.org/$(QEMU).$(QEMU_SUFFIX) > +QEMU_SOURCE := $(SRCDIR)/$(QEMU).$(QEMU_SUFFIX) > +QEMU_DIR := $(BUILDDIR)/$(QEMU) > +QEMU_LICENSE := GPL-2.0-only AND GPL-2.0-or-later AND MIT AND BSD-1-Clause AND BSD-2-Clause AND BSD-3-Clause > +QEMU_BUILD_OOT := YES Please remove the corresponding lines in host-qemu.in. It will then default to this here. > + > +# ---------------------------------------------------------------------------- > +# Prepare > +# ---------------------------------------------------------------------------- > + > +ifdef PTXCONF_ARCH_X86 > +QEMU_ARCH := i386 > +ifdef PTXCONF_ARCH_X86_64 > +QEMU_ARCH := x86_64 > +endif > +endif > +ifdef PTXCONF_ARCH_ARM > +QEMU_ARCH := arm > +endif > +ifdef PTXCONF_ARCH_ARM64 > +QEMU_ARCH := aarch64 > +endif Unused? > + > +# > +# autoconf > +# > + > +QEMU_MAKE_OPT := V=$(filter 1,$(PTXDIST_VERBOSE)) > + > +QEMU_SYS_TARGETS := $(foreach target, $(call remove_quotes,$(PTXCONF_QEMU_TARGETS)), $(patsubst %,%-softmmu,$(target))) > +QEMU_USR_TARGETS := $(foreach target, $(call remove_quotes,$(PTXCONF_QEMU_TARGETS)), $(patsubst %,%-linux-user,$(target))) > + > +QEMU_PATH := PATH=$(CROSS_PATH) > + > +QEMU_CONF_TOOL := autoconf > +# Note: not realy autoconf: > +# e.g. there is --enable-debug but not --disable-debug > +QEMU_CONF_OPT := \ > + --prefix=/usr \ > + --target-list=" \ > + $(call ptx/ifdef, PTXCONF_QEMU_SYS,$(QEMU_SYS_TARGETS),) \ > + $(call ptx/ifdef, PTXCONF_QEMU_USR,$(QEMU_USR_TARGETS),) \ > + " \ > + --meson=meson \ > + --ninja=ninja \ > + --cross-prefix=$(CROSS_COMPILE) \ > + --disable-sanitizers \ > + --disable-tsan \ > + --disable-strip \ > + --disable-werror \ > + --enable-stack-protector \ > + --audio-drv-list= \ > + --block-drv-rw-whitelist= \ > + --block-drv-ro-whitelist= \ > + --enable-trace-backends=nop \ > + --disable-tcg-interpreter \ > + --enable-malloc-trim \ > + --with-coroutine= \ > + --tls-priority=NORMAL \ > + --disable-plugins \ > + --disable-containers \ > + --$(call ptx/endis, PTXCONF_QEMU_SYS)-system \ > + --disable-user \ > + --$(call ptx/endis, PTXCONF_QEMU_USR)-linux-user \ > + --disable-bsd-user \ > + --disable-docs \ > + --disable-guest-agent \ > + --disable-guest-agent-msi \ > + --enable-pie \ > + --disable-modules \ > + --disable-module-upgrades \ > + --disable-debug-tcg \ > + --disable-debug-info \ > + --disable-lto \ > + --disable-sparse \ > + --disable-safe-stack \ > + --disable-cfi \ > + --disable-gnutls \ > + --disable-nettle \ > + --disable-gcrypt \ > + --disable-auth-pam \ > + --disable-sdl \ > + --disable-sdl-image \ > + --disable-gtk \ > + --disable-vte \ > + --disable-curses \ > + --enable-iconv \ > + --disable-vnc \ > + --disable-vnc-sasl \ > + --disable-vnc-jpeg \ > + --disable-vnc-png \ > + --disable-cocoa \ > + --enable-virtfs \ Check with the latest changes of host-qemu. This breaks without qemu-system. > + --disable-virtiofsd \ > + --disable-libudev \ > + --disable-mpath \ > + --disable-xen \ > + --disable-xen-pci-passthrough \ > + --disable-brlapi \ > + --disable-curl \ > + --enable-membarrier \ > + --$(call ptx/endis, PTXCONF_QEMU_FDT)-fdt \ > + --enable-kvm \ > + --disable-hax \ > + --disable-hvf \ > + --disable-whpx \ > + --disable-rdma \ > + --disable-pvrdma \ > + --disable-netmap \ > + --disable-linux-aio \ > + --disable-linux-io-uring \ > + --enable-cap-ng \ > + --enable-attr \ > + --enable-vhost-net \ > + --enable-vhost-vsock \ > + --enable-vhost-scsi \ > + --disable-vhost-crypto \ > + --enable-vhost-kernel \ > + --disable-vhost-user \ > + --disable-vhost-user-blk-server \ > + --disable-vhost-vdpa \ > + --disable-spice \ > + --disable-rbd \ > + --disable-libiscsi \ > + --disable-libnfs \ > + --disable-smartcard \ > + --disable-u2f \ > + --$(call ptx/endis, PTXCONF_QEMU_SYS)-libusb \ > + --disable-live-block-migration \ > + --disable-usb-redir \ > + --disable-lzo \ > + --disable-snappy \ > + --disable-bzip2 \ > + --disable-lzfse \ > + --disable-zstd \ > + --disable-seccomp \ > + --enable-coroutine-pool \ > + --disable-glusterfs \ > + --disable-tpm \ > + --disable-libssh \ > + --disable-numa \ > + --disable-libxml2 \ > + --disable-tcmalloc \ > + --disable-jemalloc \ > + --enable-replication \ > + --disable-opengl \ > + --disable-virglrenderer \ > + --disable-xfsctl \ > + --disable-qom-cast-debug \ > + --$(call ptx/endis, PTXCONF_QEMU_TOOLS)-tools \ > + --disable-bochs \ > + --disable-cloop \ > + --disable-dmg \ > + --disable-qcow1 \ > + --disable-vdi \ > + --disable-vvfat \ > + --disable-qed \ > + --disable-parallels \ > + --disable-sheepdog \ > + --disable-crypto-afalg \ > + --disable-capstone \ > + --disable-debug-mutex \ > + --disable-libpmem \ > + --disable-xkbcommon \ > + --disable-rng-none \ > + --disable-libdaxctl \ > + --disable-fuse \ > + --enable-multiprocess \ > + --disable-gio \ > + \ > + --disable-fuzzing \ > + --disable-keyring > + > +# ---------------------------------------------------------------------------- > +# Install > +# ---------------------------------------------------------------------------- > + > +$(STATEDIR)/qemu.install: > + @$(call targetinfo) > + @$(call world/install, QEMU) > +ifdef PTXCONF_QEMU_SYS > +# # necessary for qemu to find its ROM files > + @ln -vsf usr/share/qemu $(QEMU_PKGDIR)/pc-bios > +endif > + @$(call touch) > + > +# ---------------------------------------------------------------------------- > +# Target-Install > +# ---------------------------------------------------------------------------- > + > +$(STATEDIR)/qemu.targetinstall: > + @$(call targetinfo) > + > + @$(call install_init, qemu) > + @$(call install_fixup, qemu,PRIORITY,optional) > + @$(call install_fixup, qemu,SECTION,base) > + @$(call install_fixup, qemu,AUTHOR,"Christian Melki ") > + @$(call install_fixup, qemu,DESCRIPTION,missing) > + > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-edid) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-img) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-io) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-pr-helper) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-storage-daemon) > +ifdef PTXCONF_QEMU_SYS > + @$(foreach target, $(call remove_quotes,$(PTXCONF_QEMU_TARGETS)), \ QEMU_TARGETS := $(call remove_quotes,$(PTXCONF_QEMU_TARGETS) somewhere above and use it here > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-system-$(target))$(ptx/nl)) > +endif > +ifdef PTXCONF_QEMU_USER > + @$(foreach target, $(call remove_quotes,$(PTXCONF_QEMU_TARGETS)), \ and here. > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/bin/qemu-system-$(target))$(ptx/nl)) > +endif > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/libexec/qemu-bridge-helper) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/libexec/virtfs-proxy-helper) > + > + @$(call install_copy, qemu, 0, 0, 0755, /usr/share/qemu) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/bios-256k.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/bios-microvm.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/bios.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-aarch64-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-arm-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-arm-vars.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-i386-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-i386-secure-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-i386-vars.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-x86_64-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/edk2-x86_64-secure-code.fd) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/efi-e1000.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/efi-e1000e.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/efi-eepro100.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/efi-virtio.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/pxe-e1000.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/pxe-eepro100.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/pxe-virtio.rom) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/pvh.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/kvmvapic.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios-ati.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios-cirrus.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios-stdvga.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios-virtio.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios-vmware.bin) > + @$(call install_copy, qemu, 0, 0, 0644, -, /usr/share/qemu/vgabios.bin) > + > + @$(call install_copy, qemu, 0, 0, 0755, /usr/share/qemu/firmware) > + @$(call install_glob, qemu, 0, 0, -, /usr/share/qemu/firmware,, *.json) > + > + @$(call install_copy, qemu, 0, 0, 0755, /usr/share/qemu/keymaps) > + @$(call install_copy, qemu, 0, 0, 0755, -, /usr/share/qemu/keymaps/en-us) I think this stuff is only used for qemu-system. And a lot of it is architecture dependent so add some: ifneq ($(filter i386 x86_64,$(QEMU_TARGETS),) ifneq ($(filter aarch64,$(QEMU_TARGETS),) and stuff like that. Michael > + > + @$(call install_finish, qemu) > + > + @$(call touch) > + > +# vim: syntax=make > -- > 2.32.0 > > > _______________________________________________ > ptxdist mailing list > ptxdist@pengutronix.de > To unsubscribe, send a mail with subject "unsubscribe" to ptxdist-request@pengutronix.de > -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | _______________________________________________ ptxdist mailing list ptxdist@pengutronix.de To unsubscribe, send a mail with subject "unsubscribe" to ptxdist-request@pengutronix.de