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