xref: /plan9/sys/src/libventi/cache.acid (revision 368c31ab13393dea083228fdd1c3445076f83a4b)
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