ref: ad1111cb3e40371de141af7d5e72467b7d0afec7
parent: 6197758ec15bbd4104f1f340cce07f59f5c7a4ad
author: cinap_lenrek <cinap_lenrek@gmx.de>
date: Mon Oct 7 19:18:37 EDT 2013
exportfs: fix more filedescriptor leaks just closing the pipe isnt enough, we have to close all remaining file descriptors except sfd before executing sub exportfs.
--- a/sys/src/cmd/exportfs/exportsrv.c
+++ b/sys/src/cmd/exportfs/exportsrv.c
@@ -578,8 +578,9 @@
int
openmount(int sfd)
{- int p[2];
+ int p[2], fd, i, n;
char *arg[10], fdbuf[20], mbuf[20];
+ Dir *dir;
if(pipe(p) < 0)
return -1;
@@ -601,8 +602,19 @@
dup(p[0], 0);
dup(p[0], 1);
- close(p[0]);
- close(p[1]);
+
+ /* close all remaining file descriptors except sfd */
+ if((fd = open("/fd", OREAD)) < 0)+ _exits("open /fd failed");+ n = dirreadall(fd, &dir);
+ for(i=0; i<n; i++){+ if(strstr(dir[i].name, "ctl"))
+ continue;
+ fd = atoi(dir[i].name);
+ if(fd > 2 && fd != sfd)
+ close(fd);
+ }
+ free(dir);
arg[0] = "exportfs";
snprint(fdbuf, sizeof fdbuf, "-S/fd/%d", sfd);
--
⑨