1/* SPDX-License-Identifier: Apache-2.0 */ 2 3#include <mem.h> 4#include <arm/armv7-m.dtsi> 5#include <zephyr/dt-bindings/adc/adc.h> 6#include <zephyr/dt-bindings/clock/kinetis_sim.h> 7#include <zephyr/dt-bindings/clock/kinetis_mcg.h> 8#include <zephyr/dt-bindings/gpio/gpio.h> 9#include <zephyr/dt-bindings/i2c/i2c.h> 10 11/ { 12 aliases { 13 watchdog0 = &wdog; 14 }; 15 16 chosen { 17 zephyr,entropy = &rnga; 18 zephyr,flash-controller = &ftfe; 19 }; 20 21 cpus { 22 #address-cells = <1>; 23 #size-cells = <0>; 24 25 cpu0: cpu@0 { 26 device_type = "cpu"; 27 compatible = "arm,cortex-m4f"; 28 reg = <0>; 29 }; 30 }; 31 32 /* The on-chip SRAM is split into SRAM_L and SRAM_U regions that form a 33 * contiguous block in the memory map, however misaligned accesses 34 * across the 0x2000_0000 boundary are not supported in the Arm 35 * Cortex-M4 architecture. For clarity and to avoid the temptation for 36 * someone to extend sram0 without solving this issue, we define two 37 * separate memory nodes here and only use the upper one for now. A 38 * potential solution has been proposed in binutils: 39 * https://sourceware.org/ml/binutils/2017-02/msg00250.html 40 */ 41 sram_l: memory@1fff0000 { 42 compatible = "zephyr,memory-region", "mmio-sram"; 43 reg = <0x1fff0000 DT_SIZE_K(64)>; 44 zephyr,memory-region = "SRAML"; 45 }; 46 47 sram0: memory@20000000 { 48 compatible = "mmio-sram"; 49 reg = <0x20000000 DT_SIZE_K(192)>; 50 }; 51 52 temp0: temp0 { 53 compatible = "nxp,kinetis-temperature"; 54 io-channels = <&adc0 26>, <&adc0 27>; 55 io-channel-names = "SENSOR", "BANDGAP"; 56 bandgap-voltage = <1000000>; 57 vtemp25 = <716000>; 58 sensor-slope-cold = <1620>; 59 sensor-slope-hot = <1620>; 60 status = "disabled"; 61 }; 62 63 temp1: temp1 { 64 compatible = "nxp,kinetis-temperature"; 65 io-channels = <&adc1 26>, <&adc1 27>; 66 io-channel-names = "SENSOR", "BANDGAP"; 67 bandgap-voltage = <1000000>; 68 vtemp25 = <716000>; 69 sensor-slope-cold = <1620>; 70 sensor-slope-hot = <1620>; 71 status = "disabled"; 72 }; 73 74 75 /* Dummy pinctrl node, filled with pin mux options at board level */ 76 pinctrl: pinctrl { 77 compatible = "nxp,port-pinctrl"; 78 status = "okay"; 79 }; 80 81 82 soc { 83 mpu: mpu@4000d000 { 84 compatible = "nxp,k64f-mpu"; 85 reg = <0x4000d000 0x824>; 86 87 status = "disabled"; 88 }; 89 90 mcg: clock-controller@40064000 { 91 compatible = "nxp,kinetis-mcg"; 92 reg = <0x40064000 0xd>; 93 #clock-cells = <1>; 94 }; 95 96 osc: clock-controller@40065000 { 97 compatible = "nxp,k64f-osc"; 98 reg = <0x40065000 0x4>; 99 100 enable-external-reference; 101 }; 102 103 rtc: rtc@4003d000 { 104 compatible = "nxp,rtc"; 105 reg = <0x4003d000 0x1000>; 106 interrupts = <46 0>, <47 0>; 107 interrupt-names = "alarm", "seconds"; 108 clock-frequency = <32768>; 109 prescaler = <32768>; 110 }; 111 112 sim: sim@40047000 { 113 compatible = "nxp,kinetis-sim"; 114 reg = <0x40047000 0x1060>; 115 #clock-cells = <3>; 116 117 core_clk { 118 compatible = "fixed-factor-clock"; 119 clocks = <&mcg KINETIS_MCG_OUT_CLK>; 120 clock-div = <1>; 121 #clock-cells = <0>; 122 }; 123 124 bus_clk { 125 compatible = "fixed-factor-clock"; 126 clocks = <&mcg KINETIS_MCG_OUT_CLK>; 127 clock-div = <2>; 128 #clock-cells = <0>; 129 }; 130 131 flexbus_clk { 132 compatible = "fixed-factor-clock"; 133 clocks = <&mcg KINETIS_MCG_OUT_CLK>; 134 clock-div = <3>; 135 #clock-cells = <0>; 136 }; 137 138 flash_clk { 139 compatible = "fixed-factor-clock"; 140 clocks = <&mcg KINETIS_MCG_OUT_CLK>; 141 clock-div = <5>; 142 #clock-cells = <0>; 143 }; 144 }; 145 146 ftfe: flash-controller@40020000 { 147 compatible = "nxp,kinetis-ftfe"; 148 reg = <0x40020000 0x18>; 149 interrupts = <18 0>, <19 0>; 150 interrupt-names = "command-complete", "read-collision"; 151 status = "okay"; 152 153 #address-cells = <1>; 154 #size-cells = <1>; 155 156 flash0: flash@0 { 157 compatible = "soc-nv-flash"; 158 reg = <0 DT_SIZE_M(1)>; 159 erase-block-size = <4096>; 160 write-block-size = <8>; 161 }; 162 }; 163 164 i2c0: i2c@40066000 { 165 compatible = "nxp,kinetis-i2c"; 166 clock-frequency = <I2C_BITRATE_STANDARD>; 167 #address-cells = <1>; 168 #size-cells = <0>; 169 reg = <0x40066000 0x1000>; 170 interrupts = <24 0>; 171 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1034 6>; 172 status = "disabled"; 173 }; 174 175 i2c1: i2c@40067000 { 176 compatible = "nxp,kinetis-i2c"; 177 clock-frequency = <I2C_BITRATE_STANDARD>; 178 #address-cells = <1>; 179 #size-cells = <0>; 180 reg = <0x40067000 0x1000>; 181 interrupts = <25 0>; 182 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1034 7>; 183 status = "disabled"; 184 }; 185 186 i2c2: i2c@400e6000 { 187 compatible = "nxp,kinetis-i2c"; 188 clock-frequency = <I2C_BITRATE_STANDARD>; 189 #address-cells = <1>; 190 #size-cells = <0>; 191 reg = <0x400e6000 0x1000>; 192 interrupts = <74 0>; 193 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1028 6>; 194 status = "disabled"; 195 }; 196 197 uart0: uart@4006a000 { 198 compatible = "nxp,kinetis-uart"; 199 reg = <0x4006a000 0x1000>; 200 interrupts = <31 0>, <32 0>; 201 interrupt-names = "status", "error"; 202 clocks = <&sim KINETIS_SIM_CORESYS_CLK 0x1034 10>; 203 204 status = "disabled"; 205 }; 206 207 uart1: uart@4006b000 { 208 compatible = "nxp,kinetis-uart"; 209 reg = <0x4006b000 0x1000>; 210 interrupts = <33 0>, <34 0>; 211 interrupt-names = "status", "error"; 212 clocks = <&sim KINETIS_SIM_CORESYS_CLK 0x1034 11>; 213 214 status = "disabled"; 215 }; 216 217 uart2: uart@4006c000 { 218 compatible = "nxp,kinetis-uart"; 219 reg = <0x4006c000 0x1000>; 220 interrupts = <35 0>, <36 0>; 221 interrupt-names = "status", "error"; 222 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1034 12>; 223 224 status = "disabled"; 225 }; 226 227 uart3: uart@4006d000 { 228 compatible = "nxp,kinetis-uart"; 229 reg = <0x4006d000 0x1000>; 230 interrupts = <37 0>, <38 0>; 231 interrupt-names = "status", "error"; 232 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1034 13>; 233 234 status = "disabled"; 235 }; 236 237 uart4: uart@400ea000 { 238 compatible = "nxp,kinetis-uart"; 239 reg = <0x400ea000 0x1000>; 240 interrupts = <66 0>, <67 0>; 241 interrupt-names = "status", "error"; 242 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1028 10>; 243 244 status = "disabled"; 245 }; 246 247 uart5: uart@400eb000 { 248 compatible = "nxp,kinetis-uart"; 249 reg = <0x400eb000 0x1000>; 250 interrupts = <68 0>, <69 0>; 251 interrupt-names = "status", "error"; 252 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1028 11>; 253 254 status = "disabled"; 255 }; 256 257 porta: pinmux@40049000 { 258 compatible = "nxp,port-pinmux"; 259 reg = <0x40049000 0xd0>; 260 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 9>; 261 }; 262 263 portb: pinmux@4004a000 { 264 compatible = "nxp,port-pinmux"; 265 reg = <0x4004a000 0xd0>; 266 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 10>; 267 }; 268 269 portc: pinmux@4004b000 { 270 compatible = "nxp,port-pinmux"; 271 reg = <0x4004b000 0xd0>; 272 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 11>; 273 }; 274 275 portd: pinmux@4004c000 { 276 compatible = "nxp,port-pinmux"; 277 reg = <0x4004c000 0xd0>; 278 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 12>; 279 }; 280 281 porte: pinmux@4004d000 { 282 compatible = "nxp,port-pinmux"; 283 reg = <0x4004d000 0xd0>; 284 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 13>; 285 }; 286 287 gpioa: gpio@400ff000 { 288 compatible = "nxp,kinetis-gpio"; 289 status = "disabled"; 290 reg = <0x400ff000 0x40>; 291 interrupts = <59 2>; 292 gpio-controller; 293 #gpio-cells = <2>; 294 nxp,kinetis-port = <&porta>; 295 }; 296 297 gpiob: gpio@400ff040 { 298 compatible = "nxp,kinetis-gpio"; 299 status = "disabled"; 300 reg = <0x400ff040 0x40>; 301 interrupts = <60 2>; 302 gpio-controller; 303 #gpio-cells = <2>; 304 nxp,kinetis-port = <&portb>; 305 }; 306 307 gpioc: gpio@400ff080 { 308 compatible = "nxp,kinetis-gpio"; 309 status = "disabled"; 310 reg = <0x400ff080 0x40>; 311 interrupts = <61 2>; 312 gpio-controller; 313 #gpio-cells = <2>; 314 nxp,kinetis-port = <&portc>; 315 }; 316 317 gpiod: gpio@400ff0c0 { 318 compatible = "nxp,kinetis-gpio"; 319 status = "disabled"; 320 reg = <0x400ff0c0 0x40>; 321 interrupts = <62 2>; 322 gpio-controller; 323 #gpio-cells = <2>; 324 nxp,kinetis-port = <&portd>; 325 }; 326 327 gpioe: gpio@400ff100 { 328 compatible = "nxp,kinetis-gpio"; 329 status = "disabled"; 330 reg = <0x400ff100 0x40>; 331 interrupts = <63 2>; 332 gpio-controller; 333 #gpio-cells = <2>; 334 nxp,kinetis-port = <&porte>; 335 }; 336 337 spi0: spi@4002c000 { 338 compatible = "nxp,dspi"; 339 reg = <0x4002c000 0x88>; 340 interrupts = <26 3>; 341 dmas = <&edma0 0 14>, <&edma0 0 15>; 342 dma-names = "rx", "tx"; 343 rx-fifo-size = <4>; 344 tx-fifo-size = <4>; 345 clocks = <&sim KINETIS_SIM_BUS_CLK 0x103C 12>; 346 #address-cells = <1>; 347 #size-cells = <0>; 348 status = "disabled"; 349 }; 350 351 spi1: spi@4002d000 { 352 compatible = "nxp,dspi"; 353 reg = <0x4002d000 0x88>; 354 interrupts = <27 3>; 355 dmas = <&edma0 0 16>, <&edma0 0 16>; 356 dma-names = "rx", "tx"; 357 rx-fifo-size = <1>; 358 tx-fifo-size = <1>; 359 nxp,rx-tx-chn-share; 360 clocks = <&sim KINETIS_SIM_BUS_CLK 0x103C 13>; 361 #address-cells = <1>; 362 #size-cells = <0>; 363 status = "disabled"; 364 }; 365 366 spi2: spi@400ac000 { 367 compatible = "nxp,dspi"; 368 reg = <0x400ac000 0x88>; 369 interrupts = <65 3>; 370 dmas = <&edma0 0 38>, <&edma0 0 39>; 371 dma-names = "rx", "tx"; 372 rx-fifo-size = <1>; 373 tx-fifo-size = <1>; 374 nxp,rx-tx-chn-share; 375 clocks = <&sim KINETIS_SIM_BUS_CLK 0x1030 12>; 376 #address-cells = <1>; 377 #size-cells = <0>; 378 status = "disabled"; 379 }; 380 381 wdog: watchdog@40052000 { 382 compatible = "nxp,kinetis-wdog"; 383 reg = <0x40052000 16>; 384 interrupts = <22 0>; 385 clocks = <&sim KINETIS_SIM_LPO_CLK 0 0>; 386 }; 387 388 ftm0: ftm@40038000{ 389 compatible = "nxp,ftm"; 390 reg = <0x40038000 0x98>; 391 interrupts = <42 0>; 392 clocks = <&mcg KINETIS_MCG_FIXED_FREQ_CLK>; 393 prescaler = <16>; 394 status = "disabled"; 395 }; 396 397 ftm1: ftm@40039000{ 398 compatible = "nxp,ftm"; 399 reg = <0x40039000 0x98>; 400 interrupts = <43 0>; 401 clocks = <&mcg KINETIS_MCG_FIXED_FREQ_CLK>; 402 prescaler = <16>; 403 status = "disabled"; 404 }; 405 406 ftm2: ftm@4003a000{ 407 compatible = "nxp,ftm"; 408 reg = <0x4003a000 0x98>; 409 interrupts = <44 0>; 410 clocks = <&mcg KINETIS_MCG_FIXED_FREQ_CLK>; 411 prescaler = <16>; 412 status = "disabled"; 413 }; 414 415 ftm3: ftm@400b9000{ 416 compatible = "nxp,ftm"; 417 reg = <0x400b9000 0x98>; 418 interrupts = <71 0>; 419 clocks = <&mcg KINETIS_MCG_FIXED_FREQ_CLK>; 420 prescaler = <16>; 421 status = "disabled"; 422 }; 423 424 adc0: adc@4003b000{ 425 compatible = "nxp,kinetis-adc16"; 426 reg = <0x4003b000 0x70>; 427 clocks = <&sim KINETIS_SIM_SIM_SOPT7 0 0xF>, 428 <&sim KINETIS_SIM_SIM_SOPT7 7 0x80>; 429 dmas = <&edma0 0 40>; 430 dma-names = "adc0"; 431 clk-source = <0>; 432 interrupts = <39 0>; 433 status = "disabled"; 434 #io-channel-cells = <1>; 435 }; 436 437 adc1: adc@400bb000{ 438 compatible = "nxp,kinetis-adc16"; 439 reg = <0x400bb000 0x70>; 440 clocks = <&sim KINETIS_SIM_SIM_SOPT7 8 0xF00>, 441 <&sim KINETIS_SIM_SIM_SOPT7 15 0x8000>; 442 dmas = <&edma0 0 41>; 443 dma-names = "adc1"; 444 clk-source = <0>; 445 interrupts = <73 0>; 446 status = "disabled"; 447 #io-channel-cells = <1>; 448 }; 449 450 dac0: dac@400cc000 { 451 compatible = "nxp,kinetis-dac"; 452 reg = <0x400cc000 0x1000>; 453 interrupts = <56 0>; 454 voltage-reference = <1>; 455 status = "disabled"; 456 #io-channel-cells = <1>; 457 }; 458 459 dac1: dac@400cd000 { 460 compatible = "nxp,kinetis-dac"; 461 reg = <0x400cd000 0x1000>; 462 interrupts = <72 0>; 463 voltage-reference = <1>; 464 status = "disabled"; 465 #io-channel-cells = <1>; 466 }; 467 468 usbotg: usbd@40072000 { 469 compatible = "nxp,kinetis-usbd"; 470 reg = <0x40072000 0x1000>; 471 interrupts = <53 1>; 472 interrupt-names = "usb_otg"; 473 num-bidir-endpoints = <16>; 474 status = "disabled"; 475 }; 476 477 enet: ethernet@400c0000 { 478 compatible = "nxp,enet"; 479 reg = <0x400c0000 0x620>; 480 clocks = <&sim KINETIS_SIM_ENET_CLK 0 0>; 481 enet_mac: ethernet { 482 compatible = "nxp,enet-mac"; 483 interrupts = <83 0>, <84 0>, <85 0>; 484 interrupt-names = "TX", "RX", "ERR"; 485 nxp,mdio = <&enet_mdio>; 486 nxp,ptp-clock = <&enet_ptp_clock>; 487 phy-connection-type = "rmii"; 488 status = "disabled"; 489 }; 490 enet_mdio: mdio { 491 compatible = "nxp,enet-mdio"; 492 status = "disabled"; 493 #address-cells = <1>; 494 #size-cells = <0>; 495 }; 496 enet_ptp_clock: ptp_clock { 497 compatible = "nxp,enet-ptp-clock"; 498 interrupts = <82 0>; 499 interrupt-names = "IEEE1588_TMR"; 500 clocks = <&sim KINETIS_SIM_ENET_1588_CLK 0 0>; 501 status = "disabled"; 502 }; 503 }; 504 505 rnga: random@40029000 { 506 compatible = "nxp,kinetis-rnga"; 507 reg = <0x40029000 0x1000>; 508 status = "okay"; 509 interrupts = <23 0>; 510 }; 511 512 flexcan0: can@40024000 { 513 compatible = "nxp,flexcan"; 514 reg = <0x40024000 0x1000>; 515 interrupts = <75 0>, <76 0>, <77 0>, <78 0>, <79 0>, <80 0>; 516 interrupt-names = "mb-0-15", "bus-off", "error", "tx-warning", "rx-warning", "wake-up"; 517 clocks = <&sim KINETIS_SIM_BUS_CLK 0x103C 4>; 518 clk-source = <1>; 519 status = "disabled"; 520 }; 521 522 edma0: dma-controller@40008000 { 523 #dma-cells = <2>; 524 compatible = "nxp,mcux-edma"; 525 nxp,version = <2>; 526 dma-channels = <16>; 527 dma-requests = <64>; 528 nxp,mem2mem; 529 reg = <0x40008000 0x1000>, 530 <0x40021000 0x1000>; 531 interrupts = <0 0>, <1 0>, <2 0>, <3 0>, 532 <4 0>, <5 0>, <6 0>, <7 0>, 533 <8 0>, <9 0>, <10 0>, <11 0>, 534 <12 0>, <13 0>, <14 0>, <15 0>, 535 <16 0>; 536 clocks = <&sim KINETIS_SIM_DMA_CLK 0x1040 0x00000002>, 537 <&sim KINETIS_SIM_DMAMUX_CLK 0x103C 0x00000002>; 538 status = "disabled"; 539 }; 540 541 pit0: pit@40037000 { 542 compatible = "nxp,pit"; 543 reg = <0x40037000 0x1000>; 544 clocks = <&sim KINETIS_SIM_BUS_CLK 0x103c 23>; 545 status = "disabled"; 546 max-load-value = <0xffffffff>; 547 #address-cells = <1>; 548 #size-cells = <0>; 549 550 pit0_channel0: pit0_channel@0 { 551 compatible = "nxp,pit-channel"; 552 reg = <0>; 553 interrupts = <48 0>; 554 status = "disabled"; 555 }; 556 557 pit0_channel1: pit0_channel@1 { 558 compatible = "nxp,pit-channel"; 559 reg = <1>; 560 interrupts = <49 0>; 561 status = "disabled"; 562 }; 563 564 pit0_channel2: pit0_channel@2 { 565 compatible = "nxp,pit-channel"; 566 reg = <2>; 567 interrupts = <50 0>; 568 status = "disabled"; 569 }; 570 571 pit0_channel3: pit0_channel@3 { 572 compatible = "nxp,pit-channel"; 573 reg = <3>; 574 interrupts = <51 0>; 575 status = "disabled"; 576 }; 577 }; 578 }; 579}; 580 581&nvic { 582 arm,num-irq-priority-bits = <4>; 583}; 584