[PATCH v4] ppc64: Avoid pt_regs struct definition

Khem Raj posted 1 patch 2 years, 1 month ago
Test checkpatch passed
Patches applied successfully (tree, apply log)
git fetch https://github.com/patchew-project/qemu tags/patchew/20220315015740.847370-1-raj.khem@gmail.com
Maintainers: Laurent Vivier <laurent@vivier.eu>
linux-user/include/host/ppc/host-signal.h   | 38 -------------------
linux-user/include/host/ppc64/host-signal.h | 42 ++++++++++++++++++++-
2 files changed, 41 insertions(+), 39 deletions(-)
delete mode 100644 linux-user/include/host/ppc/host-signal.h
[PATCH v4] ppc64: Avoid pt_regs struct definition
Posted by Khem Raj 2 years, 1 month ago
Remove pt_regs indirection and instead reference gp_regs directly, this
makes it portable across musl/glibc

Use PT_* constants defined in asm/ptrace.h

Move the file to ppc64 subdir and leave ppc empty

Fixes
../qemu-6.2.0/linux-user/host/ppc64/../ppc/host-signal.h:16:32: error: incomplete definition of type 'struct pt_regs'
    return uc->uc_mcontext.regs->nip;
           ~~~~~~~~~~~~~~~~~~~~^

Signed-off-by: Khem Raj <raj.khem@gmail.com>
Cc: Peter Maydell <peter.maydell@linaro.org>
Cc: Philippe Mathieu-Daudé <f4bug@amsat.org>
Cc: Richard Henderson <richard.henderson@linaro.org>
---
v2: Drop ifdef __powerpc__
v3: Access go_regs directly and move the file to ppc64 dir
v4: Use PT_* constants defined in asm/ptrace.h

 linux-user/include/host/ppc/host-signal.h   | 38 -------------------
 linux-user/include/host/ppc64/host-signal.h | 42 ++++++++++++++++++++-
 2 files changed, 41 insertions(+), 39 deletions(-)
 delete mode 100644 linux-user/include/host/ppc/host-signal.h

diff --git a/linux-user/include/host/ppc/host-signal.h b/linux-user/include/host/ppc/host-signal.h
deleted file mode 100644
index b80384d135..0000000000
--- a/linux-user/include/host/ppc/host-signal.h
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * host-signal.h: signal info dependent on the host architecture
- *
- * Copyright (c) 2003-2005 Fabrice Bellard
- * Copyright (c) 2021 Linaro Limited
- *
- * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
- * See the COPYING file in the top-level directory.
- */
-
-#ifndef PPC_HOST_SIGNAL_H
-#define PPC_HOST_SIGNAL_H
-
-/* The third argument to a SA_SIGINFO handler is ucontext_t. */
-typedef ucontext_t host_sigcontext;
-
-static inline uintptr_t host_signal_pc(host_sigcontext *uc)
-{
-    return uc->uc_mcontext.regs->nip;
-}
-
-static inline void host_signal_set_pc(host_sigcontext *uc, uintptr_t pc)
-{
-    uc->uc_mcontext.regs->nip = pc;
-}
-
-static inline void *host_signal_mask(host_sigcontext *uc)
-{
-    return &uc->uc_sigmask;
-}
-
-static inline bool host_signal_write(siginfo_t *info, host_sigcontext *uc)
-{
-    return uc->uc_mcontext.regs->trap != 0x400
-        && (uc->uc_mcontext.regs->dsisr & 0x02000000);
-}
-
-#endif
diff --git a/linux-user/include/host/ppc64/host-signal.h b/linux-user/include/host/ppc64/host-signal.h
index a353c22a90..c4ea866472 100644
--- a/linux-user/include/host/ppc64/host-signal.h
+++ b/linux-user/include/host/ppc64/host-signal.h
@@ -1 +1,41 @@
-#include "../ppc/host-signal.h"
+/*
+ * host-signal.h: signal info dependent on the host architecture
+ *
+ * Copyright (c) 2003-2005 Fabrice Bellard
+ * Copyright (c) 2021 Linaro Limited
+ *
+ * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
+ * See the COPYING file in the top-level directory.
+ */
+
+#ifndef PPC_HOST_SIGNAL_H
+#define PPC_HOST_SIGNAL_H
+
+/* Needed for PT_* constants */
+#include <asm/ptrace.h>
+
+/* The third argument to a SA_SIGINFO handler is ucontext_t. */
+typedef ucontext_t host_sigcontext;
+
+static inline uintptr_t host_signal_pc(host_sigcontext *uc)
+{
+    return uc->uc_mcontext.gp_regs[PT_NIP];
+}
+
+static inline void host_signal_set_pc(host_sigcontext *uc, uintptr_t pc)
+{
+    uc->uc_mcontext.gp_regs[PT_NIP] = pc;
+}
+
+static inline void *host_signal_mask(host_sigcontext *uc)
+{
+    return &uc->uc_sigmask;
+}
+
+static inline bool host_signal_write(siginfo_t *info, host_sigcontext *uc)
+{
+    return uc->uc_mcontext.gp_regs[PT_TRAP] != 0x400
+        && (uc->uc_mcontext.gp_regs[PT_DSISR] & 0x02000000);
+}
+
+#endif
-- 
2.35.1


Re: [PATCH v4] ppc64: Avoid pt_regs struct definition
Posted by Richard Henderson 2 years, 1 month ago
On 3/14/22 18:57, Khem Raj wrote:
> Remove pt_regs indirection and instead reference gp_regs directly, this
> makes it portable across musl/glibc
> 
> Use PT_* constants defined in asm/ptrace.h
> 
> Move the file to ppc64 subdir and leave ppc empty
> 
> Fixes
> ../qemu-6.2.0/linux-user/host/ppc64/../ppc/host-signal.h:16:32: error: incomplete definition of type 'struct pt_regs'
>      return uc->uc_mcontext.regs->nip;
>             ~~~~~~~~~~~~~~~~~~~~^
> 
> Signed-off-by: Khem Raj<raj.khem@gmail.com>
> Cc: Peter Maydell<peter.maydell@linaro.org>
> Cc: Philippe Mathieu-Daudé<f4bug@amsat.org>
> Cc: Richard Henderson<richard.henderson@linaro.org>
> ---
> v2: Drop ifdef __powerpc__
> v3: Access go_regs directly and move the file to ppc64 dir
> v4: Use PT_* constants defined in asm/ptrace.h
> 
>   linux-user/include/host/ppc/host-signal.h   | 38 -------------------
>   linux-user/include/host/ppc64/host-signal.h | 42 ++++++++++++++++++++-
>   2 files changed, 41 insertions(+), 39 deletions(-)
>   delete mode 100644 linux-user/include/host/ppc/host-signal.h

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>

Thanks for your patience.


r~

Re: [PATCH v4] ppc64: Avoid pt_regs struct definition
Posted by Peter Maydell 2 years, 1 month ago
On Tue, 15 Mar 2022 at 02:14, Richard Henderson
<richard.henderson@linaro.org> wrote:
>
> On 3/14/22 18:57, Khem Raj wrote:
> > Remove pt_regs indirection and instead reference gp_regs directly, this
> > makes it portable across musl/glibc
> >
> > Use PT_* constants defined in asm/ptrace.h
> >
> > Move the file to ppc64 subdir and leave ppc empty
> >
> > Fixes
> > ../qemu-6.2.0/linux-user/host/ppc64/../ppc/host-signal.h:16:32: error: incomplete definition of type 'struct pt_regs'
> >      return uc->uc_mcontext.regs->nip;
> >             ~~~~~~~~~~~~~~~~~~~~^
> >
> > Signed-off-by: Khem Raj<raj.khem@gmail.com>
> > Cc: Peter Maydell<peter.maydell@linaro.org>
> > Cc: Philippe Mathieu-Daudé<f4bug@amsat.org>
> > Cc: Richard Henderson<richard.henderson@linaro.org>
> > ---
> > v2: Drop ifdef __powerpc__
> > v3: Access go_regs directly and move the file to ppc64 dir
> > v4: Use PT_* constants defined in asm/ptrace.h
> >
> >   linux-user/include/host/ppc/host-signal.h   | 38 -------------------
> >   linux-user/include/host/ppc64/host-signal.h | 42 ++++++++++++++++++++-
> >   2 files changed, 41 insertions(+), 39 deletions(-)
> >   delete mode 100644 linux-user/include/host/ppc/host-signal.h
>
> Reviewed-by: Richard Henderson <richard.henderson@linaro.org>

I did a compile-check and confirmed that this builds OK
on glibc headers too.

-- PMM
Re: [PATCH v4] ppc64: Avoid pt_regs struct definition
Posted by Cédric Le Goater 2 years, 1 month ago
Laurent,

On 3/15/22 11:31, Peter Maydell wrote:
> On Tue, 15 Mar 2022 at 02:14, Richard Henderson
> <richard.henderson@linaro.org> wrote:
>>
>> On 3/14/22 18:57, Khem Raj wrote:
>>> Remove pt_regs indirection and instead reference gp_regs directly, this
>>> makes it portable across musl/glibc
>>>
>>> Use PT_* constants defined in asm/ptrace.h
>>>
>>> Move the file to ppc64 subdir and leave ppc empty
>>>
>>> Fixes
>>> ../qemu-6.2.0/linux-user/host/ppc64/../ppc/host-signal.h:16:32: error: incomplete definition of type 'struct pt_regs'
>>>       return uc->uc_mcontext.regs->nip;
>>>              ~~~~~~~~~~~~~~~~~~~~^
>>>
>>> Signed-off-by: Khem Raj<raj.khem@gmail.com>
>>> Cc: Peter Maydell<peter.maydell@linaro.org>
>>> Cc: Philippe Mathieu-Daudé<f4bug@amsat.org>
>>> Cc: Richard Henderson<richard.henderson@linaro.org>
>>> ---
>>> v2: Drop ifdef __powerpc__
>>> v3: Access go_regs directly and move the file to ppc64 dir
>>> v4: Use PT_* constants defined in asm/ptrace.h
>>>
>>>    linux-user/include/host/ppc/host-signal.h   | 38 -------------------
>>>    linux-user/include/host/ppc64/host-signal.h | 42 ++++++++++++++++++++-
>>>    2 files changed, 41 insertions(+), 39 deletions(-)
>>>    delete mode 100644 linux-user/include/host/ppc/host-signal.h
>>
>> Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
> 
> I did a compile-check and confirmed that this builds OK
> on glibc headers too.

I can queue this patch for 7.0. I have a few already.

C.