xserver: Branch 'master'

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Sep 3 19:04:22 UTC 2019


 hw/xfree86/drivers/modesetting/driver.c |    9 +++++++--
 hw/xfree86/drivers/modesetting/driver.h |    1 +
 2 files changed, 8 insertions(+), 2 deletions(-)

New commits:
commit f0d78b47ac49977a6007f5fe081f00c6eb19a12e
Author: Maarten Lankhorst <dev at mblankhorst.nl>
Date:   Thu Apr 25 11:46:41 2019 +0200

    modesetting: Disable atomic support by default
    
    The atomic driver has issues with modesetting when stealing
    connectors from a different crtc, a black screen when doing rotation
    on a different crtc, and in general is just a mapping of the legacy
    helpers to atomic. This is already done in the kernel, so just
    fallback to legacy by default until this is fixed.
    
    Please backport to 1.20, as we don't want to enable it for everyone
    there. It breaks for existing users.
    
    The fixes to make the xserver more atomic have been pending on the
    mailing list for ages.
    
    Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=110375
    Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=110030
    References: https://gitlab.freedesktop.org/xorg/xserver/merge_requests/36/commits
    Signed-off-by: Maarten Lankhorst <maarten.lankhorst at linux.intel.com>

diff --git a/hw/xfree86/drivers/modesetting/driver.c b/hw/xfree86/drivers/modesetting/driver.c
index 6f9f7c43a..61db67ab4 100644
--- a/hw/xfree86/drivers/modesetting/driver.c
+++ b/hw/xfree86/drivers/modesetting/driver.c
@@ -132,6 +132,7 @@ static const OptionInfoRec Options[] = {
     {OPTION_PAGEFLIP, "PageFlip", OPTV_BOOLEAN, {0}, FALSE},
     {OPTION_ZAPHOD_HEADS, "ZaphodHeads", OPTV_STRING, {0}, FALSE},
     {OPTION_DOUBLE_SHADOW, "DoubleShadow", OPTV_BOOLEAN, {0}, FALSE},
+    {OPTION_ATOMIC, "Atomic", OPTV_BOOLEAN, {0}, FALSE},
     {-1, NULL, OPTV_NONE, {0}, FALSE}
 };
 
@@ -1039,8 +1040,12 @@ PreInit(ScrnInfoPtr pScrn, int flags)
 #endif
     }
 
-    ret = drmSetClientCap(ms->fd, DRM_CLIENT_CAP_ATOMIC, 1);
-    ms->atomic_modeset = (ret == 0);
+    if (xf86ReturnOptValBool(ms->drmmode.Options, OPTION_ATOMIC, FALSE)) {
+        ret = drmSetClientCap(ms->fd, DRM_CLIENT_CAP_ATOMIC, 1);
+        ms->atomic_modeset = (ret == 0);
+    } else {
+        ms->atomic_modeset = FALSE;
+    }
 
     ms->kms_has_modifiers = FALSE;
     ret = drmGetCap(ms->fd, DRM_CAP_ADDFB2_MODIFIERS, &value);
diff --git a/hw/xfree86/drivers/modesetting/driver.h b/hw/xfree86/drivers/modesetting/driver.h
index 7511de6d3..8355abf98 100644
--- a/hw/xfree86/drivers/modesetting/driver.h
+++ b/hw/xfree86/drivers/modesetting/driver.h
@@ -51,6 +51,7 @@ typedef enum {
     OPTION_PAGEFLIP,
     OPTION_ZAPHOD_HEADS,
     OPTION_DOUBLE_SHADOW,
+    OPTION_ATOMIC,
 } modesettingOpts;
 
 typedef struct


More information about the xorg-commit mailing list