summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app/boards/shields/Kconfig.defconfig14
-rw-r--r--app/boards/shields/Kconfig.shield5
-rw-r--r--app/boards/shields/cradio/Kconfig.defconfig23
-rw-r--r--app/boards/shields/cradio/Kconfig.shield8
-rw-r--r--app/boards/shields/cradio/cradio.dtsi50
-rw-r--r--app/boards/shields/cradio/cradio.keymap43
-rw-r--r--app/boards/shields/cradio/cradio_left.conf5
-rw-r--r--app/boards/shields/cradio/cradio_left.overlay7
-rw-r--r--app/boards/shields/cradio/cradio_right.conf5
-rw-r--r--app/boards/shields/cradio/cradio_right.overlay11
-rw-r--r--docs/docs/behavior/power.md64
-rw-r--r--docs/docs/intro.md62
-rw-r--r--docs/sidebars.js1
13 files changed, 268 insertions, 30 deletions
diff --git a/app/boards/shields/Kconfig.defconfig b/app/boards/shields/Kconfig.defconfig
new file mode 100644
index 0000000..5b9ca9a
--- /dev/null
+++ b/app/boards/shields/Kconfig.defconfig
@@ -0,0 +1,14 @@
+
+
+
+config ZMK_KEYBOARD_NAME
+ default "cradios"
+
+# Unable to use interrupts as the same pin number is used
+# across A & B controllers, and STM32F303CCT6 can't enable
+# interrutps for multiple controllers for the same "line"
+# for the external interrupts.
+config ZMK_KSCAN_GPIO_POLLING
+ default y
+
+
diff --git a/app/boards/shields/Kconfig.shield b/app/boards/shields/Kconfig.shield
new file mode 100644
index 0000000..844d433
--- /dev/null
+++ b/app/boards/shields/Kconfig.shield
@@ -0,0 +1,5 @@
+# Copyright (c) 2020 Pete Johanson
+# SPDX-License-Identifier: MIT
+
+config SHIELD_CRADIOS
+ def_bool $(shields_list_contains,cradios)
diff --git a/app/boards/shields/cradio/Kconfig.defconfig b/app/boards/shields/cradio/Kconfig.defconfig
new file mode 100644
index 0000000..4d200c9
--- /dev/null
+++ b/app/boards/shields/cradio/Kconfig.defconfig
@@ -0,0 +1,23 @@
+# Copyright (c) 2020 The ZMK Contributors
+# SPDX-License-Identifier: MIT
+
+if SHIELD_CRADIO_LEFT
+
+config ZMK_KEYBOARD_NAME
+ default "cradio left"
+
+endif
+
+if SHIELD_CRADIO_RIGHT
+
+config ZMK_KEYBOARD_NAME
+ default "cradio right"
+
+endif
+
+if SHIELD_CRADIO_RIGHT || SHIELD_CRADIO_LEFT
+
+config ZMK_KSCAN_DIRECT_POLLING
+ default y
+
+endif
diff --git a/app/boards/shields/cradio/Kconfig.shield b/app/boards/shields/cradio/Kconfig.shield
new file mode 100644
index 0000000..bb5f073
--- /dev/null
+++ b/app/boards/shields/cradio/Kconfig.shield
@@ -0,0 +1,8 @@
+# Copyright (c) 2020 The ZMK Contributors
+# SPDX-License-Identifier: MIT
+
+config SHIELD_CRADIO_LEFT
+ def_bool $(shields_list_contains,cradio_left)
+
+config SHIELD_CRADIO_RIGHT
+ def_bool $(shields_list_contains,cradio_right)
diff --git a/app/boards/shields/cradio/cradio.dtsi b/app/boards/shields/cradio/cradio.dtsi
new file mode 100644
index 0000000..43f9049
--- /dev/null
+++ b/app/boards/shields/cradio/cradio.dtsi
@@ -0,0 +1,50 @@
+/*
+ * Copyright (c) 2020 The ZMK Contributors
+ *
+ * SPDX-License-Identifier: MIT
+ */
+
+ #include <dt-bindings/zmk/matrix-transform.h>
+
+/ {
+ chosen {
+ zmk,kscan = &kscan0;
+ //zmk,matrix_transform = &default_transform;
+ };
+
+ default_transform: keymap_transform_0 {
+ compatible = "zmk,matrix-transform";
+ columns = <34>;
+ rows = <1>;
+ map = <
+ RC(0,0) RC(0,1) RC(0,2) RC(0,3) RC(0,4) RC(0,21) RC(0,20) RC(0,19) RC(0,18) RC(0,17)
+ RC(0,5) RC(0,6) RC(0,7) RC(0,8) RC(0,9) RC(0,26) RC(0,25) RC(0,24) RC(0,23) RC(0,22)
+ RC(0,10) RC(0,11) RC(0,12) RC(0,13) RC(0,14) RC(0,31) RC(0,30) RC(0,29) RC(0,28) RC(0,27)
+ RC(0,15) RC(0,16) RC(0,33) RC(0,32)
+ >;
+
+ kscan0: kscan {
+ compatible = "zmk,kscan-gpio-direct";
+ label = "KSCAN";
+ input-gpios
+ = <&pro_micro_d 7 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_a 0 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_a 1 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_a 2 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_a 3 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 15 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 14 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 16 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 10 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 1 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 2 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 3 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_a 6 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 5 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 6 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 8 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ , <&pro_micro_d 9 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>
+ ;
+ };
+ };
+ };
diff --git a/app/boards/shields/cradio/cradio.keymap b/app/boards/shields/cradio/cradio.keymap
new file mode 100644
index 0000000..487f6dc
--- /dev/null
+++ b/app/boards/shields/cradio/cradio.keymap
@@ -0,0 +1,43 @@
+/*
+ * Copyright (c) 2020 The ZMK Contributors
+ *
+ * SPDX-License-Identifier: MIT
+ */
+
+#include <behaviors.dtsi>
+#include <dt-bindings/zmk/keys.h>
+#include <dt-bindings/zmk/bt.h>
+
+
+/ {
+ keymap {
+ compatible = "zmk,keymap";
+
+ default_layer {
+ bindings = <
+ &kp Q &kp W &kp E &kp R &kp T &kp Y &kp U &kp I &kp O &kp P
+ &kp A &kp S &kp D &kp F &kp G &kp H &kp J &kp K &kp L &kp SCLN
+ &kp Z &kp X &kp C &kp V &kp B &kp N &kp M &kp CMMA &kp DOT &kp FSLH
+ &mo 1 &kp LCTL &kp SPC &mo 2
+ >;
+ };
+ upper_layer {
+ bindings = <
+ &kp NUM_1 &kp NUM_2 &kp NUM_3 &kp NUM_4 &kp NUM_5 &kp NUM_6 &kp NUM_7 &kp NUM_8 &kp NUM_9 &kp NUM_0
+ &bt BT_SEL 0 &bt BT_SEL 1 &bt BT_SEL 2 &bt BT_SEL 3 &bt BT_SEL 4 &kp H &kp J &kp K &kp L &kp SCLN
+ &kp LSFT &trans &trans &trans &trans &trans &trans &trans &trans &trans
+ &mo 1 &kp LCTL &kp SPC &mo 2
+ >;
+ };
+
+ lower_layer {
+ bindings = <
+ &kp BANG &kp ATSN &kp HASH &kp CURU &kp PRCT &kp CRRT &kp AMPS &kp KMLT &kp LPRN &kp RPRN
+ &trans &trans &trans &trans &trans &kp MINUS &kp EQL &kp LBKT &kp RBKT &kp PIPE
+ &trans &trans &trans &trans &trans &trans &trans &trans &kp BSLH &kp TILD
+ &mo 1 &kp LCTL &kp SPC &mo 2
+ >;
+ };
+
+ };
+};
diff --git a/app/boards/shields/cradio/cradio_left.conf b/app/boards/shields/cradio/cradio_left.conf
new file mode 100644
index 0000000..405f04d
--- /dev/null
+++ b/app/boards/shields/cradio/cradio_left.conf
@@ -0,0 +1,5 @@
+# Copyright (c) 2020 The ZMK Contributors
+# SPDX-License-Identifier: MIT
+
+CONFIG_ZMK_SPLIT=y
+CONFIG_ZMK_SPLIT_BLE_ROLE_CENTRAL=y
diff --git a/app/boards/shields/cradio/cradio_left.overlay b/app/boards/shields/cradio/cradio_left.overlay
new file mode 100644
index 0000000..6a3704a
--- /dev/null
+++ b/app/boards/shields/cradio/cradio_left.overlay
@@ -0,0 +1,7 @@
+/*
+ * Copyright (c) 2020 The ZMK Contributors
+ *
+ * SPDX-License-Identifier: MIT
+ */
+
+#include "cradio.dtsi"
diff --git a/app/boards/shields/cradio/cradio_right.conf b/app/boards/shields/cradio/cradio_right.conf
new file mode 100644
index 0000000..bd2c93b
--- /dev/null
+++ b/app/boards/shields/cradio/cradio_right.conf
@@ -0,0 +1,5 @@
+# Copyright (c) 2020 The ZMK Contributors
+# SPDX-License-Identifier: MIT
+
+CONFIG_ZMK_SPLIT=y
+CONFIG_ZMK_SPLIT_BLE_ROLE_PERIPHERAL=y
diff --git a/app/boards/shields/cradio/cradio_right.overlay b/app/boards/shields/cradio/cradio_right.overlay
new file mode 100644
index 0000000..01aa1ab
--- /dev/null
+++ b/app/boards/shields/cradio/cradio_right.overlay
@@ -0,0 +1,11 @@
+/*
+ * Copyright (c) 2020 The ZMK Contributors
+ *
+ * SPDX-License-Identifier: MIT
+ */
+
+#include "cradio.dtsi"
+
+&default_transform {
+ col-offset = <17>;
+};
diff --git a/docs/docs/behavior/power.md b/docs/docs/behavior/power.md
new file mode 100644
index 0000000..6b8237b
--- /dev/null
+++ b/docs/docs/behavior/power.md
@@ -0,0 +1,64 @@
+---
+title: Power Management Behaviors
+sidebar_label: Power Management
+---
+
+## Summary
+
+These page contains some of the power management behaviors currently supported by ZMK.
+
+## External Power Control
+
+The External power control behavior allows enabling or disabling the VCC power output
+to save power. Some of the LEDs will consume power even in OFF state. To preserve
+battery life in this scenario, some controller boards have support to disable the
+external power completely.
+
+The following boards currently support this feature:
+- nRFMicro
+- nice!nano
+
+## External Power Control Command Defines
+
+External power control command defines are provided through the [`dt-bindings/zmk/ext_power.h`](https://github.com/zmkfirmware/zmk/blob/main/app/include/dt-bindings/zmk/ext_power.h) header,
+which is added at the top of the keymap file:
+
+```
+#include <dt-bindings/zmk/ext_power.h>
+```
+
+This will allow you to reference the actions defined in this header such as `EXT_POWER_OFF_CMD`.
+
+Here is a table describing the command for each define:
+
+| Define | Action | Alias |
+| ------------ | -------------------------------------- | -------- |
+| `EXT_POWER_OFF_CMD` | Disable the external power. | `EP_OFF` |
+| `EXT_POWER_ON_CMD` | Enable the external power. | `EP_ON` |
+| `EXT_POWER_TOGGLE_CMD` | Toggle the external power. | `EP_TOG` |
+
+### Behavior Binding
+
+- Reference: `&ext_power`
+- Parameter#1: Command, e.g `EP_ON`
+
+### Example:
+
+1. Behavior binding to enable the external power
+
+ ```
+ &ext_power EP_ON
+ ```
+
+1. Behavior binding to disable the external power
+
+ ```
+ &ext_power EP_OFF
+ ```
+
+1. Behavior binding to toggle the external power
+
+ ```
+ &ext_power EP_TOG
+ ```
+
diff --git a/docs/docs/intro.md b/docs/docs/intro.md
index 8c1c043..60fe0d2 100644
--- a/docs/docs/intro.md
+++ b/docs/docs/intro.md
@@ -5,39 +5,41 @@ sidebar_label: Introduction
---
ZMK Firmware is an open source (MIT) keyboard
-firmware built on the [Zephyr™ Project](https://zephyrproject.org/) Real Time Operating System (RTOS).
-
-The goal is to provide a powerful, featureful keyboard firmware that is free
-of licensing issues that prevent upstream BLE support as a first-class
-feature.
+firmware built on the [Zephyr™ Project](https://zephyrproject.org/) Real Time Operating System (RTOS). ZMK's goal is to provide a modern, wireless, and powerful firmware free of licensing issues.
## Features
-At this point, ZMK is still missing many features. Currently, the working bits
-include:
-
-- Wireless connectivity via BLE HID Over GATT (HOG)
-- USB connectivity
-- Low active power usage
-- Split keyboard support
-- [Keymaps and layers](behavior/layers)
-- [Hold-tap](behavior/hold-tap) (which includes [mod-tap](behavior/mod-tap), [layer-tap](behavior/layers))
-- [Basic HID over USB](behavior/key-press)
-- [Basic consumer (media) keycodes](behavior/key-press#consumer-key-press)
-- [Encoders](feature/encoders)
-- Basic [OLED display support](feature/displays)
-- [RGB Underglow](feature/underglow)
-
-## Missing Features
-
-- One Shot Keys
-- Combo keys
-- Macros
-- Complete split support (encoders and RGB are not supported on the 'peripheral' side)
-- Battery reporting
-- Low power sleep states
-- Low power mode (to toggle LEDs and screen off)
-- Shell over BLE
+ZMK is currently missing some features found in other popular firmware. This table compares the features supported by ZMK, BlueMicro and QMK:
+
+
+| **Feature** | ZMK | BlueMicro | QMK |
+|--------------------------------------------------------------------------------------------------------|:-----------:|:------------:|:-----------:|
+| Low Latency BLE Support | ✅ | ✅ | |
+| Multi-Device BLE Support | ✅ | | |
+| USB Connectivity | ✅ | | ✅ |
+| User Configuration Repositories | ✅ | | |
+| Split Keyboard Support | ✅ | ✅ | ✅ |
+| [Keymaps and Layers](behavior/layers) | ✅ | ✅ | ✅ |
+| [Hold-Tap](behavior/hold-tap) (which includes [Mod-Tap](behavior/mod-tap) and [Layer-Tap](behavior/layers/#layer-tap)) | ✅ | ✅ | ✅ |
+| [Basic Keycodes](behavior/key-press) | ✅ | ✅ | ✅ |
+| [Basic consumer (Media) Keycodes](behavior/key-press#consumer-key-press) | ✅ | ✅ | ✅ |
+| [Encoders](feature/encoders)[^1] | ✅ | | ✅ |
+| [OLED Display Support](feature/displays)[^2] | 🚧 | 🚧 | ✅ |
+| [RGB Underglow](feature/underglow) | ✅ | ✅ | ✅ |
+| One Shot Keys | 🚧 | ✅ | ✅ |
+| Combo Keys | 🚧 | | ✅ |
+| Macros | 🚧 | ✅ | ✅ |
+| Mouse Keys | | ✅ | ✅ |
+| Low Active Power Usage | ✅ | | |
+| [Low Power Sleep States](https://github.com/zmkfirmware/zmk/pull/211) | 🚧 | ✅ | |
+| [Low Power Mode (VCC Shutoff)](https://github.com/zmkfirmware/zmk/pull/242) | 🚧 | | |
+| [Battery Reporting](https://github.com/zmkfirmware/zmk/issues/47) | 🚧 | ✅ | |
+| Shell over BLE | | | |
+| Realtime Keymap Updating | 💡 | | ✅ |
+| AVR/8 Bit | | | ✅ |
+| [Wide Range of ARM Chips Supported](https://docs.zephyrproject.org/latest/boards/index.html) | ✅ | | |
+[^2]: Encoders are not currently supported on peripheral side splits.
+[^1]: OLEDs are currently proof of concept in ZMK.
## Code Of Conduct
diff --git a/docs/sidebars.js b/docs/sidebars.js
index 93ce226..12b4a6e 100644
--- a/docs/sidebars.js
+++ b/docs/sidebars.js
@@ -23,6 +23,7 @@ module.exports = {
"behavior/reset",
"behavior/bluetooth",
"behavior/lighting",
+ "behavior/power",
],
Development: [
"dev-clean-room",