1sizeof_1_ = 8; 2aggr _1_ 3{ 4 'U' 0 lo; 5 'U' 4 hi; 6}; 7 8defn 9_1_(addr) { 10 complex _1_ addr; 11 print(" lo ", addr.lo, "\n"); 12 print(" hi ", addr.hi, "\n"); 13}; 14 15sizeofFPdbleword = 8; 16aggr FPdbleword 17{ 18 'F' 0 x; 19 { 20 'U' 0 lo; 21 'U' 4 hi; 22 }; 23}; 24 25defn 26FPdbleword(addr) { 27 complex FPdbleword addr; 28 print(" x ", addr.x, "\n"); 29 print("_1_ {\n"); 30 _1_(addr+0); 31 print("}\n"); 32}; 33 34UTFmax = 3; 35Runesync = 128; 36Runeself = 128; 37Runeerror = 128; 38sizeofFmt = 48; 39aggr Fmt 40{ 41 'b' 0 runes; 42 'X' 4 start; 43 'X' 8 to; 44 'X' 12 stop; 45 'X' 16 flush; 46 'X' 20 farg; 47 'D' 24 nfmt; 48 'X' 28 args; 49 'D' 32 r; 50 'D' 36 width; 51 'D' 40 prec; 52 'U' 44 flags; 53}; 54 55defn 56Fmt(addr) { 57 complex Fmt addr; 58 print(" runes ", addr.runes, "\n"); 59 print(" start ", addr.start\X, "\n"); 60 print(" to ", addr.to\X, "\n"); 61 print(" stop ", addr.stop\X, "\n"); 62 print(" flush ", addr.flush\X, "\n"); 63 print(" farg ", addr.farg\X, "\n"); 64 print(" nfmt ", addr.nfmt, "\n"); 65 print(" args ", addr.args\X, "\n"); 66 print(" r ", addr.r, "\n"); 67 print(" width ", addr.width, "\n"); 68 print(" prec ", addr.prec, "\n"); 69 print(" flags ", addr.flags, "\n"); 70}; 71 72FmtWidth = 1; 73FmtLeft = 2; 74FmtPrec = 4; 75FmtSharp = 8; 76FmtSpace = 16; 77FmtSign = 32; 78FmtZero = 64; 79FmtUnsigned = 128; 80FmtShort = 256; 81FmtLong = 512; 82FmtVLong = 1024; 83FmtComma = 2048; 84FmtByte = 4096; 85FmtFlag = 8192; 86sizeofTm = 40; 87aggr Tm 88{ 89 'D' 0 sec; 90 'D' 4 min; 91 'D' 8 hour; 92 'D' 12 mday; 93 'D' 16 mon; 94 'D' 20 year; 95 'D' 24 wday; 96 'D' 28 yday; 97 'a' 32 zone; 98 'D' 36 tzoff; 99}; 100 101defn 102Tm(addr) { 103 complex Tm addr; 104 print(" sec ", addr.sec, "\n"); 105 print(" min ", addr.min, "\n"); 106 print(" hour ", addr.hour, "\n"); 107 print(" mday ", addr.mday, "\n"); 108 print(" mon ", addr.mon, "\n"); 109 print(" year ", addr.year, "\n"); 110 print(" wday ", addr.wday, "\n"); 111 print(" yday ", addr.yday, "\n"); 112 print(" zone ", addr.zone, "\n"); 113 print(" tzoff ", addr.tzoff, "\n"); 114}; 115 116PNPROC = 1; 117PNGROUP = 2; 118sizeofLock = 4; 119aggr Lock 120{ 121 'D' 0 val; 122}; 123 124defn 125Lock(addr) { 126 complex Lock addr; 127 print(" val ", addr.val, "\n"); 128}; 129 130sizeofQLp = 12; 131aggr QLp 132{ 133 'D' 0 inuse; 134 'A' QLp 4 next; 135 'C' 8 state; 136}; 137 138defn 139QLp(addr) { 140 complex QLp addr; 141 print(" inuse ", addr.inuse, "\n"); 142 print(" next ", addr.next\X, "\n"); 143 print(" state ", addr.state, "\n"); 144}; 145 146sizeofQLock = 16; 147aggr QLock 148{ 149 Lock 0 lock; 150 'D' 4 locked; 151 'A' QLp 8 $head; 152 'A' QLp 12 $tail; 153}; 154 155defn 156QLock(addr) { 157 complex QLock addr; 158 print("Lock lock {\n"); 159 Lock(addr.lock); 160 print("}\n"); 161 print(" locked ", addr.locked, "\n"); 162 print(" $head ", addr.$head\X, "\n"); 163 print(" $tail ", addr.$tail\X, "\n"); 164}; 165 166sizeofRWLock = 20; 167aggr RWLock 168{ 169 Lock 0 lock; 170 'D' 4 readers; 171 'D' 8 writer; 172 'A' QLp 12 $head; 173 'A' QLp 16 $tail; 174}; 175 176defn 177RWLock(addr) { 178 complex RWLock addr; 179 print("Lock lock {\n"); 180 Lock(addr.lock); 181 print("}\n"); 182 print(" readers ", addr.readers, "\n"); 183 print(" writer ", addr.writer, "\n"); 184 print(" $head ", addr.$head\X, "\n"); 185 print(" $tail ", addr.$tail\X, "\n"); 186}; 187 188sizeofRendez = 12; 189aggr Rendez 190{ 191 'A' QLock 0 l; 192 'A' QLp 4 $head; 193 'A' QLp 8 $tail; 194}; 195 196defn 197Rendez(addr) { 198 complex Rendez addr; 199 print(" l ", addr.l\X, "\n"); 200 print(" $head ", addr.$head\X, "\n"); 201 print(" $tail ", addr.$tail\X, "\n"); 202}; 203 204sizeofNetConnInfo = 28; 205aggr NetConnInfo 206{ 207 'X' 0 dir; 208 'X' 4 root; 209 'X' 8 spec; 210 'X' 12 lsys; 211 'X' 16 lserv; 212 'X' 20 rsys; 213 'X' 24 rserv; 214}; 215 216defn 217NetConnInfo(addr) { 218 complex NetConnInfo addr; 219 print(" dir ", addr.dir\X, "\n"); 220 print(" root ", addr.root\X, "\n"); 221 print(" spec ", addr.spec\X, "\n"); 222 print(" lsys ", addr.lsys\X, "\n"); 223 print(" lserv ", addr.lserv\X, "\n"); 224 print(" rsys ", addr.rsys\X, "\n"); 225 print(" rserv ", addr.rserv\X, "\n"); 226}; 227 228RFNAMEG = 1; 229RFENVG = 2; 230RFFDG = 4; 231RFNOTEG = 8; 232RFPROC = 16; 233RFMEM = 32; 234RFNOWAIT = 64; 235RFCNAMEG = 1024; 236RFCENVG = 2048; 237RFCFDG = 4096; 238RFREND = 8192; 239RFNOMNT = 16384; 240sizeofQid = 16; 241aggr Qid 242{ 243 'W' 0 path; 244 'U' 8 vers; 245 'b' 12 type; 246}; 247 248defn 249Qid(addr) { 250 complex Qid addr; 251 print(" path ", addr.path, "\n"); 252 print(" vers ", addr.vers, "\n"); 253 print(" type ", addr.type, "\n"); 254}; 255 256sizeofDir = 60; 257aggr Dir 258{ 259 'u' 0 type; 260 'U' 4 dev; 261 Qid 8 qid; 262 'U' 24 mode; 263 'U' 28 atime; 264 'U' 32 mtime; 265 'V' 36 length; 266 'X' 44 name; 267 'X' 48 uid; 268 'X' 52 gid; 269 'X' 56 muid; 270}; 271 272defn 273Dir(addr) { 274 complex Dir addr; 275 print(" type ", addr.type, "\n"); 276 print(" dev ", addr.dev, "\n"); 277 print("Qid qid {\n"); 278 Qid(addr.qid); 279 print("}\n"); 280 print(" mode ", addr.mode, "\n"); 281 print(" atime ", addr.atime, "\n"); 282 print(" mtime ", addr.mtime, "\n"); 283 print(" length ", addr.length, "\n"); 284 print(" name ", addr.name\X, "\n"); 285 print(" uid ", addr.uid\X, "\n"); 286 print(" gid ", addr.gid\X, "\n"); 287 print(" muid ", addr.muid\X, "\n"); 288}; 289 290sizeofWaitmsg = 20; 291aggr Waitmsg 292{ 293 'D' 0 pid; 294 'a' 4 time; 295 'X' 16 msg; 296}; 297 298defn 299Waitmsg(addr) { 300 complex Waitmsg addr; 301 print(" pid ", addr.pid, "\n"); 302 print(" time ", addr.time, "\n"); 303 print(" msg ", addr.msg\X, "\n"); 304}; 305 306sizeofIOchunk = 8; 307aggr IOchunk 308{ 309 'X' 0 addr; 310 'U' 4 len; 311}; 312 313defn 314IOchunk(addr) { 315 complex IOchunk addr; 316 print(" addr ", addr.addr\X, "\n"); 317 print(" len ", addr.len, "\n"); 318}; 319 320MaxFragSize = 9216; 321VtScoreSize = 20; 322VtMaxStringSize = 1024; 323VtMaxFileSize = 281474976710655; 324VtMaxLumpSize = 57344; 325VtPointerDepth = 7; 326VtDataType = 0; 327VtDirType = 8; 328VtRootType = 16; 329VtMaxType = 17; 330VtTypeDepthMask = 7; 331VtEntryActive = 1; 332VtEntryDir = 2; 333VtEntryDepthShift = 2; 334VtEntryDepthMask = 28; 335VtEntryLocal = 32; 336VtEntrySize = 40; 337sizeofVtEntry = 40; 338aggr VtEntry 339{ 340 'U' 0 gen; 341 'u' 4 psize; 342 'u' 6 dsize; 343 'b' 8 type; 344 'b' 9 flags; 345 'W' 12 size; 346 'a' 20 score; 347}; 348 349defn 350VtEntry(addr) { 351 complex VtEntry addr; 352 print(" gen ", addr.gen, "\n"); 353 print(" psize ", addr.psize, "\n"); 354 print(" dsize ", addr.dsize, "\n"); 355 print(" type ", addr.type, "\n"); 356 print(" flags ", addr.flags, "\n"); 357 print(" size ", addr.size, "\n"); 358 print(" score ", addr.score, "\n"); 359}; 360 361sizeofVtRoot = 300; 362aggr VtRoot 363{ 364 'a' 0 name; 365 'a' 128 type; 366 'a' 256 score; 367 'u' 276 blocksize; 368 'a' 278 prev; 369}; 370 371defn 372VtRoot(addr) { 373 complex VtRoot addr; 374 print(" name ", addr.name, "\n"); 375 print(" type ", addr.type, "\n"); 376 print(" score ", addr.score, "\n"); 377 print(" blocksize ", addr.blocksize, "\n"); 378 print(" prev ", addr.prev, "\n"); 379}; 380 381VtRootSize = 300; 382VtRootVersion = 2; 383VtCryptoStrengthNone = 0; 384VtCryptoStrengthAuth = 1; 385VtCryptoStrengthWeak = 2; 386VtCryptoStrengthStrong = 3; 387VtCryptoNone = 0; 388VtCryptoSSL3 = 1; 389VtCryptoTLS1 = 2; 390VtCryptoMax = 3; 391VtCodecNone = 0; 392VtCodecDeflate = 1; 393VtCodecThwack = 2; 394VtCodecMax = 3; 395VtRerror = 1; 396VtTping = 2; 397VtRping = 3; 398VtThello = 4; 399VtRhello = 5; 400VtTgoodbye = 6; 401VtRgoodbye = 7; 402VtTauth0 = 8; 403VtRauth0 = 9; 404VtTauth1 = 10; 405VtRauth1 = 11; 406VtTread = 12; 407VtRread = 13; 408VtTwrite = 14; 409VtRwrite = 15; 410VtTsync = 16; 411VtRsync = 17; 412VtTmax = 18; 413sizeofVtFcall = 80; 414aggr VtFcall 415{ 416 'b' 0 type; 417 'b' 1 tag; 418 'X' 4 error; 419 'X' 8 version; 420 'X' 12 uid; 421 'b' 16 strength; 422 'X' 20 crypto; 423 'U' 24 ncrypto; 424 'X' 28 codec; 425 'U' 32 ncodec; 426 'X' 36 sid; 427 'b' 40 rcrypto; 428 'b' 41 rcodec; 429 'X' 44 auth; 430 'U' 48 nauth; 431 'a' 52 score; 432 'b' 72 dtype; 433 'u' 74 count; 434 'X' 76 data; 435}; 436 437defn 438VtFcall(addr) { 439 complex VtFcall addr; 440 print(" type ", addr.type, "\n"); 441 print(" tag ", addr.tag, "\n"); 442 print(" error ", addr.error\X, "\n"); 443 print(" version ", addr.version\X, "\n"); 444 print(" uid ", addr.uid\X, "\n"); 445 print(" strength ", addr.strength, "\n"); 446 print(" crypto ", addr.crypto\X, "\n"); 447 print(" ncrypto ", addr.ncrypto, "\n"); 448 print(" codec ", addr.codec\X, "\n"); 449 print(" ncodec ", addr.ncodec, "\n"); 450 print(" sid ", addr.sid\X, "\n"); 451 print(" rcrypto ", addr.rcrypto, "\n"); 452 print(" rcodec ", addr.rcodec, "\n"); 453 print(" auth ", addr.auth\X, "\n"); 454 print(" nauth ", addr.nauth, "\n"); 455 print(" score ", addr.score, "\n"); 456 print(" dtype ", addr.dtype, "\n"); 457 print(" count ", addr.count, "\n"); 458 print(" data ", addr.data\X, "\n"); 459}; 460 461VtStateAlloc = 0; 462VtStateConnected = 1; 463VtStateClosed = 2; 464sizeofVtConn = 1148; 465aggr VtConn 466{ 467 QLock 0 lk; 468 QLock 16 inlk; 469 QLock 32 outlk; 470 'D' 48 debug; 471 'D' 52 infd; 472 'D' 56 outfd; 473 'D' 60 muxer; 474 'X' 64 writeq; 475 'X' 68 readq; 476 'D' 72 state; 477 'a' 76 wait; 478 'U' 1100 ntag; 479 'U' 1104 nsleep; 480 'X' 1108 part; 481 Rendez 1112 tagrend; 482 Rendez 1124 rpcfork; 483 'X' 1136 version; 484 'X' 1140 uid; 485 'X' 1144 sid; 486}; 487 488defn 489VtConn(addr) { 490 complex VtConn addr; 491 print("QLock lk {\n"); 492 QLock(addr.lk); 493 print("}\n"); 494 print("QLock inlk {\n"); 495 QLock(addr.inlk); 496 print("}\n"); 497 print("QLock outlk {\n"); 498 QLock(addr.outlk); 499 print("}\n"); 500 print(" debug ", addr.debug, "\n"); 501 print(" infd ", addr.infd, "\n"); 502 print(" outfd ", addr.outfd, "\n"); 503 print(" muxer ", addr.muxer, "\n"); 504 print(" writeq ", addr.writeq\X, "\n"); 505 print(" readq ", addr.readq\X, "\n"); 506 print(" state ", addr.state, "\n"); 507 print(" wait ", addr.wait, "\n"); 508 print(" ntag ", addr.ntag, "\n"); 509 print(" nsleep ", addr.nsleep, "\n"); 510 print(" part ", addr.part\X, "\n"); 511 print("Rendez tagrend {\n"); 512 Rendez(addr.tagrend); 513 print("}\n"); 514 print("Rendez rpcfork {\n"); 515 Rendez(addr.rpcfork); 516 print("}\n"); 517 print(" version ", addr.version\X, "\n"); 518 print(" uid ", addr.uid\X, "\n"); 519 print(" sid ", addr.sid\X, "\n"); 520}; 521 522NilBlock = -1; 523sizeofVtBlock = 88; 524aggr VtBlock 525{ 526 'X' 0 c; 527 QLock 4 lk; 528 'X' 20 data; 529 'a' 24 score; 530 'b' 44 type; 531 'D' 48 nlock; 532 'D' 52 iostate; 533 'D' 56 ref; 534 'U' 60 heap; 535 'A' VtBlock 64 next; 536 'A' VtBlock 68 prev; 537 'U' 72 used; 538 'U' 76 used2; 539 'U' 80 addr; 540 'D' 84 decrypted; 541}; 542 543defn 544VtBlock(addr) { 545 complex VtBlock addr; 546 print(" c ", addr.c\X, "\n"); 547 print("QLock lk {\n"); 548 QLock(addr.lk); 549 print("}\n"); 550 print(" data ", addr.data\X, "\n"); 551 print(" score ", addr.score, "\n"); 552 print(" type ", addr.type, "\n"); 553 print(" nlock ", addr.nlock, "\n"); 554 print(" iostate ", addr.iostate, "\n"); 555 print(" ref ", addr.ref, "\n"); 556 print(" heap ", addr.heap, "\n"); 557 print(" next ", addr.next\X, "\n"); 558 print(" prev ", addr.prev\X, "\n"); 559 print(" used ", addr.used, "\n"); 560 print(" used2 ", addr.used2, "\n"); 561 print(" addr ", addr.addr, "\n"); 562 print(" decrypted ", addr.decrypted, "\n"); 563}; 564 565VtOREAD = 0; 566VtOWRITE = 1; 567VtORDWR = 2; 568VtOCREATE = 256; 569BioLocal = 1; 570BioVenti = 2; 571BioReading = 3; 572BioWriting = 4; 573BioEmpty = 5; 574BioVentiError = 6; 575BadHeap = -1; 576sizeofVtCache = 60; 577aggr VtCache 578{ 579 QLock 0 lk; 580 'A' VtConn 16 z; 581 'U' 20 blocksize; 582 'U' 24 now; 583 'A' VtBlock 28 hash; 584 'D' 32 nhash; 585 'A' VtBlock 36 heap; 586 'D' 40 nheap; 587 'A' VtBlock 44 block; 588 'D' 48 nblock; 589 'X' 52 mem; 590 'D' 56 mode; 591}; 592 593defn 594VtCache(addr) { 595 complex VtCache addr; 596 print("QLock lk {\n"); 597 QLock(addr.lk); 598 print("}\n"); 599 print(" z ", addr.z\X, "\n"); 600 print(" blocksize ", addr.blocksize, "\n"); 601 print(" now ", addr.now, "\n"); 602 print(" hash ", addr.hash\X, "\n"); 603 print(" nhash ", addr.nhash, "\n"); 604 print(" heap ", addr.heap\X, "\n"); 605 print(" nheap ", addr.nheap, "\n"); 606 print(" block ", addr.block\X, "\n"); 607 print(" nblock ", addr.nblock, "\n"); 608 print(" mem ", addr.mem\X, "\n"); 609 print(" mode ", addr.mode, "\n"); 610}; 611 612complex VtConn vtcachealloc:z; 613complex VtCache vtcachealloc:c; 614complex VtBlock vtcachealloc:b; 615complex VtCache vtcachefree:c; 616complex VtCache vtcachedump:c; 617complex VtBlock vtcachedump:b; 618complex VtCache cachecheck:c; 619complex VtBlock cachecheck:b; 620complex VtBlock upheap:b; 621complex VtBlock upheap:bb; 622complex VtCache upheap:c; 623complex VtBlock downheap:b; 624complex VtBlock downheap:bb; 625complex VtCache downheap:c; 626complex VtBlock heapdel:b; 627complex VtCache heapdel:c; 628complex VtBlock heapins:b; 629complex VtCache vtcachebumpblock:c; 630complex VtBlock vtcachebumpblock:b; 631complex VtCache vtcachelocal:c; 632complex VtBlock vtcachelocal:b; 633complex VtCache vtcacheallocblock:c; 634complex VtBlock vtcacheallocblock:b; 635complex VtCache vtcacheglobal:c; 636complex VtBlock vtcacheglobal:b; 637complex VtBlock vtblockduplock:b; 638complex VtBlock vtblockput:b; 639complex VtCache vtblockput:c; 640complex VtBlock vtblockwrite:b; 641complex VtCache vtblockwrite:c; 642complex VtCache vtcacheblocksize:c; 643complex VtBlock vtblockcopy:b; 644complex VtBlock vtblockcopy:bb; 645