clumpstats.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #include "stdinc.h"
  2. #include "dat.h"
  3. #include "fns.h"
  4. int count[VtMaxLumpSize][VtMaxType];
  5. enum
  6. {
  7. ClumpChunks = 32*1024
  8. };
  9. static
  10. readArenaInfo(Arena *arena)
  11. {
  12. ClumpInfo *ci, *cis;
  13. u32int clump;
  14. int i, n, ok;
  15. if(arena->clumps)
  16. fprint(2, "reading directory for arena=%s with %d entries\n", arena->name, arena->clumps);
  17. cis = MKN(ClumpInfo, ClumpChunks);
  18. ok = 1;
  19. for(clump = 0; clump < arena->clumps; clump += n){
  20. n = ClumpChunks;
  21. if(n > arena->clumps - clump)
  22. n = arena->clumps - clump;
  23. if(readClumpInfos(arena, clump, cis, n) != n){
  24. setErr(EOk, "arena directory read failed: %R");
  25. ok = 0;
  26. break;
  27. }
  28. for(i = 0; i < n; i++){
  29. ci = &cis[i];
  30. if(ci->type >= VtMaxType || ci->uncsize >= VtMaxLumpSize) {
  31. fprint(2, "bad clump: %d: type = %d: size = %d\n", clump+i, ci->type, ci->uncsize);
  32. continue;
  33. }
  34. if(ci->uncsize == 422)
  35. print("%s: %d: %V\n", arena->name, clump+i, ci->score);
  36. count[ci->uncsize][ci->type]++;
  37. }
  38. }
  39. free(cis);
  40. if(!ok)
  41. return TWID32;
  42. return clump;
  43. }
  44. static void
  45. clumpStats(Index *ix)
  46. {
  47. int ok;
  48. ulong clumps, n;
  49. int i, j, t;
  50. ok = 1;
  51. clumps = 0;
  52. for(i = 0; i < ix->narenas; i++){
  53. n = readArenaInfo(ix->arenas[i]);
  54. if(n == TWID32){
  55. ok = 0;
  56. break;
  57. }
  58. clumps += n;
  59. }
  60. if(!ok)
  61. return;
  62. print("clumps = %ld\n", clumps);
  63. for(i=0; i<VtMaxLumpSize; i++) {
  64. t = 0;
  65. for(j=0; j<VtMaxType; j++)
  66. t += count[i][j];
  67. if(t == 0)
  68. continue;
  69. print("%d\t%d", i, t);
  70. for(j=0; j<VtMaxType; j++)
  71. print("\t%d", count[i][j]);
  72. print("\n");
  73. }
  74. }
  75. void
  76. usage(void)
  77. {
  78. fprint(2, "usage: clumpstats [-B blockcachesize] config\n");
  79. exits(0);
  80. }
  81. int
  82. main(int argc, char *argv[])
  83. {
  84. u32int bcmem;
  85. vtAttach();
  86. bcmem = 0;
  87. ARGBEGIN{
  88. case 'B':
  89. bcmem = unittoull(ARGF());
  90. break;
  91. default:
  92. usage();
  93. break;
  94. }ARGEND
  95. readonly = 1;
  96. if(argc != 1)
  97. usage();
  98. if(!initVenti(argv[0], nil))
  99. fatal("can't init venti: %R");
  100. if(bcmem < maxBlockSize * (mainIndex->narenas + mainIndex->nsects * 4 + 16))
  101. bcmem = maxBlockSize * (mainIndex->narenas + mainIndex->nsects * 4 + 16);
  102. fprint(2, "initialize %d bytes of disk block cache\n", bcmem);
  103. initDCache(bcmem);
  104. clumpStats(mainIndex);
  105. exits(0);
  106. return 0; /* shut up stupid compiler */
  107. }