From: Rich Felker Date: Thu, 27 Jun 2013 01:35:56 +0000 (-0400) Subject: in sem_open, don't leak vm mapping if fstat fails X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=commitdiff_plain;h=52d4444f8eec1a4e7e0861859c705c3a558b4e2a;ds=sidebyside in sem_open, don't leak vm mapping if fstat fails fstat should not fail under normal circumstances, so this fix is mostly theoretical. --- diff --git a/src/thread/sem_open.c b/src/thread/sem_open.c index ed2353c8..8a72d4c6 100644 --- a/src/thread/sem_open.c +++ b/src/thread/sem_open.c @@ -82,8 +82,8 @@ sem_t *sem_open(const char *name, int flags, ...) if (flags != (O_CREAT|O_EXCL)) { fd = open(name, FLAGS); if (fd >= 0) { - if ((map = mmap(0, sizeof(sem_t), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == MAP_FAILED || - fstat(fd, &st) < 0) { + if (fstat(fd, &st) < 0 || + (map = mmap(0, sizeof(sem_t), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == MAP_FAILED) { close(fd); goto fail; }