Commit Graph

17 Commits

Author SHA1 Message Date
Red Bear OS e25fd20708 fix: define eventfd_t locally instead of re-export (cbindgen cross-module) 2026-06-28 16:21:45 +03:00
Red Bear OS 0c5f21d297 relibc: apply full eventfd implementation from P3 patches
- eventfd(), eventfd_read(), eventfd_write() functions
- uses kernel event scheme at /scheme/event/eventfd/
- eventfd_t type via bits_eventfd + after_includes in cbindgen
- EFD_SEMAPHORE, EFD_CLOEXEC, EFD_NONBLOCK constants
2026-06-28 11:31:27 +03:00
Red Bear OS 2ae6ef9a67 fix: add eventfd_t typedef in trailer for cbindgen 2026-06-28 11:19:01 +03:00
Red Bear OS ba2e6555af relibc: add sys/eventfd.h cbindgen config and eventfd_t type
libwayland and other users need sys/eventfd.h with:
- eventfd_t typedef (uint64_t)
- EFD_SEMAPHORE, EFD_CLOEXEC, EFD_NONBLOCK constants
- eventfd(), eventfd_read(), eventfd_write() prototypes
2026-06-28 10:35:49 +03:00
Red Bear OS c1b8c3b4cf abort: fix unsafe-op-in-unsafe-fn, signal path, unused imports
- abort() body: use signal::sys::SIGABRT (the platform-independent name
  the signal module uses for both linux and redox submodules)
- call sites: wrap abort() in unsafe { } blocks (Rust 2024 edition's
  unsafe_op_in_unsafe_fn lint makes this mandatory inside unsafe fns)
- stdlib/mod.rs, start.rs: drop now-unused 'intrinsics' import
2026-06-28 04:17:35 +03:00
Red Bear OS 4e40dc538c abort: raise(SIGABRT) + _Exit instead of ud2
Previously abort() called core::intrinsics::abort() which compiles to
the ud2 instruction, generating an Invalid Opcode fault. The kernel
logs this as 'UNHANDLED EXCEPTION' and kills the process, but the
fault message is alarming and doesn't reflect the actual intent
(SIGABRT from process self-termination).

This change uses the POSIX-compliant abort sequence: raise(SIGABRT)
first (default handler terminates the process), then _Exit(134) as
fallback if the signal handler returns. Six sites updated:
stdlib abort, assert __assert_fail, lib.rs relibc_panic/oom/_Unwind_Resume,
start.rs relibc_verify_host.

The proc-manager-fallback in redox-rt/src/sys.rs retains
core::intrinsics::abort() — that path is a true 'system unreachable'
last resort where raise/_Exit cannot succeed.
2026-06-28 04:00:30 +03:00
Red Bear OS fc8f0ec4fd Fix sched.h: use style=Both so sched_param has typedef (needed by spawn.h) 2026-06-27 23:53:21 +03:00
Red Bear OS f00e969b82 Fix: remove unnecessary unsafe block for safe sched_setscheduler call 2026-06-27 23:50:21 +03:00
Red Bear OS 3cb57fbc7f Add posix_spawnattr_{get,set}schedpolicy and schedparam functions 2026-06-27 23:45:14 +03:00
Red Bear OS a500cd9e6c Fix spawn.h: use style=Both for typedef-compatible posix_spawn types 2026-06-27 23:34:18 +03:00
Red Bear OS 32e402087f Fix sigaction.sa_flags type: c_int -> c_ulong
nix 0.30.1 expects SaFlags_t = c_ulong for target_os = "redox"
(see nix-0.30.1/src/sys/signal.rs:430). Our relibc had c_int,
causing type mismatch errors in uutils and any nix-dependent crate.
Align with nix's expectation.
2026-06-27 22:26:56 +03:00
Red Bear OS ae6549251b Implement spawn.h + fix VaList API for Rust 1.98 + signal.h stdint.h
spawn.h: Implement posix_spawn/posix_spawnp with file actions and
spawn attributes (flags, pgroup, sigmask, sigdefault). Uses fork+exec.

signal/cbindgen.toml: Add stdint.h to sys_includes for signalfd_siginfo
fixed-width integer types (uint32_t, int32_t, etc.).

VaList API migration for Rust 1.98.0-dev toolchain:
- VaListImpl merged into VaList (core::ffi::VaList)
- .arg()/.arg::<T>() renamed to .next_arg()/.next_arg::<T>()
- .as_va_list() removed (parameter is already VaList)
- .with_copy() replaced with .clone()
- printf.rs: Fix double-dereference cast for inline VaListInner

redox-rt/signal.rs: Remove unnecessary unsafe around __cpuid (safe in
new nightly).
2026-06-27 21:47:37 +03:00
Red Bear OS 31ee8b3bf9 signal/cbindgen.toml: add stdint.h to sys_includes for signalfd_siginfo types
The signalfd_siginfo struct uses uint32_t, int32_t, uint64_t, uint16_t
which require <stdint.h>. Without it, gnulib-based packages (m4, bison,
flex) fail configure's sigset_t test because signal.h doesn't compile.
2026-06-27 21:10:13 +03:00
Red Bear OS a2e4cd27fe Fix inttypes.h circular include: use stdint.h+stddef.h instead of wchar.h
inttypes.h included wchar.h for wchar_t and stdint.h, but this created
a circular dependency: wchar.h → stdint.h → gnulib inttypes.h →
inttypes.h → wchar.h. When gnulib's wchar.h wrapper was re-entered
during this cycle, wint_t and mbstate_t were not yet defined.

POSIX spec says inttypes.h should include stdint.h directly and
wchar_t comes from stddef.h. Using stdint.h + stddef.h breaks the
circular chain at its source.
2026-06-27 14:31:34 +03:00
Red Bear OS d28963d88e Fix wchar.h circular include: define types before stdio.h
relibc's wchar.h included <stdio.h> before defining wint_t and
mbstate_t. The circular chain wchar.h → stdio.h → inttypes.h →
wchar.h caused gnulib's wchar.h wrapper (used by m4, bison, etc.)
to see 'unknown type name wint_t' and 'unknown type name mbstate_t'.

Fix: Move stdio.h and time.h from sys_includes (which cbindgen
emits before type definitions) into after_includes, after wchar_t,
wint_t, and mbstate_t are defined. Also define mbstate_t manually
in after_includes with a guard, and exclude it from cbindgen export
to prevent duplicate definitions.
2026-06-27 14:22:45 +03:00
Red Bear OS 047e7c09da Add __fseterr and __freadahead to stdio ext (P3-stdio-fseterr patch) 2026-06-27 09:22:51 +03:00
Red Bear OS 1b3e94a20d Red Bear OS relibc baseline
From release 0.1.0 pre-patched archive.
This includes all Red Bear modifications previously maintained
as patches in local/patches/relibc/.
2026-06-27 09:19:26 +03:00