f31522130f
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
103 lines
2.4 KiB
C
103 lines
2.4 KiB
C
// SPDX-License-Identifier: MIT
|
|
/*
|
|
* Copyright © 2013 Red Hat, Inc.
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include <check.h>
|
|
#include <errno.h>
|
|
#include <fcntl.h>
|
|
#include <stdio.h>
|
|
|
|
#include "test-common.h"
|
|
|
|
void test_logfunc_abort_on_error(enum libevdev_log_priority priority,
|
|
void *data,
|
|
const char *file, int line,
|
|
const char *func,
|
|
const char *format, va_list args)
|
|
{
|
|
vprintf(format, args);
|
|
ck_abort();
|
|
}
|
|
|
|
void test_logfunc_ignore_error(enum libevdev_log_priority priority,
|
|
void *data,
|
|
const char *file, int line,
|
|
const char *func,
|
|
const char *format, va_list args)
|
|
{
|
|
}
|
|
|
|
void test_create_device(struct uinput_device **uidev_return,
|
|
struct libevdev **dev_return,
|
|
...)
|
|
{
|
|
int rc, fd;
|
|
struct uinput_device *uidev;
|
|
struct libevdev *dev;
|
|
va_list args;
|
|
|
|
va_start(args, dev_return);
|
|
|
|
rc = uinput_device_new_with_events_v(&uidev, TEST_DEVICE_NAME, DEFAULT_IDS, args);
|
|
va_end(args);
|
|
|
|
ck_assert_msg(rc == 0, "Failed to create uinput device: %s", strerror(-rc));
|
|
|
|
fd = uinput_device_get_fd(uidev);
|
|
|
|
rc = libevdev_new_from_fd(fd, &dev);
|
|
ck_assert_msg(rc == 0, "Failed to init device device: %s", strerror(-rc));
|
|
rc = fcntl(fd, F_SETFL, O_NONBLOCK);
|
|
ck_assert_msg(rc == 0, "fcntl failed: %s", strerror(errno));
|
|
|
|
*uidev_return = uidev;
|
|
*dev_return = dev;
|
|
}
|
|
|
|
void test_create_abs_device(struct uinput_device **uidev_return,
|
|
struct libevdev **dev_return,
|
|
int nabs,
|
|
const struct input_absinfo *abs,
|
|
...)
|
|
{
|
|
int rc, fd;
|
|
struct uinput_device *uidev;
|
|
struct libevdev *dev;
|
|
va_list args;
|
|
|
|
uidev = uinput_device_new(TEST_DEVICE_NAME);
|
|
ck_assert(uidev != NULL);
|
|
|
|
va_start(args, abs);
|
|
rc = uinput_device_set_event_bits_v(uidev, args);
|
|
ck_assert_msg(rc == 0, "Failed to set uinput bits");
|
|
va_end(args);
|
|
|
|
while (--nabs >= 0) {
|
|
int code;
|
|
struct input_absinfo a;
|
|
|
|
code = abs[nabs].value;
|
|
a = abs[nabs];
|
|
a.value = 0;
|
|
|
|
rc = uinput_device_set_abs_bit(uidev, code, &a);
|
|
ck_assert_msg(rc == 0, "for abs field %d\n", nabs);
|
|
}
|
|
|
|
rc = uinput_device_create(uidev);
|
|
ck_assert_msg(rc == 0, "Failed to create uinput device: %s", strerror(-rc));
|
|
|
|
fd = uinput_device_get_fd(uidev);
|
|
|
|
rc = libevdev_new_from_fd(fd, &dev);
|
|
ck_assert_msg(rc == 0, "Failed to init device device: %s", strerror(-rc));
|
|
rc = fcntl(fd, F_SETFL, O_NONBLOCK);
|
|
ck_assert_msg(rc == 0, "fcntl failed: %s", strerror(errno));
|
|
|
|
*uidev_return = uidev;
|
|
*dev_return = dev;
|
|
}
|