From 05749da7a684288c6ffcc7d0d3fbada22ba80d06 Mon Sep 17 00:00:00 2001 From: Peter Hutterer Date: Sun, 1 Jun 2008 15:20:42 +0930 Subject: [PATCH] xkb: delete default rules when devices are closed #16167 We only have one set of default rules options in xkb. When the second keyboard is brought up with Xkb options specified, these new options overwrite the old. In future server generations, the rules used for the VCK are a mixture of the default ones and ones previously specified for other keyboards. Simply resetting the xkb default rules to NULL avoids this issue. Reproducable by setting XkbLayout "de" and XkbVariant "nodeadkeys". In the second server generation, the VCK has "us(nodeadkeys)". This again produces a SIGABRT when the first key is hit. I could not figure out why the SIGABRT happens. This patch is avoiding the issue rather than fixing it. X.Org Bug 16167 --- dix/devices.c | 3 +++ include/xkbsrv.h | 4 ++++ xkb/xkbInit.c | 15 +++++++++++++++ 3 files changed, 22 insertions(+), 0 deletions(-) diff --git a/dix/devices.c b/dix/devices.c index 08520eb..efdc0c9 100644 --- a/dix/devices.c +++ b/dix/devices.c @@ -847,6 +847,9 @@ CloseDownDevices(void) inputInfo.off_devices = NULL; inputInfo.keyboard = NULL; inputInfo.pointer = NULL; +#ifdef XKB + XkbDeleteRulesDflts(); +#endif } /** diff --git a/include/xkbsrv.h b/include/xkbsrv.h index 7db9eef..e2fff4e 100644 --- a/include/xkbsrv.h +++ b/include/xkbsrv.h @@ -899,6 +899,10 @@ extern void XkbSetRulesDflts( char * /* options */ ); +extern void XkbDeleteRulesDflts( + void +); + extern void XkbInitDevice( DeviceIntPtr /* pXDev */ ); diff --git a/xkb/xkbInit.c b/xkb/xkbInit.c index 0d5d15e..e815721 100644 --- a/xkb/xkbInit.c +++ b/xkb/xkbInit.c @@ -279,6 +279,21 @@ XkbSetRulesDflts(char *rulesFile,char *model,char *layout, return; } +_X_EXPORT void +XkbDeleteRulesDflts() +{ + _XkbFree(XkbRulesFile); + XkbRulesFile = NULL; + _XkbFree(XkbModelDflt); + XkbModelDflt = NULL; + _XkbFree(XkbLayoutDflt); + XkbLayoutDflt = NULL; + _XkbFree(XkbVariantDflt); + XkbVariantDflt = NULL; + _XkbFree(XkbOptionsDflt); + XkbOptionsDflt = NULL; +} + /***====================================================================***/ #include "xkbDflts.h" -- 1.5.4.1