From: neilbrown Date: Mon, 11 Aug 2003 05:55:49 +0000 (+0000) Subject: close a filehandle before opening. X-Git-Tag: nfs-utils-1-0-5-post2nfs-utils-1-0-5-post3~10 X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=commitdiff_plain;h=fce515b864024bd4d25c55063f0d0835986a01f9;hp=9c8dfab04dcf5f5067061703d6cd08ee408eec8f close a filehandle before opening. --- diff --git a/ChangeLog b/ChangeLog index 81ccf88..ec81bb5 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2003-08-11 NeilBrown + * utils/mountd/cache.c(cache_get_filehandle): close the filehandle + before returning. + 2003-08-04 NeilBrown * support/include/nfs/export.h, support/nfs/exports.c, utils/exportfs/exports.c, utils/mountd/mountd.c: change diff --git a/utils/mountd/cache.c b/utils/mountd/cache.c index 96492b8..a265ecd 100644 --- a/utils/mountd/cache.c +++ b/utils/mountd/cache.c @@ -376,6 +376,7 @@ cache_get_filehandle(nfs_export *exp, int len, char *p) FILE *f = fopen("/proc/fs/nfsd/filehandle", "r+"); char buf[200]; char *bp = buf; + int failed; static struct nfs_fh_len fh; if (!f) @@ -388,7 +389,9 @@ cache_get_filehandle(nfs_export *exp, int len, char *p) qword_printint(f, len); qword_eol(f); - if (fgets(buf, sizeof(buf), f) == NULL) + failed = (fgets(buf, sizeof(buf), f) == NULL); + fclose(f); + if (failed) return NULL; memset(fh.fh_handle, 0, sizeof(fh.fh_handle)); fh.fh_size = qword_get(&bp, fh.fh_handle, NFS3_FHSIZE);