diff options
author | Ulrich Drepper <drepper@redhat.com> | 2004-09-25 05:55:20 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2004-09-25 05:55:20 +0000 |
commit | 9435d38cb1f0988a4f62fe30b90e29d9250054b1 (patch) | |
tree | 1f99edf1a3c1e900970739c768f005f75faadbd5 /nis/ypclnt.c | |
parent | 43ca813d87b81b1f713e4e48ed6fb760c235f14a (diff) | |
download | glibc-9435d38cb1f0988a4f62fe30b90e29d9250054b1.zip glibc-9435d38cb1f0988a4f62fe30b90e29d9250054b1.tar.gz glibc-9435d38cb1f0988a4f62fe30b90e29d9250054b1.tar.bz2 |
Update.
* nis/ypclnt.c (do_ypcall): Add one missing unlock. Simplify the
code a bit.
Diffstat (limited to 'nis/ypclnt.c')
-rw-r--r-- | nis/ypclnt.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/nis/ypclnt.c b/nis/ypclnt.c index 184e49d..f25c7c7 100644 --- a/nis/ypclnt.c +++ b/nis/ypclnt.c @@ -304,16 +304,10 @@ do_ypcall (const char *domain, u_long prog, xdrproc_t xargs, status = YPERR_YPERR; __libc_lock_lock (ypbindlist_lock); - if (__ypbindlist != NULL) + ydb = __ypbindlist; + while (ydb != NULL) { - ydb = __ypbindlist; - while (ydb != NULL) - { - if (strcmp (domain, ydb->dom_domain) == 0) - break; - ydb = ydb->dom_pnext; - } - if (ydb != NULL) + if (strcmp (domain, ydb->dom_domain) == 0) { if (__yp_bind (domain, &ydb) == 0) { @@ -322,6 +316,7 @@ do_ypcall (const char *domain, u_long prog, xdrproc_t xargs, resp, &ydb, 0); if (status == YPERR_SUCCESS) { + __libc_lock_unlock (ypbindlist_lock); __set_errno (saved_errno); return status; } @@ -329,7 +324,10 @@ do_ypcall (const char *domain, u_long prog, xdrproc_t xargs, /* We use ypbindlist, and the old cached data is invalid. unbind now and create a new binding */ yp_unbind_locked (domain); + + break; } + ydb = ydb->dom_pnext; } __libc_lock_unlock (ypbindlist_lock); |