123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698 |
- sizeof_1_ = 8;
- aggr _1_
- {
- 'U' 0 lo;
- 'U' 4 hi;
- };
- defn
- _1_(addr) {
- complex _1_ addr;
- print(" lo ", addr.lo, "\n");
- print(" hi ", addr.hi, "\n");
- };
- sizeofFPdbleword = 8;
- aggr FPdbleword
- {
- 'F' 0 x;
- {
- 'U' 0 lo;
- 'U' 4 hi;
- };
- };
- defn
- FPdbleword(addr) {
- complex FPdbleword addr;
- print(" x ", addr.x, "\n");
- print("_1_ {\n");
- _1_(addr+0);
- print("}\n");
- };
- UTFmax = 4;
- Runesync = 128;
- Runeself = 128;
- Runeerror = 65533;
- Runemax = 1114111;
- Runemask = 2097151;
- sizeofFmt = 48;
- aggr Fmt
- {
- 'b' 0 runes;
- 'X' 4 start;
- 'X' 8 to;
- 'X' 12 stop;
- 'X' 16 flush;
- 'X' 20 farg;
- 'D' 24 nfmt;
- 'X' 28 args;
- 'D' 32 r;
- 'D' 36 width;
- 'D' 40 prec;
- 'U' 44 flags;
- };
- defn
- Fmt(addr) {
- complex Fmt addr;
- print(" runes ", addr.runes, "\n");
- print(" start ", addr.start\X, "\n");
- print(" to ", addr.to\X, "\n");
- print(" stop ", addr.stop\X, "\n");
- print(" flush ", addr.flush\X, "\n");
- print(" farg ", addr.farg\X, "\n");
- print(" nfmt ", addr.nfmt, "\n");
- print(" args ", addr.args\X, "\n");
- print(" r ", addr.r, "\n");
- print(" width ", addr.width, "\n");
- print(" prec ", addr.prec, "\n");
- print(" flags ", addr.flags, "\n");
- };
- FmtWidth = 1;
- FmtLeft = 2;
- FmtPrec = 4;
- FmtSharp = 8;
- FmtSpace = 16;
- FmtSign = 32;
- FmtZero = 64;
- FmtUnsigned = 128;
- FmtShort = 256;
- FmtLong = 512;
- FmtVLong = 1024;
- FmtComma = 2048;
- FmtByte = 4096;
- FmtFlag = 8192;
- sizeofTm = 40;
- aggr Tm
- {
- 'D' 0 sec;
- 'D' 4 min;
- 'D' 8 hour;
- 'D' 12 mday;
- 'D' 16 mon;
- 'D' 20 year;
- 'D' 24 wday;
- 'D' 28 yday;
- 'a' 32 zone;
- 'D' 36 tzoff;
- };
- defn
- Tm(addr) {
- complex Tm addr;
- print(" sec ", addr.sec, "\n");
- print(" min ", addr.min, "\n");
- print(" hour ", addr.hour, "\n");
- print(" mday ", addr.mday, "\n");
- print(" mon ", addr.mon, "\n");
- print(" year ", addr.year, "\n");
- print(" wday ", addr.wday, "\n");
- print(" yday ", addr.yday, "\n");
- print(" zone ", addr.zone, "\n");
- print(" tzoff ", addr.tzoff, "\n");
- };
- PNPROC = 1;
- PNGROUP = 2;
- Profoff = 0;
- Profuser = 1;
- Profkernel = 2;
- Proftime = 3;
- Profsample = 4;
- sizeofLock = 8;
- aggr Lock
- {
- 'D' 0 key;
- 'D' 4 sem;
- };
- defn
- Lock(addr) {
- complex Lock addr;
- print(" key ", addr.key, "\n");
- print(" sem ", addr.sem, "\n");
- };
- sizeofQLp = 12;
- aggr QLp
- {
- 'D' 0 inuse;
- 'A' QLp 4 next;
- 'C' 8 state;
- };
- defn
- QLp(addr) {
- complex QLp addr;
- print(" inuse ", addr.inuse, "\n");
- print(" next ", addr.next\X, "\n");
- print(" state ", addr.state, "\n");
- };
- sizeofQLock = 20;
- aggr QLock
- {
- Lock 0 lock;
- 'D' 8 locked;
- 'A' QLp 12 $head;
- 'A' QLp 16 $tail;
- };
- defn
- QLock(addr) {
- complex QLock addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" locked ", addr.locked, "\n");
- print(" $head ", addr.$head\X, "\n");
- print(" $tail ", addr.$tail\X, "\n");
- };
- sizeofRWLock = 24;
- aggr RWLock
- {
- Lock 0 lock;
- 'D' 8 readers;
- 'D' 12 writer;
- 'A' QLp 16 $head;
- 'A' QLp 20 $tail;
- };
- defn
- RWLock(addr) {
- complex RWLock addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" readers ", addr.readers, "\n");
- print(" writer ", addr.writer, "\n");
- print(" $head ", addr.$head\X, "\n");
- print(" $tail ", addr.$tail\X, "\n");
- };
- sizeofRendez = 12;
- aggr Rendez
- {
- 'A' QLock 0 l;
- 'A' QLp 4 $head;
- 'A' QLp 8 $tail;
- };
- defn
- Rendez(addr) {
- complex Rendez addr;
- print(" l ", addr.l\X, "\n");
- print(" $head ", addr.$head\X, "\n");
- print(" $tail ", addr.$tail\X, "\n");
- };
- sizeofNetConnInfo = 36;
- aggr NetConnInfo
- {
- 'X' 0 dir;
- 'X' 4 root;
- 'X' 8 spec;
- 'X' 12 lsys;
- 'X' 16 lserv;
- 'X' 20 rsys;
- 'X' 24 rserv;
- 'X' 28 laddr;
- 'X' 32 raddr;
- };
- defn
- NetConnInfo(addr) {
- complex NetConnInfo addr;
- print(" dir ", addr.dir\X, "\n");
- print(" root ", addr.root\X, "\n");
- print(" spec ", addr.spec\X, "\n");
- print(" lsys ", addr.lsys\X, "\n");
- print(" lserv ", addr.lserv\X, "\n");
- print(" rsys ", addr.rsys\X, "\n");
- print(" rserv ", addr.rserv\X, "\n");
- print(" laddr ", addr.laddr\X, "\n");
- print(" raddr ", addr.raddr\X, "\n");
- };
- RFNAMEG = 1;
- RFENVG = 2;
- RFFDG = 4;
- RFNOTEG = 8;
- RFPROC = 16;
- RFMEM = 32;
- RFNOWAIT = 64;
- RFCNAMEG = 1024;
- RFCENVG = 2048;
- RFCFDG = 4096;
- RFREND = 8192;
- RFNOMNT = 16384;
- sizeofQid = 16;
- aggr Qid
- {
- 'W' 0 path;
- 'U' 8 vers;
- 'b' 12 type;
- };
- defn
- Qid(addr) {
- complex Qid addr;
- print(" path ", addr.path, "\n");
- print(" vers ", addr.vers, "\n");
- print(" type ", addr.type, "\n");
- };
- sizeofDir = 60;
- aggr Dir
- {
- 'u' 0 type;
- 'U' 4 dev;
- Qid 8 qid;
- 'U' 24 mode;
- 'U' 28 atime;
- 'U' 32 mtime;
- 'V' 36 length;
- 'X' 44 name;
- 'X' 48 uid;
- 'X' 52 gid;
- 'X' 56 muid;
- };
- defn
- Dir(addr) {
- complex Dir addr;
- print(" type ", addr.type, "\n");
- print(" dev ", addr.dev, "\n");
- print("Qid qid {\n");
- Qid(addr.qid);
- print("}\n");
- print(" mode ", addr.mode, "\n");
- print(" atime ", addr.atime, "\n");
- print(" mtime ", addr.mtime, "\n");
- print(" length ", addr.length, "\n");
- print(" name ", addr.name\X, "\n");
- print(" uid ", addr.uid\X, "\n");
- print(" gid ", addr.gid\X, "\n");
- print(" muid ", addr.muid\X, "\n");
- };
- sizeofWaitmsg = 20;
- aggr Waitmsg
- {
- 'D' 0 pid;
- 'a' 4 time;
- 'X' 16 msg;
- };
- defn
- Waitmsg(addr) {
- complex Waitmsg addr;
- print(" pid ", addr.pid, "\n");
- print(" time ", addr.time, "\n");
- print(" msg ", addr.msg\X, "\n");
- };
- sizeofIOchunk = 8;
- aggr IOchunk
- {
- 'X' 0 addr;
- 'U' 4 len;
- };
- defn
- IOchunk(addr) {
- complex IOchunk addr;
- print(" addr ", addr.addr\X, "\n");
- print(" len ", addr.len, "\n");
- };
- Nqwds = 2;
- Nqshift = 5;
- Nqmask = -1;
- Nqbits = 64;
- sizeofChannel = 36;
- aggr Channel
- {
- 'D' 0 s;
- 'U' 4 f;
- 'U' 8 n;
- 'D' 12 e;
- 'D' 16 freed;
- 'X' 20 qentry;
- 'D' 24 nentry;
- 'D' 28 closed;
- 'a' 32 v;
- };
- defn
- Channel(addr) {
- complex Channel addr;
- print(" s ", addr.s, "\n");
- print(" f ", addr.f, "\n");
- print(" n ", addr.n, "\n");
- print(" e ", addr.e, "\n");
- print(" freed ", addr.freed, "\n");
- print(" qentry ", addr.qentry\X, "\n");
- print(" nentry ", addr.nentry, "\n");
- print(" closed ", addr.closed, "\n");
- print(" v ", addr.v, "\n");
- };
- CHANEND = 0;
- CHANSND = 1;
- CHANRCV = 2;
- CHANNOP = 3;
- CHANNOBLK = 4;
- sizeofAlt = 24;
- aggr Alt
- {
- 'A' Channel 0 c;
- 'X' 4 v;
- 'D' 8 op;
- 'X' 12 err;
- 'A' Channel 16 tag;
- 'D' 20 entryno;
- };
- defn
- Alt(addr) {
- complex Alt addr;
- print(" c ", addr.c\X, "\n");
- print(" v ", addr.v\X, "\n");
- print(" op ", addr.op, "\n");
- print(" err ", addr.err\X, "\n");
- print(" tag ", addr.tag\X, "\n");
- print(" entryno ", addr.entryno, "\n");
- };
- sizeofRef = 4;
- aggr Ref
- {
- 'D' 0 ref;
- };
- defn
- Ref(addr) {
- complex Ref addr;
- print(" ref ", addr.ref, "\n");
- };
- Dead = 0;
- Running = 1;
- Ready = 2;
- Rendezvous = 3;
- Channone = 0;
- Chanalt = 1;
- Chansend = 2;
- Chanrecv = 3;
- RENDHASH = 13;
- Printsize = 2048;
- NPRIV = 8;
- sizeofRgrp = 60;
- aggr Rgrp
- {
- Lock 0 lock;
- 'a' 8 hash;
- };
- defn
- Rgrp(addr) {
- complex Rgrp addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" hash ", addr.hash, "\n");
- };
- sizeofTqueue = 12;
- aggr Tqueue
- {
- 'D' 0 asleep;
- 'X' 4 $head;
- 'X' 8 $tail;
- };
- defn
- Tqueue(addr) {
- complex Tqueue addr;
- print(" asleep ", addr.asleep, "\n");
- print(" $head ", addr.$head\X, "\n");
- print(" $tail ", addr.$tail\X, "\n");
- };
- sizeofThread = 124;
- aggr Thread
- {
- Lock 0 lock;
- 'a' 8 sched;
- 'D' 16 id;
- 'D' 20 grp;
- 'D' 24 moribund;
- 'D' 28 state;
- 'D' 32 nextstate;
- 'X' 36 stk;
- 'U' 40 stksize;
- 'A' Thread 44 next;
- 'X' 48 proc;
- 'A' Thread 52 nextt;
- 'D' 56 ret;
- 'X' 60 cmdname;
- 'D' 64 inrendez;
- 'A' Thread 68 rendhash;
- 'X' 72 rendtag;
- 'X' 76 rendval;
- 'D' 80 rendbreak;
- 'D' 84 chan;
- 'A' Alt 88 alt;
- 'a' 92 udata;
- };
- defn
- Thread(addr) {
- complex Thread addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" sched ", addr.sched, "\n");
- print(" id ", addr.id, "\n");
- print(" grp ", addr.grp, "\n");
- print(" moribund ", addr.moribund, "\n");
- print(" state ", addr.state, "\n");
- print(" nextstate ", addr.nextstate, "\n");
- print(" stk ", addr.stk\X, "\n");
- print(" stksize ", addr.stksize, "\n");
- print(" next ", addr.next\X, "\n");
- print(" proc ", addr.proc\X, "\n");
- print(" nextt ", addr.nextt\X, "\n");
- print(" ret ", addr.ret, "\n");
- print(" cmdname ", addr.cmdname\X, "\n");
- print(" inrendez ", addr.inrendez, "\n");
- print(" rendhash ", addr.rendhash\X, "\n");
- print(" rendtag ", addr.rendtag\X, "\n");
- print(" rendval ", addr.rendval\X, "\n");
- print(" rendbreak ", addr.rendbreak, "\n");
- print(" chan ", addr.chan, "\n");
- print(" alt ", addr.alt\X, "\n");
- print(" udata ", addr.udata, "\n");
- };
- sizeofExecargs = 16;
- aggr Execargs
- {
- 'X' 0 prog;
- 'X' 4 args;
- 'a' 8 fd;
- };
- defn
- Execargs(addr) {
- complex Execargs addr;
- print(" prog ", addr.prog\X, "\n");
- print(" args ", addr.args\X, "\n");
- print(" fd ", addr.fd, "\n");
- };
- sizeofProc = 2432;
- aggr Proc
- {
- Lock 0 lock;
- 'a' 8 sched;
- 'D' 16 pid;
- 'D' 20 splhi;
- 'A' Thread 24 thread;
- 'D' 28 needexec;
- Execargs 32 exec;
- 'A' Proc 48 newproc;
- 'a' 52 exitstr;
- 'D' 180 rforkflag;
- 'D' 184 nthreads;
- Tqueue 188 threads;
- Tqueue 200 ready;
- Lock 212 readylock;
- 'a' 220 printbuf;
- 'D' 2268 blocked;
- 'D' 2272 pending;
- 'D' 2276 nonotes;
- 'U' 2280 nextID;
- 'A' Proc 2284 next;
- 'X' 2288 arg;
- 'a' 2292 str;
- 'X' 2420 wdata;
- 'X' 2424 udata;
- 'C' 2428 threadint;
- };
- defn
- Proc(addr) {
- complex Proc addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" sched ", addr.sched, "\n");
- print(" pid ", addr.pid, "\n");
- print(" splhi ", addr.splhi, "\n");
- print(" thread ", addr.thread\X, "\n");
- print(" needexec ", addr.needexec, "\n");
- print("Execargs exec {\n");
- Execargs(addr.exec);
- print("}\n");
- print(" newproc ", addr.newproc\X, "\n");
- print(" exitstr ", addr.exitstr, "\n");
- print(" rforkflag ", addr.rforkflag, "\n");
- print(" nthreads ", addr.nthreads, "\n");
- print("Tqueue threads {\n");
- Tqueue(addr.threads);
- print("}\n");
- print("Tqueue ready {\n");
- Tqueue(addr.ready);
- print("}\n");
- print("Lock readylock {\n");
- Lock(addr.readylock);
- print("}\n");
- print(" printbuf ", addr.printbuf, "\n");
- print(" blocked ", addr.blocked, "\n");
- print(" pending ", addr.pending, "\n");
- print(" nonotes ", addr.nonotes, "\n");
- print(" nextID ", addr.nextID, "\n");
- print(" next ", addr.next\X, "\n");
- print(" arg ", addr.arg\X, "\n");
- print(" str ", addr.str, "\n");
- print(" wdata ", addr.wdata\X, "\n");
- print(" udata ", addr.udata\X, "\n");
- print(" threadint ", addr.threadint, "\n");
- };
- sizeofPqueue = 16;
- aggr Pqueue
- {
- Lock 0 lock;
- 'A' Proc 8 $head;
- 'A' Proc 12 $tail;
- };
- defn
- Pqueue(addr) {
- complex Pqueue addr;
- print("Lock lock {\n");
- Lock(addr.lock);
- print("}\n");
- print(" $head ", addr.$head\X, "\n");
- print(" $tail ", addr.$tail\X, "\n");
- };
- sizeofIoproc = 160;
- aggr Ioproc
- {
- 'D' 0 tid;
- 'A' Channel 4 c;
- 'A' Channel 8 creply;
- 'D' 12 inuse;
- 'X' 16 op;
- 'X' 20 arg;
- 'D' 24 ret;
- 'a' 28 err;
- 'A' Ioproc 156 next;
- };
- defn
- Ioproc(addr) {
- complex Ioproc addr;
- print(" tid ", addr.tid, "\n");
- print(" c ", addr.c\X, "\n");
- print(" creply ", addr.creply\X, "\n");
- print(" inuse ", addr.inuse, "\n");
- print(" op ", addr.op\X, "\n");
- print(" arg ", addr.arg\X, "\n");
- print(" ret ", addr.ret, "\n");
- print(" err ", addr.err, "\n");
- print(" next ", addr.next\X, "\n");
- };
- complex Pqueue _threadpq;
- complex Channel _threadwaitchan;
- complex Rgrp _threadrgrp;
- sizeof_2_ = 24;
- aggr _2_
- {
- 'X' 0 pp;
- 'X' 4 next;
- 'X' 8 last;
- 'X' 12 first;
- 'U' 16 pid;
- 'U' 20 what;
- };
- defn
- _2_(addr) {
- complex _2_ addr;
- print(" pp ", addr.pp\X, "\n");
- print(" next ", addr.next\X, "\n");
- print(" last ", addr.last\X, "\n");
- print(" first ", addr.first\X, "\n");
- print(" pid ", addr.pid, "\n");
- print(" what ", addr.what, "\n");
- };
- sizeofTos = 72;
- aggr Tos
- {
- _2_ 0 prof;
- 'W' 24 cyclefreq;
- 'V' 32 kcycles;
- 'V' 40 pcycles;
- 'U' 48 pid;
- 'U' 52 clock;
- 'a' 56 kscr;
- };
- defn
- Tos(addr) {
- complex Tos addr;
- print("_2_ prof {\n");
- _2_(addr.prof);
- print("}\n");
- print(" cyclefreq ", addr.cyclefreq, "\n");
- print(" kcycles ", addr.kcycles, "\n");
- print(" pcycles ", addr.pcycles, "\n");
- print(" pid ", addr.pid, "\n");
- print(" clock ", addr.clock, "\n");
- print(" kscr ", addr.kscr, "\n");
- };
- complex Tos _tos;
- complex Proc _schedinit:p;
- complex Thread _schedinit:t;
- complex Thread _schedinit:l;
- complex Proc needstack:p;
- complex Thread needstack:t;
- complex Proc _sched:p;
- complex Thread _sched:t;
- complex Proc runthread:p;
- complex Thread runthread:t;
- complex Tqueue runthread:q;
- complex Thread _threadready:t;
- complex Tqueue _threadready:q;
|