mirror of
https://github.com/gdsports/USBHost_t36
synced 2024-12-21 23:08:55 -05:00
Work around for MS keyboard
I updated the keyboard extras to detect if the report ID is 0xff00 and if so ignore it in the Mouse extras process code. This helped not handling a lot of extra messages generated by MS keyboard. Also updated Test app to show names of some of these special keys.
This commit is contained in:
parent
dbe5292471
commit
3c34cc2f6f
@ -128,7 +128,235 @@ void OnHIDExtrasPress(uint32_t top, uint16_t key)
|
||||
Serial.print("HID (");
|
||||
Serial.print(top, HEX);
|
||||
Serial.print(") key press:");
|
||||
Serial.println(key, HEX);
|
||||
Serial.print(key, HEX);
|
||||
if (top == 0xc0000) {
|
||||
switch (key) {
|
||||
case 0x20 : Serial.print(" - +10"); break;
|
||||
case 0x21 : Serial.print(" - +100"); break;
|
||||
case 0x22 : Serial.print(" - AM/PM"); break;
|
||||
case 0x30 : Serial.print(" - Power"); break;
|
||||
case 0x31 : Serial.print(" - Reset"); break;
|
||||
case 0x32 : Serial.print(" - Sleep"); break;
|
||||
case 0x33 : Serial.print(" - Sleep After"); break;
|
||||
case 0x34 : Serial.print(" - Sleep Mode"); break;
|
||||
case 0x35 : Serial.print(" - Illumination"); break;
|
||||
case 0x36 : Serial.print(" - Function Buttons"); break;
|
||||
case 0x40 : Serial.print(" - Menu"); break;
|
||||
case 0x41 : Serial.print(" - Menu Pick"); break;
|
||||
case 0x42 : Serial.print(" - Menu Up"); break;
|
||||
case 0x43 : Serial.print(" - Menu Down"); break;
|
||||
case 0x44 : Serial.print(" - Menu Left"); break;
|
||||
case 0x45 : Serial.print(" - Menu Right"); break;
|
||||
case 0x46 : Serial.print(" - Menu Escape"); break;
|
||||
case 0x47 : Serial.print(" - Menu Value Increase"); break;
|
||||
case 0x48 : Serial.print(" - Menu Value Decrease"); break;
|
||||
case 0x60 : Serial.print(" - Data On Screen"); break;
|
||||
case 0x61 : Serial.print(" - Closed Caption"); break;
|
||||
case 0x62 : Serial.print(" - Closed Caption Select"); break;
|
||||
case 0x63 : Serial.print(" - VCR/TV"); break;
|
||||
case 0x64 : Serial.print(" - Broadcast Mode"); break;
|
||||
case 0x65 : Serial.print(" - Snapshot"); break;
|
||||
case 0x66 : Serial.print(" - Still"); break;
|
||||
case 0x80 : Serial.print(" - Selection"); break;
|
||||
case 0x81 : Serial.print(" - Assign Selection"); break;
|
||||
case 0x82 : Serial.print(" - Mode Step"); break;
|
||||
case 0x83 : Serial.print(" - Recall Last"); break;
|
||||
case 0x84 : Serial.print(" - Enter Channel"); break;
|
||||
case 0x85 : Serial.print(" - Order Movie"); break;
|
||||
case 0x86 : Serial.print(" - Channel"); break;
|
||||
case 0x87 : Serial.print(" - Media Selection"); break;
|
||||
case 0x88 : Serial.print(" - Media Select Computer"); break;
|
||||
case 0x89 : Serial.print(" - Media Select TV"); break;
|
||||
case 0x8A : Serial.print(" - Media Select WWW"); break;
|
||||
case 0x8B : Serial.print(" - Media Select DVD"); break;
|
||||
case 0x8C : Serial.print(" - Media Select Telephone"); break;
|
||||
case 0x8D : Serial.print(" - Media Select Program Guide"); break;
|
||||
case 0x8E : Serial.print(" - Media Select Video Phone"); break;
|
||||
case 0x8F : Serial.print(" - Media Select Games"); break;
|
||||
case 0x90 : Serial.print(" - Media Select Messages"); break;
|
||||
case 0x91 : Serial.print(" - Media Select CD"); break;
|
||||
case 0x92 : Serial.print(" - Media Select VCR"); break;
|
||||
case 0x93 : Serial.print(" - Media Select Tuner"); break;
|
||||
case 0x94 : Serial.print(" - Quit"); break;
|
||||
case 0x95 : Serial.print(" - Help"); break;
|
||||
case 0x96 : Serial.print(" - Media Select Tape"); break;
|
||||
case 0x97 : Serial.print(" - Media Select Cable"); break;
|
||||
case 0x98 : Serial.print(" - Media Select Satellite"); break;
|
||||
case 0x99 : Serial.print(" - Media Select Security"); break;
|
||||
case 0x9A : Serial.print(" - Media Select Home"); break;
|
||||
case 0x9B : Serial.print(" - Media Select Call"); break;
|
||||
case 0x9C : Serial.print(" - Channel Increment"); break;
|
||||
case 0x9D : Serial.print(" - Channel Decrement"); break;
|
||||
case 0x9E : Serial.print(" - Media Select SAP"); break;
|
||||
case 0xA0 : Serial.print(" - VCR Plus"); break;
|
||||
case 0xA1 : Serial.print(" - Once"); break;
|
||||
case 0xA2 : Serial.print(" - Daily"); break;
|
||||
case 0xA3 : Serial.print(" - Weekly"); break;
|
||||
case 0xA4 : Serial.print(" - Monthly"); break;
|
||||
case 0xB0 : Serial.print(" - Play"); break;
|
||||
case 0xB1 : Serial.print(" - Pause"); break;
|
||||
case 0xB2 : Serial.print(" - Record"); break;
|
||||
case 0xB3 : Serial.print(" - Fast Forward"); break;
|
||||
case 0xB4 : Serial.print(" - Rewind"); break;
|
||||
case 0xB5 : Serial.print(" - Scan Next Track"); break;
|
||||
case 0xB6 : Serial.print(" - Scan Previous Track"); break;
|
||||
case 0xB7 : Serial.print(" - Stop"); break;
|
||||
case 0xB8 : Serial.print(" - Eject"); break;
|
||||
case 0xB9 : Serial.print(" - Random Play"); break;
|
||||
case 0xBA : Serial.print(" - Select DisC"); break;
|
||||
case 0xBB : Serial.print(" - Enter Disc"); break;
|
||||
case 0xBC : Serial.print(" - Repeat"); break;
|
||||
case 0xBD : Serial.print(" - Tracking"); break;
|
||||
case 0xBE : Serial.print(" - Track Normal"); break;
|
||||
case 0xBF : Serial.print(" - Slow Tracking"); break;
|
||||
case 0xC0 : Serial.print(" - Frame Forward"); break;
|
||||
case 0xC1 : Serial.print(" - Frame Back"); break;
|
||||
case 0xC2 : Serial.print(" - Mark"); break;
|
||||
case 0xC3 : Serial.print(" - Clear Mark"); break;
|
||||
case 0xC4 : Serial.print(" - Repeat From Mark"); break;
|
||||
case 0xC5 : Serial.print(" - Return To Mark"); break;
|
||||
case 0xC6 : Serial.print(" - Search Mark Forward"); break;
|
||||
case 0xC7 : Serial.print(" - Search Mark Backwards"); break;
|
||||
case 0xC8 : Serial.print(" - Counter Reset"); break;
|
||||
case 0xC9 : Serial.print(" - Show Counter"); break;
|
||||
case 0xCA : Serial.print(" - Tracking Increment"); break;
|
||||
case 0xCB : Serial.print(" - Tracking Decrement"); break;
|
||||
case 0xCD : Serial.print(" - Pause/Continue"); break;
|
||||
case 0xE0 : Serial.print(" - Volume"); break;
|
||||
case 0xE1 : Serial.print(" - Balance"); break;
|
||||
case 0xE2 : Serial.print(" - Mute"); break;
|
||||
case 0xE3 : Serial.print(" - Bass"); break;
|
||||
case 0xE4 : Serial.print(" - Treble"); break;
|
||||
case 0xE5 : Serial.print(" - Bass Boost"); break;
|
||||
case 0xE6 : Serial.print(" - Surround Mode"); break;
|
||||
case 0xE7 : Serial.print(" - Loudness"); break;
|
||||
case 0xE8 : Serial.print(" - MPX"); break;
|
||||
case 0xE9 : Serial.print(" - Volume Up"); break;
|
||||
case 0xEA : Serial.print(" - Volume Down"); break;
|
||||
case 0xF0 : Serial.print(" - Speed Select"); break;
|
||||
case 0xF1 : Serial.print(" - Playback Speed"); break;
|
||||
case 0xF2 : Serial.print(" - Standard Play"); break;
|
||||
case 0xF3 : Serial.print(" - Long Play"); break;
|
||||
case 0xF4 : Serial.print(" - Extended Play"); break;
|
||||
case 0xF5 : Serial.print(" - Slow"); break;
|
||||
case 0x100: Serial.print(" - Fan Enable"); break;
|
||||
case 0x101: Serial.print(" - Fan Speed"); break;
|
||||
case 0x102: Serial.print(" - Light"); break;
|
||||
case 0x103: Serial.print(" - Light Illumination Level"); break;
|
||||
case 0x104: Serial.print(" - Climate Control Enable"); break;
|
||||
case 0x105: Serial.print(" - Room Temperature"); break;
|
||||
case 0x106: Serial.print(" - Security Enable"); break;
|
||||
case 0x107: Serial.print(" - Fire Alarm"); break;
|
||||
case 0x108: Serial.print(" - Police Alarm"); break;
|
||||
case 0x150: Serial.print(" - Balance Right"); break;
|
||||
case 0x151: Serial.print(" - Balance Left"); break;
|
||||
case 0x152: Serial.print(" - Bass Increment"); break;
|
||||
case 0x153: Serial.print(" - Bass Decrement"); break;
|
||||
case 0x154: Serial.print(" - Treble Increment"); break;
|
||||
case 0x155: Serial.print(" - Treble Decrement"); break;
|
||||
case 0x160: Serial.print(" - Speaker System"); break;
|
||||
case 0x161: Serial.print(" - Channel Left"); break;
|
||||
case 0x162: Serial.print(" - Channel Right"); break;
|
||||
case 0x163: Serial.print(" - Channel Center"); break;
|
||||
case 0x164: Serial.print(" - Channel Front"); break;
|
||||
case 0x165: Serial.print(" - Channel Center Front"); break;
|
||||
case 0x166: Serial.print(" - Channel Side"); break;
|
||||
case 0x167: Serial.print(" - Channel Surround"); break;
|
||||
case 0x168: Serial.print(" - Channel Low Frequency Enhancement"); break;
|
||||
case 0x169: Serial.print(" - Channel Top"); break;
|
||||
case 0x16A: Serial.print(" - Channel Unknown"); break;
|
||||
case 0x170: Serial.print(" - Sub-channel"); break;
|
||||
case 0x171: Serial.print(" - Sub-channel Increment"); break;
|
||||
case 0x172: Serial.print(" - Sub-channel Decrement"); break;
|
||||
case 0x173: Serial.print(" - Alternate Audio Increment"); break;
|
||||
case 0x174: Serial.print(" - Alternate Audio Decrement"); break;
|
||||
case 0x180: Serial.print(" - Application Launch Buttons"); break;
|
||||
case 0x181: Serial.print(" - AL Launch Button Configuration Tool"); break;
|
||||
case 0x182: Serial.print(" - AL Programmable Button Configuration"); break;
|
||||
case 0x183: Serial.print(" - AL Consumer Control Configuration"); break;
|
||||
case 0x184: Serial.print(" - AL Word Processor"); break;
|
||||
case 0x185: Serial.print(" - AL Text Editor"); break;
|
||||
case 0x186: Serial.print(" - AL Spreadsheet"); break;
|
||||
case 0x187: Serial.print(" - AL Graphics Editor"); break;
|
||||
case 0x188: Serial.print(" - AL Presentation App"); break;
|
||||
case 0x189: Serial.print(" - AL Database App"); break;
|
||||
case 0x18A: Serial.print(" - AL Email Reader"); break;
|
||||
case 0x18B: Serial.print(" - AL Newsreader"); break;
|
||||
case 0x18C: Serial.print(" - AL Voicemail"); break;
|
||||
case 0x18D: Serial.print(" - AL Contacts/Address Book"); break;
|
||||
case 0x18E: Serial.print(" - AL Calendar/Schedule"); break;
|
||||
case 0x18F: Serial.print(" - AL Task/Project Manager"); break;
|
||||
case 0x190: Serial.print(" - AL Log/Journal/Timecard"); break;
|
||||
case 0x191: Serial.print(" - AL Checkbook/Finance"); break;
|
||||
case 0x192: Serial.print(" - AL Calculator"); break;
|
||||
case 0x193: Serial.print(" - AL A/V Capture/Playback"); break;
|
||||
case 0x194: Serial.print(" - AL Local Machine Browser"); break;
|
||||
case 0x195: Serial.print(" - AL LAN/WAN Browser"); break;
|
||||
case 0x196: Serial.print(" - AL Internet Browser"); break;
|
||||
case 0x197: Serial.print(" - AL Remote Networking/ISP Connect"); break;
|
||||
case 0x198: Serial.print(" - AL Network Conference"); break;
|
||||
case 0x199: Serial.print(" - AL Network Chat"); break;
|
||||
case 0x19A: Serial.print(" - AL Telephony/Dialer"); break;
|
||||
case 0x19B: Serial.print(" - AL Logon"); break;
|
||||
case 0x19C: Serial.print(" - AL Logoff"); break;
|
||||
case 0x19D: Serial.print(" - AL Logon/Logoff"); break;
|
||||
case 0x19E: Serial.print(" - AL Terminal Lock/Screensaver"); break;
|
||||
case 0x19F: Serial.print(" - AL Control Panel"); break;
|
||||
case 0x1A0: Serial.print(" - AL Command Line Processor/Run"); break;
|
||||
case 0x1A1: Serial.print(" - AL Process/Task Manager"); break;
|
||||
case 0x1A2: Serial.print(" - AL Select Tast/Application"); break;
|
||||
case 0x1A3: Serial.print(" - AL Next Task/Application"); break;
|
||||
case 0x1A4: Serial.print(" - AL Previous Task/Application"); break;
|
||||
case 0x1A5: Serial.print(" - AL Preemptive Halt Task/Application"); break;
|
||||
case 0x200: Serial.print(" - Generic GUI Application Controls"); break;
|
||||
case 0x201: Serial.print(" - AC New"); break;
|
||||
case 0x202: Serial.print(" - AC Open"); break;
|
||||
case 0x203: Serial.print(" - AC Close"); break;
|
||||
case 0x204: Serial.print(" - AC Exit"); break;
|
||||
case 0x205: Serial.print(" - AC Maximize"); break;
|
||||
case 0x206: Serial.print(" - AC Minimize"); break;
|
||||
case 0x207: Serial.print(" - AC Save"); break;
|
||||
case 0x208: Serial.print(" - AC Print"); break;
|
||||
case 0x209: Serial.print(" - AC Properties"); break;
|
||||
case 0x21A: Serial.print(" - AC Undo"); break;
|
||||
case 0x21B: Serial.print(" - AC Copy"); break;
|
||||
case 0x21C: Serial.print(" - AC Cut"); break;
|
||||
case 0x21D: Serial.print(" - AC Paste"); break;
|
||||
case 0x21E: Serial.print(" - AC Select All"); break;
|
||||
case 0x21F: Serial.print(" - AC Find"); break;
|
||||
case 0x220: Serial.print(" - AC Find and Replace"); break;
|
||||
case 0x221: Serial.print(" - AC Search"); break;
|
||||
case 0x222: Serial.print(" - AC Go To"); break;
|
||||
case 0x223: Serial.print(" - AC Home"); break;
|
||||
case 0x224: Serial.print(" - AC Back"); break;
|
||||
case 0x225: Serial.print(" - AC Forward"); break;
|
||||
case 0x226: Serial.print(" - AC Stop"); break;
|
||||
case 0x227: Serial.print(" - AC Refresh"); break;
|
||||
case 0x228: Serial.print(" - AC Previous Link"); break;
|
||||
case 0x229: Serial.print(" - AC Next Link"); break;
|
||||
case 0x22A: Serial.print(" - AC Bookmarks"); break;
|
||||
case 0x22B: Serial.print(" - AC History"); break;
|
||||
case 0x22C: Serial.print(" - AC Subscriptions"); break;
|
||||
case 0x22D: Serial.print(" - AC Zoom In"); break;
|
||||
case 0x22E: Serial.print(" - AC Zoom Out"); break;
|
||||
case 0x22F: Serial.print(" - AC Zoom"); break;
|
||||
case 0x230: Serial.print(" - AC Full Screen View"); break;
|
||||
case 0x231: Serial.print(" - AC Normal View"); break;
|
||||
case 0x232: Serial.print(" - AC View Toggle"); break;
|
||||
case 0x233: Serial.print(" - AC Scroll Up"); break;
|
||||
case 0x234: Serial.print(" - AC Scroll Down"); break;
|
||||
case 0x235: Serial.print(" - AC Scroll"); break;
|
||||
case 0x236: Serial.print(" - AC Pan Left"); break;
|
||||
case 0x237: Serial.print(" - AC Pan Right"); break;
|
||||
case 0x238: Serial.print(" - AC Pan"); break;
|
||||
case 0x239: Serial.print(" - AC New Window"); break;
|
||||
case 0x23A: Serial.print(" - AC Tile Horizontally"); break;
|
||||
case 0x23B: Serial.print(" - AC Tile Vertically"); break;
|
||||
case 0x23C: Serial.print(" - AC Format"); break;
|
||||
|
||||
}
|
||||
}
|
||||
Serial.println();
|
||||
}
|
||||
|
||||
void OnHIDExtrasRelease(uint32_t top, uint16_t key)
|
||||
|
@ -30,7 +30,10 @@
|
||||
bool KeyboardHIDExtrasController::claim_collection(Device_t *dev, uint32_t topusage)
|
||||
{
|
||||
// Lets try to claim a few specific Keyboard related collection/reports
|
||||
if ((topusage != TOPUSAGE_SYS_CONTROL) && (topusage != TOPUSAGE_CONSUMER_CONTROL)) return false;
|
||||
//Serial.printf("KBH Claim %x\n", topusage);
|
||||
if ((topusage != TOPUSAGE_SYS_CONTROL)
|
||||
&& (topusage != TOPUSAGE_CONSUMER_CONTROL)
|
||||
) return false;
|
||||
// only claim from one physical device
|
||||
//Serial.println("KeyboardHIDExtrasController claim collection");
|
||||
if (mydevice != NULL && dev != mydevice) return false;
|
||||
@ -56,7 +59,9 @@ void KeyboardHIDExtrasController::hid_input_begin(uint32_t topusage, uint32_t ty
|
||||
|
||||
void KeyboardHIDExtrasController::hid_input_data(uint32_t usage, int32_t value)
|
||||
{
|
||||
//Serial.printf("KeyboardHIDExtrasController: usage=%X, value=%d\n", usage, value);
|
||||
// Hack ignore 0xff00 high words as these are user values...
|
||||
if ((usage & 0xffff0000) == 0xff000000) return;
|
||||
//Serial.printf("KeyboardHIDExtrasController: topusage= %x usage=%X, value=%d\n", topusage_, usage, value);
|
||||
|
||||
// See if the value is in our keys_down list
|
||||
usage &= 0xffff; // only keep the actual key
|
||||
|
Loading…
Reference in New Issue
Block a user