aboutsummaryrefslogtreecommitdiff
path: root/src/temp (follow)
Commit message (Expand)AuthorAgeFilesLines
* avoid limited space of random temp file names if clock resolution is low•••this is not an issue that was actually hit, but I noticed it during previous changes to __randname: if the resolution of tv_nsec is too low, the space of temp file names obtainable by a thread could plausibly be exhausted. mixing in tv_sec avoids this. Rich Felker2022-06-231-1/+1
* remove random filename obfuscation that leaks ASLR information•••the __randname function is used by various temp file creation interfaces as a backend to produce a name to attempt using. it does not have to produce results that are safe against guessing, and only aims to avoid unintentional collisions. mixing the address of an object on the stack in a reversible manner leaked ASLR information, potentially allowing an attacker who can observe the temp files created and their creation timestamps to narrow down the possible ASLR state of the process that created them. there is no actual value in mixing these addresses in; it was just obfuscation. so don't do it. instead, mix the tid, just to avoid collisions if multiple processes/threads stampede to create temp files at the same moment. even without this measure, they should not collide unless the clock source is very low resolution, but it's a cheap improvement. if/when we have a guaranteed-available userspace csprng, it could be used here instead. even though there is no need for cryptographic entropy here, it would avoid having to reason about clock resolution and such to determine whether the behavior is nice. Rich Felker2022-06-031-1/+2
* remove spurious inclusion of libc.h for LFS64 ABI aliases•••the LFS64 macro was not self-documenting and barely saved any characters. simply use weak_alias directly so that it's clear what's being done, and doesn't depend on a header to provide a strange macro. Rich Felker2018-09-123-6/+3
* reduce spurious inclusion of libc.h•••libc.h was intended to be a header for access to global libc state and related interfaces, but ended up included all over the place because it was the way to get the weak_alias macro. most of the inclusions removed here are places where weak_alias was needed. a few were recently introduced for hidden. some go all the way back to when libc.h defined CANCELPT_BEGIN and _END, and all (wrongly implemented) cancellation points had to include it. remaining spurious users are mostly callers of the LOCK/UNLOCK macros and files that use the LFS64 macro to define the awful *64 aliases. in a few places, new inclusion of libc.h is added because several internal headers no longer implicitly include libc.h. declarations for __lockfile and __unlockfile are moved from libc.h to stdio_impl.h so that the latter does not need libc.h. putting them in libc.h made no sense at all, since the macros in stdio_impl.h are needed to use them correctly anyway. Rich Felker2018-09-121-1/+0
* overhaul internally-public declarations using wrapper headers•••commits leading up to this one have moved the vast majority of libc-internal interface declarations to appropriate internal headers, allowing them to be type-checked and setting the stage to limit their visibility. the ones that have not yet been moved are mostly namespace-protected aliases for standard/public interfaces, which exist to facilitate implementing plain C functions in terms of POSIX functionality, or C or POSIX functionality in terms of extensions that are not standardized. some don't quite fit this description, but are "internally public" interfacs between subsystems of libc. rather than create a number of newly-named headers to declare these functions, and having to add explicit include directives for them to every source file where they're needed, I have introduced a method of wrapping the corresponding public headers. parallel to the public headers in $(srcdir)/include, we now have wrappers in $(srcdir)/src/include that come earlier in the include path order. they include the public header they're wrapping, then add declarations for namespace-protected versions of the same interfaces and any "internally public" interfaces for the subsystem they correspond to. along these lines, the wrapper for features.h is now responsible for the definition of the hidden, weak, and weak_alias macros. this means source files will no longer need to include any special headers to access these features. over time, it is my expectation that the scope of what is "internally public" will expand, reducing the number of source files which need to include *_impl.h and related headers down to those which are actually implementing the corresponding subsystems, not just using them. Rich Felker2018-09-127-14/+0
* make mkostemps source file include the header for its declarationRich Felker2018-09-121-0/+1
* ignore access mode bits of flags in mkostemps and functions that use it•••per the text accepted for inclusion in POSIX, behavior is unspecified when any of the access mode bits are set. since it's impossible to consistently report this usage error (O_RDONLY could not be detected since its value happens to be zero), the most consistent way to handle them is just to ignore them. previously, if a caller erroneously passed O_WRONLY, the resulting access mode would be O_WRONLY|O_RDWR, which has the value 3, and this resulted in a file descriptor which rejects both read and write attempts when it is subsequently used. Rich Felker2014-10-061-0/+1
* include cleanups: remove unused headers and add feature test macrosSzabolcs Nagy2013-12-123-8/+2
* fix typo in comment in __randnameRich Felker2013-09-041-1/+1
* fix (deprecated) mktemp logic and update it to match other temp functions•••the access function cannot be used to check for existence, because it operates using real uid/gid rather than effective to determine accessibility; this matters for the non-final path components. instead, use stat. failure of stat is success if only the final component is missing (ENOENT) and otherwise is failure. Rich Felker2013-08-021-4/+11
* remove (no longer useful) namespace-protected __mktemp symbolRich Felker2013-08-021-4/+1
* make mkdtemp and mkstemp family leave template unchanged on fail•••also refactor mkdtemp based on new shared temp code, removing dependency on the deprecated mktemp, whose behavior made this logic more difficult. Rich Felker2013-08-022-13/+18
* use memcmp instead of str[n]cmp for temp function XXXXXX checkingRich Felker2013-02-202-2/+2
* fix error cases in mkostemps core•••1. wrong return value and missing errno for negative suffix len 2. failure to catch suffix len > strlen 3. remove unwanted clearing of input string in invalid case Rich Felker2013-02-201-6/+3
* remove leftover unused variable in mktemp after refactoringRich Felker2013-02-201-1/+0
* add mkostemp, mkstemps, and mkostemps functions and reorganize temp internals•••based on patch contributed by Anthony G. Basile (blueness) some issues remain with the filename generation algorithm and other small bugs, but this patch has been sitting around long enough that I feel it's best to get it committed and then work out any remaining issues. Rich Felker2013-02-206-29/+83
* remove ugly prng from mk*temp and just re-poll time on retryRich Felker2011-07-281-6/+5
* eliminate mk*temp dependency on snprintf•••this helps some tiny programs be even more tiny, and barly increases code size even if both are used. Rich Felker2011-07-281-3/+4
* another return value fix for mktemp...Rich Felker2011-06-121-1/+2
* make mktemp match the historic behavior, and update functions that use it•••the historic mktemp is supposed to blank the template string on failure, rather than returning 0. just zero the first character so that mkstemp and mkdtemp can still retry with O(1) space requirement. Rich Felker2011-02-193-5/+8
* fix major bug created from copying mkdtemp logicRich Felker2011-02-191-1/+1
* major improvements to temp file name generator•••use current time in nanoseconds and some potentially-random (if aslr is enabled) pointer values for the initial tempfile name generation, and step via a cheap linear prng on collisions. limit the number of retry attempts to prevent denial of service attacks even if an attacker can guess the filenames. Rich Felker2011-02-183-16/+21
* reformat mkstemp like mkdtemp•••this is cleaner and makes it easy to impose a limit on the number of retries later if it seems desirable to do so. Rich Felker2011-02-181-7/+5
* ensure standard functions mk[sd]temp don't depend on removed function mktempRich Felker2011-02-143-5/+9
* begin namespace-cleanup of standard C headersRich Felker2011-02-142-0/+2
* initial check-in, version 0.5.0Rich Felker2011-02-123-0/+76