Rich Felker [Tue, 11 Sep 2012 02:43:22 +0000 (22:43 -0400)]
eliminate assumption that mips syscall restart preserves r25
all past and current kernel versions have done so, but there seems to
be no reason it's necessary and the sentiment from everyone I've asked
has been that we should not rely on it. instead, use r7 (an argument
register) which will necessarily be preserved upon syscall restart.
however this only works for 0-3 argument syscalls, and we have to
resort to the function call for 4-argument syscalls.
Rich Felker [Mon, 10 Sep 2012 23:04:24 +0000 (19:04 -0400)]
asm for memmove on i386 and x86_64
for the sake of simplicity, I've only used rep movsb rather than
breaking up the copy for using rep movsd/q. on all modern cpus, this
seems to be fine, but if there are performance problems, there might
be a need to go back and add support for rep movsd/q.
Rich Felker [Mon, 10 Sep 2012 22:37:27 +0000 (18:37 -0400)]
fix another ppoll issue (missing sigset_t size argument)
Rich Felker [Mon, 10 Sep 2012 22:16:11 +0000 (18:16 -0400)]
reenable word-at-at-time copying in memmove
before restrict was added, memove called memcpy for forward copies and
used a byte-at-a-time loop for reverse copies. this was changed to
avoid invoking UB now that memcpy has an undefined copying order,
making memmove considerably slower.
performance is still rather bad, so I'll be adding asm soon.
Rich Felker [Mon, 10 Sep 2012 22:05:02 +0000 (18:05 -0400)]
fix ppoll with null timeout argument
Rich Felker [Mon, 10 Sep 2012 19:30:52 +0000 (15:30 -0400)]
add LIBCC (compiler runtime) logic and override to configure
this should both fix the issue with ARM needing -lgcc_eh (although
that's really a bug in the libgcc build process that's causing
considerable bloat, which should be fixed) and make it easier to build
musl using clang/llvm in place of gcc. unfortunately I don't know a
good way to detect and support pcc's -lpcc since it's not in pcc's
default library search path...
Rich Felker [Sun, 9 Sep 2012 20:50:20 +0000 (16:50 -0400)]
add setdomainname syscall, fix getdomainname (previously a stub)
Rich Felker [Sun, 9 Sep 2012 20:37:19 +0000 (16:37 -0400)]
mincore syscall wrapper
Rich Felker [Sun, 9 Sep 2012 20:33:47 +0000 (16:33 -0400)]
fix up lfs64 junk for preadv/pwritev
Rich Felker [Sun, 9 Sep 2012 20:29:33 +0000 (16:29 -0400)]
add preadv/pwritev syscall wrappers
Rich Felker [Sun, 9 Sep 2012 20:27:26 +0000 (16:27 -0400)]
fix typo introduced in poll.h
Rich Felker [Sun, 9 Sep 2012 20:09:29 +0000 (16:09 -0400)]
add linux ppoll syscall wrapper
Rich Felker [Sun, 9 Sep 2012 18:58:55 +0000 (14:58 -0400)]
reenable sync_file_range; should no longer break on mips
Rich Felker [Sun, 9 Sep 2012 18:53:06 +0000 (14:53 -0400)]
add 7-arg syscall support for mips
no syscalls actually use that many arguments; the issue is that some
syscalls with 64-bit arguments have them ordered badly so that
breaking them into aligned 32-bit half-arguments wastes slots with
padding, and a 7th slot is needed for the last argument.
Rich Felker [Sun, 9 Sep 2012 05:29:19 +0000 (01:29 -0400)]
inline syscall support for arm
most pure-syscall-wrapper functions compile to the smallest/simplest
code possible (save r7 ; load syscall # ; svc 0 ; restore r7 ; tail
call to __syscall_ret).
Rich Felker [Sun, 9 Sep 2012 05:01:19 +0000 (01:01 -0400)]
inline syscall support for mips
this drastically reduces the size of some functions which are purely
syscall wrappers.
disabled for clang due to known bugs satisfying register constraints.
Rich Felker [Sun, 9 Sep 2012 04:59:30 +0000 (00:59 -0400)]
fix mips syscall_cp_asm code (saved register usage)
Rich Felker [Sun, 9 Sep 2012 04:55:31 +0000 (00:55 -0400)]
fix broken mips syscall asm
this code was using $10 to save the syscall number, but $10 is not
necessarily preserved by the kernel across syscalls. only mattered for
syscalls that got interrupted by a signal and restarted. as far as i
can tell, $25 is preserved by the kernel across syscalls.
Rich Felker [Sun, 9 Sep 2012 02:48:22 +0000 (22:48 -0400)]
disable sync_file_range for now
something is wrong with the logic for the argument layout, resulting
in compile errors on mips due to too many args to syscall... further
information on how it's supposed to work will be needed before it can
be reactivated.
Rich Felker [Sun, 9 Sep 2012 02:43:14 +0000 (22:43 -0400)]
syscall organization overhaul
now public syscall.h only exposes __NR_* and SYS_* constants and the
variadic syscall function. no macros or inline functions, no
__syscall_ret or other internal details, no 16-/32-bit legacy syscall
renaming, etc. this logic has all been moved to src/internal/syscall.h
with the arch-specific parts in arch/$(ARCH)/syscall_arch.h, and the
amount of arch-specific stuff has been reduced to a minimum.
changes still need to be reviewed/double-checked. minimal testing on
i386 and mips has already been performed.
Rich Felker [Sun, 9 Sep 2012 02:23:03 +0000 (22:23 -0400)]
add acct syscall source file, omitted in last syscalls commit
Rich Felker [Sun, 9 Sep 2012 00:22:08 +0000 (20:22 -0400)]
add acct, accept4, setns, and dup3 syscalls (linux extensions)
based on patch by Justin Cormack
Rich Felker [Sat, 8 Sep 2012 23:52:51 +0000 (19:52 -0400)]
add IPPROTO_HOPOPTS to in.h
Rich Felker [Sat, 8 Sep 2012 23:43:34 +0000 (19:43 -0400)]
add IPPROTO_MAX to in.h
Rich Felker [Sat, 8 Sep 2012 22:16:33 +0000 (18:16 -0400)]
fix redundant _Noreturn def in err.h
not sure why this was missed in the earlier commit.
Rich Felker [Sat, 8 Sep 2012 21:14:52 +0000 (17:14 -0400)]
remove all remaining redundant __restrict/__inline/_Noreturn defs
Rich Felker [Sat, 8 Sep 2012 06:42:27 +0000 (02:42 -0400)]
sysmacros major/minor: result should have type unsigned int, not dev_t
Rich Felker [Sat, 8 Sep 2012 05:03:01 +0000 (01:03 -0400)]
add linux tee syscall
Rich Felker [Sat, 8 Sep 2012 04:58:25 +0000 (00:58 -0400)]
add linux sync_file_range syscall
Rich Felker [Sat, 8 Sep 2012 04:41:11 +0000 (00:41 -0400)]
move fallocate syscall wrapper to linux-specific syscalls dir
Rich Felker [Sat, 8 Sep 2012 04:40:37 +0000 (00:40 -0400)]
add linux readahead syscall
Rich Felker [Sat, 8 Sep 2012 04:33:04 +0000 (00:33 -0400)]
add fallocate (nonstandardized) function
this is equivalent to posix_fallocate except that it has an extra
mode/flags argument to control its behavior, and stores the error in
errno rather than returning an error code.
Rich Felker [Sat, 8 Sep 2012 04:26:46 +0000 (00:26 -0400)]
fix broken fallocate syscall in posix_fallocate
the syscall takes an extra flag argument which should be zero to meet
the POSIX requirements.
Rich Felker [Sat, 8 Sep 2012 04:21:02 +0000 (00:21 -0400)]
add timerfd interfaces (untested)
Rich Felker [Sat, 8 Sep 2012 04:14:25 +0000 (00:14 -0400)]
add stdnoreturn.h (C11)
features.h contains the fallback logic for pre-C11 compilers
Rich Felker [Sat, 8 Sep 2012 03:56:32 +0000 (23:56 -0400)]
TCP_* is in the reserved namespace for tcp.h; make use of that
Rich Felker [Sat, 8 Sep 2012 03:55:11 +0000 (23:55 -0400)]
remove unneeded judgemental commentary from ftw.h
Rich Felker [Sat, 8 Sep 2012 03:13:55 +0000 (23:13 -0400)]
default features: make musl usable without feature test macros
the old behavior of exposing nothing except plain ISO C can be
obtained by defining __STRICT_ANSI__ or using a compiler option (such
as -std=c99) that predefines it. the new default featureset is POSIX
with XSI plus _BSD_SOURCE. any explicit feature test macros will
inhibit the default.
installation docs have also been updated to reflect this change.
Rich Felker [Fri, 7 Sep 2012 16:18:14 +0000 (12:18 -0400)]
add clang-compatible thread-pointer code for mips
clang does not presently support the "v" constraint we want to use to
get the result from $3, and trying to use register...__asm__("$3") to
do the same invokes serious compiler bugs. so for now, i'm working
around the issue with an extra temp register and putting $3 in the
clobber list instead of using it as output. when the bugs in clang are
fixed, this issue should be revisited to generate smaller/faster code
like what gcc gets.
Rich Felker [Fri, 7 Sep 2012 04:48:25 +0000 (00:48 -0400)]
cleanup src/linux and src/misc trees, etc.
previously, it was pretty much random which one of these trees a given
function appeared in. they have now been organized into:
src/linux: non-POSIX linux syscalls (possibly shard with other nixen)
src/legacy: various obsolete/legacy functions, mostly wrappers
src/misc: still mostly uncategorized; some misc POSIX, some nonstd
src/crypt: crypt hash functions
further cleanup will be done later.
Rich Felker [Fri, 7 Sep 2012 03:57:15 +0000 (23:57 -0400)]
fix constraint violation in ftw
void* does not implicitly convert to function pointer types.
Rich Felker [Fri, 7 Sep 2012 03:49:44 +0000 (23:49 -0400)]
provide loff_t for splice syscall
so far, this is the only actual use of loff_t i've found. some
software, including glib, assumes loff_t must exist if splice exists;
this is a reasonable assumption since the official prototype for
splice uses loff_t, as it always works with 64-bit offsets regardless
of the selected libc off_t size. i'm using #define for now rather than
a typedef to make it easy to define in other headers if necessary
(like the LFS64 ugliness), but it may be necessary to add it to
alltypes.h eventually if other functions end up needing it.
Rich Felker [Fri, 7 Sep 2012 03:34:10 +0000 (23:34 -0400)]
further use of _Noreturn, for non-plain-C functions
note that POSIX does not specify these functions as _Noreturn, because
POSIX is aligned with C99, not the new C11 standard. when POSIX is
eventually updated to C11, it will almost surely give these functions
the _Noreturn attribute. for now, the actual _Noreturn keyword is not
used anyway when compiling with a c99 compiler, which is what POSIX
requires; the GCC __attribute__ is used instead if it's available,
however.
in a few places, I've added infinite for loops at the end of _Noreturn
functions to silence compiler warnings. presumably
__buildin_unreachable could achieve the same thing, but it would only
work on newer GCCs and would not be portable. the loops should have
near-zero code size cost anyway.
like the previous _Noreturn commit, this one is based on patches
contributed by philomath.
Rich Felker [Fri, 7 Sep 2012 03:27:55 +0000 (23:27 -0400)]
fix invalid implicit pointer conversion in gnulib-compat functions
Rich Felker [Fri, 7 Sep 2012 03:12:27 +0000 (23:12 -0400)]
add _Noreturn function attribute, with fallback for pre-C11 GNUC
Rich Felker [Fri, 7 Sep 2012 02:58:34 +0000 (22:58 -0400)]
dladdr should be available under _BSD_SOURCE as well as _GNU_SOURCE
Rich Felker [Fri, 7 Sep 2012 02:44:55 +0000 (22:44 -0400)]
use restrict everywhere it's required by c99 and/or posix 2008
to deal with the fact that the public headers may be used with pre-c99
compilers, __restrict is used in place of restrict, and defined
appropriately for any supported compiler. we also avoid the form
[restrict] since older versions of gcc rejected it due to a bug in the
original c99 standard, and instead use the form *restrict.
Rich Felker [Fri, 7 Sep 2012 00:28:42 +0000 (20:28 -0400)]
remove dependency of wmemmove on wmemcpy direction
unlike the memmove commit, this one should be fine to leave in place.
wmemmove is not performance-critical, and even if it were, it's
already copying whole 32-bit words at a time instead of bytes.
Rich Felker [Fri, 7 Sep 2012 00:25:48 +0000 (20:25 -0400)]
remove dependency of memmove on memcpy direction
this commit introduces a performance regression in many uses of
memmove, which will need to be addressed before the next release. i'm
making it as a temporary measure so that the restrict patch can be
committed without invoking undefined behavior when memmove calls
memcpy with overlapping regions.
Rich Felker [Fri, 7 Sep 2012 00:21:13 +0000 (20:21 -0400)]
fix broken ttyname[_r] (failure to null-terminate result)
Rich Felker [Sun, 2 Sep 2012 16:46:06 +0000 (12:46 -0400)]
avoid "inline" in public headers for strict c89 compatibility
while musl itself requires a c99 compiler, some applications insist on
being compiled with c89 compilers, and use of "inline" in the headers
was breaking them. much of this had been avoided already by just
skipping the inline keyword in pre-c99 compilers or modes, but this
new unified solution is cleaner and may/should result in better code
generation in the default gcc configuration.
Rich Felker [Sat, 1 Sep 2012 04:20:24 +0000 (00:20 -0400)]
fix wrong type for poll.h nfds_t
this should not break anything since the type should never be used
except as the argument type for poll.
Rich Felker [Thu, 30 Aug 2012 12:27:08 +0000 (08:27 -0400)]
fix missing statics in crypt_sha256 code
Rich Felker [Wed, 29 Aug 2012 16:56:12 +0000 (12:56 -0400)]
anti-DoS rounds count limits for blowfish and des crypt
all of the limits could use review, but err on the side of avoiding
excessive rounds for now.
Rich Felker [Wed, 29 Aug 2012 16:44:27 +0000 (12:44 -0400)]
limit sha512 rounds to similar runtime to sha256 limit
these limits could definitely use review, but for now, i feel
consistency and erring on the side of preventing servers from getting
bogged down by excessively-slow user-provided settings (think
.htpasswd) are the best policy. blowfish should be updated to match.
Rich Felker [Wed, 29 Aug 2012 16:41:29 +0000 (12:41 -0400)]
add sha256/sha512 crypt
based on versions sent to the list by nsz, with some simplification
and debloating. i'd still like to get them a bit smaller, or ideally
merge them into a single file with most of the code being shared, but
that can be done later.
Rich Felker [Wed, 29 Aug 2012 13:36:02 +0000 (09:36 -0400)]
get rid of eh_frame bloat
if needed for debugging, it will be output in the .debug_frame section
instead, where it is not part of the loaded program and where the
strip command is free to strip it.
Rich Felker [Mon, 27 Aug 2012 14:07:32 +0000 (10:07 -0400)]
fix bug caused by main app & libc having map set; cannot free them
Rich Felker [Mon, 27 Aug 2012 01:09:26 +0000 (21:09 -0400)]
dladdr support for dynamic linker (nonstandard extension)
based on patches submitted by boris brezillon. this commit also fixes
the issue whereby the main application and libc don't have the address
ranges of their mappings stored, which was theoretically a problem for
RTLD_NEXT support in dlsym; it didn't actually matter because libc
never calls dlsym, and it seemed to be doing the right thing (by
chance) for symbols in the main program as well.
Rich Felker [Sun, 26 Aug 2012 03:15:13 +0000 (23:15 -0400)]
implement "low hanging fruit" from C11
based on Gregor's patch sent to the list. includes:
- stdalign.h
- removing gets in C11 mode
- adding aligned_alloc and adjusting other functions to use it
- adding 'x' flag to fopen for exclusive mode
Rich Felker [Sun, 26 Aug 2012 02:49:47 +0000 (22:49 -0400)]
add c11 quick_exit and at_quick_exit functions
Rich Felker [Sat, 25 Aug 2012 21:40:27 +0000 (17:40 -0400)]
fix bug in gnu hash lookup on dlsym(handle, name) lookups
wrong hash was being passed; just a copy/paste error. did not affect
lookups in the global namespace; this is probably why it was not
caught in testing.
Rich Felker [Sat, 25 Aug 2012 21:31:59 +0000 (17:31 -0400)]
clean up search_vec usage for vdso
Rich Felker [Sat, 25 Aug 2012 21:30:59 +0000 (17:30 -0400)]
use new search_vec function to find vdso in dynamic linker
Rich Felker [Sat, 25 Aug 2012 21:24:46 +0000 (17:24 -0400)]
ensure canary is setup if stack-prot libs are dlopen'd into non-ssp app
previously, this usage could lead to a crash if the thread pointer was
still uninitialized, and otherwise would just cause the canary to be
zero (less secure).
Rich Felker [Sat, 25 Aug 2012 21:13:28 +0000 (17:13 -0400)]
add gnu hash support in the dynamic linker
based on the patches contributed by boris brezillon.
Rich Felker [Fri, 24 Aug 2012 21:01:17 +0000 (17:01 -0400)]
type exposure fixes in sys/sem.h
Rich Felker [Fri, 24 Aug 2012 20:16:30 +0000 (16:16 -0400)]
stdio_ext.h needs to include stdio.h, at least to get FILE...
Rich Felker [Fri, 24 Aug 2012 19:55:36 +0000 (15:55 -0400)]
fix missing uintXX_t in nameser.h
Rich Felker [Fri, 24 Aug 2012 18:23:16 +0000 (14:23 -0400)]
fix dirent.h with _BSD_SOURCE
Rich Felker [Thu, 23 Aug 2012 18:38:34 +0000 (14:38 -0400)]
optimize legacy ffs function
Rich Felker [Mon, 20 Aug 2012 00:48:16 +0000 (20:48 -0400)]
fix bug whereby most atexit-registered functions got skipped
Rich Felker [Sat, 18 Aug 2012 20:00:23 +0000 (16:00 -0400)]
make dynamic linker report all failures before exiting
before, only the first library that failed to load or symbol that
failed to resolve was reported, and then the dynamic linker
immediately exited. when attempting to fix a library compatibility
issue, this is about the worst possible behavior. now we print all
errors as they occur and exit at the very end if errors were
encountered.
Rich Felker [Sat, 18 Aug 2012 03:51:00 +0000 (23:51 -0400)]
release notes for 0.9.4
Rich Felker [Sat, 18 Aug 2012 03:45:21 +0000 (23:45 -0400)]
add mips to supported arch list in INSTALL file
Rich Felker [Sat, 18 Aug 2012 01:23:10 +0000 (21:23 -0400)]
crt1 must align stack pointer on mips
it's naturally aligned when entered with the kernel argv array, but if
ld.so has been invoked explicitly to run a program, the stack will not
be aligned due to having thrown away argv[0].
Rich Felker [Sat, 18 Aug 2012 00:02:37 +0000 (20:02 -0400)]
fix bug computing argc when invoking ld-musl-mips.so.1 progname ...
Rich Felker [Fri, 17 Aug 2012 23:32:24 +0000 (19:32 -0400)]
split up installation target
patch by Luca Barbato (lu_zero)
Rich Felker [Fri, 17 Aug 2012 21:13:53 +0000 (17:13 -0400)]
fix extremely rare but dangerous race condition in robust mutexes
if new shared mappings of files/devices/shared memory can be made
between the time a robust mutex is unlocked and its subsequent removal
from the pending slot in the robustlist header, the kernel can
inadvertently corrupt data in the newly-mapped pages when the process
terminates. i am fixing the bug by using the same global vm lock
mechanism that was used to fix the race condition with unmapping
barriers after pthread_barrier_wait returns.
Rich Felker [Fri, 17 Aug 2012 20:53:09 +0000 (16:53 -0400)]
fix float parsing logic for long decimal expansions
this affects at least the case of very long inputs, but may also
affect shorter inputs that become long due to growth while upscaling.
basically, the logic for the circular buffer indices of the initial
base-10^9 digit and the slot one past the final digit, and for
simplicity of the loop logic, assumes an invariant that they're not
equal. the upscale loop, which can increase the length of the
base-10^9 representation, attempted to preserve this invariant, but
was actually only ensuring that the end index did not loop around past
the start index, not that the two never become equal.
the main (only?) effect of this bug was that subsequent logic treats
the excessively long number as having no digits, leading to junk
results.
Rich Felker [Thu, 16 Aug 2012 02:35:02 +0000 (22:35 -0400)]
handle null arguments to legacy bsd err.h functions
Rich Felker [Wed, 15 Aug 2012 19:35:32 +0000 (15:35 -0400)]
improve headers to better deal with removed-in-posix-2008 features
with this patch, setting _POSIX_SOURCE, or setting _POSIX_C_SOURCE or
_XOPEN_SOURCE to an old version, will bring back the interfaces that
were removed in POSIX 2008 - at least the ones i've covered so far,
which are gethostby*, usleep, and ualarm. if there are other functions
still in widespread use that were removed for which similar changes
would be beneficial, they can be added just like this.
Rich Felker [Wed, 15 Aug 2012 12:31:44 +0000 (08:31 -0400)]
add missing xattr functions
not sure why these were originally omitted..
Rich Felker [Wed, 15 Aug 2012 04:19:42 +0000 (00:19 -0400)]
update copyright/credits for recent code additions
Rich Felker [Wed, 15 Aug 2012 02:50:16 +0000 (22:50 -0400)]
support configuring cross compiling with CROSS_COMPILE prefix variable
Rich Felker [Tue, 14 Aug 2012 01:55:35 +0000 (21:55 -0400)]
Merge remote-tracking branch 'nsz/bsd'
Rich Felker [Tue, 14 Aug 2012 01:55:22 +0000 (21:55 -0400)]
Merge remote-tracking branch 'nsz/exp'
nsz [Mon, 13 Aug 2012 20:06:01 +0000 (22:06 +0200)]
math: fix _BSD_SOURCE namespace in math.h
Rich Felker [Mon, 13 Aug 2012 20:00:31 +0000 (16:00 -0400)]
remove significandl
this function never existed historically; since the float/double
functions it's based on are nonstandard and deprecated, there's really
no justification for its existence except that glibc has it. it can be
added back if there's ever really a need...
Rich Felker [Mon, 13 Aug 2012 18:51:43 +0000 (14:51 -0400)]
add significand[fl] math functions
Rich Felker [Mon, 13 Aug 2012 18:50:30 +0000 (14:50 -0400)]
publicly expose getdents api under _BSD_SOURCE
Rich Felker [Sun, 12 Aug 2012 01:33:13 +0000 (21:33 -0400)]
memcpy asm for i386 and x86_64
Rich Felker [Sat, 11 Aug 2012 23:51:21 +0000 (19:51 -0400)]
avoid need for -march=mips2 to compile mips atomic.h asm
linux guarantees ll/sc are always available. on mips1, they will be
emulated by the kernel. thus they are part of the linux mips1 abi and
safe to use.
Rich Felker [Sat, 11 Aug 2012 22:40:33 +0000 (18:40 -0400)]
remove unused but buggy code from strstr.c
Rich Felker [Sat, 11 Aug 2012 22:39:12 +0000 (18:39 -0400)]
remove buggy short-string wcsstr implementation; always use twoway
since this interface is rarely used, it's probably best to lean
towards keeping code size down anyway. one-character needles will
still be found immediately by the initial wcschr call anyway.
Rich Felker [Sat, 11 Aug 2012 22:10:38 +0000 (18:10 -0400)]
add bsd fgetln function
optimized to avoid allocation and return lines directly out of the
stream buffer whenever possible.
Rich Felker [Sat, 11 Aug 2012 03:39:32 +0000 (23:39 -0400)]
minor but worthwhile optimization in printf: avoid expensive strspn
the strspn call was made for every format specifier and end-of-string,
even though the expected return value was 1-2 for normal usage.
replace with simple loop.
Rich Felker [Sat, 11 Aug 2012 02:18:49 +0000 (22:18 -0400)]
trivial optimization to printf: avoid wasted call frame
amusingly, this cuts more than 10% off the run time of printf("a"); on
the machine i tested it on.
sadly the same optimization is not possible for snprintf without
duplicating all the pseudo-FILE setup code, which is not worth it.
Rich Felker [Fri, 10 Aug 2012 19:13:26 +0000 (15:13 -0400)]
use int instead of long for ptrdiff_t on all 32-bit archs
this is needed to match the underlying "ABI" standards. it's not
really an ABI issue since the binary representations are the same, but
having the wrong type can lead to errors when the type arising from a
difference-of-pointers expression does not match the defined type of
ptrdiff_t. most of the problems affect C++, not C.
Rich Felker [Fri, 10 Aug 2012 18:59:20 +0000 (14:59 -0400)]
fix incorrect ptrdiff_t type on mips