From: Luis Henriques <lhenriques@suse.de>
To: Jeff Layton <jlayton@kernel.org>
Cc: ceph-devel@vger.kernel.org, idryomov@gmail.com
Subject: Re: [PATCH] ceph: add a new vxattr to return auth mds for an inode
Date: Tue, 27 Jul 2021 15:46:30 +0100 [thread overview]
Message-ID: <YQAcRqN4FIuhjXUy@suse.de> (raw)
In-Reply-To: <20210727113509.7714-1-jlayton@kernel.org>
On Tue, Jul 27, 2021 at 07:35:09AM -0400, Jeff Layton wrote:
> Add a new vxattr that shows what MDS is authoritative for an inode (if
> we happen to have auth caps). If we don't have an auth cap for the inode
> then just return -1.
>
> URL: https://tracker.ceph.com/issues/1276
> Signed-off-by: Jeff Layton <jlayton@kernel.org>
> ---
> fs/ceph/xattr.c | 16 ++++++++++++++++
> 1 file changed, 16 insertions(+)
>
> diff --git a/fs/ceph/xattr.c b/fs/ceph/xattr.c
> index 1242db8d3444..70664a19b8dc 100644
> --- a/fs/ceph/xattr.c
> +++ b/fs/ceph/xattr.c
> @@ -340,6 +340,15 @@ static ssize_t ceph_vxattrcb_caps(struct ceph_inode_info *ci, char *val,
> ceph_cap_string(issued), issued);
> }
>
> +static ssize_t ceph_vxattrcb_auth_mds(struct ceph_inode_info *ci,
> + char *val, size_t size)
> +{
> + /* return -1 if we don't have auth caps (and thus can't tell) */
> + if (!ci->i_auth_cap)
> + return ceph_fmt_xattr(val, size, "-1");
I don't really have an opinion on this as I don't have a usecase for this
xattr (other than debug, of course). But I just checked a similar function
ceph_vxattrcb_layout_pool_namespace() and, if there's no value for ns for an
inode, it just returns 0.
Anyway, just my 5c, as I'm OK with returning a '-1' string too.
Cheers,
--
Luís
> + return ceph_fmt_xattr(val, size, "%d", ci->i_auth_cap->session->s_mds);
> +}
> +
> #define CEPH_XATTR_NAME(_type, _name) XATTR_CEPH_PREFIX #_type "." #_name
> #define CEPH_XATTR_NAME2(_type, _name, _name2) \
> XATTR_CEPH_PREFIX #_type "." #_name "." #_name2
> @@ -473,6 +482,13 @@ static struct ceph_vxattr ceph_common_vxattrs[] = {
> .exists_cb = NULL,
> .flags = VXATTR_FLAG_READONLY,
> },
> + {
> + .name = "ceph.auth_mds",
> + .name_size = sizeof("ceph.auth_mds"),
> + .getxattr_cb = ceph_vxattrcb_auth_mds,
> + .exists_cb = NULL,
> + .flags = VXATTR_FLAG_READONLY,
> + },
> { .name = NULL, 0 } /* Required table terminator */
> };
>
> --
> 2.31.1
>
next prev parent reply other threads:[~2021-07-27 14:55 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-27 11:35 [PATCH] ceph: add a new vxattr to return auth mds for an inode Jeff Layton
2021-07-27 14:46 ` Luis Henriques [this message]
2021-07-27 15:17 ` Jeff Layton
2021-07-27 15:45 ` Luis Henriques
2021-07-27 15:53 ` Jeff Layton
2021-07-27 18:42 ` [PATCH v2] " Jeff Layton
2021-07-28 10:28 ` Luis Henriques
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=YQAcRqN4FIuhjXUy@suse.de \
--to=lhenriques@suse.de \
--cc=ceph-devel@vger.kernel.org \
--cc=idryomov@gmail.com \
--cc=jlayton@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.