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
93 lines
2.7 KiB
ReStructuredText
93 lines
2.7 KiB
ReStructuredText
===================
|
|
drmModeGetResources
|
|
===================
|
|
|
|
--------------------------------------------------
|
|
retrieve current display configuration information
|
|
--------------------------------------------------
|
|
|
|
:Date: September 2012
|
|
:Manual section: 3
|
|
:Manual group: Direct Rendering Manager
|
|
|
|
Synopsis
|
|
========
|
|
|
|
``#include <xf86drm.h>``
|
|
|
|
``#include <xf86drmMode.h>``
|
|
|
|
``drmModeResPtr drmModeGetResources(int fd);``
|
|
|
|
Description
|
|
===========
|
|
|
|
``drmModeGetResources`` allocates, populates, and returns a drmModeRes
|
|
structure containing information about the current display
|
|
configuration. The structure contains the following fields:
|
|
|
|
::
|
|
|
|
typedef struct _drmModeRes {
|
|
int count_fbs;
|
|
uint32_t *fbs;
|
|
|
|
int count_crtcs;
|
|
uint32_t *crtcs;
|
|
|
|
int count_connectors;
|
|
uint32_t *connectors;
|
|
|
|
int count_encoders;
|
|
uint32_t *encoders;
|
|
|
|
uint32_t min_width, max_width;
|
|
uint32_t min_height, max_height;
|
|
} drmModeRes, *drmModeResPtr;
|
|
|
|
The *count_fbs* and *fbs* fields indicate the number of currently allocated
|
|
framebuffer objects (i.e., objects that can be attached to a given CRTC
|
|
or sprite for display).
|
|
|
|
The *count_crtcs* and *crtcs* fields list the available CRTCs in the
|
|
configuration. A CRTC is simply an object that can scan out a
|
|
framebuffer to a display sink, and contains mode timing and relative
|
|
position information. CRTCs drive encoders, which are responsible for
|
|
converting the pixel stream into a specific display protocol (e.g., MIPI
|
|
or HDMI).
|
|
|
|
The *count_connectors* and *connectors* fields list the available physical
|
|
connectors on the system. Note that some of these may not be exposed
|
|
from the chassis (e.g., LVDS or eDP). Connectors are attached to
|
|
encoders and contain information about the attached display sink (e.g.,
|
|
width and height in mm, subpixel ordering, and various other
|
|
properties).
|
|
|
|
The *count_encoders* and *encoders* fields list the available encoders on
|
|
the device. Each encoder may be associated with a CRTC, and may be used
|
|
to drive a particular encoder.
|
|
|
|
The *min_\** and *max_\** fields indicate the maximum size of a framebuffer
|
|
for this device (i.e., the scanout size limit).
|
|
|
|
Return Value
|
|
============
|
|
|
|
``drmModeGetResources`` returns a drmModeRes structure pointer on
|
|
success, NULL on failure. The returned structure must be freed with
|
|
**drmModeFreeResources**\ (3).
|
|
|
|
Reporting Bugs
|
|
==============
|
|
|
|
Bugs in this function should be reported to
|
|
https://gitlab.freedesktop.org/mesa/libdrm/-/issues
|
|
|
|
See Also
|
|
========
|
|
|
|
**drm**\ (7), **drm-kms**\ (7), **drmModeGetFB**\ (3), **drmModeAddFB**\ (3),
|
|
**drmModeAddFB2**\ (3), **drmModeRmFB**\ (3), **drmModeDirtyFB**\ (3),
|
|
**drmModeGetCrtc**\ (3), **drmModeSetCrtc** (3), **drmModeGetEncoder** (3),
|
|
**drmModeGetConnector**\ (3)
|