Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/sh3/sh3 db_tlbdump_cmd - get rid of RUN_P2/P1, use ...
details: https://anonhg.NetBSD.org/src/rev/10d8ea134f21
branches: trunk
changeset: 1012593:10d8ea134f21
user: uwe <uwe%NetBSD.org@localhost>
date: Mon Aug 03 01:56:18 2020 +0000
description:
db_tlbdump_cmd - get rid of RUN_P2/P1, use functions instead.
Move the bits of code to read TLB entries into separate functions and
call them via P2 pointers instead of doing P2/P1 switch inline.
diffstat:
sys/arch/sh3/sh3/db_interface.c | 51 +++++++++++++++++++++++++++++++---------
1 files changed, 39 insertions(+), 12 deletions(-)
diffs (102 lines):
diff -r 91ee753a1bc0 -r 10d8ea134f21 sys/arch/sh3/sh3/db_interface.c
--- a/sys/arch/sh3/sh3/db_interface.c Mon Aug 03 01:38:10 2020 +0000
+++ b/sys/arch/sh3/sh3/db_interface.c Mon Aug 03 01:56:18 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: db_interface.c,v 1.63 2020/08/03 01:18:45 uwe Exp $ */
+/* $NetBSD: db_interface.c,v 1.64 2020/08/03 01:56:18 uwe Exp $ */
/*-
* Copyright (C) 2002 UCHIYAMA Yasushi. All rights reserved.
@@ -28,7 +28,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.63 2020/08/03 01:18:45 uwe Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.64 2020/08/03 01:56:18 uwe Exp $");
#include "opt_ddb.h"
#include "opt_kgdb.h"
@@ -66,6 +66,13 @@
static void kdb_printtrap(u_int, int);
static void db_tlbdump_cmd(db_expr_t, bool, db_expr_t, const char *);
+#ifdef SH4
+static __noinline void
+__db_get_itlb_sh4(uint32_t, uint32_t *, uint32_t *, uint32_t *);
+static __noinline void
+__db_get_utlb_sh4(uint32_t, uint32_t *, uint32_t *, uint32_t *);
+#endif
+
static char *__db_procname_by_asid(int);
static void __db_tlbdump_pfn(uint32_t);
#ifdef SH4
@@ -320,8 +327,13 @@
#endif /* SH3 */
#ifdef SH4
if (CPU_IS_SH4) {
+ void (*get_itlb_p2)(uint32_t, uint32_t *, uint32_t *, uint32_t *);
+ void (*get_utlb_p2)(uint32_t, uint32_t *, uint32_t *, uint32_t *);
uint32_t aa, da1, da2;
+ get_itlb_p2 = (void *)SH3_P1SEG_TO_P2SEG(__db_get_itlb_sh4);
+ get_utlb_p2 = (void *)SH3_P1SEG_TO_P2SEG(__db_get_utlb_sh4);
+
/* MMU configuration */
r = _reg_read_4(SH4_MMUCR);
db_printf("%s virtual storage mode, SQ access: (kernel%s)\n",
@@ -338,11 +350,7 @@
for (i = 0; i < 4; i++) {
e = i << SH4_ITLB_E_SHIFT;
- RUN_P2;
- aa = _reg_read_4(SH4_ITLB_AA | e);
- da1 = _reg_read_4(SH4_ITLB_DA1 | e);
- da2 = _reg_read_4(SH4_ITLB_DA2 | e);
- RUN_P1;
+ (*get_itlb_p2)(e, &aa, &da1, &da2);
db_printf("0x%08x %3d",
aa & SH4_ITLB_AA_VPN_MASK,
@@ -367,11 +375,7 @@
for (i = 0; i < 64; i++) {
e = i << SH4_UTLB_E_SHIFT;
- RUN_P2;
- aa = _reg_read_4(SH4_UTLB_AA | e);
- da1 = _reg_read_4(SH4_UTLB_DA1 | e);
- da2 = _reg_read_4(SH4_UTLB_DA2 | e);
- RUN_P1;
+ (*get_utlb_p2)(e, &aa, &da1, &da2);
db_printf("0x%08x %3d",
aa & SH4_UTLB_AA_VPN_MASK,
@@ -397,6 +401,29 @@
#endif /* SH4 */
}
+
+#ifdef SH4
+static __noinline void
+__db_get_itlb_sh4(uint32_t e, uint32_t *paa, uint32_t *pda1, uint32_t *pda2)
+{
+
+ *paa = _reg_read_4(SH4_ITLB_AA | e);
+ *pda1 = _reg_read_4(SH4_ITLB_DA1 | e);
+ *pda2 = _reg_read_4(SH4_ITLB_DA2 | e);
+}
+
+
+static __noinline void
+__db_get_utlb_sh4(uint32_t e, uint32_t *paa, uint32_t *pda1, uint32_t *pda2)
+{
+
+ *paa = _reg_read_4(SH4_UTLB_AA | e);
+ *pda1 = _reg_read_4(SH4_UTLB_DA1 | e);
+ *pda2 = _reg_read_4(SH4_UTLB_DA2 | e);
+}
+#endif /* SH4 */
+
+
static void
__db_tlbdump_pfn(uint32_t r)
{
Home |
Main Index |
Thread Index |
Old Index