1/*
2 * Copyright (c) 2017 I-SENSE group of ICCS
3 *
4 * SoC device tree include for STM32F103xC SoCs
5 * where 'x' is replaced for specific SoCs like {R,V,Z}
6 *
7 * SPDX-License-Identifier: Apache-2.0
8 */
9
10#include <mem.h>
11#include <st/f1/stm32f103Xb.dtsi>
12
13/ {
14	sram0: memory@20000000 {
15		reg = <0x20000000 DT_SIZE_K(48)>;
16	};
17
18	soc {
19		flash-controller@40022000 {
20			flash0: flash@8000000 {
21				reg = <0x08000000 DT_SIZE_K(256)>;
22				erase-block-size = <DT_SIZE_K(2)>;
23			};
24		};
25
26		uart4: serial@40004c00 {
27			compatible = "st,stm32-uart";
28			reg = <0x40004c00 0x400>;
29			clocks = <&rcc STM32_CLOCK(APB1, 19U)>;
30			resets = <&rctl STM32_RESET(APB1, 19U)>;
31			interrupts = <52 0>;
32			status = "disabled";
33		};
34
35		uart5: serial@40005000 {
36			compatible = "st,stm32-uart";
37			reg = <0x40005000 0x400>;
38			clocks = <&rcc STM32_CLOCK(APB1, 20U)>;
39			resets = <&rctl STM32_RESET(APB1, 20U)>;
40			interrupts = <53 0>;
41			status = "disabled";
42		};
43
44		timers5: timers@40000c00 {
45			compatible = "st,stm32-timers";
46			reg = <0x40000c00 0x400>;
47			clocks = <&rcc STM32_CLOCK(APB1, 3U)>;
48			resets = <&rctl STM32_RESET(APB1, 3U)>;
49			interrupts = <50 0>;
50			interrupt-names = "global";
51			st,prescaler = <0>;
52			status = "disabled";
53
54			pwm {
55				compatible = "st,stm32-pwm";
56				status = "disabled";
57				#pwm-cells = <3>;
58			};
59		};
60
61		timers6: timers@40001000 {
62			compatible = "st,stm32-timers";
63			reg = <0x40001000 0x400>;
64			clocks = <&rcc STM32_CLOCK(APB1, 4U)>;
65			resets = <&rctl STM32_RESET(APB1, 4U)>;
66			interrupts = <54 0>;
67			interrupt-names = "global";
68			st,prescaler = <0>;
69			status = "disabled";
70		};
71
72		timers7: timers@40001400 {
73			compatible = "st,stm32-timers";
74			reg = <0x40001400 0x400>;
75			clocks = <&rcc STM32_CLOCK(APB1, 5U)>;
76			resets = <&rctl STM32_RESET(APB1, 5U)>;
77			interrupts = <55 0>;
78			interrupt-names = "global";
79			st,prescaler = <0>;
80			status = "disabled";
81		};
82
83		spi3: spi@40003c00 {
84			compatible = "st,stm32-spi";
85			#address-cells = <1>;
86			#size-cells = <0>;
87			reg = <0X40003c00 0x400>;
88			clocks = <&rcc STM32_CLOCK(APB1, 15U)>;
89			interrupts = <51 5>;
90			status = "disabled";
91		};
92
93		dac1: dac@40007400 {
94			compatible = "st,stm32-dac";
95			reg = <0x40007400 0x400>;
96			clocks = <&rcc STM32_CLOCK(APB1, 29U)>;
97			status = "disabled";
98			#io-channel-cells = <1>;
99		};
100
101		pinctrl: pin-controller@40010800 {
102			reg = <0x40010800 0x2000>;
103
104			gpiof: gpio@40011c00 {
105				compatible = "st,stm32-gpio";
106				gpio-controller;
107				#gpio-cells = <2>;
108				reg = <0x40011c00 0x400>;
109				clocks = <&rcc STM32_CLOCK(APB2, 7U)>;
110			};
111
112			gpiog: gpio@40012000 {
113				compatible = "st,stm32-gpio";
114				gpio-controller;
115				#gpio-cells = <2>;
116				reg = <0x40012000 0x400>;
117				clocks = <&rcc STM32_CLOCK(APB2, 8U)>;
118			};
119		};
120
121		adc2: adc@40012800 {
122			compatible = "st,stm32-adc";
123			reg = <0x40012800 0x400>;
124			clocks = <&rcc STM32_CLOCK(APB2, 10U)>;
125			/* Shares vector with ADC1 */
126			interrupts = <18 0>;
127			status = "disabled";
128			#io-channel-cells = <1>;
129		};
130
131		adc3: adc@40013c00 {
132			compatible = "st,stm32-adc";
133			reg = <0x40013c00 0x400>;
134			clocks = <&rcc STM32_CLOCK(APB2, 15U)>;
135			interrupts = <47 0>;
136			status = "disabled";
137			#io-channel-cells = <1>;
138		};
139
140		timers8: timers@40013400 {
141			compatible = "st,stm32-timers";
142			reg = <0x40013400 0x400>;
143			clocks = <&rcc STM32_CLOCK(APB2, 13U)>;
144			resets = <&rctl STM32_RESET(APB2, 13U)>;
145			interrupts = <43 0>, <44 0>, <45 0>, <46 0>;
146			interrupt-names = "brk", "up", "trgcom", "cc";
147			st,prescaler = <0>;
148			status = "disabled";
149
150			pwm {
151				compatible = "st,stm32-pwm";
152				status = "disabled";
153				#pwm-cells = <3>;
154			};
155		};
156
157		dma2: dma@40020400 {
158			compatible = "st,stm32-dma-v2bis";
159			#dma-cells = <2>;
160			reg = <0x40020400 0x400>;
161			clocks = <&rcc STM32_CLOCK(AHB1, 1U)>;
162			interrupts = < 56 0 57 0 58 0 59 0 60 0>;
163			status = "disabled";
164		};
165	};
166};
167