mirror of
https://dev.lirent.ru/Vatrog/vm-automation-signaling.git
synced 2026-06-25 20:36:36 +03:00
9bde398b6c
- core: runtime attach/detach of a per-endpoint adapter trio (runtime-safe add_adapter + vmsig_core_detach_endpoint, deferred reap) - roster: VMSIG_EV_ROSTER + CAP_ROSTER, retained per-endpoint and replayed to late subscribers - discovery: inotify trigger dir, vmid/endpoint slot allocator, host probe; vmsigd daemon with config + per-uid admission - input driver and vgpu perception built in-tree; vgpu perception as a separate library - memctx: own the supplied ro_fd (closed at detach) - deb packaging: install rules, systemd unit, tmpfiles, default config
23 lines
1.2 KiB
C
23 lines
1.2 KiB
C
#ifndef VMSIG_MEMCTX_CFG_H
|
|
#define VMSIG_MEMCTX_CFG_H
|
|
#include <stdint.h>
|
|
|
|
/* Private config of the memctx adapter (vmie). Passed as opaque to open(); NOT
|
|
* public (layout per reference: src/<module>/include/). cfg==NULL => stub. */
|
|
typedef struct {
|
|
int stub; /* 1 => synthetic kcr3/RO-fd (spine without a VM) */
|
|
const char* ram_path; /* armed: path to guest RAM backing (NOT published outward) */
|
|
uint64_t low; /* below-4G split (vmie_win32_open / locator.low) */
|
|
int ro_fd; /* >=0 => infra hands a pre-sealed RO-fd (policy); OWNERSHIP */
|
|
/* TRANSFERS to the adapter (closed in close()) — the */
|
|
/* caller dups first if it must keep its own copy. */
|
|
/* <0 => default: open(ram_path, O_RDONLY) / stub-memfd */
|
|
} vmsig_memctx_cfg;
|
|
|
|
/* Max SRC bytes per atomic gva_write (bounds the worker POD slot; mc_req header + src
|
|
* must stay <= VMSIG_WORK_SLOT). Private to the adapter (an executor bound), NOT part of
|
|
* the neutral control contract — control only needs VMSIG_MEMWRITE_INLINE for inline SRC. */
|
|
#define VMSIG_MEMWRITE_MAX 192u
|
|
|
|
#endif /* VMSIG_MEMCTX_CFG_H */
|