Handle OOM in NSS
authorJiri Olsa <jolsa@redhat.com>
Thu, 6 Oct 2011 07:04:10 +0000 (03:04 -0400)
committerUlrich Drepper <drepper@gmail.com>
Thu, 6 Oct 2011 07:04:10 +0000 (03:04 -0400)
ChangeLog
nss/nsswitch.c

index 2fdde34..33eeafb 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2011-09-15  Jiri Olsa  <jolsa@redhat.com>
+
+       * nss/nsswitch.c (__nss_lookup_function): Handle __tsearch
+       out of memory case.
+
 2011-10-04  Andreas Schwab  <schwab@redhat.com>
 
        * include/dlfcn.h (__RTLD_NOIFUNC): Define.
index 6c15c3a..535d93b 100644 (file)
@@ -384,7 +384,10 @@ __nss_lookup_function (service_user *ni, const char *fct_name)
      will be passed to `known_compare' (above).  */
 
   found = __tsearch (&fct_name, &ni->known, &known_compare);
-  if (*found != &fct_name)
+  if (found == NULL)
+    /* This means out-of-memory.  */
+    result = NULL;
+  else if (*found != &fct_name)
     {
       /* The search found an existing structure in the tree.  */
       result = ((known_function *) *found)->fct_ptr;