From 25515523e6560101b2342ec28fb0c189b18fe769 Mon Sep 17 00:00:00 2001 From: kemonine Date: Sat, 21 Nov 2020 18:09:05 -0500 Subject: [PATCH] First attempt at zmk tidbit bring up (errors present) --- .../boards/shields/tidbit/Kconfig.defconfig | 12 +++ zmk/app/boards/shields/tidbit/Kconfig.shield | 5 + .../shields/tidbit/boards/nice_nano.overlay | 28 +++++ zmk/app/boards/shields/tidbit/tidbit.conf | 6 ++ zmk/app/boards/shields/tidbit/tidbit.keymap | 45 ++++++++ zmk/app/boards/shields/tidbit/tidbit.overlay | 101 ++++++++++++++++++ .../boards/shields/tidbit/tidbit_19key.keymap | 41 +++++++ 7 files changed, 238 insertions(+) create mode 100644 zmk/app/boards/shields/tidbit/Kconfig.defconfig create mode 100644 zmk/app/boards/shields/tidbit/Kconfig.shield create mode 100644 zmk/app/boards/shields/tidbit/boards/nice_nano.overlay create mode 100644 zmk/app/boards/shields/tidbit/tidbit.conf create mode 100644 zmk/app/boards/shields/tidbit/tidbit.keymap create mode 100644 zmk/app/boards/shields/tidbit/tidbit.overlay create mode 100644 zmk/app/boards/shields/tidbit/tidbit_19key.keymap diff --git a/zmk/app/boards/shields/tidbit/Kconfig.defconfig b/zmk/app/boards/shields/tidbit/Kconfig.defconfig new file mode 100644 index 00000000..11ea5bb6 --- /dev/null +++ b/zmk/app/boards/shields/tidbit/Kconfig.defconfig @@ -0,0 +1,12 @@ +# Copyright (c) 2020 The ZMK Contributors +# SPDX-License-Identifier: MIT + +if SHIELD_TIDBIT + +config ZMK_KEYBOARD_NAME + default "TIDBIT" + +config ZMK_USB + default y + +endif diff --git a/zmk/app/boards/shields/tidbit/Kconfig.shield b/zmk/app/boards/shields/tidbit/Kconfig.shield new file mode 100644 index 00000000..c1e8ecca --- /dev/null +++ b/zmk/app/boards/shields/tidbit/Kconfig.shield @@ -0,0 +1,5 @@ +# Copyright (c) 2020 The ZMK Contributors +# SPDX-License-Identifier: MIT + +config SHIELD_TIDBIT + def_bool $(shields_list_contains,tidbit) diff --git a/zmk/app/boards/shields/tidbit/boards/nice_nano.overlay b/zmk/app/boards/shields/tidbit/boards/nice_nano.overlay new file mode 100644 index 00000000..01fea2eb --- /dev/null +++ b/zmk/app/boards/shields/tidbit/boards/nice_nano.overlay @@ -0,0 +1,28 @@ +&spi1 { + compatible = "nordic,nrf-spim"; + status = "okay"; + mosi-pin = <10>; + // Unused pins, needed for SPI definition, but not used by the ws2812 driver itself. + sck-pin = <5>; + miso-pin = <7>; + + led_strip: ws2812@0 { + compatible = "worldsemi,ws2812-spi"; + label = "WS2812"; + + /* SPI */ + reg = <0>; /* ignored, but necessary for SPI bindings */ + spi-max-frequency = <4000000>; + + /* WS2812 */ + chain-length = <8>; /* arbitrary; change at will */ + spi-one-frame = <0x70>; + spi-zero-frame = <0x40>; + }; +}; + +/ { + chosen { + zmk,underglow = &led_strip; + }; +}; diff --git a/zmk/app/boards/shields/tidbit/tidbit.conf b/zmk/app/boards/shields/tidbit/tidbit.conf new file mode 100644 index 00000000..10b1d959 --- /dev/null +++ b/zmk/app/boards/shields/tidbit/tidbit.conf @@ -0,0 +1,6 @@ +# Copyright (c) 2020 The ZMK Contributors +# SPDX-License-Identifier: MIT + +# Uncomment to enable encoder +CONFIG_EC11=y +CONFIG_EC11_TRIGGER_GLOBAL_THREAD=y diff --git a/zmk/app/boards/shields/tidbit/tidbit.keymap b/zmk/app/boards/shields/tidbit/tidbit.keymap new file mode 100644 index 00000000..4ab4b60d --- /dev/null +++ b/zmk/app/boards/shields/tidbit/tidbit.keymap @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2020 The ZMK Contributors + * + * SPDX-License-Identifier: MIT + */ + +#include +#include +#include +#include +#include + +&encoder_1_top_row { + status = "okay"; +}; + +/ { + keymap { + compatible = "zmk,keymap"; + + default_layer { + bindings = < + &kp KP_NUMLOCK &kp KP_ASERISK &kp KP_MINUS + &kp KP_NUBMER_7 &kp KP_NUMBER_8 &kp KP_NUMBER_9 &kp KP_PLUS + &kp KP_NUMBER_4 &kp KP_NUMBER_5 &kp KP_NUMBER_6 &kp &none + &kp KP_NUMBER_1 &kp KP_NUMBER_2 &kp KP_NUMBER_3 < 1 KP_ENTER + &none &kp KP_NUMBER_0 &kp KP_DOT &none + >; + + sensor-bindings = <&inc_dec_kp K_VOLUME_UP K_VOLUME_DOWN>; + }; + + func_layer { + bindings = < + &none &rgb_ug RGB_TOG &none + &none &bt BT_CLR_CMD &rgb_ug RGB_EFF &out OUT_TOG + &none &bt BT_NEXT_CMD &rgb_ug RGB_HUI &out OUT_BLE + &reset &bt BT_PRV_CMD &rgb_ug RGB_SAI &out OUT_USB + &bootloader &bt BT_SEL_CMD &rgb_ug RGB_BRI &tog 0 + >; + + sensor-bindings = <&inc_dec_kp K_VOLUME_UP K_VOLUME_DOWN>; + }; + }; +}; diff --git a/zmk/app/boards/shields/tidbit/tidbit.overlay b/zmk/app/boards/shields/tidbit/tidbit.overlay new file mode 100644 index 00000000..610bc342 --- /dev/null +++ b/zmk/app/boards/shields/tidbit/tidbit.overlay @@ -0,0 +1,101 @@ +/* + * Copyright (c) 2020 The ZMK Contributors + * + * SPDX-License-Identifier: MIT + */ + +#include + +/ { + chosen { + zmk,kscan = &kscan0; + zmk,matrix_transform = &default_transform; + }; + + default_transform: keymap_transform_0 { + compatible = "zmk,matrix-transform"; + columns = <4>; + rows = <5>; + + map = < + RC(0,1) RC(0,2) RC(0,3) + RC(1,0) RC(1,1) RC(1,2) RC(1,3) + RC(2,0) RC(2,1) RC(2,2) RC(2,3) + RC(3,0) RC(3,1) RC(3,2) RC(3,3) + RC(4,0) RC(4,1) RC(4,2) RC(4,3) + >; + }; + + kscan0: kscan { + compatible = "zmk,kscan-gpio-matrix"; + label = "KSCAN"; + + diode-direction = "col2row"; + + row-gpios + = <&pro_micro_d 13 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 7 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 6 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 5 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 4 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + ; + + col-gpios + = <&pro_micro_a 3 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 2 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 1 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 0 GPIO_ACTIVE_HIGH> + ; + + }; + + encoder_1_top_row: encoder_1_top_row { + compatible = "alps,ec11"; + label = "Top Row Encoder"; + a-gpios = <&pro_micro_d 11 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + b-gpios = <&pro_micro_d 12 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + resolution = <4>; + status = "disabled"; + }; + + encoder_1: encoder_1 { + compatible = "alps,ec11"; + label = "Encoder 1"; + a-gpios = <&pro_micro_d 12 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + b-gpios = <&pro_micro_d 11 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + resolution = <4>; + status = "disabled"; + }; + + encoder_2: encoder_2 { + compatible = "alps,ec11"; + label = "Encoder 2"; + a-gpios = <&pro_micro_d 8 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + b-gpios = <&pro_micro_d 9 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + resolution = <4>; + status = "disabled"; + }; + + encoder_3: encoder_3 { + compatible = "alps,ec11"; + label = "Encoder 3"; + a-gpios = <&pro_micro_d 3 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + b-gpios = <&pro_micro_d 2 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + resolution = <4>; + status = "disabled"; + }; + + encoder_4: encoder_4 { + compatible = "alps,ec11"; + label = "Encoder 4"; + a-gpios = <&pro_micro_d 1 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + b-gpios = <&pro_micro_d 0 (GPIO_ACTIVE_HIGH | GPIO_PULL_UP)>; + resolution = <4>; + status = "disabled"; + }; + + sensors { + compatible = "zmk,keymap-sensors"; + sensors = <&encoder_1_top_row &encoder_1 &encoder_2 &encoder_3 &encoder_4>; + }; +}; diff --git a/zmk/app/boards/shields/tidbit/tidbit_19key.keymap b/zmk/app/boards/shields/tidbit/tidbit_19key.keymap new file mode 100644 index 00000000..565c1d42 --- /dev/null +++ b/zmk/app/boards/shields/tidbit/tidbit_19key.keymap @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2020 The ZMK Contributors + * + * SPDX-License-Identifier: MIT + */ + +#include +#include +#include +#include +#include + +/ { + keymap { + compatible = "zmk,keymap"; + + default_layer { + bindings = < + &tog 1 &kp KP_NUMLOCK &kp KP_SLASH + &kp KP_NUBMER_7 &kp KP_NUMBER_8 &kp KP_NUMBER_9 &kp KP_ASTERISK + &kp KP_NUMBER_4 &kp KP_NUMBER_5 &kp KP_NUMBER_6 &kp KP_MINUS + &kp KP_NUMBER_1 &kp KP_NUMBER_2 &kp KP_NUMBER_3 &kp KP_PLUS + &none &kp KP_NUMBER_0 &kp KP_DOT &kp KP_ENTER + >; + + sensor-bindings = <&inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp K_VOLUME_UP K_VOLUME_DOWN>; + }; + + func_layer { + bindings = < + &tog 0 &bootloader &reset + &none &bt BT_CLR_CMD &kp RGB_EFF &out OUT_TOG + &none &bt BT_NEXT_CMD &kp RGB_HUI &out OUT_BLE + &none &bt BT_PRV_CMD &kp RGB_SAI &out OUT_USB + &none &bt BT_SEL_CMD &kp RGB_BRI &none + >; + + sensor-bindings = <&inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp &none &none &inc_dec_kp K_VOLUME_UP K_VOLUME_DOWN>; + }; + }; +};