diff options
| author | Wilba <Jason.S.Williams@gmail.com> | 2020-03-19 04:28:13 +1100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-03-18 10:28:13 -0700 |
| commit | 76d8558b1a11e93193dec7d444f4d783ab97f1a5 (patch) | |
| tree | 3705790636fc024f68896afba13f55680bf6d60a | |
| parent | 8123dd264933879d5eb34c82c837e94d860c5c3f (diff) | |
| download | qmk_firmware-76d8558b1a11e93193dec7d444f4d783ab97f1a5.tar.gz qmk_firmware-76d8558b1a11e93193dec7d444f4d783ab97f1a5.zip | |
VIA support for TKC1800 (#8178)
* VIA support for TKC1800
* Fixed VENDOR_ID
| -rw-r--r-- | keyboards/tkc1800/config.h | 4 | ||||
| -rw-r--r-- | keyboards/tkc1800/keymaps/via/config.h | 1 | ||||
| -rw-r--r-- | keyboards/tkc1800/keymaps/via/keymap.c | 159 | ||||
| -rw-r--r-- | keyboards/tkc1800/keymaps/via/rules.mk | 1 | ||||
| -rw-r--r-- | keyboards/tkc1800/rules.mk | 6 |
5 files changed, 166 insertions, 5 deletions
diff --git a/keyboards/tkc1800/config.h b/keyboards/tkc1800/config.h index a45fb677e..5ba40bb35 100644 --- a/keyboards/tkc1800/config.h +++ b/keyboards/tkc1800/config.h | |||
| @@ -20,8 +20,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 20 | #include "config_common.h" | 20 | #include "config_common.h" |
| 21 | 21 | ||
| 22 | /* USB Device descriptor parameter */ | 22 | /* USB Device descriptor parameter */ |
| 23 | #define VENDOR_ID 0xFEED | 23 | #define VENDOR_ID 0x544B // "TK" |
| 24 | #define PRODUCT_ID 0x6060 | 24 | #define PRODUCT_ID 0x0001 |
| 25 | #define DEVICE_VER 0x0003 | 25 | #define DEVICE_VER 0x0003 |
| 26 | #define MANUFACTURER The Key Company | 26 | #define MANUFACTURER The Key Company |
| 27 | #define PRODUCT TKC1800 | 27 | #define PRODUCT TKC1800 |
diff --git a/keyboards/tkc1800/keymaps/via/config.h b/keyboards/tkc1800/keymaps/via/config.h new file mode 100644 index 000000000..579212d4a --- /dev/null +++ b/keyboards/tkc1800/keymaps/via/config.h | |||
| @@ -0,0 +1 @@ | |||
| #define DYNAMIC_KEYMAP_LAYER_COUNT 2 | |||
diff --git a/keyboards/tkc1800/keymaps/via/keymap.c b/keyboards/tkc1800/keymaps/via/keymap.c new file mode 100644 index 000000000..5455934a3 --- /dev/null +++ b/keyboards/tkc1800/keymaps/via/keymap.c | |||
| @@ -0,0 +1,159 @@ | |||
| 1 | /* Copyright 2017 Mathias Andersson <wraul@dbox.se> | ||
| 2 | * | ||
| 3 | * This program is free software: you can redistribute it and/or modify | ||
| 4 | * it under the terms of the GNU General Public License as published by | ||
| 5 | * the Free Software Foundation, either version 2 of the License, or | ||
| 6 | * (at your option) any later version. | ||
| 7 | * | ||
| 8 | * This program is distributed in the hope that it will be useful, | ||
| 9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 11 | * GNU General Public License for more details. | ||
| 12 | * | ||
| 13 | * You should have received a copy of the GNU General Public License | ||
| 14 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 15 | */ | ||
| 16 | #include QMK_KEYBOARD_H | ||
| 17 | #include "LUFA/Drivers/Peripheral/TWI.h" | ||
| 18 | #include "i2c.h" | ||
| 19 | #include "ssd1306.h" | ||
| 20 | |||
| 21 | |||
| 22 | //Layers | ||
| 23 | |||
| 24 | enum { | ||
| 25 | BASE = 0, | ||
| 26 | FUNCTION, | ||
| 27 | }; | ||
| 28 | |||
| 29 | bool screenWorks = 0; | ||
| 30 | |||
| 31 | //13 characters max without re-writing the "Layer: " format in iota_gfx_task_user() | ||
| 32 | static char layer_lookup[][14] = {"Base","Function"}; | ||
| 33 | |||
| 34 | |||
| 35 | |||
| 36 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 37 | /* Keymap BASE: (Base Layer) Default Layer | ||
| 38 | * ,-------------------------------------------------------. ,-------------------. | ||
| 39 | * |Esc| F1| F2| F3| F4| | F5| F6| F7| F8| | F9|F10|F11|F12| |Ins |Home|PgUp|PrSc| | ||
| 40 | * `-------------------------------------------------------' |-------------------| | ||
| 41 | * |Del |End |PgDn|ScrL| | ||
| 42 | * ,-----------------------------------------------------------. |-------------------| | ||
| 43 | * | ~ | 1 | 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backsp | |NumL| / | * |Paus| | ||
| 44 | * |-----------------------------------------------------------| |-------------------| | ||
| 45 | * |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \ | | 7 | 8 | 9 | - | | ||
| 46 | * |-----------------------------------------------------------| |-------------------| | ||
| 47 | * |CAPS | A| S| D| F| G| H| J| K| L| ;| '|Return | | 4 | 5 | 6 | + | | ||
| 48 | * |-----------------------------------------------------------' |-------------------| | ||
| 49 | * |Shift | Z| X| C| V| B| N| M| ,| .| /|Shift | Up | 1 | 2 | 3 | Ent| | ||
| 50 | * |--------------------------------------------------------'----`--------------| | | ||
| 51 | * |Ctrl|Gui |Alt | Space |Alt |Fn |Ctr|Left |Down|Rght| 0 | . | | | ||
| 52 | * `---------------------------------------------------------------------------------' | ||
| 53 | */ | ||
| 54 | [BASE] = LAYOUT( | ||
| 55 | KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_INS, KC_HOME, KC_PGUP, KC_PSCR, \ | ||
| 56 | KC_DEL, KC_END, KC_PGDN, KC_SLCK, \ | ||
| 57 | KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, XXXXXXX, KC_NLCK, KC_PSLS, KC_PAST, KC_PAUS, \ | ||
| 58 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_P7, KC_P8, KC_P9, KC_PMNS, \ | ||
| 59 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, XXXXXXX, KC_ENT, KC_P4, KC_P5, KC_P6, KC_PPLS, \ | ||
| 60 | KC_LSFT, XXXXXXX, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP, KC_P1, KC_P2, KC_P3, XXXXXXX, \ | ||
| 61 | KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, MO(FUNCTION), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT, KC_P0, KC_PDOT, KC_PENT \ | ||
| 62 | ), | ||
| 63 | /* Keymap FUNCTION: (Function Layer) | ||
| 64 | * ,-------------------------------------------------------. ,-------------------. | ||
| 65 | * | | | | | | | | | | | | | | | | | | | | | | ||
| 66 | * `-------------------------------------------------------' |-------------------| | ||
| 67 | * | | | | | | ||
| 68 | * ,-----------------------------------------------------------. |-------------------| | ||
| 69 | * | | | | | | | | | | | | | | RESET | | | | | | | ||
| 70 | * |-----------------------------------------------------------| |-------------------| | ||
| 71 | * | | | | | | | | | | | | | | | | | | | | | ||
| 72 | * |-----------------------------------------------------------| |-------------------| | ||
| 73 | * | | | | | | | | | | | | | | | | | | | | ||
| 74 | * |-----------------------------------------------------------' |-------------------| | ||
| 75 | * | |Tog|Mod|Hu+|Hu-|Sa+|Sa-|Va+|Va-|Stp| | | | | | | | | ||
| 76 | * |--------------------------------------------------------'----`--------------| | | ||
| 77 | * | | | | | | | | | | | | . | | | ||
| 78 | * `---------------------------------------------------------------------------------' | ||
| 79 | */ | ||
| 80 | [FUNCTION] = LAYOUT( | ||
| 81 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ | ||
| 82 | _______, _______, _______, _______, \ | ||
| 83 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, RESET, XXXXXXX, _______, _______, _______, _______, \ | ||
| 84 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ | ||
| 85 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX, _______, _______, _______, _______, _______, \ | ||
| 86 | _______, XXXXXXX, RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, RGB_VAI, RGB_VAD, BL_STEP, _______, _______, _______, _______, _______, _______, XXXXXXX, \ | ||
| 87 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ \ | ||
| 88 | ), | ||
| 89 | }; | ||
| 90 | |||
| 91 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||
| 92 | return true; | ||
| 93 | } | ||
| 94 | |||
| 95 | void led_set_user(uint8_t usb_led) { | ||
| 96 | |||
| 97 | } | ||
| 98 | |||
| 99 | void matrix_init_user(void) { | ||
| 100 | #ifdef USE_I2C | ||
| 101 | i2c_master_init(); | ||
| 102 | #ifdef SSD1306OLED | ||
| 103 | // calls code for the SSD1306 OLED | ||
| 104 | _delay_ms(400); | ||
| 105 | TWI_Init(TWI_BIT_PRESCALE_1, TWI_BITLENGTH_FROM_FREQ(1, 800000)); | ||
| 106 | if ( iota_gfx_init() ) { // turns on the display | ||
| 107 | screenWorks = 1; | ||
| 108 | } | ||
| 109 | #endif | ||
| 110 | #endif | ||
| 111 | #ifdef AUDIO_ENABLE | ||
| 112 | startup_user(); | ||
| 113 | #endif | ||
| 114 | } | ||
| 115 | |||
| 116 | void matrix_scan_user(void) { | ||
| 117 | #ifdef SSD1306OLED | ||
| 118 | if ( screenWorks ) { | ||
| 119 | iota_gfx_task(); // this is what updates the display continuously | ||
| 120 | }; | ||
| 121 | #endif | ||
| 122 | } | ||
| 123 | |||
| 124 | void matrix_update(struct CharacterMatrix *dest, | ||
| 125 | const struct CharacterMatrix *source) { | ||
| 126 | if (memcmp(dest->display, source->display, sizeof(dest->display))) { | ||
| 127 | memcpy(dest->display, source->display, sizeof(dest->display)); | ||
| 128 | dest->dirty = true; | ||
| 129 | } | ||
| 130 | } | ||
| 131 | |||
| 132 | void iota_gfx_task_user(void) { | ||
| 133 | #if DEBUG_TO_SCREEN | ||
| 134 | if (debug_enable) { | ||
| 135 | return; | ||
| 136 | } | ||
| 137 | #endif | ||
| 138 | |||
| 139 | struct CharacterMatrix matrix; | ||
| 140 | |||
| 141 | matrix_clear(&matrix); | ||
| 142 | matrix_write_P(&matrix, PSTR("TKC1800")); | ||
| 143 | |||
| 144 | uint8_t layer = biton32(layer_state); | ||
| 145 | |||
| 146 | char buf[40]; | ||
| 147 | snprintf(buf,sizeof(buf), "Undef-%d", layer); | ||
| 148 | matrix_write_P(&matrix, PSTR("\nLayer: ")); | ||
| 149 | matrix_write(&matrix, layer_lookup[layer]); | ||
| 150 | |||
| 151 | // Host Keyboard LED Status | ||
| 152 | char led[40]; | ||
| 153 | snprintf(led, sizeof(led), "\n\n%s %s %s", | ||
| 154 | (host_keyboard_leds() & (1<<USB_LED_NUM_LOCK)) ? "NUMLOCK" : " ", | ||
| 155 | (host_keyboard_leds() & (1<<USB_LED_CAPS_LOCK)) ? "CAPS" : " ", | ||
| 156 | (host_keyboard_leds() & (1<<USB_LED_SCROLL_LOCK)) ? "SCLK" : " "); | ||
| 157 | matrix_write(&matrix, led); | ||
| 158 | matrix_update(&display, &matrix); | ||
| 159 | } | ||
diff --git a/keyboards/tkc1800/keymaps/via/rules.mk b/keyboards/tkc1800/keymaps/via/rules.mk new file mode 100644 index 000000000..1e5b99807 --- /dev/null +++ b/keyboards/tkc1800/keymaps/via/rules.mk | |||
| @@ -0,0 +1 @@ | |||
| VIA_ENABLE = yes | |||
diff --git a/keyboards/tkc1800/rules.mk b/keyboards/tkc1800/rules.mk index 60140160c..7cc3bbe20 100644 --- a/keyboards/tkc1800/rules.mk +++ b/keyboards/tkc1800/rules.mk | |||
| @@ -14,11 +14,11 @@ BOOTLOADER = atmel-dfu | |||
| 14 | # Build Options | 14 | # Build Options |
| 15 | # change yes to no to disable | 15 | # change yes to no to disable |
| 16 | # | 16 | # |
| 17 | BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration | 17 | BOOTMAGIC_ENABLE = lite # Virtual DIP switch configuration |
| 18 | MOUSEKEY_ENABLE = yes # Mouse keys | 18 | MOUSEKEY_ENABLE = yes # Mouse keys |
| 19 | EXTRAKEY_ENABLE = yes # Audio control and System control | 19 | EXTRAKEY_ENABLE = yes # Audio control and System control |
| 20 | CONSOLE_ENABLE = yes # Console for debug | 20 | CONSOLE_ENABLE = no # Console for debug |
| 21 | COMMAND_ENABLE = yes # Commands for debug and configuration | 21 | COMMAND_ENABLE = no # Commands for debug and configuration |
| 22 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | 22 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE |
| 23 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | 23 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend |
| 24 | # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | 24 | # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work |
