On Fri, Aug 17, 2012 at 9:50 AM, Sage Weil <[email protected]> wrote:
> The debugfs directory includes the cluster fsid and our unique global_id.
> We need to delay the initialization of the debug entry until we have
> learned both the fsid and our global_id from the monitor or else the
> second client can't create its debugfs entry and will fail (and multiple
> client instances aren't properly reflected in debugfs).
>
> Reported by: Yan, Zheng <[email protected]>
> Signed-off-by: Sage Weil <[email protected]>
> ---
> fs/ceph/debugfs.c | 1 +
> net/ceph/ceph_common.c | 1 -
> net/ceph/debugfs.c | 4 +++
> net/ceph/mon_client.c | 49 +++++++++++++++++++++++++++++++++++++++++++----
> 4 files changed, 49 insertions(+), 6 deletions(-)
>
> diff --git a/fs/ceph/debugfs.c b/fs/ceph/debugfs.c
> index fb962ef..6d59006 100644
> --- a/fs/ceph/debugfs.c
> +++ b/fs/ceph/debugfs.c
> @@ -201,6 +201,7 @@ int ceph_fs_debugfs_init(struct ceph_fs_client *fsc)
> int err = -ENOMEM;
>
> dout("ceph_fs_debugfs_init\n");
> + BUG_ON(!fsc->client->debugfs_dir);
> fsc->debugfs_congestion_kb =
> debugfs_create_file("writeback_congestion_kb",
> 0600,
> diff --git a/net/ceph/ceph_common.c b/net/ceph/ceph_common.c
> index 69e38db..a802029 100644
> --- a/net/ceph/ceph_common.c
> +++ b/net/ceph/ceph_common.c
> @@ -84,7 +84,6 @@ int ceph_check_fsid(struct ceph_client *client, struct
> ceph_fsid *fsid)
> return -1;
> }
> } else {
> - pr_info("client%lld fsid %pU\n", ceph_client_id(client),
> fsid);
> memcpy(&client->fsid, fsid, sizeof(*fsid));
> }
> return 0;
> diff --git a/net/ceph/debugfs.c b/net/ceph/debugfs.c
> index 54b531a..38b5dc1 100644
> --- a/net/ceph/debugfs.c
> +++ b/net/ceph/debugfs.c
> @@ -189,6 +189,9 @@ int ceph_debugfs_client_init(struct ceph_client *client)
> snprintf(name, sizeof(name), "%pU.client%lld", &client->fsid,
> client->monc.auth->global_id);
>
> + dout("ceph_debugfs_client_init %p %s\n", client, name);
> +
> + BUG_ON(client->debugfs_dir);
> client->debugfs_dir = debugfs_create_dir(name, ceph_debugfs_dir);
> if (!client->debugfs_dir)
> goto out;
> @@ -234,6 +237,7 @@ out:
>
> void ceph_debugfs_client_cleanup(struct ceph_client *client)
> {
> + dout("ceph_debugfs_client_cleanup %p\n", client);
> debugfs_remove(client->debugfs_osdmap);
> debugfs_remove(client->debugfs_monmap);
> debugfs_remove(client->osdc.debugfs_file);
> diff --git a/net/ceph/mon_client.c b/net/ceph/mon_client.c
> index 105d533..b9f412d 100644
> --- a/net/ceph/mon_client.c
> +++ b/net/ceph/mon_client.c
> @@ -311,6 +311,17 @@ int ceph_monc_open_session(struct ceph_mon_client *monc)
> EXPORT_SYMBOL(ceph_monc_open_session);
>
> /*
> + * We require the fsid and global_id in order to initialize our
> + * debugfs dir.
> + */
> +static bool have_debugfs_info(struct ceph_mon_client *monc)
> +{
> + dout("have_debugfs_info fsid %d globalid %lld\n",
> + (int)monc->client->have_fsid, monc->auth->global_id);
> + return monc->client->have_fsid && monc->auth->global_id > 0;
> +}
> +
> +/*
> * The monitor responds with mount ack indicate mount success. The
> * included client ticket allows the client to talk to MDSs and OSDs.
> */
> @@ -320,9 +331,12 @@ static void ceph_monc_handle_map(struct ceph_mon_client
> *monc,
> struct ceph_client *client = monc->client;
> struct ceph_monmap *monmap = NULL, *old = monc->monmap;
> void *p, *end;
> + int had_debugfs_info, init_debugfs = 0;
>
> mutex_lock(&monc->mutex);
>
> + had_debugfs_info = have_debugfs_info(monc);
> +
> dout("handle_monmap\n");
> p = msg->front.iov_base;
> end = p + msg->front.iov_len;
> @@ -344,12 +358,21 @@ static void ceph_monc_handle_map(struct ceph_mon_client
> *monc,
>
> if (!client->have_fsid) {
> client->have_fsid = true;
> + if (!had_debugfs_info && have_debugfs_info(monc)) {
> + pr_info("client%lld fsid %pU\n",
> + ceph_client_id(monc->client),
> + &monc->client->fsid);
> + init_debugfs = 1;
> + }
> mutex_unlock(&monc->mutex);
> - /*
> - * do debugfs initialization without mutex to avoid
> - * creating a locking dependency
> - */
> - ceph_debugfs_client_init(client);
> +
> + if (init_debugfs)
You should really add brackets here
> + /*
> + * do debugfs initialization without mutex to avoid
> + * creating a locking dependency
> + */
> + ceph_debugfs_client_init(monc->client);
> +
> goto out_unlocked;
> }
> out:
> @@ -865,8 +888,10 @@ static void handle_auth_reply(struct ceph_mon_client
> *monc,
> {
> int ret;
> int was_auth = 0;
> + int had_debugfs_info, init_debugfs = 0;
>
> mutex_lock(&monc->mutex);
> + had_debugfs_info = have_debugfs_info(monc);
> if (monc->auth->ops)
> was_auth = monc->auth->ops->is_authenticated(monc->auth);
> monc->pending_auth = 0;
> @@ -889,7 +914,21 @@ static void handle_auth_reply(struct ceph_mon_client
> *monc,
> __send_subscribe(monc);
> __resend_generic_request(monc);
> }
> +
> + if (!had_debugfs_info && have_debugfs_info(monc)) {
> + pr_info("client%lld fsid %pU\n",
> + ceph_client_id(monc->client),
> + &monc->client->fsid);
> + init_debugfs = 1;
> + }
> mutex_unlock(&monc->mutex);
> +
> + if (init_debugfs)
Same here
> + /*
> + * do debugfs initialization without mutex to avoid
> + * creating a locking dependency
> + */
> + ceph_debugfs_client_init(monc->client);
> }
>
> static int __validate_auth(struct ceph_mon_client *monc)
> --
> 1.7.9
>
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to [email protected]
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html