mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2025-11-05 13:29:47 -05:00
Merge branch 'wlr_output_group' into 'master'
Draft: output: introduce wlr_output_group See merge request wlroots/wlroots!4154
This commit is contained in:
commit
6d38da24b3
11 changed files with 801 additions and 5 deletions
|
|
@ -15,6 +15,7 @@
|
|||
#include <wlr/interfaces/wlr_output.h>
|
||||
#include <wlr/render/drm_syncobj.h>
|
||||
#include <wlr/render/wlr_renderer.h>
|
||||
#include <wlr/types/wlr_output_group.h>
|
||||
#include <wlr/util/box.h>
|
||||
#include <wlr/util/log.h>
|
||||
#include <wlr/util/transform.h>
|
||||
|
|
@ -1724,6 +1725,12 @@ static bool connect_drm_connector(struct wlr_drm_connector *wlr_conn,
|
|||
}
|
||||
free(edid);
|
||||
|
||||
size_t tile_len = 0;
|
||||
uint8_t *tile = get_drm_prop_blob(drm->fd,
|
||||
wlr_conn->id, wlr_conn->props.tile, &tile_len);
|
||||
parse_tile(wlr_conn, tile_len, tile);
|
||||
free(tile);
|
||||
|
||||
char *subconnector = NULL;
|
||||
if (wlr_conn->props.subconnector) {
|
||||
subconnector = get_drm_prop_enum(drm->fd,
|
||||
|
|
@ -1870,10 +1877,20 @@ 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_drm_conn_log(conn, WLR_INFO, "Requesting modeset");
|
||||
wl_signal_emit_mutable(&drm->backend.events.new_output,
|
||||
&conn->output);
|
||||
if(conn->tile_info.group_id) {
|
||||
struct wlr_output_group *group = wlr_output_group_match_tile(&conn->tile_info);
|
||||
if (group) {
|
||||
wlr_drm_conn_log(conn, WLR_INFO, "Adding %s to existing group", conn->name);
|
||||
} else {
|
||||
wlr_drm_conn_log(conn, WLR_INFO, "Creating output group for %s", conn->name);
|
||||
group = wlr_output_group_create();
|
||||
}
|
||||
wlr_output_group_add_tile(group, &conn->output, &conn->tile_info);
|
||||
} else {
|
||||
wlr_drm_conn_log(conn, WLR_INFO, "Requesting modeset");
|
||||
wl_signal_emit_mutable(&drm->backend.events.new_output,
|
||||
&conn->output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -27,6 +27,7 @@ static const struct prop_info connector_info[] = {
|
|||
{ "EDID", INDEX(edid) },
|
||||
{ "HDR_OUTPUT_METADATA", INDEX(hdr_output_metadata) },
|
||||
{ "PATH", INDEX(path) },
|
||||
{ "TILE", INDEX(tile) },
|
||||
{ "content type", INDEX(content_type) },
|
||||
{ "link-status", INDEX(link_status) },
|
||||
{ "max bpc", INDEX(max_bpc) },
|
||||
|
|
|
|||
|
|
@ -97,6 +97,47 @@ void parse_edid(struct wlr_drm_connector *conn, size_t len, const uint8_t *data)
|
|||
di_info_destroy(info);
|
||||
}
|
||||
|
||||
void parse_tile(struct wlr_drm_connector *conn, size_t len, const uint8_t *data) {
|
||||
struct wlr_output_group_tile_info *tile_info = &conn->tile_info;
|
||||
memset(tile_info, 0, sizeof(*tile_info));
|
||||
if (len == 0)
|
||||
return;
|
||||
|
||||
// Reference:
|
||||
// - include/linux/drm/drm_connector.h tile_blob_ptr
|
||||
// - drivers/gpu/drm/drm_edid.c drm_parse_tiled_block()
|
||||
//
|
||||
// Note: group_id is always > 0
|
||||
int ret = sscanf((char*)data, "%d:%d:%d:%d:%d:%d:%d:%d",
|
||||
&tile_info->group_id,
|
||||
&tile_info->is_single_monitor,
|
||||
&tile_info->num_h,
|
||||
&tile_info->num_v,
|
||||
&tile_info->h_loc,
|
||||
&tile_info->v_loc,
|
||||
&tile_info->h_size,
|
||||
&tile_info->v_size);
|
||||
if(ret != 8) {
|
||||
wlr_log(WLR_ERROR, "Unable to understand tile information for "
|
||||
"connector %s", conn->name);
|
||||
return;
|
||||
}
|
||||
|
||||
wlr_log(WLR_INFO, "Connector '%s' TILE information: "
|
||||
"group ID %d, single monitor %d, total %d horizontal tiles, "
|
||||
"total %d vertical tiles, horizontal tile %d, vertical tile "
|
||||
"%d, width %d, height %d",
|
||||
conn->name,
|
||||
tile_info->group_id,
|
||||
tile_info->is_single_monitor,
|
||||
tile_info->num_h,
|
||||
tile_info->num_v,
|
||||
tile_info->h_loc,
|
||||
tile_info->v_loc,
|
||||
tile_info->h_size,
|
||||
tile_info->v_size);
|
||||
}
|
||||
|
||||
const char *drm_connector_status_str(drmModeConnection status) {
|
||||
switch (status) {
|
||||
case DRM_MODE_CONNECTED:
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue