On Jun 09, 2006 17:32 -0400, Jeff Garzik wrote: > Dave Jones wrote: > >Am I missing something fundamental that precludes the use of both > >extent-based and current existing filesystems from the same code > >simultaneously ? > > Nothing precludes it. The point is that introducing major format > changes inline in this manner just complicates the code progressively to > the point where your directory walking, inode block walking, and other > code winds up being > > if (new) > ... > else > ... > > _anyway_, at which point it is essentially multiple independent > filesystems. I guarantee this won't be the last fundamental fs metadata > design change people will want to make... Umm, and how is this fundamentally different from similar code paths in the VFS (e.g. O_DIRECT vs regular writes)? Should we make a copy of the whole write path for each of O_DIRECT, AIO, pwrite, etc writes, or should we instead add in a small change to the write path than leverages the majority of the existing code? What is better, using the 95% of the VFS that is common and change 5% to work with the filesystem, or duplicate the whole VFS just because 5% needs to be different? In the extents case, the large majority of the ext3 code is the same (directory, inode handling, superblock, etc) and only the on-disk format for indirect blocks has changed. Yes, we also want to change the block allocator next in order to improve the performance in conjunction with extents, but that is purely an in-memory change that has no direct relation to on-disk layout. The major motivations for the extents format: (a) more compact on-disk representation for large files (improves unlink performance, reduces memory usage for metadata) (b) support for larger filesystems (which will affect everyone soon enough). (c) integrate well with improved allocation support For most of the ext3 developers (b) is the primary motivation here, and given that so many people are vocal about ext3 changes that must mean that there are a lot of ext3 users here. Does that mean that in the next few years all of the objectors will abandon ext3 in favour of ext4 or XFS or JFS or reiserfs or reiser4 when you get a new system with a single 12TB disk? And we can delete ext3 then, or will you be happy then that ext3 supports these large disks without any effort on your part? Maybe we should start by deleting ext2 because it is old and obsolete? The reality is that we will never merge the forks back once they are made. Cheers, Andreas -- Andreas Dilger Principal Software Engineer Cluster File Systems, Inc. - To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html