|
|
Plan 9 NeXT
#include "u.h"
#include "../port/lib.h"
#include "mem.h"
#include "dat.h"
#include "fns.h"
#include "ureg.h"
#include "io.h"
int faulting;
void
fault386(Ureg *ur, void *a)
{
ulong addr;
int read;
int user;
int n;
int insyscall;
char buf[ERRLEN];
USED(a);
insyscall = u->p->insyscall;
u->p->insyscall = 1;
addr = getcr2();
read = !(ur->ecode & 2);
user = (ur->cs&0xffff) == UESEL;
spllo();
/* print("F%d:A#%lux:U%d:R%d|", u->p->pid, addr, user, read);/**/
n = fault(addr, read);
if(n < 0){
if(user){
sprint(buf, "sys: trap: fault %s addr=0x%lux",
read? "read" : "write", addr);
postnote(u->p, 1, buf, NDebug);
return;
}
dumpregs(ur);
panic("fault: 0x%lux", addr);
}
u->p->insyscall = insyscall;
}
void
faultinit(void)
{
setvec(Faultvec, fault386, 0);
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.