Hi everybody I encountered a very strange behaviour:
I modified the keyboard-library for the german keyboard-layout.
This means the translation table which ASCII-code is what USB-report-value is different.
while testing I recognized that the "3" is not typed.
I did quite some debuging to narrow down the problem.
I added debug-output if the corresponding USB-report-value is set properly
YES it is set properly
So finally I modified the correct value which is 0#20 with the value for character "+" which is 0x30
Then I sended the keystrokes "01234567890"
and received "012 + 4567890"
this confirms the ASCII-code-table is used correctly. If ASCCI-code of character "3" is handed over which is ASCII-code decimal 51 my code looks up the table at position decimal 51
If at this position 51 is the USB-report-value for "+" the character "+" is sended.
If at this position 51 is the USB-report-value for "3" NO character is sended.
I confirmed this behaviour on a second computer.
Huh ?!?!?! what's that ??
here is the ASCII-Code table in the german version
/* German keyboard (as HID standard) */
#define KEY_MOD_TABLE_SIZE (127)
const KEY_MOD_VALUE key_mod_values[KEY_MOD_TABLE_SIZE] = {
{0x00, 0 }, /* 0 */
{0x00, 0 }, /* 1 */
{0x00, 0 }, /* 2 */
{0x00, 0 }, /* 3 */
{0x00, 0 }, /* 4 */
{0x00, 0 }, /* 5 */
{0x00, 0 }, /* 6 */
{0x00, 0 }, /* 7 */
{0x00, 0 }, /* 8 */
{0x00, 0 }, /* 9 */
{0x00, 0 }, /* 10 */
{0x00, 0 }, /* 11 */
{0x00, 0 }, /* 12 */
{0x00, 0 }, /* 13 */
{0x00, 0 }, /* 14 */
{0x00, 0 }, /* 15 */
{0x00, 0 }, /* 16 */
{0x00, 0 }, /* 17 */
{0x00, 0 }, /* 18 */
{0x00, 0 }, /* 19 */
{0x00, 0 }, /* 20 */
{0x00, 0 }, /* 21 */
{0x00, 0 }, /* 22 */
{0x00, 0 }, /* 23 */
{0x00, 0 }, /* 24 */
{0x00, 0 }, /* 25 */
{0x00, 0 }, /* 26 */
{0x00, 0 }, /* 27 */
{0x00, 0 }, /* 28 */
{0x00, 0 }, /* 29 */
{0x00, 0 }, /* 30 */
{0x00, 0 }, /* 31 */
{0x00, 0 }, /* 32 */
{0x1E, KEY_SHIFT }, /* 33 ! */
{0x0 , 0 }, /* 34 */
{0x31, 0 }, /* 35 # */
{0x21, KEY_SHIFT }, /* 36 $ */
{0x22, KEY_SHIFT }, /* 37 % */
{0x23, KEY_SHIFT }, /* 38 & */
{0x31, KEY_SHIFT }, /* 39 ' */
{0x25, KEY_SHIFT }, /* 40 ( */
{0x26, KEY_SHIFT }, /* 41 ) */
{0x30, KEY_SHIFT }, /* 42 * */
{0x30, 0 }, /* 43 + */
{0x36, 0 }, /* 44 , */
{0x38, 0 }, /* 45 - */
{0x37, 0 }, /* 46 . */
{0x24, KEY_SHIFT }, /* 47 / */
{0x27, 0 }, /* 48 0 */
{0x1E, 0 }, /* 49 1 */
{0x1F, 0 }, /* 50 2 */
{0x20, 0 }, /* 51 3 */ // {0x20, 0 }, /* 51 3 */
{0x21, 0 }, /* 52 4 */
{0x22, 0 }, /* 53 5 */
{0x23, 0 }, /* 54 6 */
{0x24, 0 }, /* 55 7 */
{0x25, 0 }, /* 56 8 */
{0x26, 0 }, /* 57 9 */
{0x37, KEY_SHIFT }, /* 58 : */
{0x36, KEY_SHIFT }, /* 59 ; */
{0x64, 0 }, /* 60 < */
{0x27, KEY_SHIFT }, /* 61 = */
{0x64, KEY_SHIFT }, /* 62 > */
{0x2D, KEY_SHIFT }, /* 63 ? */
{0x14, KEY_CTRL_ALT }, /* 64 @ */
{0x04, KEY_SHIFT }, /* 65 A */
{0x05, KEY_SHIFT }, /* 66 B */
{0x06, KEY_SHIFT }, /* 67 C */
{0x07, KEY_SHIFT }, /* 68 D */
{0x08, KEY_SHIFT }, /* 69 E */
{0x09, KEY_SHIFT }, /* 70 F */
{0x0A, KEY_SHIFT }, /* 71 G */
{0x0B, KEY_SHIFT }, /* 72 H */
{0x0C, KEY_SHIFT }, /* 73 I */
{0x0D, KEY_SHIFT }, /* 74 J */
{0x0E, KEY_SHIFT }, /* 75 K */
{0x0F, KEY_SHIFT }, /* 76 L */
{0x10, KEY_SHIFT }, /* 77 M */
{0x11, KEY_SHIFT }, /* 78 N */
{0x12, KEY_SHIFT }, /* 79 O */
{0x13, KEY_SHIFT }, /* 80 P */
{0x14, KEY_SHIFT }, /* 81 Q */
{0x15, KEY_SHIFT }, /* 82 R */
{0x16, KEY_SHIFT }, /* 83 S */
{0x17, KEY_SHIFT }, /* 84 T */
{0x18, KEY_SHIFT }, /* 85 U */
{0x19, KEY_SHIFT }, /* 86 V */
{0x1A, KEY_SHIFT }, /* 87 W */
{0x1B, KEY_SHIFT }, /* 88 X */
{0x1D, KEY_SHIFT }, /* 89 Y */
{0x1C, KEY_SHIFT }, /* 90 Z */
{0x25, KEY_CTRL_ALT }, /* 91 [ */
{0x2D, KEY_CTRL_ALT }, /* 92 \ */
{0x26, KEY_CTRL_ALT }, /* 93 ] */
{0x35, 0 }, /* 94 ^ */
{0x38, KEY_SHIFT }, /* 95 _ */
{0x2E, KEY_SHIFT }, /* 96 ` */
{0x04, 0 }, /* 97 a */
{0x05, 0 }, /* 98 b */
{0x06, 0 }, /* 99 c */
{0x07, 0 }, /* 100 d */
{0x08, 0 }, /* 101 e */
{0x09, 0 }, /* 102 f */
{0x0A, 0 }, /* 103 g */
{0x0B, 0 }, /* 104 h */
{0x0C, 0 }, /* 105 i */
{0x0D, 0 }, /* 106 j */
{0x0E, 0 }, /* 107 k */
{0x0F, 0 }, /* 108 l */
{0x10, 0 }, /* 109 m */
{0x11, 0 }, /* 110 n */
{0x12, 0 }, /* 111 o */
{0x13, 0 }, /* 112 p */
{0x14, 0 }, /* 113 q */
{0x15, 0 }, /* 114 r */
{0x16, 0 }, /* 115 s */
{0x17, 0 }, /* 116 t */
{0x18, 0 }, /* 117 u */
{0x19, 0 }, /* 118 v */
{0x1A, 0 }, /* 119 w */
{0x1B, 0 }, /* 120 x */
{0x1D, 0 }, /* 121 y */
{0x1C, 0 }, /* 122 z */
{0x0 , 0 }, /* 123 { */
{0x64, KEY_CTRL_ALT }, /* 124 | */
{0x0 , 0 }, /* 125 } */
{0x30, KEY_CTRL_ALT }, /* 126 ~ */
};
in the original keyboard.cpp for US-keyboard-layout it is the same USB-report-value 0x20. The original lookup-table of the keyboard.cpp has
different encoding for the modifier-key (it is "OR-ing" the value for the Shift-key) but the value for character "3" is the same
#define SHIFT 0x80
const uint8_t _asciimap[128] =
{
0x00, // NUL
0x00, // SOH
0x00, // STX
0x00, // ETX
0x00, // EOT
0x00, // ENQ
0x00, // ACK
0x00, // BEL
0x2a, // BS Backspace
0x2b, // TAB Tab
0x28, // LF Enter
0x00, // VT
0x00, // FF
0x00, // CR
0x00, // SO
0x00, // SI
0x00, // DEL
0x00, // DC1
0x00, // DC2
0x00, // DC3
0x00, // DC4
0x00, // NAK
0x00, // SYN
0x00, // ETB
0x00, // CAN
0x00, // EM
0x00, // SUB
0x00, // ESC
0x00, // FS
0x00, // GS
0x00, // RS
0x00, // US
0x2c, // ' '
0x1e|SHIFT, // !
0x34|SHIFT, // "
0x20|SHIFT, // #
0x21|SHIFT, // $
0x22|SHIFT, // %
0x24|SHIFT, // &
0x34, // '
0x26|SHIFT, // (
0x27|SHIFT, // )
0x25|SHIFT, // *
0x2e|SHIFT, // +
0x36, // ,
0x2d, // -
0x37, // .
0x38, // /
0x27, // 0
0x1e, // 1
0x1f, // 2
0x20, // 3 <<<===== same value 0x20 for character "3"
0x21, // 4
0x22, // 5
0x23, // 6
0x24, // 7
0x25, // 8
0x26, // 9
0x33|SHIFT, // :
0x33, // ;
0x36|SHIFT, // <
0x2e, // =
0x37|SHIFT, // >
0x38|SHIFT, // ?
0x1f|SHIFT, // @
0x04|SHIFT, // A
0x05|SHIFT, // B
0x06|SHIFT, // C
0x07|SHIFT, // D
0x08|SHIFT, // E
0x09|SHIFT, // F
0x0a|SHIFT, // G
0x0b|SHIFT, // H
0x0c|SHIFT, // I
0x0d|SHIFT, // J
0x0e|SHIFT, // K
0x0f|SHIFT, // L
0x10|SHIFT, // M
0x11|SHIFT, // N
0x12|SHIFT, // O
0x13|SHIFT, // P
0x14|SHIFT, // Q
0x15|SHIFT, // R
0x16|SHIFT, // S
0x17|SHIFT, // T
0x18|SHIFT, // U
0x19|SHIFT, // V
0x1a|SHIFT, // W
0x1b|SHIFT, // X
0x1c|SHIFT, // Y
0x1d|SHIFT, // Z
0x2f, // [
0x31, // bslash
0x30, // ]
0x23|SHIFT, // ^
0x2d|SHIFT, // _
0x35, // `
0x04, // a
0x05, // b
0x06, // c
0x07, // d
0x08, // e
0x09, // f
0x0a, // g
0x0b, // h
0x0c, // i
0x0d, // j
0x0e, // k
0x0f, // l
0x10, // m
0x11, // n
0x12, // o
0x13, // p
0x14, // q
0x15, // r
0x16, // s
0x17, // t
0x18, // u
0x19, // v
0x1a, // w
0x1b, // x
0x1c, // y
0x1d, // z
0x2f|SHIFT, // {
0x31|SHIFT, // |
0x30|SHIFT, // }
0x35|SHIFT, // ~
0 // DEL
};
Does anybody have a clue what could cause this bug?
best regards Stefan