diff -ruN /var/abs/extra/x11/xorg-server/PKGBUILD /var/abs/local/xorg-server/PKGBUILD --- /var/abs/extra/x11/xorg-server/PKGBUILD 2007-11-06 15:28:08.000000000 +0100 +++ /var/abs/local/xorg-server/PKGBUILD 2007-11-06 20:59:28.000000000 +0100 @@ -31,7 +31,8 @@ xorg-server-1.2.0-defaultdpi.patch xorg-x11-server-1.1.1-no-scanpci.patch xserver-1.3.0-newglx-offscreen-pixmaps.patch - xorg-server-1.4-kbd-leds-fix.patch) + xorg-server-1.4-kbd-leds-fix.patch + xorg-server-1.4-mapping-changes-for-all.patch) build() { cd ${startdir}/src/${pkgname}-${pkgver} @@ -48,6 +49,7 @@ # Own patches patch -Np1 -i ${startdir}/src/xorg-server-1.2.0-defaultdpi.patch || return 1 + patch -Np1 -i ${startdir}/src/xorg-server-1.4-mapping-changes-for-all.patch || return 1 aclocal autoconf @@ -103,4 +105,5 @@ 'e162134c68230f7b168430fe73b4881a' '43257d8ade0f087870426eca1f09005c' '0241d51f94de450845531b4df2af2527' - '958d907381f0df253668a5d9473d1adf') + '958d907381f0df253668a5d9473d1adf' + '4b744e3ccebbeb1420b6f8e04daca532') diff -ruN /var/abs/extra/x11/xorg-server/xorg-server-1.4-mapping-changes-for-all.patch /var/abs/local/xorg-server/xorg-server-1.4-mapping-changes-for-all.patch --- /var/abs/extra/x11/xorg-server/xorg-server-1.4-mapping-changes-for-all.patch 1970-01-01 01:00:00.000000000 +0100 +++ /var/abs/local/xorg-server/xorg-server-1.4-mapping-changes-for-all.patch 2007-11-06 20:54:38.000000000 +0100 @@ -0,0 +1,155 @@ +commit 27ad5d74c20f01516a1bff73be283f8982fcf0fe +Author: Daniel Stone +Date: Sun Sep 23 17:17:03 2007 +0300 + + Input: Generate XKB mapping changes for all core-sending devices (bug #12523) + + When we change the mapping on a core device, make sure we propagate this + through to XKB for all extended devices as well. + +diff --git a/Xi/exevents.c b/Xi/exevents.c +index fe297ab..377311e 100644 +--- a/Xi/exevents.c ++++ b/Xi/exevents.c +@@ -73,6 +73,10 @@ SOFTWARE. + #include "dixgrabs.h" /* CreateGrab() */ + #include "scrnintstr.h" + ++#ifdef XKB ++#include "xkbsrv.h" ++#endif ++ + #define WID(w) ((w) ? ((w)->drawable.id) : 0) + #define AllModifiersMask ( \ + ShiftMask | LockMask | ControlMask | Mod1Mask | Mod2Mask | \ +@@ -942,7 +946,7 @@ SetModifierMapping(ClientPtr client, DeviceIntPtr dev, int len, int rlen, + } + + void +-SendDeviceMappingNotify(CARD8 request, ++SendDeviceMappingNotify(ClientPtr client, CARD8 request, + KeyCode firstKeyCode, CARD8 count, DeviceIntPtr dev) + { + xEvent event; +@@ -957,6 +961,11 @@ SendDeviceMappingNotify(CARD8 request, + ev->count = count; + } + ++#ifdef XKB ++ if (request == MappingKeyboard || request == MappingModifier) ++ XkbApplyMappingChange(dev, request, firstKeyCode, count, client); ++#endif ++ + SendEventToAllWindows(dev, DeviceMappingNotifyMask, (xEvent *) ev, 1); + } + +@@ -992,7 +1001,7 @@ ChangeKeyMapping(ClientPtr client, + keysyms.map = map; + if (!SetKeySymsMap(&k->curKeySyms, &keysyms)) + return BadAlloc; +- SendDeviceMappingNotify(MappingKeyboard, firstKeyCode, keyCodes, dev); ++ SendDeviceMappingNotify(client, MappingKeyboard, firstKeyCode, keyCodes, dev); + return client->noClientException; + } + +diff --git a/Xi/setbmap.c b/Xi/setbmap.c +index bdfa513..1f5970d 100644 +--- a/Xi/setbmap.c ++++ b/Xi/setbmap.c +@@ -134,7 +134,7 @@ ProcXSetDeviceButtonMapping(ClientPtr client) + } + + if (ret != MappingBusy) +- SendDeviceMappingNotify(MappingPointer, 0, 0, dev); ++ SendDeviceMappingNotify(client, MappingPointer, 0, 0, dev); + return Success; + } + +diff --git a/Xi/setmmap.c b/Xi/setmmap.c +index 0078499..e30213e 100644 +--- a/Xi/setmmap.c ++++ b/Xi/setmmap.c +@@ -122,7 +122,7 @@ ProcXSetDeviceModifierMapping(ClientPtr client) + if (ret == MappingSuccess || ret == MappingBusy || ret == MappingFailed) { + rep.success = ret; + if (ret == MappingSuccess) +- SendDeviceMappingNotify(MappingModifier, 0, 0, dev); ++ SendDeviceMappingNotify(client, MappingModifier, 0, 0, dev); + WriteReplyToClient(client, sizeof(xSetDeviceModifierMappingReply), + &rep); + } else { +diff --git a/dix/devices.c b/dix/devices.c +index 9f3c576..e05444e 100644 +--- a/dix/devices.c ++++ b/dix/devices.c +@@ -1208,10 +1208,9 @@ SendMappingNotify(unsigned request, unsigned firstKeyCode, unsigned count, + } + #ifdef XKB + if (!noXkbExtension && +- ((request == MappingKeyboard) || (request == MappingModifier))) { +- XkbApplyMappingChange(inputInfo.keyboard,request,firstKeyCode,count, +- client); +- } ++ ((request == MappingKeyboard) || (request == MappingModifier))) ++ XkbApplyMappingChange(inputInfo.keyboard, request, firstKeyCode, count, ++ client); + #endif + + /* 0 is the server client */ +@@ -1359,6 +1358,7 @@ int + ProcSetModifierMapping(ClientPtr client) + { + xSetModifierMappingReply rep; ++ DeviceIntPtr dev; + REQUEST(xSetModifierMappingReq); + + REQUEST_AT_LEAST_SIZE(xSetModifierMappingReq); +@@ -1374,8 +1374,10 @@ ProcSetModifierMapping(ClientPtr client) + rep.success = DoSetModifierMapping(client, (KeyCode *)&stuff[1], + stuff->numKeyPerModifier); + +- /* FIXME: Send mapping notifies for all the extended devices as well. */ + SendMappingNotify(MappingModifier, 0, 0, client); ++ for (dev = inputInfo.devices; dev; dev = dev->next) ++ if (dev->key && dev->coreEvents) ++ SendDeviceMappingNotify(client, MappingModifier, 0, 0, dev); + WriteReplyToClient(client, sizeof(xSetModifierMappingReply), &rep); + return client->noClientException; + } +@@ -1438,16 +1440,19 @@ ProcChangeKeyboardMapping(ClientPtr client) + keysyms.maxKeyCode = stuff->firstKeyCode + stuff->keyCodes - 1; + keysyms.mapWidth = stuff->keySymsPerKeyCode; + keysyms.map = (KeySym *)&stuff[1]; +- for (pDev = inputInfo.devices; pDev; pDev = pDev->next) { +- if ((pDev->coreEvents || pDev == inputInfo.keyboard) && pDev->key) { ++ for (pDev = inputInfo.devices; pDev; pDev = pDev->next) ++ if ((pDev->coreEvents || pDev == inputInfo.keyboard) && pDev->key) + if (!SetKeySymsMap(&pDev->key->curKeySyms, &keysyms)) + return BadAlloc; +- } +- } + +- /* FIXME: Send mapping notifies for all the extended devices as well. */ + SendMappingNotify(MappingKeyboard, stuff->firstKeyCode, stuff->keyCodes, + client); ++ for (pDev = inputInfo.devices; pDev; pDev = pDev->next) ++ if (pDev->key && pDev->coreEvents) ++ SendDeviceMappingNotify(client, MappingKeyboard, ++ stuff->firstKeyCode, stuff->keyCodes, ++ pDev); ++ + return client->noClientException; + } + +diff --git a/include/exevents.h b/include/exevents.h +index 69d4abc..cf7d71a 100644 +--- a/include/exevents.h ++++ b/include/exevents.h +@@ -129,6 +129,7 @@ extern int SetModifierMapping( + KeyClassPtr * /* k */); + + extern void SendDeviceMappingNotify( ++ ClientPtr /* client, */, + CARD8 /* request, */, + KeyCode /* firstKeyCode */, + CARD8 /* count */,