Subversion Repositories planix.SVN

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 - 1
sizeof_1_ = 8;
2
aggr _1_
3
{
4
	'U' 0 lo;
5
	'U' 4 hi;
6
};
7
 
8
defn
9
_1_(addr) {
10
	complex _1_ addr;
11
	print("	lo	", addr.lo, "\n");
12
	print("	hi	", addr.hi, "\n");
13
};
14
 
15
sizeofFPdbleword = 8;
16
aggr FPdbleword
17
{
18
	'F' 0 x;
19
	{
20
	'U' 0 lo;
21
	'U' 4 hi;
22
	};
23
};
24
 
25
defn
26
FPdbleword(addr) {
27
	complex FPdbleword addr;
28
	print("	x	", addr.x, "\n");
29
	print("_1_ {\n");
30
		_1_(addr+0);
31
	print("}\n");
32
};
33
 
34
UTFmax = 3;
35
Runesync = 128;
36
Runeself = 128;
37
Runeerror = 65533;
38
sizeofFmt = 48;
39
aggr 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
 
55
defn
56
Fmt(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
 
72
FmtWidth = 1;
73
FmtLeft = 2;
74
FmtPrec = 4;
75
FmtSharp = 8;
76
FmtSpace = 16;
77
FmtSign = 32;
78
FmtZero = 64;
79
FmtUnsigned = 128;
80
FmtShort = 256;
81
FmtLong = 512;
82
FmtVLong = 1024;
83
FmtComma = 2048;
84
FmtByte = 4096;
85
FmtFlag = 8192;
86
sizeofTm = 40;
87
aggr 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
 
101
defn
102
Tm(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
 
116
PNPROC = 1;
117
PNGROUP = 2;
118
Profoff = 0;
119
Profuser = 1;
120
Profkernel = 2;
121
Proftime = 3;
122
Profsample = 4;
123
sizeofLock = 4;
124
aggr Lock
125
{
126
	'D' 0 val;
127
};
128
 
129
defn
130
Lock(addr) {
131
	complex Lock addr;
132
	print("	val	", addr.val, "\n");
133
};
134
 
135
sizeofQLp = 12;
136
aggr QLp
137
{
138
	'D' 0 inuse;
139
	'A' QLp 4 next;
140
	'C' 8 state;
141
};
142
 
143
defn
144
QLp(addr) {
145
	complex QLp addr;
146
	print("	inuse	", addr.inuse, "\n");
147
	print("	next	", addr.next\X, "\n");
148
	print("	state	", addr.state, "\n");
149
};
150
 
151
sizeofQLock = 16;
152
aggr QLock
153
{
154
	Lock 0 lock;
155
	'D' 4 locked;
156
	'A' QLp 8 $head;
157
	'A' QLp 12 $tail;
158
};
159
 
160
defn
161
QLock(addr) {
162
	complex QLock addr;
163
	print("Lock lock {\n");
164
	Lock(addr.lock);
165
	print("}\n");
166
	print("	locked	", addr.locked, "\n");
167
	print("	$head	", addr.$head\X, "\n");
168
	print("	$tail	", addr.$tail\X, "\n");
169
};
170
 
171
sizeofRWLock = 20;
172
aggr RWLock
173
{
174
	Lock 0 lock;
175
	'D' 4 readers;
176
	'D' 8 writer;
177
	'A' QLp 12 $head;
178
	'A' QLp 16 $tail;
179
};
180
 
181
defn
182
RWLock(addr) {
183
	complex RWLock addr;
184
	print("Lock lock {\n");
185
	Lock(addr.lock);
186
	print("}\n");
187
	print("	readers	", addr.readers, "\n");
188
	print("	writer	", addr.writer, "\n");
189
	print("	$head	", addr.$head\X, "\n");
190
	print("	$tail	", addr.$tail\X, "\n");
191
};
192
 
193
sizeofRendez = 12;
194
aggr Rendez
195
{
196
	'A' QLock 0 l;
197
	'A' QLp 4 $head;
198
	'A' QLp 8 $tail;
199
};
200
 
201
defn
202
Rendez(addr) {
203
	complex Rendez addr;
204
	print("	l	", addr.l\X, "\n");
205
	print("	$head	", addr.$head\X, "\n");
206
	print("	$tail	", addr.$tail\X, "\n");
207
};
208
 
209
sizeofNetConnInfo = 36;
210
aggr NetConnInfo
211
{
212
	'X' 0 dir;
213
	'X' 4 root;
214
	'X' 8 spec;
215
	'X' 12 lsys;
216
	'X' 16 lserv;
217
	'X' 20 rsys;
218
	'X' 24 rserv;
219
	'X' 28 laddr;
220
	'X' 32 raddr;
221
};
222
 
223
defn
224
NetConnInfo(addr) {
225
	complex NetConnInfo addr;
226
	print("	dir	", addr.dir\X, "\n");
227
	print("	root	", addr.root\X, "\n");
228
	print("	spec	", addr.spec\X, "\n");
229
	print("	lsys	", addr.lsys\X, "\n");
230
	print("	lserv	", addr.lserv\X, "\n");
231
	print("	rsys	", addr.rsys\X, "\n");
232
	print("	rserv	", addr.rserv\X, "\n");
233
	print("	laddr	", addr.laddr\X, "\n");
234
	print("	raddr	", addr.raddr\X, "\n");
235
};
236
 
237
RFNAMEG = 1;
238
RFENVG = 2;
239
RFFDG = 4;
240
RFNOTEG = 8;
241
RFPROC = 16;
242
RFMEM = 32;
243
RFNOWAIT = 64;
244
RFCNAMEG = 1024;
245
RFCENVG = 2048;
246
RFCFDG = 4096;
247
RFREND = 8192;
248
RFNOMNT = 16384;
249
sizeofQid = 16;
250
aggr Qid
251
{
252
	'W' 0 path;
253
	'U' 8 vers;
254
	'b' 12 type;
255
};
256
 
257
defn
258
Qid(addr) {
259
	complex Qid addr;
260
	print("	path	", addr.path, "\n");
261
	print("	vers	", addr.vers, "\n");
262
	print("	type	", addr.type, "\n");
263
};
264
 
265
sizeofDir = 60;
266
aggr Dir
267
{
268
	'u' 0 type;
269
	'U' 4 dev;
270
	Qid 8 qid;
271
	'U' 24 mode;
272
	'U' 28 atime;
273
	'U' 32 mtime;
274
	'V' 36 length;
275
	'X' 44 name;
276
	'X' 48 uid;
277
	'X' 52 gid;
278
	'X' 56 muid;
279
};
280
 
281
defn
282
Dir(addr) {
283
	complex Dir addr;
284
	print("	type	", addr.type, "\n");
285
	print("	dev	", addr.dev, "\n");
286
	print("Qid qid {\n");
287
	Qid(addr.qid);
288
	print("}\n");
289
	print("	mode	", addr.mode, "\n");
290
	print("	atime	", addr.atime, "\n");
291
	print("	mtime	", addr.mtime, "\n");
292
	print("	length	", addr.length, "\n");
293
	print("	name	", addr.name\X, "\n");
294
	print("	uid	", addr.uid\X, "\n");
295
	print("	gid	", addr.gid\X, "\n");
296
	print("	muid	", addr.muid\X, "\n");
297
};
298
 
299
sizeofWaitmsg = 20;
300
aggr Waitmsg
301
{
302
	'D' 0 pid;
303
	'a' 4 time;
304
	'X' 16 msg;
305
};
306
 
307
defn
308
Waitmsg(addr) {
309
	complex Waitmsg addr;
310
	print("	pid	", addr.pid, "\n");
311
	print("	time	", addr.time, "\n");
312
	print("	msg	", addr.msg\X, "\n");
313
};
314
 
315
sizeofIOchunk = 8;
316
aggr IOchunk
317
{
318
	'X' 0 addr;
319
	'U' 4 len;
320
};
321
 
322
defn
323
IOchunk(addr) {
324
	complex IOchunk addr;
325
	print("	addr	", addr.addr\X, "\n");
326
	print("	len	", addr.len, "\n");
327
};
328
 
329
sizeofPool = 88;
330
aggr Pool
331
{
332
	'X' 0 name;
333
	'U' 4 maxsize;
334
	'U' 8 cursize;
335
	'U' 12 curfree;
336
	'U' 16 curalloc;
337
	'U' 20 minarena;
338
	'U' 24 quantum;
339
	'U' 28 minblock;
340
	'X' 32 freeroot;
341
	'X' 36 arenalist;
342
	'X' 40 alloc;
343
	'X' 44 merge;
344
	'X' 48 move;
345
	'D' 52 flags;
346
	'D' 56 nfree;
347
	'D' 60 lastcompact;
348
	'X' 64 lock;
349
	'X' 68 unlock;
350
	'X' 72 print;
351
	'X' 76 panic;
352
	'X' 80 logstack;
353
	'X' 84 private;
354
};
355
 
356
defn
357
Pool(addr) {
358
	complex Pool addr;
359
	print("	name	", addr.name\X, "\n");
360
	print("	maxsize	", addr.maxsize, "\n");
361
	print("	cursize	", addr.cursize, "\n");
362
	print("	curfree	", addr.curfree, "\n");
363
	print("	curalloc	", addr.curalloc, "\n");
364
	print("	minarena	", addr.minarena, "\n");
365
	print("	quantum	", addr.quantum, "\n");
366
	print("	minblock	", addr.minblock, "\n");
367
	print("	freeroot	", addr.freeroot\X, "\n");
368
	print("	arenalist	", addr.arenalist\X, "\n");
369
	print("	alloc	", addr.alloc\X, "\n");
370
	print("	merge	", addr.merge\X, "\n");
371
	print("	move	", addr.move\X, "\n");
372
	print("	flags	", addr.flags, "\n");
373
	print("	nfree	", addr.nfree, "\n");
374
	print("	lastcompact	", addr.lastcompact, "\n");
375
	print("	lock	", addr.lock\X, "\n");
376
	print("	unlock	", addr.unlock\X, "\n");
377
	print("	print	", addr.print\X, "\n");
378
	print("	panic	", addr.panic\X, "\n");
379
	print("	logstack	", addr.logstack\X, "\n");
380
	print("	private	", addr.private\X, "\n");
381
};
382
 
383
complex Pool mainmem;
384
complex Pool imagmem;
385
POOL_ANTAGONISM = 1;
386
POOL_PARANOIA = 2;
387
POOL_VERBOSITY = 4;
388
POOL_DEBUGGING = 8;
389
POOL_LOGGING = 16;
390
POOL_TOLERANCE = 32;
391
POOL_NOREUSE = 64;
392
sizeofBhdr = 8;
393
aggr Bhdr
394
{
395
	'U' 0 magic;
396
	'U' 4 size;
397
};
398
 
399
defn
400
Bhdr(addr) {
401
	complex Bhdr addr;
402
	print("	magic	", addr.magic, "\n");
403
	print("	size	", addr.size, "\n");
404
};
405
 
406
NOT_MAGIC = 3735943697;
407
DEAD_MAGIC = 3735936685;
408
TAIL_MAGIC0 = 190;
409
TAIL_MAGIC1 = 239;
410
sizeofBtail = 8;
411
aggr Btail
412
{
413
	'b' 0 magic0;
414
	'a' 1 datasize;
415
	'b' 3 magic1;
416
	'U' 4 size;
417
};
418
 
419
defn
420
Btail(addr) {
421
	complex Btail addr;
422
	print("	magic0	", addr.magic0, "\n");
423
	print("	datasize	", addr.datasize, "\n");
424
	print("	magic1	", addr.magic1, "\n");
425
	print("	size	", addr.size, "\n");
426
};
427
 
428
sizeofFree = 24;
429
aggr Free
430
{
431
	{
432
	'U' 0 magic;
433
	'U' 4 size;
434
	};
435
	'A' Free 8 left;
436
	'A' Free 12 right;
437
	'A' Free 16 next;
438
	'A' Free 20 prev;
439
};
440
 
441
defn
442
Free(addr) {
443
	complex Free addr;
444
	print("Bhdr {\n");
445
		Bhdr(addr+0);
446
	print("}\n");
447
	print("	left	", addr.left\X, "\n");
448
	print("	right	", addr.right\X, "\n");
449
	print("	next	", addr.next\X, "\n");
450
	print("	prev	", addr.prev\X, "\n");
451
};
452
 
453
FREE_MAGIC = 3126770193;
454
sizeofAlloc = 8;
455
aggr Alloc
456
{
457
	{
458
	'U' 0 magic;
459
	'U' 4 size;
460
	};
461
};
462
 
463
defn
464
Alloc(addr) {
465
	complex Alloc addr;
466
	print("Bhdr {\n");
467
		Bhdr(addr+0);
468
	print("}\n");
469
};
470
 
471
ALLOC_MAGIC = 168889353;
472
UNALLOC_MAGIC = 3400535327;
473
sizeofArena = 24;
474
aggr Arena
475
{
476
	{
477
	'U' 0 magic;
478
	'U' 4 size;
479
	};
480
	'A' Arena 8 aup;
481
	'A' Arena 12 down;
482
	'U' 16 asize;
483
	'U' 20 pad;
484
};
485
 
486
defn
487
Arena(addr) {
488
	complex Arena addr;
489
	print("Bhdr {\n");
490
		Bhdr(addr+0);
491
	print("}\n");
492
	print("	aup	", addr.aup\X, "\n");
493
	print("	down	", addr.down\X, "\n");
494
	print("	asize	", addr.asize, "\n");
495
	print("	pad	", addr.pad, "\n");
496
};
497
 
498
ARENA_MAGIC = 3231835599;
499
ARENATAIL_MAGIC = 3965590029;
500
ALIGN_MAGIC = 2716979649;
501
MINBLOCKSIZE = 32;
502
complex Free checklist:t;
503
complex Free checklist:q;
504
complex Free checktree:t;
505
complex Free ltreewalk:t;
506
complex Free treelookup:t;
507
complex Free treeinsert:tree;
508
complex Free treeinsert:node;
509
complex Free treeinsert:loc;
510
complex Free treeinsert:repl;
511
complex Free treedelete:tree;
512
complex Free treedelete:node;
513
complex Free treedelete:loc;
514
complex Free treedelete:lsucc;
515
complex Free treedelete:succ;
516
complex Free treelookupgt:t;
517
complex Free treelookupgt:lastgood;
518
complex Free listadd:list;
519
complex Free listadd:node;
520
complex Free listdelete:list;
521
complex Free listdelete:node;
522
complex Pool pooladd:p;
523
complex Alloc pooladd:anode;
524
complex Free pooladd:lst;
525
complex Free pooladd:olst;
526
complex Free pooladd:node;
527
complex Free pooladd:parent;
528
complex Pool pooldel:p;
529
complex Free pooldel:node;
530
complex Free pooldel:lst;
531
complex Free pooldel:olst;
532
complex Free pooldel:parent;
533
complex Pool dsize2bsize:p;
534
complex Pool bsize2asize:p;
535
complex Pool blockmerge:pool;
536
complex Bhdr blockmerge:a;
537
complex Bhdr blockmerge:b;
538
complex Btail blockmerge:t;
539
complex Bhdr blocksetsize:b;
540
complex Btail blocksetsize:t;
541
complex Alloc getdsize:b;
542
complex Btail getdsize:t;
543
complex Pool blocksetdsize:p;
544
complex Alloc blocksetdsize:b;
545
complex Btail blocksetdsize:t;
546
complex Pool trim:p;
547
complex Alloc trim:b;
548
complex Alloc trim:frag;
549
complex Pool freefromfront:p;
550
complex Alloc freefromfront:b;
551
complex Alloc freefromfront:bb;
552
complex Arena arenasetsize:a;
553
complex Bhdr arenasetsize:atail;
554
complex Pool poolnewarena:p;
555
complex Arena poolnewarena:a;
556
complex Arena poolnewarena:ap;
557
complex Arena poolnewarena:lastap;
558
complex Alloc poolnewarena:b;
559
complex Pool blockgrow:p;
560
complex Bhdr blockgrow:b;
561
complex Alloc blockgrow:a;
562
complex Bhdr blockgrow:bnxt;
563
complex Alloc blockgrow:a;
564
complex Pool arenamerge:p;
565
complex Arena arenamerge:bot;
566
complex Arena arenamerge:top;
567
complex Bhdr arenamerge:bbot;
568
complex Bhdr arenamerge:btop;
569
complex Btail arenamerge:t;
570
complex Pool dumpblock:p;
571
complex Bhdr dumpblock:b;
572
complex Pool printblock:p;
573
complex Bhdr printblock:b;
574
complex Pool panicblock:p;
575
complex Bhdr panicblock:b;
576
complex Pool blockcheck:p;
577
complex Bhdr blockcheck:b;
578
complex Alloc blockcheck:a;
579
complex Btail blockcheck:t;
580
FLOATING_MAGIC = 3419130827;
581
complex Pool arenacompact:p;
582
complex Arena arenacompact:a;
583
complex Bhdr arenacompact:b;
584
complex Bhdr arenacompact:wb;
585
complex Bhdr arenacompact:eb;
586
complex Bhdr arenacompact:nxt;
587
complex Pool poolcompactl:pool;
588
complex Arena poolcompactl:a;
589
complex Pool B2D:p;
590
complex Alloc B2D:a;
591
complex Pool D2B:p;
592
complex Alloc D2B:a;
593
complex Pool poolallocl:p;
594
complex Free poolallocl:fb;
595
complex Alloc poolallocl:ab;
596
complex Pool poolreallocl:p;
597
complex Alloc poolreallocl:a;
598
complex Bhdr poolreallocl:left;
599
complex Bhdr poolreallocl:right;
600
complex Bhdr poolreallocl:newb;
601
complex Btail poolreallocl:t;
602
complex Pool poolallocalignl:p;
603
complex Alloc poolallocalignl:b;
604
complex Pool poolfreel:p;
605
complex Alloc poolfreel:ab;
606
complex Bhdr poolfreel:back;
607
complex Bhdr poolfreel:fwd;
608
complex Pool poolalloc:p;
609
complex Pool poolallocalign:p;
610
complex Pool poolcompact:p;
611
complex Pool poolrealloc:p;
612
complex Pool poolfree:p;
613
complex Pool poolmsize:p;
614
complex Alloc poolmsize:b;
615
complex Pool poolcheckarena:p;
616
complex Arena poolcheckarena:a;
617
complex Bhdr poolcheckarena:b;
618
complex Bhdr poolcheckarena:atail;
619
complex Pool poolcheckl:p;
620
complex Arena poolcheckl:a;
621
complex Pool poolcheck:p;
622
complex Pool poolblockcheck:p;
623
complex Pool pooldumpl:p;
624
complex Arena pooldumpl:a;
625
complex Pool pooldump:p;
626
complex Pool pooldumparena:p;
627
complex Arena pooldumparena:a;
628
complex Bhdr pooldumparena:b;