summaryrefslogtreecommitdiffstats
path: root/src/kvstorage_server.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2011-11-25 19:31:59 +0300
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2011-11-25 19:31:59 +0300
commit8cff136c17d945280161d7f5224dc09341035bd9 (patch)
tree97d2a4fd93c8ffeb7b61a724e1b58eb91a3dd33f /src/kvstorage_server.c
parent8641ae433bc85df26be852a454500e1b7d7da76d (diff)
downloadrspamd-8cff136c17d945280161d7f5224dc09341035bd9.tar.gz
rspamd-8cff136c17d945280161d7f5224dc09341035bd9.zip
Try to fix a deadlock.
Diffstat (limited to 'src/kvstorage_server.c')
-rw-r--r--src/kvstorage_server.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/kvstorage_server.c b/src/kvstorage_server.c
index 3e4cedcf9..0eba6fcff 100644
--- a/src/kvstorage_server.c
+++ b/src/kvstorage_server.c
@@ -475,6 +475,7 @@ kvstorage_process_command (struct kvstorage_session *session, gboolean is_redis)
else if (session->command == KVSTORAGE_CMD_GET) {
elt = rspamd_kv_storage_lookup (session->cf->storage, session->key, session->keylen, session->now);
if (elt == NULL) {
+ g_static_rw_lock_reader_unlock (&session->cf->storage->rwlock);
if (!is_redis) {
return rspamd_dispatcher_write (session->dispather, ERROR_NOT_FOUND,
sizeof (ERROR_NOT_FOUND) - 1, FALSE, TRUE);
@@ -485,7 +486,6 @@ kvstorage_process_command (struct kvstorage_session *session, gboolean is_redis)
}
}
else {
- session->elt = elt;
if (elt->flags & KV_ELT_INTEGER) {
eltlen = rspamd_snprintf (intbuf, sizeof (intbuf), "%l", ELT_LONG (elt));
@@ -504,6 +504,7 @@ kvstorage_process_command (struct kvstorage_session *session, gboolean is_redis)
}
if (!rspamd_dispatcher_write (session->dispather, outbuf,
r, TRUE, FALSE)) {
+ g_static_rw_lock_reader_unlock (&session->cf->storage->rwlock);
return FALSE;
}
if (elt->flags & KV_ELT_INTEGER) {
@@ -518,6 +519,7 @@ kvstorage_process_command (struct kvstorage_session *session, gboolean is_redis)
return FALSE;
}
}
+ session->elt = elt;
if (!is_redis) {
res = rspamd_dispatcher_write (session->dispather, CRLF "END" CRLF,
sizeof (CRLF "END" CRLF) - 1, FALSE, TRUE);
@@ -895,7 +897,6 @@ kvstorage_write_socket (void *arg)
struct kvstorage_session *session = (struct kvstorage_session *) arg;
if (session->elt) {
-
if ((session->elt->flags & KV_ELT_NEED_INSERT) != 0) {
/* Insert to cache and free element */
session->elt->flags &= ~KV_ELT_NEED_INSERT;
@@ -930,6 +931,12 @@ kvstorage_err_socket (GError * err, void *arg)
thr_info ("%ud: abnormally closing connection from: %s, error: %s",
thr->id, inet_ntoa (session->client_addr), err->message);
}
+
+ if (session->elt) {
+ g_static_rw_lock_reader_unlock (&session->cf->storage->rwlock);
+ session->elt = NULL;
+ }
+
g_error_free (err);
free_kvstorage_session (session);
}