Preparing ARM for USB NKRO
- API changes from the AVR NKRO support
This commit is contained in:
parent
9f6be5794b
commit
ed9abf88a3
@ -20,9 +20,9 @@ set( CHIP
|
|||||||
# "at90usb162" # Teensy 1.0 (avr)
|
# "at90usb162" # Teensy 1.0 (avr)
|
||||||
# "atmega32u4" # Teensy 2.0 (avr)
|
# "atmega32u4" # Teensy 2.0 (avr)
|
||||||
# "at90usb646" # Teensy++ 1.0 (avr)
|
# "at90usb646" # Teensy++ 1.0 (avr)
|
||||||
"at90usb1286" # Teensy++ 2.0 (avr)
|
# "at90usb1286" # Teensy++ 2.0 (avr)
|
||||||
# "mk20dx128" # Teensy 3.0 (arm)
|
# "mk20dx128" # Teensy 3.0 (arm)
|
||||||
# "mk20dx128vlf5" # McHCK mk20dx128vlf5
|
"mk20dx128vlf5" # McHCK mk20dx128vlf5
|
||||||
# "mk20dx256" # Teensy 3.1 (arm)
|
# "mk20dx256" # Teensy 3.1 (arm)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -48,8 +48,7 @@ include( initialize )
|
|||||||
#| Please look at the {Scan,Macro,Output,Debug} for information on the modules and how to create new ones
|
#| Please look at the {Scan,Macro,Output,Debug} for information on the modules and how to create new ones
|
||||||
|
|
||||||
##| Deals with acquiring the keypress information and turning it into a key index
|
##| Deals with acquiring the keypress information and turning it into a key index
|
||||||
set( ScanModule "DPH" )
|
set( ScanModule "MD1" )
|
||||||
#set( ScanModule "MD1" )
|
|
||||||
|
|
||||||
##| Provides the mapping functions for DefaultMap and handles any macro processing before sending to the OutputModule
|
##| Provides the mapping functions for DefaultMap and handles any macro processing before sending to the OutputModule
|
||||||
set( MacroModule "PartialMap" )
|
set( MacroModule "PartialMap" )
|
||||||
@ -89,17 +88,15 @@ set( DebugModule "full" )
|
|||||||
##| Set the base keyboard .kll map, defaults to "defaultMap" if not found
|
##| Set the base keyboard .kll map, defaults to "defaultMap" if not found
|
||||||
##| Looks in Scan/<Module Name> for the available BaseMaps
|
##| Looks in Scan/<Module Name> for the available BaseMaps
|
||||||
##| TODO Support layering in basemap
|
##| TODO Support layering in basemap
|
||||||
set( BaseMap "kishsaver" )
|
set( BaseMap "defaultMap" )
|
||||||
#set( BaseMap "defaultMap" )
|
|
||||||
|
|
||||||
##| Layer additonal .kll maps on the BaseMap, layers are in order from 1st to nth
|
##| Layer additonal .kll maps on the BaseMap, layers are in order from 1st to nth
|
||||||
##| Can be set to ""
|
##| Can be set to ""
|
||||||
#set( DefaultMap "colemak stdFuncMap" )
|
set( DefaultMap "colemak stdFuncMap" )
|
||||||
set( DefaultMap "colemak kishsaver_unix1 stdFuncMap" )
|
|
||||||
|
|
||||||
##| ParitalMaps available on top of the BaseMap. See above for syntax on specifying multiple layers vs. layering
|
##| ParitalMaps available on top of the BaseMap. See above for syntax on specifying multiple layers vs. layering
|
||||||
##| Can be set to ""
|
##| Can be set to ""
|
||||||
#set( PartialMaps "hhkbpro2" )
|
set( PartialMaps "hhkbpro2" )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* Teensyduino Core Library
|
/* Teensyduino Core Library
|
||||||
* http://www.pjrc.com/teensy/
|
* http://www.pjrc.com/teensy/
|
||||||
* Copyright (c) 2013 PJRC.COM, LLC.
|
* Copyright (c) 2013 PJRC.COM, LLC.
|
||||||
|
* Modifications by Jacob Alexander 2013-2014
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
* a copy of this software and associated documentation files (the
|
* a copy of this software and associated documentation files (the
|
||||||
@ -28,17 +29,26 @@
|
|||||||
* SOFTWARE.
|
* SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "usb_dev.h"
|
// ----- Includes -----
|
||||||
#include "usb_keyboard.h"
|
|
||||||
#include <Lib/OutputLib.h>
|
// Compiler Includes
|
||||||
#include <string.h> // for memcpy()
|
#include <string.h> // for memcpy()
|
||||||
|
|
||||||
|
// Project Includes
|
||||||
|
#include <Lib/OutputLib.h>
|
||||||
|
#include <print.h>
|
||||||
|
|
||||||
|
// Local Includes
|
||||||
|
#include "usb_dev.h"
|
||||||
|
#include "usb_keyboard.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Defines -----
|
||||||
|
|
||||||
// Maximum number of transmit packets to queue so we don't starve other endpoints for memory
|
// Maximum number of transmit packets to queue so we don't starve other endpoints for memory
|
||||||
#define TX_PACKET_LIMIT 4
|
#define TX_PACKET_LIMIT 4
|
||||||
|
|
||||||
static uint8_t transmit_previous_timeout=0;
|
|
||||||
|
|
||||||
// When the PC isn't listening, how long do we wait before discarding data?
|
// When the PC isn't listening, how long do we wait before discarding data?
|
||||||
#define TX_TIMEOUT_MSEC 50
|
#define TX_TIMEOUT_MSEC 50
|
||||||
|
|
||||||
@ -51,32 +61,53 @@ static uint8_t transmit_previous_timeout=0;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Variables -----
|
||||||
|
|
||||||
|
static uint8_t transmit_previous_timeout = 0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Functions -----
|
||||||
|
|
||||||
// send the contents of keyboard_keys and keyboard_modifier_keys
|
// send the contents of keyboard_keys and keyboard_modifier_keys
|
||||||
int usb_keyboard_send(void)
|
void usb_keyboard_send()
|
||||||
{
|
{
|
||||||
uint32_t wait_count = 0;
|
uint32_t wait_count = 0;
|
||||||
usb_packet_t *tx_packet;
|
usb_packet_t *tx_packet;
|
||||||
|
|
||||||
while (1) {
|
while ( 1 )
|
||||||
if (!usb_configuration) {
|
{
|
||||||
return -1;
|
if ( !usb_configuration )
|
||||||
|
{
|
||||||
|
erro_print("USB not configured...");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
if (usb_tx_packet_count(KEYBOARD_ENDPOINT) < TX_PACKET_LIMIT) {
|
if ( usb_tx_packet_count(KEYBOARD_ENDPOINT) < TX_PACKET_LIMIT )
|
||||||
|
{
|
||||||
tx_packet = usb_malloc();
|
tx_packet = usb_malloc();
|
||||||
if (tx_packet) break;
|
if ( tx_packet )
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if (++wait_count > TX_TIMEOUT || transmit_previous_timeout) {
|
if ( ++wait_count > TX_TIMEOUT || transmit_previous_timeout )
|
||||||
|
{
|
||||||
transmit_previous_timeout = 1;
|
transmit_previous_timeout = 1;
|
||||||
return -1;
|
warn_print("USB Transmit Timeout...");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
yield();
|
yield();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Boot Mode
|
||||||
*(tx_packet->buf) = USBKeys_Modifiers;
|
*(tx_packet->buf) = USBKeys_Modifiers;
|
||||||
*(tx_packet->buf + 1) = 0;
|
*(tx_packet->buf + 1) = 0;
|
||||||
memcpy(tx_packet->buf + 2, USBKeys_Array, USB_MAX_KEY_SEND);
|
memcpy( tx_packet->buf + 2, USBKeys_Keys, USB_BOOT_MAX_KEYS );
|
||||||
tx_packet->len = 8;
|
tx_packet->len = 8;
|
||||||
usb_tx(KEYBOARD_ENDPOINT, tx_packet);
|
|
||||||
|
|
||||||
return 0;
|
// Send USB Packet
|
||||||
|
usb_tx( KEYBOARD_ENDPOINT, tx_packet );
|
||||||
|
USBKeys_Changed = USBKeyChangeState_None;
|
||||||
|
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* Teensyduino Core Library
|
/* Teensyduino Core Library
|
||||||
* http://www.pjrc.com/teensy/
|
* http://www.pjrc.com/teensy/
|
||||||
* Copyright (c) 2013 PJRC.COM, LLC.
|
* Copyright (c) 2013 PJRC.COM, LLC.
|
||||||
|
* Modifications by Jacob Alexander 2013-2014
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
* a copy of this software and associated documentation files (the
|
* a copy of this software and associated documentation files (the
|
||||||
@ -31,10 +32,21 @@
|
|||||||
#ifndef USBkeyboard_h_
|
#ifndef USBkeyboard_h_
|
||||||
#define USBkeyboard_h_
|
#define USBkeyboard_h_
|
||||||
|
|
||||||
#include <inttypes.h>
|
// ----- Includes -----
|
||||||
#include "output_com.h"
|
|
||||||
|
// Compiler Includes
|
||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
// Local Includes
|
||||||
|
#include <output_com.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Functions -----
|
||||||
|
|
||||||
|
void usb_keyboard_send();
|
||||||
|
|
||||||
|
|
||||||
int usb_keyboard_send(void);
|
|
||||||
|
|
||||||
#endif // USBkeyboard_h_
|
#endif // USBkeyboard_h_
|
||||||
|
|
||||||
|
@ -99,6 +99,7 @@ inline void usb_keyboard_send()
|
|||||||
// Send boot keyboard interrupt packet(s)
|
// Send boot keyboard interrupt packet(s)
|
||||||
case 0:
|
case 0:
|
||||||
usb_keyboard_toHost();
|
usb_keyboard_toHost();
|
||||||
|
USBKeys_Changed = USBKeyChangeState_None;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Send NKRO keyboard interrupts packet(s)
|
// Send NKRO keyboard interrupts packet(s)
|
||||||
|
@ -106,7 +106,7 @@ volatile uint8_t USBKeys_LEDs = 0;
|
|||||||
// Protocol setting from the host.
|
// Protocol setting from the host.
|
||||||
// 0 - Boot Mode
|
// 0 - Boot Mode
|
||||||
// 1 - NKRO Mode (Default, unless set by a BIOS or boot interface)
|
// 1 - NKRO Mode (Default, unless set by a BIOS or boot interface)
|
||||||
volatile uint8_t USBKeys_Protocol = 1;
|
volatile uint8_t USBKeys_Protocol = 0;
|
||||||
|
|
||||||
// Indicate if USB should send update
|
// Indicate if USB should send update
|
||||||
// OS only needs update if there has been a change in state
|
// OS only needs update if there has been a change in state
|
||||||
@ -379,29 +379,18 @@ inline void Output_setup()
|
|||||||
// USB Data Send
|
// USB Data Send
|
||||||
inline void Output_send()
|
inline void Output_send()
|
||||||
{
|
{
|
||||||
// Don't send update if USB has not changed
|
|
||||||
if ( !USBKeys_Changed )
|
|
||||||
{
|
|
||||||
// Clear modifiers and keys
|
|
||||||
USBKeys_Modifiers = 0;
|
|
||||||
USBKeys_Sent = 0;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Boot Mode Only, unset stale keys
|
// Boot Mode Only, unset stale keys
|
||||||
if ( USBKeys_Protocol == 0 )
|
if ( USBKeys_Protocol == 0 )
|
||||||
for ( uint8_t c = USBKeys_Sent; c < USB_BOOT_MAX_KEYS; c++ )
|
for ( uint8_t c = USBKeys_Sent; c < USB_BOOT_MAX_KEYS; c++ )
|
||||||
USBKeys_Keys[c] = 0;
|
USBKeys_Keys[c] = 0;
|
||||||
|
|
||||||
// Send keypresses
|
// Send keypresses while there are pending changes
|
||||||
while ( USBKeys_Changed )
|
while ( USBKeys_Changed )
|
||||||
usb_keyboard_send();
|
usb_keyboard_send();
|
||||||
|
|
||||||
// Clear modifiers and keys
|
// Clear modifiers and keys
|
||||||
USBKeys_Modifiers = 0;
|
USBKeys_Modifiers = 0;
|
||||||
USBKeys_Sent = 0;
|
USBKeys_Sent = 0;
|
||||||
USBKeys_Changed = USBKeyChangeState_None;
|
|
||||||
|
|
||||||
// Signal Scan Module we are finished
|
// Signal Scan Module we are finished
|
||||||
switch ( USBKeys_Protocol )
|
switch ( USBKeys_Protocol )
|
||||||
|
Reference in New Issue
Block a user