Commit 4972cf60 authored by Ilya Dryomov's avatar Ilya Dryomov

libceph, ceph: disambiguate ceph_connection_operations handlers

Since a few years, kernel addresses are no longer included in oops
dumps, at least on x86.  All we get is a symbol name with offset and
size.

This is a problem for ceph_connection_operations handlers, especially
con->ops->dispatch().  All three handlers have the same name and there
is little context to disambiguate between e.g. monitor and OSD clients
because almost everything is inlined.  gdb sneakily stops at the first
matching symbol, so one has to resort to nm and addr2line.

Some of these are already prefixed with mon_, osd_ or mds_.  Let's do
the same for all others.
Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
Acked-by: default avatarJeff Layton <jlayton@kernel.org>
parent 10f42b3e
...@@ -5038,7 +5038,7 @@ void ceph_mdsc_handle_mdsmap(struct ceph_mds_client *mdsc, struct ceph_msg *msg) ...@@ -5038,7 +5038,7 @@ void ceph_mdsc_handle_mdsmap(struct ceph_mds_client *mdsc, struct ceph_msg *msg)
return; return;
} }
static struct ceph_connection *con_get(struct ceph_connection *con) static struct ceph_connection *mds_get_con(struct ceph_connection *con)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
...@@ -5047,7 +5047,7 @@ static struct ceph_connection *con_get(struct ceph_connection *con) ...@@ -5047,7 +5047,7 @@ static struct ceph_connection *con_get(struct ceph_connection *con)
return NULL; return NULL;
} }
static void con_put(struct ceph_connection *con) static void mds_put_con(struct ceph_connection *con)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
...@@ -5058,7 +5058,7 @@ static void con_put(struct ceph_connection *con) ...@@ -5058,7 +5058,7 @@ static void con_put(struct ceph_connection *con)
* if the client is unresponsive for long enough, the mds will kill * if the client is unresponsive for long enough, the mds will kill
* the session entirely. * the session entirely.
*/ */
static void peer_reset(struct ceph_connection *con) static void mds_peer_reset(struct ceph_connection *con)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
struct ceph_mds_client *mdsc = s->s_mdsc; struct ceph_mds_client *mdsc = s->s_mdsc;
...@@ -5067,7 +5067,7 @@ static void peer_reset(struct ceph_connection *con) ...@@ -5067,7 +5067,7 @@ static void peer_reset(struct ceph_connection *con)
send_mds_reconnect(mdsc, s); send_mds_reconnect(mdsc, s);
} }
static void dispatch(struct ceph_connection *con, struct ceph_msg *msg) static void mds_dispatch(struct ceph_connection *con, struct ceph_msg *msg)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
struct ceph_mds_client *mdsc = s->s_mdsc; struct ceph_mds_client *mdsc = s->s_mdsc;
...@@ -5125,8 +5125,8 @@ static void dispatch(struct ceph_connection *con, struct ceph_msg *msg) ...@@ -5125,8 +5125,8 @@ static void dispatch(struct ceph_connection *con, struct ceph_msg *msg)
* Note: returned pointer is the address of a structure that's * Note: returned pointer is the address of a structure that's
* managed separately. Caller must *not* attempt to free it. * managed separately. Caller must *not* attempt to free it.
*/ */
static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con, static struct ceph_auth_handshake *
int *proto, int force_new) mds_get_authorizer(struct ceph_connection *con, int *proto, int force_new)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
struct ceph_mds_client *mdsc = s->s_mdsc; struct ceph_mds_client *mdsc = s->s_mdsc;
...@@ -5142,7 +5142,7 @@ static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con, ...@@ -5142,7 +5142,7 @@ static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con,
return auth; return auth;
} }
static int add_authorizer_challenge(struct ceph_connection *con, static int mds_add_authorizer_challenge(struct ceph_connection *con,
void *challenge_buf, int challenge_buf_len) void *challenge_buf, int challenge_buf_len)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
...@@ -5153,7 +5153,7 @@ static int add_authorizer_challenge(struct ceph_connection *con, ...@@ -5153,7 +5153,7 @@ static int add_authorizer_challenge(struct ceph_connection *con,
challenge_buf, challenge_buf_len); challenge_buf, challenge_buf_len);
} }
static int verify_authorizer_reply(struct ceph_connection *con) static int mds_verify_authorizer_reply(struct ceph_connection *con)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
struct ceph_mds_client *mdsc = s->s_mdsc; struct ceph_mds_client *mdsc = s->s_mdsc;
...@@ -5165,7 +5165,7 @@ static int verify_authorizer_reply(struct ceph_connection *con) ...@@ -5165,7 +5165,7 @@ static int verify_authorizer_reply(struct ceph_connection *con)
NULL, NULL, NULL, NULL); NULL, NULL, NULL, NULL);
} }
static int invalidate_authorizer(struct ceph_connection *con) static int mds_invalidate_authorizer(struct ceph_connection *con)
{ {
struct ceph_mds_session *s = con->private; struct ceph_mds_session *s = con->private;
struct ceph_mds_client *mdsc = s->s_mdsc; struct ceph_mds_client *mdsc = s->s_mdsc;
...@@ -5288,15 +5288,15 @@ static int mds_check_message_signature(struct ceph_msg *msg) ...@@ -5288,15 +5288,15 @@ static int mds_check_message_signature(struct ceph_msg *msg)
} }
static const struct ceph_connection_operations mds_con_ops = { static const struct ceph_connection_operations mds_con_ops = {
.get = con_get, .get = mds_get_con,
.put = con_put, .put = mds_put_con,
.dispatch = dispatch,
.get_authorizer = get_authorizer,
.add_authorizer_challenge = add_authorizer_challenge,
.verify_authorizer_reply = verify_authorizer_reply,
.invalidate_authorizer = invalidate_authorizer,
.peer_reset = peer_reset,
.alloc_msg = mds_alloc_msg, .alloc_msg = mds_alloc_msg,
.dispatch = mds_dispatch,
.peer_reset = mds_peer_reset,
.get_authorizer = mds_get_authorizer,
.add_authorizer_challenge = mds_add_authorizer_challenge,
.verify_authorizer_reply = mds_verify_authorizer_reply,
.invalidate_authorizer = mds_invalidate_authorizer,
.sign_message = mds_sign_message, .sign_message = mds_sign_message,
.check_message_signature = mds_check_message_signature, .check_message_signature = mds_check_message_signature,
.get_auth_request = mds_get_auth_request, .get_auth_request = mds_get_auth_request,
......
...@@ -1433,7 +1433,7 @@ static int mon_handle_auth_bad_method(struct ceph_connection *con, ...@@ -1433,7 +1433,7 @@ static int mon_handle_auth_bad_method(struct ceph_connection *con,
/* /*
* handle incoming message * handle incoming message
*/ */
static void dispatch(struct ceph_connection *con, struct ceph_msg *msg) static void mon_dispatch(struct ceph_connection *con, struct ceph_msg *msg)
{ {
struct ceph_mon_client *monc = con->private; struct ceph_mon_client *monc = con->private;
int type = le16_to_cpu(msg->hdr.type); int type = le16_to_cpu(msg->hdr.type);
...@@ -1565,21 +1565,21 @@ static void mon_fault(struct ceph_connection *con) ...@@ -1565,21 +1565,21 @@ static void mon_fault(struct ceph_connection *con)
* will come from the messenger workqueue, which is drained prior to * will come from the messenger workqueue, which is drained prior to
* mon_client destruction. * mon_client destruction.
*/ */
static struct ceph_connection *con_get(struct ceph_connection *con) static struct ceph_connection *mon_get_con(struct ceph_connection *con)
{ {
return con; return con;
} }
static void con_put(struct ceph_connection *con) static void mon_put_con(struct ceph_connection *con)
{ {
} }
static const struct ceph_connection_operations mon_con_ops = { static const struct ceph_connection_operations mon_con_ops = {
.get = con_get, .get = mon_get_con,
.put = con_put, .put = mon_put_con,
.dispatch = dispatch,
.fault = mon_fault,
.alloc_msg = mon_alloc_msg, .alloc_msg = mon_alloc_msg,
.dispatch = mon_dispatch,
.fault = mon_fault,
.get_auth_request = mon_get_auth_request, .get_auth_request = mon_get_auth_request,
.handle_auth_reply_more = mon_handle_auth_reply_more, .handle_auth_reply_more = mon_handle_auth_reply_more,
.handle_auth_done = mon_handle_auth_done, .handle_auth_done = mon_handle_auth_done,
......
...@@ -5412,7 +5412,7 @@ void ceph_osdc_cleanup(void) ...@@ -5412,7 +5412,7 @@ void ceph_osdc_cleanup(void)
/* /*
* handle incoming message * handle incoming message
*/ */
static void dispatch(struct ceph_connection *con, struct ceph_msg *msg) static void osd_dispatch(struct ceph_connection *con, struct ceph_msg *msg)
{ {
struct ceph_osd *osd = con->private; struct ceph_osd *osd = con->private;
struct ceph_osd_client *osdc = osd->o_osdc; struct ceph_osd_client *osdc = osd->o_osdc;
...@@ -5534,9 +5534,9 @@ static struct ceph_msg *alloc_msg_with_page_vector(struct ceph_msg_header *hdr) ...@@ -5534,9 +5534,9 @@ static struct ceph_msg *alloc_msg_with_page_vector(struct ceph_msg_header *hdr)
return m; return m;
} }
static struct ceph_msg *alloc_msg(struct ceph_connection *con, static struct ceph_msg *osd_alloc_msg(struct ceph_connection *con,
struct ceph_msg_header *hdr, struct ceph_msg_header *hdr,
int *skip) int *skip)
{ {
struct ceph_osd *osd = con->private; struct ceph_osd *osd = con->private;
int type = le16_to_cpu(hdr->type); int type = le16_to_cpu(hdr->type);
...@@ -5560,7 +5560,7 @@ static struct ceph_msg *alloc_msg(struct ceph_connection *con, ...@@ -5560,7 +5560,7 @@ static struct ceph_msg *alloc_msg(struct ceph_connection *con,
/* /*
* Wrappers to refcount containing ceph_osd struct * Wrappers to refcount containing ceph_osd struct
*/ */
static struct ceph_connection *get_osd_con(struct ceph_connection *con) static struct ceph_connection *osd_get_con(struct ceph_connection *con)
{ {
struct ceph_osd *osd = con->private; struct ceph_osd *osd = con->private;
if (get_osd(osd)) if (get_osd(osd))
...@@ -5568,7 +5568,7 @@ static struct ceph_connection *get_osd_con(struct ceph_connection *con) ...@@ -5568,7 +5568,7 @@ static struct ceph_connection *get_osd_con(struct ceph_connection *con)
return NULL; return NULL;
} }
static void put_osd_con(struct ceph_connection *con) static void osd_put_con(struct ceph_connection *con)
{ {
struct ceph_osd *osd = con->private; struct ceph_osd *osd = con->private;
put_osd(osd); put_osd(osd);
...@@ -5582,8 +5582,8 @@ static void put_osd_con(struct ceph_connection *con) ...@@ -5582,8 +5582,8 @@ static void put_osd_con(struct ceph_connection *con)
* Note: returned pointer is the address of a structure that's * Note: returned pointer is the address of a structure that's
* managed separately. Caller must *not* attempt to free it. * managed separately. Caller must *not* attempt to free it.
*/ */
static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con, static struct ceph_auth_handshake *
int *proto, int force_new) osd_get_authorizer(struct ceph_connection *con, int *proto, int force_new)
{ {
struct ceph_osd *o = con->private; struct ceph_osd *o = con->private;
struct ceph_osd_client *osdc = o->o_osdc; struct ceph_osd_client *osdc = o->o_osdc;
...@@ -5599,7 +5599,7 @@ static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con, ...@@ -5599,7 +5599,7 @@ static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con,
return auth; return auth;
} }
static int add_authorizer_challenge(struct ceph_connection *con, static int osd_add_authorizer_challenge(struct ceph_connection *con,
void *challenge_buf, int challenge_buf_len) void *challenge_buf, int challenge_buf_len)
{ {
struct ceph_osd *o = con->private; struct ceph_osd *o = con->private;
...@@ -5610,7 +5610,7 @@ static int add_authorizer_challenge(struct ceph_connection *con, ...@@ -5610,7 +5610,7 @@ static int add_authorizer_challenge(struct ceph_connection *con,
challenge_buf, challenge_buf_len); challenge_buf, challenge_buf_len);
} }
static int verify_authorizer_reply(struct ceph_connection *con) static int osd_verify_authorizer_reply(struct ceph_connection *con)
{ {
struct ceph_osd *o = con->private; struct ceph_osd *o = con->private;
struct ceph_osd_client *osdc = o->o_osdc; struct ceph_osd_client *osdc = o->o_osdc;
...@@ -5622,7 +5622,7 @@ static int verify_authorizer_reply(struct ceph_connection *con) ...@@ -5622,7 +5622,7 @@ static int verify_authorizer_reply(struct ceph_connection *con)
NULL, NULL, NULL, NULL); NULL, NULL, NULL, NULL);
} }
static int invalidate_authorizer(struct ceph_connection *con) static int osd_invalidate_authorizer(struct ceph_connection *con)
{ {
struct ceph_osd *o = con->private; struct ceph_osd *o = con->private;
struct ceph_osd_client *osdc = o->o_osdc; struct ceph_osd_client *osdc = o->o_osdc;
...@@ -5731,18 +5731,18 @@ static int osd_check_message_signature(struct ceph_msg *msg) ...@@ -5731,18 +5731,18 @@ static int osd_check_message_signature(struct ceph_msg *msg)
} }
static const struct ceph_connection_operations osd_con_ops = { static const struct ceph_connection_operations osd_con_ops = {
.get = get_osd_con, .get = osd_get_con,
.put = put_osd_con, .put = osd_put_con,
.dispatch = dispatch, .alloc_msg = osd_alloc_msg,
.get_authorizer = get_authorizer, .dispatch = osd_dispatch,
.add_authorizer_challenge = add_authorizer_challenge, .fault = osd_fault,
.verify_authorizer_reply = verify_authorizer_reply,
.invalidate_authorizer = invalidate_authorizer,
.alloc_msg = alloc_msg,
.reencode_message = osd_reencode_message, .reencode_message = osd_reencode_message,
.get_authorizer = osd_get_authorizer,
.add_authorizer_challenge = osd_add_authorizer_challenge,
.verify_authorizer_reply = osd_verify_authorizer_reply,
.invalidate_authorizer = osd_invalidate_authorizer,
.sign_message = osd_sign_message, .sign_message = osd_sign_message,
.check_message_signature = osd_check_message_signature, .check_message_signature = osd_check_message_signature,
.fault = osd_fault,
.get_auth_request = osd_get_auth_request, .get_auth_request = osd_get_auth_request,
.handle_auth_reply_more = osd_handle_auth_reply_more, .handle_auth_reply_more = osd_handle_auth_reply_more,
.handle_auth_done = osd_handle_auth_done, .handle_auth_done = osd_handle_auth_done,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment