Blame


1 7a4ee46d 2003-11-23 devnull #include "stdinc.h"
2 7a4ee46d 2003-11-23 devnull #include "dat.h"
3 7a4ee46d 2003-11-23 devnull #include "fns.h"
4 7a4ee46d 2003-11-23 devnull
5 7a4ee46d 2003-11-23 devnull int count[VtMaxLumpSize][VtMaxType];
6 7a4ee46d 2003-11-23 devnull
7 7a4ee46d 2003-11-23 devnull enum
8 7a4ee46d 2003-11-23 devnull {
9 7a4ee46d 2003-11-23 devnull ClumpChunks = 32*1024
10 7a4ee46d 2003-11-23 devnull };
11 7a4ee46d 2003-11-23 devnull
12 7a4ee46d 2003-11-23 devnull static int
13 7a4ee46d 2003-11-23 devnull readarenainfo(Arena *arena)
14 7a4ee46d 2003-11-23 devnull {
15 7a4ee46d 2003-11-23 devnull ClumpInfo *ci, *cis;
16 7a4ee46d 2003-11-23 devnull u32int clump;
17 7a4ee46d 2003-11-23 devnull int i, n, ok;
18 7a4ee46d 2003-11-23 devnull
19 7a4ee46d 2003-11-23 devnull if(arena->clumps)
20 7a4ee46d 2003-11-23 devnull fprint(2, "reading directory for arena=%s with %d entries\n", arena->name, arena->clumps);
21 7a4ee46d 2003-11-23 devnull
22 7a4ee46d 2003-11-23 devnull cis = MKN(ClumpInfo, ClumpChunks);
23 7a4ee46d 2003-11-23 devnull ok = 0;
24 7a4ee46d 2003-11-23 devnull for(clump = 0; clump < arena->clumps; clump += n){
25 7a4ee46d 2003-11-23 devnull n = ClumpChunks;
26 7a4ee46d 2003-11-23 devnull
27 7a4ee46d 2003-11-23 devnull if(n > arena->clumps - clump)
28 7a4ee46d 2003-11-23 devnull n = arena->clumps - clump;
29 7a4ee46d 2003-11-23 devnull
30 7a4ee46d 2003-11-23 devnull if((i=readclumpinfos(arena, clump, cis, n)) != n){
31 7a4ee46d 2003-11-23 devnull seterr(EOk, "arena directory read failed %d not %d: %r", i, n);
32 7a4ee46d 2003-11-23 devnull ok = -1;
33 7a4ee46d 2003-11-23 devnull break;
34 7a4ee46d 2003-11-23 devnull }
35 7a4ee46d 2003-11-23 devnull
36 7a4ee46d 2003-11-23 devnull for(i = 0; i < n; i++){
37 7a4ee46d 2003-11-23 devnull ci = &cis[i];
38 7a4ee46d 2003-11-23 devnull if(ci->type >= VtMaxType || ci->uncsize >= VtMaxLumpSize) {
39 7a4ee46d 2003-11-23 devnull fprint(2, "bad clump: %d: type = %d: size = %d\n", clump+i, ci->type, ci->uncsize);
40 7a4ee46d 2003-11-23 devnull continue;
41 7a4ee46d 2003-11-23 devnull }
42 7a4ee46d 2003-11-23 devnull if(ci->uncsize == 422)
43 7a4ee46d 2003-11-23 devnull print("%s: %d: %V\n", arena->name, clump+i, ci->score);
44 7a4ee46d 2003-11-23 devnull count[ci->uncsize][ci->type]++;
45 7a4ee46d 2003-11-23 devnull }
46 7a4ee46d 2003-11-23 devnull }
47 7a4ee46d 2003-11-23 devnull free(cis);
48 7a4ee46d 2003-11-23 devnull if(ok < 0)
49 7a4ee46d 2003-11-23 devnull return TWID32;
50 7a4ee46d 2003-11-23 devnull return clump;
51 7a4ee46d 2003-11-23 devnull }
52 7a4ee46d 2003-11-23 devnull
53 7a4ee46d 2003-11-23 devnull static void
54 7a4ee46d 2003-11-23 devnull clumpstats(Index *ix)
55 7a4ee46d 2003-11-23 devnull {
56 7a4ee46d 2003-11-23 devnull int ok;
57 7a4ee46d 2003-11-23 devnull ulong clumps, n;
58 7a4ee46d 2003-11-23 devnull int i, j, t;
59 7a4ee46d 2003-11-23 devnull
60 7a4ee46d 2003-11-23 devnull ok = 0;
61 7a4ee46d 2003-11-23 devnull clumps = 0;
62 7a4ee46d 2003-11-23 devnull for(i = 0; i < ix->narenas; i++){
63 7a4ee46d 2003-11-23 devnull n = readarenainfo(ix->arenas[i]);
64 7a4ee46d 2003-11-23 devnull if(n == TWID32){
65 7a4ee46d 2003-11-23 devnull ok = -1;
66 7a4ee46d 2003-11-23 devnull break;
67 7a4ee46d 2003-11-23 devnull }
68 7a4ee46d 2003-11-23 devnull clumps += n;
69 7a4ee46d 2003-11-23 devnull }
70 7a4ee46d 2003-11-23 devnull
71 7a4ee46d 2003-11-23 devnull if(ok < 0)
72 7a4ee46d 2003-11-23 devnull return;
73 7a4ee46d 2003-11-23 devnull
74 7a4ee46d 2003-11-23 devnull print("clumps = %ld\n", clumps);
75 7a4ee46d 2003-11-23 devnull for(i=0; i<VtMaxLumpSize; i++) {
76 7a4ee46d 2003-11-23 devnull t = 0;
77 7a4ee46d 2003-11-23 devnull for(j=0; j<VtMaxType; j++)
78 7a4ee46d 2003-11-23 devnull t += count[i][j];
79 7a4ee46d 2003-11-23 devnull if(t == 0)
80 7a4ee46d 2003-11-23 devnull continue;
81 7a4ee46d 2003-11-23 devnull print("%d\t%d", i, t);
82 7a4ee46d 2003-11-23 devnull for(j=0; j<VtMaxType; j++)
83 7a4ee46d 2003-11-23 devnull print("\t%d", count[i][j]);
84 7a4ee46d 2003-11-23 devnull print("\n");
85 7a4ee46d 2003-11-23 devnull }
86 7a4ee46d 2003-11-23 devnull }
87 7a4ee46d 2003-11-23 devnull
88 7a4ee46d 2003-11-23 devnull
89 7a4ee46d 2003-11-23 devnull void
90 7a4ee46d 2003-11-23 devnull usage(void)
91 7a4ee46d 2003-11-23 devnull {
92 7a4ee46d 2003-11-23 devnull fprint(2, "usage: clumpstats [-B blockcachesize] config\n");
93 7a4ee46d 2003-11-23 devnull threadexitsall(0);
94 7a4ee46d 2003-11-23 devnull }
95 7a4ee46d 2003-11-23 devnull
96 7a4ee46d 2003-11-23 devnull void
97 7a4ee46d 2003-11-23 devnull threadmain(int argc, char *argv[])
98 7a4ee46d 2003-11-23 devnull {
99 7a4ee46d 2003-11-23 devnull u32int bcmem;
100 7a4ee46d 2003-11-23 devnull
101 7a4ee46d 2003-11-23 devnull bcmem = 0;
102 7a4ee46d 2003-11-23 devnull
103 7a4ee46d 2003-11-23 devnull ARGBEGIN{
104 7a4ee46d 2003-11-23 devnull case 'B':
105 7a4ee46d 2003-11-23 devnull bcmem = unittoull(ARGF());
106 7a4ee46d 2003-11-23 devnull break;
107 7a4ee46d 2003-11-23 devnull default:
108 7a4ee46d 2003-11-23 devnull usage();
109 7a4ee46d 2003-11-23 devnull break;
110 7a4ee46d 2003-11-23 devnull }ARGEND
111 7a4ee46d 2003-11-23 devnull
112 7a4ee46d 2003-11-23 devnull readonly = 1;
113 7a4ee46d 2003-11-23 devnull
114 7a4ee46d 2003-11-23 devnull if(argc != 1)
115 7a4ee46d 2003-11-23 devnull usage();
116 7a4ee46d 2003-11-23 devnull
117 7a4ee46d 2003-11-23 devnull if(initventi(argv[0]) < 0)
118 7a4ee46d 2003-11-23 devnull sysfatal("can't init venti: %r");
119 7a4ee46d 2003-11-23 devnull
120 7a4ee46d 2003-11-23 devnull if(bcmem < maxblocksize * (mainindex->narenas + mainindex->nsects * 4 + 16))
121 7a4ee46d 2003-11-23 devnull bcmem = maxblocksize * (mainindex->narenas + mainindex->nsects * 4 + 16);
122 7a4ee46d 2003-11-23 devnull fprint(2, "initialize %d bytes of disk block cache\n", bcmem);
123 7a4ee46d 2003-11-23 devnull initdcache(bcmem);
124 7a4ee46d 2003-11-23 devnull
125 7a4ee46d 2003-11-23 devnull clumpstats(mainindex);
126 7a4ee46d 2003-11-23 devnull
127 7a4ee46d 2003-11-23 devnull threadexitsall(0);
128 7a4ee46d 2003-11-23 devnull }