diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-03-29 08:37:57 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-03-29 08:37:57 -0400 |
commit | a88edbec15abe3c8e08d5065d8bea399898e757c (patch) | |
tree | 03fffdfb13788c61fbaaa942e478ec4b6653b649 /src/stdio/tmpfile.c | |
parent | 507a9fa6ff9948eb7d858467b7be2cb1dcf15d03 (diff) | |
download | musl-a88edbec15abe3c8e08d5065d8bea399898e757c.tar.gz |
make tmpfile fail after exceeding max tries.
Diffstat (limited to 'src/stdio/tmpfile.c')
-rw-r--r-- | src/stdio/tmpfile.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/stdio/tmpfile.c b/src/stdio/tmpfile.c index b050f7fd..a6b72236 100644 --- a/src/stdio/tmpfile.c +++ b/src/stdio/tmpfile.c @@ -3,14 +3,17 @@ #include <unistd.h> #include "stdio_impl.h" +#define MAXTRIES 100 + FILE *tmpfile(void) { char buf[L_tmpnam], *s; int fd; FILE *f; - for (;;) { + int try; + for (try=0; try<MAXTRIES; try++) { s = tmpnam(buf); - if (!s) return NULL; + if (!s) return 0; fd = syscall(SYS_open, s, O_RDWR|O_CREAT|O_EXCL|O_LARGEFILE, 0600); if (fd >= 0) { f = __fdopen(fd, "w+"); @@ -18,6 +21,7 @@ FILE *tmpfile(void) return f; } } + return 0; } LFS64(tmpfile); |