Files
RedBear-OS/local/recipes/wayland/libwayland/source/tests/data/small-server.h
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

266 lines
5.8 KiB
C

/* SCANNER TEST */
#ifndef SMALL_TEST_SERVER_PROTOCOL_H
#define SMALL_TEST_SERVER_PROTOCOL_H
#include <stdint.h>
#include <stddef.h>
#include "wayland-server.h"
#ifdef __cplusplus
extern "C" {
#endif
struct wl_client;
struct wl_resource;
/**
* @page page_small_test The small_test protocol
* @section page_ifaces_small_test Interfaces
* - @subpage page_iface_intf_A - the thing A
* @section page_copyright_small_test Copyright
* <pre>
*
* Copyright © 2016 Collabora, Ltd.
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation files
* (the "Software"), to deal in the Software without restriction,
* including without limitation the rights to use, copy, modify, merge,
* publish, distribute, sublicense, and/or sell copies of the Software,
* and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice (including the
* next paragraph) shall be included in all copies or substantial
* portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
* </pre>
*/
struct another_intf;
struct intf_A;
struct intf_not_here;
#ifndef INTF_A_INTERFACE
#define INTF_A_INTERFACE
/**
* @page page_iface_intf_A intf_A
* @section page_iface_intf_A_desc Description
*
* A useless example trying to tickle the scanner.
* @section page_iface_intf_A_api API
* See @ref iface_intf_A.
*/
/**
* @defgroup iface_intf_A The intf_A interface
*
* A useless example trying to tickle the scanner.
*/
extern const struct wl_interface intf_A_interface;
#endif
#ifndef INTF_A_FOO_ENUM
#define INTF_A_FOO_ENUM
enum intf_A_foo {
/**
* this is the first
*/
INTF_A_FOO_FIRST = 0,
/**
* this is the second
*/
INTF_A_FOO_SECOND = 1,
/**
* this is the third
* @since 2
*/
INTF_A_FOO_THIRD = 2,
/**
* this is a negative value
* @since 2
*/
INTF_A_FOO_NEGATIVE = -1,
/**
* this is a deprecated value
* @since 2
* @deprecated Deprecated since version 3
*/
INTF_A_FOO_DEPRECATED = 3,
};
/**
* @ingroup iface_intf_A
*/
#define INTF_A_FOO_THIRD_SINCE_VERSION 2
/**
* @ingroup iface_intf_A
*/
#define INTF_A_FOO_NEGATIVE_SINCE_VERSION 2
/**
* @ingroup iface_intf_A
*/
#define INTF_A_FOO_DEPRECATED_SINCE_VERSION 2
#endif /* INTF_A_FOO_ENUM */
#ifndef INTF_A_FOO_ENUM_IS_VALID
#define INTF_A_FOO_ENUM_IS_VALID
/**
* @ingroup iface_intf_A
* Validate a intf_A foo value.
*
* @return true on success, false on error.
* @ref intf_A_foo
*/
static inline bool
intf_A_foo_is_valid(uint32_t value, uint32_t version) {
switch (value) {
case INTF_A_FOO_FIRST:
return version >= 1;
case INTF_A_FOO_SECOND:
return version >= 1;
case INTF_A_FOO_THIRD:
return version >= 2;
case (uint32_t)INTF_A_FOO_NEGATIVE:
return version >= 2;
case INTF_A_FOO_DEPRECATED:
return version >= 2;
default:
return false;
}
}
#endif /* INTF_A_FOO_ENUM_IS_VALID */
#ifndef INTF_A_BAR_ENUM
#define INTF_A_BAR_ENUM
enum intf_A_bar {
/**
* this is the first
*/
INTF_A_BAR_FIRST = 0x01,
/**
* this is the second
*/
INTF_A_BAR_SECOND = 0x02,
/**
* this is the third
* @since 2
*/
INTF_A_BAR_THIRD = 0x04,
};
/**
* @ingroup iface_intf_A
*/
#define INTF_A_BAR_THIRD_SINCE_VERSION 2
#endif /* INTF_A_BAR_ENUM */
#ifndef INTF_A_BAR_ENUM_IS_VALID
#define INTF_A_BAR_ENUM_IS_VALID
/**
* @ingroup iface_intf_A
* Validate a intf_A bar value.
*
* @return true on success, false on error.
* @ref intf_A_bar
*/
static inline bool
intf_A_bar_is_valid(uint32_t value, uint32_t version) {
uint32_t valid = 0;
if (version >= 1)
valid |= INTF_A_BAR_FIRST;
if (version >= 1)
valid |= INTF_A_BAR_SECOND;
if (version >= 2)
valid |= INTF_A_BAR_THIRD;
return (value & ~valid) == 0;
}
#endif /* INTF_A_BAR_ENUM_IS_VALID */
/**
* @ingroup iface_intf_A
* @struct intf_A_interface
*/
struct intf_A_interface {
/**
* @param interface name of the objects interface
* @param version version of the objects interface
*/
void (*rq1)(struct wl_client *client,
struct wl_resource *resource,
const char *interface, uint32_t version, uint32_t untyped_new);
/**
*/
void (*rq2)(struct wl_client *client,
struct wl_resource *resource,
uint32_t typed_new,
const char *str,
int32_t i,
uint32_t u,
wl_fixed_t f,
int32_t fd,
struct wl_resource *obj);
/**
*/
void (*destroy)(struct wl_client *client,
struct wl_resource *resource);
};
#define INTF_A_HEY 0
#define INTF_A_YO 1
/**
* @ingroup iface_intf_A
*/
#define INTF_A_HEY_SINCE_VERSION 1
/**
* @ingroup iface_intf_A
*/
#define INTF_A_YO_SINCE_VERSION 2
/**
* @ingroup iface_intf_A
*/
#define INTF_A_RQ1_SINCE_VERSION 1
/**
* @ingroup iface_intf_A
*/
#define INTF_A_RQ2_SINCE_VERSION 1
/**
* @ingroup iface_intf_A
*/
#define INTF_A_DESTROY_SINCE_VERSION 1
/**
* @ingroup iface_intf_A
* Sends an hey event to the client owning the resource.
* @param resource_ The client's resource
*/
static inline void
intf_A_send_hey(struct wl_resource *resource_)
{
wl_resource_post_event(resource_, INTF_A_HEY);
}
/**
* @ingroup iface_intf_A
* Sends an yo event to the client owning the resource.
* @param resource_ The client's resource
*/
static inline void
intf_A_send_yo(struct wl_resource *resource_)
{
wl_resource_post_event(resource_, INTF_A_YO);
}
#ifdef __cplusplus
}
#endif
#endif