Commit Graph

2010 Commits

Author SHA1 Message Date
97d0988fd8 add _res (__res_state()) dummy 2011-04-06 15:47:26 -04:00
1fee6186fe fix prototype for strsep 2011-04-06 14:28:29 -04:00
6b87e941f9 fix completely bogus loop condition in getmntent_r
somehow this worked on my simple fstab, but horribly broke in general,
leading to use of uninitialized offset array and crashes.
2011-04-06 12:35:05 -04:00
a113434cd6 major semaphore improvements (performance and correctness)
1. make sem_[timed]wait interruptible by signals, per POSIX
2. keep a waiter count in order to avoid unnecessary futex wake syscalls
2011-04-06 12:24:34 -04:00
cd3bb38412 fix signal-based timers with null sigevent argument
since timer_create is no longer allocating a structure for the timer_t
and simply using the kernel timer id, it was impossible to specify the
timer_t as the argument to the signal handler. the solution is to pass
the null sigevent pointer on to the kernel, rather than filling it in
userspace, so that the kernel does the right thing. however, that
precludes the clever timerid-versus-threadid encoding we were doing.

instead, just assume timerids are below 1M and thread pointers are
above 1M. (in perspective: timerids are sequentially allocated and
seem limited to 32k, and thread pointers are at roughly 3G.)
2011-04-06 09:26:41 -04:00
104d013441 fix incorrect (and conflicting on LP64 archs) types for sysv ipc msgq functions 2011-04-06 00:02:20 -04:00
fc0cf2852d fix (hopefully) statvfs breakage on x86_64 that resulted from fixing i386... 2011-04-05 23:58:36 -04:00
729cb49f52 new framework to inhibit thread cancellation when needed
with these small changes, libc functions which need to call functions
which are cancellation points, but which themselves must not be
cancellation points, can use the CANCELPT_INHIBIT and CANCELPT_RESUME
macros to temporarily inhibit all cancellation.
2011-04-05 18:00:28 -04:00
8bb82b4e58 add sysv ipc message queues (completely untested) 2011-04-05 16:33:55 -04:00
f209440bcf implement the adjtime and adjtimex functions (nonstandard) 2011-04-05 15:38:20 -04:00
2c4e9e6e4b add getmntent_r interface (all of mntent is nonstandard anyway) 2011-04-05 14:11:14 -04:00
92b2eb8d03 implement if_indextoname and if_nametoindex functions 2011-04-05 13:20:08 -04:00
ef8b4b1aa6 add (nonstandard) cfmakeraw function 2011-04-05 12:35:09 -04:00
5546f7a73a add pivot_root syscall wrapper 2011-04-05 12:32:10 -04:00
e72180083e add more legacy functions: setlinebuf and setbuffer 2011-04-05 12:25:31 -04:00
39e48531ef support the nonstandard err.h interfaces
note that unlike the originals, these do not print the program
name/argv[0] because we have not saved it anywhere. this could be
changed in __libc_start_main if desired.
2011-04-05 11:16:49 -04:00
16675df793 fix misaligned read on early string termination in strchr
this could actually cause rare crashes in the case where a short
string is located at the end of a page and the following page is not
readable, and in fact this was seen in gcc compiling certain files.
2011-04-05 09:27:41 -04:00
2f3d02cd83 fix overflow in printf %N$ argument handling 2011-04-05 09:24:03 -04:00
f9569662c0 fix various floating point rounding and formatting errors in *printf 2011-04-05 09:16:40 -04:00
b761bd19aa fix rare but nasty under-allocation bug in malloc with large requests
the bug appeared only with requests roughly 2*sizeof(size_t) to
4*sizeof(size_t) bytes smaller than a multiple of the page size, and
only for requests large enough to be serviced by mmap instead of the
normal heap. it was only ever observed on 64-bit machines but
presumably could also affect 32-bit (albeit with a smaller window of
opportunity).
2011-04-04 17:26:41 -04:00
98c5583ad5 simplify vdprintf implementation greatly based on recent vfprintf changes
since vfprintf will provide a temporary buffer in the case where the
target FILE has a zero buffer size, don't bother setting up a real
buffer for vdprintf. this also allows us to skip the call to fflush
since we know everything will be written out before vfprintf returns.
2011-04-04 16:30:39 -04:00
bd57e2b43a use a local temp buffer for unbuffered streams in vfprintf
this change makes it so most calls to fprintf(stderr, ...) will result
in a single writev syscall, as opposed to roughly 2*N syscalls (and
possibly more) where N is the number of format specifiers. in
principle we could use a much larger buffer, but it's best not to
increase the stack requirements too much. most messages are under 80
chars.
2011-04-04 16:24:49 -04:00
5600088d38 fix nl_langinfo to actually use the existing, correct internal version 2011-04-03 19:51:14 -04:00
3910e93340 make ualarm actually work (obsolete function removed from SUS) 2011-04-03 19:18:43 -04:00
e898a79053 fix various bugs in strtold:
0e10000000000000000000000000000000 was setting ERANGE

exponent char e/p was considered part of the match even if not
followed by a valid decimal value

"1e +10" was parsed as "1e+10"

hex digits were misinterpreted as 0..5 instead of 10..15
2011-04-03 18:44:37 -04:00
c68b26369e fix serious bug in strchr - char signedness
search for bytes with high bit set was giving (potentially dangerous)
wrong results. i've tested, cleaned up, and hopefully sped up this
function now.
2011-04-03 18:16:11 -04:00
1db283bf19 add setresuid/setresgid functions (nonstandard) 2011-04-03 16:20:57 -04:00
7fd3995282 pthread_create need not set errno 2011-04-03 16:15:15 -04:00
7e795ca7ed fix statvfs syscalls (missing size argument) 2011-04-03 15:42:31 -04:00
66def4e776 block all signals during rsyscall
otherwise a signal handler could see an inconsistent and nonconformant
program state where different threads have different uids/gids.
2011-04-03 13:15:42 -04:00
1ad049b7b6 fix race condition in rsyscall handler
the problem: there is a (single-instruction) race condition window
between a thread flagging itself dead and decrementing itself from the
thread count. if it receives the rsyscall signal at this exact moment,
the rsyscall caller will never succeed in signalling enough flags to
succeed, and will deadlock forever. in previous versions of musl, the
about-to-terminate thread masked all signals prior to decrementing
the thread count, but this cost a whole syscall just to account for
extremely rare races.

the solution is a huge hack: rather than blocking in the signal
handler if the thread is dead, modify the signal mask of the saved
context and return in order to prevent further signal handling by the
dead thread. this allows the dead thread to continue decrementing the
thread count (if it had not yet done so) and exiting, even while the
live part of the program blocks for rsyscall.
2011-04-03 13:03:18 -04:00
c9b2d8016f don't trust siginfo in rsyscall handler
for some inexplicable reason, linux allows the sender of realtime
signals to spoof its identity. permission checks for sending signals
should limit the impact to same-user processes, but just to be safe,
we avoid trusting the siginfo structure and instead simply examine the
program state to see if we're in the middle of a legitimate rsyscall.
2011-04-03 12:20:51 -04:00
6e9ed66d0d timer threads should sleep and stay asleep... a long time 2011-04-03 12:10:24 -04:00
6f1414e102 revert to deleting kernel-level timer from cancellation handler
this is necessary in order to avoid breaking timer_getoverrun in the
last run of the timer event handler, if it has not yet finished.
2011-04-03 12:08:34 -04:00
f01d351842 simplify calling of timer signal handler 2011-04-03 12:03:58 -04:00
537d33d334 simplify pthread tsd key handling 2011-04-03 02:40:18 -04:00
fd80cfa00b omit pthread tsd dtor code if tsd is not used 2011-04-03 02:33:50 -04:00
8de03e1a90 don't disable seeking after first seek failure
this could cause problems if the application uses dup2(fd,fileno(f))
to redirect, and the old fd was not seekable but the new fd is.
2011-04-02 13:55:54 -04:00
9a909fcd91 apparently fseek should not set the error flag on failed seek 2011-04-02 13:54:55 -04:00
bf8785825a avoid over-allocation of brk on first malloc
if init_malloc returns positive (successful first init), malloc will
retry getting a chunk from the free bins rather than expanding the
heap again. also pass init_malloc a hint for the size of the initial
allocation.
2011-04-01 23:07:03 -04:00
952987a0cb reorganize the __libc structure for threaded performance issues
we want to keep atomically updated fields (locks and thread count) and
really anything writable far away from frequently-needed function
pointers. stuff some rarely-needed function pointers in between to
pad, hopefully up to a cache line boundary.
2011-04-01 22:35:20 -04:00
4ae5e811f8 simplify setting result on thread cancellation 2011-04-01 22:15:03 -04:00
6c16d3e98a use bss instead of mmap for main thread's pthread thread-specific data
this simplifies code and removes a failure case
2011-04-01 22:07:59 -04:00
5243e5f160 remove obsolete and useless useconds_t type 2011-04-01 21:10:01 -04:00
3df3d4f512 fix misspelled PTHREAD_CANCELED constant 2011-04-01 20:48:02 -04:00
ded6cb5f71 use a_store to set cancel flag in pthread_cancel, to ensure a barrier 2011-04-01 19:53:16 -04:00
c1b39b203d simplify pthread_key_delete
calling this function on an uninitialized key value is UB, so there is
no need to check that the table pointer was initialized.
2011-03-31 19:06:22 -04:00
c9806fc2f9 greatly simplify pthread_key_create (~20% size reduction) 2011-03-31 19:04:56 -04:00
3990c5c6a4 avoid all malloc/free in timer creation/destruction
instead of allocating a userspace structure for signal-based timers,
simply use the kernel timer id. we use the fact that thread pointers
will always be zero in the low bit (actually more) to encode integer
timerid values as pointers.

also, this change ensures that the timer_destroy syscall has completed
before the library timer_destroy function returns, in case it matters.
2011-03-30 13:04:55 -04:00
b8be64c43d optimize timer creation and possibly protect against some minor races
the major idea of this patch is not to depend on having the timer
pointer delivered to the signal handler, and instead use the thread
pointer to get the callback function address and argument. this way,
the parent thread can make the timer_create syscall while the child
thread is starting, and it should never have to block waiting for the
barrier.
2011-03-30 12:06:39 -04:00