Github messages for voidlinux
 help / color / mirror / Atom feed
* [PR PATCH] qemu: replace ppc64 musl patches with a generalized ppc32/64 one
@ 2019-07-01 18:33 voidlinux-github
  2019-07-01 19:10 ` [PR PATCH] [Merged]: " voidlinux-github
  0 siblings, 1 reply; 2+ messages in thread
From: voidlinux-github @ 2019-07-01 18:33 UTC (permalink / raw)
  To: ml

[-- Attachment #1: Type: text/plain, Size: 434 bytes --]

There is a new pull request by q66 against master on the void-packages repository

https://github.com/void-power/void-packages qemu
https://github.com/void-linux/void-packages/pull/12774

qemu: replace ppc64 musl patches with a generalized ppc32/64 one
the previous patches didn't cover ppc32, replace both with a bit cleaner unified patch...

A patch file from https://github.com/void-linux/void-packages/pull/12774.patch is attached

[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: github-pr-qemu-12774.patch --]
[-- Type: application/text/x-diff, Size: 5015 bytes --]

From a3798d8a08ed6c81996e2101a3f0d36cd268d0e5 Mon Sep 17 00:00:00 2001
From: q66 <daniel@octaforge.org>
Date: Mon, 1 Jul 2019 20:15:35 +0200
Subject: [PATCH] qemu: replace ppc64 musl patches with a generalized ppc32/64
 one

[ci skip]
---
 srcpkgs/qemu/patches/musl-ppc.patch           | 60 +++++++++++++++++++
 srcpkgs/qemu/patches/musl-ppc64-pt_nip.patch  | 12 ----
 srcpkgs/qemu/patches/musl-ppc64-pt_regs.patch | 16 -----
 3 files changed, 60 insertions(+), 28 deletions(-)
 create mode 100644 srcpkgs/qemu/patches/musl-ppc.patch
 delete mode 100644 srcpkgs/qemu/patches/musl-ppc64-pt_nip.patch
 delete mode 100644 srcpkgs/qemu/patches/musl-ppc64-pt_regs.patch

diff --git a/srcpkgs/qemu/patches/musl-ppc.patch b/srcpkgs/qemu/patches/musl-ppc.patch
new file mode 100644
index 00000000000..86c21df4f1f
--- /dev/null
+++ b/srcpkgs/qemu/patches/musl-ppc.patch
@@ -0,0 +1,60 @@
+--- accel/tcg/user-exec.c
++++ accel/tcg/user-exec.c
+@@ -286,6 +286,7 @@ int cpu_signal_handler(int host_signum, void *pinfo,
+  */
+ #ifdef linux
+ /* All Registers access - only for local access */
++#if defined(__GLIBC__)
+ #define REG_sig(reg_name, context)              \
+     ((context)->uc_mcontext.regs->reg_name)
+ /* Gpr Registers access  */
+@@ -302,6 +303,19 @@ int cpu_signal_handler(int host_signum, void *pinfo,
+ #define LR_sig(context)                        REG_sig(link, context)
+ /* Condition register */
+ #define CR_sig(context)                        REG_sig(ccr, context)
++#else /* musl */
++#if defined(_ARCH_PPC64)
++#define REG_sig(reg_num, context) ((context)->uc_mcontext.gp_regs[reg_num])
++#else
++#define REG_sig(reg_num, context) ((context)->uc_mcontext.gregs[reg_num])
++#endif
++#define IAR_sig(context)                       REG_sig(32, context)
++#define MSR_sig(context)                       REG_sig(33, context)
++#define CTR_sig(context)                       REG_sig(35, context)
++#define XER_sig(context)                       REG_sig(37, context)
++#define LR_sig(context)                        REG_sig(36, context)
++#define CR_sig(context)                        REG_sig(38, context)
++#endif
+ 
+ /* Float Registers access  */
+ #define FLOAT_sig(reg_num, context)                                     \
+@@ -309,9 +323,15 @@ int cpu_signal_handler(int host_signum, void *pinfo,
+ #define FPSCR_sig(context) \
+     (*(int *)((char *)((context)->uc_mcontext.regs + (48 + 32 * 2) * 4)))
+ /* Exception Registers access */
++#if defined(__GLIBC__)
+ #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__)
+--- linux-user/host/ppc64/hostdep.h
++++ linux-user/host/ppc64/hostdep.h
+@@ -27,7 +27,11 @@ extern char safe_syscall_end[];
+ static inline void rewind_if_in_safe_syscall(void *puc)
+ {
+     ucontext_t *uc = puc;
++#if defined(__GLIBC__)
+     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) {
diff --git a/srcpkgs/qemu/patches/musl-ppc64-pt_nip.patch b/srcpkgs/qemu/patches/musl-ppc64-pt_nip.patch
deleted file mode 100644
index 5c5eaea126e..00000000000
--- a/srcpkgs/qemu/patches/musl-ppc64-pt_nip.patch
+++ /dev/null
@@ -1,12 +0,0 @@
-This include is necessary to get PT_NIP on musl.
---- linux-user/host/ppc64/hostdep.h
-+++ linux-user/host/ppc64/hostdep.h
-@@ -17,6 +17,8 @@
- 
- #ifndef __ASSEMBLER__
- 
-+#include <asm/ptrace.h>
-+
- /* These are defined by the safe-syscall.inc.S file */
- extern char safe_syscall_start[];
- extern char safe_syscall_end[];
diff --git a/srcpkgs/qemu/patches/musl-ppc64-pt_regs.patch b/srcpkgs/qemu/patches/musl-ppc64-pt_regs.patch
deleted file mode 100644
index bdd7e7eacab..00000000000
--- a/srcpkgs/qemu/patches/musl-ppc64-pt_regs.patch
+++ /dev/null
@@ -1,16 +0,0 @@
-On musl, the regs field in uc_mcontext is void * so it is necessary to
-cast it. The sys/user.h include is to get access to definition of pt_regs.
---- accel/tcg/user-exec.c
-+++ accel/tcg/user-exec.c
-@@ -285,9 +285,10 @@ int cpu_signal_handler(int host_signum, void *pinfo,
-  * From Wine
-  */
- #ifdef linux
-+#include <sys/user.h>
- /* All Registers access - only for local access */
- #define REG_sig(reg_name, context)              \
--    ((context)->uc_mcontext.regs->reg_name)
-+    (((struct pt_regs *)(context)->uc_mcontext.regs)->reg_name)
- /* Gpr Registers access  */
- #define GPR_sig(reg_num, context)              REG_sig(gpr[reg_num], context)
- /* Program counter */

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PR PATCH] [Merged]: qemu: replace ppc64 musl patches with a generalized ppc32/64 one
  2019-07-01 18:33 [PR PATCH] qemu: replace ppc64 musl patches with a generalized ppc32/64 one voidlinux-github
@ 2019-07-01 19:10 ` voidlinux-github
  0 siblings, 0 replies; 2+ messages in thread
From: voidlinux-github @ 2019-07-01 19:10 UTC (permalink / raw)
  To: ml

[-- Attachment #1: Type: text/plain, Size: 286 bytes --]

There's a merged pull request on the void-packages repository

qemu: replace ppc64 musl patches with a generalized ppc32/64 one
https://github.com/void-linux/void-packages/pull/12774
Description: the previous patches didn't cover ppc32, replace both with a bit cleaner unified patch...

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2019-07-01 19:10 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-07-01 18:33 [PR PATCH] qemu: replace ppc64 musl patches with a generalized ppc32/64 one voidlinux-github
2019-07-01 19:10 ` [PR PATCH] [Merged]: " voidlinux-github

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).