summaryrefslogtreecommitdiff
path: root/Src/parse.c
diff options
context:
space:
mode:
authorPeter Stephenson <pws@zsh.org>2013-07-25 09:45:33 +0100
committerPeter Stephenson <pws@zsh.org>2013-07-25 09:45:33 +0100
commit4095e175b6dcdaf901e783752bbd5a503c27881b (patch)
tree3d90acf4caf8bf53e24781310b3acac4bf9e89bd /Src/parse.c
parent673760876c767c25bcfce74915e1f0ffbfc88437 (diff)
downloadzsh-4095e175b6dcdaf901e783752bbd5a503c27881b.tar.gz
zsh-4095e175b6dcdaf901e783752bbd5a503c27881b.zip
31574: alternative fix for bad fd if no FD_CLOEXEC.
Remove dump records more consistently in that case.
Diffstat (limited to 'Src/parse.c')
-rw-r--r--Src/parse.c24
1 files changed, 16 insertions, 8 deletions
diff --git a/Src/parse.c b/Src/parse.c
index b670925de..0c2a45833 100644
--- a/Src/parse.c
+++ b/Src/parse.c
@@ -3418,6 +3418,16 @@ incrdumpcount(FuncDump f)
f->count++;
}
+/**/
+static void
+freedump(FuncDump f)
+{
+ munmap((void *) f->addr, f->len);
+ zclose(f->fd);
+ zsfree(f->filename);
+ zfree(f, sizeof(*f));
+}
+
/* Decrement the reference counter for a dump file. If zero, unmap the file. */
/**/
@@ -3434,10 +3444,7 @@ decrdumpcount(FuncDump f)
q->next = p->next;
else
dumps = p->next;
- munmap((void *) f->addr, f->len);
- zclose(f->fd);
- zsfree(f->filename);
- zfree(f, sizeof(*f));
+ freedump(f);
}
}
}
@@ -3447,10 +3454,11 @@ decrdumpcount(FuncDump f)
mod_export void
closedumps(void)
{
- FuncDump p;
-
- for (p = dumps; p; p = p->next)
- zclose(p->fd);
+ while (dumps) {
+ FuncDump p = dumps->next;
+ freedump(dumps);
+ dumps = p;
+ }
}
#endif