All of lore.kernel.org
 help / color / mirror / Atom feed
From: Warner Losh <imp@bsdimp.com>
To: qemu-devel@nongnu.org
Cc: "Philippe Mathieu-Daudé" <f4bug@amsat.org>,
	qemu-trivial@nongnu.org, kevans@freebsd.org,
	"Jiaxun Yang" <jiaxun.yang@flygoat.com>,
	"Richard Henderson" <richard.henderson@linaro.org>,
	"Michael Tokarev" <mjt@tls.msk.ru>,
	"Warner Losh" <imp@bsdimp.com>,
	"Laurent Vivier" <laurent@vivier.eu>,
	"Stacey Son" <sson@FreeBSD.org>,
	"Kyle Evans" <kevans@FreeBSD.org>
Subject: [PULL 22/37] bsd-user/arm/target_arch_reg.h: Implement core dump register copying
Date: Sat,  8 Jan 2022 00:37:22 -0700	[thread overview]
Message-ID: <20220108073737.5959-23-imp@bsdimp.com> (raw)
In-Reply-To: <20220108073737.5959-1-imp@bsdimp.com>

Implement the register copying routines to extract registers from the
cpu for core dump generation.

Signed-off-by: Stacey Son <sson@FreeBSD.org>
Signed-off-by: Warner Losh <imp@bsdimp.com>
Reviewed-by: Kyle Evans <kevans@FreeBSD.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
 bsd-user/arm/target_arch_reg.h | 60 ++++++++++++++++++++++++++++++++++
 1 file changed, 60 insertions(+)
 create mode 100644 bsd-user/arm/target_arch_reg.h

diff --git a/bsd-user/arm/target_arch_reg.h b/bsd-user/arm/target_arch_reg.h
new file mode 100644
index 00000000000..ef5ed5154f1
--- /dev/null
+++ b/bsd-user/arm/target_arch_reg.h
@@ -0,0 +1,60 @@
+/*
+ *  FreeBSD arm register structures
+ *
+ *  Copyright (c) 2015 Stacey Son
+ *
+ *  This program is free software; you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation; either version 2 of the License, or
+ *  (at your option) any later version.
+ *
+ *  This program is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with this program; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef _TARGET_ARCH_REG_H_
+#define _TARGET_ARCH_REG_H_
+
+/* See sys/arm/include/reg.h */
+typedef struct target_reg {
+    uint32_t        r[13];
+    uint32_t        r_sp;
+    uint32_t        r_lr;
+    uint32_t        r_pc;
+    uint32_t        r_cpsr;
+} target_reg_t;
+
+typedef struct target_fp_reg {
+    uint32_t        fp_exponent;
+    uint32_t        fp_mantissa_hi;
+    u_int32_t       fp_mantissa_lo;
+} target_fp_reg_t;
+
+typedef struct target_fpreg {
+    uint32_t        fpr_fpsr;
+    target_fp_reg_t fpr[8];
+} target_fpreg_t;
+
+#define tswapreg(ptr)   tswapal(ptr)
+
+static inline void target_copy_regs(target_reg_t *regs, const CPUARMState *env)
+{
+    int i;
+
+    for (i = 0; i < 13; i++) {
+        regs->r[i] = tswapreg(env->regs[i + 1]);
+    }
+    regs->r_sp = tswapreg(env->regs[13]);
+    regs->r_lr = tswapreg(env->regs[14]);
+    regs->r_pc = tswapreg(env->regs[15]);
+    regs->r_cpsr = tswapreg(cpsr_read((CPUARMState *)env));
+}
+
+#undef tswapreg
+
+#endif /* !_TARGET_ARCH_REG_H_ */
-- 
2.33.1



WARNING: multiple messages have this Message-ID (diff)
From: Warner Losh <imp@bsdimp.com>
To: qemu-devel@nongnu.org
Cc: "Stacey Son" <sson@FreeBSD.org>,
	qemu-trivial@nongnu.org, "Kyle Evans" <kevans@FreeBSD.org>,
	"Michael Tokarev" <mjt@tls.msk.ru>,
	"Philippe Mathieu-Daudé" <f4bug@amsat.org>,
	"Laurent Vivier" <laurent@vivier.eu>,
	"Richard Henderson" <richard.henderson@linaro.org>,
	"Warner Losh" <imp@bsdimp.com>
Subject: [PULL 22/37] bsd-user/arm/target_arch_reg.h: Implement core dump register copying
Date: Sat,  8 Jan 2022 00:37:22 -0700	[thread overview]
Message-ID: <20220108073737.5959-23-imp@bsdimp.com> (raw)
In-Reply-To: <20220108073737.5959-1-imp@bsdimp.com>

Implement the register copying routines to extract registers from the
cpu for core dump generation.

Signed-off-by: Stacey Son <sson@FreeBSD.org>
Signed-off-by: Warner Losh <imp@bsdimp.com>
Reviewed-by: Kyle Evans <kevans@FreeBSD.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
 bsd-user/arm/target_arch_reg.h | 60 ++++++++++++++++++++++++++++++++++
 1 file changed, 60 insertions(+)
 create mode 100644 bsd-user/arm/target_arch_reg.h

diff --git a/bsd-user/arm/target_arch_reg.h b/bsd-user/arm/target_arch_reg.h
new file mode 100644
index 00000000000..ef5ed5154f1
--- /dev/null
+++ b/bsd-user/arm/target_arch_reg.h
@@ -0,0 +1,60 @@
+/*
+ *  FreeBSD arm register structures
+ *
+ *  Copyright (c) 2015 Stacey Son
+ *
+ *  This program is free software; you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation; either version 2 of the License, or
+ *  (at your option) any later version.
+ *
+ *  This program is distributed in the hope that it will be useful,
+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *  GNU General Public License for more details.
+ *
+ *  You should have received a copy of the GNU General Public License
+ *  along with this program; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef _TARGET_ARCH_REG_H_
+#define _TARGET_ARCH_REG_H_
+
+/* See sys/arm/include/reg.h */
+typedef struct target_reg {
+    uint32_t        r[13];
+    uint32_t        r_sp;
+    uint32_t        r_lr;
+    uint32_t        r_pc;
+    uint32_t        r_cpsr;
+} target_reg_t;
+
+typedef struct target_fp_reg {
+    uint32_t        fp_exponent;
+    uint32_t        fp_mantissa_hi;
+    u_int32_t       fp_mantissa_lo;
+} target_fp_reg_t;
+
+typedef struct target_fpreg {
+    uint32_t        fpr_fpsr;
+    target_fp_reg_t fpr[8];
+} target_fpreg_t;
+
+#define tswapreg(ptr)   tswapal(ptr)
+
+static inline void target_copy_regs(target_reg_t *regs, const CPUARMState *env)
+{
+    int i;
+
+    for (i = 0; i < 13; i++) {
+        regs->r[i] = tswapreg(env->regs[i + 1]);
+    }
+    regs->r_sp = tswapreg(env->regs[13]);
+    regs->r_lr = tswapreg(env->regs[14]);
+    regs->r_pc = tswapreg(env->regs[15]);
+    regs->r_cpsr = tswapreg(cpsr_read((CPUARMState *)env));
+}
+
+#undef tswapreg
+
+#endif /* !_TARGET_ARCH_REG_H_ */
-- 
2.33.1



  parent reply	other threads:[~2022-01-08  7:39 UTC|newest]

Thread overview: 78+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-01-08  7:37 [PULL 00/37] Bsd user arm patches Warner Losh
2022-01-08  7:37 ` Warner Losh
2022-01-08  7:37 ` [PULL 01/37] bsd-user/mips*: Remove mips support Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 02/37] bsd-user/freebsd: Create common target_os_ucontext.h file Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 03/37] bsd-user: create a per-arch signal.c file Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 04/37] bsd-user/i386/target_arch_signal.h: Remove target_sigcontext Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 05/37] bsd-user/i386/target_arch_signal.h: use new target_os_ucontext.h Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 06/37] bsd-user/i386/target_arch_signal.h: Update mcontext_t to match FreeBSD Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 07/37] bsd-user/i386: Move the inlines into signal.c Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 08/37] bsd-user/x86_64/target_arch_signal.h: Remove target_sigcontext Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 09/37] bsd-user/x86_64/target_arch_signal.h: use new target_os_ucontext.h Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 10/37] bsd-user/x86_64/target_arch_signal.h: Fill in mcontext_t Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 11/37] bsd-user/x86_64: Move functions into signal.c Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 12/37] bsd-user/target_os_signal.h: Move signal prototypes to target_os_ucontext.h Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 13/37] bsd-user/arm/target_arch_sysarch.h: Use consistent include guards Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 14/37] bsd-user/arm/target_syscall.h: Add copyright and update name Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 15/37] bsd-user/arm/target_arch_cpu.c: Target specific TLS routines Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 16/37] bsd-user/arm/target_arch_cpu.h: CPU Loop definitions Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 17/37] bsd-user/arm/target_arch_cpu.h: Implement target_cpu_clone_regs Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 18/37] bsd-user/arm/target_arch_cpu.h: Dummy target_cpu_loop implementation Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 19/37] bsd-user/arm/target_arch_cpu.h: Implement trivial EXCP exceptions Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 20/37] bsd-user/arm/target_arch_cpu.h: Implement data abort exceptions Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 21/37] bsd-user/arm/target_arch_cpu.h: Implement system call dispatch Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` Warner Losh [this message]
2022-01-08  7:37   ` [PULL 22/37] bsd-user/arm/target_arch_reg.h: Implement core dump register copying Warner Losh
2022-01-08  7:37 ` [PULL 23/37] bsd-user/arm/target_arch_vmparam.h: Parameters for arm address space Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 24/37] bsd-user/arm/target_arch_sigtramp.h: Signal Trampoline for arm Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 25/37] bsd-user/arm/target_arch_thread.h: Routines to create and switch to a thread Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 26/37] bsd-user/arm/target_arch_elf.h: arm defines for ELF Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 27/37] bsd-user/arm/target_arch_elf.h: arm get hwcap Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 28/37] bsd-user/arm/target_arch_elf.h: arm get_hwcap2 impl Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 29/37] bsd-user/arm/target_arch_signal.h: arm specific signal registers and stack Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 30/37] bsd-user/arm/target_arch_signal.h: arm machine context and trapframe for signals Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 31/37] bsd-user/arm/target_arch_signal.h: Define size of *context_t Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 32/37] bsd-user/arm/signal.c: arm set_sigtramp_args Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 33/37] bsd-user/arm/signal.c: arm get_mcontext Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 34/37] bsd-user/arm/signal.c: arm set_mcontext Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 35/37] bsd-user/arm/signal.c: arm get_ucontext_sigreturn Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 36/37] bsd-user/freebsd/target_os_ucontext.h: Require TARGET_*CONTEXT_SIZE Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08  7:37 ` [PULL 37/37] bsd-user: add arm target build Warner Losh
2022-01-08  7:37   ` Warner Losh
2022-01-08 19:18 ` [PULL 00/37] Bsd user arm patches Richard Henderson
2022-01-08 19:18   ` Richard Henderson

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220108073737.5959-23-imp@bsdimp.com \
    --to=imp@bsdimp.com \
    --cc=f4bug@amsat.org \
    --cc=jiaxun.yang@flygoat.com \
    --cc=kevans@freebsd.org \
    --cc=laurent@vivier.eu \
    --cc=mjt@tls.msk.ru \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-trivial@nongnu.org \
    --cc=richard.henderson@linaro.org \
    --cc=sson@FreeBSD.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.