1/* 2 * Copyright (c) 2020 Linumiz 3 * Author: Parthiban Nallathambi <parthiban@linumiz.com> 4 * 5 * SPDX-License-Identifier: Apache-2.0 6 */ 7 8#include <arm/armv7-m.dtsi> 9#include <zephyr/dt-bindings/adc/adc.h> 10#include <zephyr/dt-bindings/gpio/gpio.h> 11#include <zephyr/dt-bindings/gpio/infineon-xmc4xxx-gpio.h> 12 13/ { 14 cpus { 15 #address-cells = <1>; 16 #size-cells = <0>; 17 18 cpu0: cpu@0 { 19 compatible = "arm,cortex-m4f"; 20 reg = <0>; 21 }; 22 }; 23 24 flash_controller: flash_controller@58001000 { 25 compatible = "infineon,xmc4xxx-flash-controller"; 26 reg = <0x58001000 0x1400>; 27 #address-cells = <1>; 28 #size-cells = <1>; 29 flash0: flash@c000000 { 30 compatible = "infineon,xmc4xxx-nv-flash","soc-nv-flash"; 31 write-block-size = <256>; 32 }; 33 }; 34 35 sysclk: system-clock { 36 compatible = "fixed-clock"; 37 clock-frequency = <120000000>; 38 #clock-cells = <0>; 39 }; 40 41 soc { 42 intc: eru@40044000 { 43 compatible = "infineon,xmc4xxx-intc"; 44 reg = <0x40044000 0xff>, <0x50004800 0xff>; 45 /* naming order is intentional. eru1 maps to a lower address than eru0 */ 46 reg-names = "eru1", "eru0"; 47 interrupts = <1 1>, <2 1>, <3 1>, <4 1>, <5 1>, <6 1>, <7 1>, <8 1>; 48 interrupt-names = "eru0sr0", "eru0sr1", "eru0sr2", "eru0sr3", 49 "eru1sr0", "eru1sr1", "eru1sr2", "eru1sr3"; 50 }; 51 52 pinctrl: pinctrl@48028000 { 53 compatible = "infineon,xmc4xxx-pinctrl"; 54 reg = <0x48028000 0x1000>; 55 #address-cells = <1>; 56 #size-cells = <1>; 57 58 gpio0: gpio@48028000 { 59 compatible = "infineon,xmc4xxx-gpio"; 60 gpio-controller; 61 #gpio-cells = <2>; 62 reg = <0x48028000 0x100>; 63 status = "disabled"; 64 }; 65 66 gpio1: gpio@48028100 { 67 compatible = "infineon,xmc4xxx-gpio"; 68 gpio-controller; 69 #gpio-cells = <2>; 70 reg = <0x48028100 0x100>; 71 status = "disabled"; 72 }; 73 74 gpio2: gpio@48028200 { 75 compatible = "infineon,xmc4xxx-gpio"; 76 gpio-controller; 77 #gpio-cells = <2>; 78 reg = <0x48028200 0x100>; 79 status = "disabled"; 80 }; 81 82 gpio14: gpio@48028e00 { 83 compatible = "infineon,xmc4xxx-gpio"; 84 gpio-controller; 85 #gpio-cells = <2>; 86 reg = <0x48028e00 0x100>; 87 status = "disabled"; 88 }; 89 90 gpio15: gpio@48028f00 { 91 compatible = "infineon,xmc4xxx-gpio"; 92 gpio-controller; 93 #gpio-cells = <2>; 94 reg = <0x48028f00 0x100>; 95 status = "disabled"; 96 }; 97 }; 98 99 dma0: dma0@50014000{ 100 compatible = "infineon,xmc4xxx-dma"; 101 reg = <0x50014000 0x2bc>; 102 interrupts = <105 1>; 103 dma-channels = <8>; 104 #dma-cells = <3>; 105 status = "disabled"; 106 }; 107 108 dma1: dma1@50018000 { 109 compatible = "infineon,xmc4xxx-dma"; 110 reg = <0x50018000 0x15c>; 111 interrupts = <110 1>; 112 dma-channels = <4>; 113 #dma-cells = <3>; 114 status = "disabled"; 115 }; 116 117 usic0ch0: usic@40030000 { 118 reg = <0x40030000 0x1ff>; 119 clocks = <&sysclk>; 120 status = "disabled"; 121 }; 122 123 usic0ch1: usic@40030200 { 124 reg = <0x40030200 0x1ff>; 125 clocks = <&sysclk>; 126 status = "disabled"; 127 }; 128 129 usic1ch0: usic@48020000 { 130 reg = <0x48020000 0x1ff>; 131 clocks = <&sysclk>; 132 status = "disabled"; 133 }; 134 135 usic1ch1: usic@48020200 { 136 reg = <0x48020200 0x1ff>; 137 clocks = <&sysclk>; 138 status = "disabled"; 139 }; 140 141 usic2ch0: usic@48024000 { 142 reg = <0x48024000 0x1ff>; 143 clocks = <&sysclk>; 144 status = "disabled"; 145 }; 146 147 usic2ch1: usic@48024200 { 148 reg = <0x48024200 0x1ff>; 149 clocks = <&sysclk>; 150 status = "disabled"; 151 }; 152 153 adc0: adc@40004400 { 154 compatible = "infineon,xmc4xxx-adc"; 155 reg = <0x40004400 0x400>; 156 interrupts = <18 62>; 157 #io-channel-cells = <1>; 158 status = "disabled"; 159 }; 160 161 adc1: adc@40004800 { 162 compatible = "infineon,xmc4xxx-adc"; 163 reg = <0x40004800 0x400>; 164 interrupts = <22 62>; 165 #io-channel-cells = <1>; 166 status = "disabled"; 167 }; 168 169 adc2: adc@40004c00 { 170 compatible = "infineon,xmc4xxx-adc"; 171 reg = <0x40004C00 0x400>; 172 interrupts = <26 62>; 173 #io-channel-cells = <1>; 174 status = "disabled"; 175 }; 176 177 adc3: adc@40005000 { 178 compatible = "infineon,xmc4xxx-adc"; 179 reg = <0x40005000 0x400>; 180 interrupts = <30 62>; 181 #io-channel-cells = <1>; 182 status = "disabled"; 183 }; 184 185 die_temp: die_temp@5000408c { 186 reg = <0x5000408c 0x8>; 187 compatible = "infineon,xmc4xxx-temp"; 188 status = "disabled"; 189 }; 190 191 pwm_ccu40: ccu40@4000c000 { 192 compatible = "infineon,xmc4xxx-ccu4-pwm"; 193 reg = <0x4000c000 0x4000>; 194 #pwm-cells = <3>; 195 status = "disabled"; 196 }; 197 198 pwm_ccu41: ccu41@40010000 { 199 compatible = "infineon,xmc4xxx-ccu4-pwm"; 200 reg = <0x40010000 0x4000>; 201 #pwm-cells = <3>; 202 status = "disabled"; 203 }; 204 205 pwm_ccu42: ccu42@40014000 { 206 compatible = "infineon,xmc4xxx-ccu4-pwm"; 207 reg = <0x40014000 0x4000>; 208 #pwm-cells = <3>; 209 status = "disabled"; 210 }; 211 212 pwm_ccu43: ccu43@48004000 { 213 compatible = "infineon,xmc4xxx-ccu4-pwm"; 214 reg = <0x48004000 0x4000>; 215 #pwm-cells = <3>; 216 status = "disabled"; 217 }; 218 219 pwm_ccu80: ccu80@40020000 { 220 compatible = "infineon,xmc4xxx-ccu8-pwm"; 221 reg = <0x40020000 0x4000>; 222 #pwm-cells = <3>; 223 status = "disabled"; 224 }; 225 226 pwm_ccu81: ccu81@40024000 { 227 compatible = "infineon,xmc4xxx-ccu8-pwm"; 228 reg = <0x40024000 0x4000>; 229 #pwm-cells = <3>; 230 status = "disabled"; 231 }; 232 233 wdt0: watchdog@50008000 { 234 compatible = "infineon,xmc4xxx-watchdog"; 235 reg = <0x50008000 0x4000>; 236 interrupts = <0 1>; // shared interrupt line with rtc 237 status = "disabled"; 238 }; 239 240 rtc: rtc@50004a00 { 241 compatible = "infineon,xmc4xxx-rtc"; 242 reg = <0x50004a00 0x200>; 243 interrupts = <0 1>; // shared interrupt line with wdt0 244 alarms-count = <1>; 245 status = "disabled"; 246 }; 247 248 ethernet@5000c000 { 249 reg = <0x5000C000 0x3FFF>; 250 251 eth: ethernet { 252 compatible = "infineon,xmc4xxx-ethernet"; 253 interrupts = <108 1>; 254 status = "disabled"; 255 }; 256 257 mdio: mdio { 258 compatible = "infineon,xmc4xxx-mdio"; 259 status = "disabled"; 260 #address-cells = <1>; 261 #size-cells = <0>; 262 }; 263 }; 264 265 can: can@48014000 { 266 compatible = "infineon,xmc4xxx-can"; 267 reg = <0x48014000 0x4000>; 268 clock-prescaler = <1>; 269 270 #address-cells = <1>; 271 #size-cells = <1>; 272 273 can_node0: can_node0@48014200 { 274 compatible = "infineon,xmc4xxx-can-node"; 275 reg = <0x48014200 0x100>; 276 interrupts = <76 1>; 277 status = "disabled"; 278 }; 279 280 can_node1: can_node1@48014300 { 281 compatible = "infineon,xmc4xxx-can-node"; 282 reg = <0x48014300 0x100>; 283 interrupts = <77 1>; 284 status = "disabled"; 285 }; 286 287 can_node2: can_node2@48014400 { 288 compatible = "infineon,xmc4xxx-can-node"; 289 reg = <0x48014400 0x100>; 290 interrupts = <78 1>; 291 status = "disabled"; 292 }; 293 }; 294 }; 295}; 296 297&nvic { 298 arm,num-irq-priority-bits = <6>; 299}; 300