Skip to content

Commit

Permalink
bump(main/zig): 0.14.0
Browse files Browse the repository at this point in the history
  • Loading branch information
TomJo2000 committed Mar 6, 2025
1 parent f5178fa commit 5d40ace
Show file tree
Hide file tree
Showing 7 changed files with 329 additions and 313 deletions.
271 changes: 271 additions & 0 deletions packages/zig/0.14.0/zig-lib-libc-musl-src.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,271 @@
--- a/zig/lib/libc/musl/src/ipc/semtimedop.c
+++ b/zig/lib/libc/musl/src/ipc/semtimedop.c
@@ -16,7 +16,7 @@

int semtimedop(int id, struct sembuf *buf, size_t n, const struct timespec *ts)
{
-#ifdef SYS_semtimedop_time64
+#if defined(SYS_semtimedop_time64) && !defined(__ILP32__)
time_t s = ts ? ts->tv_sec : 0;
long ns = ts ? ts->tv_nsec : 0;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/linux/clock_adjtime.c
+++ b/zig/lib/libc/musl/src/linux/clock_adjtime.c
@@ -37,7 +37,7 @@
int clock_adjtime (clockid_t clock_id, struct timex *utx)
{
int r = -ENOSYS;
-#ifdef SYS_clock_adjtime64
+#if defined(SYS_clock_adjtime64) && !defined(__ILP32__)
struct ktimex64 ktx = {
.modes = utx->modes,
.offset = utx->offset,
--- a/zig/lib/libc/musl/src/linux/timerfd.c
+++ b/zig/lib/libc/musl/src/linux/timerfd.c
@@ -11,7 +11,7 @@

int timerfd_settime(int fd, int flags, const struct itimerspec *new, struct itimerspec *old)
{
-#ifdef SYS_timerfd_settime64
+#if defined(SYS_timerfd_settime64) && !defined(__ILP32__)
time_t is = new->it_interval.tv_sec, vs = new->it_value.tv_sec;
long ins = new->it_interval.tv_nsec, vns = new->it_value.tv_nsec;
int r = -ENOSYS;
@@ -39,7 +39,7 @@

int timerfd_gettime(int fd, struct itimerspec *cur)
{
-#ifdef SYS_timerfd_gettime64
+#if defined(SYS_timerfd_gettime64) && !defined(__ILP32__)
int r = -ENOSYS;
if (sizeof(time_t) > 4)
r = __syscall(SYS_timerfd_gettime64, fd, cur);
--- a/zig/lib/libc/musl/src/linux/wait4.c
+++ b/zig/lib/libc/musl/src/linux/wait4.c
@@ -8,7 +8,7 @@
pid_t wait4(pid_t pid, int *status, int options, struct rusage *ru)
{
int r;
-#ifdef SYS_wait4_time64
+#if defined(SYS_wait4_time64) && !defined(__ILP32__)
if (ru) {
long long kru64[18];
r = __syscall(SYS_wait4_time64, pid, status, options, kru64);
--- a/zig/lib/libc/musl/src/misc/getrusage.c
+++ b/zig/lib/libc/musl/src/misc/getrusage.c
@@ -6,7 +6,7 @@
int getrusage(int who, struct rusage *ru)
{
int r;
-#ifdef SYS_getrusage_time64
+#if defined(SYS_getrusage_time64) && !defined(__ILP32__)
long long kru64[18];
r = __syscall(SYS_getrusage_time64, who, kru64);
if (!r) {
--- a/zig/lib/libc/musl/src/mq/mq_timedsend.c
+++ b/zig/lib/libc/musl/src/mq/mq_timedsend.c
@@ -7,7 +7,7 @@

int mq_timedsend(mqd_t mqd, const char *msg, size_t len, unsigned prio, const struct timespec *at)
{
-#ifdef SYS_mq_timedsend_time64
+#if defined(SYS_mq_timedsend_time64) && !defined(__ILP32__)
time_t s = at ? at->tv_sec : 0;
long ns = at ? at->tv_nsec : 0;
long r = -ENOSYS;
--- a/zig/lib/libc/musl/src/network/recvmmsg.c
+++ b/zig/lib/libc/musl/src/network/recvmmsg.c
@@ -18,7 +18,7 @@
for (i = vlen; i; i--, mh++)
mh->msg_hdr.__pad1 = mh->msg_hdr.__pad2 = 0;
#endif
-#ifdef SYS_recvmmsg_time64
+#if defined(SYS_recvmmsg_time64) && !defined(__ILP32__)
time_t s = timeout ? timeout->tv_sec : 0;
long ns = timeout ? timeout->tv_nsec : 0;
int r = __syscall_cp(SYS_recvmmsg_time64, fd, msgvec, vlen, flags,
--- a/zig/lib/libc/musl/src/select/ppoll.c
+++ b/zig/lib/libc/musl/src/select/ppoll.c
@@ -11,7 +11,7 @@
{
time_t s = to ? to->tv_sec : 0;
long ns = to ? to->tv_nsec : 0;
-#ifdef SYS_ppoll_time64
+#if defined(SYS_ppoll_time64) && !defined(__ILP32__)
int r = -ENOSYS;
if (SYS_ppoll == SYS_ppoll_time64 || !IS32BIT(s))
r = __syscall_cp(SYS_ppoll_time64, fds, n,
--- a/zig/lib/libc/musl/src/select/pselect.c
+++ b/zig/lib/libc/musl/src/select/pselect.c
@@ -12,7 +12,7 @@
syscall_arg_t data[2] = { (uintptr_t)mask, _NSIG/8 };
time_t s = ts ? ts->tv_sec : 0;
long ns = ts ? ts->tv_nsec : 0;
-#ifdef SYS_pselect6_time64
+#if defined(SYS_pselect6_time64) && !defined(__ILP32__)
int r = -ENOSYS;
if (SYS_pselect6 == SYS_pselect6_time64 || !IS32BIT(s))
r = __syscall_cp(SYS_pselect6_time64, n, rfds, wfds, efds,
--- a/zig/lib/libc/musl/src/select/select.c
+++ b/zig/lib/libc/musl/src/select/select.c
@@ -25,7 +25,7 @@
ns = us*1000;
}

-#ifdef SYS_pselect6_time64
+#if defined(SYS_pselect6_time64) && !defined(__ILP32__)
int r = -ENOSYS;
if (SYS_pselect6 == SYS_pselect6_time64 || !IS32BIT(s))
r = __syscall_cp(SYS_pselect6_time64, n, rfds, wfds, efds,
--- a/zig/lib/libc/musl/src/signal/sigtimedwait.c
+++ b/zig/lib/libc/musl/src/signal/sigtimedwait.c
@@ -7,7 +7,7 @@

static int do_sigtimedwait(const sigset_t *restrict mask, siginfo_t *restrict si, const struct timespec *restrict ts)
{
-#ifdef SYS_rt_sigtimedwait_time64
+#if defined(SYS_rt_sigtimedwait_time64) && !defined(__ILP32__)
time_t s = ts ? ts->tv_sec : 0;
long ns = ts ? ts->tv_nsec : 0;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/stat/fstatat.c
+++ b/zig/lib/libc/musl/src/stat/fstatat.c
@@ -7,6 +7,9 @@
#include <sys/sysmacros.h>
#include "syscall.h"

+#undef SYS_lstat
+#undef SYS_stat
+
struct statx {
uint32_t stx_mask;
uint32_t stx_blksize;
@@ -140,14 +143,18 @@
{
int ret;
#ifdef SYS_fstatat
+#if 0
if (sizeof((struct kstat){0}.st_atime_sec) < sizeof(time_t)) {
ret = fstatat_statx(fd, path, st, flag);
if (ret!=-ENOSYS) return __syscall_ret(ret);
}
+#endif
ret = fstatat_kstat(fd, path, st, flag);
#else
+#if 0
ret = fstatat_statx(fd, path, st, flag);
#endif
+#endif
return __syscall_ret(ret);
}

--- a/zig/lib/libc/musl/src/stat/utimensat.c
+++ b/zig/lib/libc/musl/src/stat/utimensat.c
@@ -12,7 +12,7 @@
int r;
if (times && times[0].tv_nsec==UTIME_NOW && times[1].tv_nsec==UTIME_NOW)
times = 0;
-#ifdef SYS_utimensat_time64
+#if defined(SYS_utimensat_time64) && !defined(__ILP32__)
r = -ENOSYS;
time_t s0=0, s1=0;
long ns0=0, ns1=0;
--- a/zig/lib/libc/musl/src/thread/__timedwait.c
+++ b/zig/lib/libc/musl/src/thread/__timedwait.c
@@ -11,7 +11,7 @@
static int __futex4_cp(volatile void *addr, int op, int val, const struct timespec *to)
{
int r;
-#ifdef SYS_futex_time64
+#if defined(SYS_futex_time64) && !defined(__ILP32__)
time_t s = to ? to->tv_sec : 0;
long ns = to ? to->tv_nsec : 0;
r = -ENOSYS;
--- a/zig/lib/libc/musl/src/thread/pthread_mutex_timedlock.c
+++ b/zig/lib/libc/musl/src/thread/pthread_mutex_timedlock.c
@@ -5,7 +5,7 @@

static int __futex4(volatile void *addr, int op, int val, const struct timespec *to)
{
-#ifdef SYS_futex_time64
+#if defined(SYS_futex_time64) && !defined(__ILP32__)
time_t s = to ? to->tv_sec : 0;
long ns = to ? to->tv_nsec : 0;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/time/clock_gettime.c
+++ b/zig/lib/libc/musl/src/time/clock_gettime.c
@@ -75,7 +75,7 @@
}
#endif

-#ifdef SYS_clock_gettime64
+#if defined(SYS_clock_gettime64) && !defined(__ILP32__)
r = -ENOSYS;
if (sizeof(time_t) > 4)
r = __syscall(SYS_clock_gettime64, clk, ts);
--- a/zig/lib/libc/musl/src/time/clock_nanosleep.c
+++ b/zig/lib/libc/musl/src/time/clock_nanosleep.c
@@ -8,7 +8,7 @@
int __clock_nanosleep(clockid_t clk, int flags, const struct timespec *req, struct timespec *rem)
{
if (clk == CLOCK_THREAD_CPUTIME_ID) return EINVAL;
-#ifdef SYS_clock_nanosleep_time64
+#if defined(SYS_clock_nanosleep_time64) && !defined(__ILP32__)
time_t s = req->tv_sec;
long ns = req->tv_nsec;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/time/clock_settime.c
+++ b/zig/lib/libc/musl/src/time/clock_settime.c
@@ -6,7 +6,7 @@

int clock_settime(clockid_t clk, const struct timespec *ts)
{
-#ifdef SYS_clock_settime64
+#if defined(SYS_clock_settime64) && !defined(__ILP32__)
time_t s = ts->tv_sec;
long ns = ts->tv_nsec;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/time/timer_gettime.c
+++ b/zig/lib/libc/musl/src/time/timer_gettime.c
@@ -8,7 +8,7 @@
pthread_t td = (void *)((uintptr_t)t << 1);
t = (void *)(uintptr_t)(td->timer_id & INT_MAX);
}
-#ifdef SYS_timer_gettime64
+#if defined(SYS_timer_gettime64) && !defined(__ILP32__)
int r = -ENOSYS;
if (sizeof(time_t) > 4)
r = __syscall(SYS_timer_gettime64, t, val);
--- a/zig/lib/libc/musl/src/time/timer_settime.c
+++ b/zig/lib/libc/musl/src/time/timer_settime.c
@@ -10,7 +10,7 @@
pthread_t td = (void *)((uintptr_t)t << 1);
t = (void *)(uintptr_t)(td->timer_id & INT_MAX);
}
-#ifdef SYS_timer_settime64
+#if defined(SYS_timer_settime64) && !defined(__ILP32__)
time_t is = val->it_interval.tv_sec, vs = val->it_value.tv_sec;
long ins = val->it_interval.tv_nsec, vns = val->it_value.tv_nsec;
int r = -ENOSYS;
--- a/zig/lib/libc/musl/src/unistd/access.c
+++ b/zig/lib/libc/musl/src/unistd/access.c
@@ -4,7 +4,7 @@

int access(const char *filename, int amode)
{
-#ifdef SYS_access
+#if defined(SYS_access) && !defined(__LP64__)
return syscall(SYS_access, filename, amode);
#else
return syscall(SYS_faccessat, AT_FDCWD, filename, amode, 0);
--- a/zig/lib/libc/musl/src/unistd/pipe.c
+++ b/zig/lib/libc/musl/src/unistd/pipe.c
@@ -3,7 +3,7 @@

int pipe(int fd[2])
{
-#ifdef SYS_pipe
+#if defined(SYS_pipe) && !defined(__LP64__)
return syscall(SYS_pipe, fd);
#else
return syscall(SYS_pipe2, fd, 0);
21 changes: 21 additions & 0 deletions packages/zig/0.14.0/zig-lib-std-os-linux.zig.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
diff -uNr zig-bootstrap-0.14.0.orig/zig/lib/std/os/linux.zig zig-bootstrap-0.14.0/zig/lib/std/os/linux.zig
--- zig-bootstrap-0.14.0.orig/zig/lib/std/os/linux.zig 2025-03-06 04:47:21.734564519 +0100
+++ zig-bootstrap-0.14.0/zig/lib/std/os/linux.zig 2025-03-06 04:55:49.549917625 +0100
@@ -1120,7 +1120,7 @@
}

pub fn access(path: [*:0]const u8, mode: u32) usize {
- if (@hasField(SYS, "access")) {
+ if (@hasField(SYS, "access") and (comptime builtin.cpu.arch != .x86_64)) {
return syscall2(.access, @intFromPtr(path), mode);
} else {
return syscall4(.faccessat, @as(usize, @bitCast(@as(isize, AT.FDCWD))), @intFromPtr(path), mode, 0);
@@ -1134,7 +1134,7 @@
pub fn pipe(fd: *[2]i32) usize {
if (comptime (native_arch.isMIPS() or native_arch.isSPARC())) {
return syscall_pipe(fd);
- } else if (@hasField(SYS, "pipe")) {
+ } else if (@hasField(SYS, "pipe") and (comptime builtin.cpu.arch != .x86_64)) {
return syscall1(.pipe, @intFromPtr(fd));
} else {
return syscall2(.pipe2, @intFromPtr(fd), 0);
41 changes: 31 additions & 10 deletions packages/zig/build.patch
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
--- a/build
+++ b/build
@@ -24,7 +24,7 @@
diff -uNr zig-bootstrap-0.14.0.orig/build zig-bootstrap-0.14.0/build
--- zig-bootstrap-0.14.0.orig/build 2025-03-06 04:47:21.200134111 +0100
+++ zig-bootstrap-0.14.0/build 2025-03-06 22:34:08.396147070 +0100
@@ -24,10 +24,12 @@
# First build the libraries for Zig to link against, as well as native `llvm-tblgen`.
mkdir -p "$ROOTDIR/out/build-llvm-host"
cd "$ROOTDIR/out/build-llvm-host"
Expand All @@ -9,7 +10,12 @@
-DCMAKE_INSTALL_PREFIX="$ROOTDIR/out/host" \
-DCMAKE_PREFIX_PATH="$ROOTDIR/out/host" \
-DCMAKE_BUILD_TYPE=Release \
@@ -51,18 +51,18 @@
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE \
-DLLVM_ENABLE_BINDINGS=OFF \
-DLLVM_ENABLE_LIBEDIT=OFF \
-DLLVM_ENABLE_LIBPFM=OFF \
@@ -55,18 +57,20 @@
-DCLANG_TOOL_ARCMT_TEST_BUILD=OFF \
-DCLANG_TOOL_C_ARCMT_TEST_BUILD=OFF \
-DCLANG_TOOL_LIBCLANG_BUILD=OFF
Expand All @@ -25,13 +31,15 @@
-DCMAKE_INSTALL_PREFIX="$ROOTDIR/out/host" \
-DCMAKE_PREFIX_PATH="$ROOTDIR/out/host" \
-DCMAKE_BUILD_TYPE=Release \
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE \
-DZIG_VERSION="$ZIG_VERSION"
-cmake --build . --target install
+ninja -j"${TERMUX_PKG_MAKE_PROCESSES}" install

# Now we have Zig as a cross compiler.
ZIG="$ROOTDIR/out/host/bin/zig"
@@ -71,7 +71,7 @@
@@ -75,7 +79,7 @@
# the final zig binary to have zlib support enabled.
mkdir -p "$ROOTDIR/out/build-zlib-$TARGET-$MCPU"
cd "$ROOTDIR/out/build-zlib-$TARGET-$MCPU"
Expand All @@ -40,16 +48,20 @@
-DCMAKE_INSTALL_PREFIX="$ROOTDIR/out/$TARGET-$MCPU" \
-DCMAKE_PREFIX_PATH="$ROOTDIR/out/$TARGET-$MCPU" \
-DCMAKE_BUILD_TYPE=Release \
@@ -83,7 +83,7 @@
@@ -86,8 +90,10 @@
-DCMAKE_ASM_COMPILER="$ZIG;cc;-fno-sanitize=all;-s;-target;$TARGET;-mcpu=$MCPU" \
-DCMAKE_RC_COMPILER="$ROOTDIR/out/host/bin/llvm-rc" \
-DCMAKE_AR="$ROOTDIR/out/host/bin/llvm-ar" \
-DCMAKE_RANLIB="$ROOTDIR/out/host/bin/llvm-ranlib"
- -DCMAKE_RANLIB="$ROOTDIR/out/host/bin/llvm-ranlib"
-cmake --build . --target install
+ -DCMAKE_RANLIB="$ROOTDIR/out/host/bin/llvm-ranlib" \
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE
+ninja -j"${TERMUX_PKG_MAKE_PROCESSES}" install

# Same deal for zstd.
# The build system for zstd is whack so I just put all the files here.
@@ -133,7 +133,7 @@
@@ -137,7 +143,7 @@
# Rebuild LLVM with Zig.
mkdir -p "$ROOTDIR/out/build-llvm-$TARGET-$MCPU"
cd "$ROOTDIR/out/build-llvm-$TARGET-$MCPU"
Expand All @@ -58,9 +70,18 @@
-DCMAKE_INSTALL_PREFIX="$ROOTDIR/out/$TARGET-$MCPU" \
-DCMAKE_PREFIX_PATH="$ROOTDIR/out/$TARGET-$MCPU" \
-DCMAKE_BUILD_TYPE=Release \
@@ -186,7 +186,7 @@
@@ -149,6 +155,8 @@
-DCMAKE_RC_COMPILER="$ROOTDIR/out/host/bin/llvm-rc" \
-DCMAKE_AR="$ROOTDIR/out/host/bin/llvm-ar" \
-DCMAKE_RANLIB="$ROOTDIR/out/host/bin/llvm-ranlib" \
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE \
-DLLVM_ENABLE_BACKTRACES=OFF \
-DLLVM_ENABLE_BINDINGS=OFF \
-DLLVM_ENABLE_CRASH_OVERRIDES=OFF \
@@ -188,7 +196,7 @@
-DCLANG_TOOL_C_ARCMT_TEST_BUILD=OFF \
-DCLANG_TOOL_LIBCLANG_BUILD=OFF \
-DLIBCLANG_BUILD_STATIC=ON \
-DLLD_BUILD_TOOLS=OFF
-cmake --build . --target install
+ninja -j"${TERMUX_PKG_MAKE_PROCESSES}" install
Expand Down
4 changes: 2 additions & 2 deletions packages/zig/build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ TERMUX_PKG_DESCRIPTION="General-purpose programming language and toolchain"
TERMUX_PKG_LICENSE="MIT"
TERMUX_PKG_LICENSE_FILE="zig/LICENSE"
TERMUX_PKG_MAINTAINER="@termux"
TERMUX_PKG_VERSION="0.13.0"
TERMUX_PKG_VERSION="0.14.0"
TERMUX_PKG_SRCURL=https://github.com/ziglang/zig/releases/download/${TERMUX_PKG_VERSION}/zig-bootstrap-${TERMUX_PKG_VERSION}.tar.xz
TERMUX_PKG_SHA256=cd446c084b5da7bc42e8ad9b4e1c910a957f2bf3f82bcc02888102cd0827c139
TERMUX_PKG_SHA256=bf3fcb22be0b83f4791748adb567d3304779d66d7bf9b1bd557ef6c2e0232807
TERMUX_PKG_BUILD_IN_SRC=true
TERMUX_PKG_AUTO_UPDATE=true

Expand Down
Loading

0 comments on commit 5d40ace

Please sign in to comment.