mirror of
https://github.com/zephyrproject-rtos/zephyr
synced 2025-09-01 08:36:00 +00:00
Defines device tree aliases for on-chip peripherals at the soc level instead of the board level for all kinetis socs. The eliminates some duplicate code in the board level device trees, and will allow drivers to use device-tree generated macros directly instead of through dts fixups. Signed-off-by: Maureen Helm <maureen.helm@nxp.com>
237 lines
4.8 KiB
Plaintext
237 lines
4.8 KiB
Plaintext
/* SPDX-License-Identifier: Apache-2.0 */
|
|
|
|
#include <arm/armv6-m.dtsi>
|
|
#include <dt-bindings/clock/kinetis_sim.h>
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
#include <dt-bindings/i2c/i2c.h>
|
|
|
|
/ {
|
|
aliases {
|
|
adc-0 = &adc0;
|
|
gpio-a = &gpioa;
|
|
gpio-b = &gpiob;
|
|
gpio-c = &gpioc;
|
|
i2c-0 = &i2c0;
|
|
i2c-1 = &i2c1;
|
|
pinmux-a = &pinmux_a;
|
|
pinmux-b = &pinmux_b;
|
|
pinmux-c = &pinmux_c;
|
|
pwm-0 = &pwm0;
|
|
pwm-1 = &pwm1;
|
|
pwm-2 = &pwm2;
|
|
rtc-0 = &rtc0;
|
|
spi-0 = &spi0;
|
|
spi-1 = &spi1;
|
|
uart-0 = &lpuart0;
|
|
};
|
|
|
|
cpus {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
cpu@0 {
|
|
device_type = "cpu";
|
|
compatible = "arm,cortex-m0+";
|
|
reg = <0>;
|
|
};
|
|
};
|
|
|
|
sram0: memory@20000000 {
|
|
compatible = "mmio-sram";
|
|
reg = <0x20000000 0x20000>;
|
|
};
|
|
|
|
soc {
|
|
mcg: clock-controller@40064000 {
|
|
compatible = "nxp,kw41z-mcg";
|
|
reg = <0x40064000 0x13>;
|
|
};
|
|
|
|
clock-controller@40065000 {
|
|
compatible = "nxp,kw41z-osc";
|
|
reg = <0x40065000 0x4>;
|
|
enable-external-reference;
|
|
};
|
|
|
|
rtc0: rtc@4003d000 {
|
|
compatible = "nxp,kinetis-rtc";
|
|
reg = <0x4003d000 0x20>;
|
|
interrupts = <20 0>;
|
|
clock-frequency = <32768>;
|
|
label = "RTC_0";
|
|
prescaler = <32768>;
|
|
};
|
|
|
|
sim: sim@40047000 {
|
|
compatible = "nxp,kinetis-sim";
|
|
reg = <0x40047000 0x1060>;
|
|
label = "SIM";
|
|
|
|
#clock-cells = <3>;
|
|
};
|
|
|
|
flash-controller@40020000 {
|
|
compatible = "nxp,kinetis-ftfa";
|
|
label = "FLASH_CTRL";
|
|
reg = <0x40020000 0x2c>;
|
|
interrupts = <5 0>;
|
|
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
|
|
flash0: flash@0 {
|
|
compatible = "soc-nv-flash";
|
|
label = "MCUX_FLASH";
|
|
reg = <0 0x80000>;
|
|
erase-block-size = <2048>;
|
|
write-block-size = <4>;
|
|
};
|
|
};
|
|
|
|
i2c0: i2c@40066000 {
|
|
compatible = "nxp,kinetis-i2c";
|
|
clock-frequency = <I2C_BITRATE_STANDARD>;
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x40066000 0x1000>;
|
|
interrupts = <8 0>;
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x1034 6>;
|
|
label = "I2C_0";
|
|
status = "disabled";
|
|
};
|
|
|
|
i2c1: i2c@40067000 {
|
|
compatible = "nxp,kinetis-i2c";
|
|
clock-frequency = <I2C_BITRATE_STANDARD>;
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x40067000 0x1000>;
|
|
interrupts = <9 0>;
|
|
clocks = <&sim KINETIS_SIM_CORESYS_CLK 0x1034 7>;
|
|
label = "I2C_1";
|
|
status = "disabled";
|
|
};
|
|
|
|
lpuart0: lpuart@40054000 {
|
|
compatible = "nxp,kinetis-lpuart";
|
|
reg = <0x40054000 0x18>;
|
|
interrupts = <12 0>;
|
|
clocks = <&sim KINETIS_SIM_CORESYS_CLK 0x1038 20>;
|
|
label = "UART_0";
|
|
|
|
status = "disabled";
|
|
};
|
|
|
|
pinmux_a: pinmux@40049000 {
|
|
compatible = "nxp,kinetis-pinmux";
|
|
reg = <0x40049000 0xa4>;
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 9>;
|
|
};
|
|
|
|
pinmux_b: pinmux@4004a000 {
|
|
compatible = "nxp,kinetis-pinmux";
|
|
reg = <0x4004a000 0xa4>;
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 10>;
|
|
};
|
|
|
|
pinmux_c: pinmux@4004b000 {
|
|
compatible = "nxp,kinetis-pinmux";
|
|
reg = <0x4004b000 0xa4>;
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x1038 11>;
|
|
};
|
|
|
|
gpioa: gpio@400ff000 {
|
|
compatible = "nxp,kinetis-gpio";
|
|
reg = <0x400ff000 0x40>;
|
|
interrupts = <30 2>;
|
|
label = "GPIO_0";
|
|
gpio-controller;
|
|
#gpio-cells = <2>;
|
|
};
|
|
|
|
gpiob: gpio@400ff040 {
|
|
compatible = "nxp,kinetis-gpio";
|
|
reg = <0x400ff040 0x40>;
|
|
label = "GPIO_1";
|
|
gpio-controller;
|
|
#gpio-cells = <2>;
|
|
};
|
|
|
|
gpioc: gpio@400ff080 {
|
|
compatible = "nxp,kinetis-gpio";
|
|
reg = <0x400ff080 0x40>;
|
|
interrupts = <31 2>;
|
|
label = "GPIO_2";
|
|
gpio-controller;
|
|
#gpio-cells = <2>;
|
|
};
|
|
|
|
spi0: spi@4002c000 {
|
|
compatible = "nxp,kinetis-dspi";
|
|
reg = <0x4002c000 0x9C>;
|
|
interrupts = <10 3>;
|
|
label = "SPI_0";
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x103C 12>;
|
|
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
};
|
|
|
|
spi1: spi@4002d000 {
|
|
compatible = "nxp,kinetis-dspi";
|
|
reg = <0x4002d000 0x9C>;
|
|
interrupts = <29 3>;
|
|
label = "SPI_1";
|
|
clocks = <&sim KINETIS_SIM_BUS_CLK 0x103C 13>;
|
|
status = "disabled";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
};
|
|
|
|
pwm0: pwm@40038000 {
|
|
compatible = "nxp,kw41z-pwm";
|
|
reg = <0x40038000 0x88>;
|
|
prescaler = <2>;
|
|
period = <1000>;
|
|
/* channel information needed - fixme */
|
|
};
|
|
|
|
pwm1: pwm@40039000 {
|
|
compatible = "nxp,kw41z-pwm";
|
|
reg = <0x40039000 0x88>;
|
|
prescaler = <2>;
|
|
period = <1000>;
|
|
/* channel information needed - fixme */
|
|
};
|
|
|
|
pwm2: pwm@4003a000 {
|
|
compatible = "nxp,kw41z-pwm";
|
|
reg = <0x4003a000 0x88>;
|
|
prescaler = <2>;
|
|
period = <1000>;
|
|
/* channel information needed - fixme */
|
|
};
|
|
|
|
adc0: adc@4003b000{
|
|
compatible = "nxp,kinetis-adc16";
|
|
reg = <0x4003b000 0x70>;
|
|
interrupts = <15 0>;
|
|
label = "ADC_0";
|
|
status = "disabled";
|
|
#io-channel-cells = <1>;
|
|
};
|
|
|
|
trng: random@40029000 {
|
|
compatible = "nxp,kinetis-trng";
|
|
reg = <0x40029000 0x1000>;
|
|
status = "okay";
|
|
interrupts = <13 0>;
|
|
label = "TRNG";
|
|
};
|
|
};
|
|
};
|
|
|
|
&nvic {
|
|
arm,num-irq-priority-bits = <2>;
|
|
};
|