fix temp file leak in sem_open on successful creation of new semaphore

This commit is contained in:
Rich Felker 2013-06-26 21:41:51 -04:00
parent a033cd22aa
commit 7c20a11801

View File

@ -123,9 +123,9 @@ sem_t *sem_open(const char *name, int flags, ...)
goto fail;
}
close(fd);
if (link(tmp, name) == 0) break;
e = errno;
e = link(tmp, name) ? errno : 0;
unlink(tmp);
if (!e) break;
/* Failure is only fatal when doing an exclusive open;
* otherwise, next iteration will try to open the
* existing file. */