[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20121204200013.GD7790@thunk.org>
Date: Tue, 4 Dec 2012 15:00:13 -0500
From: Theodore Ts'o <tytso@....edu>
To: Darren Hart <dvhart@...radead.org>
Cc: Andreas Dilger <aedilger@...il.com>,
Andreas Dilger <adilger@...ger.ca>,
linux-ext4 <linux-ext4@...r.kernel.org>
Subject: Re: [e2fsprogs] initdir: Writing inode after the initial write?
On Tue, Dec 04, 2012 at 11:40:47AM -0800, Darren Hart wrote:
>
> 1) Update debugfs to completely support our use-case
> [ ] Add symlink support
> [ ] Add hardlink support
This exists already. See the "link" command. It doesn't update the
inode i_links_count, but that's probably something I would add by
adding an option (-i) which did this.
> [ ] Add meta-data mirroring
Not sure what what you mean by meta-data mirroring?
> 2) Refactor filesystem creation functions from debugfs and move them into
> libext2fs alongside existing filesystem creation functions like
> ext2fs_mkdir()
I'm not sure that creating new libext2fs functions is necessarily
needed. We'll need to discuss that on a case-by-case basis. For
creating a new symlink, sure, I'll buy that --- there's enough
complexity involved that it makes sense to move that into the library.
For creating a new hard link, we already have ext2fs_link(). Whether
or not it makes sense to add an entirely new function just to bump
i_links_count seems very dubious to me. We could add a flag which
reads in the target inode, bumps i_links_count, and then writes it
back out, but then we start asking whether or not we need to add an
option to set the ctime field or not, etc., etc., etc.
Taken to extremes that way lies the insanity of VMS's create_process
system call, with its huge number of parameters and options, as
opposed to separating fork() and exec(), and allowing the application
program to close file descriptors dup them, edit environment
variables, etc., between the fork() and exec(), which was a much saner
way of doing things in Unix.
So it's actually quite deliberate that what we have are very low-level
primitives in libext2fs. That being said, API design is a bit of an
art, as I said, for something as complicated as symlink creation,
where you need to do different things depending on whether the symlink
pathname can fit in the inode, etc., it does make sense to have a new
function.
> 3) Add the "-r initialdir" option to mke2fs that leverages these new
> functions
> from libext2fs.
Assuming the code for -r can be well constrained in terms of cleanly
added to the mke2fs sources (probably the bulk of the code should go
in a new .c file), and assuming that it doesn't bloat the mke2fs
binary too badly, I have no objections to adding the -r option to
mke2fs. (Worst case we can have a --disable-mke2fs-init-dir if there
are still people worried about making mke2fs fit on a boot/root 1.44M
floppy. :-)
That being said, if it bloats mke2fs too badly (for example, because
you tried using libxml2 for some kind of control file to specify the
character/block devices, and it dragged in megabytes and megabytes of
compiled object code, I'd certainly object, both because of the
addition of the external dependency, and because at that point people
really would complain --- and of course, because XML is just
horrible. :-)
- Ted
--
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists