diff options
author | Michel Dänzer <michel.daenzer@amd.com> | 2016-03-09 16:44:32 +0900 |
---|---|---|
committer | Michel Dänzer <michel@daenzer.net> | 2016-03-23 16:51:50 +0900 |
commit | 3de480e83c0a1824838d662d6d67c9fe85277298 (patch) | |
tree | 74f6e3eaba6356d633b7fa0b0f2a68d62fd13ccc /src | |
parent | 2e0b458e747c7df81dd5f9579a762262af3350e1 (diff) |
Factor out HW cursor checking code into drmmode_can_use_hw_cursor
And add a check for RandR 1.4 multihead.
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/drmmode_display.c | 39 |
1 files changed, 29 insertions, 10 deletions
diff --git a/src/drmmode_display.c b/src/drmmode_display.c index eac37d89..3769e44c 100644 --- a/src/drmmode_display.c +++ b/src/drmmode_display.c @@ -620,6 +620,33 @@ radeon_screen_damage_report(DamagePtr damage, RegionPtr region, void *closure) damage->damage.data = NULL; } +static Bool +drmmode_can_use_hw_cursor(xf86CrtcPtr crtc) +{ + RADEONInfoPtr info = RADEONPTR(crtc->scrn); + + /* Check for Option "SWcursor" */ + if (xf86ReturnOptValBool(info->Options, OPTION_SW_CURSOR, FALSE)) + return FALSE; + + /* Fall back to SW cursor if the CRTC is transformed */ + if (crtc->transformPresent) + return FALSE; + + /* Xorg doesn't correctly handle cursor position transform in the + * rotation case + */ + if (crtc->driverIsPerformingTransform && + (crtc->rotation & 0xf) != RR_Rotate_0) + return FALSE; + + /* HW cursor not supported yet with RandR 1.4 multihead */ + if (!xorg_list_is_empty(&crtc->scrn->pScreen->pixmap_dirty_list)) + return FALSE; + + return TRUE; +} + #if XF86_CRTC_VERSION >= 4 static Bool @@ -833,7 +860,7 @@ drmmode_set_mode_major(xf86CrtcPtr crtc, DisplayModePtr mode, } } - if (!xf86ReturnOptValBool(info->Options, OPTION_SW_CURSOR, FALSE)) + if (drmmode_can_use_hw_cursor(crtc)) xf86_reload_cursors(pScreen); done: @@ -951,15 +978,7 @@ drmmode_load_cursor_argb (xf86CrtcPtr crtc, CARD32 *image) static Bool drmmode_load_cursor_argb_check(xf86CrtcPtr crtc, CARD32 * image) { - /* Fall back to SW cursor if the CRTC is transformed */ - if (crtc->transformPresent) - return FALSE; - - /* Xorg doesn't correctly handle cursor position transform in the - * rotation case - */ - if (crtc->driverIsPerformingTransform && - (crtc->rotation & 0xf) != RR_Rotate_0) + if (!drmmode_can_use_hw_cursor(crtc)) return FALSE; drmmode_load_cursor_argb(crtc, image); |