1/*
2 * Copyright (c) 2023 Evan Perry Grove
3 * Copyright (c) 2024 STMicroelectronics
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8/dts-v1/;
9#include <st/f7/stm32f722Xe.dtsi>
10#include <st/f7/stm32f722z(c-e)tx-pinctrl.dtsi>
11#include "arduino_r3_connector.dtsi"
12#include <zephyr/dt-bindings/input/input-event-codes.h>
13
14/ {
15	model = "STMicroelectronics STM32F722ZE-NUCLEO board";
16	compatible = "st,stm32f722ze-nucleo";
17
18	chosen {
19		zephyr,console = &usart3;
20		zephyr,shell-uart = &usart3;
21		zephyr,sram = &sram0;
22		zephyr,flash = &flash0;
23		zephyr,dtcm = &dtcm;
24		zephyr,canbus = &can1;
25		zephyr,code-partition = &slot0_partition;
26	};
27
28	leds {
29		compatible = "gpio-leds";
30		green_led: led_1 {
31			gpios = <&gpiob 0 GPIO_ACTIVE_HIGH>;
32			label = "User LD1";
33		};
34		blue_led: led_2 {
35			gpios = <&gpiob 7 GPIO_ACTIVE_HIGH>;
36			label = "User LD2";
37		};
38		red_led: led_3 {
39			gpios = <&gpiob 14 GPIO_ACTIVE_HIGH>;
40			label = "User LD3";
41		};
42	};
43
44	gpio_keys {
45		compatible = "gpio-keys";
46		user_button: button {
47			label = "User";
48			gpios = <&gpioc 13 GPIO_ACTIVE_HIGH>;
49			zephyr,code = <INPUT_KEY_0>;
50		};
51	};
52
53	aliases {
54		led0 = &green_led;
55		led1 = &blue_led;
56		led2 = &red_led;
57		sw0 = &user_button;
58		watchdog0 = &iwdg;
59		die-temp0 = &die_temp;
60		volt-sensor0 = &vref;
61	};
62};
63
64&clk_hse {
65	clock-frequency = <DT_FREQ_M(8)>;
66	status = "okay";
67};
68
69&clk_hsi {
70	status = "disabled";
71};
72
73&clk_lsi {
74	status = "okay";
75};
76
77&pll {
78	div-m = <4>;
79	mul-n = <216>;
80	div-p = <2>;
81	div-q = <9>;
82	clocks = <&clk_hse>;
83	status = "okay";
84};
85
86&rcc {
87	clocks = <&pll>;
88	clock-frequency = <DT_FREQ_M(216)>;
89	ahb-prescaler = <1>;
90	apb1-prescaler = <4>;
91	apb2-prescaler = <2>;
92};
93
94&sdmmc1 {
95	status = "okay";
96	pinctrl-0 = <&sdmmc1_d0_pc8 &sdmmc1_d1_pc9 &sdmmc1_d2_pc10
97		&sdmmc1_d3_pc11 &sdmmc1_ck_pc12 &sdmmc1_cmd_pd2>;
98	pinctrl-names = "default";
99	cd-gpios = <&gpioi 15 GPIO_ACTIVE_LOW>;
100};
101
102&adc1 {
103	pinctrl-0 = <&adc1_in3_pa3 &adc1_in10_pc0>;
104	pinctrl-names = "default";
105	st,adc-clock-source = "SYNC";
106	st,adc-prescaler = <2>;
107	status = "okay";
108};
109
110&dac1 {
111	pinctrl-0 = <&dac_out1_pa4>;
112	pinctrl-names = "default";
113	status = "okay";
114};
115
116&i2c2 {
117	pinctrl-0 = <&i2c2_scl_pf1 &i2c2_sda_pf0>;
118	pinctrl-names = "default";
119	status = "okay";
120	clock-frequency = <I2C_BITRATE_FAST>;
121};
122
123&can1 {
124	pinctrl-0 = <&can1_rx_pd0 &can1_tx_pd1>;
125	pinctrl-names = "default";
126	status = "okay";
127};
128
129&usart2 {
130	pinctrl-0 = <&usart2_tx_pd5 &usart2_rx_pd6 &usart2_rts_pd4 &usart2_cts_pd3>;
131	pinctrl-names = "default";
132	current-speed = <115200>;
133	status = "okay";
134};
135
136&usart3 {
137	pinctrl-0 = <&usart3_tx_pd8 &usart3_rx_pd9>;
138	pinctrl-names = "default";
139	current-speed = <115200>;
140	status = "okay";
141};
142
143&i2c1 {
144	pinctrl-0 = <&i2c1_scl_pb8 &i2c1_sda_pb9>;
145	pinctrl-names = "default";
146	status = "okay";
147};
148
149&spi1 {
150	pinctrl-0 = <&spi1_sck_pa5 &spi1_miso_pa6 &spi1_mosi_pa7>;
151	pinctrl-names = "default";
152	cs-gpios = <&gpiod 14 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
153	status = "okay";
154};
155
156&timers1 {
157	status = "okay";
158
159	pwm1: pwm {
160		status = "okay";
161		pinctrl-0 = <&tim1_ch2_pe11 &tim1_ch3_pe13>;
162		pinctrl-names = "default";
163	};
164};
165
166&usart6 {
167	pinctrl-0 = <&usart6_tx_pg14 &usart6_rx_pg9>;
168	pinctrl-names = "default";
169	current-speed = <115200>;
170	status = "okay";
171};
172
173zephyr_udc0: &usbotg_fs {
174	pinctrl-0 = <&usb_otg_fs_dm_pa11 &usb_otg_fs_dp_pa12 &usb_otg_fs_id_pa10>;
175	pinctrl-names = "default";
176	status = "okay";
177};
178
179&rtc {
180	clocks = <&rcc STM32_CLOCK_BUS_APB1 0x10000000>,
181		<&rcc STM32_SRC_LSI RTC_SEL(2)>;
182	status = "okay";
183};
184
185&die_temp {
186	status = "okay";
187};
188
189&dma2 {
190	status = "okay";
191};
192
193&iwdg {
194	status = "okay";
195};
196
197&vref {
198	status = "okay";
199};
200
201&rng {
202	status = "okay";
203};
204
205&backup_sram {
206	status = "okay";
207};
208
209&quadspi {
210	pinctrl-names = "default";
211	pinctrl-0 = <&quadspi_clk_pb2 &quadspi_bk1_ncs_pb6
212				&quadspi_bk1_io0_pd11 &quadspi_bk1_io1_pd12
213				&quadspi_bk1_io2_pe2 &quadspi_bk1_io3_pd13>;
214	flash-id = <1>;
215	status = "okay";
216};
217
218&flash0 {
219
220	partitions {
221		compatible = "fixed-partitions";
222		#address-cells = <1>;
223		#size-cells = <1>;
224
225		/* sectors 0-3 */
226		boot_partition: partition@0 {
227			label = "mcuboot";
228			reg = <0x00000000 DT_SIZE_K(64)>;
229			read-only;
230		};
231
232		/* sector 4 */
233		storage_partition: partition@10000 {
234			label = "storage";
235			reg = <0x00010000 DT_SIZE_K(64)>;
236		};
237
238		/* sector 5 */
239		slot0_partition: partition@20000 {
240			label = "image-0";
241			reg = <0x00020000 DT_SIZE_K(128)>;
242		};
243
244		/* sector 6 */
245		slot1_partition: partition@40000 {
246			label = "image-1";
247			reg = <0x00040000 DT_SIZE_K(128)>;
248		};
249
250		/* sector 7 */
251		scratch_partition: partition@60000 {
252			label = "image-scratch";
253			reg = <0x00060000 DT_SIZE_K(128)>;
254		};
255	};
256};
257