diff options
author | Ulrich Drepper <drepper@redhat.com> | 2000-09-29 02:56:42 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2000-09-29 02:56:42 +0000 |
commit | e658b54e8e67c00063a0b549fa25b73d8e6d4076 (patch) | |
tree | 2c481b771c920873bdf6977faf071eafda5c39c5 | |
parent | ee6c5330273edda1ab102ad780d1984aca055e77 (diff) | |
download | glibc-e658b54e8e67c00063a0b549fa25b73d8e6d4076.zip glibc-e658b54e8e67c00063a0b549fa25b73d8e6d4076.tar.gz glibc-e658b54e8e67c00063a0b549fa25b73d8e6d4076.tar.bz2 |
Update.
* stdio-common/tmpnam.c (tmpnam): Optimize a bit.
* sysdeps/posix/getaddrinfo.c (gaih_local): Don't use tmpnam, use
underlying functions directly.
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | stdio-common/tmpnam.c | 8 | ||||
-rw-r--r-- | sysdeps/posix/getaddrinfo.c | 10 |
3 files changed, 19 insertions, 4 deletions
@@ -1,5 +1,10 @@ 2000-09-28 Ulrich Drepper <drepper@redhat.com> + * stdio-common/tmpnam.c (tmpnam): Optimize a bit. + + * sysdeps/posix/getaddrinfo.c (gaih_local): Don't use tmpnam, use + underlying functions directly. + * sysdeps/unix/sysv/linux/bits/resource.h: Add RLIMIT_LOCKS. * sysdeps/unix/sysv/linux/arm/bits/resource.h: Likewise. * sysdeps/unix/sysv/linux/i386/bits/resource.h: Likewise. diff --git a/stdio-common/tmpnam.c b/stdio-common/tmpnam.c index c202760..fc30026 100644 --- a/stdio-common/tmpnam.c +++ b/stdio-common/tmpnam.c @@ -29,15 +29,17 @@ tmpnam (char *s) { /* By using two buffers we manage to be thread safe in the case where S != NULL. */ - char tmpbuf[L_tmpnam]; + char tmpbufmem[L_tmpnam]; + char tmpbuf = s ?: tmpbufmem; /* In the following call we use the buffer pointed to by S if non-NULL although we don't know the size. But we limit the size to L_tmpnam characters in any case. */ - if (__path_search (s ? : tmpbuf, L_tmpnam, NULL, NULL, 0)) + if (__builtin_expect (__path_search (tmpbuf, L_tmpnam, NULL, NULL, 0), + 0)) return NULL; - if (__gen_tempname (s ? : tmpbuf, __GT_NOCREATE)) + if (__builtin_expect (__gen_tempname (tmpbuf, __GT_NOCREATE), 0)) return NULL; if (s == NULL) diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c index fdd8729..7a84cd3 100644 --- a/sysdeps/posix/getaddrinfo.c +++ b/sysdeps/posix/getaddrinfo.c @@ -206,7 +206,15 @@ gaih_local (const char *name, const struct gaih_service *service, } else { - if (tmpnam (((struct sockaddr_un *) (*pai)->ai_addr)->sun_path) == NULL) + /* This is a dangerous use of the interface since there is a time + window between the test for the file and the actual creation + (done by the caller) in which a file with the same name could + be created. */ + char *buf = ((struct sockaddr_un *) (*pai)->ai_addr)->sun_path; + + if (__builtin_expect (__path_search (buf, L_tmpnam, NULL, NULL, 0), + 0) != 0 + || __builtin_expect (__gen_tempname (buf, __GT_NOCREATE), 0) != 0) return -EAI_SYSTEM; } |