1/*
2 * Copyright (c) 2020-2024 STMicroelectronics
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7/dts-v1/;
8#include <st/wl/stm32wl55Xc.dtsi>
9#include <st/wl/stm32wl55jcix-pinctrl.dtsi>
10#include "arduino_r3_connector.dtsi"
11#include "st_morpho_connector.dtsi"
12#include <zephyr/dt-bindings/input/input-event-codes.h>
13
14/ {
15	model = "STMicroelectronics STM32WL55JC-NUCLEO board";
16	compatible = "st,stm32wl55-nucleo";
17
18	chosen {
19		zephyr,console = &lpuart1;
20		zephyr,shell-uart = &lpuart1;
21		zephyr,sram = &sram0;
22		zephyr,flash = &flash0;
23		zephyr,code-partition = &slot0_partition;
24	};
25
26	leds: leds {
27		compatible = "gpio-leds";
28		blue_led_1: led_0 {
29			gpios = <&gpiob 15 GPIO_ACTIVE_HIGH>;
30			label = "User LED1";
31		};
32		green_led_2: led_1 {
33			gpios = <&gpiob 9 GPIO_ACTIVE_HIGH>;
34			label = "User LED2";
35		};
36		green_led_3: led_2 {
37			gpios = <&gpiob 11 GPIO_ACTIVE_HIGH>;
38			label = "User LED3";
39		};
40	};
41
42	gpio_keys {
43		compatible = "gpio-keys";
44		user_button_1: button_0 {
45			label = "SW1";
46			gpios = <&gpioa 0 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
47			zephyr,code = <INPUT_KEY_0>;
48		};
49		user_button_2: button_1 {
50			label = "SW2";
51			gpios = <&gpioa 1 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
52			zephyr,code = <INPUT_KEY_1>;
53		};
54		user_button_3: button_2 {
55			label = "SW3";
56			gpios = <&gpioc 6 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
57			zephyr,code = <INPUT_KEY_2>;
58		};
59	};
60
61	aliases {
62		led0 = &green_led_2;
63		sw0 = &user_button_1;
64		sw1 = &user_button_2;
65		sw2 = &user_button_3;
66		lora0 = &lora;
67		watchdog0 = &iwdg;
68		die-temp0 = &die_temp;
69		volt-sensor0 = &vref;
70		volt-sensor1 = &vbat;
71	};
72};
73
74&clk_lsi {
75	status = "okay";
76};
77
78stm32_lp_tick_source: &lptim1 {
79	clocks = <&rcc STM32_CLOCK_BUS_APB1 0x80000000>,
80		 <&rcc STM32_SRC_LSI LPTIM1_SEL(1)>;
81	status = "okay";
82};
83
84&clk_hsi {
85	status = "okay";
86};
87
88&clk_lse {
89	status = "okay";
90};
91
92&pll {
93	div-m = <1>;
94	mul-n = <6>;
95	div-r = <2>;
96	div-q = <2>;
97	clocks = <&clk_hsi>;
98	status = "okay";
99};
100
101&rcc {
102	clocks = <&pll>;
103	clock-frequency = <DT_FREQ_M(48)>;
104	cpu1-prescaler = <1>;
105	cpu2-prescaler = <1>;
106	ahb3-prescaler = <1>;
107	apb1-prescaler = <1>;
108	apb2-prescaler = <1>;
109};
110
111&lpuart1 {
112	pinctrl-0 = <&lpuart1_tx_pa2 &lpuart1_rx_pa3>;
113	pinctrl-names = "default";
114	current-speed = <115200>;
115	status = "okay";
116};
117
118&i2c2 {
119	pinctrl-0 = <&i2c2_scl_pa12 &i2c2_sda_pa11>;
120	pinctrl-names = "default";
121	status = "okay";
122	clock-frequency = <I2C_BITRATE_FAST>;
123};
124
125&spi1 {
126	pinctrl-0 = <&spi1_nss_pa4 &spi1_sck_pa5
127		     &spi1_miso_pa6 &spi1_mosi_pa7>;
128	pinctrl-names = "default";
129	status = "okay";
130};
131
132
133&dac1 {
134	pinctrl-0 = <&dac_out1_pa10>;
135	pinctrl-names = "default";
136	status = "okay";
137};
138
139&timers2 {
140	status = "okay";
141	pwm2: pwm {
142		status = "okay";
143		pinctrl-0 = <&tim2_ch4_pb11>;
144		pinctrl-names = "default";
145	};
146};
147
148
149&adc1 {
150	pinctrl-0 = <&adc_in5_pb1 &adc_in0_pb13>;
151	pinctrl-names = "default";
152	st,adc-clock-source = "SYNC";
153	st,adc-prescaler = <4>;
154	status = "okay";
155};
156
157&die_temp {
158	status = "okay";
159};
160
161&aes {
162	status = "okay";
163};
164
165&rng {
166	status = "okay";
167};
168
169&iwdg {
170	status = "okay";
171};
172
173&subghzspi {
174	status = "okay";
175	lora: radio@0 {
176		status = "okay";
177		tx-enable-gpios = <&gpioc 4 GPIO_ACTIVE_LOW>; /* FE_CTRL1 */
178		rx-enable-gpios = <&gpioc 5 GPIO_ACTIVE_LOW>; /* FE_CTRL2 */
179		dio3-tcxo-voltage = <SX126X_DIO3_TCXO_1V7>;
180		tcxo-power-startup-delay-ms = <5>;
181		/* High-power output is selected as a consequence of using
182		 * tx/rx-enable-gpio to control FE_CTRL1 and FE_CTRL2. Low-power
183		 * output would require both FE_CTRL1 and FE_CTRL2 to be high,
184		 * which is not currently supported by the driver.
185		 */
186		power-amplifier-output = "rfo-hp";
187		rfo-lp-max-power = <15>;
188		rfo-hp-max-power = <22>;
189	};
190};
191
192&flash0 {
193	partitions {
194		compatible = "fixed-partitions";
195		#address-cells = <1>;
196		#size-cells = <1>;
197
198		boot_partition: partition@0 {
199			label = "mcuboot";
200			reg = <0x00000000 DT_SIZE_K(32)>;
201			read-only;
202		};
203		slot0_partition: partition@8000 {
204			label = "image-0";
205			reg = <0x00008000 DT_SIZE_K(104)>;
206		};
207		slot1_partition: partition@22000 {
208			label = "image-1";
209			reg = <0x00022000 DT_SIZE_K(104)>;
210		};
211
212		/*
213		 * Set 16kB of storage (8x2kB pages) at the end of the 256kB of
214		 * flash.
215		 */
216		storage_partition: partition@3c000 {
217			label = "storage";
218			reg = <0x0003c000 DT_SIZE_K(16)>;
219		};
220	};
221};
222
223&rtc {
224	clocks = <&rcc STM32_CLOCK_BUS_APB1 0x00000400>,
225		 <&rcc STM32_SRC_LSE RTC_SEL(1)>;
226	status = "okay";
227};
228
229&vref {
230	status = "okay";
231};
232
233&vbat {
234	status = "okay";
235};
236