diff options
Diffstat (limited to 'tmk_core')
| -rw-r--r-- | tmk_core/common.mk | 9 | ||||
| -rw-r--r-- | tmk_core/common/keyboard.c | 11 | ||||
| -rw-r--r-- | tmk_core/protocol/chibios/main.c | 30 | 
3 files changed, 45 insertions, 5 deletions
| diff --git a/tmk_core/common.mk b/tmk_core/common.mk index d71fba9bc..5bae0d762 100644 --- a/tmk_core/common.mk +++ b/tmk_core/common.mk @@ -97,6 +97,15 @@ ifeq ($(strip $(KEYMAP_SECTION_ENABLE)), yes)      endif  endif +ifeq ($(MASTER),right)	 +	OPT_DEFS += -DMASTER_IS_ON_RIGHT +else  +	ifneq ($(MASTER),left) +$(error MASTER does not have a valid value(left/right)) +	endif +endif + +  # Version string  OPT_DEFS += -DVERSION=$(shell (git describe --always --dirty || echo 'unknown') 2> /dev/null) diff --git a/tmk_core/common/keyboard.c b/tmk_core/common/keyboard.c index 81df8eb73..3a1262a9f 100644 --- a/tmk_core/common/keyboard.c +++ b/tmk_core/common/keyboard.c @@ -49,6 +49,9 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.  #ifdef RGBLIGHT_ENABLE  #   include "rgblight.h"  #endif +#ifdef SERIAL_LINK_ENABLE +#   include "serial_link/system/serial_link.h" +#endif  #ifdef MATRIX_HAS_GHOST  static bool has_ghost_in_row(uint8_t row) @@ -167,11 +170,15 @@ MATRIX_LOOP_END:  #endif  #ifdef SERIAL_MOUSE_ENABLE -        serial_mouse_task(); +    serial_mouse_task();  #endif  #ifdef ADB_MOUSE_ENABLE -        adb_mouse_task(); +    adb_mouse_task(); +#endif + +#ifdef SERIAL_LINK_ENABLE +	serial_link_update();  #endif      // update LED diff --git a/tmk_core/protocol/chibios/main.c b/tmk_core/protocol/chibios/main.c index 54bb6a8f5..aeb11752f 100644 --- a/tmk_core/protocol/chibios/main.c +++ b/tmk_core/protocol/chibios/main.c @@ -35,6 +35,9 @@  #ifdef SLEEP_LED_ENABLE  #include "sleep_led.h"  #endif +#ifdef SERIAL_LINK_ENABLE +#include "serial_link/system/serial_link.h" +#endif  #include "suspend.h" @@ -98,9 +101,27 @@ int main(void) {    /* init printf */    init_printf(NULL,sendchar_pf); -  /* Wait until the USB is active */ -  while(USB_DRIVER.state != USB_ACTIVE) +#ifdef SERIAL_LINK_ENABLE +  init_serial_link(); +#endif + +  host_driver_t* driver = NULL; + +  /* Wait until the USB or serial link is active */ +  while (true) { +    if(USB_DRIVER.state == USB_ACTIVE) { +      driver = &chibios_driver; +      break; +    } +#ifdef SERIAL_LINK_ENABLE +    if(is_serial_link_connected()) { +      driver = get_serial_link_driver(); +      break; +    } +    serial_link_update(); +#endif      chThdSleepMilliseconds(50); +  }    /* Do need to wait here!     * Otherwise the next print might start a transfer on console EP @@ -113,7 +134,7 @@ int main(void) {    /* init TMK modules */    keyboard_init(); -  host_set_driver(&chibios_driver); +  host_set_driver(driver);  #ifdef SLEEP_LED_ENABLE    sleep_led_init(); @@ -128,6 +149,9 @@ int main(void) {        print("[s]");        while(USB_DRIVER.state == USB_SUSPENDED) {          /* Do this in the suspended state */ +#ifdef SERIAL_LINK_ENABLE +        serial_link_update(); +#endif          suspend_power_down(); // on AVR this deep sleeps for 15ms          /* Remote wakeup */          if((USB_DRIVER.status & 2) && suspend_wakeup_condition()) { | 
