On Fri, 13 Dec 2002, Peter Wemm wrote:
> Julian Elischer wrote: > > On Fri, 13 Dec 2002, Julian Elischer wrote: > > > On Fri, 13 Dec 2002, Dan Nelson wrote: > > > > > > > In the last episode (Dec 13), Julian Elischer said: > > > > > It's always been there. the question is > > > > > "Who has broken it?" > > > > > > I think this is a 5.0 showstopper. Having 5.0 overwrite your > > > Windows partition would be "poor" PR. > > > Having a quick look at it, it shouldn't be too hard for PHK > > > to fix it as he has all the correct parts currently "loaded" > > > into his head. Especially such things as making GEOM not allow writes > > > to -ve blocknumbers (as must have happenned for root to have been > > > overwritten). > > > > > > looking at the code in src/sys/i386/i386/dump_machdep.c, > > > > we see: > > 78 dumplo = di->mediaoffset + di->mediasize - Maxmem * > > (off_t)PAGE_SIZE; > > 79 dumplo -= sizeof kdh * 2; > > 80 i = di->dumper(di->priv, &kdh, 0, dumplo, sizeof kdh); > > 81 if (i) > > 82 printf("\nDump failed writing header (%d)\n", i); > > 83 dumplo += sizeof kdh; > > 84 i = 0; > > > > It looks like the following test should go after line 77 > > > > if (di->mediasize < ((Maxmem * (off_t)PAGE_SIZE) + > > (sizeof kdh * 2) + (16*1024)) { > > /* 16K is an arbitrary buffer > > * in case the swap part is > > * the first part > > */ > > printf("\nDump failed. Partition too small.\n"); > > return; > > } > > We used to force a 64K safety buffer for swapon, and I think we also did > 64K for dump before the last MI dump code conversion. I'd feel a little > happier if you used 64K here instead of 16K. Actually I think we could put this in the MI code.... somewhat like as follows: src/sys/kern/kern_shutdown.c 228 static void 229 doadump(void) 230 { 231 savectx(&dumppcb); 232 dumping++; > > if (dumper.mediasize < ((Maxmem * (off_t)PAGE_SIZE) + > > (sizeof kdh * 2) + (16*1024)) { > > /* 16K is an arbitrary buffer > > * in case the swap part is > > * the first part > > */ > > printf("\nDump failed. Partition too small.\n"); > > return; > > } 233 dumpsys(&dumper); 234 } but I guess that assumes that each architecture doesn't have sparse dumps or sparse address spaces.. > > > Cheers, > -Peter > -- > Peter Wemm - [EMAIL PROTECTED]; [EMAIL PROTECTED]; [EMAIL PROTECTED] > "All of this is for nothing if we don't go to the stars" - JMS/B5 > > To Unsubscribe: send mail to [EMAIL PROTECTED] with "unsubscribe freebsd-current" in the body of the message