Fix crash in unsuccessful uses of nss_db
authorUlrich Drepper <drepper@gmail.com>
Tue, 21 Jun 2011 21:09:44 +0000 (17:09 -0400)
committerUlrich Drepper <drepper@gmail.com>
Tue, 21 Jun 2011 21:09:44 +0000 (17:09 -0400)
ChangeLog
nss/nss_db/db-XXX.c

index abc4894..5dc235e 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2011-06-21  Ulrich Drepper  <drepper@gmail.com>
 
+       * nss/nss_db/db-XXX.c (nss_db_setENT): Only set entidx for successful
+       calls to internal_setent.
+
        [BZ #12885]
        * sysdeps/posix/getaddrinfo.c (gaih_inet): When looking up only IPv6
        addresses using gethostbyname4_r ignore IPv4 addresses.
index 3947893..0600e38 100644 (file)
@@ -71,11 +71,14 @@ CONCAT(_nss_db_set,ENTNAME) (int stayopen)
 
   status = internal_setent (DBFILE, &state);
 
-  /* Remember STAYOPEN flag.  */
   if (status == NSS_STATUS_SUCCESS)
-    keep_db |= stayopen;
-  /* Reset the sequential index.  */
-  entidx  = (const char *) state.header + state.header->valstroffset;
+    {
+      /* Remember STAYOPEN flag.  */
+      keep_db |= stayopen;
+
+      /* Reset the sequential index.  */
+      entidx  = (const char *) state.header + state.header->valstroffset;
+    }
 
   __libc_lock_unlock (lock);