From 98736912c382fd083db7db6f71259c26ce2f6cab Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Wed, 11 Dec 2024 14:14:01 -0800 Subject: [PATCH] Revert upstream musl LFS64 changes. Revert musl patches: - 246f1c811448f37a44b41cd8df8d0ef9736d95f4 - 25e6fee27f4a293728dd15b659170e7b9c7db9bc - 7c41047285a24a97e700b4fb5b6b69f4505e2d82 - 718f363bc2067b6487900eddc9180c84e7739f80 In upstream musl, these patches replace the explicit LFS64 symbols with dynamic linker symbol lookups, which wasi-libc doesn't have. To preserve compatibility with existing code using these symbols, revert these patches in wasi-libc. --- libc-top-half/musl/compat/time32/__xstat.c | 8 ++--- .../musl/compat/time32/aio_suspend_time32.c | 2 ++ .../musl/compat/time32/fstat_time32.c | 2 ++ .../musl/compat/time32/fstatat_time32.c | 2 ++ .../musl/compat/time32/lstat_time32.c | 2 ++ .../musl/compat/time32/stat_time32.c | 2 ++ libc-top-half/musl/include/aio.h | 2 +- libc-top-half/musl/include/dirent.h | 2 +- libc-top-half/musl/include/fcntl.h | 4 +-- libc-top-half/musl/include/glob.h | 2 +- libc-top-half/musl/include/sys/mman.h | 2 +- libc-top-half/musl/include/sys/resource.h | 2 +- libc-top-half/musl/include/sys/sendfile.h | 2 +- libc-top-half/musl/include/sys/stat.h | 2 +- libc-top-half/musl/include/sys/statfs.h | 2 +- libc-top-half/musl/include/sys/statvfs.h | 2 +- libc-top-half/musl/include/sys/types.h | 2 +- libc-top-half/musl/include/sys/uio.h | 2 +- libc-top-half/musl/include/unistd.h | 2 +- libc-top-half/musl/ldso/dynlink.c | 35 ------------------- libc-top-half/musl/src/aio/aio.c | 7 ++++ libc-top-half/musl/src/aio/aio_suspend.c | 4 +++ libc-top-half/musl/src/aio/lio_listio.c | 2 ++ libc-top-half/musl/src/dirent/alphasort.c | 2 ++ libc-top-half/musl/src/dirent/readdir.c | 2 ++ libc-top-half/musl/src/dirent/readdir_r.c | 2 ++ libc-top-half/musl/src/dirent/scandir.c | 2 ++ libc-top-half/musl/src/dirent/versionsort.c | 3 ++ libc-top-half/musl/src/fcntl/creat.c | 2 ++ libc-top-half/musl/src/fcntl/open.c | 2 ++ libc-top-half/musl/src/fcntl/openat.c | 2 ++ libc-top-half/musl/src/fcntl/posix_fadvise.c | 2 ++ .../musl/src/fcntl/posix_fallocate.c | 2 ++ libc-top-half/musl/src/legacy/ftw.c | 2 ++ libc-top-half/musl/src/linux/fallocate.c | 3 ++ libc-top-half/musl/src/linux/getdents.c | 2 ++ libc-top-half/musl/src/linux/prlimit.c | 3 ++ libc-top-half/musl/src/linux/sendfile.c | 2 ++ libc-top-half/musl/src/misc/getrlimit.c | 2 ++ libc-top-half/musl/src/misc/lockf.c | 2 ++ libc-top-half/musl/src/misc/nftw.c | 2 ++ libc-top-half/musl/src/misc/setrlimit.c | 2 ++ libc-top-half/musl/src/mman/mmap.c | 2 ++ libc-top-half/musl/src/regex/glob.c | 3 ++ libc-top-half/musl/src/stat/__xstat.c | 5 +++ libc-top-half/musl/src/stat/fstat.c | 4 +++ libc-top-half/musl/src/stat/fstatat.c | 4 +++ libc-top-half/musl/src/stat/lstat.c | 4 +++ libc-top-half/musl/src/stat/stat.c | 4 +++ libc-top-half/musl/src/stat/statvfs.c | 5 +++ libc-top-half/musl/src/stdio/fgetpos.c | 2 ++ libc-top-half/musl/src/stdio/fopen.c | 2 ++ libc-top-half/musl/src/stdio/freopen.c | 2 ++ libc-top-half/musl/src/stdio/fseek.c | 2 ++ libc-top-half/musl/src/stdio/fsetpos.c | 2 ++ libc-top-half/musl/src/stdio/ftell.c | 2 ++ libc-top-half/musl/src/stdio/tmpfile.c | 2 ++ libc-top-half/musl/src/temp/mkostemp.c | 2 ++ libc-top-half/musl/src/temp/mkostemps.c | 1 + libc-top-half/musl/src/temp/mkstemp.c | 2 ++ libc-top-half/musl/src/temp/mkstemps.c | 2 ++ libc-top-half/musl/src/unistd/ftruncate.c | 2 ++ libc-top-half/musl/src/unistd/lseek.c | 1 + libc-top-half/musl/src/unistd/mipsn32/lseek.c | 1 + libc-top-half/musl/src/unistd/pread.c | 2 ++ libc-top-half/musl/src/unistd/preadv.c | 2 ++ libc-top-half/musl/src/unistd/pwrite.c | 2 ++ libc-top-half/musl/src/unistd/pwritev.c | 2 ++ libc-top-half/musl/src/unistd/truncate.c | 2 ++ libc-top-half/musl/src/unistd/x32/lseek.c | 1 + 70 files changed, 148 insertions(+), 54 deletions(-) diff --git a/libc-top-half/musl/compat/time32/__xstat.c b/libc-top-half/musl/compat/time32/__xstat.c index e52b5deb2..acfbd3cc5 100644 --- a/libc-top-half/musl/compat/time32/__xstat.c +++ b/libc-top-half/musl/compat/time32/__xstat.c @@ -3,22 +3,22 @@ struct stat32; -int __fxstat(int ver, int fd, struct stat32 *buf) +int __fxstat64(int ver, int fd, struct stat32 *buf) { return __fstat_time32(fd, buf); } -int __fxstatat(int ver, int fd, const char *path, struct stat32 *buf, int flag) +int __fxstatat64(int ver, int fd, const char *path, struct stat32 *buf, int flag) { return __fstatat_time32(fd, path, buf, flag); } -int __lxstat(int ver, const char *path, struct stat32 *buf) +int __lxstat64(int ver, const char *path, struct stat32 *buf) { return __lstat_time32(path, buf); } -int __xstat(int ver, const char *path, struct stat32 *buf) +int __xstat64(int ver, const char *path, struct stat32 *buf) { return __stat_time32(path, buf); } diff --git a/libc-top-half/musl/compat/time32/aio_suspend_time32.c b/libc-top-half/musl/compat/time32/aio_suspend_time32.c index d99cb651d..ed5119bd7 100644 --- a/libc-top-half/musl/compat/time32/aio_suspend_time32.c +++ b/libc-top-half/musl/compat/time32/aio_suspend_time32.c @@ -7,3 +7,5 @@ int __aio_suspend_time32(const struct aiocb *const cbs[], int cnt, const struct return aio_suspend(cbs, cnt, ts32 ? (&(struct timespec){ .tv_sec = ts32->tv_sec, .tv_nsec = ts32->tv_nsec}) : 0); } + +weak_alias(aio_suspend, aio_suspend64); diff --git a/libc-top-half/musl/compat/time32/fstat_time32.c b/libc-top-half/musl/compat/time32/fstat_time32.c index e5d52022d..3e0843988 100644 --- a/libc-top-half/musl/compat/time32/fstat_time32.c +++ b/libc-top-half/musl/compat/time32/fstat_time32.c @@ -13,3 +13,5 @@ int __fstat_time32(int fd, struct stat32 *restrict st32) if (!r) memcpy(st32, &st, offsetof(struct stat, st_atim)); return r; } + +weak_alias(fstat, fstat64); diff --git a/libc-top-half/musl/compat/time32/fstatat_time32.c b/libc-top-half/musl/compat/time32/fstatat_time32.c index 31d42e636..85dcb008e 100644 --- a/libc-top-half/musl/compat/time32/fstatat_time32.c +++ b/libc-top-half/musl/compat/time32/fstatat_time32.c @@ -13,3 +13,5 @@ int __fstatat_time32(int fd, const char *restrict path, struct stat32 *restrict if (!r) memcpy(st32, &st, offsetof(struct stat, st_atim)); return r; } + +weak_alias(fstatat, fstatat64); diff --git a/libc-top-half/musl/compat/time32/lstat_time32.c b/libc-top-half/musl/compat/time32/lstat_time32.c index 28cb5a0b9..c1257a144 100644 --- a/libc-top-half/musl/compat/time32/lstat_time32.c +++ b/libc-top-half/musl/compat/time32/lstat_time32.c @@ -13,3 +13,5 @@ int __lstat_time32(const char *restrict path, struct stat32 *restrict st32) if (!r) memcpy(st32, &st, offsetof(struct stat, st_atim)); return r; } + +weak_alias(lstat, lstat64); diff --git a/libc-top-half/musl/compat/time32/stat_time32.c b/libc-top-half/musl/compat/time32/stat_time32.c index b154b0f9f..8c6121dad 100644 --- a/libc-top-half/musl/compat/time32/stat_time32.c +++ b/libc-top-half/musl/compat/time32/stat_time32.c @@ -13,3 +13,5 @@ int __stat_time32(const char *restrict path, struct stat32 *restrict st32) if (!r) memcpy(st32, &st, offsetof(struct stat, st_atim)); return r; } + +weak_alias(stat, stat64); diff --git a/libc-top-half/musl/include/aio.h b/libc-top-half/musl/include/aio.h index a938fcad5..453c41b74 100644 --- a/libc-top-half/musl/include/aio.h +++ b/libc-top-half/musl/include/aio.h @@ -49,7 +49,7 @@ int aio_fsync(int, struct aiocb *); int lio_listio(int, struct aiocb *__restrict const *__restrict, int, struct sigevent *__restrict); -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define aiocb64 aiocb #define aio_read64 aio_read #define aio_write64 aio_write diff --git a/libc-top-half/musl/include/dirent.h b/libc-top-half/musl/include/dirent.h index 88db23d46..52a3b16a4 100644 --- a/libc-top-half/musl/include/dirent.h +++ b/libc-top-half/musl/include/dirent.h @@ -68,7 +68,7 @@ int getdents(int, struct dirent *, size_t); int versionsort(const struct dirent **, const struct dirent **); #endif -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define dirent64 dirent #define readdir64 readdir #ifdef __wasilibc_unmodified_upstream /* readdir_r is obsolete */ diff --git a/libc-top-half/musl/include/fcntl.h b/libc-top-half/musl/include/fcntl.h index b06e79950..9c06d25bc 100644 --- a/libc-top-half/musl/include/fcntl.h +++ b/libc-top-half/musl/include/fcntl.h @@ -203,6 +203,7 @@ struct f_owner_ex { #endif #ifdef __wasilibc_unmodified_upstream /* WASI has no fallocate */ int fallocate(int, int, off_t, off_t); +#define posix_fallocate64 posix_fallocate #endif #ifdef __wasilibc_unmodified_upstream /* WASI has no name_to_handle_at */ int name_to_handle_at(int, const char *, struct file_handle *, int *, int); @@ -234,9 +235,6 @@ ssize_t tee(int, int, size_t, unsigned); #define lockf64 lockf #endif #define posix_fadvise64 posix_fadvise -#ifdef __wasilibc_unmodified_upstream /* WASI has no fallocate */ -#define posix_fallocate64 posix_fallocate -#endif #define off64_t off_t #ifdef __wasilibc_unmodified_upstream /* WASI has no fallocate */ #if defined(_GNU_SOURCE) diff --git a/libc-top-half/musl/include/glob.h b/libc-top-half/musl/include/glob.h index edaa16eff..8c4bf1589 100644 --- a/libc-top-half/musl/include/glob.h +++ b/libc-top-half/musl/include/glob.h @@ -41,7 +41,7 @@ void globfree(glob_t *); #define GLOB_NOMATCH 3 #define GLOB_NOSYS 4 -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define glob64 glob #define globfree64 globfree #define glob64_t glob_t diff --git a/libc-top-half/musl/include/sys/mman.h b/libc-top-half/musl/include/sys/mman.h index 170df2eb5..335ba2d71 100644 --- a/libc-top-half/musl/include/sys/mman.h +++ b/libc-top-half/musl/include/sys/mman.h @@ -145,7 +145,7 @@ int mincore (void *, size_t, unsigned char *); int shm_open (const char *, int, mode_t); int shm_unlink (const char *); -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define mmap64 mmap #define off64_t off_t #endif diff --git a/libc-top-half/musl/include/sys/resource.h b/libc-top-half/musl/include/sys/resource.h index 0736fb48f..6c3a7ff2a 100644 --- a/libc-top-half/musl/include/sys/resource.h +++ b/libc-top-half/musl/include/sys/resource.h @@ -101,7 +101,7 @@ int prlimit(pid_t, int, const struct rlimit *, struct rlimit *); #define RLIM_NLIMITS RLIMIT_NLIMITS -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define RLIM64_INFINITY RLIM_INFINITY #define RLIM64_SAVED_CUR RLIM_SAVED_CUR #define RLIM64_SAVED_MAX RLIM_SAVED_MAX diff --git a/libc-top-half/musl/include/sys/sendfile.h b/libc-top-half/musl/include/sys/sendfile.h index 253a041b1..e7570d8e5 100644 --- a/libc-top-half/musl/include/sys/sendfile.h +++ b/libc-top-half/musl/include/sys/sendfile.h @@ -10,7 +10,7 @@ extern "C" { ssize_t sendfile(int, int, off_t *, size_t); -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define sendfile64 sendfile #define off64_t off_t #endif diff --git a/libc-top-half/musl/include/sys/stat.h b/libc-top-half/musl/include/sys/stat.h index d3d20f11d..01d30ddaf 100644 --- a/libc-top-half/musl/include/sys/stat.h +++ b/libc-top-half/musl/include/sys/stat.h @@ -169,7 +169,7 @@ int statx(int, const char *__restrict, int, unsigned, struct statx *__restrict); #endif #endif -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define stat64 stat #define fstat64 fstat #define lstat64 lstat diff --git a/libc-top-half/musl/include/sys/statfs.h b/libc-top-half/musl/include/sys/statfs.h index 7a2e11cd5..6f4c6230f 100644 --- a/libc-top-half/musl/include/sys/statfs.h +++ b/libc-top-half/musl/include/sys/statfs.h @@ -18,7 +18,7 @@ typedef struct __fsid_t { int statfs (const char *, struct statfs *); int fstatfs (int, struct statfs *); -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define statfs64 statfs #define fstatfs64 fstatfs #define fsblkcnt64_t fsblkcnt_t diff --git a/libc-top-half/musl/include/sys/statvfs.h b/libc-top-half/musl/include/sys/statvfs.h index 71d9d1f92..6cf35c594 100644 --- a/libc-top-half/musl/include/sys/statvfs.h +++ b/libc-top-half/musl/include/sys/statvfs.h @@ -43,7 +43,7 @@ int fstatvfs (int, struct statvfs *); #define ST_NODIRATIME 2048 #define ST_RELATIME 4096 -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define statvfs64 statvfs #define fstatvfs64 fstatvfs #define fsblkcnt64_t fsblkcnt_t diff --git a/libc-top-half/musl/include/sys/types.h b/libc-top-half/musl/include/sys/types.h index 3363374fd..0c35541da 100644 --- a/libc-top-half/musl/include/sys/types.h +++ b/libc-top-half/musl/include/sys/types.h @@ -71,7 +71,7 @@ typedef unsigned long long u_quad_t; #include #endif -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define blkcnt64_t blkcnt_t #define fsblkcnt64_t fsblkcnt_t #define fsfilcnt64_t fsfilcnt_t diff --git a/libc-top-half/musl/include/sys/uio.h b/libc-top-half/musl/include/sys/uio.h index 946e40180..f102d5a56 100644 --- a/libc-top-half/musl/include/sys/uio.h +++ b/libc-top-half/musl/include/sys/uio.h @@ -29,7 +29,7 @@ ssize_t writev (int, const struct iovec *, int); #if defined(_GNU_SOURCE) || defined(_BSD_SOURCE) ssize_t preadv (int, const struct iovec *, int, off_t); ssize_t pwritev (int, const struct iovec *, int, off_t); -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define preadv64 preadv #define pwritev64 pwritev #define off64_t off_t diff --git a/libc-top-half/musl/include/unistd.h b/libc-top-half/musl/include/unistd.h index 869661603..1c1d62d22 100644 --- a/libc-top-half/musl/include/unistd.h +++ b/libc-top-half/musl/include/unistd.h @@ -288,7 +288,7 @@ pid_t gettid(void); #endif #endif -#if defined(_LARGEFILE64_SOURCE) +#if defined(_LARGEFILE64_SOURCE) || defined(_GNU_SOURCE) #define lseek64 lseek #define pread64 pread #define pwrite64 pwrite diff --git a/libc-top-half/musl/ldso/dynlink.c b/libc-top-half/musl/ldso/dynlink.c index 324aa8591..0897f3aeb 100644 --- a/libc-top-half/musl/ldso/dynlink.c +++ b/libc-top-half/musl/ldso/dynlink.c @@ -345,40 +345,6 @@ static struct symdef find_sym(struct dso *dso, const char *s, int need_def) return find_sym2(dso, s, need_def, 0); } -static struct symdef get_lfs64(const char *name) -{ - const char *p; - static const char lfs64_list[] = - "aio_cancel\0aio_error\0aio_fsync\0aio_read\0aio_return\0" - "aio_suspend\0aio_write\0alphasort\0creat\0fallocate\0" - "fgetpos\0fopen\0freopen\0fseeko\0fsetpos\0fstat\0" - "fstatat\0fstatfs\0fstatvfs\0ftello\0ftruncate\0ftw\0" - "getdents\0getrlimit\0glob\0globfree\0lio_listio\0" - "lockf\0lseek\0lstat\0mkostemp\0mkostemps\0mkstemp\0" - "mkstemps\0mmap\0nftw\0open\0openat\0posix_fadvise\0" - "posix_fallocate\0pread\0preadv\0prlimit\0pwrite\0" - "pwritev\0readdir\0scandir\0sendfile\0setrlimit\0" - "stat\0statfs\0statvfs\0tmpfile\0truncate\0versionsort\0" - "__fxstat\0__fxstatat\0__lxstat\0__xstat\0"; - size_t l; - char buf[16]; - for (l=0; name[l]; l++) { - if (l >= sizeof buf) goto nomatch; - buf[l] = name[l]; - } - if (!strcmp(name, "readdir64_r")) - return find_sym(&ldso, "readdir_r", 1); - if (l<2 || name[l-2]!='6' || name[l-1]!='4') - goto nomatch; - buf[l-=2] = 0; - for (p=lfs64_list; *p; p++) { - if (!strcmp(buf, p)) return find_sym(&ldso, buf, 1); - while (*p) p++; - } -nomatch: - return (struct symdef){ 0 }; -} - static void do_relocs(struct dso *dso, size_t *rel, size_t rel_size, size_t stride) { unsigned char *base = dso->base; @@ -432,7 +398,6 @@ static void do_relocs(struct dso *dso, size_t *rel, size_t rel_size, size_t stri def = (sym->st_info>>4) == STB_LOCAL ? (struct symdef){ .dso = dso, .sym = sym } : find_sym(ctx, name, type==REL_PLT); - if (!def.sym) def = get_lfs64(name); if (!def.sym && (sym->st_shndx != SHN_UNDEF || sym->st_info>>4 != STB_WEAK)) { if (dso->lazy && (type==REL_PLT || type==REL_GOT)) { diff --git a/libc-top-half/musl/src/aio/aio.c b/libc-top-half/musl/src/aio/aio.c index d7e063bf9..37309d34f 100644 --- a/libc-top-half/musl/src/aio/aio.c +++ b/libc-top-half/musl/src/aio/aio.c @@ -430,3 +430,10 @@ void __aio_atfork(int who) * We are not a lock holder anyway; the thread in the parent was. */ pthread_rwlock_init(&maplock, 0); } + +weak_alias(aio_cancel, aio_cancel64); +weak_alias(aio_error, aio_error64); +weak_alias(aio_fsync, aio_fsync64); +weak_alias(aio_read, aio_read64); +weak_alias(aio_write, aio_write64); +weak_alias(aio_return, aio_return64); diff --git a/libc-top-half/musl/src/aio/aio_suspend.c b/libc-top-half/musl/src/aio/aio_suspend.c index 1f0c9aaaa..290b43f27 100644 --- a/libc-top-half/musl/src/aio/aio_suspend.c +++ b/libc-top-half/musl/src/aio/aio_suspend.c @@ -73,3 +73,7 @@ int aio_suspend(const struct aiocb *const cbs[], int cnt, const struct timespec } } } + +#if !_REDIR_TIME64 +weak_alias(aio_suspend, aio_suspend64); +#endif diff --git a/libc-top-half/musl/src/aio/lio_listio.c b/libc-top-half/musl/src/aio/lio_listio.c index a672812f4..0799c15d8 100644 --- a/libc-top-half/musl/src/aio/lio_listio.c +++ b/libc-top-half/musl/src/aio/lio_listio.c @@ -139,3 +139,5 @@ int lio_listio(int mode, struct aiocb *restrict const *restrict cbs, int cnt, st return 0; } + +weak_alias(lio_listio, lio_listio64); diff --git a/libc-top-half/musl/src/dirent/alphasort.c b/libc-top-half/musl/src/dirent/alphasort.c index ab2624e2c..bee672ebd 100644 --- a/libc-top-half/musl/src/dirent/alphasort.c +++ b/libc-top-half/musl/src/dirent/alphasort.c @@ -5,3 +5,5 @@ int alphasort(const struct dirent **a, const struct dirent **b) { return strcoll((*a)->d_name, (*b)->d_name); } + +weak_alias(alphasort, alphasort64); diff --git a/libc-top-half/musl/src/dirent/readdir.c b/libc-top-half/musl/src/dirent/readdir.c index 5a03b3635..569fc7057 100644 --- a/libc-top-half/musl/src/dirent/readdir.c +++ b/libc-top-half/musl/src/dirent/readdir.c @@ -25,3 +25,5 @@ struct dirent *readdir(DIR *dir) dir->tell = de->d_off; return de; } + +weak_alias(readdir, readdir64); diff --git a/libc-top-half/musl/src/dirent/readdir_r.c b/libc-top-half/musl/src/dirent/readdir_r.c index 0d5de5f56..e2a818f36 100644 --- a/libc-top-half/musl/src/dirent/readdir_r.c +++ b/libc-top-half/musl/src/dirent/readdir_r.c @@ -25,3 +25,5 @@ int readdir_r(DIR *restrict dir, struct dirent *restrict buf, struct dirent **re *result = buf; return 0; } + +weak_alias(readdir_r, readdir64_r); diff --git a/libc-top-half/musl/src/dirent/scandir.c b/libc-top-half/musl/src/dirent/scandir.c index 7456b9b8b..7ee195dd8 100644 --- a/libc-top-half/musl/src/dirent/scandir.c +++ b/libc-top-half/musl/src/dirent/scandir.c @@ -43,3 +43,5 @@ int scandir(const char *path, struct dirent ***res, *res = names; return cnt; } + +weak_alias(scandir, scandir64); diff --git a/libc-top-half/musl/src/dirent/versionsort.c b/libc-top-half/musl/src/dirent/versionsort.c index 976961051..d4c489230 100644 --- a/libc-top-half/musl/src/dirent/versionsort.c +++ b/libc-top-half/musl/src/dirent/versionsort.c @@ -6,3 +6,6 @@ int versionsort(const struct dirent **a, const struct dirent **b) { return strverscmp((*a)->d_name, (*b)->d_name); } + +#undef versionsort64 +weak_alias(versionsort, versionsort64); diff --git a/libc-top-half/musl/src/fcntl/creat.c b/libc-top-half/musl/src/fcntl/creat.c index c9c43910d..8f8aab646 100644 --- a/libc-top-half/musl/src/fcntl/creat.c +++ b/libc-top-half/musl/src/fcntl/creat.c @@ -4,3 +4,5 @@ int creat(const char *filename, mode_t mode) { return open(filename, O_CREAT|O_WRONLY|O_TRUNC, mode); } + +weak_alias(creat, creat64); diff --git a/libc-top-half/musl/src/fcntl/open.c b/libc-top-half/musl/src/fcntl/open.c index 4c3c82759..1d817a2d6 100644 --- a/libc-top-half/musl/src/fcntl/open.c +++ b/libc-top-half/musl/src/fcntl/open.c @@ -19,3 +19,5 @@ int open(const char *filename, int flags, ...) return __syscall_ret(fd); } + +weak_alias(open, open64); diff --git a/libc-top-half/musl/src/fcntl/openat.c b/libc-top-half/musl/src/fcntl/openat.c index 83a9e0d00..ad165ec32 100644 --- a/libc-top-half/musl/src/fcntl/openat.c +++ b/libc-top-half/musl/src/fcntl/openat.c @@ -15,3 +15,5 @@ int openat(int fd, const char *filename, int flags, ...) return syscall_cp(SYS_openat, fd, filename, flags|O_LARGEFILE, mode); } + +weak_alias(openat, openat64); diff --git a/libc-top-half/musl/src/fcntl/posix_fadvise.c b/libc-top-half/musl/src/fcntl/posix_fadvise.c index 07346d21a..75b8e1aed 100644 --- a/libc-top-half/musl/src/fcntl/posix_fadvise.c +++ b/libc-top-half/musl/src/fcntl/posix_fadvise.c @@ -14,3 +14,5 @@ int posix_fadvise(int fd, off_t base, off_t len, int advice) __SYSCALL_LL_E(len), advice); #endif } + +weak_alias(posix_fadvise, posix_fadvise64); diff --git a/libc-top-half/musl/src/fcntl/posix_fallocate.c b/libc-top-half/musl/src/fcntl/posix_fallocate.c index 80a65cbfd..c57a24aef 100644 --- a/libc-top-half/musl/src/fcntl/posix_fallocate.c +++ b/libc-top-half/musl/src/fcntl/posix_fallocate.c @@ -6,3 +6,5 @@ int posix_fallocate(int fd, off_t base, off_t len) return -__syscall(SYS_fallocate, fd, 0, __SYSCALL_LL_E(base), __SYSCALL_LL_E(len)); } + +weak_alias(posix_fallocate, posix_fallocate64); diff --git a/libc-top-half/musl/src/legacy/ftw.c b/libc-top-half/musl/src/legacy/ftw.c index e757fc6f0..506bd29ce 100644 --- a/libc-top-half/musl/src/legacy/ftw.c +++ b/libc-top-half/musl/src/legacy/ftw.c @@ -7,3 +7,5 @@ int ftw(const char *path, int (*fn)(const char *, const struct stat *, int), int * actually undefined, but works on all real-world machines. */ return nftw(path, (int (*)())fn, fd_limit, FTW_PHYS); } + +weak_alias(ftw, ftw64); diff --git a/libc-top-half/musl/src/linux/fallocate.c b/libc-top-half/musl/src/linux/fallocate.c index 9146350e3..7d68bc8f6 100644 --- a/libc-top-half/musl/src/linux/fallocate.c +++ b/libc-top-half/musl/src/linux/fallocate.c @@ -7,3 +7,6 @@ int fallocate(int fd, int mode, off_t base, off_t len) return syscall(SYS_fallocate, fd, mode, __SYSCALL_LL_E(base), __SYSCALL_LL_E(len)); } + +#undef fallocate64 +weak_alias(fallocate, fallocate64); diff --git a/libc-top-half/musl/src/linux/getdents.c b/libc-top-half/musl/src/linux/getdents.c index 97f76e147..796c1e5c9 100644 --- a/libc-top-half/musl/src/linux/getdents.c +++ b/libc-top-half/musl/src/linux/getdents.c @@ -8,3 +8,5 @@ int getdents(int fd, struct dirent *buf, size_t len) if (len>INT_MAX) len = INT_MAX; return syscall(SYS_getdents, fd, buf, len); } + +weak_alias(getdents, getdents64); diff --git a/libc-top-half/musl/src/linux/prlimit.c b/libc-top-half/musl/src/linux/prlimit.c index fcf45aaba..3df9ffba7 100644 --- a/libc-top-half/musl/src/linux/prlimit.c +++ b/libc-top-half/musl/src/linux/prlimit.c @@ -21,3 +21,6 @@ int prlimit(pid_t pid, int resource, const struct rlimit *new_limit, struct rlim } return r; } + +#undef prlimit64 +weak_alias(prlimit, prlimit64); diff --git a/libc-top-half/musl/src/linux/sendfile.c b/libc-top-half/musl/src/linux/sendfile.c index fc1577d34..9afe6dd61 100644 --- a/libc-top-half/musl/src/linux/sendfile.c +++ b/libc-top-half/musl/src/linux/sendfile.c @@ -5,3 +5,5 @@ ssize_t sendfile(int out_fd, int in_fd, off_t *ofs, size_t count) { return syscall(SYS_sendfile, out_fd, in_fd, ofs, count); } + +weak_alias(sendfile, sendfile64); diff --git a/libc-top-half/musl/src/misc/getrlimit.c b/libc-top-half/musl/src/misc/getrlimit.c index a5558d815..bf6763071 100644 --- a/libc-top-half/musl/src/misc/getrlimit.c +++ b/libc-top-half/musl/src/misc/getrlimit.c @@ -26,3 +26,5 @@ int getrlimit(int resource, struct rlimit *rlim) return ret; #endif } + +weak_alias(getrlimit, getrlimit64); diff --git a/libc-top-half/musl/src/misc/lockf.c b/libc-top-half/musl/src/misc/lockf.c index 0162442b0..16a80bec1 100644 --- a/libc-top-half/musl/src/misc/lockf.c +++ b/libc-top-half/musl/src/misc/lockf.c @@ -28,3 +28,5 @@ int lockf(int fd, int op, off_t size) errno = EINVAL; return -1; } + +weak_alias(lockf, lockf64); diff --git a/libc-top-half/musl/src/misc/nftw.c b/libc-top-half/musl/src/misc/nftw.c index bdae6272f..e32743b5a 100644 --- a/libc-top-half/musl/src/misc/nftw.c +++ b/libc-top-half/musl/src/misc/nftw.c @@ -146,3 +146,5 @@ int nftw(const char *path, int (*fn)(const char *, const struct stat *, int, str #endif return r; } + +weak_alias(nftw, nftw64); diff --git a/libc-top-half/musl/src/misc/setrlimit.c b/libc-top-half/musl/src/misc/setrlimit.c index edb413fa7..5b713cf36 100644 --- a/libc-top-half/musl/src/misc/setrlimit.c +++ b/libc-top-half/musl/src/misc/setrlimit.c @@ -49,3 +49,5 @@ int setrlimit(int resource, const struct rlimit *rlim) return __syscall_ret(ret); #endif } + +weak_alias(setrlimit, setrlimit64); diff --git a/libc-top-half/musl/src/mman/mmap.c b/libc-top-half/musl/src/mman/mmap.c index 43e5e0294..eff88d82a 100644 --- a/libc-top-half/musl/src/mman/mmap.c +++ b/libc-top-half/musl/src/mman/mmap.c @@ -37,3 +37,5 @@ void *__mmap(void *start, size_t len, int prot, int flags, int fd, off_t off) } weak_alias(__mmap, mmap); + +weak_alias(mmap, mmap64); diff --git a/libc-top-half/musl/src/regex/glob.c b/libc-top-half/musl/src/regex/glob.c index 79fb615d8..435d12e43 100644 --- a/libc-top-half/musl/src/regex/glob.c +++ b/libc-top-half/musl/src/regex/glob.c @@ -312,3 +312,6 @@ void globfree(glob_t *g) g->gl_pathc = 0; g->gl_pathv = NULL; } + +weak_alias(glob, glob64); +weak_alias(globfree, globfree64); diff --git a/libc-top-half/musl/src/stat/__xstat.c b/libc-top-half/musl/src/stat/__xstat.c index b4560df7c..630936a0f 100644 --- a/libc-top-half/musl/src/stat/__xstat.c +++ b/libc-top-half/musl/src/stat/__xstat.c @@ -22,6 +22,11 @@ int __xstat(int ver, const char *path, struct stat *buf) return stat(path, buf); } +weak_alias(__fxstat, __fxstat64); +weak_alias(__fxstatat, __fxstatat64); +weak_alias(__lxstat, __lxstat64); +weak_alias(__xstat, __xstat64); + #endif int __xmknod(int ver, const char *path, mode_t mode, dev_t *dev) diff --git a/libc-top-half/musl/src/stat/fstat.c b/libc-top-half/musl/src/stat/fstat.c index fd28b8ac4..27db0ccbf 100644 --- a/libc-top-half/musl/src/stat/fstat.c +++ b/libc-top-half/musl/src/stat/fstat.c @@ -11,3 +11,7 @@ int __fstat(int fd, struct stat *st) } weak_alias(__fstat, fstat); + +#if !_REDIR_TIME64 +weak_alias(fstat, fstat64); +#endif diff --git a/libc-top-half/musl/src/stat/fstatat.c b/libc-top-half/musl/src/stat/fstatat.c index 9eed063b2..7b97216e2 100644 --- a/libc-top-half/musl/src/stat/fstatat.c +++ b/libc-top-half/musl/src/stat/fstatat.c @@ -152,3 +152,7 @@ int __fstatat(int fd, const char *restrict path, struct stat *restrict st, int f } weak_alias(__fstatat, fstatat); + +#if !_REDIR_TIME64 +weak_alias(fstatat, fstatat64); +#endif diff --git a/libc-top-half/musl/src/stat/lstat.c b/libc-top-half/musl/src/stat/lstat.c index 6822fcae4..6fe004dec 100644 --- a/libc-top-half/musl/src/stat/lstat.c +++ b/libc-top-half/musl/src/stat/lstat.c @@ -5,3 +5,7 @@ int lstat(const char *restrict path, struct stat *restrict buf) { return fstatat(AT_FDCWD, path, buf, AT_SYMLINK_NOFOLLOW); } + +#if !_REDIR_TIME64 +weak_alias(lstat, lstat64); +#endif diff --git a/libc-top-half/musl/src/stat/stat.c b/libc-top-half/musl/src/stat/stat.c index 23570e7a2..ea70efc4a 100644 --- a/libc-top-half/musl/src/stat/stat.c +++ b/libc-top-half/musl/src/stat/stat.c @@ -5,3 +5,7 @@ int stat(const char *restrict path, struct stat *restrict buf) { return fstatat(AT_FDCWD, path, buf, 0); } + +#if !_REDIR_TIME64 +weak_alias(stat, stat64); +#endif diff --git a/libc-top-half/musl/src/stat/statvfs.c b/libc-top-half/musl/src/stat/statvfs.c index bc12da8bf..8a4c12e55 100644 --- a/libc-top-half/musl/src/stat/statvfs.c +++ b/libc-top-half/musl/src/stat/statvfs.c @@ -57,3 +57,8 @@ int fstatvfs(int fd, struct statvfs *buf) fixup(buf, &kbuf); return 0; } + +weak_alias(statvfs, statvfs64); +weak_alias(statfs, statfs64); +weak_alias(fstatvfs, fstatvfs64); +weak_alias(fstatfs, fstatfs64); diff --git a/libc-top-half/musl/src/stdio/fgetpos.c b/libc-top-half/musl/src/stdio/fgetpos.c index 392f7323c..50813d2c5 100644 --- a/libc-top-half/musl/src/stdio/fgetpos.c +++ b/libc-top-half/musl/src/stdio/fgetpos.c @@ -7,3 +7,5 @@ int fgetpos(FILE *restrict f, fpos_t *restrict pos) *(long long *)pos = off; return 0; } + +weak_alias(fgetpos, fgetpos64); diff --git a/libc-top-half/musl/src/stdio/fopen.c b/libc-top-half/musl/src/stdio/fopen.c index a72e6b708..670f43892 100644 --- a/libc-top-half/musl/src/stdio/fopen.c +++ b/libc-top-half/musl/src/stdio/fopen.c @@ -47,3 +47,5 @@ FILE *fopen(const char *restrict filename, const char *restrict mode) #endif return 0; } + +weak_alias(fopen, fopen64); diff --git a/libc-top-half/musl/src/stdio/freopen.c b/libc-top-half/musl/src/stdio/freopen.c index d98cf5415..7c0ef085d 100644 --- a/libc-top-half/musl/src/stdio/freopen.c +++ b/libc-top-half/musl/src/stdio/freopen.c @@ -78,3 +78,5 @@ FILE *freopen(const char *restrict filename, const char *restrict mode, FILE *re fclose(f); return NULL; } + +weak_alias(freopen, freopen64); diff --git a/libc-top-half/musl/src/stdio/fseek.c b/libc-top-half/musl/src/stdio/fseek.c index c7425802c..c07f7e952 100644 --- a/libc-top-half/musl/src/stdio/fseek.c +++ b/libc-top-half/musl/src/stdio/fseek.c @@ -46,3 +46,5 @@ int fseek(FILE *f, long off, int whence) } weak_alias(__fseeko, fseeko); + +weak_alias(fseeko, fseeko64); diff --git a/libc-top-half/musl/src/stdio/fsetpos.c b/libc-top-half/musl/src/stdio/fsetpos.c index 779cb3ccf..77ab8d820 100644 --- a/libc-top-half/musl/src/stdio/fsetpos.c +++ b/libc-top-half/musl/src/stdio/fsetpos.c @@ -4,3 +4,5 @@ int fsetpos(FILE *f, const fpos_t *pos) { return __fseeko(f, *(const long long *)pos, SEEK_SET); } + +weak_alias(fsetpos, fsetpos64); diff --git a/libc-top-half/musl/src/stdio/ftell.c b/libc-top-half/musl/src/stdio/ftell.c index 1e1a08d82..1a2afbbce 100644 --- a/libc-top-half/musl/src/stdio/ftell.c +++ b/libc-top-half/musl/src/stdio/ftell.c @@ -37,3 +37,5 @@ long ftell(FILE *f) } weak_alias(__ftello, ftello); + +weak_alias(ftello, ftello64); diff --git a/libc-top-half/musl/src/stdio/tmpfile.c b/libc-top-half/musl/src/stdio/tmpfile.c index 2fa8803fc..ae493987b 100644 --- a/libc-top-half/musl/src/stdio/tmpfile.c +++ b/libc-top-half/musl/src/stdio/tmpfile.c @@ -27,3 +27,5 @@ FILE *tmpfile(void) } return 0; } + +weak_alias(tmpfile, tmpfile64); diff --git a/libc-top-half/musl/src/temp/mkostemp.c b/libc-top-half/musl/src/temp/mkostemp.c index e3dfdd912..d8dcb8052 100644 --- a/libc-top-half/musl/src/temp/mkostemp.c +++ b/libc-top-half/musl/src/temp/mkostemp.c @@ -5,3 +5,5 @@ int mkostemp(char *template, int flags) { return __mkostemps(template, 0, flags); } + +weak_alias(mkostemp, mkostemp64); diff --git a/libc-top-half/musl/src/temp/mkostemps.c b/libc-top-half/musl/src/temp/mkostemps.c index 093d2380d..ef24eeae2 100644 --- a/libc-top-half/musl/src/temp/mkostemps.c +++ b/libc-top-half/musl/src/temp/mkostemps.c @@ -26,3 +26,4 @@ int __mkostemps(char *template, int len, int flags) } weak_alias(__mkostemps, mkostemps); +weak_alias(__mkostemps, mkostemps64); diff --git a/libc-top-half/musl/src/temp/mkstemp.c b/libc-top-half/musl/src/temp/mkstemp.c index 76c835bb0..166b8afe4 100644 --- a/libc-top-half/musl/src/temp/mkstemp.c +++ b/libc-top-half/musl/src/temp/mkstemp.c @@ -4,3 +4,5 @@ int mkstemp(char *template) { return __mkostemps(template, 0, 0); } + +weak_alias(mkstemp, mkstemp64); diff --git a/libc-top-half/musl/src/temp/mkstemps.c b/libc-top-half/musl/src/temp/mkstemps.c index f8eabfec0..6b7531b5e 100644 --- a/libc-top-half/musl/src/temp/mkstemps.c +++ b/libc-top-half/musl/src/temp/mkstemps.c @@ -5,3 +5,5 @@ int mkstemps(char *template, int len) { return __mkostemps(template, len, 0); } + +weak_alias(mkstemps, mkstemps64); diff --git a/libc-top-half/musl/src/unistd/ftruncate.c b/libc-top-half/musl/src/unistd/ftruncate.c index 54ff34bc3..b41be0fa6 100644 --- a/libc-top-half/musl/src/unistd/ftruncate.c +++ b/libc-top-half/musl/src/unistd/ftruncate.c @@ -5,3 +5,5 @@ int ftruncate(int fd, off_t length) { return syscall(SYS_ftruncate, fd, __SYSCALL_LL_O(length)); } + +weak_alias(ftruncate, ftruncate64); diff --git a/libc-top-half/musl/src/unistd/lseek.c b/libc-top-half/musl/src/unistd/lseek.c index 5d71c46d6..48a638a37 100644 --- a/libc-top-half/musl/src/unistd/lseek.c +++ b/libc-top-half/musl/src/unistd/lseek.c @@ -20,3 +20,4 @@ off_t __lseek(int fd, off_t offset, int whence) } weak_alias(__lseek, lseek); +weak_alias(__lseek, lseek64); diff --git a/libc-top-half/musl/src/unistd/mipsn32/lseek.c b/libc-top-half/musl/src/unistd/mipsn32/lseek.c index 0f6cbcaa7..60e74a51f 100644 --- a/libc-top-half/musl/src/unistd/mipsn32/lseek.c +++ b/libc-top-half/musl/src/unistd/mipsn32/lseek.c @@ -17,3 +17,4 @@ off_t __lseek(int fd, off_t offset, int whence) } weak_alias(__lseek, lseek); +weak_alias(__lseek, lseek64); diff --git a/libc-top-half/musl/src/unistd/pread.c b/libc-top-half/musl/src/unistd/pread.c index b03fb0ad9..5681b045d 100644 --- a/libc-top-half/musl/src/unistd/pread.c +++ b/libc-top-half/musl/src/unistd/pread.c @@ -5,3 +5,5 @@ ssize_t pread(int fd, void *buf, size_t size, off_t ofs) { return syscall_cp(SYS_pread, fd, buf, size, __SYSCALL_LL_PRW(ofs)); } + +weak_alias(pread, pread64); diff --git a/libc-top-half/musl/src/unistd/preadv.c b/libc-top-half/musl/src/unistd/preadv.c index 890ab403f..8376d60f2 100644 --- a/libc-top-half/musl/src/unistd/preadv.c +++ b/libc-top-half/musl/src/unistd/preadv.c @@ -8,3 +8,5 @@ ssize_t preadv(int fd, const struct iovec *iov, int count, off_t ofs) return syscall_cp(SYS_preadv, fd, iov, count, (long)(ofs), (long)(ofs>>32)); } + +weak_alias(preadv, preadv64); diff --git a/libc-top-half/musl/src/unistd/pwrite.c b/libc-top-half/musl/src/unistd/pwrite.c index 869b69f03..ca3765762 100644 --- a/libc-top-half/musl/src/unistd/pwrite.c +++ b/libc-top-half/musl/src/unistd/pwrite.c @@ -5,3 +5,5 @@ ssize_t pwrite(int fd, const void *buf, size_t size, off_t ofs) { return syscall_cp(SYS_pwrite, fd, buf, size, __SYSCALL_LL_PRW(ofs)); } + +weak_alias(pwrite, pwrite64); diff --git a/libc-top-half/musl/src/unistd/pwritev.c b/libc-top-half/musl/src/unistd/pwritev.c index becf9debf..f5a612c48 100644 --- a/libc-top-half/musl/src/unistd/pwritev.c +++ b/libc-top-half/musl/src/unistd/pwritev.c @@ -8,3 +8,5 @@ ssize_t pwritev(int fd, const struct iovec *iov, int count, off_t ofs) return syscall_cp(SYS_pwritev, fd, iov, count, (long)(ofs), (long)(ofs>>32)); } + +weak_alias(pwritev, pwritev64); diff --git a/libc-top-half/musl/src/unistd/truncate.c b/libc-top-half/musl/src/unistd/truncate.c index 077351e1b..972968007 100644 --- a/libc-top-half/musl/src/unistd/truncate.c +++ b/libc-top-half/musl/src/unistd/truncate.c @@ -5,3 +5,5 @@ int truncate(const char *path, off_t length) { return syscall(SYS_truncate, path, __SYSCALL_LL_O(length)); } + +weak_alias(truncate, truncate64); diff --git a/libc-top-half/musl/src/unistd/x32/lseek.c b/libc-top-half/musl/src/unistd/x32/lseek.c index 5f93292fb..326364295 100644 --- a/libc-top-half/musl/src/unistd/x32/lseek.c +++ b/libc-top-half/musl/src/unistd/x32/lseek.c @@ -12,3 +12,4 @@ off_t __lseek(int fd, off_t offset, int whence) } weak_alias(__lseek, lseek); +weak_alias(__lseek, lseek64);