X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=utils%2Fmountd%2Frmtab.c;h=19b22eea280d2028dd607ae5911c9687e91fc588;hp=c371f8db8bef27bd8d9dd5e98807d026e754122d;hb=2ba89d65421cba255a0e75a7f646e4bbb2487193;hpb=f0ed8401e854e1cbd23b2fb5dca5e88dec2df7c4 diff --git a/utils/mountd/rmtab.c b/utils/mountd/rmtab.c index c371f8d..19b22ee 100644 --- a/utils/mountd/rmtab.c +++ b/utils/mountd/rmtab.c @@ -24,6 +24,7 @@ #include "ha-callout.h" #include /* PATH_MAX */ +#include extern int reverse_resolve; @@ -143,23 +144,16 @@ mountlist_del_all(struct sockaddr_in *sin) return; if (!(hp = gethostbyaddr((char *)&addr, sizeof(addr), AF_INET))) { xlog(L_ERROR, "can't get hostname of %s", inet_ntoa(addr)); - xfunlock(lockid); - return; + goto out_unlock; } - else - hp = hostent_dup (hp); + hp = hostent_dup (hp); + + if (!setrmtabent("r")) + goto out_free; + + if (!(fp = fsetrmtabent(_PATH_RMTABTMP, "w"))) + goto out_close; - if (!setrmtabent("r")) { - xfunlock(lockid); - free (hp); - return; - } - if (!(fp = fsetrmtabent(_PATH_RMTABTMP, "w"))) { - endrmtabent(); - xfunlock(lockid); - free (hp); - return; - } while ((rep = getrmtabent(1, NULL)) != NULL) { if (strcmp(rep->r_client, hp->h_name) == 0 && (exp = auth_authenticate("umountall", sin, rep->r_path))) @@ -170,10 +164,13 @@ mountlist_del_all(struct sockaddr_in *sin) xlog(L_ERROR, "couldn't rename %s to %s", _PATH_RMTABTMP, _PATH_RMTAB); } - endrmtabent(); /* close & unlink */ fendrmtabent(fp); - xfunlock(lockid); +out_close: + endrmtabent(); /* close & unlink */ +out_free: free (hp); +out_unlock: + xfunlock(lockid); } mountlist @@ -191,7 +188,9 @@ mountlist_list(void) if ((lockid = xflock(_PATH_RMTABLCK, "r")) < 0) return NULL; if (stat(_PATH_RMTAB, &stb) < 0) { - xlog(L_ERROR, "can't stat %s", _PATH_RMTAB); + xlog(L_ERROR, "can't stat %s: %s", + _PATH_RMTAB, strerror(errno)); + xfunlock(lockid); return NULL; } if (stb.st_mtime != last_mtime) {