Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch Clean up dbregs; remove useless comments, remove ar...



details:   https://anonhg.NetBSD.org/src/rev/e5ffab725ba6
branches:  trunk
changeset: 991622:e5ffab725ba6
user:      maxv <maxv%NetBSD.org@localhost>
date:      Sun Jul 22 15:02:51 2018 +0000

description:
Clean up dbregs; remove useless comments, remove arguments from prototypes,
style, add KASSERT and move x86_dbregspl into dbregs.c. No real functional
change.

diffstat:

 sys/arch/amd64/amd64/machdep.c |  12 ++----
 sys/arch/i386/i386/machdep.c   |  12 ++----
 sys/arch/x86/include/dbregs.h  |  68 ++++++++++-------------------------------
 sys/arch/x86/x86/dbregs.c      |  52 ++++++++++++++++---------------
 4 files changed, 52 insertions(+), 92 deletions(-)

diffs (truncated from 346 to 300 lines):

diff -r 863453e409bc -r e5ffab725ba6 sys/arch/amd64/amd64/machdep.c
--- a/sys/arch/amd64/amd64/machdep.c    Sat Jul 21 21:26:30 2018 +0000
+++ b/sys/arch/amd64/amd64/machdep.c    Sun Jul 22 15:02:51 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: machdep.c,v 1.307 2018/07/21 06:09:13 maxv Exp $       */
+/*     $NetBSD: machdep.c,v 1.308 2018/07/22 15:02:51 maxv Exp $       */
 
 /*
  * Copyright (c) 1996, 1997, 1998, 2000, 2006, 2007, 2008, 2011
@@ -110,7 +110,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.307 2018/07/21 06:09:13 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.308 2018/07/22 15:02:51 maxv Exp $");
 
 #include "opt_modular.h"
 #include "opt_user_ldt.h"
@@ -280,7 +280,7 @@
 void (*initclock_func)(void) = xen_initclocks;
 #endif
 
-struct pool x86_dbregspl;
+extern struct pool x86_dbregspl;
 
 struct nmistore {
        uint64_t cr3;
@@ -1929,11 +1929,7 @@
 #endif
 
        pcb->pcb_dbregs = NULL;
-
-       x86_dbregs_setup_initdbstate();
-
-       pool_init(&x86_dbregspl, sizeof(struct dbreg), 16, 0, 0, "dbregs",
-           NULL, IPL_NONE);
+       x86_dbregs_init();
 }
 
 void
diff -r 863453e409bc -r e5ffab725ba6 sys/arch/i386/i386/machdep.c
--- a/sys/arch/i386/i386/machdep.c      Sat Jul 21 21:26:30 2018 +0000
+++ b/sys/arch/i386/i386/machdep.c      Sun Jul 22 15:02:51 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: machdep.c,v 1.806 2018/04/05 08:43:07 maxv Exp $       */
+/*     $NetBSD: machdep.c,v 1.807 2018/07/22 15:02:51 maxv Exp $       */
 
 /*
  * Copyright (c) 1996, 1997, 1998, 2000, 2004, 2006, 2008, 2009, 2017
@@ -67,7 +67,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.806 2018/04/05 08:43:07 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.807 2018/07/22 15:02:51 maxv Exp $");
 
 #include "opt_beep.h"
 #include "opt_compat_freebsd.h"
@@ -213,7 +213,7 @@
 int i386_has_sse;
 int i386_has_sse2;
 
-struct pool x86_dbregspl;
+extern struct pool x86_dbregspl;
 
 vaddr_t idt_vaddr;
 paddr_t idt_paddr;
@@ -1443,11 +1443,7 @@
        }
 
        pcb->pcb_dbregs = NULL;
-
-       x86_dbregs_setup_initdbstate();
-
-       pool_init(&x86_dbregspl, sizeof(struct dbreg), 16, 0, 0, "dbregs",
-           NULL, IPL_NONE);
+       x86_dbregs_init();
 }
 
 #include <dev/ic/mc146818reg.h>                /* for NVRAM POST */
diff -r 863453e409bc -r e5ffab725ba6 sys/arch/x86/include/dbregs.h
--- a/sys/arch/x86/include/dbregs.h     Sat Jul 21 21:26:30 2018 +0000
+++ b/sys/arch/x86/include/dbregs.h     Sun Jul 22 15:02:51 2018 +0000
@@ -1,6 +1,6 @@
-/*     $NetBSD: dbregs.h,v 1.4 2017/02/23 03:34:22 kamil Exp $ */
+/*     $NetBSD: dbregs.h,v 1.5 2018/07/22 15:02:51 maxv Exp $  */
 
-/*-
+/*
  * Copyright (c) 2016 The NetBSD Foundation, Inc.
  * All rights reserved.
  *
@@ -26,7 +26,6 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 
-
 #ifndef        _X86_DBREGS_H_
 #define        _X86_DBREGS_H_
 
@@ -50,11 +49,11 @@
 /*
  * CPU Debug Control Register (DR7)
  *
- * LOCAL_EXACT_BREAKPOINT and GLOBAL_EXACT_BREAKPOINT are no longer used since
- * the P6 processor family - portable code should set these bits
- * unconditionally in oder to get exact breakpoints
+ * LOCAL_EXACT_BREAKPOINT and GLOBAL_EXACT_BREAKPOINT are no longer used
+ * since the P6 processor family - portable code should set these bits
+ * unconditionally in order to get exact breakpoints.
  *
- * Reserved bits: 10, 12, 14-15 and on x86_64 32-64
+ * Reserved bits: 10, 12, 14-15 and on x86_64 32-64.
  */
 #define X86_DR7_LOCAL_DR0_BREAKPOINT           __BIT(0)
 #define X86_DR7_GLOBAL_DR0_BREAKPOINT          __BIT(1)
@@ -79,9 +78,9 @@
 #define X86_DR7_DR3_LENGTH_MASK                        __BITS(30, 31)
 
 /*
- * X86_DR7_CONDITION_IO_READWRITE is currently unused
- * it requires DE (debug extension) flag in control register CR4 set
- * not all CPUs support it
+ * X86_DR7_CONDITION_IO_READWRITE is currently unused. It requires DE
+ * (debug extension) flag in control register CR4 set, and not all CPUs
+ * support it.
  */
 enum x86_dr7_condition {
        X86_DR7_CONDITION_EXECUTION             = 0x0,
@@ -91,7 +90,7 @@
 };
 
 /*
- * 0x2 is currently unimplemented - it reflects 8 bytes on modern CPUs
+ * 0x2 is currently unimplemented - it reflects 8 bytes on modern CPUs.
  */
 enum x86_dr7_length {
        X86_DR7_LENGTH_BYTE             = 0x0,
@@ -107,46 +106,13 @@
  */
 #define X86_DBREGS     4
 
-/*
- * Store the initial Debug Register state of CPU
- * This copy will be used to initialize new debug register state
- */
-void x86_dbregs_setup_initdbstate(void);
-
-/*
- * Reset CPU Debug Registers - to be used after returning to user context
- */
-void x86_dbregs_clear(struct lwp *l);
-
-/*
- * Retrieve Debug Registers from LWP's PCB and save in regs
- * In case of empty register set, initialize it
- */
-void x86_dbregs_read(struct lwp *l, struct dbreg *regs);
-
-/*
- * Set CPU Debug Registers - to be used before entering user-land context
- */
-void x86_dbregs_set(struct lwp *l);
-
-/*
- * Store DR6 in LWP - to be used in trap function
- */
-void x86_dbregs_store_dr6(struct lwp *l);
-
-/*
- * Check if trap is triggered from user-land if so return nonzero value
- */
+void x86_dbregs_init(void);
+void x86_dbregs_clear(struct lwp *);
+void x86_dbregs_read(struct lwp *, struct dbreg *);
+void x86_dbregs_set(struct lwp *);
+void x86_dbregs_store_dr6(struct lwp *);
 int x86_dbregs_user_trap(void);
-
-/*
- * Check if trap is triggered from user-land if so return nonzero value
- */
-int x86_dbregs_validate(const struct dbreg *regs);
-
-/*
- * Write new Debug Registers from regs into LWP's PCB
- */
-void x86_dbregs_write(struct lwp *l, const struct dbreg *regs);
+int x86_dbregs_validate(const struct dbreg *);
+void x86_dbregs_write(struct lwp *, const struct dbreg *);
 
 #endif /* !_X86_DBREGS_H_ */
diff -r 863453e409bc -r e5ffab725ba6 sys/arch/x86/x86/dbregs.c
--- a/sys/arch/x86/x86/dbregs.c Sat Jul 21 21:26:30 2018 +0000
+++ b/sys/arch/x86/x86/dbregs.c Sun Jul 22 15:02:51 2018 +0000
@@ -1,6 +1,6 @@
-/*     $NetBSD: dbregs.c,v 1.9 2018/04/08 14:21:23 kamil Exp $ */
+/*     $NetBSD: dbregs.c,v 1.10 2018/07/22 15:02:51 maxv Exp $ */
 
-/*-
+/*
  * Copyright (c) 2016 The NetBSD Foundation, Inc.
  * All rights reserved.
  *
@@ -26,7 +26,6 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 
-
 #include <sys/param.h>
 #include <sys/types.h>
 #include <sys/lwp.h>
@@ -39,7 +38,7 @@
 
 #include <machine/pmap.h>
 
-extern struct pool x86_dbregspl;
+struct pool x86_dbregspl;
 
 static struct dbreg initdbstate;
 
@@ -56,7 +55,7 @@
        X86_DR7_GLOBAL_DR3_BREAKPOINT )
 
 void
-x86_dbregs_setup_initdbstate(void)
+x86_dbregs_init(void)
 {
        /* DR0-DR3 should always be 0 */
        initdbstate.dr[0] = rdr0();
@@ -70,14 +69,14 @@
        /* DR8-DR15 are reserved - skip */
 
        /*
-        * Paranoid case.
-        *
         * Explicitly reset some bits just in case they could be
         * set by brave software/hardware before the kernel boot.
         */
        initdbstate.dr[6] &= ~X86_BREAKPOINT_CONDITION_DETECTED;
+       initdbstate.dr[7] &= ~X86_DR7_GENERAL_DETECT_ENABLE;
 
-       initdbstate.dr[7] &= ~X86_DR7_GENERAL_DETECT_ENABLE;
+       pool_init(&x86_dbregspl, sizeof(struct dbreg), 16, 0, 0, "dbregs",
+           NULL, IPL_NONE);
 }
 
 void
@@ -88,16 +87,16 @@
        KASSERT(pcb->pcb_dbregs == NULL);
 
        /*
-        * It's sufficient to just disable Debug Control Register (DR7)
-        * it will deactivate hardware watchpoints
+        * It's sufficient to just disable Debug Control Register (DR7).
+        * It will deactivate hardware watchpoints.
         */
        ldr7(0);
 
        /*
-        * However at some point we need to clear Debug Status Registers (DR6)
-        * CPU will never do it automatically
+        * However at some point we need to clear Debug Status Registers
+        * (DR6). The CPU will never do it automatically.
         *
-        * Clear BREAKPOINT_CONDITION_DETECTED bits and ignore the rest
+        * Clear BREAKPOINT_CONDITION_DETECTED bits and ignore the rest.
         */
        ldr6(rdr6() & ~X86_BREAKPOINT_CONDITION_DETECTED);
 }
@@ -135,6 +134,7 @@
 {
        struct pcb *pcb = lwp_getpcb(l);
 
+       KASSERT(l == curlwp);
        KASSERT(pcb->pcb_dbregs != NULL);
 
        pcb->pcb_dbregs->dr[6] = rdr6();
@@ -143,15 +143,14 @@
 int
 x86_dbregs_user_trap(void)
 {
-       register_t dr7, dr6;    /* debug registers dr6 and dr7 */
-       register_t bp;          /* breakpoint bits extracted from dr6 */
+       register_t dr7, dr6;
+       register_t bp;
 
        dr7 = rdr7();
        if ((dr7 & X86_GLOBAL_BREAKPOINT) == 0) {
                /*
-                * all Global Breakpoint bits in the DR7 register are zero,
-                * thus the trap couldn't have been caused by the
-                * hardware debug registers
+                * All Global Breakpoint bits are zero, thus the trap couldn't
+                * have been caused by the hardware debug registers.
                 */
                return 0;
        }
@@ -161,15 +160,15 @@
 



Home | Main Index | Thread Index | Old Index