1SUMMARY = "Fast open source processor emulator"
2DESCRIPTION = "QEMU is a hosted virtual machine monitor: it emulates the \
3machine's processor through dynamic binary translation and provides a set \
4of different hardware and device models for the machine, enabling it to run \
5a variety of guest operating systems"
6HOMEPAGE = "http://qemu.org"
7LICENSE = "GPL-2.0-only & LGPL-2.1-only"
8
9RDEPENDS:${PN}-ptest = "bash"
10
11require qemu-targets.inc
12inherit pkgconfig ptest update-rc.d systemd
13
14LIC_FILES_CHKSUM = "file://COPYING;md5=441c28d2cf86e15a37fa47e15a72fbac \
15                    file://COPYING.LIB;endline=24;md5=8c5efda6cf1e1b03dcfd0e6c0d271c7f"
16
17SRC_URI = "https://download.qemu.org/${BPN}-${PV}.tar.xz \
18           file://powerpc_rom.bin \
19           file://run-ptest \
20           file://0001-qemu-Add-addition-environment-space-to-boot-loader-q.patch \
21           file://0003-apic-fixup-fallthrough-to-PIC.patch \
22           file://0004-configure-Add-pkg-config-handling-for-libgcrypt.patch \
23           file://0005-qemu-Do-not-include-file-if-not-exists.patch \
24           file://0006-qemu-Add-some-user-space-mmap-tweaks-to-address-musl.patch \
25           file://0007-qemu-Determinism-fixes.patch \
26           file://0008-tests-meson.build-use-relative-path-to-refer-to-file.patch \
27           file://0009-Define-MAP_SYNC-and-MAP_SHARED_VALIDATE-on-needed-li.patch \
28           file://0010-hw-pvrdma-Protect-against-buggy-or-malicious-guest-d.patch \
29           file://0002-linux-user-Replace-use-of-lfs64-related-functions-an.patch \
30           file://0001-tracetool-use-relative-paths-for-line-preprocessor-d.patch \
31           file://qemu-guest-agent.init \
32           file://qemu-guest-agent.udev \
33           file://ppc.patch \
34           "
35UPSTREAM_CHECK_REGEX = "qemu-(?P<pver>\d+(\.\d+)+)\.tar"
36
37SRC_URI[sha256sum] = "bb60f0341531181d6cc3969dd19a013d0427a87f918193970d9adb91131e56d0"
38
39SRC_URI:append:class-target = " file://cross.patch"
40SRC_URI:append:class-nativesdk = " file://cross.patch"
41
42# Applies against virglrender < 0.6.0 and not qemu itself
43CVE_CHECK_IGNORE += "CVE-2017-5957"
44
45# The VNC server can expose host files uder some circumstances. We don't
46# enable it by default.
47CVE_CHECK_IGNORE += "CVE-2007-0998"
48
49# 'The issues identified by this CVE were determined to not constitute a vulnerability.'
50# https://bugzilla.redhat.com/show_bug.cgi?id=1609015#c11
51CVE_CHECK_IGNORE += "CVE-2018-18438"
52
53# As per https://nvd.nist.gov/vuln/detail/CVE-2023-0664
54# https://bugzilla.redhat.com/show_bug.cgi?id=2167423
55# this bug related to windows specific.
56CVE_CHECK_IGNORE += "CVE-2023-0664"
57
58COMPATIBLE_HOST:mipsarchn32 = "null"
59COMPATIBLE_HOST:mipsarchn64 = "null"
60COMPATIBLE_HOST:riscv32 = "null"
61
62# Per https://lists.nongnu.org/archive/html/qemu-devel/2020-09/msg03873.html
63# upstream states qemu doesn't work without optimization
64DEBUG_BUILD = "0"
65
66do_install:append() {
67    # Prevent QA warnings about installed ${localstatedir}/run
68    if [ -d ${D}${localstatedir}/run ]; then rmdir ${D}${localstatedir}/run; fi
69}
70
71do_install_ptest() {
72	cp -rL ${B}/tests ${D}${PTEST_PATH}
73	find ${D}${PTEST_PATH}/tests -type f -name "*.[Sshcodp]" | xargs -i rm -rf {}
74
75	# Don't check the file genreated by configure
76	sed -i -e "1s,#!/usr/bin/bash,#!${base_bindir}/bash," ${D}${PTEST_PATH}/tests/data/acpi/disassemle-aml.sh
77
78	# Strip the paths from the QEMU variable, we can use PATH
79	makfiles=$(find ${D}${PTEST_PATH} -name "*.mak")
80	sed -i -e "s#^QEMU=.*/qemu-#QEMU=qemu-#g" $makfiles
81
82	# Strip compiler flags as they break reproducibility
83	sed -i -e "s,^CC=.*,CC=gcc," \
84	       -e "s,^CCAS=.*,CCAS=gcc," \
85	       -e "s,^LD=.*,LD=ld," $makfiles
86
87	# Update SRC_PATH variable to the right place on target
88	sed -i -e "s#^SRC_PATH=.*#SRC_PATH=${PTEST_PATH}#g" $makfiles
89
90	# https://gitlab.com/qemu-project/qemu/-/issues/1403
91	rm ${D}${PTEST_PATH}/tests/unit/test-io-channel-command
92}
93
94# QEMU_TARGETS is overridable variable
95QEMU_TARGETS ?= "arm aarch64 i386 loongarch64 mips mipsel mips64 mips64el ppc ppc64 ppc64le riscv32 riscv64 sh4 x86_64"
96
97EXTRA_OECONF = " \
98    --prefix=${prefix} \
99    --bindir=${bindir} \
100    --includedir=${includedir} \
101    --libdir=${libdir} \
102    --mandir=${mandir} \
103    --datadir=${datadir} \
104    --docdir=${docdir}/${BPN} \
105    --sysconfdir=${sysconfdir} \
106    --libexecdir=${libexecdir} \
107    --localstatedir=${localstatedir} \
108    --with-suffix=${BPN} \
109    --disable-strip \
110    --disable-werror \
111    --extra-cflags='${CFLAGS}' \
112    --extra-ldflags='${LDFLAGS}' \
113    --with-git=/bin/false \
114    --with-git-submodules=ignore \
115    --meson=meson \
116    ${PACKAGECONFIG_CONFARGS} \
117    "
118
119B = "${WORKDIR}/build"
120
121#EXTRA_OECONF:append = " --python=${HOSTTOOLS_DIR}/python3"
122
123do_configure:prepend:class-native() {
124	# Append build host pkg-config paths for native target since the host may provide sdl
125	BHOST_PKGCONFIG_PATH=$(PATH=/usr/bin:/bin pkg-config --variable pc_path pkg-config || echo "")
126	if [ ! -z "$BHOST_PKGCONFIG_PATH" ]; then
127		export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:$BHOST_PKGCONFIG_PATH
128	fi
129}
130
131do_configure() {
132    ${S}/configure ${EXTRA_OECONF}
133}
134do_configure[cleandirs] += "${B}"
135
136do_install () {
137	export STRIP=""
138	oe_runmake 'DESTDIR=${D}' install
139
140	# If we built the guest agent, also install startup/udev rules
141	if [ -e "${D}${bindir}/qemu-ga" ]; then
142		install -d ${D}${sysconfdir}/init.d/
143		install -m 0755 ${WORKDIR}/qemu-guest-agent.init ${D}${sysconfdir}/init.d/qemu-guest-agent
144		sed -i 's:@bindir@:${bindir}:' ${D}${sysconfdir}/init.d/qemu-guest-agent
145
146		install -d ${D}${sysconfdir}/udev/rules.d/
147		install -m 0644 ${WORKDIR}/qemu-guest-agent.udev ${D}${sysconfdir}/udev/rules.d/60-qemu-guest-agent.rules
148
149		install -d ${D}${systemd_unitdir}/system/
150		install -m 0644 ${S}/contrib/systemd/qemu-guest-agent.service ${D}${systemd_unitdir}/system
151		sed -i -e 's,-/usr/bin/,-${bindir}/,g' ${D}${systemd_unitdir}/system/qemu-guest-agent.service
152	fi
153}
154
155# The following fragment will create a wrapper for qemu-mips user emulation
156# binary in order to work around a segmentation fault issue. Basically, by
157# default, the reserved virtual address space for 32-on-64 bit is set to 4GB.
158# This will trigger a MMU access fault in the virtual CPU. With this change,
159# the qemu-mips works fine.
160# IMPORTANT: This piece needs to be removed once the root cause is fixed!
161do_install:append() {
162	if [ -e "${D}/${bindir}/qemu-mips" ]; then
163		create_wrapper ${D}/${bindir}/qemu-mips \
164			QEMU_RESERVED_VA=0x0
165	fi
166}
167# END of qemu-mips workaround
168
169# Disable kvm/virgl/mesa on targets that do not support it
170PACKAGECONFIG:remove:darwin = "kvm virglrenderer epoxy gtk+"
171PACKAGECONFIG:remove:mingw32 = "kvm virglrenderer epoxy gtk+"
172
173PACKAGECONFIG[sdl] = "--enable-sdl,--disable-sdl,libsdl2"
174PACKAGECONFIG[png] = "--enable-png,--disable-png,libpng"
175PACKAGECONFIG[virtfs] = "--enable-virtfs --enable-attr --enable-cap-ng,--disable-virtfs,libcap-ng attr,"
176PACKAGECONFIG[aio] = "--enable-linux-aio,--disable-linux-aio,libaio,"
177PACKAGECONFIG[uring] = "--enable-linux-io-uring,--disable-linux-io-uring,liburing"
178PACKAGECONFIG[xen] = "--enable-xen,--disable-xen,xen-tools,xen-tools-libxenstore xen-tools-libxenctrl xen-tools-libxenguest"
179PACKAGECONFIG[vnc-sasl] = "--enable-vnc --enable-vnc-sasl,--disable-vnc-sasl,cyrus-sasl,"
180PACKAGECONFIG[vnc-jpeg] = "--enable-vnc --enable-vnc-jpeg,--disable-vnc-jpeg,jpeg,"
181PACKAGECONFIG[libcurl] = "--enable-curl,--disable-curl,curl,"
182PACKAGECONFIG[nss] = "--enable-smartcard,--disable-smartcard,nss,"
183PACKAGECONFIG[curses] = "--enable-curses,--disable-curses,ncurses,"
184PACKAGECONFIG[gtk+] = "--enable-gtk,--disable-gtk,gtk+3 gettext-native"
185PACKAGECONFIG[vte] = "--enable-vte,--disable-vte,vte gettext-native"
186PACKAGECONFIG[libcap-ng] = "--enable-cap-ng,--disable-cap-ng,libcap-ng,"
187PACKAGECONFIG[ssh] = "--enable-libssh,--disable-libssh,libssh,"
188PACKAGECONFIG[gcrypt] = "--enable-gcrypt,--disable-gcrypt,libgcrypt,"
189PACKAGECONFIG[nettle] = "--enable-nettle,--disable-nettle,nettle"
190PACKAGECONFIG[libusb] = "--enable-libusb,--disable-libusb,libusb1"
191PACKAGECONFIG[fdt] = "--enable-fdt,--disable-fdt,dtc"
192PACKAGECONFIG[alsa] = "--audio-drv-list=default,,alsa-lib"
193PACKAGECONFIG[epoxy] = "--enable-opengl,--disable-opengl,libepoxy"
194PACKAGECONFIG[lzo] = "--enable-lzo,--disable-lzo,lzo"
195PACKAGECONFIG[numa] = "--enable-numa,--disable-numa,numactl"
196PACKAGECONFIG[gnutls] = "--enable-gnutls,--disable-gnutls,gnutls"
197PACKAGECONFIG[bzip2] = "--enable-bzip2,--disable-bzip2,bzip2"
198PACKAGECONFIG[libiscsi] = "--enable-libiscsi,--disable-libiscsi"
199PACKAGECONFIG[kvm] = "--enable-kvm,--disable-kvm"
200PACKAGECONFIG[virglrenderer] = "--enable-virglrenderer,--disable-virglrenderer,virglrenderer"
201# spice will be in meta-networking layer
202PACKAGECONFIG[spice] = "--enable-spice,--disable-spice,spice"
203# usbredir will be in meta-networking layer
204PACKAGECONFIG[usb-redir] = "--enable-usb-redir,--disable-usb-redir,usbredir"
205PACKAGECONFIG[snappy] = "--enable-snappy,--disable-snappy,snappy"
206PACKAGECONFIG[glusterfs] = "--enable-glusterfs,--disable-glusterfs,glusterfs"
207PACKAGECONFIG[xkbcommon] = "--enable-xkbcommon,--disable-xkbcommon,libxkbcommon"
208PACKAGECONFIG[libudev] = "--enable-libudev,--disable-libudev,eudev"
209PACKAGECONFIG[attr] = "--enable-attr,--disable-attr,attr,"
210PACKAGECONFIG[rbd] = "--enable-rbd,--disable-rbd,ceph,ceph"
211PACKAGECONFIG[vhost] = "--enable-vhost-net,--disable-vhost-net,,"
212PACKAGECONFIG[ust] = "--enable-trace-backends=ust,,lttng-ust,"
213PACKAGECONFIG[pie] = "--enable-pie,--disable-pie,,"
214PACKAGECONFIG[seccomp] = "--enable-seccomp,--disable-seccomp,libseccomp"
215# libnfs is currently provided by meta-kodi
216PACKAGECONFIG[libnfs] = "--enable-libnfs,--disable-libnfs,libnfs"
217PACKAGECONFIG[pmem] = "--enable-libpmem,--disable-libpmem,pmdk"
218PACKAGECONFIG[pulsedio] = "--enable-pa,--disable-pa,pulseaudio"
219PACKAGECONFIG[selinux] = "--enable-selinux,--disable-selinux"
220PACKAGECONFIG[bpf] = "--enable-bpf,--disable-bpf,libbpf"
221PACKAGECONFIG[capstone] = "--enable-capstone,--disable-capstone"
222PACKAGECONFIG[rdma] = "--enable-rdma,--disable-rdma"
223PACKAGECONFIG[vde] = "--enable-vde,--disable-vde"
224PACKAGECONFIG[slirp] = "--enable-slirp,--disable-slirp,libslirp"
225PACKAGECONFIG[brlapi] = "--enable-brlapi,--disable-brlapi"
226PACKAGECONFIG[jack] = "--enable-jack,--disable-jack,jack,"
227PACKAGECONFIG[debuginfo] = "--enable-libdw,--disable-libdw,elfutils"
228
229INSANE_SKIP:${PN} = "arch"
230
231FILES:${PN} += "${datadir}/icons"
232
233# Put the guest agent in a separate package
234PACKAGES =+ "${PN}-guest-agent"
235SUMMARY:${PN}-guest-agent = "QEMU guest agent"
236FILES:${PN}-guest-agent += " \
237    ${bindir}/qemu-ga \
238    ${sysconfdir}/udev/rules.d/60-qemu-guest-agent.rules \
239    ${sysconfdir}/init.d/qemu-guest-agent \
240    ${systemd_unitdir}/system/qemu-guest-agent.service \
241"
242
243INITSCRIPT_PACKAGES = "${PN}-guest-agent"
244INITSCRIPT_NAME:${PN}-guest-agent = "qemu-guest-agent"
245INITSCRIPT_PARAMS:${PN}-guest-agent = "defaults"
246
247SYSTEMD_PACKAGES = "${PN}-guest-agent"
248SYSTEMD_SERVICE:${PN}-guest-agent = "qemu-guest-agent.service"
249