fmtarenas.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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 'a':
  29. asize = unittoull(ARGF());
  30. if(asize == TWID64)
  31. usage();
  32. break;
  33. case 'b':
  34. blockSize = unittoull(ARGF());
  35. if(blockSize == ~0)
  36. usage();
  37. if(blockSize > MaxDiskBlock){
  38. fprint(2, "block size too large, max %d\n", MaxDiskBlock);
  39. exits("usage");
  40. }
  41. break;
  42. case 'Z':
  43. zero = 0;
  44. break;
  45. default:
  46. usage();
  47. break;
  48. }ARGEND
  49. if(argc != 2)
  50. usage();
  51. name = argv[0];
  52. file = argv[1];
  53. if(!nameOk(name))
  54. fatal("illegal name template %s", name);
  55. part = initPart(file, 1);
  56. if(part == nil)
  57. fatal("can't open partition %s: %r", file);
  58. if(zero)
  59. zeroPart(part, blockSize);
  60. ap = newArenaPart(part, blockSize, tabSize);
  61. if(ap == nil)
  62. fatal("can't initialize arena: %R");
  63. apsize = ap->size - ap->arenaBase;
  64. n = apsize / asize;
  65. fprint(2, "configuring %s with arenas=%d for a total storage of bytes=%lld and directory bytes=%d\n",
  66. file, n, apsize, ap->tabSize);
  67. ap->narenas = n;
  68. ap->map = MKNZ(AMap, n);
  69. ap->arenas = MKNZ(Arena*, n);
  70. addr = ap->arenaBase;
  71. for(i = 0; i < n; i++){
  72. limit = addr + asize;
  73. snprint(aname, ANameSize, "%s%d", name, i);
  74. fprint(2, "adding arena %s at [%lld,%lld)\n", aname, addr, limit);
  75. arena = newArena(part, aname, addr, limit - addr, blockSize);
  76. if(!arena)
  77. fprint(2, "can't make new arena %s: %r", aname);
  78. freeArena(arena);
  79. ap->map[i].start = addr;
  80. ap->map[i].stop = limit;
  81. nameCp(ap->map[i].name, aname);
  82. addr = limit;
  83. }
  84. if(!wbArenaPart(ap))
  85. fprint(2, "can't write back arena partition header for %s: %R\n", file);
  86. exits(0);
  87. return 0; /* shut up stupid compiler */
  88. }