On Wed, 2008-12-10 at 20:06 -0800, Andrew Morton wrote: > On Thu, 11 Dec 2008 14:14:36 +1100 Stephen Rothwell <sfr@xxxxxxxxxxxxxxxx> wrote: > > > Hi Andrew, > > > > On Wed, 10 Dec 2008 21:34:56 -0500 Chris Mason <chris.mason@xxxxxxxxxx> wrote: > > > > > > Just an update, while I still have a long todo list and plenty of things > > > to fix in the code, these src trees have been updated with a disk format > > > I hope to maintain compatibility with from here on. There are still > > > format changes planned, but should go in through the compat mechanisms > > > in the sources now. > > > > > > The btrfs trees are still at 2.6.28-rc5, but I just tested against > > > linux-next without problems. > > > > Do you think this is ready to be added to the end of linux-next, yet? Or > > is this more -mm material? > > I'd prefer that it go into linux-next in the usual fashion. But the > first step is review.. I'm updating the various docs on the btrfs wiki. From a kernel impact point of view, btrfs only changes fs/Kconfig and fs/Makefile. Some of the most visible problems in the code are: No support for fs blocksizes other than the page size. This includes data blocks and btree leaves/nodes. In both cases, the infrastructure to do it is about 1/2 there, but some ugly problems remain. btrfs_file_write should just be removed in favor of write_begin/end. Right now, the main thing btrfs_file_write does is the dance to setup delalloc, so this should be fairly easy. The multi-device code uses a very simple brute force scan from userland to populate the list of devices that belong to a given FS. Kay Sievers has some ideas on hotplug magic to make this less dumb. (The scan isn't required for single device filesystems). extent_io.c should be split up into two files, one for the extent_buffer code and one for the state bit code. struct-funcs.c needs a big flashing neon sign about what it does and why. The extent_buffer interface needs much clearer documentation around why it is there and how it works. There are too many worker threads. At least some of them should be shared between filesystems instead of started for each FS. Each pool of worker thread represents some operation that would end up deadlocking if it shared threads with another pool. There are too many memory allocations on the IO submission path. It needs mempools and other steps to limit the amount of ram used to write a single block. The IO submission path is generally twisty, with helper threads and lookup functions. There is quite a bit going on here in terms of asynchronous checksumming and compression and it needs better documentation. ENOSPC == BUG() The extent allocation tree is what records which extents are allocated on disk, and tree blocks for the extent allocation tree allocated from the extent allocation tree. This recursion is controlled by deferring some operations for later processing, and the resulting complexity needs better documentation. -chris -- 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