mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-23 15:09:49 +01:00
backend/drm: introduce wlr_drm_conn_log
Simplify and unify connector-specific logging with a new wlr_drm_conn_log macro. This makes it easier to understand which connector a failure is about, without having to explicitly integrate the connector name in each log message.
This commit is contained in:
parent
0aefa18690
commit
c89b131f29
3 changed files with 62 additions and 65 deletions
|
@ -363,8 +363,8 @@ static bool drm_crtc_page_flip(struct wlr_drm_connector *conn) {
|
|||
// we'll wait for all queued page-flips to complete, so we don't need this
|
||||
// safeguard.
|
||||
if (conn->pageflip_pending && !crtc->pending_modeset) {
|
||||
wlr_log(WLR_ERROR, "Failed to page-flip output '%s': "
|
||||
"a page-flip is already pending", conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Failed to page-flip output: "
|
||||
"a page-flip is already pending");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -445,7 +445,8 @@ static bool drm_connector_test(struct wlr_output *output) {
|
|||
output->pending.enabled) {
|
||||
if (output->current_mode == NULL &&
|
||||
!(output->pending.committed & WLR_OUTPUT_STATE_MODE)) {
|
||||
wlr_log(WLR_DEBUG, "Can't enable an output without a mode");
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG,
|
||||
"Can't enable an output without a mode");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@ -492,7 +493,7 @@ static bool drm_connector_commit_buffer(struct wlr_output *output) {
|
|||
switch (output->pending.buffer_type) {
|
||||
case WLR_OUTPUT_STATE_BUFFER_RENDER:
|
||||
if (!drm_fb_lock_surface(&plane->pending_fb, &plane->surf)) {
|
||||
wlr_log(WLR_ERROR, "drm_fb_lock_surface failed");
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "drm_fb_lock_surface failed");
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
|
@ -527,13 +528,13 @@ bool drm_connector_supports_vrr(struct wlr_drm_connector *conn) {
|
|||
if (conn->props.vrr_capable == 0 ||
|
||||
!get_drm_prop(drm->fd, conn->id, conn->props.vrr_capable,
|
||||
&vrr_capable) || !vrr_capable) {
|
||||
wlr_log(WLR_DEBUG, "Failed to enable adaptive sync: "
|
||||
"connector '%s' doesn't support VRR", conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "Failed to enable adaptive sync: "
|
||||
"connector doesn't support VRR");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (crtc->props.vrr_enabled == 0) {
|
||||
wlr_log(WLR_DEBUG, "Failed to enable adaptive sync: "
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "Failed to enable adaptive sync: "
|
||||
"CRTC %"PRIu32" doesn't support VRR", crtc->id);
|
||||
return false;
|
||||
}
|
||||
|
@ -663,8 +664,7 @@ struct wlr_drm_fb *plane_get_next_fb(struct wlr_drm_plane *plane) {
|
|||
static bool drm_connector_pageflip_renderer(struct wlr_drm_connector *conn) {
|
||||
struct wlr_drm_crtc *crtc = conn->crtc;
|
||||
if (!crtc) {
|
||||
wlr_log(WLR_ERROR, "Page-flip failed on connector '%s': no CRTC",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Page-flip failed: no CRTC");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -691,13 +691,12 @@ static bool drm_connector_init_renderer(struct wlr_drm_connector *conn,
|
|||
return false;
|
||||
}
|
||||
|
||||
wlr_log(WLR_DEBUG, "Initializing renderer on connector '%s'",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "Initializing renderer");
|
||||
|
||||
struct wlr_drm_crtc *crtc = conn->crtc;
|
||||
if (!crtc) {
|
||||
wlr_log(WLR_ERROR, "Failed to initialize renderer on connector '%s': "
|
||||
"no CRTC", conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR,
|
||||
"Failed to initialize renderer: no CRTC");
|
||||
return false;
|
||||
}
|
||||
struct wlr_drm_plane *plane = crtc->primary;
|
||||
|
@ -713,7 +712,7 @@ static bool drm_connector_init_renderer(struct wlr_drm_connector *conn,
|
|||
bool modifiers = true;
|
||||
const char *no_modifiers = getenv("WLR_DRM_NO_MODIFIERS");
|
||||
if (no_modifiers != NULL && strcmp(no_modifiers, "1") == 0) {
|
||||
wlr_log(WLR_DEBUG,
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG,
|
||||
"WLR_DRM_NO_MODIFIERS set, initializing planes without modifiers");
|
||||
modifiers = false;
|
||||
}
|
||||
|
@ -721,15 +720,15 @@ static bool drm_connector_init_renderer(struct wlr_drm_connector *conn,
|
|||
if (!drm_plane_init_surface(plane, drm, width, height, format, false, modifiers) ||
|
||||
!drm_connector_pageflip_renderer(conn)) {
|
||||
if (!modifiers) {
|
||||
wlr_log(WLR_ERROR, "Failed to initialize renderer "
|
||||
"on connector '%s': initial page-flip failed",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Failed to initialize renderer:"
|
||||
"initial page-flip failed");
|
||||
return false;
|
||||
}
|
||||
|
||||
// If page-flipping with modifiers enabled doesn't work, retry without
|
||||
// modifiers
|
||||
wlr_log(WLR_INFO, "Page-flip failed with primary FB modifiers enabled, "
|
||||
wlr_drm_conn_log(conn, WLR_INFO,
|
||||
"Page-flip failed with primary FB modifiers enabled, "
|
||||
"retrying without modifiers");
|
||||
modifiers = false;
|
||||
|
||||
|
@ -742,9 +741,8 @@ static bool drm_connector_init_renderer(struct wlr_drm_connector *conn,
|
|||
return false;
|
||||
}
|
||||
if (!drm_connector_pageflip_renderer(conn)) {
|
||||
wlr_log(WLR_ERROR, "Failed to initialize renderer "
|
||||
"on connector '%s': initial page-flip failed",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Failed to initialize renderer:"
|
||||
"initial page-flip failed");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@ -762,8 +760,8 @@ static void attempt_enable_needs_modeset(struct wlr_drm_backend *drm) {
|
|||
if (conn->state == WLR_DRM_CONN_NEEDS_MODESET &&
|
||||
conn->crtc != NULL && conn->desired_mode != NULL &&
|
||||
conn->desired_enabled) {
|
||||
wlr_log(WLR_DEBUG, "Output %s has a desired mode and a CRTC, "
|
||||
"attempting a modeset", conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG,
|
||||
"Output has a desired mode and a CRTC, attempting a modeset");
|
||||
drm_connector_set_mode(conn, conn->desired_mode);
|
||||
}
|
||||
}
|
||||
|
@ -794,7 +792,8 @@ bool drm_connector_set_mode(struct wlr_drm_connector *conn,
|
|||
|
||||
if (conn->state != WLR_DRM_CONN_CONNECTED
|
||||
&& conn->state != WLR_DRM_CONN_NEEDS_MODESET) {
|
||||
wlr_log(WLR_ERROR, "Cannot modeset a disconnected output");
|
||||
wlr_drm_conn_log(conn, WLR_ERROR,
|
||||
"Cannot modeset a disconnected output");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -803,18 +802,19 @@ bool drm_connector_set_mode(struct wlr_drm_connector *conn,
|
|||
realloc_crtcs(drm);
|
||||
}
|
||||
if (conn->crtc == NULL) {
|
||||
wlr_log(WLR_ERROR, "Cannot modeset '%s': no CRTC for this connector",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR,
|
||||
"Cannot perform modeset: no CRTC for this connector");
|
||||
return false;
|
||||
}
|
||||
|
||||
wlr_log(WLR_INFO, "Modesetting '%s' with '%" PRId32 "x%" PRId32 "@%" PRId32 "mHz'",
|
||||
conn->output.name, wlr_mode->width, wlr_mode->height,
|
||||
wlr_mode->refresh);
|
||||
wlr_drm_conn_log(conn, WLR_INFO,
|
||||
"Modesetting with '%" PRId32 "x%" PRId32 "@%" PRId32 "mHz'",
|
||||
wlr_mode->width, wlr_mode->height, wlr_mode->refresh);
|
||||
|
||||
struct wlr_drm_mode *mode = (struct wlr_drm_mode *)wlr_mode;
|
||||
if (!drm_connector_init_renderer(conn, mode)) {
|
||||
wlr_log(WLR_ERROR, "Failed to initialize renderer for plane");
|
||||
wlr_drm_conn_log(conn, WLR_ERROR,
|
||||
"Failed to initialize renderer for plane");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -857,7 +857,7 @@ struct wlr_output_mode *wlr_drm_connector_add_mode(struct wlr_output *output,
|
|||
mode->wlr_mode.height = mode->drm_mode.vdisplay;
|
||||
mode->wlr_mode.refresh = calculate_refresh_rate(modeinfo);
|
||||
|
||||
wlr_log(WLR_INFO, "Registered custom mode "
|
||||
wlr_drm_conn_log(conn, WLR_INFO, "Registered custom mode "
|
||||
"%"PRId32"x%"PRId32"@%"PRId32,
|
||||
mode->wlr_mode.width, mode->wlr_mode.height,
|
||||
mode->wlr_mode.refresh);
|
||||
|
@ -893,7 +893,7 @@ static bool drm_connector_set_cursor(struct wlr_output *output,
|
|||
|
||||
if (!drm_plane_init_surface(plane, drm, w, h,
|
||||
DRM_FORMAT_ARGB8888, true, false)) {
|
||||
wlr_log(WLR_ERROR, "Cannot allocate cursor resources");
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Cannot allocate cursor resources");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@ -931,7 +931,7 @@ static bool drm_connector_set_cursor(struct wlr_output *output,
|
|||
height = height * output->scale / scale;
|
||||
|
||||
if (width > (int)plane->surf.width || height > (int)plane->surf.height) {
|
||||
wlr_log(WLR_ERROR, "Cursor too large (max %dx%d)",
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Cursor too large (max %dx%d)",
|
||||
(int)plane->surf.width, (int)plane->surf.height);
|
||||
return false;
|
||||
}
|
||||
|
@ -1043,8 +1043,8 @@ static void dealloc_crtc(struct wlr_drm_connector *conn) {
|
|||
return;
|
||||
}
|
||||
|
||||
wlr_log(WLR_DEBUG, "De-allocating CRTC %zu for output '%s'",
|
||||
conn->crtc - drm->crtcs, conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "De-allocating CRTC %zu",
|
||||
conn->crtc - drm->crtcs);
|
||||
|
||||
conn->crtc->pending_modeset = true;
|
||||
conn->crtc->pending.active = false;
|
||||
|
@ -1159,8 +1159,7 @@ static void realloc_crtcs(struct wlr_drm_backend *drm) {
|
|||
|
||||
if (connector_match[i] == -1) {
|
||||
if (prev_enabled) {
|
||||
wlr_log(WLR_DEBUG, "Output has %s lost its CRTC",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "Output has lost its CRTC");
|
||||
conn->state = WLR_DRM_CONN_NEEDS_MODESET;
|
||||
wlr_output_update_enabled(&conn->output, false);
|
||||
conn->desired_mode = conn->output.current_mode;
|
||||
|
@ -1179,8 +1178,7 @@ static void realloc_crtcs(struct wlr_drm_backend *drm) {
|
|||
struct wlr_drm_mode *mode =
|
||||
(struct wlr_drm_mode *)conn->output.current_mode;
|
||||
if (!drm_connector_init_renderer(conn, mode)) {
|
||||
wlr_log(WLR_ERROR, "Failed to initialize renderer on output %s",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_ERROR, "Failed to initialize renderer");
|
||||
wlr_output_update_enabled(&conn->output, false);
|
||||
continue;
|
||||
}
|
||||
|
@ -1298,14 +1296,14 @@ void scan_drm_connectors(struct wlr_drm_backend *drm) {
|
|||
uint64_t link_status;
|
||||
if (!get_drm_prop(drm->fd, wlr_conn->id,
|
||||
wlr_conn->props.link_status, &link_status)) {
|
||||
wlr_log(WLR_ERROR, "Failed to get link status for '%s'",
|
||||
wlr_conn->output.name);
|
||||
wlr_drm_conn_log(wlr_conn, WLR_ERROR,
|
||||
"Failed to get link status prop");
|
||||
continue;
|
||||
}
|
||||
|
||||
if (link_status == DRM_MODE_LINK_STATUS_BAD) {
|
||||
// We need to reload our list of modes and force a modeset
|
||||
wlr_log(WLR_INFO, "Bad link for '%s'", wlr_conn->output.name);
|
||||
wlr_drm_conn_log(wlr_conn, WLR_INFO, "Bad link detected");
|
||||
drm_connector_cleanup(wlr_conn);
|
||||
}
|
||||
}
|
||||
|
@ -1368,8 +1366,7 @@ void scan_drm_connectors(struct wlr_drm_backend *drm) {
|
|||
|
||||
wlr_conn->possible_crtc = get_possible_crtcs(drm->fd, res, drm_conn);
|
||||
if (wlr_conn->possible_crtc == 0) {
|
||||
wlr_log(WLR_ERROR, "No CRTC possible for connector '%s'",
|
||||
wlr_conn->output.name);
|
||||
wlr_drm_conn_log(wlr_conn, WLR_ERROR, "No CRTC possible");
|
||||
}
|
||||
|
||||
// TODO: this results in connectors being enabled without a mode
|
||||
|
@ -1414,8 +1411,7 @@ void scan_drm_connectors(struct wlr_drm_backend *drm) {
|
|||
for (size_t i = 0; i < new_outputs_len; ++i) {
|
||||
struct wlr_drm_connector *conn = new_outputs[i];
|
||||
|
||||
wlr_log(WLR_INFO, "Requesting modeset for '%s'",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log(conn, WLR_INFO, "Requesting modeset");
|
||||
wlr_signal_emit_safe(&drm->backend.events.new_output,
|
||||
&conn->output);
|
||||
}
|
||||
|
@ -1440,7 +1436,7 @@ static void page_flip_handler(int fd, unsigned seq,
|
|||
}
|
||||
}
|
||||
if (!conn) {
|
||||
wlr_log(WLR_DEBUG, "No connector for crtc_id %u", crtc_id);
|
||||
wlr_log(WLR_DEBUG, "No connector for CRTC %u", crtc_id);
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
|
@ -42,15 +42,14 @@ static bool legacy_crtc_commit(struct wlr_drm_backend *drm,
|
|||
DRM_MODE_DPMS_ON : DRM_MODE_DPMS_OFF;
|
||||
if (drmModeConnectorSetProperty(drm->fd, conn->id, conn->props.dpms,
|
||||
dpms) != 0) {
|
||||
wlr_log_errno(WLR_ERROR, "%s: failed to set DPMS property",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_ERROR,
|
||||
"Failed to set DPMS property");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (drmModeSetCrtc(drm->fd, crtc->id, fb_id, 0, 0,
|
||||
conns, conns_len, mode)) {
|
||||
wlr_log_errno(WLR_ERROR, "%s: failed to set CRTC",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_ERROR, "Failed to set CRTC");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@ -67,16 +66,15 @@ static bool legacy_crtc_commit(struct wlr_drm_backend *drm,
|
|||
if (drmModeObjectSetProperty(drm->fd, crtc->id, DRM_MODE_OBJECT_CRTC,
|
||||
crtc->props.vrr_enabled,
|
||||
output->pending.adaptive_sync_enabled) != 0) {
|
||||
wlr_log_errno(WLR_ERROR,
|
||||
wlr_drm_conn_log_errno(conn, WLR_ERROR,
|
||||
"drmModeObjectSetProperty(VRR_ENABLED) failed");
|
||||
return false;
|
||||
}
|
||||
output->adaptive_sync_status = output->pending.adaptive_sync_enabled ?
|
||||
WLR_OUTPUT_ADAPTIVE_SYNC_ENABLED :
|
||||
WLR_OUTPUT_ADAPTIVE_SYNC_DISABLED;
|
||||
wlr_log(WLR_DEBUG, "VRR %s on connector '%s'",
|
||||
output->pending.adaptive_sync_enabled ? "enabled" : "disabled",
|
||||
output->name);
|
||||
wlr_drm_conn_log(conn, WLR_DEBUG, "VRR %s",
|
||||
output->pending.adaptive_sync_enabled ? "enabled" : "disabled");
|
||||
}
|
||||
|
||||
if (cursor != NULL && drm_connector_is_cursor_visible(conn)) {
|
||||
|
@ -84,29 +82,26 @@ static bool legacy_crtc_commit(struct wlr_drm_backend *drm,
|
|||
struct gbm_bo *cursor_bo =
|
||||
drm_fb_acquire(cursor_fb, drm, &cursor->mgpu_surf);
|
||||
if (!cursor_bo) {
|
||||
wlr_log_errno(WLR_DEBUG, "%s: failed to acquire cursor FB",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_DEBUG,
|
||||
"Failed to acquire cursor FB");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (drmModeSetCursor(drm->fd, crtc->id,
|
||||
gbm_bo_get_handle(cursor_bo).u32,
|
||||
cursor->surf.width, cursor->surf.height)) {
|
||||
wlr_log_errno(WLR_DEBUG, "%s: failed to set hardware cursor",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_DEBUG, "drmModeSetCursor failed");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (drmModeMoveCursor(drm->fd,
|
||||
crtc->id, conn->cursor_x, conn->cursor_y) != 0) {
|
||||
wlr_log_errno(WLR_ERROR, "%s: failed to move cursor",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_ERROR, "drmModeMoveCursor failed");
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if (drmModeSetCursor(drm->fd, crtc->id, 0, 0, 0)) {
|
||||
wlr_log_errno(WLR_DEBUG, "%s: failed to unset hardware cursor",
|
||||
conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_DEBUG, "drmModeSetCursor failed");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
@ -114,7 +109,7 @@ static bool legacy_crtc_commit(struct wlr_drm_backend *drm,
|
|||
if (flags & DRM_MODE_PAGE_FLIP_EVENT) {
|
||||
if (drmModePageFlip(drm->fd, crtc->id, fb_id,
|
||||
DRM_MODE_PAGE_FLIP_EVENT, drm)) {
|
||||
wlr_log_errno(WLR_ERROR, "%s: Failed to page flip", conn->output.name);
|
||||
wlr_drm_conn_log_errno(conn, WLR_ERROR, "drmModePageFlip failed");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -110,9 +110,10 @@ struct wlr_drm_mode {
|
|||
};
|
||||
|
||||
struct wlr_drm_connector {
|
||||
struct wlr_output output;
|
||||
struct wlr_output output; // only valid if state != DISCONNECTED
|
||||
|
||||
struct wlr_drm_backend *backend;
|
||||
char name[24];
|
||||
enum wlr_drm_connector_state state;
|
||||
struct wlr_output_mode *desired_mode;
|
||||
bool desired_enabled;
|
||||
|
@ -155,4 +156,9 @@ size_t drm_crtc_get_gamma_lut_size(struct wlr_drm_backend *drm,
|
|||
|
||||
struct wlr_drm_fb *plane_get_next_fb(struct wlr_drm_plane *plane);
|
||||
|
||||
#define wlr_drm_conn_log(conn, verb, fmt, ...) \
|
||||
wlr_log(verb, "connector %s: " fmt, conn->output.name, ##__VA_ARGS__)
|
||||
#define wlr_drm_conn_log_errno(conn, verb, fmt, ...) \
|
||||
wlr_log_errno(verb, "connector %s: " fmt, conn->output.name, ##__VA_ARGS__)
|
||||
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue