compositor-drm: drm_output_apply_state_legacy heads

Fix this function to support more than one head per output.

v9:
- Change { connectors, 0 } to { NULL, 0 } in drmModeSetCrtc() args.

Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Daniel Stone <daniels@collabora.com>
Acked-by: Derek Foreman <derekf@osg.samsung.com>
This commit is contained in:
Pekka Paalanen 2017-09-12 16:02:01 +03:00
parent eacec815a3
commit 02aeb5c66e

View File

@ -1797,18 +1797,24 @@ static int
drm_output_apply_state_legacy(struct drm_output_state *state) drm_output_apply_state_legacy(struct drm_output_state *state)
{ {
struct drm_output *output = state->output; struct drm_output *output = state->output;
struct drm_head *head = to_drm_head(weston_output_get_first_head(&output->base));
struct drm_backend *backend = to_drm_backend(output->base.compositor); struct drm_backend *backend = to_drm_backend(output->base.compositor);
struct drm_plane *scanout_plane = output->scanout_plane; struct drm_plane *scanout_plane = output->scanout_plane;
struct drm_property_info *dpms_prop = struct drm_property_info *dpms_prop;
&head->props_conn[WDRM_CONNECTOR_DPMS];
struct drm_plane_state *scanout_state; struct drm_plane_state *scanout_state;
struct drm_plane_state *ps; struct drm_plane_state *ps;
struct drm_plane *p; struct drm_plane *p;
struct drm_mode *mode; struct drm_mode *mode;
struct drm_head *head;
uint32_t connectors[MAX_CLONED_CONNECTORS];
int n_conn = 0;
struct timespec now; struct timespec now;
int ret = 0; int ret = 0;
wl_list_for_each(head, &output->base.head_list, base.output_link) {
assert(n_conn < MAX_CLONED_CONNECTORS);
connectors[n_conn++] = head->connector_id;
}
/* If disable_planes is set then assign_planes() wasn't /* If disable_planes is set then assign_planes() wasn't
* called for this render, so we could still have a stale * called for this render, so we could still have a stale
* cursor plane set up. * cursor plane set up.
@ -1844,7 +1850,7 @@ drm_output_apply_state_legacy(struct drm_output_state *state)
} }
ret = drmModeSetCrtc(backend->drm.fd, output->crtc_id, 0, 0, 0, ret = drmModeSetCrtc(backend->drm.fd, output->crtc_id, 0, 0, 0,
&head->connector_id, 0, NULL); NULL, 0, NULL);
if (ret) if (ret)
weston_log("drmModeSetCrtc failed disabling: %m\n"); weston_log("drmModeSetCrtc failed disabling: %m\n");
@ -1879,7 +1885,7 @@ drm_output_apply_state_legacy(struct drm_output_state *state)
ret = drmModeSetCrtc(backend->drm.fd, output->crtc_id, ret = drmModeSetCrtc(backend->drm.fd, output->crtc_id,
scanout_state->fb->fb_id, scanout_state->fb->fb_id,
0, 0, 0, 0,
&head->connector_id, 1, connectors, n_conn,
&mode->mode_info); &mode->mode_info);
if (ret) { if (ret) {
weston_log("set mode failed: %m\n"); weston_log("set mode failed: %m\n");
@ -1950,14 +1956,20 @@ drm_output_apply_state_legacy(struct drm_output_state *state)
} }
} }
if (dpms_prop->prop_id && state->dpms != output->state_cur->dpms) { if (state->dpms != output->state_cur->dpms) {
ret = drmModeConnectorSetProperty(backend->drm.fd, wl_list_for_each(head, &output->base.head_list, base.output_link) {
head->connector_id, dpms_prop = &head->props_conn[WDRM_CONNECTOR_DPMS];
dpms_prop->prop_id, if (dpms_prop->prop_id == 0)
state->dpms); continue;
if (ret) {
weston_log("DRM: DPMS: failed property set for %s\n", ret = drmModeConnectorSetProperty(backend->drm.fd,
output->base.name); head->connector_id,
dpms_prop->prop_id,
state->dpms);
if (ret) {
weston_log("DRM: DPMS: failed property set for %s\n",
head->base.name);
}
} }
} }