commit:     1fc5ab0a22228d2b385c4e1c80e7d78b60a7104a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed May 31 00:35:14 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 31 00:35:14 2023 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=1fc5ab0a

app-emulation/qemu: treeclean

::gentoo works AFAIK.

Signed-off-by: Sam James <sam <AT> gentoo.org>

 app-emulation/qemu/Manifest                        |   1 -
 app-emulation/qemu/files/65-kvm.rules-r2           |   3 -
 app-emulation/qemu/files/bridge.conf               |  14 -
 ...linux-user-fix-build-with-musl-on-aarch64.patch |  31 -
 ...linux-user-fix-build-with-musl-on-ppc64le.patch |  67 --
 ...-input-use-safe-64-bit-time-accessors-for.patch |  40 -
 ...-input-use-safe-64-bit-time-accessors-for.patch |  40 -
 ...signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch |  37 -
 .../qemu/files/musl-patches/MAP_SYNC-fix.patch     |  22 -
 .../musl-patches/fix-segevent-and-sigval_t.patch   |  24 -
 .../qemu/files/musl-patches/fix-sendmsg.patch      |  13 -
 .../files/musl-patches/fix-sockios-header.patch    |  13 -
 ...gnals-33-and-64-to-allow-golang-emulation.patch |  56 --
 .../qemu/files/musl-patches/mips-softfloat.patch   |  32 -
 .../musl-patches/musl-F_SHLCK-and-F_EXLCK.patch    |  19 -
 .../qemu/files/musl-patches/xattr_size_max.patch   |  15 -
 .../files/qemu-2.11.1-capstone_include_path.patch  |  11 -
 .../qemu/files/qemu-5.2.0-cleaner-werror.patch     |  40 -
 .../qemu/files/qemu-5.2.0-dce-locks.patch          |  18 -
 .../qemu/files/qemu-5.2.0-disable-keymap.patch     |  25 -
 app-emulation/qemu/files/qemu-5.2.0-strings.patch  |  23 -
 app-emulation/qemu/files/qemu-6.0.0-make.patch     |  14 -
 app-emulation/qemu/files/qemu-binfmt.initd.head    |  64 --
 app-emulation/qemu/files/qemu-binfmt.initd.tail    |  14 -
 app-emulation/qemu/metadata.xml                    |  69 --
 app-emulation/qemu/qemu-6.0.0-r55.ebuild           | 924 ---------------------
 26 files changed, 1629 deletions(-)

diff --git a/app-emulation/qemu/Manifest b/app-emulation/qemu/Manifest
deleted file mode 100644
index 4e6705f4..00000000
--- a/app-emulation/qemu/Manifest
+++ /dev/null
@@ -1 +0,0 @@
-DIST qemu-6.0.0.tar.xz 107333232 BLAKE2B 
7746329d3e13782b7c346ce4052cc517cfc65cd9b2d514d199e4d5b8570ca79566ec04b0c114db2e97c84e68eb551e0d4cdce1b14b91a88fe08d2a5f682c1418
 SHA512 
ee3ff00aebec4d8891d2ff6dabe4e667e510b2a4fe3f6190aa34673a91ea32dcd2db2e9bf94c2f1bf05aa79788f17cfbbedc6027c0988ea08a92587b79ee05e4

diff --git a/app-emulation/qemu/files/65-kvm.rules-r2 
b/app-emulation/qemu/files/65-kvm.rules-r2
deleted file mode 100644
index 15c89b20..00000000
--- a/app-emulation/qemu/files/65-kvm.rules-r2
+++ /dev/null
@@ -1,3 +0,0 @@
-KERNEL=="kvm", GROUP="kvm", MODE="0660"
-KERNEL=="vhost-net", GROUP="kvm", MODE="0660", OPTIONS+="static_node=vhost-net"
-KERNEL=="vhost-vsock", GROUP="kvm", MODE="0660", 
OPTIONS+="static_node=vhost-vsock"

diff --git a/app-emulation/qemu/files/bridge.conf 
b/app-emulation/qemu/files/bridge.conf
deleted file mode 100644
index 2bde37e2..00000000
--- a/app-emulation/qemu/files/bridge.conf
+++ /dev/null
@@ -1,14 +0,0 @@
-# This should have the following permissions: root:qemu 0640
-
-# allow br0
-# Uncommenting the above would allow users in the 'qemu' group
-# to add devices to 'br0'
-
-# allow virbr0
-# Uncommenting the above would allow users in the 'qemu' group
-# to add devices to 'virbr0'
-
-# include /etc/qemu/bob.conf
-# Uncommenting the above would allow users in the 'bob' group
-# to have permissions defined in it, iff it has the following
-# permissions: root:bob 0640

diff --git 
a/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-aarch64.patch
 
b/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-aarch64.patch
deleted file mode 100644
index 1bbae7de..00000000
--- 
a/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-aarch64.patch
+++ /dev/null
@@ -1,31 +0,0 @@
-From 806cb2ed28a16cf2894fabef034347f426f1d04e Mon Sep 17 00:00:00 2001
-From: Natanael Copa <[email protected]>
-Date: Thu, 15 Dec 2016 11:53:07 +0100
-Subject: [PATCH] linux-user: fix build with musl on aarch64
-
-Use the standard uint64_t instead of internal __u64.
-
-This fixes compiler error with musl libc on aarch64:
-.../qemu-2.7.0/linux-user/host/aarch64/hostdep.h:28:5:
-error: unknown type name '__u64'
-     __u64 *pcreg = &uc->uc_mcontext.pc;
-     ^~~~~
-
-Signed-off-by: Natanael Copa <[email protected]>
----
- linux-user/host/aarch64/hostdep.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/linux-user/host/aarch64/hostdep.h 
b/linux-user/host/aarch64/hostdep.h
-index 64f75cef49..6fd6e36b2a 100644
---- a/linux-user/host/aarch64/hostdep.h
-+++ b/linux-user/host/aarch64/hostdep.h
-@@ -25,7 +25,7 @@ extern char safe_syscall_end[];
- static inline void rewind_if_in_safe_syscall(void *puc)
- {
-     ucontext_t *uc = puc;
--    __u64 *pcreg = &uc->uc_mcontext.pc;
-+    uint64_t *pcreg = &uc->uc_mcontext.pc;
- 
-     if (*pcreg > (uintptr_t)safe_syscall_start
-         && *pcreg < (uintptr_t)safe_syscall_end) {

diff --git 
a/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-ppc64le.patch
 
b/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-ppc64le.patch
deleted file mode 100644
index c3a91877..00000000
--- 
a/app-emulation/qemu/files/musl-patches/0001-linux-user-fix-build-with-musl-on-ppc64le.patch
+++ /dev/null
@@ -1,67 +0,0 @@
---- a/linux-user/host/ppc64/hostdep.h
-+++ b/linux-user/host/ppc64/hostdep.h
-@@ -25,7 +25,11 @@
- static inline void rewind_if_in_safe_syscall(void *puc)
- {
-     ucontext_t *uc = puc;
-+#if defined(__GLIBC__) || defined(__UCLIBC__)
-     unsigned long *pcreg = &uc->uc_mcontext.gp_regs[PT_NIP];
-+#else // Musl
-+    unsigned long *pcreg = &uc->uc_mcontext.gp_regs[32];
-+#endif
- 
-     if (*pcreg > (uintptr_t)safe_syscall_start
-         && *pcreg < (uintptr_t)safe_syscall_end) {
---- a/accel/tcg/user-exec.c
-+++ a/accel/tcg/user-exec.c
-@@ -228,6 +228,7 @@
-  */
- #ifdef linux
- /* All Registers access - only for local access */
-+#if defined(__GLIBC__) || defined(__UCLIBC__)
- #define REG_sig(reg_name, context)              \
-     ((context)->uc_mcontext.regs->reg_name)
- /* Gpr Registers access  */
-@@ -245,15 +246,42 @@
- /* Condition register */
- #define CR_sig(context)                        REG_sig(ccr, context)
-
-+#else // Musl
-+#define REG_sig(reg_num, context)              \
-+    ((context)->uc_mcontext.gp_regs[reg_num])
-+/* Gpr Registers access  */
-+#define GPR_sig(reg_num, context)              REG_sig(gpr[reg_num], context)
-+/* Program counter */
-+#define IAR_sig(context)                       REG_sig(32, context)
-+/* Machine State Register (Supervisor) */
-+#define MSR_sig(context)                       REG_sig(33, context)
-+/* Count register */
-+#define CTR_sig(context)                       REG_sig(35, context)
-+/* User's integer exception register */
-+#define XER_sig(context)                       REG_sig(37, context)
-+/* Link register */
-+#define LR_sig(context)                        REG_sig(36, context)
-+/* Condition register */
-+#define CR_sig(context)                        REG_sig(38, context)
-+#endif
-+
-+
- /* Float Registers access  */
- #define FLOAT_sig(reg_num, context)                                     \
-     (((double *)((char *)((context)->uc_mcontext.regs + 48 * 4)))[reg_num])
- #define FPSCR_sig(context) \
-     (*(int *)((char *)((context)->uc_mcontext.regs + (48 + 32 * 2) * 4)))
- /* Exception Registers access */
-+#if defined(__GLIBC__) || defined(__UCLIBC__)
- #define DAR_sig(context)                       REG_sig(dar, context)
- #define DSISR_sig(context)                     REG_sig(dsisr, context)
- #define TRAP_sig(context)                      REG_sig(trap, context)
-+#else // Musl
-+#define DAR_sig(context)                       REG_sig(41, context)
-+#define DSISR_sig(context)                     REG_sig(42, context)
-+#define TRAP_sig(context)                      REG_sig(40, context)
-+#endif
-+
- #endif /* linux */
-
- #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)

diff --git 
a/app-emulation/qemu/files/musl-patches/0001-virtio-host-input-use-safe-64-bit-time-accessors-for.patch
 
b/app-emulation/qemu/files/musl-patches/0001-virtio-host-input-use-safe-64-bit-time-accessors-for.patch
deleted file mode 100644
index ba66aae1..00000000
--- 
a/app-emulation/qemu/files/musl-patches/0001-virtio-host-input-use-safe-64-bit-time-accessors-for.patch
+++ /dev/null
@@ -1,40 +0,0 @@
-From 388ef67707f01fe4ad337642325ae974dd81c242 Mon Sep 17 00:00:00 2001
-From: Ariadne Conill <[email protected]>
-Date: Wed, 22 Jul 2020 02:45:00 -0600
-Subject: [PATCH 1/2] virtio host input: use safe 64-bit time accessors for
- input_event
-
-On 32-bit systems with 64-bit time_t, input_event.time is not
-directly accessible.  Instead, we must use input_event_sec and
-input_event_usec accessors to set the time values.
-
-Signed-off-by: Ariadne Conill <[email protected]>
----
- hw/input/virtio-input-host.c | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-diff --git a/hw/input/virtio-input-host.c b/hw/input/virtio-input-host.c
-index 85daf73f1a..7b81bf09f5 100644
---- a/hw/input/virtio-input-host.c
-+++ b/hw/input/virtio-input-host.c
-@@ -193,13 +193,16 @@ static void virtio_input_host_handle_status(VirtIOInput 
*vinput,
- {
-     VirtIOInputHost *vih = VIRTIO_INPUT_HOST(vinput);
-     struct input_event evdev;
-+    struct timeval tv;
-     int rc;
- 
--    if (gettimeofday(&evdev.time, NULL)) {
-+    if (gettimeofday(&tv, NULL)) {
-         perror("virtio_input_host_handle_status: gettimeofday");
-         return;
-     }
- 
-+    evdev.input_event_sec = tv.tv_sec;
-+    evdev.input_event_usec = tv.tv_usec;
-     evdev.type = le16_to_cpu(event->type);
-     evdev.code = le16_to_cpu(event->code);
-     evdev.value = le32_to_cpu(event->value);
--- 
-2.27.0
-

diff --git 
a/app-emulation/qemu/files/musl-patches/0002-virtio-user-input-use-safe-64-bit-time-accessors-for.patch
 
b/app-emulation/qemu/files/musl-patches/0002-virtio-user-input-use-safe-64-bit-time-accessors-for.patch
deleted file mode 100644
index b965f66e..00000000
--- 
a/app-emulation/qemu/files/musl-patches/0002-virtio-user-input-use-safe-64-bit-time-accessors-for.patch
+++ /dev/null
@@ -1,40 +0,0 @@
-From de7cf9878a216143db677820c23407c3b032d12c Mon Sep 17 00:00:00 2001
-From: Ariadne Conill <[email protected]>
-Date: Wed, 22 Jul 2020 02:51:30 -0600
-Subject: [PATCH 2/2] virtio user input: use safe 64-bit time accessors for
- input_event
-
-On 32-bit systems with 64-bit time_t, input_event.time is not
-directly accessible.  Instead, we must use input_event_sec and
-input_event_usec accessors to set the time values.
-
-Signed-off-by: Ariadne Conill <[email protected]>
----
- contrib/vhost-user-input/main.c | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-diff --git a/contrib/vhost-user-input/main.c b/contrib/vhost-user-input/main.c
-index 6020c6f33a..4887a6cb44 100644
---- a/contrib/vhost-user-input/main.c
-+++ b/contrib/vhost-user-input/main.c
-@@ -115,13 +115,16 @@ vi_evdev_watch(VuDev *dev, int condition, void *data)
- static void vi_handle_status(VuInput *vi, virtio_input_event *event)
- {
-     struct input_event evdev;
-+    struct timeval tv;
-     int rc;
- 
--    if (gettimeofday(&evdev.time, NULL)) {
-+    if (gettimeofday(&tv, NULL)) {
-         perror("vi_handle_status: gettimeofday");
-         return;
-     }
- 
-+    evdev.input_event_sec = tv.tv_sec;
-+    evdev.input_event_usec = tv.tv_usec;
-     evdev.type = le16toh(event->type);
-     evdev.code = le16toh(event->code);
-     evdev.value = le32toh(event->value);
--- 
-2.27.0
-

diff --git 
a/app-emulation/qemu/files/musl-patches/0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
 
b/app-emulation/qemu/files/musl-patches/0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
deleted file mode 100644
index 528b5d5d..00000000
--- 
a/app-emulation/qemu/files/musl-patches/0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
+++ /dev/null
@@ -1,37 +0,0 @@
-From 8fbb4e6797ed67310b74cbaaa061269db45a5b71 Mon Sep 17 00:00:00 2001
-From: Natanael Copa <[email protected]>
-Date: Tue, 29 Apr 2014 15:51:31 +0200
-Subject: [PATCH] linux-user/signal.c: define __SIGRTMIN/MAX for non-GNU
- platforms
-
-The __SIGRTMIN and __SIGRTMAX are glibc internals and are not available
-on all platforms, so we define those if they are missing.
-
-This is needed for musl libc.
-
-Signed-off-by: Natanael Copa <[email protected]>
----
- linux-user/signal.c | 7 +++++++
- 1 file changed, 7 insertions(+)
-
-diff --git a/linux-user/signal.c b/linux-user/signal.c
-index 5ca6d62b15..e917c16d91 100644
---- a/linux-user/signal.c
-+++ b/linux-user/signal.c
-@@ -25,6 +25,13 @@
- #include "trace.h"
- #include "signal-common.h"
- 
-+#ifndef __SIGRTMIN
-+#define __SIGRTMIN 32
-+#endif
-+#ifndef __SIGRTMAX
-+#define __SIGRTMAX (NSIG-1)
-+#endif
-+
- static struct target_sigaction sigact_table[TARGET_NSIG];
- 
- static void host_signal_handler(int host_signum, siginfo_t *info,
--- 
-2.23.0
-

diff --git a/app-emulation/qemu/files/musl-patches/MAP_SYNC-fix.patch 
b/app-emulation/qemu/files/musl-patches/MAP_SYNC-fix.patch
deleted file mode 100644
index e13609d7..00000000
--- a/app-emulation/qemu/files/musl-patches/MAP_SYNC-fix.patch
+++ /dev/null
@@ -1,22 +0,0 @@
-diff --git a/util/mmap-alloc.c b/util/mmap-alloc.c
-index f7f177d..7598960 100644
---- a/util/mmap-alloc.c
-+++ b/util/mmap-alloc.c
-@@ -10,14 +10,16 @@
-  * later.  See the COPYING file in the top-level directory.
-  */
- 
-+#include "qemu/osdep.h"
-+
- #ifdef CONFIG_LINUX
- #include <linux/mman.h>
-+#include <asm-generic/mman.h> /* for ppc64le */
- #else  /* !CONFIG_LINUX */
- #define MAP_SYNC              0x0
- #define MAP_SHARED_VALIDATE   0x0
- #endif /* CONFIG_LINUX */
- 
--#include "qemu/osdep.h"
- #include "qemu/mmap-alloc.h"
- #include "qemu/host-utils.h"
- 

diff --git 
a/app-emulation/qemu/files/musl-patches/fix-segevent-and-sigval_t.patch 
b/app-emulation/qemu/files/musl-patches/fix-segevent-and-sigval_t.patch
deleted file mode 100644
index 1f99eacb..00000000
--- a/app-emulation/qemu/files/musl-patches/fix-segevent-and-sigval_t.patch
+++ /dev/null
@@ -1,24 +0,0 @@
---- qemu-2.2.1/linux-user/syscall.c.orig       2015-04-10 07:10:06.305662505 
+0000
-+++ qemu-2.2.1/linux-user/syscall.c    2015-04-10 07:36:53.801871968 +0000
-@@ -5020,9 +5020,20 @@
-     return 0;
- }
- 
--static inline abi_long target_to_host_sigevent(struct sigevent *host_sevp,
-+struct host_sigevent {
-+    union sigval sigev_value;
-+    int sigev_signo;
-+    int sigev_notify;
-+    union {
-+       int _pad[64-sizeof(int) * 2 + sizeof(union sigval)];
-+       int _tid;
-+    } _sigev_un;
-+};
-+
-+static inline abi_long target_to_host_sigevent(struct sigevent *sevp,
-                                                abi_ulong target_addr)
- {
-+    struct host_sigevent *host_sevp = (struct host_sigevent *) sevp;
-     struct target_sigevent *target_sevp;
- 
-     if (!lock_user_struct(VERIFY_READ, target_sevp, target_addr, 1)) {

diff --git a/app-emulation/qemu/files/musl-patches/fix-sendmsg.patch 
b/app-emulation/qemu/files/musl-patches/fix-sendmsg.patch
deleted file mode 100644
index dc9c4bca..00000000
--- a/app-emulation/qemu/files/musl-patches/fix-sendmsg.patch
+++ /dev/null
@@ -1,13 +0,0 @@
-diff --git a/linux-user/syscall.c b/linux-user/syscall.c
-index 389ec09764..116d5eaff5 100644
---- a/linux-user/syscall.c
-+++ b/linux-user/syscall.c
-@@ -3337,7 +3337,7 @@ static abi_long do_sendrecvmsg_locked(int fd, struct 
target_msghdr *msgp,
-                                       int flags, int send)
- {
-     abi_long ret, len;
--    struct msghdr msg;
-+    struct msghdr msg = {};
-     abi_ulong count;
-     struct iovec *vec;
-     abi_ulong target_vec;

diff --git a/app-emulation/qemu/files/musl-patches/fix-sockios-header.patch 
b/app-emulation/qemu/files/musl-patches/fix-sockios-header.patch
deleted file mode 100644
index 1f3cd767..00000000
--- a/app-emulation/qemu/files/musl-patches/fix-sockios-header.patch
+++ /dev/null
@@ -1,13 +0,0 @@
-diff --git a/linux-user/syscall.c b/linux-user/syscall.c
-index 43d0562..afa0ac4 100644
---- a/linux-user/syscall.c
-+++ b/linux-user/syscall.c
-@@ -59,6 +59,7 @@ int __clone2(int (*fn)(void *), void *child_stack_base,
- #include <linux/icmp.h>
- #include <linux/icmpv6.h>
- #include <linux/errqueue.h>
-+#include <linux/sockios.h>
- #include <linux/random.h>
- #include "qemu-common.h"
- #ifdef CONFIG_TIMERFD
- #include <sys/timerfd.h>

diff --git 
a/app-emulation/qemu/files/musl-patches/ignore-signals-33-and-64-to-allow-golang-emulation.patch
 
b/app-emulation/qemu/files/musl-patches/ignore-signals-33-and-64-to-allow-golang-emulation.patch
deleted file mode 100644
index 11625422..00000000
--- 
a/app-emulation/qemu/files/musl-patches/ignore-signals-33-and-64-to-allow-golang-emulation.patch
+++ /dev/null
@@ -1,56 +0,0 @@
-From db186a3f83454268c43fc793a48bc28c41368a6c Mon Sep 17 00:00:00 2001
-From: Petros Angelatos <[email protected]>
-Date: Thu, 3 Mar 2016 23:58:53 -0800
-Subject: [PATCH] linux-user: ignore signals 33 and 64 to allow golang
- emulation
-
-Signal 33 will always fail. This causes golang crash since
-https://github.com/golang/go/commit/675eb72c285cd0dd44a5f280bb3fa456ddf6de16
-
-As explained in that commit, these signals are very rarely used in a
-way that causes problems, so it's ok-ish to ignore one of them.
-
-Signal 64 will fail because QEMU uses SIGRTMAX for itself. This causes
-golang to crash for versions earlier than
-https://github.com/golang/go/commit/d10675089d74db0408f2432eae3bd89a8e1c2d6a
-
-Since after that commit golang ignores that signal, we also ignore it here to
-allow earlier versions to run as well.
-
-Signed-off-by: Petros Angelatos <[email protected]>
----
- linux-user/signal.c | 21 +++++++++++++++++++++
- 1 file changed, 21 insertions(+)
-
-diff --git a/linux-user/signal.c b/linux-user/signal.c
-index 9a4d894..90aca55 100644
---- a/linux-user/signal.c
-+++ b/linux-user/signal.c
-@@ -744,6 +744,27 @@ int do_sigaction(int sig, const struct target_sigaction 
*act,
-     }
- 
-     k = &sigact_table[sig - 1];
-+
-+    /* This signal will always fail. This causes golang crash since
-+     * 
https://github.com/golang/go/commit/675eb72c285cd0dd44a5f280bb3fa456ddf6de16
-+     *
-+     * As explained in that commit, these signals are very rarely used in a
-+     * way that causes problems, so it's ok-ish to ignore one of them here.
-+     */
-+    if (sig == 33) {
-+        return 0;
-+    }
-+    /* This signal will fail because QEMU uses SIGRTMAX for itself. This 
causes
-+     * golang to crash for versions earlier than
-+     * 
https://github.com/golang/go/commit/d10675089d74db0408f2432eae3bd89a8e1c2d6a
-+     *
-+     * Since after that commit golang ignores that signal, we also ignore it 
here to
-+     * allow earlier versions to run as well.
-+     */
-+    if (sig == 64) {
-+        return 0;
-+    }
-+
-     if (oact) {
-         __put_user(k->_sa_handler, &oact->_sa_handler);
-         __put_user(k->sa_flags, &oact->sa_flags);

diff --git a/app-emulation/qemu/files/musl-patches/mips-softfloat.patch 
b/app-emulation/qemu/files/musl-patches/mips-softfloat.patch
deleted file mode 100644
index 4d9b4892..00000000
--- a/app-emulation/qemu/files/musl-patches/mips-softfloat.patch
+++ /dev/null
@@ -1,32 +0,0 @@
-diff --git a/tests/fp/fp-bench.c b/tests/fp/fp-bench.c
-index 4ba5e1d..313256c 100644
---- a/tests/fp/fp-bench.c
-+++ b/tests/fp/fp-bench.c
-@@ -479,6 +479,7 @@ static void QEMU_NORETURN die_host_rounding(enum rounding 
rounding)
-     exit(EXIT_FAILURE);
- }
- 
-+#ifndef __mips_soft_float
- static void set_host_precision(enum rounding rounding)
- {
-     int rhost;
-@@ -507,6 +508,7 @@ static void set_host_precision(enum rounding rounding)
-         die_host_rounding(rounding);
-     }
- }
-+#endif
- 
- static void set_soft_precision(enum rounding rounding)
- {
-@@ -596,9 +598,11 @@ static void parse_args(int argc, char *argv[])
- 
-     /* set precision and rounding mode based on the tester */
-     switch (tester) {
-+#ifndef __mips_soft_float
-     case TESTER_HOST:
-         set_host_precision(rounding);
-         break;
-+#endif
-     case TESTER_SOFT:
-         set_soft_precision(rounding);
-         switch (precision) {

diff --git 
a/app-emulation/qemu/files/musl-patches/musl-F_SHLCK-and-F_EXLCK.patch 
b/app-emulation/qemu/files/musl-patches/musl-F_SHLCK-and-F_EXLCK.patch
deleted file mode 100644
index 316819af..00000000
--- a/app-emulation/qemu/files/musl-patches/musl-F_SHLCK-and-F_EXLCK.patch
+++ /dev/null
@@ -1,19 +0,0 @@
-This patch was not upstreamed to qemu as those should probably be
-defined in musl libc.
-
---- ./linux-user/syscall.c.orig
-+++ ./linux-user/syscall.c
-@@ -114,6 +114,13 @@
- 
- #include "qemu.h"
- 
-+#ifndef F_SHLCK
-+#define F_SHLCK 8
-+#endif
-+#ifndef F_EXLCK
-+#define F_EXLCK 4
-+#endif
-+
- #ifndef CLONE_IO
- #define CLONE_IO                0x80000000      /* Clone io context */
- #endif

diff --git a/app-emulation/qemu/files/musl-patches/xattr_size_max.patch 
b/app-emulation/qemu/files/musl-patches/xattr_size_max.patch
deleted file mode 100644
index 1a33cbf5..00000000
--- a/app-emulation/qemu/files/musl-patches/xattr_size_max.patch
+++ /dev/null
@@ -1,15 +0,0 @@
-diff --git a/hw/9pfs/9p.c b/hw/9pfs/9p.c
-index faebd91..a0f15b6 100644
---- a/hw/9pfs/9p.c
-+++ b/hw/9pfs/9p.c
-@@ -25,6 +25,10 @@
- #include "trace.h"
- #include "migration/migration.h"
- 
-+#ifdef __linux__
-+#include <linux/limits.h> /* for XATTR_SIZE_MAX */
-+#endif
-+
- int open_fd_hw;
- int total_open_fd;
- static int open_fd_rc;

diff --git a/app-emulation/qemu/files/qemu-2.11.1-capstone_include_path.patch 
b/app-emulation/qemu/files/qemu-2.11.1-capstone_include_path.patch
deleted file mode 100644
index d79570eb..00000000
--- a/app-emulation/qemu/files/qemu-2.11.1-capstone_include_path.patch
+++ /dev/null
@@ -1,11 +0,0 @@
---- qemu-2.11.1/include/disas/capstone.h       2018-02-14 22:53:22.000000000 
+0100
-+++ qemu-2.11.1/include/disas/capstone.h       2018-02-17 20:12:12.754703951 
+0100
-@@ -3,7 +3,7 @@
- 
- #ifdef CONFIG_CAPSTONE
- 
--#include <capstone.h>
-+#include <capstone/capstone.h>
- 
- #else
- 

diff --git a/app-emulation/qemu/files/qemu-5.2.0-cleaner-werror.patch 
b/app-emulation/qemu/files/qemu-5.2.0-cleaner-werror.patch
deleted file mode 100644
index 33115f1d..00000000
--- a/app-emulation/qemu/files/qemu-5.2.0-cleaner-werror.patch
+++ /dev/null
@@ -1,40 +0,0 @@
--Wall -Wextra compains about unused arguments,
-causes safe-stack to be mis-detected.
---- a/configure
-+++ b/configure
-@@ -2293,7 +2293,7 @@ fi
- cat > $TMPC << EOF
- #include <stdint.h>
- #include <stdio.h>
--int main(int argc, char *argv[]) {
-+int main(void) {
-     return printf("%zu", SIZE_MAX);
- }
- EOF
-@@ -4911,7 +4911,7 @@ fi
- 
- if test "$safe_stack" = "yes"; then
- cat > $TMPC << EOF
--int main(int argc, char *argv[])
-+int main(void)
- {
- #if ! __has_feature(safe_stack)
- #error SafeStack Disabled
-@@ -4933,7 +4933,7 @@ EOF
-   fi
- else
- cat > $TMPC << EOF
--int main(int argc, char *argv[])
-+int main(void)
- {
- #if defined(__has_feature)
- #if __has_feature(safe_stack)
-@@ -5283,7 +5283,7 @@ static const int Z = 1;
- #define TAUT(X) ((X) == Z)
- #define PAREN(X, Y) (X == Y)
- #define ID(X) (X)
--int main(int argc, char *argv[])
-+int main(void)
- {
-     int x = 0, y = 0;
-     x = ID(x);

diff --git a/app-emulation/qemu/files/qemu-5.2.0-dce-locks.patch 
b/app-emulation/qemu/files/qemu-5.2.0-dce-locks.patch
deleted file mode 100644
index 679a9f39..00000000
--- a/app-emulation/qemu/files/qemu-5.2.0-dce-locks.patch
+++ /dev/null
@@ -1,18 +0,0 @@
-Fix CFLAGS=-Og build break. -Og fails because gcc does not enable dead
-code elimination (but does set __OPTIMIZE__ define).
-
-The fix avoids DCE reliance downstream entirely.
-
-Reported-by: Luke-Jr
-Bug: https://bugs.gentoo.org/782364
---- a/include/qemu/lockable.h
-+++ b/include/qemu/lockable.h
-@@ -28,7 +28,7 @@ struct QemuLockable {
-  * to QEMU_MAKE_LOCKABLE.  For optimized builds, we can rely on dead-code 
elimination
-  * from the compiler, and give the errors already at link time.
-  */
--#if defined(__OPTIMIZE__) && !defined(__SANITIZE_ADDRESS__)
-+#if defined(__OPTIMIZE__) && !defined(__SANITIZE_ADDRESS__) && 
defined(VALIDATE_LOCKS_VIA_DCE)
- void unknown_lock_type(void *);
- #else
- static inline void unknown_lock_type(void *unused)

diff --git a/app-emulation/qemu/files/qemu-5.2.0-disable-keymap.patch 
b/app-emulation/qemu/files/qemu-5.2.0-disable-keymap.patch
deleted file mode 100644
index 4b5676be..00000000
--- a/app-emulation/qemu/files/qemu-5.2.0-disable-keymap.patch
+++ /dev/null
@@ -1,25 +0,0 @@
-Do not use system's 'qemu-keymap' in native case.
---- a/meson.build
-+++ b/meson.build
-@@ -337,6 +337,8 @@ if 'CONFIG_LIBCAP_NG' in config_host
- endif
- if get_option('xkbcommon').auto() and not have_system and not have_tools
-   xkbcommon = not_found
-+elif get_option('xkbcommon').disabled()
-+  xkbcommon = not_found
- else
-   xkbcommon = dependency('xkbcommon', required: get_option('xkbcommon'),
-                          method: 'pkg-config', static: enable_static)
---- a/pc-bios/keymaps/meson.build
-+++ b/pc-bios/keymaps/meson.build
-@@ -33,7 +33,9 @@ keymaps = {
-   'tr': '-l tr',
- }
- 
--if meson.is_cross_build() or 'CONFIG_XKBCOMMON' not in config_host
-+if meson.is_cross_build()
-   native_qemu_keymap = find_program('qemu-keymap', required: false, disabler: 
true)
-+elif get_option('xkbcommon').disabled()
-+  native_qemu_keymap = not_found
- else
-   native_qemu_keymap = qemu_keymap

diff --git a/app-emulation/qemu/files/qemu-5.2.0-strings.patch 
b/app-emulation/qemu/files/qemu-5.2.0-strings.patch
deleted file mode 100644
index 0b3dcdce..00000000
--- a/app-emulation/qemu/files/qemu-5.2.0-strings.patch
+++ /dev/null
@@ -1,23 +0,0 @@
-https://bugs.gentoo.org/759310
---- a/configure
-+++ b/configure
-@@ -521,6 +521,7 @@ ld="${LD-${cross_prefix}ld}"
- ranlib="${RANLIB-${cross_prefix}ranlib}"
- nm="${NM-${cross_prefix}nm}"
- strip="${STRIP-${cross_prefix}strip}"
-+strings="${STRINGS-${cross_prefix}strings}"
- windres="${WINDRES-${cross_prefix}windres}"
- pkg_config_exe="${PKG_CONFIG-${cross_prefix}pkg-config}"
- query_pkg_config() {
-@@ -2265,9 +2266,9 @@ int main(int argc, char *argv[]) {
- EOF
- 
- if compile_object ; then
--    if strings -a $TMPO | grep -q BiGeNdIaN ; then
-+    if $strings -a $TMPO | grep -q BiGeNdIaN ; then
-         bigendian="yes"
--    elif strings -a $TMPO | grep -q LiTtLeEnDiAn ; then
-+    elif $strings -a $TMPO | grep -q LiTtLeEnDiAn ; then
-         bigendian="no"
-     else
-         echo big/little test failed

diff --git a/app-emulation/qemu/files/qemu-6.0.0-make.patch 
b/app-emulation/qemu/files/qemu-6.0.0-make.patch
deleted file mode 100644
index 2dac1ca1..00000000
--- a/app-emulation/qemu/files/qemu-6.0.0-make.patch
+++ /dev/null
@@ -1,14 +0,0 @@
-Allow MAKE='make V=1' and similar.
-
-https://bugs.gentoo.org/795678
---- a/configure
-+++ b/configure
-@@ -1953,7 +1953,7 @@ if test -z "$python"
- then
-     error_exit "Python not found. Use --python=/path/to/python"
- fi
--if ! has "$make"
-+if ! has $make
- then
-     error_exit "GNU make ($make) not found"
- fi

diff --git a/app-emulation/qemu/files/qemu-binfmt.initd.head 
b/app-emulation/qemu/files/qemu-binfmt.initd.head
deleted file mode 100644
index 7bada958..00000000
--- a/app-emulation/qemu/files/qemu-binfmt.initd.head
+++ /dev/null
@@ -1,64 +0,0 @@
-#!/sbin/openrc-run
-# Copyright 1999-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# Enable automatic non-native program execution by the kernel.
-
-# Defaulting to OC should be safe because it comes down to:
-#  - do we trust the interp itself to not be malicious?  yes; we built it.
-#  - do we trust the programs we're running?  ish; same permission as native
-#    binaries apply.  so if user can do bad stuff natively, cross isn't worse.
-: ${QEMU_BINFMT_FLAGS:=OC}
-
-depend() {
-       after procfs
-}
-
-start() {
-       ebegin "Registering qemu-user binaries (flags: ${QEMU_BINFMT_FLAGS})"
-
-       if [ ! -d /proc/sys/fs/binfmt_misc ] ; then
-               modprobe -q binfmt_misc
-       fi
-
-       if [ ! -d /proc/sys/fs/binfmt_misc ] ; then
-               eend 1 "You need support for 'misc binaries' in your kernel!"
-               return
-       fi
-
-       if [ ! -f /proc/sys/fs/binfmt_misc/register ] ; then
-               mount -t binfmt_misc -o nodev,noexec,nosuid \
-                       binfmt_misc /proc/sys/fs/binfmt_misc >/dev/null 2>&1
-               eend $? || return
-       fi
-
-       # Probe the native cpu type so we don't try registering them.
-       local cpu="$(uname -m)"
-       case "${cpu}" in
-       armv[4-9]*)
-               cpu="arm"
-               ;;
-       i386|i486|i586|i686|i86pc|BePC|x86_64)
-               cpu="i386"
-               ;;
-       m68k)
-               cpu="m68k"
-               ;;
-       mips*)
-               cpu="mips"
-               ;;
-       "Power Macintosh"|ppc|ppc64)
-               cpu="ppc"
-               ;;
-       s390*)
-               cpu="s390"
-               ;;
-       sh*)
-               cpu="sh"
-               ;;
-       sparc*)
-               cpu="sparc"
-               ;;
-       esac
-
-       # Register the interpreter for each cpu except for the native one.

diff --git a/app-emulation/qemu/files/qemu-binfmt.initd.tail 
b/app-emulation/qemu/files/qemu-binfmt.initd.tail
deleted file mode 100644
index 76794819..00000000
--- a/app-emulation/qemu/files/qemu-binfmt.initd.tail
+++ /dev/null
@@ -1,14 +0,0 @@
-       eend 0
-}
-
-stop() {
-       # We unregister everything in the "qemu-xxx" namespace.
-       ebegin "Unregistering qemu-user binaries"
-       local f
-       for f in /proc/sys/fs/binfmt_misc/qemu-* ; do
-               if [ -f "${f}" ] ; then
-                       echo '-1' > "${f}"
-               fi
-       done
-       eend 0
-}

diff --git a/app-emulation/qemu/metadata.xml b/app-emulation/qemu/metadata.xml
deleted file mode 100644
index c46cc091..00000000
--- a/app-emulation/qemu/metadata.xml
+++ /dev/null
@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd";>
-<pkgmetadata>
-       <maintainer type="person">
-               <email>[email protected]</email>
-               <name>Matthias Maier</name>
-       </maintainer>
-       <maintainer type="person">
-               <email>[email protected]</email>
-               <name>Mikle Kolyada</name>
-       </maintainer>
-       <maintainer type="project">
-               <email>[email protected]</email>
-               <name>Gentoo Virtualization Project</name>
-       </maintainer>
-       <use>
-               <flag name="accessibility">Adds support for braille displays 
using brltty</flag>
-               <flag name="aio">Enables support for Linux's Async IO</flag>
-               <flag name="alsa">Enable alsa output for sound emulation</flag>
-               <flag name="capstone">Enable disassembly support with 
<pkg>dev-libs/capstone</pkg></flag>
-               <flag name="curl">Support ISOs / -cdrom directives via HTTP or 
HTTPS.</flag>
-               <flag name="fdt">Enables firmware device tree support</flag>
-               <flag name="fuse">Enables FUSE block device export</flag>
-               <flag name="glusterfs">Enables GlusterFS cluster fileystem via
-                       <pkg>sys-cluster/glusterfs</pkg></flag>
-               <flag name="gnutls">Enable TLS support for the VNC console 
server.
-               For 1.4 and newer this also enables WebSocket support.
-               For 2.0 through 2.3 also enables disk quorum support.</flag>
-               <flag name="iscsi">Enable direct iSCSI support via
-               <pkg>net-libs/libiscsi</pkg> instead of indirectly via the Linux
-               block layer that <pkg>sys-block/open-iscsi</pkg> does.</flag>
-               <flag name="io-uring">Enable efficient I/O via 
<pkg>sys-libs/liburing</pkg>.</flag>
-               <flag name="multipath">Enable multipath persistent reservation 
passthrough via
-               <pkg>sys-fs/multipath-tools</pkg>.</flag>
-               <flag name="ncurses">Enable the ncurses-based console</flag>
-               <flag name="nfs">Enable NFS support</flag>
-               <flag name="numa">Enable NUMA support</flag>
-               <flag name="pin-upstream-blobs">Pin the versions of BIOS 
firmware to the version included in the upstream release.
-               This is needed to sanely support 
migration/suspend/resume/snapshotting/etc... of instances.
-               When the blobs are different, random 
corruption/bugs/crashes/etc... may be observed.</flag>
-               <flag name="plugins">Enable qemu plugin API via shared library 
loading.</flag>
-               <flag name="pulseaudio">Enable pulseaudio output for sound 
emulation</flag>
-               <flag name="rbd">Enable rados block device backend support, see 
http://ceph.newdream.net/wiki/QEMU-RBD</flag>
-               <flag name="sdl">Enable the SDL-based console</flag>
-               <flag name="sdl-image">SDL Image support for icons</flag>
-               <flag name="slirp">Enable TCP/IP in hypervisor via 
<pkg>net-libs/libslirp</pkg></flag>
-               <flag name="spice">Enable Spice protocol support via 
<pkg>app-emulation/spice</pkg></flag>
-               <flag name="ssh">Enable SSH based block device support via 
<pkg>net-libs/libssh2</pkg></flag>
-               <flag name="static-user">Build the User targets as static 
binaries</flag>
-               <flag name="static">Build the User and Software MMU (system) 
targets as well as tools as static binaries</flag>
-               <flag name="systemtap">Enable SystemTAP/DTrace tracing</flag>
-               <flag name="jemalloc">Enable jemalloc allocator support</flag>
-               <flag name="jpeg">Enable jpeg image support for the VNC console 
server</flag>
-               <flag name="png">Enable png image support for the VNC console 
server</flag>
-               <flag name="usb">Enable USB passthrough via 
<pkg>dev-libs/libusb</pkg></flag>
-               <flag name="usbredir">Use <pkg>sys-apps/usbredir</pkg> to 
redirect USB devices to another machine over TCP</flag>
-               <flag name="vde">Enable VDE-based networking</flag>
-               <flag name="vhost-net">Enable accelerated networking using 
vhost-net, see http://www.linux-kvm.org/page/VhostNet</flag>
-               <flag name="vhost-user-fs">Enable shared file system access 
using the FUSE protocol carried over virtio.</flag>
-               <flag name="virgl">Enable experimental Virgil 3d (virtual 
software GPU)</flag>
-               <flag name="virtfs">Enable VirtFS via virtio-9p-pci / fsdev. 
See http://wiki.qemu.org/Documentation/9psetup</flag>
-               <flag name="vte">Enable terminal support 
(<pkg>x11-libs/vte</pkg>) in the GTK+ interface</flag>
-               <flag name="xattr">Add support for getting and setting POSIX 
extended attributes, through
-               <pkg>sys-apps/attr</pkg>. Requisite for the virtfs 
backend.</flag>
-               <flag name="xen">Enables support for Xen backends</flag>
-               <flag name="xfs">Support xfsctl() notification and syncing for 
XFS backed
-               virtual disks.</flag>
-       </use>
-</pkgmetadata>

diff --git a/app-emulation/qemu/qemu-6.0.0-r55.ebuild 
b/app-emulation/qemu/qemu-6.0.0-r55.ebuild
deleted file mode 100644
index ecfcef8f..00000000
--- a/app-emulation/qemu/qemu-6.0.0-r55.ebuild
+++ /dev/null
@@ -1,924 +0,0 @@
-# Copyright 1999-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI="7"
-
-PYTHON_COMPAT=( python3_{7,8,9,10} )
-PYTHON_REQ_USE="ncurses,readline"
-
-FIRMWARE_ABI_VERSION="6.0.0-r50"
-
-inherit eutils linux-info toolchain-funcs multilib python-r1
-inherit udev fcaps readme.gentoo-r1 pax-utils xdg-utils
-
-if [[ ${PV} = *9999* ]]; then
-       EGIT_REPO_URI="https://git.qemu.org/git/qemu.git";
-       EGIT_SUBMODULES=(
-               meson
-               tests/fp/berkeley-softfloat-3
-               tests/fp/berkeley-testfloat-3
-               ui/keycodemapdb
-       )
-       inherit git-r3
-       SRC_URI=""
-else
-       SRC_URI="https://download.qemu.org/${P}.tar.xz";
-       KEYWORDS="amd64 arm64 ~ppc ppc64 x86"
-fi
-
-DESCRIPTION="QEMU + Kernel-based Virtual Machine userland tools"
-HOMEPAGE="https://www.qemu.org https://www.linux-kvm.org";
-
-LICENSE="GPL-2 LGPL-2 BSD-2"
-SLOT="0"
-
-IUSE="accessibility +aio alsa bzip2 capstone +caps +curl debug +doc
-       +fdt fuse glusterfs gnutls gtk infiniband iscsi io-uring
-       jack jemalloc +jpeg kernel_linux
-       kernel_FreeBSD lzo multipath
-       ncurses nfs nls numa opengl +oss +pin-upstream-blobs
-       plugins +png pulseaudio python rbd sasl +seccomp sdl sdl-image selinux
-       +slirp
-       smartcard snappy spice ssh static static-user systemtap test udev usb
-       usbredir vde +vhost-net vhost-user-fs virgl virtfs +vnc vte xattr xen
-       xfs zstd"
-
-COMMON_TARGETS="
-       aarch64
-       alpha
-       arm
-       cris
-       hppa
-       i386
-       m68k
-       microblaze
-       microblazeel
-       mips
-       mips64
-       mips64el
-       mipsel
-       nios2
-       or1k
-       ppc
-       ppc64
-       riscv32
-       riscv64
-       s390x
-       sh4
-       sh4eb
-       sparc
-       sparc64
-       x86_64
-       xtensa
-       xtensaeb
-"
-IUSE_SOFTMMU_TARGETS="
-       ${COMMON_TARGETS}
-       avr
-       lm32
-       moxie
-       rx
-       tricore
-       unicore32
-"
-IUSE_USER_TARGETS="
-       ${COMMON_TARGETS}
-       aarch64_be
-       armeb
-       hexagon
-       mipsn32
-       mipsn32el
-       ppc64abi32
-       ppc64le
-       sparc32plus
-"
-
-use_softmmu_targets=$(printf ' qemu_softmmu_targets_%s' 
${IUSE_SOFTMMU_TARGETS})
-use_user_targets=$(printf ' qemu_user_targets_%s' ${IUSE_USER_TARGETS})
-IUSE+=" ${use_softmmu_targets} ${use_user_targets}"
-
-RESTRICT="!test? ( test )"
-# Allow no targets to be built so that people can get a tools-only build.
-# Block USE flag configurations known to not work.
-REQUIRED_USE="${PYTHON_REQUIRED_USE}
-       qemu_softmmu_targets_arm? ( fdt )
-       qemu_softmmu_targets_microblaze? ( fdt )
-       qemu_softmmu_targets_mips64el? ( fdt )
-       qemu_softmmu_targets_ppc64? ( fdt )
-       qemu_softmmu_targets_ppc? ( fdt )
-       qemu_softmmu_targets_riscv32? ( fdt )
-       qemu_softmmu_targets_riscv64? ( fdt )
-       sdl-image? ( sdl )
-       static? ( static-user !alsa !gtk !jack !opengl !pulseaudio !plugins 
!rbd !snappy !udev )
-       static-user? ( !plugins )
-       vhost-user-fs? ( caps seccomp )
-       virgl? ( opengl )
-       virtfs? ( caps xattr )
-       vte? ( gtk )
-       multipath? ( udev )
-       plugins? ( !static !static-user )
-"
-
-# Dependencies required for qemu tools (qemu-nbd, qemu-img, qemu-io, ...)
-# and user/softmmu targets (qemu-*, qemu-system-*).
-#
-# Yep, you need both libcap and libcap-ng since virtfs only uses libcap.
-#
-# The attr lib isn't always linked in (although the USE flag is always
-# respected).  This is because qemu supports using the C library's API
-# when available rather than always using the external library.
-ALL_DEPEND="
-       >=dev-libs/glib-2.0[static-libs(+)]
-       sys-libs/zlib[static-libs(+)]
-       python? ( ${PYTHON_DEPS} )
-       systemtap? ( dev-util/systemtap )
-       xattr? ( sys-apps/attr[static-libs(+)] )"
-
-# Dependencies required for qemu tools (qemu-nbd, qemu-img, qemu-io, ...)
-# softmmu targets (qemu-system-*).
-SOFTMMU_TOOLS_DEPEND="
-       dev-libs/libxml2[static-libs(+)]
-       >=x11-libs/pixman-0.28.0[static-libs(+)]
-       accessibility? (
-               app-accessibility/brltty[api]
-               app-accessibility/brltty[static-libs(+)]
-       )
-       aio? ( dev-libs/libaio[static-libs(+)] )
-       alsa? ( >=media-libs/alsa-lib-1.0.13 )
-       bzip2? ( app-arch/bzip2[static-libs(+)] )
-       capstone? ( dev-libs/capstone:= )
-       caps? ( sys-libs/libcap-ng[static-libs(+)] )
-       curl? ( >=net-misc/curl-7.15.4[static-libs(+)] )
-       fdt? ( >=sys-apps/dtc-1.5.0[static-libs(+)] )
-       fuse? ( >=sys-fs/fuse-3.1:3[static-libs(+)] )
-       glusterfs? ( >=sys-cluster/glusterfs-3.4.0[static-libs(+)] )
-       gnutls? (
-               dev-libs/nettle:=[static-libs(+)]
-               >=net-libs/gnutls-3.0:=[static-libs(+)]
-       )
-       gtk? (
-               x11-libs/gtk+:3
-               vte? ( x11-libs/vte:2.91 )
-       )
-       infiniband? ( sys-cluster/rdma-core[static-libs(+)] )
-       iscsi? ( net-libs/libiscsi )
-       io-uring? ( sys-libs/liburing:=[static-libs(+)] )
-       jack? ( virtual/jack )
-       jemalloc? ( dev-libs/jemalloc )
-       jpeg? ( virtual/jpeg:0=[static-libs(+)] )
-       lzo? ( dev-libs/lzo:2[static-libs(+)] )
-       multipath? ( sys-fs/multipath-tools )
-       ncurses? (
-               sys-libs/ncurses:=[unicode(+)]
-               sys-libs/ncurses:=[static-libs(+)]
-       )
-       nfs? ( >=net-fs/libnfs-1.9.3:=[static-libs(+)] )
-       numa? ( sys-process/numactl[static-libs(+)] )
-       opengl? (
-               virtual/opengl
-               media-libs/libepoxy[static-libs(+)]
-               media-libs/mesa[static-libs(+)]
-               media-libs/mesa[egl(+),gbm(+)]
-       )
-       png? ( media-libs/libpng:0=[static-libs(+)] )
-       pulseaudio? ( media-sound/pulseaudio )
-       rbd? ( sys-cluster/ceph )
-       sasl? ( dev-libs/cyrus-sasl[static-libs(+)] )
-       sdl? (
-               media-libs/libsdl2[video]
-               media-libs/libsdl2[static-libs(+)]
-       )
-       sdl-image? ( media-libs/sdl2-image[static-libs(+)] )
-       seccomp? ( >=sys-libs/libseccomp-2.1.0[static-libs(+)] )
-       slirp? ( net-libs/libslirp[static-libs(+)] )
-       smartcard? ( >=app-emulation/libcacard-2.5.0[static-libs(+)] )
-       snappy? ( app-arch/snappy:= )
-       spice? (
-               >=app-emulation/spice-protocol-0.12.3
-               >=app-emulation/spice-0.12.0[static-libs(+)]
-       )
-       ssh? ( >=net-libs/libssh-0.8.6[static-libs(+)] )
-       udev? ( virtual/libudev:= )
-       usb? ( >=virtual/libusb-1-r2[static-libs(+)] )
-       usbredir? ( >=sys-apps/usbredir-0.6[static-libs(+)] )
-       vde? ( net-misc/vde[static-libs(+)] )
-       virgl? ( media-libs/virglrenderer[static-libs(+)] )
-       virtfs? ( sys-libs/libcap )
-       xen? ( app-emulation/xen-tools:= )
-       xfs? ( sys-fs/xfsprogs[static-libs(+)] )
-       zstd? ( >=app-arch/zstd-1.4.0[static-libs(+)] )
-"
-
-EDK2_OVMF_VERSION="202105"
-SEABIOS_VERSION="1.14.0"
-
-X86_FIRMWARE_DEPEND="
-       pin-upstream-blobs? (
-               ~sys-firmware/edk2-ovmf-${EDK2_OVMF_VERSION}[binary]
-               ~sys-firmware/ipxe-1.21.1[binary,qemu]
-               ~sys-firmware/seabios-${SEABIOS_VERSION}[binary,seavgabios]
-               ~sys-firmware/sgabios-0.1_pre10[binary]
-       )
-       !pin-upstream-blobs? (
-               >=sys-firmware/edk2-ovmf-${EDK2_OVMF_VERSION}
-               sys-firmware/ipxe[qemu]
-               >=sys-firmware/seabios-${SEABIOS_VERSION}[seavgabios]
-               sys-firmware/sgabios
-       )"
-PPC_FIRMWARE_DEPEND="
-       pin-upstream-blobs? (
-               ~sys-firmware/seabios-${SEABIOS_VERSION}[binary,seavgabios]
-       )
-       !pin-upstream-blobs? (
-               >=sys-firmware/seabios-${SEABIOS_VERSION}[seavgabios]
-       )
-"
-
-BDEPEND="
-       $(python_gen_impl_dep)
-       dev-lang/perl
-       sys-apps/texinfo
-       virtual/pkgconfig
-       doc? ( dev-python/sphinx[${PYTHON_USEDEP}] )
-       gtk? ( nls? ( sys-devel/gettext ) )
-       test? (
-               dev-libs/glib[utils]
-               sys-devel/bc
-       )
-"
-CDEPEND="
-       !static? (
-               ${ALL_DEPEND//\[static-libs(+)]}
-               ${SOFTMMU_TOOLS_DEPEND//\[static-libs(+)]}
-       )
-       qemu_softmmu_targets_i386? ( ${X86_FIRMWARE_DEPEND} )
-       qemu_softmmu_targets_x86_64? ( ${X86_FIRMWARE_DEPEND} )
-       qemu_softmmu_targets_ppc? ( ${PPC_FIRMWARE_DEPEND} )
-       qemu_softmmu_targets_ppc64? ( ${PPC_FIRMWARE_DEPEND} )
-"
-DEPEND="${CDEPEND}
-       kernel_linux? ( >=sys-kernel/linux-headers-2.6.35 )
-       static? (
-               ${ALL_DEPEND}
-               ${SOFTMMU_TOOLS_DEPEND}
-       )
-       static-user? ( ${ALL_DEPEND} )"
-RDEPEND="${CDEPEND}
-       acct-group/kvm
-       selinux? ( sec-policy/selinux-qemu )"
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-2.11.1-capstone_include_path.patch
-       "${FILESDIR}"/${PN}-5.2.0-strings.patch
-       "${FILESDIR}"/${PN}-5.2.0-cleaner-werror.patch
-       "${FILESDIR}"/${PN}-5.2.0-disable-keymap.patch
-       "${FILESDIR}"/${PN}-5.2.0-dce-locks.patch
-       "${FILESDIR}"/${PN}-6.0.0-make.patch
-)
-
-QA_PREBUILT="
-       usr/share/qemu/hppa-firmware.img
-       usr/share/qemu/openbios-ppc
-       usr/share/qemu/openbios-sparc64
-       usr/share/qemu/openbios-sparc32
-       usr/share/qemu/opensbi-riscv64-generic-fw_dynamic.elf
-       usr/share/qemu/opensbi-riscv32-generic-fw_dynamic.elf
-       usr/share/qemu/palcode-clipper
-       usr/share/qemu/s390-ccw.img
-       usr/share/qemu/s390-netboot.img
-       usr/share/qemu/u-boot.e500
-"
-
-QA_WX_LOAD="usr/bin/qemu-i386
-       usr/bin/qemu-x86_64
-       usr/bin/qemu-alpha
-       usr/bin/qemu-arm
-       usr/bin/qemu-cris
-       usr/bin/qemu-m68k
-       usr/bin/qemu-microblaze
-       usr/bin/qemu-microblazeel
-       usr/bin/qemu-mips
-       usr/bin/qemu-mipsel
-       usr/bin/qemu-or1k
-       usr/bin/qemu-ppc
-       usr/bin/qemu-ppc64
-       usr/bin/qemu-ppc64abi32
-       usr/bin/qemu-sh4
-       usr/bin/qemu-sh4eb
-       usr/bin/qemu-sparc
-       usr/bin/qemu-sparc64
-       usr/bin/qemu-armeb
-       usr/bin/qemu-sparc32plus
-       usr/bin/qemu-s390x
-       usr/bin/qemu-unicore32
-"
-
-DOC_CONTENTS="If you don't have kvm compiled into the kernel, make sure you 
have the
-kernel module loaded before running kvm. The easiest way to ensure that the
-kernel module is loaded is to load it on boot.
-       For AMD CPUs the module is called 'kvm-amd'.
-       For Intel CPUs the module is called 'kvm-intel'.
-Please review /etc/conf.d/modules for how to load these.
-
-Make sure your user is in the 'kvm' group. Just run
-       $ gpasswd -a <USER> kvm
-then have <USER> re-login.
-
-For brand new installs, the default permissions on /dev/kvm might not let
-you access it.  You can tell udev to reset ownership/perms:
-       $ udevadm trigger -c add /dev/kvm
-
-If you want to register binfmt handlers for qemu user targets:
-For openrc:
-       # rc-update add qemu-binfmt
-For systemd:
-       # ln -s /usr/share/qemu/binfmt.d/qemu.conf /etc/binfmt.d/qemu.conf"
-
-pkg_pretend() {
-       if use kernel_linux && kernel_is lt 2 6 25; then
-               eerror "This version of KVM requires a host kernel of 2.6.25 or 
higher."
-       elif use kernel_linux; then
-               if ! linux_config_exists; then
-                       eerror "Unable to check your kernel for KVM support"
-               else
-                       CONFIG_CHECK="~KVM ~TUN ~BRIDGE"
-                       ERROR_KVM="You must enable KVM in your kernel to 
continue"
-                       ERROR_KVM_AMD="If you have an AMD CPU, you must enable 
KVM_AMD in"
-                       ERROR_KVM_AMD+=" your kernel configuration."
-                       ERROR_KVM_INTEL="If you have an Intel CPU, you must 
enable"
-                       ERROR_KVM_INTEL+=" KVM_INTEL in your kernel 
configuration."
-                       ERROR_TUN="You will need the Universal TUN/TAP driver 
compiled"
-                       ERROR_TUN+=" into your kernel or loaded as a module to 
use the"
-                       ERROR_TUN+=" virtual network device if using -net tap."
-                       ERROR_BRIDGE="You will also need support for 802.1d"
-                       ERROR_BRIDGE+=" Ethernet Bridging for some network 
configurations."
-                       use vhost-net && CONFIG_CHECK+=" ~VHOST_NET"
-                       ERROR_VHOST_NET="You must enable VHOST_NET to have 
vhost-net"
-                       ERROR_VHOST_NET+=" support"
-
-                       if use amd64 || use x86 || use amd64-linux || use 
x86-linux; then
-                               if grep -q AuthenticAMD /proc/cpuinfo; then
-                                       CONFIG_CHECK+=" ~KVM_AMD"
-                               elif grep -q GenuineIntel /proc/cpuinfo; then
-                                       CONFIG_CHECK+=" ~KVM_INTEL"
-                               fi
-                       fi
-
-                       use python && CONFIG_CHECK+=" ~DEBUG_FS"
-                       ERROR_DEBUG_FS="debugFS support required for kvm_stat"
-
-                       # Now do the actual checks setup above
-                       check_extra_config
-               fi
-       fi
-
-       if grep -qs '/usr/bin/qemu-kvm' "${EROOT}"/etc/libvirt/qemu/*.xml; then
-               eerror "The kvm/qemu-kvm wrappers no longer exist, but your 
libvirt"
-               eerror "instances are still pointing to it.  Please update your"
-               eerror "configs in /etc/libvirt/qemu/ to use the -enable-kvm 
flag"
-               eerror "and the right system binary (e.g. qemu-system-x86_64)."
-               die "update your virt configs to not use qemu-kvm"
-       fi
-}
-
-# Sanity check to make sure target lists are kept up-to-date.
-check_targets() {
-       local var=$1 mak=$2
-       local detected sorted
-
-       pushd "${S}"/default-configs/targets/ >/dev/null || die
-
-       # Force C locale until glibc is updated. #564936
-       detected=$(echo $(printf '%s\n' *-${mak}.mak | sed "s:-${mak}.mak::" | 
LC_COLLATE=C sort -u))
-       sorted=$(echo $(printf '%s\n' ${!var} | LC_COLLATE=C sort -u))
-       if [[ ${sorted} != "${detected}" ]] ; then
-               eerror "The ebuild needs to be kept in sync."
-               eerror "${var}: ${sorted}"
-               eerror "$(printf '%-*s' ${#var} configure): ${detected}"
-               die "sync ${var} to the list of targets"
-       fi
-
-       popd >/dev/null
-}
-
-src_prepare() {
-       check_targets IUSE_SOFTMMU_TARGETS softmmu
-       check_targets IUSE_USER_TARGETS linux-user
-
-       default
-
-       # Use correct toolchain to fix cross-compiling
-       tc-export AR AS LD NM OBJCOPY PKG_CONFIG RANLIB STRINGS
-       export WINDRES=${CHOST}-windres
-
-       # Verbose builds
-       MAKEOPTS+=" V=1"
-
-       # Remove bundled copy of libfdt
-       rm -r dtc || die
-
-       # conditionally apply patches for musl support
-       if use elibc_musl ; then
-               eapply 
"${FILESDIR}"/musl-patches/0001-linux-user-fix-build-with-musl-on-aarch64.patch
-               eapply 
"${FILESDIR}"/musl-patches/0001-linux-user-fix-build-with-musl-on-ppc64le.patch
-               eapply 
"${FILESDIR}"/musl-patches/0001-virtio-host-input-use-safe-64-bit-time-accessors-for.patch
-               eapply 
"${FILESDIR}"/musl-patches/0002-virtio-user-input-use-safe-64-bit-time-accessors-for.patch
-               eapply 
"${FILESDIR}"/musl-patches/0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
-               eapply "${FILESDIR}"/musl-patches/MAP_SYNC-fix.patch
-               eapply 
"${FILESDIR}"/musl-patches/fix-segevent-and-sigval_t.patch
-               eapply "${FILESDIR}"/musl-patches/fix-sendmsg.patch
-               eapply "${FILESDIR}"/musl-patches/fix-sockios-header.patch
-               eapply 
"${FILESDIR}"/musl-patches/ignore-signals-33-and-64-to-allow-golang-emulation.patch
-               eapply "${FILESDIR}"/musl-patches/mips-softfloat.patch
-               eapply "${FILESDIR}"/musl-patches/musl-F_SHLCK-and-F_EXLCK.patch
-               eapply "${FILESDIR}"/musl-patches/xattr_size_max.patch
-       fi
-}
-
-##
-# configures qemu based on the build directory and the build type
-# we are using.
-#
-qemu_src_configure() {
-       debug-print-function ${FUNCNAME} "$@"
-
-       local buildtype=$1
-       local builddir="${S}/${buildtype}-build"
-
-       mkdir "${builddir}"
-
-       local conf_opts=(
-               --prefix=/usr
-               --sysconfdir=/etc
-               --bindir=/usr/bin
-               --libdir=/usr/$(get_libdir)
-               --datadir=/usr/share
-               --docdir=/usr/share/doc/${PF}/html
-               --mandir=/usr/share/man
-               --localstatedir=/var
-               --disable-bsd-user
-               --disable-containers # bug #732972
-               --disable-guest-agent
-               --disable-strip
-
-               # bug #746752: TCG interpreter has a few limitations:
-               # - it does not support FPU
-               # - it's generally slower on non-self-modifying code
-               # It's advantage is support for host architectures
-               # where native codegeneration is not implemented.
-               # Gentoo has qemu keyworded only on targets with
-               # native code generation available. Avoid the interpreter.
-               --disable-tcg-interpreter
-
-               --disable-werror
-               # We support gnutls/nettle for crypto operations.  It is 
possible
-               # to use gcrypt when gnutls/nettle are disabled (but not when 
they
-               # are enabled), but it's not really worth the hassle.  Disable 
it
-               # all the time to avoid automatically detecting it. #568856
-               --disable-gcrypt
-               --python="${PYTHON}"
-               --cc="$(tc-getCC)"
-               --cxx="$(tc-getCXX)"
-               --host-cc="$(tc-getBUILD_CC)"
-               $(use_enable debug debug-info)
-               $(use_enable debug debug-tcg)
-               $(use_enable doc docs)
-               $(use_enable nls gettext)
-               $(use_enable plugins)
-               $(use_enable xattr attr)
-       )
-
-       # Disable options not used by user targets. This simplifies building
-       # static user targets (USE=static-user) considerably.
-       conf_notuser() {
-               if [[ ${buildtype} == "user" ]] ; then
-                       echo "--disable-${2:-$1}"
-               else
-                       use_enable "$@"
-               fi
-       }
-       # Enable option only for softmmu build, but not 'user' or 'tools'
-       conf_softmmu() {
-               if [[ ${buildtype} == "softmmu" ]] ; then
-                       use_enable "$@"
-               else
-                       echo "--disable-${2:-$1}"
-               fi
-       }
-       # Enable option only for tools build, but not 'user' or 'softmmu'
-       conf_tools() {
-               if [[ ${buildtype} == "tools" ]] ; then
-                       use_enable "$@"
-               else
-                       echo "--disable-${2:-$1}"
-               fi
-       }
-       conf_opts+=(
-               $(conf_notuser accessibility brlapi)
-               $(conf_notuser aio linux-aio)
-               $(conf_notuser bzip2)
-               $(conf_notuser capstone)
-               $(conf_notuser caps cap-ng)
-               $(conf_notuser curl)
-               $(conf_notuser fdt)
-               $(conf_notuser fuse)
-               $(conf_notuser glusterfs)
-               $(conf_notuser gnutls)
-               $(conf_notuser gnutls nettle)
-               $(conf_notuser gtk)
-               $(conf_notuser infiniband rdma)
-               $(conf_notuser iscsi libiscsi)
-               $(conf_notuser io-uring linux-io-uring)
-               $(conf_notuser jemalloc jemalloc)
-               $(conf_notuser jpeg vnc-jpeg)
-               $(conf_notuser kernel_linux kvm)
-               $(conf_notuser lzo)
-               $(conf_notuser multipath mpath)
-               $(conf_notuser ncurses curses)
-               $(conf_notuser nfs libnfs)
-               $(conf_notuser numa)
-               $(conf_notuser opengl)
-               $(conf_notuser png vnc-png)
-               $(conf_notuser rbd)
-               $(conf_notuser sasl vnc-sasl)
-               $(conf_notuser sdl)
-               $(conf_softmmu sdl-image)
-               $(conf_notuser seccomp)
-               $(conf_notuser slirp slirp system)
-               $(conf_notuser smartcard)
-               $(conf_notuser snappy)
-               $(conf_notuser spice)
-               $(conf_notuser ssh libssh)
-               $(conf_notuser udev libudev)
-               $(conf_notuser usb libusb)
-               $(conf_notuser usbredir usb-redir)
-               $(conf_notuser vde)
-               $(conf_notuser vhost-net)
-               $(conf_notuser vhost-user-fs)
-               $(conf_tools vhost-user-fs virtiofsd)
-               $(conf_notuser virgl virglrenderer)
-               $(conf_softmmu virtfs)
-               $(conf_notuser vnc)
-               $(conf_notuser vte)
-               $(conf_notuser xen)
-               $(conf_notuser xen xen-pci-passthrough)
-               $(conf_notuser xfs xfsctl)
-               # use prebuilt keymaps, bug #759604
-               --disable-xkbcommon
-               $(conf_notuser zstd)
-       )
-
-       if [[ ${buildtype} == "user" ]] ; then
-               conf_opts+=( --disable-libxml2 )
-       else
-               conf_opts+=( --enable-libxml2 )
-       fi
-
-       if [[ ! ${buildtype} == "user" ]] ; then
-               # audio options
-               local audio_opts=(
-                       # Note: backend order matters here: #716202
-                       # We iterate from higher-level to lower level.
-                       $(usex pulseaudio pa "")
-                       $(usev jack)
-                       $(usev sdl)
-                       $(usev alsa)
-                       $(usev oss)
-               )
-               conf_opts+=(
-                       --audio-drv-list=$(printf "%s," "${audio_opts[@]}")
-               )
-       fi
-
-       case ${buildtype} in
-       user)
-               conf_opts+=(
-                       --enable-linux-user
-                       --disable-system
-                       --disable-blobs
-                       --disable-tools
-               )
-               local static_flag="static-user"
-               ;;
-       softmmu)
-               conf_opts+=(
-                       --disable-linux-user
-                       --enable-system
-                       --disable-tools
-               )
-               local static_flag="static"
-               ;;
-       tools)
-               conf_opts+=(
-                       --disable-linux-user
-                       --disable-system
-                       --disable-blobs
-                       --enable-tools
-               )
-               local static_flag="static"
-               ;;
-       esac
-
-       local targets="${buildtype}_targets"
-       [[ -n ${targets} ]] && conf_opts+=( --target-list="${!targets}" )
-
-       # Add support for SystemTAP
-       use systemtap && conf_opts+=( --enable-trace-backend=dtrace )
-
-       # We always want to attempt to build with PIE support as it results
-       # in a more secure binary. But it doesn't work with static or if
-       # the current GCC doesn't have PIE support.
-       if use ${static_flag}; then
-               conf_opts+=( --static --disable-pie )
-       else
-               tc-enables-pie && conf_opts+=( --enable-pie )
-       fi
-
-       # Meson will not use a cross-file unless cross_prefix is set.
-       tc-is-cross-compiler && conf_opts+=( --cross-prefix="${CHOST}-" )
-
-       # Plumb through equivalent of EXTRA_ECONF to allow experiments
-       # like bug #747928.
-       conf_opts+=( ${EXTRA_CONF_QEMU} )
-
-       echo "../configure ${conf_opts[*]}"
-       cd "${builddir}"
-       ../configure "${conf_opts[@]}" || die "configure failed"
-
-       # FreeBSD's kernel does not support QEMU assigning/grabbing
-       # host USB devices yet
-       use kernel_FreeBSD && \
-               sed -i -E -e "s|^(HOST_USB=)bsd|\1stub|" "${S}"/config-host.mak
-}
-
-src_configure() {
-       local target
-
-       python_setup
-
-       softmmu_targets= softmmu_bins=()
-       user_targets= user_bins=()
-
-       for target in ${IUSE_SOFTMMU_TARGETS} ; do
-               if use "qemu_softmmu_targets_${target}"; then
-                       softmmu_targets+=",${target}-softmmu"
-                       softmmu_bins+=( "qemu-system-${target}" )
-               fi
-       done
-
-       for target in ${IUSE_USER_TARGETS} ; do
-               if use "qemu_user_targets_${target}"; then
-                       user_targets+=",${target}-linux-user"
-                       user_bins+=( "qemu-${target}" )
-               fi
-       done
-
-       softmmu_targets=${softmmu_targets#,}
-       user_targets=${user_targets#,}
-
-       [[ -n ${softmmu_targets} ]] && qemu_src_configure "softmmu"
-       [[ -n ${user_targets}    ]] && qemu_src_configure "user"
-       qemu_src_configure "tools"
-}
-
-src_compile() {
-       if [[ -n ${user_targets} ]]; then
-               cd "${S}/user-build"
-               default
-       fi
-
-       if [[ -n ${softmmu_targets} ]]; then
-               cd "${S}/softmmu-build"
-               default
-       fi
-
-       cd "${S}/tools-build"
-       default
-}
-
-src_test() {
-       if [[ -n ${softmmu_targets} ]]; then
-               cd "${S}/softmmu-build"
-               pax-mark m */qemu-system-* #515550
-               emake check
-       fi
-}
-
-qemu_python_install() {
-       python_domodule "${S}/python/qemu"
-
-       python_doscript "${S}/scripts/kvm/vmxcap"
-       python_doscript "${S}/scripts/qmp/qmp-shell"
-       python_doscript "${S}/scripts/qmp/qemu-ga-client"
-}
-
-# Generate binfmt support files.
-#   - /etc/init.d/qemu-binfmt script which registers the user handlers (openrc)
-#   - /usr/share/qemu/binfmt.d/qemu.conf (for use with systemd-binfmt)
-generate_initd() {
-       local out="${T}/qemu-binfmt"
-       local out_systemd="${T}/qemu.conf"
-       local d="${T}/binfmt.d"
-
-       einfo "Generating qemu binfmt scripts and configuration files"
-
-       # Generate the debian fragments first.
-       mkdir -p "${d}"
-       "${S}"/scripts/qemu-binfmt-conf.sh \
-               --debian \
-               --exportdir "${d}" \
-               --qemu-path "${EPREFIX}/usr/bin" \
-               || die
-       # Then turn the fragments into a shell script we can source.
-       sed -E -i \
-               -e 's:^([^ ]+) (.*)$:\1="\2":' \
-               "${d}"/* || die
-
-       # Generate the init.d script by assembling the fragments from above.
-       local f qcpu package interpreter magic mask
-       cat "${FILESDIR}"/qemu-binfmt.initd.head >"${out}" || die
-       for f in "${d}"/qemu-* ; do
-               source "${f}"
-
-               # Normalize the cpu logic like we do in the init.d for the 
native cpu.
-               qcpu=${package#qemu-}
-               case ${qcpu} in
-               arm*)   qcpu="arm";;
-               mips*)  qcpu="mips";;
-               ppc*)   qcpu="ppc";;
-               s390*)  qcpu="s390";;
-               sh*)    qcpu="sh";;
-               sparc*) qcpu="sparc";;
-               esac
-
-               # we use 'printf' here to be portable across 'sh'
-               # implementations: #679168
-               cat <<EOF >>"${out}"
-       if [ "\${cpu}" != "${qcpu}" -a -x "${interpreter}" ] ; then
-               printf '%s\n' 
':${package}:M::${magic}:${mask}:${interpreter}:'"\${QEMU_BINFMT_FLAGS}" 
>/proc/sys/fs/binfmt_misc/register
-       fi
-EOF
-
-               echo ":${package}:M::${magic}:${mask}:${interpreter}:OC" 
>>"${out_systemd}"
-
-       done
-       cat "${FILESDIR}"/qemu-binfmt.initd.tail >>"${out}" || die
-}
-
-src_install() {
-       if [[ -n ${user_targets} ]]; then
-               cd "${S}/user-build"
-               emake DESTDIR="${ED}" install
-
-               # Install binfmt handler init script for user targets.
-               generate_initd
-               doinitd "${T}/qemu-binfmt"
-
-               # Install binfmt/qemu.conf.
-               insinto "/usr/share/qemu/binfmt.d"
-               doins "${T}/qemu.conf"
-       fi
-
-       if [[ -n ${softmmu_targets} ]]; then
-               cd "${S}/softmmu-build"
-               emake DESTDIR="${ED}" install
-
-               # This might not exist if the test failed. #512010
-               [[ -e check-report.html ]] && dodoc check-report.html
-
-               if use kernel_linux; then
-                       udev_newrules "${FILESDIR}"/65-kvm.rules-r2 65-kvm.rules
-               fi
-
-               if use python; then
-                       python_foreach_impl qemu_python_install
-               fi
-       fi
-
-       cd "${S}/tools-build"
-       emake DESTDIR="${ED}" install
-
-       # Disable mprotect on the qemu binaries as they use JITs to be fast 
#459348
-       pushd "${ED}"/usr/bin >/dev/null
-       pax-mark mr "${softmmu_bins[@]}" "${user_bins[@]}" # bug 575594
-       popd >/dev/null
-
-       # Install config file example for qemu-bridge-helper
-       insinto "/etc/qemu"
-       doins "${FILESDIR}/bridge.conf"
-
-       cd "${S}"
-       dodoc MAINTAINERS docs/specs/pci-ids.txt
-       newdoc pc-bios/README README.pc-bios
-
-       # Disallow stripping of prebuilt firmware files.
-       dostrip -x ${QA_PREBUILT}
-
-       if [[ -n ${softmmu_targets} ]]; then
-               # Remove SeaBIOS since we're using the SeaBIOS packaged one
-               rm "${ED}/usr/share/qemu/bios.bin"
-               rm "${ED}/usr/share/qemu/bios-256k.bin"
-               if use qemu_softmmu_targets_x86_64 || use 
qemu_softmmu_targets_i386; then
-                       dosym ../seabios/bios.bin /usr/share/qemu/bios.bin
-                       dosym ../seabios/bios-256k.bin 
/usr/share/qemu/bios-256k.bin
-               fi
-
-               # Remove vgabios since we're using the seavgabios packaged one
-               rm "${ED}/usr/share/qemu/vgabios.bin"
-               rm "${ED}/usr/share/qemu/vgabios-cirrus.bin"
-               rm "${ED}/usr/share/qemu/vgabios-qxl.bin"
-               rm "${ED}/usr/share/qemu/vgabios-stdvga.bin"
-               rm "${ED}/usr/share/qemu/vgabios-virtio.bin"
-               rm "${ED}/usr/share/qemu/vgabios-vmware.bin"
-               # PPC/PPC64 loads vgabios-stdvga
-               if use qemu_softmmu_targets_x86_64 || use 
qemu_softmmu_targets_i386 || use qemu_softmmu_targets_ppc || use 
qemu_softmmu_targets_ppc64; then
-                       dosym ../seavgabios/vgabios-isavga.bin 
/usr/share/qemu/vgabios.bin
-                       dosym ../seavgabios/vgabios-cirrus.bin 
/usr/share/qemu/vgabios-cirrus.bin
-                       dosym ../seavgabios/vgabios-qxl.bin 
/usr/share/qemu/vgabios-qxl.bin
-                       dosym ../seavgabios/vgabios-stdvga.bin 
/usr/share/qemu/vgabios-stdvga.bin
-                       dosym ../seavgabios/vgabios-virtio.bin 
/usr/share/qemu/vgabios-virtio.bin
-                       dosym ../seavgabios/vgabios-vmware.bin 
/usr/share/qemu/vgabios-vmware.bin
-               fi
-
-               # Remove sgabios since we're using the sgabios packaged one
-               rm "${ED}/usr/share/qemu/sgabios.bin"
-               if use qemu_softmmu_targets_x86_64 || use 
qemu_softmmu_targets_i386; then
-                       dosym ../sgabios/sgabios.bin /usr/share/qemu/sgabios.bin
-               fi
-
-               # Remove iPXE since we're using the iPXE packaged one
-               rm "${ED}"/usr/share/qemu/pxe-*.rom
-               if use qemu_softmmu_targets_x86_64 || use 
qemu_softmmu_targets_i386; then
-                       dosym ../ipxe/8086100e.rom /usr/share/qemu/pxe-e1000.rom
-                       dosym ../ipxe/80861209.rom 
/usr/share/qemu/pxe-eepro100.rom
-                       dosym ../ipxe/10500940.rom 
/usr/share/qemu/pxe-ne2k_pci.rom
-                       dosym ../ipxe/10222000.rom /usr/share/qemu/pxe-pcnet.rom
-                       dosym ../ipxe/10ec8139.rom 
/usr/share/qemu/pxe-rtl8139.rom
-                       dosym ../ipxe/1af41000.rom 
/usr/share/qemu/pxe-virtio.rom
-               fi
-       fi
-
-       DISABLE_AUTOFORMATTING=true
-       readme.gentoo_create_doc
-}
-
-firmware_abi_change() {
-       local pv
-       for pv in ${REPLACING_VERSIONS}; do
-               if ver_test ${pv} -lt ${FIRMWARE_ABI_VERSION}; then
-                       return 0
-               fi
-       done
-       return 1
-}
-
-pkg_postinst() {
-       if [[ -n ${softmmu_targets} ]] && use kernel_linux; then
-               udev_reload
-       fi
-
-       xdg_icon_cache_update
-
-       [[ -z ${EPREFIX} ]] && [[ -f ${EROOT}/usr/libexec/qemu-bridge-helper ]] 
&& \
-               fcaps cap_net_admin ${EROOT}/usr/libexec/qemu-bridge-helper
-
-       DISABLE_AUTOFORMATTING=true
-       readme.gentoo_print_elog
-
-       if use pin-upstream-blobs && firmware_abi_change; then
-               ewarn "This version of qemu pins new versions of firmware 
blobs:"
-               ewarn " $(best_version sys-firmware/edk2-ovmf)"
-               ewarn " $(best_version sys-firmware/ipxe)"
-               ewarn " $(best_version sys-firmware/seabios)"
-               ewarn " $(best_version sys-firmware/sgabios)"
-               ewarn "This might break resume of hibernated guests (started 
with a different"
-               ewarn "firmware version) and live migration to/from qemu 
versions with different"
-               ewarn "firmware. Please (cold) restart all running guests. For 
functional"
-               ewarn "guest migration ensure that all"
-               ewarn "hosts run at least"
-               ewarn " app-emulation/qemu-${FIRMWARE_ABI_VERSION}."
-       fi
-}
-
-pkg_info() {
-       echo "Using:"
-       echo "  $(best_version app-emulation/spice-protocol)"
-       echo "  $(best_version sys-firmware/edk2-ovmf)"
-       if has_version 'sys-firmware/edk2-ovmf[binary]'; then
-               echo "    USE=binary"
-       else
-               echo "    USE=''"
-       fi
-       echo "  $(best_version sys-firmware/ipxe)"
-       echo "  $(best_version sys-firmware/seabios)"
-       if has_version 'sys-firmware/seabios[binary]'; then
-               echo "    USE=binary"
-       else
-               echo "    USE=''"
-       fi
-       echo "  $(best_version sys-firmware/sgabios)"
-}
-
-pkg_postrm() {
-       xdg_icon_cache_update
-}

Reply via email to