X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Ftemp%2Fmktemp.c;h=1462a16c6dd189ff8354656a924bfcc324ddc67b;hp=1078b9df805e433ebd2d0f4fbe2ab87553e80df9;hb=446b4207cc7a30d8a4d5b2445a5a1b27d440f55d;hpb=3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3 diff --git a/src/temp/mktemp.c b/src/temp/mktemp.c index 1078b9df..1462a16c 100644 --- a/src/temp/mktemp.c +++ b/src/temp/mktemp.c @@ -4,28 +4,30 @@ #include #include #include +#include +#include #include "libc.h" char *__mktemp(char *template) { - static int lock; - static int index; - int l = strlen(template); + struct timespec ts; + size_t l = strlen(template); + int retries = 10000; + unsigned long r; if (l < 6 || strcmp(template+l-6, "XXXXXX")) { errno = EINVAL; - return NULL; + return 0; } - LOCK(&lock); - for (; index < 1000000; index++) { - snprintf(template+l-6, 6, "%06d", index); - if (access(template, F_OK) != 0) { - UNLOCK(&lock); - return template; - } + clock_gettime(CLOCK_REALTIME, &ts); + r = ts.tv_nsec + (uintptr_t)&ts / 16 + (uintptr_t)template; + while (retries--) { + snprintf(template+l-6, 7, "%06lX", r & 0xffffff); + if (access(template, F_OK) < 0) return template; + r = r * 1103515245 + 12345; } - UNLOCK(&lock); - return NULL; + errno = EEXIST; + return 0; } weak_alias(__mktemp, mktemp);