Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/aarch64 add support PT_STEP
details: https://anonhg.NetBSD.org/src/rev/6094e59f3811
branches: trunk
changeset: 995262:6094e59f3811
user: ryo <ryo%NetBSD.org@localhost>
date: Thu Dec 13 10:44:25 2018 +0000
description:
add support PT_STEP
diffstat:
sys/arch/aarch64/aarch64/cpuswitch.S | 11 +++++++++--
sys/arch/aarch64/aarch64/db_machdep.c | 8 +++-----
sys/arch/aarch64/aarch64/genassym.cf | 8 +++++++-
sys/arch/aarch64/aarch64/locore.S | 15 +++++++++++----
sys/arch/aarch64/aarch64/process_machdep.c | 15 +++++++++++++--
sys/arch/aarch64/aarch64/trap.c | 18 +++++++++++++++---
sys/arch/aarch64/include/armreg.h | 16 +++++++++++++++-
sys/arch/aarch64/include/ptrace.h | 19 ++++++++++++-------
8 files changed, 85 insertions(+), 25 deletions(-)
diffs (truncated from 311 to 300 lines):
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/cpuswitch.S
--- a/sys/arch/aarch64/aarch64/cpuswitch.S Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/cpuswitch.S Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpuswitch.S,v 1.9 2018/12/12 11:14:51 ryo Exp $ */
+/* $NetBSD: cpuswitch.S,v 1.10 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -37,7 +37,7 @@
#include "opt_ddb.h"
#include "opt_kasan.h"
-RCSID("$NetBSD: cpuswitch.S,v 1.9 2018/12/12 11:14:51 ryo Exp $")
+RCSID("$NetBSD: cpuswitch.S,v 1.10 2018/12/13 10:44:25 ryo Exp $")
/*
* At IPL_SCHED:
@@ -341,6 +341,13 @@
msr spsr_el1, x1 /* exception pstate */
msr sp_el0, x2 /* restore EL0 stack */
+ /* if the process is traced, enable MDSCR_EL1.SS */
+ tbz x1, #SPSR_SS_SHIFT, 1f
+ mrs x0, mdscr_el1
+ orr x0, x0, #MDSCR_SS
+ msr mdscr_el1, x0
+1:
+
unwind_x0_x2
/* leave sp at l_md.md_utf, return back to EL0 user process */
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/db_machdep.c
--- a/sys/arch/aarch64/aarch64/db_machdep.c Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/db_machdep.c Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: db_machdep.c,v 1.11 2018/11/28 19:13:15 ryo Exp $ */
+/* $NetBSD: db_machdep.c,v 1.12 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_machdep.c,v 1.11 2018/11/28 19:13:15 ryo Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_machdep.c,v 1.12 2018/12/13 10:44:25 ryo Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd32.h"
@@ -616,11 +616,9 @@
}
mdscr = reg_mdscr_el1_read();
- mdscr |= __BIT(15);
- mdscr |= __BIT(13);
+ mdscr |= MDSCR_MDE; /* enable watchpoint and breakpoint */
reg_mdscr_el1_write(mdscr);
reg_oslar_el1_write(0);
- daif_enable(DAIF_D);
}
static void
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/genassym.cf
--- a/sys/arch/aarch64/aarch64/genassym.cf Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/genassym.cf Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: genassym.cf,v 1.10 2018/12/11 05:46:14 ryo Exp $
+# $NetBSD: genassym.cf,v 1.11 2018/12/13 10:44:25 ryo Exp $
#-
# Copyright (c) 2014 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -329,6 +329,7 @@
define CNTHCTL_EL1PCTEN CNTHCTL_EL1PCTEN
define CNTHCTL_EL1PCEN CNTHCTL_EL1PCEN
define CNTKCTL_EL0VCTEN CNTKCTL_EL0VCTEN
+define SPSR_SS_SHIFT SPSR_SS_SHIFT
define SPSR_F SPSR_F
define SPSR_I SPSR_I
define SPSR_A SPSR_A
@@ -352,6 +353,11 @@
define MPIDR_AFF2 MPIDR_AFF2
define MPIDR_AFF3 MPIDR_AFF3
+define MDSCR_MDE MDSCR_MDE
+define MDSCR_KDE MDSCR_KDE
+define MDSCR_TDCC MDSCR_TDCC
+define MDSCR_SS MDSCR_SS
+
define MAIR_ATTR0 MAIR_ATTR0
define MAIR_ATTR1 MAIR_ATTR1
define MAIR_ATTR2 MAIR_ATTR2
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/locore.S
--- a/sys/arch/aarch64/aarch64/locore.S Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/locore.S Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: locore.S,v 1.31 2018/11/08 08:28:07 maxv Exp $ */
+/* $NetBSD: locore.S,v 1.32 2018/12/13 10:44:25 ryo Exp $ */
/*
* Copyright (c) 2017 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -39,7 +39,7 @@
#include <aarch64/hypervisor.h>
#include "assym.h"
-RCSID("$NetBSD: locore.S,v 1.31 2018/11/08 08:28:07 maxv Exp $")
+RCSID("$NetBSD: locore.S,v 1.32 2018/12/13 10:44:25 ryo Exp $")
/*#define DEBUG_LOCORE /* debug print */
@@ -218,8 +218,10 @@
init_sysregs:
stp x0, lr, [sp, #-16]!
- /* Disable debug event */
- msr mdscr_el1, xzr
+ /* init debug event */
+ ldr x0, mdscr_setting
+ msr mdscr_el1, x0
+ msr oslar_el1, xzr
/* Clear context id register */
msr contextidr_el1, xzr
@@ -1008,6 +1010,11 @@
SCTLR_A | /* Alignment check enable */ \
0)
+mdscr_setting:
+ .quad ( \
+ MDSCR_TDCC | /* Trap Debug Communications Channel access */ \
+ 0)
+
.L_devmap_addr:
.quad VM_KERNEL_IO_ADDRESS
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/process_machdep.c
--- a/sys/arch/aarch64/aarch64/process_machdep.c Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/process_machdep.c Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: process_machdep.c,v 1.3 2018/07/17 00:36:30 christos Exp $ */
+/* $NetBSD: process_machdep.c,v 1.4 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
#include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: process_machdep.c,v 1.3 2018/07/17 00:36:30 christos Exp $");
+__KERNEL_RCSID(1, "$NetBSD: process_machdep.c,v 1.4 2018/12/13 10:44:25 ryo Exp $");
#include <sys/param.h>
#include <sys/types.h>
@@ -89,6 +89,17 @@
}
int
+process_sstep(struct lwp *l, int sstep)
+{
+ if (sstep)
+ l->l_md.md_utf->tf_spsr |= SPSR_SS;
+ else
+ l->l_md.md_utf->tf_spsr &= ~SPSR_SS;
+
+ return 0;
+}
+
+int
process_set_pc(struct lwp *l, void *addr)
{
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/aarch64/trap.c
--- a/sys/arch/aarch64/aarch64/trap.c Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/aarch64/trap.c Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.c,v 1.13 2018/12/12 18:11:00 ryo Exp $ */
+/* $NetBSD: trap.c,v 1.14 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
#include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: trap.c,v 1.13 2018/12/12 18:11:00 ryo Exp $");
+__KERNEL_RCSID(1, "$NetBSD: trap.c,v 1.14 2018/12/13 10:44:25 ryo Exp $");
#include "opt_arm_intr_impl.h"
#include "opt_compat_netbsd32.h"
@@ -232,6 +232,8 @@
const uint32_t esr = tf->tf_esr;
const uint32_t eclass = __SHIFTOUT(esr, ESR_EC); /* exception class */
+ /* disable trace */
+ reg_mdscr_el1_write(reg_mdscr_el1_read() & ~MDSCR_SS);
/* enable traps and interrupts */
daif_enable(DAIF_D|DAIF_A|DAIF_I|DAIF_F);
@@ -265,11 +267,16 @@
case ESR_EC_BKPT_INSN_A64:
case ESR_EC_BRKPNT_EL0:
- case ESR_EC_SW_STEP_EL0:
case ESR_EC_WTCHPNT_EL0:
do_trapsignal(l, SIGTRAP, TRAP_BRKPT, (void *)tf->tf_pc, esr);
userret(l);
break;
+ case ESR_EC_SW_STEP_EL0:
+ /* disable trace, and send trace trap */
+ tf->tf_spsr &= ~SPSR_SS;
+ do_trapsignal(l, SIGTRAP, TRAP_TRACE, (void *)tf->tf_pc, esr);
+ userret(l);
+ break;
default:
case ESR_EC_UNKNOWN:
@@ -305,6 +312,9 @@
}
#endif
+ /* disable trace */
+ reg_mdscr_el1_write(reg_mdscr_el1_read() & ~MDSCR_SS);
+
/* enable traps */
daif_enable(DAIF_D|DAIF_A);
@@ -322,6 +332,8 @@
const uint32_t esr = tf->tf_esr;
const uint32_t eclass = __SHIFTOUT(esr, ESR_EC); /* exception class */
+ /* disable trace */
+ reg_mdscr_el1_write(reg_mdscr_el1_read() & ~MDSCR_SS);
/* enable traps and interrupts */
daif_enable(DAIF_D|DAIF_A|DAIF_I|DAIF_F);
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/include/armreg.h
--- a/sys/arch/aarch64/include/armreg.h Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/include/armreg.h Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: armreg.h,v 1.21 2018/11/20 01:59:51 mrg Exp $ */
+/* $NetBSD: armreg.h,v 1.22 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -596,6 +596,7 @@
#define SPSR_A32_IT1 __BIT(23) // A32: IT[1]
#define SPSR_A32_IT0 __BIT(22) // A32: IT[0]
#define SPSR_SS __BIT(21) // Software Step
+#define SPSR_SS_SHIFT 21
#define SPSR_IL __BIT(20) // Instruction Length
#define SPSR_GE __BITS(19,16) // A32: SIMD GE
#define SPSR_IT7 __BIT(15) // A32: IT[7]
@@ -805,6 +806,19 @@
AARCH64REG_READ_INLINE(mdscr_el1) // Monitor Debug System Control Register
AARCH64REG_WRITE_INLINE(mdscr_el1)
+#define MDSCR_RXFULL __BIT(30) // for EDSCR.RXfull
+#define MDSCR_TXFULL __BIT(29) // for EDSCR.TXfull
+#define MDSCR_RXO __BIT(27) // for EDSCR.RXO
+#define MDSCR_TXU __BIT(26) // for EDSCR.TXU
+#define MDSCR_INTDIS __BITS(32,22) // for EDSCR.INTdis
+#define MDSCR_TDA __BIT(21) // for EDSCR.TDA
+#define MDSCR_MDE __BIT(15) // Monitor debug events
+#define MDSCR_HDE __BIT(14) // for EDSCR.HDE
+#define MDSCR_KDE __BIT(13) // Local debug enable
+#define MDSCR_TDCC __BIT(12) // Trap Debug CommCh access
+#define MDSCR_ERR __BIT(6) // for EDSCR.ERR
+#define MDSCR_SS __BIT(0) // Software step
+
AARCH64REG_WRITE_INLINE(oslar_el1) // OS Lock Access Register
AARCH64REG_READ_INLINE(oslsr_el1) // OS Lock Status Register
diff -r f60bb069cb1b -r 6094e59f3811 sys/arch/aarch64/include/ptrace.h
--- a/sys/arch/aarch64/include/ptrace.h Thu Dec 13 10:27:51 2018 +0000
+++ b/sys/arch/aarch64/include/ptrace.h Thu Dec 13 10:44:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ptrace.h,v 1.7 2018/07/21 18:58:05 ryo Exp $ */
+/* $NetBSD: ptrace.h,v 1.8 2018/12/13 10:44:25 ryo Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -36,18 +36,23 @@
/*
* AARCH64-dependent ptrace definitions.
- * Note that PT_STEP is _not_ supported.
*/
-#define PT_GETREGS (PT_FIRSTMACH + 0)
-#define PT_SETREGS (PT_FIRSTMACH + 1)
-#define PT_GETFPREGS (PT_FIRSTMACH + 2)
-#define PT_SETFPREGS (PT_FIRSTMACH + 3)
+#define PT_GETREGS (PT_FIRSTMACH + 0)
+#define PT_SETREGS (PT_FIRSTMACH + 1)
+#define PT_GETFPREGS (PT_FIRSTMACH + 2)
+#define PT_SETFPREGS (PT_FIRSTMACH + 3)
+#define PT_STEP (PT_FIRSTMACH + 4)
+#define PT_SETSTEP (PT_FIRSTMACH + 5)
+#define PT_CLEARSTEP (PT_FIRSTMACH + 6)
#define PT_MACHDEP_STRINGS \
Home |
Main Index |
Thread Index |
Old Index