From: "Theodore Ts'o" <tytso@mit.edu>
To: harshadshirwadkar@gmail.com
Cc: linux-ext4@vger.kernel.org, adilger@dilger.ca
Subject: Re: [PATCH v3] ext4: shrink directory when last block is empty
Date: Sun, 7 Apr 2019 19:58:36 -0400 [thread overview]
Message-ID: <20190407235836.GA29128@mit.edu> (raw)
In-Reply-To: <20190227040118.246464-1-harshadshirwadkar@gmail.com>
On Tue, Feb 26, 2019 at 08:01:18PM -0800, harshadshirwadkar@gmail.com wrote:
>
+static bool
+ext4_dx_delete_entry(handle_t *handle, struct inode *dir,
+ struct dx_frame *dx_frame, __le64 block)
+{
>
The function name is a bit problematic. The ext4_find_entry,
ext4_dx_find_entry, ext4_delete_entry() all operate on the directory
entry. This is doing something different --- it's operating to remove
the hash tree dx entry. So something maybe like
ext4_remove_dx_entry()? And we definitely need some documentation for
this function.
Also, I think we can drop last argument, since you can get it from
cpu_to_le64(dx_get_block(dx_frame->at)).
> +
> +static inline bool should_try_dx_delete(struct dx_frame *dx_frame,
> + struct buffer_head *bh,
> + struct inode *dir)
> +{
> + return dx_frame && dx_frame->bh && is_empty_dirent_block(dir, bh) &&
> + dx_get_block(dx_frame->at) ==
> + (dir->i_size - 1) >> dir->i_sb->s_blocksize_bits;
> +}
As above, I'm not sure this is a great name for the function --- and
for that matter, I'm not sure it's worth it to separate this out.
First of all, we want to be able to truncate non-indexed directory,
not just indexed directories. So moving this logic into
ext4_delete_entry() probably makes sense.
If the directory is not indexed, it's really trivial to truncate it
--- and the xfstests change you submitted would fail on file system
configurations if the dir_index feature is not set, so we should
really do that simple case while we're at it.
> -static struct buffer_head * ext4_find_entry (struct inode *dir,
> - const struct qstr *d_name,
> - struct ext4_dir_entry_2 **res_dir,
> - int *inlined)
> +static struct buffer_head *ext4_find_entry(struct inode *dir,
> + const struct qstr *d_name,
> + struct ext4_dir_entry_2 **res_dir,
> + int *inlined,
> + struct dx_frame *dx_frame)
Could you add some documentation for this function --- specifically,
why a caller might want to pass in dx_frame, and what it's used for?
BTW, ext4_rmdir() should have also been modified to pass in dx_frame
when calling ext4_find_entry(). Right now with this patch, if the
last entry is a directory, when it's rmdir'ed, since ext4_rmdir()
doesn't have the plumbing to pass dx_frame to ext4_delete_entry(),
we'll end up leaving an empty directory entry on the directory entry.
Thanks,
- Ted
next prev parent reply other threads:[~2019-04-07 23:58 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-02-27 4:01 [PATCH v3] ext4: shrink directory when last block is empty harshadshirwadkar
2019-04-07 23:58 ` Theodore Ts'o [this message]
2019-08-13 0:24 ` harshad shirwadkar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190407235836.GA29128@mit.edu \
--to=tytso@mit.edu \
--cc=adilger@dilger.ca \
--cc=harshadshirwadkar@gmail.com \
--cc=linux-ext4@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).