about summary refs log tree commit diff
path: root/src/libnsss/nsss_switch_getpwent_r.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/libnsss/nsss_switch_getpwent_r.c')
-rw-r--r--src/libnsss/nsss_switch_getpwent_r.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/libnsss/nsss_switch_getpwent_r.c b/src/libnsss/nsss_switch_getpwent_r.c
index 7795af0..e982f11 100644
--- a/src/libnsss/nsss_switch_getpwent_r.c
+++ b/src/libnsss/nsss_switch_getpwent_r.c
@@ -1,7 +1,10 @@
 /* ISC license. */
 
 #include <errno.h>
+#include <pthread.h>
+
 #include <skalibs/stralloc.h>
+
 #include <nsss/config.h>
 #include <nsss/pwd-switch.h>
 #include <nsss/nsss-switch.h>
@@ -12,16 +15,18 @@ int nsss_switch_getpwent_r (struct passwd *pw, char *buf, size_t buflen, struct
 {
   struct passwd pw2 ;
   stralloc sa = STRALLOC_ZERO ;
-  int e ;
-  if (!nsss_switch_start(&nsss_switch_here, NSSS_SWITCH_PWD, NSSS_NSSSD_PATH, 0, 0)) return errno ;
+  int e = pthread_mutex_lock(&nsss_switch_enumerator_mutex) ;
+  if (e) return e ;
+  if (!nsss_switch_start(&nsss_switch_enumerator, NSSS_SWITCH_PWD, NSSS_NSSSD_PATH, 0, 0)) goto err ;
   e = errno ;
   errno = 0 ;
-  if (!nsss_switch_pwd_get(&nsss_switch_here, &pw2, &sa, 0, 0))
+  if (!nsss_switch_pwd_get(&nsss_switch_enumerator, &pw2, &sa, 0, 0))
   {
     *pwp = 0 ;
     if (!errno) errno = ENOENT ;
-    return errno ;
+    goto err ;
   }
+  pthread_mutex_unlock(&nsss_switch_enumerator_mutex) ;
   if (!nsss_pwd_copy(pw, buf, buflen, &pw2, sa.s, sa.len))
   {
     stralloc_free(&sa) ;
@@ -31,4 +36,8 @@ int nsss_switch_getpwent_r (struct passwd *pw, char *buf, size_t buflen, struct
   stralloc_free(&sa) ;
   *pwp = pw ;
   return (errno = e, 0) ;
+
+ err:
+  pthread_mutex_unlock(&nsss_switch_enumerator_mutex) ;
+  return errno ;
 }