summaryrefslogtreecommitdiffstats
path: root/xlators
diff options
context:
space:
mode:
Diffstat (limited to 'xlators')
-rw-r--r--xlators/protocol/server/src/server-handshake.c7
-rw-r--r--xlators/protocol/server/src/server.c4
2 files changed, 9 insertions, 2 deletions
diff --git a/xlators/protocol/server/src/server-handshake.c b/xlators/protocol/server/src/server-handshake.c
index 7761f78c474..5f6830a0551 100644
--- a/xlators/protocol/server/src/server-handshake.c
+++ b/xlators/protocol/server/src/server-handshake.c
@@ -664,6 +664,13 @@ fail:
rsp.op_ret = op_ret;
rsp.op_errno = gf_errno_to_error (op_errno);
+ /* if bound_xl is NULL or something fails, then put the connection
+ * back. Otherwise the connection would have been added to the
+ * list of connections the server is maintaining and might segfault
+ * during statedump when bound_xl of the connection is accessed.
+ */
+ if (op_ret && conn)
+ server_connection_put (this, conn, NULL);
server_submit_reply (NULL, req, &rsp, NULL, 0, NULL,
(xdrproc_t)xdr_gf_setvolume_rsp);
diff --git a/xlators/protocol/server/src/server.c b/xlators/protocol/server/src/server.c
index 4f6527fa46e..5e20bf34ea3 100644
--- a/xlators/protocol/server/src/server.c
+++ b/xlators/protocol/server/src/server.c
@@ -307,7 +307,7 @@ ltable_dump (server_connection_t *trav)
gf_proc_dump_build_key(key,
"conn","bound_xl.ltable.inodelk.%s",
- trav->bound_xl->name);
+ trav->bound_xl?trav->bound_xl->name:"");
gf_proc_dump_add_section(key);
list_for_each_entry (locker, &trav->ltable->inodelk_lockers, lockers) {
@@ -341,7 +341,7 @@ ltable_dump (server_connection_t *trav)
locker = NULL;
gf_proc_dump_build_key(key,
"conn","bound_xl.ltable.entrylk.%s",
- trav->bound_xl->name);
+ trav->bound_xl?trav->bound_xl->name:"");
gf_proc_dump_add_section(key);
list_for_each_entry (locker, &trav->ltable->entrylk_lockers,