Fix lock handling in memory hander of nscd.
authorPetr Baudis <pasky@suse.cz>
Thu, 16 Jul 2009 17:10:10 +0000 (10:10 -0700)
committerUlrich Drepper <drepper@redhat.com>
Thu, 16 Jul 2009 17:10:10 +0000 (10:10 -0700)
The commit 20e498bd removes the pthread_mutex_rdlock() calls, but not the
corresponding pthread_mutex_unlock() calls. Also, the database lock is never
unlocked in one branch of the mempool_alloc() if.

I think unreproducible random assert(dh->usable) crashes in prune_cache() were
caused by this. But an easy way to make nscd threads hang with the broken
locking was.

ChangeLog
nscd/aicache.c
nscd/grpcache.c
nscd/hstcache.c
nscd/initgrcache.c
nscd/mem.c
nscd/pwdcache.c
nscd/servicescache.c

index a81c5b4..37f20a4 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,13 @@
+2009-07-16  Petr Baudis  <pasky@suse.cz>
+
+       * nscd/mem.c (mempool_alloc): Fix unlock missing in the else branch.
+       * nscd/aicache.c: Remove bogus db->lock unlock.
+       * nscd/grpcache.c: Likewise.
+       * nscd/hstcache.c: Likewise.
+       * nscd/initgrcache.c: Likewise.
+       * nscd/pwdcache.c: Likewise.
+       * nscd/servicescache.c: Likewise.
+
 2009-07-16  Ulrich Drepper  <drepper@redhat.com>
 
        * nscd/cache.c (cache_add): Use atomic_compare_and_exchange_bool_rel
@@ -5,6 +15,7 @@
        is written before the list head update.
        Patch by Andreas Schwab <aschwab@redhat.com>.
 
+2009-07-16  Ulrich Drepper  <drepper@redhat.com>
            Jakub Jelinek  <jakub@redhat.com>
 
        * malloc/malloc.c [ATOMIC_FASTBINS] (_int_free): Make check for
index 524c0a6..8dac48e 100644 (file)
@@ -543,8 +543,6 @@ next_nip:
       (void) cache_add (req->type, key_copy, req->key_len, &dataset->head,
                        true, db, uid, he == NULL);
 
-      pthread_rwlock_unlock (&db->lock);
-
       /* Mark the old entry as obsolete.  */
       if (dh != NULL)
        dh->usable = false;
index 184d538..fc20084 100644 (file)
@@ -146,8 +146,6 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
              (void) cache_add (req->type, &dataset->strdata, req->key_len,
                                &dataset->head, true, db, owner, he == NULL);
 
-             pthread_rwlock_unlock (&db->lock);
-
              /* Mark the old entry as obsolete.  */
              if (dh != NULL)
                dh->usable = false;
@@ -367,12 +365,10 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
                (void) cache_add (GETGRBYGID, cp, key_offset, &dataset->head,
                                  false, db, owner, false);
            }
-
-       out:
-         pthread_rwlock_unlock (&db->lock);
        }
     }
 
+out:
   if (__builtin_expect (written != total, 0) && debug_level > 0)
     {
       char buf[256];
index 51e2273..77ffcdf 100644 (file)
@@ -153,8 +153,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
              (void) cache_add (req->type, &dataset->strdata, req->key_len,
                                &dataset->head, true, db, owner, he == NULL);
 
-             pthread_rwlock_unlock (&db->lock);
-
              /* Mark the old entry as obsolete.  */
              if (dh != NULL)
                dh->usable = false;
@@ -404,8 +402,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
 
          (void) cache_add (req->type, key_copy, req->key_len,
                            &dataset->head, true, db, owner, he == NULL);
-
-         pthread_rwlock_unlock (&db->lock);
        }
     }
 
index c33aaf3..f8d4742 100644 (file)
@@ -230,8 +230,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
              (void) cache_add (req->type, key_copy, req->key_len,
                                &dataset->head, true, db, uid, he == NULL);
 
-             pthread_rwlock_unlock (&db->lock);
-
              /* Mark the old entry as obsolete.  */
              if (dh != NULL)
                dh->usable = false;
@@ -388,8 +386,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
 
          (void) cache_add (INITGROUPS, cp, req->key_len, &dataset->head, true,
                            db, uid, he == NULL);
-
-         pthread_rwlock_unlock (&db->lock);
        }
     }
 
index fcea6db..80ea951 100644 (file)
@@ -566,9 +566,6 @@ mempool_alloc (struct database_dyn *db, size_t len, int data_alloc)
            }
        }
 
-      if (data_alloc)
-       pthread_rwlock_unlock (&db->lock);
-
       if (! db->last_alloc_failed)
        {
          dbg_log (_("no more memory for database '%s'"), dbnames[db - dbs]);
@@ -591,5 +588,8 @@ mempool_alloc (struct database_dyn *db, size_t len, int data_alloc)
 
   pthread_mutex_unlock (&db->memlock);
 
+  if (data_alloc)
+    pthread_rwlock_unlock (&db->lock);
+
   return res;
 }
index 2338e7e..fc5b44e 100644 (file)
@@ -153,8 +153,6 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
              (void) cache_add (req->type, key_copy, req->key_len,
                                &dataset->head, true, db, owner, he == NULL);
 
-             pthread_rwlock_unlock (&db->lock);
-
              /* Mark the old entry as obsolete.  */
              if (dh != NULL)
                dh->usable = false;
@@ -362,12 +360,10 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
                (void) cache_add (GETPWBYUID, cp, key_offset, &dataset->head,
                                  false, db, owner, false);
            }
-
-       out:
-         pthread_rwlock_unlock (&db->lock);
        }
     }
 
+out:
   if (__builtin_expect (written != total, 0) && debug_level > 0)
     {
       char buf[256];
index dc98d30..c965c97 100644 (file)
@@ -136,8 +136,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
              (void) cache_add (req->type, &dataset->strdata, req->key_len,
                                &dataset->head, true, db, owner, he == NULL);
 
-             pthread_rwlock_unlock (&db->lock);
-
              /* Mark the old entry as obsolete.  */
              if (dh != NULL)
                dh->usable = false;
@@ -317,8 +315,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
 
          (void) cache_add (req->type, key_copy, req->key_len,
                            &dataset->head, true, db, owner, he == NULL);
-
-         pthread_rwlock_unlock (&db->lock);
        }
     }