On Sun, Jan 09, 2011 at 09:58:38AM -0500, Ted Ts'o wrote: > On Sun, Jan 09, 2011 at 09:12:49AM +0100, Rogier Wolff wrote: > > > No. The superblock nor its offset will never change. It's like the > > > syscall ABI, only worse. If we changed it would break *everybody*. > > > Fortunately there is a huge amount of space left over in the 1024 byte > > > superblock. > > > > It's called defensive programming. It prevents bugs before they > > happen. By your reasoning you could've written 2048 or 0x800 there. > > Defensive programming would be something like > > BUG_ON(sizeof(struct ext4_super_block) != 1024); It is one form of "defense", but not what I call defensive programming. Defensive programming, is that you make things robust in the the face of unexpected changes. If you do the BUG_ON and do this throughout the code, one day your grandson will be increasing the superblock size. He'll fix all the BUG_ON and your other "defensive" measures. But lo and behold. He's human, and forgot one or two. Especially the run-time detections that only get called occasionally (like in this case on an error sitatuation) might take a while before they are noticed. What use is it to turn a "we've found a serious error in your filesystem, we strongly recommend you no longer write to it and run fsck first" into a "system halted"? What is wrong with just putting the right formula where it belongs? We need to set the variable "len" to the amount of free space beyond the superblock in the first block of the filesystem. So we take the size of the first block, subtract the size of the superblock and we subtract the start of the superblock. It's as simple as that. > We could add that, if people like. I do have regression tests (i.e., > boot a system with ext4) which would die if anything like that > changed, though. How about Makefile: ext4.o: ...the objects.... testsbsize.out testsbsize.out: testsbsize ./testsbsize (oh and something about useing "hostcc" for testsbsize). with testsbsize.c: #include <stdio.h> #include <...ext4....> int main (int argc, char **argv) { if (sizeof (struct ext4_super_block) != 1024) { fprintf (stderr, "Superblock size is %d, should be 1024.\n", sizeof (struct ext4_super_block)); exit (1); } exit (0); } Roger. -- ** R.E.Wolff@xxxxxxxxxxxx ** http://www.BitWizard.nl/ ** +31-15-2600998 ** ** Delftechpark 26 2628 XH Delft, The Netherlands. KVK: 27239233 ** *-- BitWizard writes Linux device drivers for any device you may have! --* Q: It doesn't work. A: Look buddy, doesn't work is an ambiguous statement. Does it sit on the couch all day? Is it unemployed? Please be specific! Define 'it' and what it isn't doing. --------- Adapted from lxrbot FAQ -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html