Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/usermode/usermode Oops, forgot a debug printf
details: https://anonhg.NetBSD.org/src/rev/d85ac6fda3e6
branches: trunk
changeset: 991801:d85ac6fda3e6
user: reinoud <reinoud%NetBSD.org@localhost>
date: Wed Aug 01 09:44:31 2018 +0000
description:
Oops, forgot a debug printf
diffstat:
sys/arch/usermode/usermode/machdep.c | 22 +++++++++-
sys/arch/usermode/usermode/pmap.c | 5 +-
sys/arch/usermode/usermode/thunk.c | 79 +++++++++++++++++++++++++++++++++++-
sys/arch/usermode/usermode/trap.c | 38 ++++++++++++++---
4 files changed, 130 insertions(+), 14 deletions(-)
diffs (284 lines):
diff -r 1209ee19c268 -r d85ac6fda3e6 sys/arch/usermode/usermode/machdep.c
--- a/sys/arch/usermode/usermode/machdep.c Wed Aug 01 09:43:17 2018 +0000
+++ b/sys/arch/usermode/usermode/machdep.c Wed Aug 01 09:44:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: machdep.c,v 1.56 2018/06/11 19:35:56 reinoud Exp $ */
+/* $NetBSD: machdep.c,v 1.57 2018/08/01 09:44:31 reinoud Exp $ */
/*-
* Copyright (c) 2011 Reinoud Zandijk <reinoud%netbsd.org@localhost>
@@ -37,7 +37,7 @@
#include "opt_memsize.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.56 2018/06/11 19:35:56 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.57 2018/08/01 09:44:31 reinoud Exp $");
#include <sys/types.h>
#include <sys/systm.h>
@@ -59,6 +59,11 @@
#include <machine/machdep.h>
#include <machine/mainbus.h>
#include <machine/thunk.h>
+#include <machine/cpu.h>
+#include <sys/kgdb.h>
+
+#include "opt_ddb.h"
+#include "opt_kgdb.h"
#ifndef MAX_DISK_IMAGES
#define MAX_DISK_IMAGES 4
@@ -272,6 +277,18 @@
splinit();
splraise(IPL_HIGH);
+#ifdef DDB
+ if (boothowto & RB_KDB)
+ Debugger();
+#endif
+#ifdef KGDB
+ if (boothowto & RB_KDB) {
+ kgdb_port_init();
+ kgdb_debug_init = 1;
+ kgdb_connect(1);
+ }
+#endif
+
kernmain();
}
@@ -297,6 +314,7 @@
void
consinit(void)
{
+// kgdb_connect(0);
printf("NetBSD/usermode startup\n");
}
diff -r 1209ee19c268 -r d85ac6fda3e6 sys/arch/usermode/usermode/pmap.c
--- a/sys/arch/usermode/usermode/pmap.c Wed Aug 01 09:43:17 2018 +0000
+++ b/sys/arch/usermode/usermode/pmap.c Wed Aug 01 09:44:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.c,v 1.108 2018/08/01 09:43:17 reinoud Exp $ */
+/* $NetBSD: pmap.c,v 1.109 2018/08/01 09:44:31 reinoud Exp $ */
/*-
* Copyright (c) 2011 Reinoud Zandijk <reinoud%NetBSD.org@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.108 2018/08/01 09:43:17 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.109 2018/08/01 09:44:31 reinoud Exp $");
#include "opt_memsize.h"
#include "opt_kmempages.h"
@@ -660,7 +660,6 @@
/* not known! then it must be UVM's work */
if (pv == NULL) {
-thunk_printf("%s: no mapping yet for %p\n", __func__, (void *) va);
thunk_printf_debug("%s: no mapping yet\n", __func__);
*atype = VM_PROT_READ; /* assume it was a read */
return false;
diff -r 1209ee19c268 -r d85ac6fda3e6 sys/arch/usermode/usermode/thunk.c
--- a/sys/arch/usermode/usermode/thunk.c Wed Aug 01 09:43:17 2018 +0000
+++ b/sys/arch/usermode/usermode/thunk.c Wed Aug 01 09:44:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: thunk.c,v 1.90 2018/06/04 19:53:01 reinoud Exp $ */
+/* $NetBSD: thunk.c,v 1.91 2018/08/01 09:44:31 reinoud Exp $ */
/*-
* Copyright (c) 2011 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -28,7 +28,7 @@
#include <sys/cdefs.h>
#ifdef __NetBSD__
-__RCSID("$NetBSD: thunk.c,v 1.90 2018/06/04 19:53:01 reinoud Exp $");
+__RCSID("$NetBSD: thunk.c,v 1.91 2018/08/01 09:44:31 reinoud Exp $");
#endif
#define _KMEMUSER
@@ -92,6 +92,9 @@
//#define RFB_DEBUG
+static ssize_t safe_recv(int s, void *buf, int len);
+static ssize_t safe_send(int s, const void *msg, int len);
+
extern int boothowto;
void
@@ -1017,6 +1020,78 @@
return 0;
}
+int
+thunk_gdb_open(void)
+{
+ struct sockaddr_in sin;
+ int sockfd;
+ int portnr = 5001; /* XXX configurable or random */
+
+ /* create socket */
+ sockfd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
+ if (sockfd < 0) {
+ warn("kgdb stub: couldn't create socket");
+ return 0;
+ }
+
+ /* bind to requested port */
+ memset(&sin, 0, sizeof(sin));
+ sin.sin_family = AF_INET;
+ sin.sin_addr.s_addr = htonl(INADDR_ANY);
+ sin.sin_port = htons(portnr);
+
+ if (bind(sockfd, (struct sockaddr *)&sin, sizeof(sin)) < 0) {
+ warn("kgdb stub: couldn't bind port %d", portnr);
+ close(sockfd);
+ return 0;
+ }
+
+ /* listen for connections */
+ if (listen(sockfd, 1) < 0) {
+ warn("kgdb stub: couldn't listen on socket");
+ close(sockfd);
+ return 0;
+ }
+ printf("kgdb stub: accepting connections on port %d\n", portnr);
+
+ return sockfd;
+}
+
+int
+thunk_gdb_accept(int sockfd)
+{
+ struct sockaddr_in client_addr;
+ socklen_t client_addrlen;
+ int fd, flags;
+
+ fd = accept(sockfd, (struct sockaddr *) &client_addr, &client_addrlen);
+ if (fd < 0) {
+ warn("kgdb_stub: connect error");
+ return 0;
+ }
+
+ /* make FIFO unblocking */
+ flags = fcntl(fd, F_GETFL, 0);
+ if (flags == -1)
+ flags = 0;
+ if (fcntl(fd, F_SETFL, flags | O_NONBLOCK) < 0) {
+ warn("kgdb_stub: can't make socket non blocking");
+ }
+ return fd;
+}
+
+int
+thunk_kgdb_getc(int fd, char *ch)
+{
+ return safe_recv(fd, ch, 1);
+}
+
+int
+thunk_kgdb_putc(int fd, char ch)
+{
+ return safe_send(fd, &ch, 1);
+}
+
static ssize_t
safe_send(int s, const void *msg, int len)
{
diff -r 1209ee19c268 -r d85ac6fda3e6 sys/arch/usermode/usermode/trap.c
--- a/sys/arch/usermode/usermode/trap.c Wed Aug 01 09:43:17 2018 +0000
+++ b/sys/arch/usermode/usermode/trap.c Wed Aug 01 09:44:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.c,v 1.69 2018/07/28 17:17:38 reinoud Exp $ */
+/* $NetBSD: trap.c,v 1.70 2018/08/01 09:44:31 reinoud Exp $ */
/*-
* Copyright (c) 2011 Reinoud Zandijk <reinoud%netbsd.org@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.69 2018/07/28 17:17:38 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.70 2018/08/01 09:44:31 reinoud Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -46,6 +46,12 @@
#include <machine/intr.h>
#include <machine/thunk.h>
+#include "opt_kgdb.h"
+
+#ifdef KGDB
+#include <sys/kgdb.h>
+#endif
+
/* define maximum signal number */
#ifndef NSIG
#define NSIG 64
@@ -61,6 +67,8 @@
static sigfunc_t sigio;
static sigfunc_t pass_on;
+void kgdb_kernel_trap(int signo, vaddr_t pc, vaddr_t va, ucontext_t *ctx);
+
/* raw signal handlers */
static char sig_stack[SIGSTKSZ];
static stack_t sigstk;
@@ -123,7 +131,7 @@
/* INT */ /* ttycons ^C */
/* QUIT */
signal_intr_establish(SIGILL, illegal_instruction);
- /* TRAP */
+ signal_intr_establish(SIGTRAP, pass_on); /* special */
/* ABRT */
/* SIGEMT */
signal_intr_establish(SIGFPE, pass_on);
@@ -317,9 +325,6 @@
f = sig_funcs[sig];
KASSERT(f);
- l = curlwp; KASSERT(l);
- pcb = lwp_getpcb(l); KASSERT(pcb);
-
/* get address of possible faulted memory access and page align it */
va = (vaddr_t) info->si_addr;
va = trunc_page(va);
@@ -327,7 +332,22 @@
/* get PC address of possibly faulted instruction */
pc = md_get_pc(ctx);
- /* nest it on the stack */
+ /*
+ * short-cut for SIGTRAP as we have NO indication anything is valid
+ */
+#ifdef KGDB
+ if (sig == SIGTRAP) {
+ from_userland = 0;
+ if (pc < kmem_user_end)
+ from_userland = 1;
+ if (!from_userland) {
+ kgdb_kernel_trap(sig, pc, va, ucp);
+ return;
+ }
+ }
+#endif
+
+ /* get stack pointer for nesting */
sp = md_get_sp(ctx);
if (sig == SIGBUS || sig == SIGSEGV)
@@ -335,6 +355,10 @@
if (sig == SIGILL)
print_illegal_instruction_siginfo(sig, info, ctx, pc, va, sp);
+ /* get thread */
+ l = curlwp; KASSERT(l);
+ pcb = lwp_getpcb(l); KASSERT(pcb);
+
/* currently running on the dedicated signal stack */
/* if we're running on a userland stack, switch to the system stack */
Home |
Main Index |
Thread Index |
Old Index