From 4835412986d12b2e7a86b111a84da7465272422f Mon Sep 17 00:00:00 2001 From: Sam Date: Mon, 4 Nov 2024 12:59:27 -0500 Subject: [PATCH] samnrf --- boards/shields/samnrf/.DS_Store | Bin 0 -> 6148 bytes boards/shields/samnrf/Kconfig | 5 + boards/shields/samnrf/Kconfig.board | 3 + boards/shields/samnrf/Kconfig.defconfig | 22 ++++ boards/shields/samnrf/README.md | 9 ++ boards/shields/samnrf/board.cmake | 7 ++ boards/shields/samnrf/samnrf.dts | 151 ++++++++++++++++++++++++ boards/shields/samnrf/samnrf.keymap | 89 ++++++++++++++ boards/shields/samnrf/samnrf.yaml | 14 +++ boards/shields/samnrf/samnrf.zmk.yml | 11 ++ boards/shields/samnrf/samnrf_defconfig | 21 ++++ build.yaml | 3 +- 12 files changed, 334 insertions(+), 1 deletion(-) create mode 100644 boards/shields/samnrf/.DS_Store create mode 100644 boards/shields/samnrf/Kconfig create mode 100644 boards/shields/samnrf/Kconfig.board create mode 100644 boards/shields/samnrf/Kconfig.defconfig create mode 100644 boards/shields/samnrf/README.md create mode 100644 boards/shields/samnrf/board.cmake create mode 100644 boards/shields/samnrf/samnrf.dts create mode 100644 boards/shields/samnrf/samnrf.keymap create mode 100644 boards/shields/samnrf/samnrf.yaml create mode 100644 boards/shields/samnrf/samnrf.zmk.yml create mode 100644 boards/shields/samnrf/samnrf_defconfig diff --git a/boards/shields/samnrf/.DS_Store b/boards/shields/samnrf/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..5008ddfcf53c02e82d7eee2e57c38e5672ef89f6 GIT binary patch literal 6148 zcmeH~Jr2S!425mzP>H1@V-^m;4Wg<&0T*E43hX&L&p$$qDprKhvt+--jT7}7np#A3 zem<@ulZcFPQ@L2!n>{z**++&mCkOWA81W14cNZlEfg7;MkzE(HCqgga^y>{tEnwC%0;vJ&^%eQ zLs35+`xjp>T0 + +#include + +/ { + model = "samnrf"; + compatible = "samnrf"; + + chosen { + zephyr,code-partition = &code_partition; + zephyr,sram = &sram0; + zephyr,flash = &flash0; + zephyr,console = &cdc_acm_uart; + zmk,battery = &vbatt; + zmk,kscan = &kscan0; + zmk,matrix_transform = &default_transform; + }; + + default_transform: keymap_transform_0 { + compatible = "zmk,matrix-transform"; + columns = <15>; + rows = <6>; + // | MX1 | MX7 | MX13 | MX19 | MX25 | MX30 | MX35 | MX41 | MX46 | MX51 | MX57 | MX63 | MX69 | MX75 | MX80 | | MX81 | + // | MX2 | MX8 | MX14 | MX20 | MX26 | MX31 | MX36 | MX42 | MX47 | MX52 | MX58 | MX64 | MX70 | MX76 | | MX82 | + // | MX3 | MX9 | MX15 | MX21 | MX27 | MX32 | MX37 | MX43 | MX48 | MX53 | MX59 | MX65 | MX71 | MX77 | | MX79 | + // | MX4 | MX10 | MX16 | MX22 | MX28 | MX33 | MX38 | MX44 | MX49 | MX54 | MX60 | MX66 | MX72 | | MX83 | + // | MX5 | MX11 | MX17 | MX23 | MX29 | MX34 | MX39 | MX45 | MX50 | MX55 | MX61 | MX67 | MX73 | MX73 | + // | MX6 | MX12 | MX18 | MX24 | MX40 | MX56 | MX62 | MX68 | MX74 | MX78 | + map = < + RC(0,0) RC(0,1) RC(0,2) RC(0,3) RC(0,4) RC(0,5) RC(0,6) RC(0,7) RC(0,8) RC(0,9) RC(0,10) RC(0,11) RC(0,12) RC(0,13) RC(0,14) RC(1,14) + RC(1,0) RC(1,1) RC(1,2) RC(1,3) RC(1,4) RC(1,5) RC(1,6) RC(1,7) RC(1,8) RC(1,9) RC(1,10) RC(1,11) RC(1,12) RC(1,13) RC(2,14) + RC(2,0) RC(2,1) RC(2,2) RC(2,3) RC(2,4) RC(2,5) RC(2,6) RC(2,7) RC(2,8) RC(2,9) RC(2,10) RC(2,11) RC(2,12) RC(2,13) RC(3,13) + RC(3,0) RC(3,1) RC(3,2) RC(3,3) RC(3,4) RC(3,5) RC(3,6) RC(3,7) RC(3,8) RC(3,9) RC(3,10) RC(3,11) RC(3,12) RC(4,13) + RC(4,0) RC(4,1) RC(4,2) RC(4,3) RC(4,4) RC(4,5) RC(4,6) RC(4,7) RC(4,8) RC(4,9) RC(4,10) RC(4,11) RC(4,12) + RC(5,0) RC(5,1) RC(5,2) RC(5,3) RC(5,6) RC(5,9) RC(5,10) RC(5,11) RC(5,12) RC(5,13) + >; + }; + + kscan0: kscan { + compatible = "zmk,kscan-gpio-matrix"; + label = "KSCAN"; + + diode-direction = "col2row"; + col-gpios + = <&gpio0 7 GPIO_ACTIVE_HIGH> + , <&gpio0 12 GPIO_ACTIVE_HIGH> + , <&gpio0 4 GPIO_ACTIVE_HIGH> + , <&gpio0 8 GPIO_ACTIVE_HIGH> + , <&gpio1 11 GPIO_ACTIVE_HIGH> + , <&gpio0 26 GPIO_ACTIVE_HIGH> + , <&gpio0 6 GPIO_ACTIVE_HIGH> + , <&gpio0 30 GPIO_ACTIVE_HIGH> + , <&gpio0 5 GPIO_ACTIVE_HIGH> + , <&gpio0 22 GPIO_ACTIVE_HIGH> + , <&gpio1 2 GPIO_ACTIVE_HIGH> + , <&gpio1 6 GPIO_ACTIVE_HIGH> + , <&gpio0 20 GPIO_ACTIVE_HIGH> + , <&gpio0 17 GPIO_ACTIVE_HIGH> + , <&gpio0 15 GPIO_ACTIVE_HIGH> + ; + + row-gpios + = <&gpio0 3 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&gpio0 28 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&gpio1 13 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&gpio0 2 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&gpio0 29 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&gpio0 10 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + ; + }; + + vbatt: vbatt { + compatible = "zmk,battery-voltage-divider"; + label = "BATTERY"; + io-channels = <&adc 7>; + output-ohms = <2000000>; + full-ohms = <(2000000 + 806000)>; + }; +}; + +&adc { + status = "okay"; +}; + +&gpiote { + status = "okay"; +}; + +&gpio0 { + status = "okay"; +}; + +&gpio1 { + status = "okay"; +}; + +&usbd { + status = "okay"; + cdc_acm_uart: cdc_acm_uart { + compatible = "zephyr,cdc-acm-uart"; + label = "CDC_ACM_0"; + }; +}; + +&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 = "mbr"; + reg = <0x00000000 0x00001000>; + }; + + code_partition: partition@1000 { + label = "code_partition"; + reg = <0x00001000 0x000d3000>; + }; + + /* + * The flash starting at 0x000d4000 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@d4000 { + label = "storage"; + reg = <0x000d4000 0x00020000>; + }; + + boot_partition: partition@f4000 { + label = "adafruit_boot"; + reg = <0x000f4000 0x0000c000>; + }; + }; +}; diff --git a/boards/shields/samnrf/samnrf.keymap b/boards/shields/samnrf/samnrf.keymap new file mode 100644 index 0000000..1cc936c --- /dev/null +++ b/boards/shields/samnrf/samnrf.keymap @@ -0,0 +1,89 @@ +#include +#include +#include + +/ { + macros { + screenshot_full: screenshot_full { + label = "SA_screenshot_full"; + compatible = "zmk,behavior-macro"; + #binding-cells = <0>; + bindings + = <¯o_press &kp LSHFT> + , <¯o_press &kp LGUI> + , <¯o_press &kp N1> + , <¯o_release &kp LSHFT> + , <¯o_release &kp LGUI> + , <¯o_release &kp N1> + ; + }; + screenshot_part: screenshot_part { + label = "SA_screenshot_part"; + compatible = "zmk,behavior-macro"; + #binding-cells = <0>; + bindings + = <¯o_press &kp LSHFT> + , <¯o_press &kp LGUI> + , <¯o_press &kp N2> + , <¯o_release &kp LSHFT> + , <¯o_release &kp LGUI> + , <¯o_release &kp N2> + ; + }; + }; + + keymap { + compatible = "zmk,keymap"; + + default_layer { + +// | MX1 | MX7 | MX13 | MX19 | MX25 | MX30 | MX35 | MX41 | MX46 | MX51 | MX57 | MX63 | MX69 | MX75 | MX80 | | MX81 | +// | MX2 | MX8 | MX14 | MX20 | MX26 | MX31 | MX36 | MX42 | MX47 | MX52 | MX58 | MX64 | MX70 | MX76 | | MX82 | +// | MX3 | MX9 | MX15 | MX21 | MX27 | MX32 | MX37 | MX43 | MX48 | MX53 | MX59 | MX65 | MX71 | MX77 | | MX79 | +// | MX4 | MX10 | MX16 | MX22 | MX28 | MX33 | MX38 | MX44 | MX49 | MX54 | MX60 | MX66 | MX72 | | MX83 | +// | MX5 | MX11 | MX17 | MX23 | MX29 | MX34 | MX39 | MX45 | MX50 | MX55 | MX61 | MX67 | MX73 | MX73 | +// | MX6 | MX12 | MX18 | MX24 | MX40 | MX56 | MX62 | MX68 | MX74 | MX78 | + + +// ------------------------------------------------------------------------------------------ +// | ESC | f1 | f2 | f3 | f4 | f5 | f5 | f6 | f7 | f8 | f9 | f10 | f11 | f12 | f13 | f14 | Full Screenshot | +// | ~ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | BKSP | Selection Screenshot | +// | TAB | Q | W | E | R | T | Y | U | I | O | P | [ | ] | "|" | | MO(1) | +// | CAPS | A | S | D | F | G | H | J | K | L | ; | ' | ENTER | | Delete | +// | SHIFT | Z | X | C | V | B | N | M | , | . | / | SHIFT | UP | +// | FN | CTL | ALT | WIN | SPACE | WIN | ALT | LEFT | DN | RIGHT | +// ------------------------------------------------------------------------------------------ + bindings = < + &gresc &kp C_BRI_DN &kp C_BRI_UP &kp C_AC_DESKTOP_SHOW_ALL_WINDOWS &kp C_AC_DESKTOP_SHOW_ALL_APPLICATIONS &kp F5 &kp F6 &kp F7 &kp F8 &kp C_PREV &kp C_PP &kp C_NEXT &kp C_MUTE &kp C_VOL_DN &kp C_VOL_UP &screenshot_full + &kp GRAVE &kp N1 &kp N2 &kp N3 &kp N4 &kp N5 &kp N6 &kp N7 &kp N8 &kp N9 &kp N0 &kp MINUS &kp EQUAL &kp BSPC &screenshot_part + &kp TAB &kp Q &kp W &kp E &kp R &kp T &kp Y &kp U &kp I &kp O &kp P &kp LBKT &kp RBKT &kp BSLH &mo 2 + &kp CLCK &kp A &kp S &kp D &kp F &kp G &kp H &kp J &kp K &kp L &kp SEMI &kp SQT &kp RET &kp DEL + &kp LSHFT &kp Z &kp X &kp C &kp V &kp B &kp N &kp M &kp COMMA &kp DOT &kp FSLH &kp RSHFT &kp UP + &mo 1 &kp LCTRL &kp LALT &kp LGUI &kp SPACE &kp RGUI &kp RALT &kp LEFT &kp DOWN &kp RIGHT + >; + }; + + fn_layer { + bindings = < + &trans &kp F1 &kp F2 &kp F3 &kp F4 &kp F5 &kp F6 &kp F7 &kp F8 &kp F9 &kp F10 &kp F11 &kp F12 &kp F13 &kp F14 &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + >; + }; + + blue_layer { + bindings = < + &trans &bt BT_SEL 1 &bt BT_SEL 2 &bt BT_SEL 3 &bt BT_SEL 4 &bt BT_SEL 5 &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &bt BT_CLR &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + &trans &trans &trans &trans &trans &trans &trans &trans &trans &trans + >; + }; + + }; +}; diff --git a/boards/shields/samnrf/samnrf.yaml b/boards/shields/samnrf/samnrf.yaml new file mode 100644 index 0000000..018c448 --- /dev/null +++ b/boards/shields/samnrf/samnrf.yaml @@ -0,0 +1,14 @@ +identifier: samnrf +name: samnrf +type: mcu +arch: arm +toolchain: + - zephyr + - gnuarmemb +supported: + - adc + - usb_device + - ble + - ieee802154 + - pwm + - watchdog diff --git a/boards/shields/samnrf/samnrf.zmk.yml b/boards/shields/samnrf/samnrf.zmk.yml new file mode 100644 index 0000000..1c22db1 --- /dev/null +++ b/boards/shields/samnrf/samnrf.zmk.yml @@ -0,0 +1,11 @@ +file_format: "1" +id: samnrf +name: samnrf +type: board +arch: arm +features: + - keys +outputs: + - usb + - ble +url: https://github.com/samerbam/zmk-config diff --git a/boards/shields/samnrf/samnrf_defconfig b/boards/shields/samnrf/samnrf_defconfig new file mode 100644 index 0000000..a833803 --- /dev/null +++ b/boards/shields/samnrf/samnrf_defconfig @@ -0,0 +1,21 @@ +CONFIG_SOC_SERIES_NRF52X=y +CONFIG_SOC_NRF52840_QIAA=y +CONFIG_BOARD_SAMNRF=y + +# Enable MPU +CONFIG_ARM_MPU=y + +# enable GPIO +CONFIG_GPIO=y + +CONFIG_USE_DT_CODE_PARTITION=y +CONFIG_BUILD_OUTPUT_UF2=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 + +CONFIG_ZMK_USB_LOGGING=y \ No newline at end of file diff --git a/build.yaml b/build.yaml index acb6f8c..d3c13e0 100644 --- a/build.yaml +++ b/build.yaml @@ -18,4 +18,5 @@ # --- include: - - board: nice60 + - board: samnrf + shield: samnrf