kernel/rdb: need to reenable polling mode on the uart, remove cruft
This commit is contained in:
parent
9eb192f586
commit
a87ce74d60
1 changed files with 22 additions and 51 deletions
|
@ -6,51 +6,27 @@
|
||||||
#include "io.h"
|
#include "io.h"
|
||||||
#include "ureg.h"
|
#include "ureg.h"
|
||||||
|
|
||||||
#define DBG if(0)scrprint
|
|
||||||
#pragma varargck argpos scrprint 1
|
|
||||||
static Ureg ureg;
|
|
||||||
|
|
||||||
static void
|
|
||||||
scrprint(char *fmt, ...)
|
|
||||||
{
|
|
||||||
char buf[128];
|
|
||||||
va_list va;
|
|
||||||
int n;
|
|
||||||
|
|
||||||
va_start(va, fmt);
|
|
||||||
n = vseprint(buf, buf+sizeof buf, fmt, va)-buf;
|
|
||||||
va_end(va);
|
|
||||||
putstrn(buf, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
static char*
|
static char*
|
||||||
getline(void)
|
getline(void)
|
||||||
{
|
{
|
||||||
static char buf[128];
|
static char buf[128];
|
||||||
int i, c;
|
int i, c;
|
||||||
|
|
||||||
for(;;){
|
for(i = 0; i < sizeof(buf)-1 && (c=uartgetc()) != '\n'; i++)
|
||||||
for(i=0; i<nelem(buf) && (c=uartgetc()) != '\n'; i++){
|
buf[i] = c;
|
||||||
DBG("%c...", c);
|
buf[i] = 0;
|
||||||
buf[i] = c;
|
return buf;
|
||||||
}
|
|
||||||
|
|
||||||
if(i < nelem(buf)){
|
|
||||||
buf[i] = 0;
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void*
|
static void*
|
||||||
addr(char *s, Ureg *ureg, char **p)
|
addr(char *s, Ureg *ureg, char **p)
|
||||||
{
|
{
|
||||||
ulong a;
|
uvlong a;
|
||||||
|
|
||||||
a = strtoul(s, p, 16);
|
a = strtoull(s, p, 16);
|
||||||
if(a < sizeof(Ureg))
|
if(a < sizeof(Ureg))
|
||||||
return ((uchar*)ureg)+a;
|
return ((uchar*)ureg)+a;
|
||||||
return (void*)a;
|
return (void*)(uintptr)a;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -59,18 +35,27 @@ talkrdb(Ureg *ureg)
|
||||||
uchar *a;
|
uchar *a;
|
||||||
char *p, *req;
|
char *p, *req;
|
||||||
|
|
||||||
serialoq = nil; /* turn off serial console */
|
if(consuart == nil)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(serialoq != nil){
|
||||||
|
qhangup(serialoq, nil);
|
||||||
|
if(consuart->phys->disable != nil)
|
||||||
|
consuart->phys->disable(consuart);
|
||||||
|
if(consuart->phys->enable != nil)
|
||||||
|
consuart->phys->enable(consuart, 0);
|
||||||
|
serialoq = nil;
|
||||||
|
}
|
||||||
kprintoq = nil; /* turn off /dev/kprint if active */
|
kprintoq = nil; /* turn off /dev/kprint if active */
|
||||||
// scrprint("Plan 9 debugger\n");
|
|
||||||
iprint("Edebugger reset\n");
|
iprint("Edebugger reset\n");
|
||||||
for(;;){
|
for(;;){
|
||||||
req = getline();
|
req = getline();
|
||||||
switch(*req){
|
switch(*req){
|
||||||
case 'r':
|
case 'r':
|
||||||
a = addr(req+1, ureg, nil);
|
a = addr(req+1, ureg, nil);
|
||||||
DBG("read %p\n", a);
|
iprint("R%.8zux %.2ux %.2ux %.2ux %.2ux\n",
|
||||||
iprint("R%.8lux %.2ux %.2ux %.2ux %.2ux\n",
|
(uintptr)a, a[0], a[1], a[2], a[3]);
|
||||||
strtoul(req+1, 0, 16), a[0], a[1], a[2], a[3]);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'w':
|
case 'w':
|
||||||
|
@ -78,22 +63,8 @@ talkrdb(Ureg *ureg)
|
||||||
*(ulong*)a = strtoul(p, nil, 16);
|
*(ulong*)a = strtoul(p, nil, 16);
|
||||||
iprint("W\n");
|
iprint("W\n");
|
||||||
break;
|
break;
|
||||||
/*
|
|
||||||
* case Tmput:
|
|
||||||
n = min[4];
|
|
||||||
if(n > 4){
|
|
||||||
mesg(Rerr, Ecount);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
a = addr(min+0);
|
|
||||||
scrprint("mput %.8lux\n", a);
|
|
||||||
memmove(a, min+5, n);
|
|
||||||
mesg(Rmput, mout);
|
|
||||||
break;
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
default:
|
default:
|
||||||
DBG("unknown %c\n", *req);
|
|
||||||
iprint("Eunknown message\n");
|
iprint("Eunknown message\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue