fmtarenas.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. #include "stdinc.h"
  2. #include "dat.h"
  3. #include "fns.h"
  4. void
  5. usage(void)
  6. {
  7. fprint(2, "usage: fmtarenas [-Z] [-b blocksize] [-a arenasize] name file\n");
  8. exits(0);
  9. }
  10. int
  11. main(int argc, char *argv[])
  12. {
  13. ArenaPart *ap;
  14. Part *part;
  15. Arena *arena;
  16. u64int addr, limit, asize, apsize;
  17. char *file, *name, aname[ANameSize];
  18. int i, n, blockSize, tabSize, zero;
  19. fmtinstall('V', vtScoreFmt);
  20. fmtinstall('R', vtErrFmt);
  21. vtAttach();
  22. statsInit();
  23. blockSize = 8 * 1024;
  24. asize = 512 * 1024 *1024;
  25. tabSize = 64 * 1024; /* BUG: should be determine from number of arenas */
  26. zero = 1;
  27. ARGBEGIN{
  28. case 'd':
  29. chattyzero++;
  30. break;
  31. case 'a':
  32. asize = unittoull(ARGF());
  33. if(asize == TWID64)
  34. usage();
  35. break;
  36. case 'b':
  37. blockSize = unittoull(ARGF());
  38. if(blockSize == ~0)
  39. usage();
  40. if(blockSize > MaxDiskBlock){
  41. fprint(2, "block size too large, max %d\n", MaxDiskBlock);
  42. exits("usage");
  43. }
  44. break;
  45. case 'Z':
  46. zero = 0;
  47. break;
  48. default:
  49. usage();
  50. break;
  51. }ARGEND
  52. if(argc != 2)
  53. usage();
  54. name = argv[0];
  55. file = argv[1];
  56. if(!nameOk(name))
  57. fatal("illegal name template %s", name);
  58. part = initPart(file, 1);
  59. if(part == nil)
  60. fatal("can't open partition %s: %r", file);
  61. if(zero)
  62. zeroPart(part, blockSize);
  63. ap = newArenaPart(part, blockSize, tabSize);
  64. if(ap == nil)
  65. fatal("can't initialize arena: %R");
  66. apsize = ap->size - ap->arenaBase;
  67. n = apsize / asize;
  68. fprint(2, "configuring %s with arenas=%d for a total storage of bytes=%lld and directory bytes=%d\n",
  69. file, n, apsize, ap->tabSize);
  70. ap->narenas = n;
  71. ap->map = MKNZ(AMap, n);
  72. ap->arenas = MKNZ(Arena*, n);
  73. addr = ap->arenaBase;
  74. for(i = 0; i < n; i++){
  75. limit = addr + asize;
  76. snprint(aname, ANameSize, "%s%d", name, i);
  77. fprint(2, "adding arena %s at [%lld,%lld)\n", aname, addr, limit);
  78. arena = newArena(part, aname, addr, limit - addr, blockSize);
  79. if(!arena)
  80. fprint(2, "can't make new arena %s: %r", aname);
  81. freeArena(arena);
  82. ap->map[i].start = addr;
  83. ap->map[i].stop = limit;
  84. nameCp(ap->map[i].name, aname);
  85. addr = limit;
  86. }
  87. if(!wbArenaPart(ap))
  88. fprint(2, "can't write back arena partition header for %s: %R\n", file);
  89. exits(0);
  90. return 0; /* shut up stupid compiler */
  91. }