| plan 9 kernel history: overview | file list | diff list |
1992/1126/power/faultmips.c (diff list | history)
| 1992/1126/sys/src/9/power/faultmips.c:1,55 – 1993/0501/sys/src/9/power/faultmips.c:1,53 (short | long | prev | next) | ||
| 1990/1212 | #include "u.h" | |
| 1992/0321 | #include "../port/lib.h" | |
| 1990/1212 | #include "mem.h" #include "dat.h" #include "fns.h" #include "ureg.h" | |
| 1992/0111 | #include "../port/error.h" | |
| 1992/0508 | #include "io.h" | |
| 1990/1212 | /* * find out fault address and type of access. * Call common fault handler. */ void faultmips(Ureg *ur, int user, int code) { | |
| 1993/0501 | int read; | |
| 1990/1212 | ulong addr; extern char *excname[]; | |
| 1991/0705 |
| |
| 1990/1212 |
| |
| 1993/0501 | char *p, buf[ERRLEN]; | |
| 1990/1212 | ||
| 1992/0508 |
| |
| 1990/1212 | addr = ur->badvaddr; | |
| 1992/1126 |
| |
| 1992/0609 |
| |
| 1990/1212 | addr &= ~(BY2PG-1); read = !(code==CTLBM || code==CTLBS); | |
| 1991/0926 | ||
| 1990/1212 |
| |
| 1991/1218 |
| |
| 1991/0705 |
| |
| 1992/0508 |
| |
| 1991/0705 |
| |
| 1990/1212 |
| |
| 1992/1124 |
| |
| 1990/1212 |
| |
| 1993/0501 | if(fault(addr, read) == 0) return; if(user) { p = "store"; if(read) p = "load"; sprint(buf, "sys: trap: fault %s addr=0x%lux", p, ur->badvaddr); postnote(up, 1, buf, NDebug); return; | |
| 1990/1212 | } | |
| 1992/1126 |
| |
| 1993/0501 | print("kernel %s vaddr=0x%lux\n", excname[code], ur->badvaddr); print("status=0x%lux pc=0x%lux sp=0x%lux\n", ur->status, ur->pc, ur->sp); dumpregs(ur); panic("fault"); | |
| 1990/1212 | } /* * called in sysfile.c */ void evenaddr(ulong addr) { if(addr & 3){ | |
| 1993/0501 | postnote(up, 1, "sys: odd address", NDebug); | |
| 1990/1212 | error(Ebadarg); } } | |