Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for Nucleo WB55CG board & Zephirum shield #938

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
feat(boards): Add Nucleo WB55CG dongle.
  • Loading branch information
Cedric Vincent authored and cdc-mkb committed Nov 29, 2021
commit 1441738d02848d7036a56f969bc5a70d46f6950c
8 changes: 8 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/Kconfig.board
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
# STM32WB55CG Nucleo USB dongle configuration

# Copyright (c) 2021 The ZMK Contributors
# SPDX-License-Identifier: MIT

config BOARD_NUCLEO_WB55CG_DONGLE
bool "Nucleo WB55CG USB Dongle"
depends on SOC_STM32WB55XX
33 changes: 33 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/Kconfig.defconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# STM32LWB55CG USB dongle configuration

# Copyright (c) 2021 The ZMK Contributors
# SPDX-License-Identifier: MIT

if BOARD_NUCLEO_WB55CG_DONGLE

config BOARD
default "nucleo_wb55cg_dongle"

config CLOCK_STM32_LSE
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This one was nixed in Zephyr 3.0.0 too.

default y

choice STM32_LPTIM_CLOCK
default STM32_LPTIM_CLOCK_LSE
depends on STM32_LPTIM_TIMER
endchoice

choice BT_HCI_BUS_TYPE
default BT_STM32_IPM
depends on BT
endchoice

config SYSTEM_WORKQUEUE_STACK_SIZE
default 2048

config ZMK_USB
default y

config ZMK_KSCAN_MATRIX_POLLING
default y

endif # BOARD_NUCLEO_WB55CG
10 changes: 10 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/README.md
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it's appropriate to put shield-specific information in this readme when the board could be used by other shields.

Most "generic" boards don't have READMEs, so you could probably just omit this.

Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
# Nucleo WB55CG dongle support for [Zephirum](http://zephirum.tuxfamily.org)

Zephirum is an ergo monoblock angled keyboards powered by a Nucleo
WB55CG USB dongle.

## Building ZMK firmware

```
west build -b nucleo_wb55cg_dongle -- -DSHIELD=zephirum
```
6 changes: 6 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/board.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Copyright (c) 2021 The ZMK Contributors
# SPDX-License-Identifier: MIT

board_runner_args(dfu-util "--pid=0483:df11" "--alt=0" "--dfuse")

include(${ZEPHYR_BASE}/boards/common/dfu-util.board.cmake)
136 changes: 136 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/nucleo_wb55cg_dongle.dts
Original file line number Diff line number Diff line change
@@ -0,0 +1,136 @@
/*
* Copyright (c) 2021 The ZMK Contributors
* SPDX-License-Identifier: MIT
*/

/dts-v1/;
#include <st/wb/stm32wb55Xg.dtsi>
#include <st/wb/stm32wb55cgux-pinctrl.dtsi>

/ {
model = "STMicroelectronics STM32WB55CG USB dongle";
compatible = "st,stm32wb55cg-dongle";

chosen {
zephyr,bt-mon-uart = &lpuart1;
zephyr,sram = &sram0;
zephyr,flash = &flash0;
zephyr,code-partition = &slot0_partition;
};

leds {
compatible = "gpio-leds";
blue_led_1: led_0 {
gpios = <&gpioa 4 GPIO_ACTIVE_HIGH>;
label = "D1";
};
green_led_2: led_1 {
gpios = <&gpiob 0 GPIO_ACTIVE_HIGH>;
label = "D2";
};
red_led_3: led_2 {
gpios = <&gpiob 1 GPIO_ACTIVE_HIGH>;
label = "D3";
};
};

gpio_keys {
compatible = "gpio-keys";
user_button_1: button_0 {
label = "SW1";
gpios = <&gpioa 10 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
};
};

aliases {
led0 = &blue_led_1;
led1 = &green_led_2;
led2 = &red_led_3;
sw0 = &user_button_1;
};
};

&i2c1 {
status = "okay";
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
status = "okay";

Per a suggestion made on another board:

For ZMK boards, dodn't enable the UART, SPI, etc by default. This is a bit different from the upstream Zephyr board approach.

I'm only going to make the suggestion in one place, but this applies to a number of nodes.

clock-frequency = <I2C_BITRATE_FAST>;
pinctrl-0 = <&i2c1_scl_pb8 &i2c1_sda_pb9>;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
pinctrl-0 = <&i2c1_scl_pb8 &i2c1_sda_pb9>;
pinctrl-0 = <&i2c1_scl_pb8 &i2c1_sda_pb9>;
pinctrl-names = "default";

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

pinctrl-names is now a required property. As above, this suggestion is applicable to a number of nodes.

...In truth, a chunk of this configuration should probably be pulled out into app/boards/arm/nucleo_wb55cg_dongle/nucleo_wb55cg_dongle.dtsi and #included in this file—in order to leverage the pinctrl system introduced with Zephyr 3.2.

};

&rtc {
status = "okay";
};

&spi1 {
pinctrl-0 = <&spi1_sck_pa5 &spi1_miso_pa6 &spi1_mosi_pa7>;
status = "okay";
};

&timers2 {
status = "okay";
pwm2: pwm {
status = "okay";
pinctrl-0 = <&tim2_ch1_pa0>;
};
};

&lpuart1 {
pinctrl-0 = <&lpuart1_tx_pa2 &lpuart1_rx_pa3>;
current-speed = <115200>;
status = "okay";
};

&adc1 {
pinctrl-0 = <&adc1_in6_pa1>;
status = "okay";
};

&iwdg {
status = "okay";
};

&lptim1 {
status = "okay";
};

&usb {
status = "okay";
pinctrl-0 = <&usb_dm_pa11 &usb_dp_pa12>;
};

&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>;

/* Set all partitions with first 812K of flash */
/* last 212K are reseved for M0 usage */
/* Configure partitions to make use of the whole 812K */

boot_partition: partition@0 {
label = "mcuboot";
reg = <0x00000000 0xc000>;
};
slot0_partition: partition@c000 {
label = "image-0";
reg = <0x0000C000 0x5c000>;
};
slot1_partition: partition@68000 {
label = "image-1";
reg = <0x00068000 0x5c000>;
};
scratch_partition: partition@c4000 {
label = "image-scratch";
reg = <0x000c4000 0x4000>;
};
storage_partition: partition@c8000 {
label = "storage";
reg = <0x000c8000 0x3000>;
};

};
};
19 changes: 19 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/nucleo_wb55cg_dongle.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
identifier: nucleo_wb55cg_dongle
name: ST Nucleo WB55CG Dongle
type: mcu
arch: arm
toolchain:
- zephyr
- gnuarmemb
- xtools
ram: 96
flash: 1024
supported:
- gpio
- i2c
- counter
- spi
- pwm
- adc
- watchdog
- usb_device
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
file_format: "1"
id: nucleo_wb55cg_dongle
name: ST Nucleo WB55CG Dongle
type: board
arch: arm
outputs:
- usb
url: https://www.st.com/en/evaluation-tools/p-nucleo-wb55.html
exposes: [nucleo_wb55cg_dongle]
26 changes: 26 additions & 0 deletions app/boards/arm/nucleo_wb55cg_dongle/nucleo_wb55cg_dongle_defconfig
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Per the Zephyr 3.0.0 changelog:

STM32 clock_control driver configuration was moved from Kconfig to devicetree. See the st,stm32-rcc devicetree binding for more information. As a consequence, [the] following Kconfig symbols were removed:

  • CONFIG_CLOCK_STM32_SYSCLK_SRC_HSE
  • CONFIG_CLOCK_STM32_APB1_PRESCALER
  • CONFIG_CLOCK_STM32_APB2_PRESCALER
  • CONFIG_CLOCK_STM32_CPU1_PRESCALER
  • CONFIG_CLOCK_STM32_CPU2_PRESCALER
  • CONFIG_CLOCK_STM32_AHB4_PRESCALER

Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
CONFIG_SOC_SERIES_STM32WBX=y
CONFIG_SOC_STM32WB55XX=y
# 32MHz system clock
CONFIG_SYS_CLOCK_HW_CYCLES_PER_SEC=32000000

# enable pinmux
CONFIG_PINMUX=y

# enable GPIO
CONFIG_GPIO=y

# clock configuration
CONFIG_CLOCK_CONTROL=y
# SYSCLK selection
# CONFIG_CLOCK_STM32_SYSCLK_SRC_PLL=y
CONFIG_CLOCK_STM32_SYSCLK_SRC_HSE=y
CONFIG_CLOCK_STM32_HSE_CLOCK=32000000

CONFIG_CLOCK_STM32_CPU1_PRESCALER=1
CONFIG_CLOCK_STM32_CPU2_PRESCALER=1
CONFIG_CLOCK_STM32_APB1_PRESCALER=1
CONFIG_CLOCK_STM32_APB2_PRESCALER=1
CONFIG_CLOCK_STM32_AHB4_PRESCALER=1

# Enable MPU
CONFIG_ARM_MPU=y