From 96fbd39a414f7b9c096dfc3764538b85b53947e2 Mon Sep 17 00:00:00 2001
From: Britney Fransen <brfransen@gmail.com>
Date: Fri, 22 Jan 2016 21:57:23 +0000
Subject: xorg-server: update to 1.18.0

---
 ...accelerated-valuators-to-the-ValuatorMask.patch | 210 ---------------------
 ...md-logind-do-not-rely-on-directed-signals.patch |  55 ++++++
 ...-hook-up-the-unaccelerated-valuator-masks.patch | 134 -------------
 abs/core/xorg-server/PKGBUILD                      |  55 +++---
 abs/core/xorg-server/autoconfig-sis.patch          |  21 ---
 abs/core/xorg-server/nvidia-drm-outputclass.conf   |   6 -
 ...te-libdrm-based-detection-for-KMS-drivers.patch |  12 ++
 ...bugging-messages-other-than-GL-API-errors.patch |  14 ++
 8 files changed, 110 insertions(+), 397 deletions(-)
 delete mode 100644 abs/core/xorg-server/0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch
 create mode 100644 abs/core/xorg-server/0001-systemd-logind-do-not-rely-on-directed-signals.patch
 delete mode 100644 abs/core/xorg-server/0002-dix-hook-up-the-unaccelerated-valuator-masks.patch
 delete mode 100644 abs/core/xorg-server/autoconfig-sis.patch
 delete mode 100644 abs/core/xorg-server/nvidia-drm-outputclass.conf
 create mode 100644 abs/core/xorg-server/v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch
 create mode 100644 abs/core/xorg-server/xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch

diff --git a/abs/core/xorg-server/0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch b/abs/core/xorg-server/0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch
deleted file mode 100644
index 86744f1..0000000
--- a/abs/core/xorg-server/0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch
+++ /dev/null
@@ -1,210 +0,0 @@
-From e1a7f4bb5333b0271d29f785eb55f1c3273e626a Mon Sep 17 00:00:00 2001
-From: Peter Hutterer <peter.hutterer@who-t.net>
-Date: Tue, 5 May 2015 14:18:54 +1000
-Subject: [PATCH] dix: Add unaccelerated valuators to the ValuatorMask
-
-Allows a mask to carry both accelerated and unaccelerated motion at the same
-time.
-
-This is required for xf86-input-libinput where the pointer acceleration
-happens in libinput already, but parts of the server, specifically raw events
-and DGA rely on device-specific unaccelerated data.
-
-To ease integration add this as a second set to the ValuatorMask rather than
-extending all APIs to carry a second, possibly NULL set of valuators.
-
-Note that a valuator mask should only be used in either accel/unaccel or
-standard mode at any time. Switching requires either a valuator_mask_zero()
-call or unsetting all valuators one-by-one. Trying to mix the two will produce
-a warning.
-
-The server has a shortcut for changing a mask with the
-valuator_mask_drop_unaccelerated() call. This saves us from having to loop
-through all valuators on every event, we can just drop the bits we know we
-don't want.
-
-Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-Reviewed-by: Hans de Goede <hdegoede@redhat.com>
----
- dix/inpututils.c               | 82 +++++++++++++++++++++++++++++++++++++++---
- hw/xfree86/common/xf86Module.h |  2 +-
- include/input.h                | 15 ++++++++
- include/inpututils.h           |  2 ++
- 4 files changed, 95 insertions(+), 6 deletions(-)
-
-diff --git a/dix/inpututils.c b/dix/inpututils.c
-index 5c2a32d..1363988 100644
---- a/dix/inpututils.c
-+++ b/dix/inpututils.c
-@@ -505,11 +505,8 @@ valuator_mask_isset(const ValuatorMask *mask, int valuator)
-     return mask->last_bit >= valuator && BitIsOn(mask->mask, valuator);
- }
- 
--/**
-- * Set the valuator to the given floating-point data.
-- */
--void
--valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
-+static inline void
-+_valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
- {
-     mask->last_bit = max(valuator, mask->last_bit);
-     SetBit(mask->mask, valuator);
-@@ -517,6 +514,17 @@ valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
- }
- 
- /**
-+ * Set the valuator to the given floating-point data.
-+ */
-+void
-+valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
-+{
-+    BUG_WARN_MSG(mask->has_unaccelerated,
-+                 "Do not mix valuator types, zero mask first\n");
-+    _valuator_mask_set_double(mask, valuator, data);
-+}
-+
-+/**
-  * Set the valuator to the given integer data.
-  */
- void
-@@ -594,11 +602,15 @@ valuator_mask_unset(ValuatorMask *mask, int valuator)
- 
-         ClearBit(mask->mask, valuator);
-         mask->valuators[valuator] = 0.0;
-+        mask->unaccelerated[valuator] = 0.0;
- 
-         for (i = 0; i <= mask->last_bit; i++)
-             if (valuator_mask_isset(mask, i))
-                 lastbit = max(lastbit, i);
-         mask->last_bit = lastbit;
-+
-+        if (mask->last_bit == -1)
-+            mask->has_unaccelerated = FALSE;
-     }
- }
- 
-@@ -611,6 +623,66 @@ valuator_mask_copy(ValuatorMask *dest, const ValuatorMask *src)
-         valuator_mask_zero(dest);
- }
- 
-+Bool
-+valuator_mask_has_unaccelerated(const ValuatorMask *mask)
-+{
-+    return mask->has_unaccelerated;
-+}
-+
-+void
-+valuator_mask_drop_unaccelerated(ValuatorMask *mask)
-+{
-+    memset(mask->unaccelerated, 0, sizeof(mask->unaccelerated));
-+    mask->has_unaccelerated = FALSE;
-+}
-+
-+/**
-+ * Set both accelerated and unaccelerated value for this mask.
-+ */
-+void
-+valuator_mask_set_unaccelerated(ValuatorMask *mask,
-+                                int valuator,
-+                                double accel,
-+                                double unaccel)
-+{
-+    BUG_WARN_MSG(mask->last_bit != -1 && !mask->has_unaccelerated,
-+                 "Do not mix valuator types, zero mask first\n");
-+    _valuator_mask_set_double(mask, valuator, accel);
-+    mask->has_unaccelerated = TRUE;
-+    mask->unaccelerated[valuator] = unaccel;
-+}
-+
-+double
-+valuator_mask_get_accelerated(const ValuatorMask *mask,
-+                              int valuator)
-+{
-+    return valuator_mask_get_double(mask, valuator);
-+}
-+
-+double
-+valuator_mask_get_unaccelerated(const ValuatorMask *mask,
-+                                int valuator)
-+{
-+    return mask->unaccelerated[valuator];
-+}
-+
-+Bool
-+valuator_mask_fetch_unaccelerated(const ValuatorMask *mask,
-+                                  int valuator,
-+                                  double *accel,
-+                                  double *unaccel)
-+{
-+    if (valuator_mask_isset(mask, valuator)) {
-+        if (accel)
-+            *accel = valuator_mask_get_accelerated(mask, valuator);
-+        if (unaccel)
-+            *unaccel = valuator_mask_get_unaccelerated(mask, valuator);
-+        return TRUE;
-+    }
-+    else
-+        return FALSE;
-+}
-+
- int
- CountBits(const uint8_t * mask, int len)
- {
-diff --git a/hw/xfree86/common/xf86Module.h b/hw/xfree86/common/xf86Module.h
-index e68fe9c..6133641 100644
---- a/hw/xfree86/common/xf86Module.h
-+++ b/hw/xfree86/common/xf86Module.h
-@@ -81,7 +81,7 @@ typedef enum {
-  */
- #define ABI_ANSIC_VERSION	SET_ABI_VERSION(0, 4)
- #define ABI_VIDEODRV_VERSION	SET_ABI_VERSION(19, 0)
--#define ABI_XINPUT_VERSION	SET_ABI_VERSION(21, 0)
-+#define ABI_XINPUT_VERSION	SET_ABI_VERSION(21, 1)
- #define ABI_EXTENSION_VERSION	SET_ABI_VERSION(9, 0)
- #define ABI_FONT_VERSION	SET_ABI_VERSION(0, 6)
- 
-diff --git a/include/input.h b/include/input.h
-index bf22dc7..0a4c4f7 100644
---- a/include/input.h
-+++ b/include/input.h
-@@ -674,6 +674,21 @@ extern _X_EXPORT Bool valuator_mask_fetch(const ValuatorMask *mask,
- extern _X_EXPORT Bool valuator_mask_fetch_double(const ValuatorMask *mask,
-                                                  int valnum, double *val);
- 
-+extern _X_EXPORT Bool valuator_mask_has_unaccelerated(const ValuatorMask *mask);
-+extern _X_EXPORT void valuator_mask_set_unaccelerated(ValuatorMask *mask,
-+                                                      int valuator,
-+                                                      double accel,
-+                                                      double unaccel);
-+extern _X_EXPORT double valuator_mask_get_accelerated(const ValuatorMask *mask,
-+                                                      int valuator);
-+extern _X_EXPORT double valuator_mask_get_unaccelerated(const ValuatorMask *mask,
-+                                                        int valuator);
-+extern _X_EXPORT Bool valuator_mask_fetch_unaccelerated(const ValuatorMask *mask,
-+                                                        int valuator,
-+                                                        double *accel,
-+                                                        double *unaccel);
-+extern _X_HIDDEN void valuator_mask_drop_unaccelerated(ValuatorMask *mask);
-+
- /* InputOption handling interface */
- extern _X_EXPORT InputOption *input_option_new(InputOption *list,
-                                                const char *key,
-diff --git a/include/inpututils.h b/include/inpututils.h
-index 53c96ba..4e90815 100644
---- a/include/inpututils.h
-+++ b/include/inpututils.h
-@@ -36,8 +36,10 @@ extern Mask event_filters[MAXDEVICES][MAXEVENTS];
- 
- struct _ValuatorMask {
-     int8_t last_bit;            /* highest bit set in mask */
-+    int8_t has_unaccelerated;
-     uint8_t mask[(MAX_VALUATORS + 7) / 8];
-     double valuators[MAX_VALUATORS];    /* valuator data */
-+    double unaccelerated[MAX_VALUATORS];    /* valuator data */
- };
- 
- extern void verify_internal_event(const InternalEvent *ev);
--- 
-2.4.1
-
diff --git a/abs/core/xorg-server/0001-systemd-logind-do-not-rely-on-directed-signals.patch b/abs/core/xorg-server/0001-systemd-logind-do-not-rely-on-directed-signals.patch
new file mode 100644
index 0000000..9daadf6
--- /dev/null
+++ b/abs/core/xorg-server/0001-systemd-logind-do-not-rely-on-directed-signals.patch
@@ -0,0 +1,55 @@
+From 780a69aff0ff57ef813179a2f09556eaf488cdfc Mon Sep 17 00:00:00 2001
+From: David Herrmann <dh.herrmann@gmail.com>
+Date: Mon, 22 Jun 2015 21:13:05 +0200
+Subject: systemd-logind: do not rely on directed signals
+
+Right now, Xorg does not install DBus matches for "PauseDevice" /
+"ResumeDevice". Therefore, it should usually not receive those DBus
+signals from logind. It is just a coincidence that systemd-logind sends
+those signals in a directed manner right now. Therefore, dbus-daemon
+bypasses the broadcast matches.
+
+However, this is not ABI and Xorg should not rely on this. systemd-logind
+is free to send those signals as broadcasts, in which case Xorg will
+freeze the VT. Fix this by always installing those matches.
+
+Cc: Hans de Goede <hdegoede@redhat.com>
+Cc: Keith Packard <keithp@keithp.com>
+Reported-by: Jan Alexander Steffens <jan.steffens@gmail.com>
+Signed-off-by: David Herrmann <dh.herrmann@gmail.com>
+Reviewed-by: Hans de Goede <hdegoede@redhat.com>
+Tested-by: Hans de Goede <hdegoede@redhat.com>
+Signed-off-by: Hans de Goede <hdegoede@redhat.com>
+
+diff --git a/hw/xfree86/os-support/linux/systemd-logind.c b/hw/xfree86/os-support/linux/systemd-logind.c
+index 69e2f67..2612d9e 100644
+--- a/hw/xfree86/os-support/linux/systemd-logind.c
++++ b/hw/xfree86/os-support/linux/systemd-logind.c
+@@ -507,6 +507,24 @@ connect_hook(DBusConnection *connection, void *data)
+         goto cleanup;
+     }
+ 
++    dbus_bus_add_match(connection,
++        "type='signal',sender='org.freedesktop.login1',interface='org.freedesktop.login1.Session',member='PauseDevice'",
++        &error);
++    if (dbus_error_is_set(&error)) {
++        LogMessage(X_ERROR, "systemd-logind: could not add match: %s\n",
++                   error.message);
++        goto cleanup;
++    }
++
++    dbus_bus_add_match(connection,
++        "type='signal',sender='org.freedesktop.login1',interface='org.freedesktop.login1.Session',member='ResumeDevice'",
++        &error);
++    if (dbus_error_is_set(&error)) {
++        LogMessage(X_ERROR, "systemd-logind: could not add match: %s\n",
++                   error.message);
++        goto cleanup;
++    }
++
+     /*
+      * HdG: This is not useful with systemd <= 208 since the signal only
+      * contains invalidated property names there, rather than property, val
+-- 
+cgit v0.10.2
+
diff --git a/abs/core/xorg-server/0002-dix-hook-up-the-unaccelerated-valuator-masks.patch b/abs/core/xorg-server/0002-dix-hook-up-the-unaccelerated-valuator-masks.patch
deleted file mode 100644
index 6b8b1e5..0000000
--- a/abs/core/xorg-server/0002-dix-hook-up-the-unaccelerated-valuator-masks.patch
+++ /dev/null
@@ -1,134 +0,0 @@
-From 7504fbd2239257f1a00a1a15d02862eea81f167c Mon Sep 17 00:00:00 2001
-From: Peter Hutterer <peter.hutterer@who-t.net>
-Date: Tue, 5 May 2015 14:48:41 +1000
-Subject: [PATCH] dix: hook up the unaccelerated valuator masks
-
-If present, access the unaccelerated valuator mask values for DGA and XI2 raw
-events.
-
-Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-Reviewed-by: Hans de Goede <hdegoede@redhat.com>
----
- dix/getevents.c                | 31 ++++++++++++++++++++++---------
- hw/xfree86/common/xf86Xinput.c |  4 ++++
- 2 files changed, 26 insertions(+), 9 deletions(-)
-
-diff --git a/dix/getevents.c b/dix/getevents.c
-index 6fb12c5..64bf76e 100644
---- a/dix/getevents.c
-+++ b/dix/getevents.c
-@@ -213,14 +213,25 @@ init_raw(DeviceIntPtr dev, RawDeviceEvent *event, Time ms, int type, int detail)
- }
- 
- static void
--set_raw_valuators(RawDeviceEvent *event, ValuatorMask *mask, double *data)
-+set_raw_valuators(RawDeviceEvent *event, ValuatorMask *mask,
-+                  BOOL use_unaccel, double *data)
- {
-     int i;
- 
-+    use_unaccel = use_unaccel && valuator_mask_has_unaccelerated(mask);
-+
-     for (i = 0; i < valuator_mask_size(mask); i++) {
-         if (valuator_mask_isset(mask, i)) {
-+            double v;
-+
-             SetBit(event->valuators.mask, i);
--            data[i] = valuator_mask_get_double(mask, i);
-+
-+            if (use_unaccel)
-+                v = valuator_mask_get_unaccelerated(mask, i);
-+            else
-+                v = valuator_mask_get_double(mask, i);
-+
-+            data[i] = v;
-         }
-     }
- }
-@@ -1138,11 +1149,11 @@ GetKeyboardEvents(InternalEvent *events, DeviceIntPtr pDev, int type,
-     valuator_mask_copy(&mask, mask_in);
- 
-     init_raw(pDev, raw, ms, type, key_code);
--    set_raw_valuators(raw, &mask, raw->valuators.data_raw);
-+    set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
- 
-     clipValuators(pDev, &mask);
- 
--    set_raw_valuators(raw, &mask, raw->valuators.data);
-+    set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
- 
-     event = &events->device_event;
-     init_device_event(event, pDev, ms);
-@@ -1423,9 +1434,11 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
-         num_events++;
- 
-         init_raw(pDev, raw, ms, type, buttons);
--        set_raw_valuators(raw, &mask, raw->valuators.data_raw);
-+        set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
-     }
- 
-+    valuator_mask_drop_unaccelerated(&mask);
-+
-     /* valuators are in driver-native format (rel or abs) */
- 
-     if (flags & POINTER_ABSOLUTE) {
-@@ -1438,7 +1451,7 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
-         transformAbsolute(pDev, &mask);
-         clipAbsolute(pDev, &mask);
-         if ((flags & POINTER_NORAW) == 0 && raw)
--            set_raw_valuators(raw, &mask, raw->valuators.data);
-+            set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
-     }
-     else {
-         transformRelative(pDev, &mask);
-@@ -1446,7 +1459,7 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
-         if (flags & POINTER_ACCELERATE)
-             accelPointer(pDev, &mask, ms);
-         if ((flags & POINTER_NORAW) == 0 && raw)
--            set_raw_valuators(raw, &mask, raw->valuators.data);
-+            set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
- 
-         moveRelative(pDev, flags, &mask);
-     }
-@@ -1951,7 +1964,7 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid,
-         events++;
-         num_events++;
-         init_raw(dev, raw, ms, type, client_id);
--        set_raw_valuators(raw, &mask, raw->valuators.data_raw);
-+        set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
-     }
- 
-     event = &events->device_event;
-@@ -2013,7 +2026,7 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid,
-         screeny = dev->spriteInfo->sprite->hotPhys.y;
-     }
-     if (need_rawevent)
--        set_raw_valuators(raw, &mask, raw->valuators.data);
-+        set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
- 
-     /* Indirect device touch coordinates are not used for cursor positioning.
-      * They are merely informational, and are provided in device coordinates.
-diff --git a/hw/xfree86/common/xf86Xinput.c b/hw/xfree86/common/xf86Xinput.c
-index 1fb5b16..5ce4c71 100644
---- a/hw/xfree86/common/xf86Xinput.c
-+++ b/hw/xfree86/common/xf86Xinput.c
-@@ -1137,12 +1137,16 @@ xf86CheckMotionEvent4DGA(DeviceIntPtr device, int is_absolute,
-                 dx = valuator_mask_get(mask, 0);
-                 if (is_absolute)
-                     dx -= device->last.valuators[0];
-+                else if (valuator_mask_has_unaccelerated(mask))
-+                    dx = valuator_mask_get_unaccelerated(mask, 0);
-             }
- 
-             if (valuator_mask_isset(mask, 1)) {
-                 dy = valuator_mask_get(mask, 1);
-                 if (is_absolute)
-                     dy -= device->last.valuators[1];
-+                else if (valuator_mask_has_unaccelerated(mask))
-+                    dy = valuator_mask_get_unaccelerated(mask, 1);
-             }
- 
-             if (DGAStealMotionEvent(device, idx, dx, dy))
--- 
-2.4.1
-
diff --git a/abs/core/xorg-server/PKGBUILD b/abs/core/xorg-server/PKGBUILD
index f84da16..7f0e9d5 100644
--- a/abs/core/xorg-server/PKGBUILD
+++ b/abs/core/xorg-server/PKGBUILD
@@ -4,10 +4,11 @@
 
 pkgbase=xorg-server
 pkgname=('xorg-server' 'xorg-server-xephyr' 'xorg-server-xdmx' 'xorg-server-xvfb' 'xorg-server-xnest' 'xorg-server-xwayland' 'xorg-server-common' 'xorg-server-devel')
-pkgver=1.17.2
-pkgrel=1 # build first with 0.1 and then rebuild it after xf86-input-evdev rebuild
+pkgver=1.18.0
+pkgrel=4
 arch=('i686' 'x86_64')
 license=('custom')
+groups=('xorg')
 url="http://xorg.freedesktop.org"
 makedepends=('pixman' 'libx11' 'mesa' 'mesa-libgl' 'xf86driproto' 'xcmiscproto' 'xtrans' 'bigreqsproto' 'randrproto' 
              'inputproto' 'fontsproto' 'videoproto' 'presentproto' 'compositeproto' 'recordproto' 'scrnsaverproto'
@@ -15,36 +16,33 @@ makedepends=('pixman' 'libx11' 'mesa' 'mesa-libgl' 'xf86driproto' 'xcmiscproto'
              'xf86dgaproto' 'libxmu' 'libxrender' 'libxi' 'dmxproto' 'libxaw' 'libdmx' 'libxtst' 'libxres'
              'xorg-xkbcomp' 'xorg-util-macros' 'xorg-font-util' 'glproto' 'dri2proto' 'libgcrypt' 'libepoxy'
              'xcb-util' 'xcb-util-image' 'xcb-util-renderutil' 'xcb-util-wm' 'xcb-util-keysyms' 'dri3proto'
-             'libxshmfence' 'libunwind') 
+             'libxshmfence' 'libunwind')
 source=(${url}/releases/individual/xserver/${pkgbase}-${pkgver}.tar.bz2{,.sig}
-        nvidia-drm-outputclass.conf
         xvfb-run
         xvfb-run.1
-        0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch
-        0002-dix-hook-up-the-unaccelerated-valuator-masks.patch
+        0001-systemd-logind-do-not-rely-on-directed-signals.patch
+        v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch
+        xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch
         Xwrapper.config)
 validpgpkeys=('7B27A3F1A6E18CD9588B4AE8310180050905E40C'
               'C383B778255613DFDB409D91DB221A6900000011'
               'DD38563A8A8224537D1F90E45B8A2D50A0ECD0D3')
-sha256sums=('f61120612728f2c5034671d0ca3e2273438c60aba93b3dda4a8aa40e6a257993'
-            'SKIP'
-            'af1c3d2ea5de7f6a6b5f7c60951a189a4749d1495e5462f3157ae7ac8fe1dc56'
-            'ff0156309470fc1d378fd2e104338020a884295e285972cc88e250e031cc35b9'
-            '2460adccd3362fefd4cdc5f1c70f332d7b578091fb9167bf88b5f91265bbd776'
-            '3dc795002b8763a7d29db94f0af200131da9ce5ffc233bfd8916060f83a8fad7'
-            '416a1422eed71efcebb1d893de74e7f27e408323a56c4df003db37f5673b3f96'
-            'SKIP')
 
 prepare() {
   cd "${pkgbase}-${pkgver}"
-  # fix FS#45229, merged upstream
-  patch -Np1 -i ../0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch
-  patch -Np1 -i ../0002-dix-hook-up-the-unaccelerated-valuator-masks.patch
+  # fix VT switching with kdbus; from upstream
+  patch -Np1 -i ../0001-systemd-logind-do-not-rely-on-directed-signals.patch
+
+  # fix xorg only working with root FS#47061
+  patch -Np1 -i ../v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch
+  # disable debugging glamor messages in xorg log file
+  patch -Np1 -i ../xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch
+
+  autoreconf -fvi
 }
 
 build() {
   cd "${pkgbase}-${pkgver}"
-  autoreconf -fi
   ./configure --prefix=/usr \
       --enable-ipv6 \
       --enable-dri \
@@ -58,9 +56,7 @@ build() {
       --enable-xephyr \
       --enable-glamor \
       --enable-xwayland \
-      --enable-glx-tls \
       --enable-kdrive \
-      --enable-kdrive-evdev \
       --enable-kdrive-kbd \
       --enable-kdrive-mouse \
       --enable-config-udev \
@@ -113,22 +109,21 @@ package_xorg-server-common() {
 
 package_xorg-server() {
   pkgdesc="Xorg X server"
-  depends=(libepoxy libxdmcp libxfont libpciaccess libdrm pixman libgcrypt libxau xorg-server-common xf86-input-evdev libxshmfence libgl)
+  depends=(libepoxy libxdmcp libxfont libpciaccess libdrm pixman libgcrypt libxau xorg-server-common libxshmfence libgl xf86-input-driver)
+
   # see xorg-server-*/hw/xfree86/common/xf86Module.h for ABI versions - we provide major numbers that drivers can depend on
   # and /usr/lib/pkgconfig/xorg-server.pc in xorg-server-devel pkg
-  provides=('X-ABI-VIDEODRV_VERSION=19' 'X-ABI-XINPUT_VERSION=21.1' 'X-ABI-EXTENSION_VERSION=9.0' 'x-server')
-  groups=('xorg')
+  provides=('X-ABI-VIDEODRV_VERSION=20' 'X-ABI-XINPUT_VERSION=22.1' 'X-ABI-EXTENSION_VERSION=9.0' 'x-server')
   conflicts=('nvidia-utils<=331.20' 'glamor-egl' 'xf86-video-modesetting')
   replaces=('glamor-egl' 'xf86-video-modesetting')
   install=xorg-server.install
 
   cd "${pkgbase}-${pkgver}"
   make DESTDIR="${pkgdir}" install
-
+  
   # distro specific files must be installed in /usr/share/X11/xorg.conf.d
   install -m755 -d "${pkgdir}/etc/X11/xorg.conf.d"
-  install -m644 "${srcdir}/nvidia-drm-outputclass.conf" "${pkgdir}/usr/share/X11/xorg.conf.d/"
-
+  
   # LinHES Xwrapper.config
   install -m644 "${srcdir}/Xwrapper.config" "${pkgdir}/etc/X11/Xwrapper.config"
 
@@ -232,3 +227,11 @@ package_xorg-server-devel() {
   install -m755 -d "${pkgdir}/usr/share/licenses/xorg-server-devel"
   ln -sf ../xorg-server-common/COPYING "${pkgdir}/usr/share/licenses/xorg-server-devel/COPYING"
 }
+md5sums=('3c1c1057d3ad27380d8dd87ffcc182cd'
+         'SKIP'
+         '52fd3effd80d7bc6c1660d4ecf23d31c'
+         '376c70308715cd2643f7bff936d9934b'
+         'bea02fd837ba756456bf14ed51ff36c8'
+         'ea8214d68150f3819eb049326b275f43'
+         'dc9eda462a8d83413d3edd2e7b9669f6'
+         'e3d31449c79ce49a748a678463ea3f20')
diff --git a/abs/core/xorg-server/autoconfig-sis.patch b/abs/core/xorg-server/autoconfig-sis.patch
deleted file mode 100644
index 0b50049..0000000
--- a/abs/core/xorg-server/autoconfig-sis.patch
+++ /dev/null
@@ -1,21 +0,0 @@
---- hw/xfree86/common/xf86pciBus.c.orig	2011-09-24 10:53:45.421697668 +0000
-+++ hw/xfree86/common/xf86pciBus.c	2011-09-24 10:55:56.416250708 +0000
-@@ -1200,9 +1200,15 @@
-             break;
-         }
-         break;
--    case 0x1039:
--        driverList[0] = "sis";
--        break;
-+	case 0x1039:
-+	    switch (dev->device_id)
-+	    {
-+		case 0x6350: case 0x6351:
-+		    driverList[0] = "sisimedia"; driverList[1] = "sis"; break;
-+		default:
-+		    driverList[0] = "sis"; break;
-+	    }
-+	    break;
-     case 0x126f:
-         driverList[0] = "siliconmotion";
-         break;
diff --git a/abs/core/xorg-server/nvidia-drm-outputclass.conf b/abs/core/xorg-server/nvidia-drm-outputclass.conf
deleted file mode 100644
index 40c1e08..0000000
--- a/abs/core/xorg-server/nvidia-drm-outputclass.conf
+++ /dev/null
@@ -1,6 +0,0 @@
-Section "OutputClass"
-	Identifier "nvidia"
-	MatchDriver "nvidia-drm"
-	Driver "nvidia"
-EndSection
-
diff --git a/abs/core/xorg-server/v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch b/abs/core/xorg-server/v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch
new file mode 100644
index 0000000..220c5bb
--- /dev/null
+++ b/abs/core/xorg-server/v2-Xorg.wrap-activate-libdrm-based-detection-for-KMS-drivers.patch
@@ -0,0 +1,12 @@
+diff --git a/hw/xfree86/xorg-wrapper.c b/hw/xfree86/xorg-wrapper.c
+index 4c37cfc..d930962 100644
+--- a/hw/xfree86/xorg-wrapper.c
++++ b/hw/xfree86/xorg-wrapper.c
+@@ -24,6 +24,7 @@
+  */
+ 
+ #include "dix-config.h"
++#include "xorg-config.h"
+ 
+ #include <errno.h>
+ #include <fcntl.h>
diff --git a/abs/core/xorg-server/xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch b/abs/core/xorg-server/xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch
new file mode 100644
index 0000000..41a67c7
--- /dev/null
+++ b/abs/core/xorg-server/xserver-glamor-Disable-debugging-messages-other-than-GL-API-errors.patch
@@ -0,0 +1,14 @@
+diff --git a/glamor/glamor.c b/glamor/glamor.c
+index 116d10c..81aba2d 100644
+--- a/glamor/glamor.c
++++ b/glamor/glamor.c
+@@ -393,6 +393,9 @@ glamor_setup_debug_output(ScreenPtr screen)
+         return;
+ 
+     glEnable(GL_DEBUG_OUTPUT_SYNCHRONOUS);
++    /* Disable debugging messages other than GL API errors */
++    glDebugMessageControl(GL_DONT_CARE, GL_DONT_CARE, GL_DONT_CARE, 0, NULL,
++                          GL_FALSE);
+     glDebugMessageControl(GL_DEBUG_SOURCE_API,
+                           GL_DEBUG_TYPE_ERROR,
+                           GL_DONT_CARE,
-- 
cgit v0.12