diff options
| author | Simon Ser <contact@emersion.fr> | 2020-05-07 21:28:42 +0200 | 
|---|---|---|
| committer | Simon Ser <contact@emersion.fr> | 2020-05-09 16:42:25 +0200 | 
| commit | da63d11d341e9e1bc3c0dcb040e2cc5d82a3959e (patch) | |
| tree | 9938608ed1a38307cb6042828b1c5151afc2e01f /backend | |
| parent | f8e02db4bcd297f6bef2387dc1a65b837619c07c (diff) | |
| download | wlroots-da63d11d341e9e1bc3c0dcb040e2cc5d82a3959e.tar.xz | |
backend/drm: remove crtc_set_cursor from interface
Diffstat (limited to 'backend')
| -rw-r--r-- | backend/drm/atomic.c | 10 | ||||
| -rw-r--r-- | backend/drm/backend.c | 13 | ||||
| -rw-r--r-- | backend/drm/drm.c | 15 | ||||
| -rw-r--r-- | backend/drm/legacy.c | 59 | 
4 files changed, 30 insertions, 67 deletions
| diff --git a/backend/drm/atomic.c b/backend/drm/atomic.c index 0b258cfb..d4f033f0 100644 --- a/backend/drm/atomic.c +++ b/backend/drm/atomic.c @@ -237,15 +237,6 @@ static bool atomic_crtc_commit(struct wlr_drm_backend *drm,  		return false;  	} -	if (crtc->active && crtc->cursor) { -		drm_fb_move(&crtc->cursor->queued_fb, &crtc->cursor->pending_fb); -	} -	return true; -} - -static bool atomic_crtc_set_cursor(struct wlr_drm_backend *drm, -		struct wlr_drm_crtc *crtc, struct gbm_bo *bo) { -	/* Cursor updates happen when we pageflip */  	return true;  } @@ -267,6 +258,5 @@ static size_t atomic_crtc_get_gamma_size(struct wlr_drm_backend *drm,  const struct wlr_drm_interface atomic_iface = {  	.crtc_commit = atomic_crtc_commit, -	.crtc_set_cursor = atomic_crtc_set_cursor,  	.crtc_get_gamma_size = atomic_crtc_get_gamma_size,  }; diff --git a/backend/drm/backend.c b/backend/drm/backend.c index 4eabb0ec..6f9370f3 100644 --- a/backend/drm/backend.c +++ b/backend/drm/backend.c @@ -100,19 +100,6 @@ static void session_signal(struct wl_listener *listener, void *data) {  			} else {  				enable_drm_connector(&conn->output, false);  			} - -			if (!conn->crtc) { -				continue; -			} - -			struct wlr_drm_plane *plane = conn->crtc->cursor; -			struct gbm_bo *bo = NULL; -			if (plane->cursor_enabled) { -				bo = drm_fb_acquire(&plane->current_fb, drm, -					&plane->mgpu_surf); -			} - -			drm->iface->crtc_set_cursor(drm, conn->crtc, bo);  		}  	} else {  		wlr_log(WLR_INFO, "DRM fd paused"); diff --git a/backend/drm/drm.c b/backend/drm/drm.c index ed01459b..60df4348 100644 --- a/backend/drm/drm.c +++ b/backend/drm/drm.c @@ -360,6 +360,7 @@ static bool drm_crtc_page_flip(struct wlr_drm_connector *conn) {  	conn->pageflip_pending = true;  	drm_fb_move(&crtc->primary->queued_fb, &crtc->primary->pending_fb); +	drm_fb_move(&crtc->cursor->queued_fb, &crtc->cursor->pending_fb);  	wlr_output_update_enabled(&conn->output, true);  	return true;  } @@ -1013,17 +1014,7 @@ static bool drm_connector_set_cursor(struct wlr_output *output,  		plane->cursor_enabled = true;  	} -	if (!drm->session->active) { -		return true; // will be committed when session is resumed -	} - -	struct gbm_bo *bo = NULL; -  	if (plane->cursor_enabled) { -		bo = drm_fb_acquire(&plane->pending_fb, drm, &plane->mgpu_surf); - -		wlr_log(WLR_DEBUG, "SET_CURSOR %p %p", plane->pending_fb.bo, bo); -  		/* Workaround for nouveau buffers created with GBM_BO_USER_LINEAR are  		 * placed in NOUVEAU_GEM_DOMAIN_GART. When the bo is attached to the  		 * cursor plane it is moved to NOUVEAU_GEM_DOMAIN_VRAM. However, this @@ -1035,10 +1026,6 @@ static bool drm_connector_set_cursor(struct wlr_output *output,  		glFinish();  	} -	if (!drm->iface->crtc_set_cursor(drm, crtc, bo)) { -		return false; -	} -  	wlr_output_update_needs_frame(output);  	return true;  } diff --git a/backend/drm/legacy.c b/backend/drm/legacy.c index ecf67092..09e7df16 100644 --- a/backend/drm/legacy.c +++ b/backend/drm/legacy.c @@ -56,46 +56,46 @@ static bool legacy_crtc_commit(struct wlr_drm_backend *drm,  		}  	} -	if (cursor != NULL && cursor->cursor_enabled && 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); -		return false; -	} - -	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); +	if (cursor != NULL && cursor->cursor_enabled) { +		struct wlr_drm_fb *cursor_fb = plane_get_next_fb(cursor); +		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);  			return false;  		} -	} -	return true; -} - -bool legacy_crtc_set_cursor(struct wlr_drm_backend *drm, -		struct wlr_drm_crtc *crtc, struct gbm_bo *bo) { -	if (!crtc || !crtc->cursor) { -		return true; -	} +		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); +			return false; +		} -	if (!bo) { +		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); +			return false; +		} +	} else {  		if (drmModeSetCursor(drm->fd, crtc->id, 0, 0, 0)) { -			wlr_log_errno(WLR_DEBUG, "Failed to clear hardware cursor"); +			wlr_log_errno(WLR_DEBUG, "%s: failed to unset hardware cursor", +				conn->output.name);  			return false;  		} -		return true;  	} -	struct wlr_drm_plane *plane = crtc->cursor; - -	if (drmModeSetCursor(drm->fd, crtc->id, gbm_bo_get_handle(bo).u32, -			plane->surf.width, plane->surf.height)) { -		wlr_log_errno(WLR_DEBUG, "Failed to set hardware cursor"); -		return false; +	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); +			return false; +		}  	} -	drm_fb_move(&crtc->cursor->queued_fb, &crtc->cursor->pending_fb);  	return true;  } @@ -124,6 +124,5 @@ static size_t legacy_crtc_get_gamma_size(struct wlr_drm_backend *drm,  const struct wlr_drm_interface legacy_iface = {  	.crtc_commit = legacy_crtc_commit, -	.crtc_set_cursor = legacy_crtc_set_cursor,  	.crtc_get_gamma_size = legacy_crtc_get_gamma_size,  }; | 
