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 = 4; aggr Lock { 'D' 0 val; }; defn Lock(addr) { complex Lock addr; print(" val ", addr.val, "\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 = 16; aggr QLock { Lock 0 lock; 'D' 4 locked; 'A' QLp 8 $head; 'A' QLp 12 $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 = 20; aggr RWLock { Lock 0 lock; 'D' 4 readers; 'D' 8 writer; 'A' QLp 12 $head; 'A' QLp 16 $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; 'X' 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\X, "\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"); }; sizeofCHAN UINT = 44; aggr CHAN UINT { { 'D' 0 s; 'U' 4 f; 'U' 8 n; 'D' 12 e; 'D' 16 freed; 'X' 20 qentry; 'D' 24 nentry; 'D' 28 closed; 'X' 32 v; }; 'U' 36 @in; 'U' 40 @out; }; defn CHAN UINT(addr) { complex CHAN UINT addr; print("Channel {\n"); Channel(addr+0); print("}\n"); print(" @in ", addr.@in, "\n"); print(" @out ", addr.@out, "\n"); }; sizeofKeyboardctl = 20; aggr Keyboardctl { 'A' CHAN UINT 0 c; 'X' 4 file; 'D' 8 consfd; 'D' 12 ctlfd; 'D' 16 pid; }; defn Keyboardctl(addr) { complex Keyboardctl addr; print(" c ", addr.c\X, "\n"); print(" file ", addr.file\X, "\n"); print(" consfd ", addr.consfd, "\n"); print(" ctlfd ", addr.ctlfd, "\n"); print(" pid ", addr.pid, "\n"); }; sizeofCHAN IND STRUCT Waitmsg = 44; aggr CHAN IND STRUCT Waitmsg { { 'D' 0 s; 'U' 4 f; 'U' 8 n; 'D' 12 e; 'D' 16 freed; 'X' 20 qentry; 'D' 24 nentry; 'D' 28 closed; 'X' 32 v; }; 'A' Waitmsg 36 @in; 'A' Waitmsg 40 @out; }; defn CHAN IND STRUCT Waitmsg(addr) { complex CHAN IND STRUCT Waitmsg addr; print("Channel {\n"); Channel(addr+0); print("}\n"); print(" @in ", addr.@in\X, "\n"); print(" @out ", addr.@out\X, "\n"); }; Dead = 0; Running = 1; Ready = 2; Rendezvous = 3; Channone = 0; Chanalt = 1; Chansend = 2; Chanrecv = 3; RENDHASH = 13; Printsize = 2048; sizeofRgrp = 56; aggr Rgrp { Lock 0 lock; 'a' 4 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 = 92; aggr Thread { Lock 0 lock; 'a' 4 sched; 'D' 12 id; 'D' 16 grp; 'D' 20 moribund; 'D' 24 state; 'D' 28 nextstate; 'X' 32 stk; 'U' 36 stksize; 'A' Thread 40 next; 'X' 44 proc; 'A' Thread 48 nextt; 'D' 52 ret; 'X' 56 cmdname; 'D' 60 inrendez; 'A' Thread 64 rendhash; 'X' 68 rendtag; 'X' 72 rendval; 'D' 76 rendbreak; 'D' 80 chan; 'A' Alt 84 alts; 'X' 88 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(" alts ", addr.alts\X, "\n"); print(" udata ", addr.udata\X, "\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 = 2420; aggr Proc { Lock 0 lock; 'a' 4 sched; 'D' 12 pid; 'D' 16 splhi; 'A' Thread 20 thread; 'D' 24 needexec; Execargs 28 exec; 'A' Proc 44 newproc; 'a' 48 exitstr; 'D' 176 rforkflag; 'D' 180 nthreads; Tqueue 184 threads; Tqueue 196 ready; Lock 208 readylock; 'a' 212 printbuf; 'D' 2260 blocked; 'D' 2264 pending; 'D' 2268 nonotes; 'U' 2272 nextID; 'A' Proc 2276 next; 'X' 2280 arg; 'a' 2284 str; 'X' 2412 udata; 'C' 2416 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(" udata ", addr.udata\X, "\n"); print(" threadint ", addr.threadint, "\n"); }; sizeofPqueue = 12; aggr Pqueue { Lock 0 lock; 'A' Proc 4 $head; 'A' Proc 8 $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 = 32; aggr Ioproc { { Lock 0 lock; 'D' 4 locked; 'A' QLp 8 $head; 'A' QLp 12 $tail; }; 'D' 16 intr; 'D' 20 ctl; 'A' Channel 24 c; 'A' Channel 28 creply; }; defn Ioproc(addr) { complex Ioproc addr; print("QLock {\n"); QLock(addr+0); print("}\n"); print(" intr ", addr.intr, "\n"); print(" ctl ", addr.ctl, "\n"); print(" c ", addr.c\X, "\n"); print(" creply ", addr.creply\X, "\n"); }; sizeofIocall = 140; aggr Iocall { 'X' 0 op; 'X' 4 arg; 'D' 8 ret; 'a' 12 err; }; defn Iocall(addr) { complex Iocall addr; print(" op ", addr.op\X, "\n"); print(" arg ", addr.arg\X, "\n"); print(" ret ", addr.ret, "\n"); print(" err ", addr.err, "\n"); }; complex Pqueue _threadpq; complex CHAN IND STRUCT Waitmsg _threadwaitchan; complex Rgrp _threadrgrp; CHANCLOSD = 12649965; complex Lock chanlock; complex Channel _chanfree:c; complex Channel chanfree:c; complex Channel rtchancreate:c; complex Channel chancreate:c; complex Channel isopenfor:c; complex Alt doalt:alts; complex Alt doalt:a; complex Alt doalt:xa; complex Alt doalt:ca; complex Channel doalt:c; complex Thread doalt:t; complex Channel chanclose:c; complex Alt chanclose:a; complex Channel chanclosing:c; complex Channel runop:c; complex Channel recv:c; complex Channel nbrecv:c; complex Channel send:c; complex Channel nbsend:c; complex Channel channelsize:c; complex Channel sendul:c; complex Channel recvul:c; complex Channel sendp:c; complex Channel recvp:c; complex Channel nbsendul:c; complex Channel nbrecvul:c; complex Channel nbsendp:c; complex Channel nbrecvp:c; complex Channel emptyentry:c; complex Alt enqueue:a; complex Channel enqueue:c; complex Alt dequeue:a; complex Channel dequeue:c; complex Alt canexec:a; complex Channel canexec:c; complex Alt altexecbuffered:a; complex Channel altexecbuffered:c; complex Alt altexec:a; complex Alt altexec:b; complex Channel altexec:c;