Files
RedBear-OS/local/recipes/system/seatd/source/examples/simpletest/main.c
T
vasilito f31522130f fix: comprehensive boot warnings and exceptions — fixable silenced, unfixable diagnosed
Build system (5 gaps hardened):
- COOKBOOK_OFFLINE defaults to true (fork-mode)
- normalize_patch handles diff -ruN format
- New 'repo validate-patches' command (25/25 relibc patches)
- 14 patched Qt/Wayland/display recipes added to protected list
- relibc archive regenerated with current patch chain

Boot fixes (fixable):
- Full ISO EFI partition: 16 MiB → 1 MiB (matches mini, BIOS hardcoded 2 MiB offset)
- D-Bus system bus: absolute /usr/bin/dbus-daemon path (was skipped)
- redbear-sessiond: absolute /usr/bin/redbear-sessiond path (was skipped)
- daemon framework: silenced spurious INIT_NOTIFY warnings for oneshot_async services (P0-daemon-silence-init-notify.patch)
- udev-shim: demoted INIT_NOTIFY warning to INFO (expected for oneshot_async)
- relibc: comprehensive named semaphores (sem_open/close/unlink) replacing upstream todo!() stubs
- greeterd: Wayland socket timeout 15s → 30s (compositor DRM wait)
- greeter-ui: built and linked (header guard unification, sem_compat stubs removed)
- mc: un-ignored in both configs, fixed glib/libiconv/pcre2 transitive deps
- greeter config: removed stale keymapd dependency from display/greeter services
- prefix toolchain: relibc headers synced, _RELIBC_STDLIB_H guard unified

Unfixable (diagnosed, upstream):
- i2c-hidd: abort on no-I2C-hardware (QEMU) — process::exit → relibc abort
- kded6/greeter-ui: page fault 0x8 — Qt library null deref
- Thread panics fd != -1 — Rust std library on Redox
- DHCP timeout / eth0 MAC — QEMU user-mode networking
- hwrngd/thermald — no hardware RNG/thermal in VM
- live preload allocation — BIOS memory fragmentation, continues on demand
2026-05-05 20:20:37 +01:00

69 lines
1.7 KiB
C

#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "libseat.h"
static void handle_enable(struct libseat *backend, void *data) {
(void)backend;
int *active = (int *)data;
(*active)++;
}
static void handle_disable(struct libseat *backend, void *data) {
(void)backend;
int *active = (int *)data;
(*active)--;
libseat_disable_seat(backend);
}
int main(int argc, char *argv[]) {
if (argc < 2) {
fprintf(stderr, "Specify name of file to open as argument\n");
return -1;
}
char *file = argv[1];
int active = 0;
struct libseat_seat_listener listener = {
.enable_seat = handle_enable,
.disable_seat = handle_disable,
};
libseat_set_log_level(LIBSEAT_LOG_LEVEL_DEBUG);
struct libseat *backend = libseat_open_seat(&listener, &active);
fprintf(stderr, "libseat_open_seat(listener: %p, userdata: %p) = %p\n", (void *)&listener,
(void *)&active, (void *)backend);
if (backend == NULL) {
fprintf(stderr, "libseat_open_seat() failed: %s\n", strerror(errno));
return -1;
}
while (active == 0) {
fprintf(stderr, "waiting for activation...\n");
if (libseat_dispatch(backend, -1) == -1) {
libseat_close_seat(backend);
fprintf(stderr, "libseat_dispatch() failed: %s\n", strerror(errno));
return -1;
}
}
fprintf(stderr, "active!\n");
int fd, device;
device = libseat_open_device(backend, file, &fd);
fprintf(stderr, "libseat_open_device(backend: %p, path: %s, fd: %p) = %d\n",
(void *)backend, file, (void *)&fd, device);
if (device == -1) {
fprintf(stderr, "libseat_open_device() failed: %s\n", strerror(errno));
libseat_close_seat(backend);
return 1;
}
libseat_close_device(backend, device);
close(fd);
libseat_close_seat(backend);
return 0;
}