[PATCH:xf86-input-keyboard 07/21] Add translation table for AT/PS2 pseudo XT scancodes.

walter harms wharms at bfs.de
Sat Jul 27 02:27:59 PDT 2013



Am 26.07.2013 23:24, schrieb Thomas Klausner:
> Add another translation table to make the modular kbd driver cope with NetBSD's
> AT/PS2 pseudo XT scancodes. Tested on shark and sgimips with an IBM Model M -
> this should be tested with more keyboards, there might still be errors in the
> table.
> 
> From Michael Lorenz <macallan at NetBSD.org>
> Signed-off-by: Thomas Klausner <wiz at NetBSD.org>
> ---
>  src/bsd_KbdMap.c | 235 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-
>  1 file changed, 234 insertions(+), 1 deletion(-)
> 
> diff --git a/src/bsd_KbdMap.c b/src/bsd_KbdMap.c
> index b994c05..0d710f0 100644
> --- a/src/bsd_KbdMap.c
> +++ b/src/bsd_KbdMap.c
> @@ -452,6 +452,239 @@ TransMapRec wsUsb = {
>      wsUsbMap
>  };
>  
> +static CARD8 wsXtMap[] = {
> +	/* 0 */ KEY_NOTUSED,
> +	/* 1 */ KEY_Escape,
> +	/* 2 */ KEY_1,
> +	/* 3 */ KEY_2,
> +	/* 4 */ KEY_3,		
> +	/* 5 */ KEY_4,
> +	/* 6 */ KEY_5,
> +	/* 7 */ KEY_6,
> +	/* 8 */ KEY_7,
> +	/* 9 */ KEY_8,
> +	/* 10 */ KEY_9,
> +	/* 11 */ KEY_0,
> +	/* 12 */ KEY_Minus,
> +	/* 13 */ KEY_Equal,
> +	/* 14 */ KEY_BackSpace,
> +	/* 15 */ KEY_Tab,
> +	/* 16 */ KEY_Q,
> +	/* 17 */ KEY_W,
> +	/* 18 */ KEY_E,
> +	/* 19 */ KEY_R,
> +	/* 20 */ KEY_T,
> +	/* 21 */ KEY_Y,
> +	/* 22 */ KEY_U,
> +	/* 23 */ KEY_I,
> +	/* 24 */ KEY_O,
> +	/* 25 */ KEY_P,
> +	/* 26 */ KEY_LBrace,
> +	/* 27 */ KEY_RBrace,
> +	/* 28 */ KEY_Enter,
> +	/* 29 */ KEY_LCtrl,
> +	/* 30 */ KEY_A,
> +	/* 31 */ KEY_S,
> +	/* 32 */ KEY_D,
> +	/* 33 */ KEY_F,
> +	/* 34 */ KEY_G,
> +	/* 35 */ KEY_H,
> +	/* 36 */ KEY_J,
> +	/* 37 */ KEY_K,
> +	/* 38 */ KEY_L,
> +	/* 39 */ KEY_SemiColon,
> +	/* 40 */ KEY_Quote,
> +	/* 41 */ KEY_Tilde,
> +	/* 42 */ KEY_ShiftL,
> +	/* 43 */ KEY_BSlash,
> +	/* 44 */ KEY_Z,
> +	/* 45 */ KEY_X,
> +	/* 46 */ KEY_C,
> +	/* 47 */ KEY_V,
> +	/* 48 */ KEY_B,
> +	/* 49 */ KEY_N,
> +	/* 50 */ KEY_M,
> +	/* 51 */ KEY_Comma,
> +	/* 52 */ KEY_Period,
> +	/* 53 */ KEY_Slash,
> +	/* 54 */ KEY_ShiftR,
> +	/* 55 */ KEY_KP_Multiply,
> +	/* 56 */ KEY_Alt,
> +	/* 57 */ KEY_Space,
> +	/* 58 */ KEY_CapsLock,
> +	/* 59 */ KEY_F1,
> +	/* 60 */ KEY_F2,
> +	/* 61 */ KEY_F3,
> +	/* 62 */ KEY_F4,
> +	/* 63 */ KEY_F5,
> +	/* 64 */ KEY_F6,
> +	/* 65 */ KEY_F7,
> +	/* 66 */ KEY_F8,
> +	/* 67 */ KEY_F9,
> +	/* 68 */ KEY_F10,
> +	/* 69 */ KEY_NumLock,
> +	/* 70 */ KEY_ScrollLock,
> +	/* 71 */ KEY_KP_7,
> +	/* 72 */ KEY_KP_8,
> +	/* 73 */ KEY_KP_9,
> +	/* 74 */ KEY_KP_Minus,
> +	/* 75 */ KEY_KP_4,
> +	/* 76 */ KEY_KP_5,
> +	/* 77 */ KEY_KP_6,
> +	/* 78 */ KEY_KP_Plus,
> +	/* 79 */ KEY_KP_1,
> +	/* 80 */ KEY_KP_2,
> +	/* 81 */ KEY_KP_3,
> +	/* 82 */ KEY_KP_0,
> +	/* 83 */ KEY_KP_Decimal,
> +	/* 84 */ KEY_NOTUSED,
> +	/* 85 */ KEY_NOTUSED,
> +	/* 86 */ KEY_Less,	/* backslash on uk, < on german */
> +	/* 87 */ KEY_F11,
> +	/* 88 */ KEY_F12,
> +	/* 89 */ KEY_NOTUSED,
> +	/* 90 */ KEY_NOTUSED,
> +	/* 91 */ KEY_NOTUSED,
> +	/* 92 */ KEY_NOTUSED,
> +	/* 93 */ KEY_NOTUSED,
> +	/* 94 */ KEY_NOTUSED,
> +	/* 95 */ KEY_NOTUSED,
> +	/* 96 */ KEY_NOTUSED,
> +	/* 97 */ KEY_NOTUSED,
> +	/* 98 */ KEY_NOTUSED,
> +	/* 99 */ KEY_NOTUSED,
> +	/* 100 */ KEY_NOTUSED,
> +	/* 101 */ KEY_NOTUSED,
> +	/* 102 */ KEY_NOTUSED,
> +	/* 103 */ KEY_NOTUSED,
> +	/* 104 */ KEY_NOTUSED,
> +	/* 105 */ KEY_NOTUSED,
> +	/* 106 */ KEY_NOTUSED,
> +	/* 107 */ KEY_NOTUSED,
> +	/* 108 */ KEY_NOTUSED,
> +	/* 109 */ KEY_NOTUSED,
> +	/* 110 */ KEY_NOTUSED,
> +	/* 111 */ KEY_NOTUSED,
> +	/* 112 */ KEY_NOTUSED,
> +	/* 113 */ KEY_NOTUSED,
> +	/* 114 */ KEY_NOTUSED,
> +	/* 115 */ KEY_NOTUSED,
> +	/* 116 */ KEY_NOTUSED,
> +	/* 117 */ KEY_NOTUSED,
> +	/* 118 */ KEY_NOTUSED,
> +	/* 119 */ KEY_NOTUSED,
> +	/* 120 */ KEY_NOTUSED,
> +	/* 121 */ KEY_NOTUSED,
> +	/* 122 */ KEY_NOTUSED,
> +	/* 123 */ KEY_NOTUSED,
> +	/* 124 */ KEY_NOTUSED,
> +	/* 125 */ KEY_NOTUSED,
> +	/* 126 */ KEY_NOTUSED,
> +	/* 127 */ KEY_Pause,
> +	/* 128 */ KEY_NOTUSED,
> +	/* 129 */ KEY_NOTUSED,
> +	/* 130 */ KEY_NOTUSED,
> +	/* 131 */ KEY_NOTUSED,
> +	/* 132 */ KEY_NOTUSED,
> +	/* 133 */ KEY_NOTUSED,
> +	/* 134 */ KEY_NOTUSED,
> +	/* 135 */ KEY_NOTUSED,
> +	/* 136 */ KEY_NOTUSED,
> +	/* 137 */ KEY_NOTUSED,
> +	/* 138 */ KEY_NOTUSED,
> +	/* 139 */ KEY_NOTUSED,
> +	/* 140 */ KEY_NOTUSED,
> +	/* 141 */ KEY_NOTUSED,
> +	/* 142 */ KEY_NOTUSED,
> +	/* 143 */ KEY_NOTUSED,
> +	/* 144 */ KEY_NOTUSED,
> +	/* 145 */ KEY_NOTUSED,
> +	/* 146 */ KEY_NOTUSED,
> +	/* 147 */ KEY_NOTUSED,
> +	/* 148 */ KEY_NOTUSED,
> +	/* 149 */ KEY_NOTUSED,
> +	/* 150 */ KEY_NOTUSED,
> +	/* 151 */ KEY_NOTUSED,
> +	/* 152 */ KEY_NOTUSED,
> +	/* 153 */ KEY_NOTUSED,
> +	/* 154 */ KEY_NOTUSED,
> +	/* 155 */ KEY_NOTUSED,
> +	/* 156 */ KEY_KP_Enter,
> +	/* 157 */ KEY_RCtrl,
> +	/* 158 */ KEY_NOTUSED,
> +	/* 159 */ KEY_NOTUSED,
> +	/* 160 */ KEY_Mute,
> +	/* 161 */ KEY_NOTUSED,
> +	/* 162 */ KEY_NOTUSED,
> +	/* 163 */ KEY_NOTUSED,
> +	/* 164 */ KEY_NOTUSED,
> +	/* 165 */ KEY_NOTUSED,
> +	/* 166 */ KEY_NOTUSED,
> +	/* 167 */ KEY_NOTUSED,
> +	/* 168 */ KEY_NOTUSED,
> +	/* 169 */ KEY_NOTUSED,
> +	/* 170 */ KEY_Print,
> +	/* 171 */ KEY_NOTUSED,
> +	/* 172 */ KEY_NOTUSED,
> +	/* 173 */ KEY_NOTUSED,
> +	/* 174 */ KEY_AudioLower,
> +	/* 175 */ KEY_AudioRaise,
> +	/* 176 */ KEY_NOTUSED,
> +	/* 177 */ KEY_NOTUSED,
> +	/* 178 */ KEY_NOTUSED,
> +	/* 179 */ KEY_NOTUSED,
> +	/* 180 */ KEY_NOTUSED,
> +	/* 181 */ KEY_KP_Divide,
> +	/* 182 */ KEY_NOTUSED,
> +	/* 183 */ KEY_Print,
> +	/* 184 */ KEY_AltLang,
> +	/* 185 */ KEY_NOTUSED,
> +	/* 186 */ KEY_NOTUSED,
> +	/* 187 */ KEY_NOTUSED,
> +	/* 188 */ KEY_NOTUSED,
> +	/* 189 */ KEY_NOTUSED,
> +	/* 190 */ KEY_NOTUSED,
> +	/* 191 */ KEY_NOTUSED,
> +	/* 192 */ KEY_NOTUSED,
> +	/* 193 */ KEY_NOTUSED,
> +	/* 194 */ KEY_NOTUSED,
> +	/* 195 */ KEY_NOTUSED,
> +	/* 196 */ KEY_NOTUSED,
> +	/* 197 */ KEY_NOTUSED,
> +	/* 198 */ KEY_NOTUSED,
> +	/* 199 */ KEY_Home,
> +	/* 200 */ KEY_Up,
> +	/* 201 */ KEY_PgUp,
> +	/* 202 */ KEY_NOTUSED,
> +	/* 203 */ KEY_Left,
> +	/* 204 */ KEY_NOTUSED,
> +	/* 205 */ KEY_Right,
> +	/* 206 */ KEY_NOTUSED,
> +	/* 207 */ KEY_End,
> +	/* 208 */ KEY_Down,
> +	/* 209 */ KEY_PgDown,
> +	/* 210 */ KEY_Insert,
> +	/* 211 */ KEY_Delete,
> +	/* 212 */ KEY_NOTUSED,
> +	/* 213 */ KEY_NOTUSED,
> +	/* 214 */ KEY_NOTUSED,
> +	/* 215 */ KEY_NOTUSED,
> +	/* 216 */ KEY_NOTUSED,
> +	/* 217 */ KEY_NOTUSED,
> +	/* 218 */ KEY_NOTUSED,
> +	/* 219 */ KEY_LMeta,
> +	/* 220 */ KEY_RMeta,
> +	/* 221 */ KEY_Menu,
> +};
> +#define WS_XT_MAP_SIZE (sizeof(wsXtMap)/sizeof(unsigned char))
> +

I would be careful here, the type is CARD8, that may be or not
size of unsigned char. I prefer using *wsXtMap or wsXtMap[0]
that circumvents the problem very nicely.

I do not know how it is handled else it is just my personal taste.

re,
 wh


> +static
> +TransMapRec wsXt = {
> +    0,
> +    WS_XT_MAP_SIZE,
> +    wsXtMap
> +};
> +
>  /* Map for adb keyboards  */
>  static CARD8 wsAdbMap[] = {
>  	/* 0 */ KEY_A,
> @@ -860,7 +1093,7 @@ KbdGetMapping (InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
>             switch (pKbd->wsKbdType) {
>  	       case WSKBD_TYPE_PC_XT:
>  	       case WSKBD_TYPE_PC_AT:
> -                    pKbd->RemapScanCode = ATScancode;
> +                    pKbd->scancodeMap = &wsXt;
>                      break;
>  	       case WSKBD_TYPE_USB:
>                      pKbd->scancodeMap = &wsUsb;


More information about the xorg-devel mailing list