1*4882a593SmuzhiyunFrom 1007d8479e84780e244a5d7ba0e0a0964e2ba900 Mon Sep 17 00:00:00 2001 2*4882a593SmuzhiyunFrom: Jeffy Chen <jeffy.chen@rock-chips.com> 3*4882a593SmuzhiyunDate: Tue, 13 Jul 2021 10:56:56 +0800 4*4882a593SmuzhiyunSubject: [PATCH 50/95] Support sw-cursor config 5*4882a593Smuzhiyun 6*4882a593SmuzhiyunTested with: 7*4882a593Smuzhiyun[core] 8*4882a593Smuzhiyunsw-cursor=true 9*4882a593Smuzhiyun 10*4882a593SmuzhiyunSigned-off-by: Jeffy Chen <jeffy.chen@rock-chips.com> 11*4882a593Smuzhiyun--- 12*4882a593Smuzhiyun compositor/main.c | 2 ++ 13*4882a593Smuzhiyun include/libweston/backend-drm.h | 2 ++ 14*4882a593Smuzhiyun libweston/backend-drm/drm.c | 2 ++ 15*4882a593Smuzhiyun 3 files changed, 6 insertions(+) 16*4882a593Smuzhiyun 17*4882a593Smuzhiyundiff --git a/compositor/main.c b/compositor/main.c 18*4882a593Smuzhiyunindex 7a1cc20..d376594 100644 19*4882a593Smuzhiyun--- a/compositor/main.c 20*4882a593Smuzhiyun+++ b/compositor/main.c 21*4882a593Smuzhiyun@@ -2955,6 +2955,8 @@ load_drm_backend(struct weston_compositor *c, 22*4882a593Smuzhiyun &config.pageflip_timeout, 0); 23*4882a593Smuzhiyun weston_config_section_get_bool(section, "pixman-shadow", 24*4882a593Smuzhiyun &config.use_pixman_shadow, true); 25*4882a593Smuzhiyun+ weston_config_section_get_bool(section, "sw-cursor", 26*4882a593Smuzhiyun+ &config.use_sw_cursor, false); 27*4882a593Smuzhiyun if (without_input) 28*4882a593Smuzhiyun c->require_input = !without_input; 29*4882a593Smuzhiyun 30*4882a593Smuzhiyundiff --git a/include/libweston/backend-drm.h b/include/libweston/backend-drm.h 31*4882a593Smuzhiyunindex 071125f..a9b6ebd 100644 32*4882a593Smuzhiyun--- a/include/libweston/backend-drm.h 33*4882a593Smuzhiyun+++ b/include/libweston/backend-drm.h 34*4882a593Smuzhiyun@@ -239,6 +239,8 @@ struct weston_drm_backend_config { 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun /** Use shadow buffer if using Pixman-renderer. */ 37*4882a593Smuzhiyun bool use_pixman_shadow; 38*4882a593Smuzhiyun+ 39*4882a593Smuzhiyun+ bool use_sw_cursor; 40*4882a593Smuzhiyun }; 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun #ifdef __cplusplus 43*4882a593Smuzhiyundiff --git a/libweston/backend-drm/drm.c b/libweston/backend-drm/drm.c 44*4882a593Smuzhiyunindex 97e3382..805e428 100644 45*4882a593Smuzhiyun--- a/libweston/backend-drm/drm.c 46*4882a593Smuzhiyun+++ b/libweston/backend-drm/drm.c 47*4882a593Smuzhiyun@@ -4426,6 +4426,8 @@ drm_backend_create(struct weston_compositor *compositor, 48*4882a593Smuzhiyun /* 'compute' faked zpos values in case HW doesn't expose any */ 49*4882a593Smuzhiyun drm_backend_create_faked_zpos(b); 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun+ device->cursors_are_broken |= config->use_sw_cursor; 52*4882a593Smuzhiyun+ 53*4882a593Smuzhiyun /* A this point we have some idea of whether or not we have a working 54*4882a593Smuzhiyun * cursor plane. */ 55*4882a593Smuzhiyun if (!device->cursors_are_broken) 56*4882a593Smuzhiyun-- 57*4882a593Smuzhiyun2.20.1 58*4882a593Smuzhiyun 59