summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
29 hoursbump version for 1.0.51 releaseHEADv1.0.51masterWaldemar Brodkorb
33 hoursclock_adjtime: warn instead of error outWaldemar Brodkorb
8 daysfix possible overflow in pointer arithmetics strnlen()Frank Mehnert
It is undefined behavior to compare two pointers belonging to different objects. This includes the case where the addition overflows. Clang-20 seems to follow this rule more eagerly and optimizes away the old test. Fix the test by performing the addition on uintptr_t values rather than on on char pointers. See also https://github.com/llvm/llvm-project/issues/121909. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
8 daysprevent warning about setting an unused variableFrank Mehnert
Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
8 daystime64_helpers.h: error out when attempting to compile with TIME64 for 32bit ↵Nadav Tasher
targets on Linux versions prior to 5.1.0 Using 64bit time on 32bit targets was only introduced in Linux 5.1.0. On versions prior to that, compiling uClibc-ng produces incorrect headers that cause the `clock_nanosleep` syscall to receive incorrect arguments. This change was previously introduced in `features.h`, but was reverted due to inclusion errors when compiling other projects. Signed-off-by: Nadav Tasher <tashernadav@gmail.com>
8 daysRevert "features.h: error out when attempting to compile with TIME64 for ↵Nadav Tasher
32bit targets on Linux versions prior to 5.1.0" This reverts previous changes made to features.h which caused redefinitions when including `features.h`. The reverted functionality will be reintroduced in a future commit. Signed-off-by: Nadav Tasher <tashernadav@gmail.com>
9 daysuclibc: prevent warning about declaring an unused functionFrank Mehnert
Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
9 daysuclibc: prevent warning about setting an unused variableFrank Mehnert
This variable is used either if __UCLIBC_HAS_FLOATS__ is defined or if __UCLIBC_HAS_GLIBC_DIGIT_GROUPING__ is defined. Instead of adding more complicated #ifdef magic, just mark this variable as possibly unused to satisfy the compiler. Signed-off-by: marcus.haehnel@kernkonzept.com
13 daysfeatures.h: error out when attempting to compile with TIME64 for 32bit ↵Nadav Tasher
targets on Linux versions prior to 5.1.0 Using 64bit time on 32bit targets was only introduced in Linux 5.1.0. On versions prior to that, compiling uClibc-ng produces incorrect headers that cause the `clock_nanosleep` syscall to receive incorrect arguments. Signed-off-by: Nadav Tasher <tashernadav@gmail.com>
2024-10-30fix TLS memory leak with dlopenMingxiang Lu
Signed-off-by: Mingxiang Lu <lu.mingxiang@h3c.com> Signed-off-by: Waldemar Brodkorb <wbx@uclibc-ng.org>
2024-09-08Revert "mips64: time64 for n32 ABI breaks a lot of tests, disable it for now"Dmitry Chestnykh
This reverts commit dd01754e21da71706af07f3e56eade66fc9164fb. Signed-off-by: Dmitry Chestnykh <dm.chestnykh@gmail.com>
2024-09-08mips64n32, time64: Select correct _dl_fstat implDmitry Chestnykh
With time64 enabled we have to use statx() instead of stat() or fstat() If the _dl_fstat implementation isn't selected correctly we can have multiple errors inside dynamic linker during startup of the system and of the almost every process Add sparc exclusion like in other places inside this header Signed-off-by: Dmitry Chestnykh <dm.chestnykh@gmail.com>
2024-08-16mips64: time64 for n32 ABI breaks a lot of tests, disable it for nowWaldemar Brodkorb
2024-08-14add process_vm_{read,write}v syscall wrapper from glibcWaldemar Brodkorb
2024-08-13bump version for 1.0.50 releasev1.0.50Waldemar Brodkorb
2024-08-13getrandom: remove __USE_GNU / add GRND_INSECUREWaldemar Brodkorb
Neither glibc nor musl use __GNU macro to hide getrandom. While there sync with glibc and add GRND_INSECURE flag.
2024-08-11add memfd_create syscall wrapperWaldemar Brodkorb
2024-08-11riscv: remove incomplete context implementation, use libucontextWaldemar Brodkorb
2024-08-09bits/stat.h: Declare st_mtim if defined(__USE_XOPEN2K8), add missingWaldemar Brodkorb
d0c8c185b439187b12644457bb2aa0326f25aaf7 was not complete, add missing architectures.
2024-08-09lseek: allow SEEK_DATA/SEEK_HOLE to be usedWaldemar Brodkorb
2024-07-30iconv: prevent compiler warning during initialization with jis0208Frank Mehnert
The data in jis0208.h initializes a two-dimensional array, so insert the missing braces to prevent a compiler warning about missing braces around initializer. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30iconv: fix parameter type of utf8seq_is_{overlong,surrogate,illegal}Frank Mehnert
Use `unsigned char *s` rather than `char *s`. First, this fixes compiler warnings when these functions are called from utf8dec_wchar() passing the `in` pointer of type `unsigned char *`. Second, these functions are always called with characters >= 0x80 so the sign bit is set. Shifting right a negative signed value will insert `1` from the left side, so `foo >> 1` where foo is negative will always have the sign bit set. So at least "case 2" would never return true. There is a similar problem with tests like (*(s+1) >= 0xA0) && (*(s+1) <= 0xBF) This condition is always false with `char *s`. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30ldso.c: use 'unsigned int' as loop variable typeFrank Mehnert
As the condition for terminating the loop compares the loop variable against an ElfW() variable which is, depending on the platform, either uint32_t or uint64_t, use 'unsigned int' rather than 'int' for the loop variable to prevent corresponding compiler warnings. Note that it would not make sense to use 'unsigned long' because the number of program headers will never exceed 32-bit. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30iconv: explicitly state operator precedenceFrank Mehnert
gcc suggests to set parentheses around '-'/'+' inside '<<' if the corresponding warnings are enabled. Make the compiler happy and make the code easier to understand for developers. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30iconv: explicit cast to `unsigned char*`Frank Mehnert
Perform an explicit cast to prevent the corresponding compiler warning. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30libdl: properly cast parameters for %p format string specifierFrank Mehnert
The "%p" format specifier requires a void pointer. Cast parameters of type ElfW(Addr) to 'void *'. This fixes warnings if _dl_if_debug_print() performs parameter type checking. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-30Group conditions after `&&`Dmitry Chestnykh
If the conditions are not grouped we can reach this block even if `__NR_stat` is not defined. `defined __NR_stat && ((!defined(__UCLIBC_USE_TIME64__) || defined(__sparc__))` gives us false but `LINUX_VERSION_CODE <= KERNEL_VERSION(5,1,0))` may give us true. So if linux headers version is below 5.1.0 and __NR_stat is not defined we can have compilation error Signed-off-by: Dmitry Chestnykh <dm.chestnykh@gmail.com>
2024-07-27bits/stat.h: Declare st_mtim if defined(__USE_XOPEN2K8), everywhereJ. Neuschäfer
While building software that sets _POSIX_C_SOURCE=200809L and uses stat.st_mtim for ARM, it was noticed that st_mtim was not defined. This seems to be because common/bits/stat.h was picked up, which does not take __USE_XOPEN2K8 as a reason to enable st_mtim and related fields. This appears to be an oversight, and porting the check from common-generic/bits/stat.h to other architectures does indeed fix the build issue. This patch is based on commit 50bd6d06e ("Fix memory corruption due to struct stat field"). Signed-off-by: J. Neuschäfer <j.neuschaefer@gmx.net>
2024-07-24add SEEK_DATA/SEEK_HOLEWaldemar Brodkorb
2024-07-21Fix compilation with 4.x kernel headersDmitry Chestnykh
- Fallback to __NR_stat syscall in ld.so if we use 4.x kernel headers. 4.x kernel doesn't support 64-bit time so we can use old syscall - Add preprocessor conditions to have fstat64 and fstatat64 in libc with old kernel headers Signed-off-by: Dmitry Chestnykh <dm.chestnykh@gmail.com>
2024-07-19arm: Replace deprecated asm instructions for ARMv8 AArch32Valentin Gehrke
ARMv8 has particular restrictions which coprocessor can be used and as such these instructions, which were likely used for backwards compatibility purposes, cannot be used on ARMv8. We solve this by checking for ARMv8 and then using the corresponding mnemonics which were placed in comments alongside the instructions causing issues. Fixes the following errors: .../setjmp.S:59:6: error: invalid operand for instruction stc p11, cr8, [r12], #68 ^ .../setjmp.S:62:6: error: invalid operand for instruction mrc p10, 7, r2, cr1, cr0, 0 ^ .../__longjmp.S:69:6: error: invalid operand for instruction ldc p11, cr8, [r12], #68 ^ .../__longjmp.S:73:6: error: invalid operand for instruction mcr p10, 7, r1, cr1, cr0, 0 ^ Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-17allow to use <sys/ucontext.h>Waldemar Brodkorb
For architectures without ucontext implementation it is possible to use libucontext with this small adaptation.
2024-07-09Clang support for gnu_inline attributeWaldemar Brodkorb
Clang also supports the gnu_inline attribute and the __GNUC_STDC_INLINE__ macro (C99 semantics). However, it reports as GCC 4.2 compatible (__GNUC_MINOR__ / __GNUC__) and thus the current defines do not think it can support this. Add clang as an alternative for this support. Documentation shows that this attribute is supported since at least Clang 8. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09buildsys: allow building with gcc-14Marcus Haehnel
GCC-14 requires all functions to have an explicit return type. An implicit return type is no longer supported. main() in the ncurses link check was declared without return type. Add it to make this work on GCC-14. See also: https://gcc.gnu.org/gcc-14/porting_to.html Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09features.h: add clang prerequisite macroMarcus Haehnel
This can be used to guard features for specific clang versions. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09c++: Remove deprecated dynamic exception specificationSven Linker
Dynamic exception specification using `throw()` is deprecated since C++11 and removed in C++17. This change replaces `throw()` with `noexcept` when compiling for newer standards. Co-authored-by: Sven Linker <sven.linker@kernkonzept.com> Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09stdlib: increase number of static atexit handlers to 32Yann Le Du
The existing limit of 20 was found to be insufficient when moving from gcc 8 to gcc 9. At the time a test ran already 16 handlers had been installed leaving only minimal room for application installed handlers. Musl uses 32, as does newlib. Further, the ISO C standard for C99 specifies that: The implementation shall support the registration of at least 32 functions. (7.20.4.2 The atexit function) Co-authored-by: Yann Le Du <yann.le.du@kernkonzept.com> Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09libm: Fix float conversion compiler warningMarcus Haehnel
Make two implicit casts from double to int explicit to silence compiler warnings about them. The casts are required during the computation of exponentiation. Co-authored-by: Sven Linker <sven.linker@kernkonzept.com> Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09uclibc: Fix double promotion warningMarcus Haehnel
Add casts where necessary to convince clang that the promotion of float to double is intentional. Co-authored-by: Sven Linker <sven.linker@kernkonzept.com> Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-07-09ldso/dl-vdso: avoid compiler warning if configured without vdsoMarcus Haehnel
The parameters are not used in the function variant without vdso support, so tell this to the compiler to avoid a warning. Also fix the indentation to be in-line with other functions in the file. Signed-off-by: Marcus Haehnel <marcus.haehnel@kernkonzept.com>
2024-06-15bump version for 1.0.49 releasev1.0.49Waldemar Brodkorb
2024-06-15libc: cast free() argument to void * in wchar.cYuriy Kolerov
iconv_close() accepts iconv_t type (which is void *) and passes it to free() which accepts void *. However, GCC 14 raises a -Wint-conversion warning if it is not casted to void * because GCC cannot unwind typedef of iconv_t. Signed-off-by: Yuriy Kolerov <ykolerov@synopsys.com>
2024-06-10config: enable TIME64 by defaultWaldemar Brodkorb
2024-06-10config: make ctor/dtor visible againWaldemar Brodkorb
2024-06-10m68k: fix for m68000 cpuWaldemar Brodkorb
See here for details: https://github.com/wbx-github/uclibc-ng/issues/15
2024-06-04xtensa: add FDPIC supportMax Filippov
This change implements Xtensa FDPIC ABI as specified in the first version of the following document: https://github.com/jcmvbkbc/xtensa-abi/blob/master/fdpic-xtensa.txt Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
2024-05-31epoll.h: Add epoll ioctlsJoe Damato
add two ioctls to get and set struct epoll_params to allow users to control epoll based busy polling of network sockets. added to uapi in commit 18e2bf0edf4dd88d9656ec92395aa47392e85b61 (Linux kernel 6.9 and newer). Signed-off-by: Joe Damato <jdamato@fastly.com>
2024-05-21xtensa: make _init and _fini hiddenMax Filippov
Make _init and _fini hidden so that references to these symbols bind locally in the shared objects. glibc does the same. Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
2024-05-21xtensa: use compiler-provided XCHAL macrosMax Filippov
Starting with gcc-13 the compiler provides configuration-specific macro definitions for the target xtensa core. Use them when available instead of the configuration overlay file xtensa-config.h Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
2024-05-21linuxthreads: enable unwinding over signal framesMax Filippov
linuxthreads use a helper function to invoke signal handlers, this function needs stack unwinding information to enable stack unwinding from signal handlers over signal frames. Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>