git: 1c1f31a5e517 - main - Remove unused registes from the arm pcb

From: Andrew Turner <andrew_at_FreeBSD.org>
Date: Thu, 23 Mar 2023 19:02:49 UTC
The branch main has been updated by andrew:

URL: https://cgit.FreeBSD.org/src/commit/?id=1c1f31a5e517ebb940c752c3468b03cdc687c5c7

commit 1c1f31a5e517ebb940c752c3468b03cdc687c5c7
Author:     Andrew Turner <andrew@FreeBSD.org>
AuthorDate: 2023-03-22 12:33:05 +0000
Commit:     Andrew Turner <andrew@FreeBSD.org>
CommitDate: 2023-03-23 18:56:26 +0000

    Remove unused registes from the arm pcb
    
    These were kept for ABI reasons. Remove them and bump __FreeBSD_version
    so debuggers can be updated to use the new layout.
    
    Reviewed by:    jhb
    Sponsored by:   Arm Ltd
    Sponsored by:   The FreeBSD Foundation
    Differential Revision:  https://reviews.freebsd.org/D35378
---
 sys/arm64/arm64/db_trace.c      |  2 +-
 sys/arm64/arm64/gdb_machdep.c   | 12 ++++++------
 sys/arm64/arm64/genassym.c      |  1 -
 sys/arm64/arm64/machdep.c       |  6 +++---
 sys/arm64/arm64/stack_machdep.c |  2 +-
 sys/arm64/arm64/vm_machdep.c    |  4 ++--
 sys/arm64/include/db_machdep.h  |  4 ++--
 sys/arm64/include/gdb_machdep.h |  1 +
 sys/arm64/include/pcb.h         | 14 ++++++++------
 9 files changed, 24 insertions(+), 22 deletions(-)

diff --git a/sys/arm64/arm64/db_trace.c b/sys/arm64/arm64/db_trace.c
index 6abdd6c5ca7a..42230f273716 100644
--- a/sys/arm64/arm64/db_trace.c
+++ b/sys/arm64/arm64/db_trace.c
@@ -145,7 +145,7 @@ db_trace_thread(struct thread *thr, int count)
 		ctx = kdb_thr_ctx(thr);
 
 		frame.fp = (uintptr_t)ctx->pcb_x[PCB_FP];
-		frame.pc = (uintptr_t)ctx->pcb_lr;
+		frame.pc = (uintptr_t)ctx->pcb_x[PCB_LR];
 		db_stack_trace_cmd(thr, &frame);
 	} else
 		db_trace_self();
diff --git a/sys/arm64/arm64/gdb_machdep.c b/sys/arm64/arm64/gdb_machdep.c
index b27e1edb3d7f..fed8a8b5e9d4 100644
--- a/sys/arm64/arm64/gdb_machdep.c
+++ b/sys/arm64/arm64/gdb_machdep.c
@@ -60,10 +60,10 @@ gdb_cpu_getreg(int regnum, size_t *regsz)
 	switch (regnum) {
 	case GDB_REG_SP: return (&kdb_thrctx->pcb_sp);
 	case GDB_REG_PC: /* FALLTHROUGH */
-	case GDB_REG_LR: return (&kdb_thrctx->pcb_lr);
+	case GDB_REG_LR: return (&kdb_thrctx->pcb_x[PCB_LR]);
 	default:
-		if (regnum >= GDB_REG_X0 && regnum <= GDB_REG_X29)
-			return (&kdb_thrctx->pcb_x[regnum]);
+		if (regnum >= GDB_REG_X19 && regnum <= GDB_REG_X29)
+			return (&kdb_thrctx->pcb_x[regnum - GDB_REG_X19]);
 		break;
 	}
 
@@ -89,11 +89,11 @@ gdb_cpu_setreg(int regnum, void *val)
 	}
 	switch (regnum) {
 	case GDB_REG_PC: /* FALLTHROUGH */
-	case GDB_REG_LR: kdb_thrctx->pcb_lr = regval; break;
+	case GDB_REG_LR: kdb_thrctx->pcb_x[PCB_LR] = regval; break;
 	case GDB_REG_SP: kdb_thrctx->pcb_sp = regval; break;
 	default:
-		if (regnum >= GDB_REG_X0 && regnum <= GDB_REG_X29) {
-			kdb_thrctx->pcb_x[regnum] = regval;
+		if (regnum >= GDB_REG_X19 && regnum <= GDB_REG_X29) {
+			kdb_thrctx->pcb_x[regnum - GDB_REG_X19] = regval;
 		}
 		break;
 	}
diff --git a/sys/arm64/arm64/genassym.c b/sys/arm64/arm64/genassym.c
index db07f1714f5a..2bc0804aef27 100644
--- a/sys/arm64/arm64/genassym.c
+++ b/sys/arm64/arm64/genassym.c
@@ -57,7 +57,6 @@ ASSYM(PCB_SIZE, roundup2(sizeof(struct pcb), STACKALIGNBYTES + 1));
 ASSYM(PCB_SINGLE_STEP_SHIFT, PCB_SINGLE_STEP_SHIFT);
 ASSYM(PCB_REGS, offsetof(struct pcb, pcb_x));
 ASSYM(PCB_X19, PCB_X19);
-ASSYM(PCB_LR, offsetof(struct pcb, pcb_lr));
 ASSYM(PCB_SP, offsetof(struct pcb, pcb_sp));
 ASSYM(PCB_TPIDRRO, offsetof(struct pcb, pcb_tpidrro_el0));
 ASSYM(PCB_ONFAULT, offsetof(struct pcb, pcb_onfault));
diff --git a/sys/arm64/arm64/machdep.c b/sys/arm64/arm64/machdep.c
index 0659602a9ded..31e7568a0605 100644
--- a/sys/arm64/arm64/machdep.c
+++ b/sys/arm64/arm64/machdep.c
@@ -356,10 +356,10 @@ makectx(struct trapframe *tf, struct pcb *pcb)
 	int i;
 
 	for (i = 0; i < nitems(pcb->pcb_x); i++)
-		pcb->pcb_x[i] = tf->tf_x[i];
+		pcb->pcb_x[i] = tf->tf_x[i + PCB_X_START];
 
-	/* NB: pcb_lr is the PC, see PC_REGS() in db_machdep.h */
-	pcb->pcb_lr = tf->tf_elr;
+	/* NB: pcb_x[PCB_LR] is the PC, see PC_REGS() in db_machdep.h */
+	pcb->pcb_x[PCB_LR] = tf->tf_elr;
 	pcb->pcb_sp = tf->tf_sp;
 }
 
diff --git a/sys/arm64/arm64/stack_machdep.c b/sys/arm64/arm64/stack_machdep.c
index 8a3e8ce7dbc7..9fdb3da211cd 100644
--- a/sys/arm64/arm64/stack_machdep.c
+++ b/sys/arm64/arm64/stack_machdep.c
@@ -69,7 +69,7 @@ stack_save_td(struct stack *st, struct thread *td)
 		return (EOPNOTSUPP);
 
 	frame.fp = td->td_pcb->pcb_x[PCB_FP];
-	frame.pc = ADDR_MAKE_CANONICAL(td->td_pcb->pcb_lr);
+	frame.pc = ADDR_MAKE_CANONICAL(td->td_pcb->pcb_x[PCB_LR]);
 
 	stack_capture(td, st, &frame);
 	return (0);
diff --git a/sys/arm64/arm64/vm_machdep.c b/sys/arm64/arm64/vm_machdep.c
index dee42a8b568d..e111995f09b0 100644
--- a/sys/arm64/arm64/vm_machdep.c
+++ b/sys/arm64/arm64/vm_machdep.c
@@ -107,7 +107,7 @@ cpu_fork(struct thread *td1, struct proc *p2, struct thread *td2, int flags)
 	/* Set the return value registers for fork() */
 	td2->td_pcb->pcb_x[PCB_X19] = (uintptr_t)fork_return;
 	td2->td_pcb->pcb_x[PCB_X20] = (uintptr_t)td2;
-	td2->td_pcb->pcb_lr = (uintptr_t)fork_trampoline;
+	td2->td_pcb->pcb_x[PCB_LR] = (uintptr_t)fork_trampoline;
 	td2->td_pcb->pcb_sp = (uintptr_t)td2->td_frame;
 
 	vfp_new_thread(td2, td1, true);
@@ -185,7 +185,7 @@ cpu_copy_thread(struct thread *td, struct thread *td0)
 
 	td->td_pcb->pcb_x[PCB_X19] = (uintptr_t)fork_return;
 	td->td_pcb->pcb_x[PCB_X20] = (uintptr_t)td;
-	td->td_pcb->pcb_lr = (uintptr_t)fork_trampoline;
+	td->td_pcb->pcb_x[PCB_LR] = (uintptr_t)fork_trampoline;
 	td->td_pcb->pcb_sp = (uintptr_t)td->td_frame;
 
 	/* Update VFP state for the new thread */
diff --git a/sys/arm64/include/db_machdep.h b/sys/arm64/include/db_machdep.h
index 9ec0b6402a91..88cebee8fc30 100644
--- a/sys/arm64/include/db_machdep.h
+++ b/sys/arm64/include/db_machdep.h
@@ -44,7 +44,7 @@
 typedef vm_offset_t	db_addr_t;
 typedef long		db_expr_t;
 
-#define	PC_REGS()	((db_addr_t)kdb_thrctx->pcb_lr)
+#define	PC_REGS()	((db_addr_t)kdb_thrctx->pcb_x[PCB_LR])
 
 #define	BKPT_INST	(0xd4200000)
 #define	BKPT_SIZE	(4)
@@ -52,7 +52,7 @@ typedef long		db_expr_t;
 
 #define	BKPT_SKIP do {				\
 	kdb_frame->tf_elr += BKPT_SIZE;		\
-	kdb_thrctx->pcb_lr += BKPT_SIZE;	\
+	kdb_thrctx->pcb_x[PCB_LR] += BKPT_SIZE;	\
 } while (0)
 
 #define	db_clear_single_step	kdb_cpu_clear_singlestep
diff --git a/sys/arm64/include/gdb_machdep.h b/sys/arm64/include/gdb_machdep.h
index 17b46edd1a27..82354f52bd5e 100644
--- a/sys/arm64/include/gdb_machdep.h
+++ b/sys/arm64/include/gdb_machdep.h
@@ -34,6 +34,7 @@
 #define	GDB_BUFSZ	4096
 #define	GDB_NREGS	68
 #define	GDB_REG_X0	0
+#define	GDB_REG_X19	19
 #define	GDB_REG_X29	29
 #define	GDB_REG_LR	30
 #define	GDB_REG_SP	31
diff --git a/sys/arm64/include/pcb.h b/sys/arm64/include/pcb.h
index 8767a9e4dba3..8ffe6f2d483e 100644
--- a/sys/arm64/include/pcb.h
+++ b/sys/arm64/include/pcb.h
@@ -36,14 +36,16 @@
 
 struct trapframe;
 
-#define	PCB_X19		19
-#define	PCB_X20		20
-#define	PCB_FP		29
+/* The first register in pcb_x is x19 */
+#define	PCB_X_START	19
+
+#define	PCB_X19		0
+#define	PCB_X20		1
+#define	PCB_FP		10
+#define	PCB_LR		11
 
 struct pcb {
-	uint64_t	pcb_x[30];
-	uint64_t	pcb_lr;
-	uint64_t	_reserved;	/* Was pcb_pc */
+	uint64_t	pcb_x[12];
 	/* These two need to be in order as we access them together */
 	uint64_t	pcb_sp;
 	uint64_t	pcb_tpidr_el0;