summaryrefslogtreecommitdiff
path: root/config/boards/arm/adv360
diff options
context:
space:
mode:
authorReFil <harryherring@gmail.com>2022-04-03 22:06:51 +0100
committerReFil <harryherring@gmail.com>2022-04-03 22:06:51 +0100
commit6aae0c6be2d58739cdc58b276a3797f479b09e5a (patch)
tree32dae3d8a6def0dab67c97cabc67cdf829471ee0 /config/boards/arm/adv360
parent0a38e2de04e0cb8d21b4cc0a4de4e431dca256b7 (diff)
Initial commit
Diffstat (limited to 'config/boards/arm/adv360')
-rw-r--r--config/boards/arm/adv360/CMakeLists.txt8
-rw-r--r--config/boards/arm/adv360/Kconfig7
-rw-r--r--config/boards/arm/adv360/Kconfig.board12
-rw-r--r--config/boards/arm/adv360/Kconfig.defconfig60
-rw-r--r--config/boards/arm/adv360/adv360.dtsi170
-rw-r--r--config/boards/arm/adv360/adv360.yaml19
-rw-r--r--config/boards/arm/adv360/adv360_left.dts47
-rw-r--r--config/boards/arm/adv360/adv360_left_defconfig84
-rw-r--r--config/boards/arm/adv360/adv360_right.dts54
-rw-r--r--config/boards/arm/adv360/adv360_right_defconfig83
-rw-r--r--config/boards/arm/adv360/board.cmake9
11 files changed, 553 insertions, 0 deletions
diff --git a/config/boards/arm/adv360/CMakeLists.txt b/config/boards/arm/adv360/CMakeLists.txt
new file mode 100644
index 0000000..7b388db
--- /dev/null
+++ b/config/boards/arm/adv360/CMakeLists.txt
@@ -0,0 +1,8 @@
+set_property(GLOBAL APPEND PROPERTY extra_post_build_commands
+ COMMAND ${PYTHON_EXECUTABLE} ${ZEPHYR_BASE}/../tools/uf2/utils/uf2conv.py
+ -c
+ -b 0x26000
+ -f 0xADA52840
+ -o ${PROJECT_BINARY_DIR}/${CONFIG_KERNEL_BIN_NAME}.uf2
+ ${PROJECT_BINARY_DIR}/${CONFIG_KERNEL_BIN_NAME}.bin
+)
diff --git a/config/boards/arm/adv360/Kconfig b/config/boards/arm/adv360/Kconfig
new file mode 100644
index 0000000..148ad95
--- /dev/null
+++ b/config/boards/arm/adv360/Kconfig
@@ -0,0 +1,7 @@
+# SPDX-License-Identifier: MIT
+
+config BOARD_ENABLE_DCDC
+ bool "Enable DCDC mode"
+ select SOC_DCDC_NRF52X
+ default y
+ depends on BOARD_BT60
diff --git a/config/boards/arm/adv360/Kconfig.board b/config/boards/arm/adv360/Kconfig.board
new file mode 100644
index 0000000..cacf2cf
--- /dev/null
+++ b/config/boards/arm/adv360/Kconfig.board
@@ -0,0 +1,12 @@
+#
+# Copyright (c) 2021 Polarity Works
+# SPDX-License-Identifier: MIT
+#
+
+config BOARD_ADV360_LEFT
+ bool "adv360_left"
+ depends on SOC_NRF52840_QIAA
+
+config BOARD_ADV360_RIGHT
+ bool "adv360_right"
+ depends on SOC_NRF52840_QIAA
diff --git a/config/boards/arm/adv360/Kconfig.defconfig b/config/boards/arm/adv360/Kconfig.defconfig
new file mode 100644
index 0000000..9d60f88
--- /dev/null
+++ b/config/boards/arm/adv360/Kconfig.defconfig
@@ -0,0 +1,60 @@
+#
+# Copyright (c) 2021 Polarity Works
+# SPDX-License-Identifier: MIT
+#
+
+if BOARD_ADV360_LEFT
+
+ config ZMK_KEYBOARD_NAME
+ default "Adv360 Pro"
+
+endif # BOARD_ADV360_LEFT
+
+if BOARD_ADV360_RIGHT
+
+ config ZMK_KEYBOARD_NAME
+ default "Adv360 Pro rt"
+
+endif # BOARD_ADV360_RIGHT
+
+
+if BOARD_ADV360_LEFT || BOARD_ADV360_RIGHT
+
+config BOARD
+ default "adv360"
+
+config ZMK_SPLIT
+ default y
+
+config SPI
+ bool
+ default y
+
+config BT_CTLR
+ default BT
+
+config ZMK_BLE
+ default y
+
+config ZMK_USB
+ default y
+
+if USB
+
+config USB_NRFX
+ default y
+
+config USB_DEVICE_STACK
+ default y
+
+endif # USB
+
+config ZMK_BATTERY_VOLTAGE_DIVIDER
+ default y
+
+config SPI
+ default y
+
+
+
+endif # BOARD_ADV360_LEFT || BOARD_ADV360_RIGHT
diff --git a/config/boards/arm/adv360/adv360.dtsi b/config/boards/arm/adv360/adv360.dtsi
new file mode 100644
index 0000000..c25243b
--- /dev/null
+++ b/config/boards/arm/adv360/adv360.dtsi
@@ -0,0 +1,170 @@
+/*
+*
+* Copyright (c) 2021 Polarity Works
+* SPDX-License-Identifier: MIT
+*
+*/
+
+/dts-v1/;
+#include <nordic/nrf52840_qiaa.dtsi>
+
+#include <dt-bindings/zmk/matrix_transform.h>
+
+/ {
+ model = "Adv360";
+ compatible = "adv360";
+
+ chosen {
+ zephyr,code-partition = &code_partition;
+ zephyr,sram = &sram0;
+ zephyr,flash = &flash0;
+ zmk,kscan = &kscan0;
+ zmk,underglow = &led_strip;
+ zmk,backlight = &backlight;
+ zmk,matrix_transform = &default_transform;
+ };
+
+ default_transform: keymap_transform_0 {
+ compatible = "zmk,matrix-transform";
+ columns = <22>;
+ rows = <5>;
+
+
+ map = <
+ RC(4,0) RC(4,1) RC(4,2) RC(4,3) RC(4,4) RC(4,5) RC(4,6) RC(4,15) RC(4,16) RC(4,17) RC(4,18) RC(4,19) RC(4,20) RC(4,21)
+ RC(3,0) RC(3,1) RC(3,2) RC(3,3) RC(3,4) RC(3,5) RC(3,6) RC(3,15) RC(3,16) RC(3,17) RC(3,18) RC(3,19) RC(3,20) RC(3,21)
+ RC(2,0) RC(2,1) RC(2,2) RC(2,3) RC(2,4) RC(2,5) RC(2,6) RC(2,8) RC(2,9) RC(2,12) RC(2,13) RC(2,15) RC(2,16) RC(2,17) RC(2,18) RC(2,19) RC(2,20) RC(2,21)
+ RC(1,0) RC(1,1) RC(1,2) RC(1,3) RC(1,4) RC(1,5) RC(1,7) RC(1,8) RC(1,9) RC(1,10) RC(1,11) RC(1,12) RC(1,13) RC(1,14) RC(1,16) RC(1,17) RC(1,18) RC(1,19) RC(1,20) RC(1,21)
+ RC(0,0) RC(0,1) RC(0,2) RC(0,3) RC(0,4) RC(0,7) RC(0,8) RC(0,9) RC(0,12) RC(0,13) RC(0,14) RC(0,17) RC(0,18) RC(0,19) RC(0,20) RC(0,21)
+
+ >;
+ };
+ ext-power {
+ compatible = "zmk,ext-power-generic";
+ label = "EXT_POWER";
+ control-gpios = <&gpio0 13 GPIO_ACTIVE_HIGH>;
+ };
+ backlight: pwmleds {
+ compatible = "pwm-leds";
+ label = "Backlight LEDs";
+ pwm_led_0 {
+ pwms = <&pwm0 17>;
+ label = "Backlight LED 0";
+ };
+
+};
+ leds {
+ compatible = "gpio-leds";
+ blue_led: led_0 {
+ gpios = <&gpio0 15 GPIO_ACTIVE_HIGH>;
+ label = "Blue LED";
+ };
+ };
+
+ vbatt {
+ compatible = "zmk,battery-voltage-divider";
+ label = "BATTERY";
+ io-channels = <&adc 2>;
+ output-ohms = <100000>;
+ full-ohms = <(100000 + 100000)>;
+ };
+};
+
+&pwm0 {
+ status = "okay";
+ ch0-pin = <17>;
+};
+
+&adc {
+ status = "okay";
+};
+
+&gpiote {
+ status = "okay";
+};
+
+&gpio0 {
+ status = "okay";
+};
+
+&gpio1 {
+ status = "okay";
+};
+
+&usbd {
+ status = "okay";
+};
+
+&uart0 {
+ compatible = "nordic,nrf-uarte";
+ status = "okay";
+ current-speed = <115200>;
+ tx-pin = <39>;
+ rx-pin = <44>;
+ rts-pin = <34>;
+ cts-pin = <9>;
+};
+
+
+&flash0 {
+ /*
+ * For more information, see:
+ * http://docs.zephyrproject.org/latest/devices/dts/flash_partitions.html
+ */
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ sd_partition: partition@0 {
+ label = "softdevice";
+ reg = <0x00000000 0x00026000>;
+ };
+ code_partition: partition@26000 {
+ label = "code_partition";
+ reg = <0x00026000 0x000c6000>;
+ };
+
+ /*
+ * The flash starting at 0x000ec000 and ending at
+ * 0x000f3fff is reserved for use by the application.
+ */
+
+ /*
+ * Storage partition will be used by FCB/LittleFS/NVS
+ * if enabled.
+ */
+ storage_partition: partition@ec000 {
+ label = "storage";
+ reg = <0x000ec000 0x00008000>;
+ };
+
+ boot_partition: partition@f4000 {
+ label = "adafruit_boot";
+ reg = <0x000f4000 0x0000c000>;
+ };
+ };
+};
+
+&spi1 {
+ compatible = "nordic,nrf-spim";
+ status = "okay";
+ mosi-pin = <20>;
+ // Unused pins, needed for SPI definition, but not used by the ws2812 driver itself.
+ sck-pin = <27>;
+ miso-pin = <8>;
+
+ led_strip: ws2812@0 {
+ compatible = "worldsemi,ws2812-spi";
+ label = "WS2812";
+
+ /* SPI */
+ reg = <0>;
+ spi-max-frequency = <4000000>;
+
+ /* WS2812 */
+ chain-length = <3>; /* number of LEDs */
+ spi-one-frame = <0x70>;
+ spi-zero-frame = <0x40>;
+ };
+};
diff --git a/config/boards/arm/adv360/adv360.yaml b/config/boards/arm/adv360/adv360.yaml
new file mode 100644
index 0000000..1cefe88
--- /dev/null
+++ b/config/boards/arm/adv360/adv360.yaml
@@ -0,0 +1,19 @@
+identifier: adv360
+name: Adv360
+type: keyboard
+arch: arm
+toolchain:
+ - zephyr
+ - gnuarmemb
+ - xtools
+supported:
+ - gpio
+ - i2c
+ - counter
+ - spi
+ - usb_device
+ - nvs
+ - can
+ - kscan
+ - ble
+ - pwm
diff --git a/config/boards/arm/adv360/adv360_left.dts b/config/boards/arm/adv360/adv360_left.dts
new file mode 100644
index 0000000..8055fd1
--- /dev/null
+++ b/config/boards/arm/adv360/adv360_left.dts
@@ -0,0 +1,47 @@
+/*
+*
+* Copyright (c) 2021 Polarity Works
+* SPDX-License-Identifier: MIT
+*
+*/
+
+#include "adv360.dtsi"
+
+/{
+ kscan0: kscan {
+ compatible = "zmk,kscan-gpio-matrix";
+ label = "KSCAN";
+
+ diode-direction = "col2row";
+ row-gpios
+ = <&gpio1 11 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio1 15 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio0 3 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio1 14 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio1 12 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ ;
+
+ col-gpios
+ = <&gpio0 25 GPIO_ACTIVE_HIGH>
+ , <&gpio0 11 GPIO_ACTIVE_HIGH>
+ , <&gpio0 2 GPIO_ACTIVE_HIGH>
+ , <&gpio0 28 GPIO_ACTIVE_HIGH>
+ , <&gpio0 29 GPIO_ACTIVE_HIGH>
+ , <&gpio0 30 GPIO_ACTIVE_HIGH>
+ , <&gpio0 31 GPIO_ACTIVE_HIGH>
+ , <&gpio1 9 GPIO_ACTIVE_HIGH>
+ , <&gpio0 12 GPIO_ACTIVE_HIGH>
+ , <&gpio0 7 GPIO_ACTIVE_HIGH>
+ , <&gpio0 5 GPIO_ACTIVE_HIGH>
+ ;
+ };
+
+ leds {
+ compatible = "gpio-leds";
+ blue_led: led_0 {
+ gpios = <&gpio0 15 GPIO_ACTIVE_HIGH>;
+ label = "Blue LED";
+ };
+ };
+
+};
diff --git a/config/boards/arm/adv360/adv360_left_defconfig b/config/boards/arm/adv360/adv360_left_defconfig
new file mode 100644
index 0000000..8972881
--- /dev/null
+++ b/config/boards/arm/adv360/adv360_left_defconfig
@@ -0,0 +1,84 @@
+#
+# Copyright (c) 2021 Polarity Works
+# SPDX-License-Identifier: MIT
+#
+
+CONFIG_SOC_SERIES_NRF52X=y
+CONFIG_SOC_NRF52840_QIAA=y
+CONFIG_BOARD_ADV360_LEFT=y
+CONFIG_ZMK_SPLIT=y
+CONFIG_ZMK_SPLIT_BLE=y
+CONFIG_ZMK_SPLIT_BLE_ROLE_CENTRAL=y
+
+# Enable MPU
+CONFIG_ARM_MPU=y
+
+# enable GPIO
+CONFIG_GPIO=y
+
+
+# Enable SPI
+CONFIG_SPI=y
+
+CONFIG_SPI_NRFX=y
+
+# Enable writing to flash
+CONFIG_USE_DT_CODE_PARTITION=y
+CONFIG_MPU_ALLOW_FLASH_WRITE=y
+CONFIG_NVS=y
+CONFIG_SETTINGS_NVS=y
+CONFIG_FLASH=y
+CONFIG_FLASH_PAGE_LAYOUT=y
+CONFIG_FLASH_MAP=y
+
+# Enable 32kHz crystal
+CONFIG_CLOCK_CONTROL_NRF_K32SRC_XTAL=y
+CONFIG_CLOCK_CONTROL_NRF_K32SRC_30PPM=y
+
+CONFIG_ZMK_RGB_UNDERGLOW=y
+CONFIG_ZMK_RGB_UNDERGLOW_EXT_POWER=y
+CONFIG_ZMK_RGB_UNDERGLOW_ON_START=y
+CONFIG_ZMK_RGB_UNDERGLOW_EFF_START=4
+CONFIG_ZMK_RGB_UNDERGLOW_AUTO_OFF_IDLE=y
+
+# Use the STRIP config specific to the LEDs you're using
+CONFIG_WS2812_STRIP=y
+CONFIG_BT_CTLR_TX_PWR_PLUS_8=y
+CONFIG_PWM=y
+CONFIG_ZMK_LED_PWM=y
+CONFIG_ZMK_BACKLIGHT=y
+CONFIG_ZMK_BACKLIGHT_BRT_START=20
+CONFIG_ZMK_BACKLIGHT_AUTO_OFF_IDLE=y
+
+CONFIG_ZMK_HID_REPORT_TYPE_NKRO=y
+CONFIG_ZMK_HID_CONSUMER_REPORT_USAGES_BASIC=y
+
+
+# Turn on logging, and set ZMK logging to debug output
+CONFIG_LOG=y
+CONFIG_ZMK_USB_LOGGING=y
+CONFIG_ZMK_LOG_LEVEL_DBG=y
+CONFIG_LOG_BUFFER_SIZE=65536
+CONFIG_LOG_STRDUP_BUF_COUNT=160
+#CONFIG_I2C_LOG_LEVEL_DBG=y
+#CONFIG_SPI_LOG_LEVEL_DBG=y
+
+
+# Turn on USB CDC ACM device
+CONFIG_USB=y
+CONFIG_USB_DEVICE_STACK=y
+CONFIG_USB_CDC_ACM=y
+CONFIG_USB_CDC_ACM_RINGBUF_SIZE=1024
+CONFIG_USB_CDC_ACM_DEVICE_NAME="CDC_ACM"
+CONFIG_USB_CDC_ACM_DEVICE_COUNT=1
+
+# Enable serial console
+CONFIG_SERIAL=y
+CONFIG_CONSOLE=y
+CONFIG_UART_INTERRUPT_DRIVEN=y
+CONFIG_UART_LINE_CTRL=y
+
+# Enable USB UART, and set the console device
+CONFIG_UART_CONSOLE=y
+CONFIG_USB_UART_CONSOLE=y
+CONFIG_UART_CONSOLE_ON_DEV_NAME="CDC_ACM_0"
diff --git a/config/boards/arm/adv360/adv360_right.dts b/config/boards/arm/adv360/adv360_right.dts
new file mode 100644
index 0000000..afd38f3
--- /dev/null
+++ b/config/boards/arm/adv360/adv360_right.dts
@@ -0,0 +1,54 @@
+/*
+*
+* Copyright (c) 2021 Polarity Works
+* SPDX-License-Identifier: MIT
+*
+*/
+
+#include "adv360.dtsi"
+
+/{
+
+
+
+ kscan0: kscan {
+ compatible = "zmk,kscan-gpio-matrix";
+ label = "KSCAN";
+
+ diode-direction = "col2row";
+ row-gpios
+ = <&gpio0 19 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio0 5 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio0 31 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio0 30 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ , <&gpio0 29 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>
+ ;
+
+ col-gpios
+ = <&gpio1 14 GPIO_ACTIVE_HIGH>
+ , <&gpio0 12 GPIO_ACTIVE_HIGH>
+ , <&gpio1 9 GPIO_ACTIVE_HIGH>
+ , <&gpio0 7 GPIO_ACTIVE_HIGH>
+ , <&gpio1 11 GPIO_ACTIVE_HIGH>
+ , <&gpio1 10 GPIO_ACTIVE_HIGH>
+ , <&gpio1 13 GPIO_ACTIVE_HIGH>
+ , <&gpio1 15 GPIO_ACTIVE_HIGH>
+ , <&gpio0 3 GPIO_ACTIVE_HIGH>
+ , <&gpio0 2 GPIO_ACTIVE_HIGH>
+ , <&gpio0 28 GPIO_ACTIVE_HIGH>
+ ;
+ };
+
+ leds {
+ compatible = "gpio-leds";
+ blue_led: led_0 {
+ gpios = <&gpio0 15 GPIO_ACTIVE_HIGH>;
+ label = "Blue LED";
+ };
+ };
+
+};
+
+&default_transform {
+ col-offset = <11>;
+ };
diff --git a/config/boards/arm/adv360/adv360_right_defconfig b/config/boards/arm/adv360/adv360_right_defconfig
new file mode 100644
index 0000000..ebad2a4
--- /dev/null
+++ b/config/boards/arm/adv360/adv360_right_defconfig
@@ -0,0 +1,83 @@
+#
+# Copyright (c) 2021 Polarity Works
+# SPDX-License-Identifier: MIT
+#
+
+CONFIG_SOC_SERIES_NRF52X=y
+CONFIG_SOC_NRF52840_QIAA=y
+CONFIG_BOARD_ADV360_RIGHT=y
+CONFIG_ZMK_SPLIT_BLE=y
+#CONFIG_ZMK_SPLIT_BLE_ROLE_PERIPHERAL=y
+
+# Enable MPU
+CONFIG_ARM_MPU=y
+
+# enable GPIO
+CONFIG_GPIO=y
+
+
+
+# Enable SPI
+CONFIG_SPI=y
+CONFIG_SPI_NRFX=y
+
+# Enable writing to flash
+CONFIG_USE_DT_CODE_PARTITION=y
+CONFIG_MPU_ALLOW_FLASH_WRITE=y
+CONFIG_NVS=y
+CONFIG_SETTINGS_NVS=y
+CONFIG_FLASH=y
+CONFIG_FLASH_PAGE_LAYOUT=y
+CONFIG_FLASH_MAP=y
+
+# Enable 32kHz crystal
+CONFIG_CLOCK_CONTROL_NRF_K32SRC_XTAL=y
+CONFIG_CLOCK_CONTROL_NRF_K32SRC_30PPM=y
+
+CONFIG_ZMK_RGB_UNDERGLOW=y
+CONFIG_ZMK_RGB_UNDERGLOW_EXT_POWER=y
+CONFIG_ZMK_RGB_UNDERGLOW_ON_START=y
+CONFIG_ZMK_RGB_UNDERGLOW_EFF_START=4
+CONFIG_ZMK_RGB_UNDERGLOW_AUTO_OFF_IDLE=y
+
+# Use the STRIP config specific to the LEDs you're using
+CONFIG_WS2812_STRIP=y
+CONFIG_BT_CTLR_TX_PWR_PLUS_8=y
+CONFIG_PWM=y
+CONFIG_ZMK_LED_PWM=y
+CONFIG_ZMK_BACKLIGHT=y
+CONFIG_ZMK_BACKLIGHT_BRT_START=20
+CONFIG_ZMK_BACKLIGHT_AUTO_OFF_IDLE=y
+
+CONFIG_ZMK_HID_REPORT_TYPE_NKRO=y
+CONFIG_ZMK_HID_CONSUMER_REPORT_USAGES_BASIC=y
+
+
+# Turn on logging, and set ZMK logging to debug output
+CONFIG_LOG=y
+CONFIG_ZMK_USB_LOGGING=y
+CONFIG_ZMK_LOG_LEVEL_DBG=y
+CONFIG_LOG_BUFFER_SIZE=10000
+CONFIG_LOG_STRDUP_BUF_COUNT=60
+#CONFIG_I2C_LOG_LEVEL_DBG=y
+#CONFIG_SPI_LOG_LEVEL_DBG=y
+
+
+# Turn on USB CDC ACM device
+CONFIG_USB=y
+CONFIG_USB_DEVICE_STACK=y
+CONFIG_USB_CDC_ACM=y
+CONFIG_USB_CDC_ACM_RINGBUF_SIZE=1024
+CONFIG_USB_CDC_ACM_DEVICE_NAME="CDC_ACM"
+CONFIG_USB_CDC_ACM_DEVICE_COUNT=1
+
+# Enable serial console
+CONFIG_SERIAL=y
+CONFIG_CONSOLE=y
+CONFIG_UART_INTERRUPT_DRIVEN=y
+CONFIG_UART_LINE_CTRL=y
+
+# Enable USB UART, and set the console device
+CONFIG_UART_CONSOLE=y
+CONFIG_USB_UART_CONSOLE=y
+CONFIG_UART_CONSOLE_ON_DEV_NAME="CDC_ACM_0"
diff --git a/config/boards/arm/adv360/board.cmake b/config/boards/arm/adv360/board.cmake
new file mode 100644
index 0000000..4eb4820
--- /dev/null
+++ b/config/boards/arm/adv360/board.cmake
@@ -0,0 +1,9 @@
+#
+# Copyright (c) 2021 Polarity Works
+# SPDX-License-Identifier: MIT
+#
+
+board_runner_args(nrfjprog "--nrf-family=NRF52" "--softreset")
+
+include(${ZEPHYR_BASE}/boards/common/nrfjprog.board.cmake)
+#include(${ZEPHYR_BASE}/boards/common/blackmagicprobe.board.cmake)