From: Gabriel Krisman Bertazi <gabriel@krisman.be>
To: "André Almeida" <andrealmeid@igalia.com>
Cc: Hugh Dickins <hughd@google.com>,
Andrew Morton <akpm@linux-foundation.org>,
Alexander Viro <viro@zeniv.linux.org.uk>,
Christian Brauner <brauner@kernel.org>, Jan Kara <jack@suse.cz>,
linux-mm@kvack.org, linux-kernel@vger.kernel.org,
linux-fsdevel@vger.kernel.org, kernel-dev@igalia.com,
Daniel Rosenberg <drosen@google.com>,
smcv@collabora.com, Christoph Hellwig <hch@lst.de>,
Theodore Ts'o <tytso@mit.edu>
Subject: Re: [PATCH v4 06/10] libfs: Export generic_ci_ dentry functions
Date: Thu, 12 Sep 2024 15:13:05 -0400 [thread overview]
Message-ID: <87r09ok7ni.fsf@mailhost.krisman.be> (raw)
In-Reply-To: <20240911144502.115260-7-andrealmeid@igalia.com> (=?utf-8?Q?=22Andr=C3=A9?= Almeida"'s message of "Wed, 11 Sep 2024 11:44:58 -0300")
André Almeida <andrealmeid@igalia.com> writes:
> Export generic_ci_ dentry functions so they can be used by
> case-insensitive filesystems that need something more custom than the
> default one set by `struct generic_ci_dentry_ops`.
>
> Signed-off-by: André Almeida <andrealmeid@igalia.com>
> ---
> Changes from v3:
> - New patch
> ---
> fs/libfs.c | 8 +++++---
> include/linux/fs.h | 3 +++
> 2 files changed, 8 insertions(+), 3 deletions(-)
>
> diff --git a/fs/libfs.c b/fs/libfs.c
> index 838524314b1b..c09254ecdcdd 100644
> --- a/fs/libfs.c
> +++ b/fs/libfs.c
> @@ -1783,8 +1783,8 @@ bool is_empty_dir_inode(struct inode *inode)
> *
> * Return: 0 if names match, 1 if mismatch, or -ERRNO
> */
> -static int generic_ci_d_compare(const struct dentry *dentry, unsigned int len,
> - const char *str, const struct qstr *name)
> +int generic_ci_d_compare(const struct dentry *dentry, unsigned int len,
> + const char *str, const struct qstr *name)
> {
> const struct dentry *parent;
> const struct inode *dir;
> @@ -1827,6 +1827,7 @@ static int generic_ci_d_compare(const struct dentry *dentry, unsigned int len,
>
> return utf8_strncasecmp(dentry->d_sb->s_encoding, name, &qstr);
> }
> +EXPORT_SYMBOL(generic_ci_d_compare);
>
> /**
> * generic_ci_d_hash - generic d_hash implementation for casefolding filesystems
> @@ -1835,7 +1836,7 @@ static int generic_ci_d_compare(const struct dentry *dentry, unsigned int len,
> *
> * Return: 0 if hash was successful or unchanged, and -EINVAL on error
> */
> -static int generic_ci_d_hash(const struct dentry *dentry, struct qstr *str)
> +int generic_ci_d_hash(const struct dentry *dentry, struct qstr *str)
> {
> const struct inode *dir = READ_ONCE(dentry->d_inode);
> struct super_block *sb = dentry->d_sb;
> @@ -1850,6 +1851,7 @@ static int generic_ci_d_hash(const struct dentry *dentry, struct qstr *str)
> return -EINVAL;
> return 0;
> }
> +EXPORT_SYMBOL(generic_ci_d_hash);
>
> static const struct dentry_operations generic_ci_dentry_ops = {
> .d_hash = generic_ci_d_hash,
> diff --git a/include/linux/fs.h b/include/linux/fs.h
> index 937142950dfe..4cd86d36c03d 100644
> --- a/include/linux/fs.h
> +++ b/include/linux/fs.h
> @@ -3386,6 +3386,9 @@ extern int generic_ci_match(const struct inode *parent,
> const struct qstr *folded_name,
> const u8 *de_name, u32 de_name_len);
> bool generic_ci_validate_strict_name(struct inode *dir, struct qstr *name);
> +int generic_ci_d_hash(const struct dentry *dentry, struct qstr *str);
> +int generic_ci_d_compare(const struct dentry *dentry, unsigned int len,
> + const char *str, const struct qstr *name);
guard these with:
#if IS_ENABLED(CONFIG_UNICODE)
#endif
>
> static inline bool sb_has_encoding(const struct super_block *sb)
> {
--
Gabriel Krisman Bertazi
next prev parent reply other threads:[~2024-09-12 19:13 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-11 14:44 [PATCH v4 00/10] tmpfs: Add case-insensitive support for tmpfs André Almeida
2024-09-11 14:44 ` [PATCH v4 01/10] libfs: Create the helper function generic_ci_validate_strict_name() André Almeida
2024-09-12 19:16 ` Gabriel Krisman Bertazi
2024-09-11 14:44 ` [PATCH v4 02/10] ext4: Use generic_ci_validate_strict_name helper André Almeida
2024-09-12 19:14 ` Gabriel Krisman Bertazi
2024-09-11 14:44 ` [PATCH v4 03/10] unicode: Recreate utf8_parse_version() André Almeida
2024-09-12 19:14 ` Gabriel Krisman Bertazi
2024-09-11 14:44 ` [PATCH v4 04/10] unicode: Export latest available UTF-8 version number André Almeida
2024-09-11 14:44 ` [PATCH v4 05/10] libfs: Check for casefold dirs on simple_lookup() André Almeida
2024-09-11 14:44 ` [PATCH v4 06/10] libfs: Export generic_ci_ dentry functions André Almeida
2024-09-12 19:13 ` Gabriel Krisman Bertazi [this message]
2024-09-11 14:44 ` [PATCH v4 07/10] tmpfs: Add casefold lookup support André Almeida
2024-09-12 19:04 ` Gabriel Krisman Bertazi
2024-10-02 1:40 ` André Almeida
2024-10-02 21:29 ` Gabriel Krisman Bertazi
2024-09-13 16:28 ` kernel test robot
2024-09-13 18:25 ` kernel test robot
2024-09-11 14:45 ` [PATCH v4 08/10] tmpfs: Add flag FS_CASEFOLD_FL support for tmpfs dirs André Almeida
2024-09-12 19:10 ` Gabriel Krisman Bertazi
2024-09-11 14:45 ` [PATCH v4 09/10] tmpfs: Expose filesystem features via sysfs André Almeida
2024-09-12 19:07 ` Gabriel Krisman Bertazi
2024-09-11 14:45 ` [PATCH v4 10/10] docs: tmpfs: Add casefold options André Almeida
2024-09-12 19:07 ` Gabriel Krisman Bertazi
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=87r09ok7ni.fsf@mailhost.krisman.be \
--to=gabriel@krisman.be \
--cc=akpm@linux-foundation.org \
--cc=andrealmeid@igalia.com \
--cc=brauner@kernel.org \
--cc=drosen@google.com \
--cc=hch@lst.de \
--cc=hughd@google.com \
--cc=jack@suse.cz \
--cc=kernel-dev@igalia.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=smcv@collabora.com \
--cc=tytso@mit.edu \
--cc=viro@zeniv.linux.org.uk \
/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