| /* |
| * Copyright 2014 Texas Instruments, Inc. |
| * |
| * Keystone 2 Lamarr SoC specific device tree |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation. |
| */ |
| |
| #include <dt-bindings/reset/ti-syscon.h> |
| |
| / { |
| compatible = "ti,k2l", "ti,keystone"; |
| model = "Texas Instruments Keystone 2 Lamarr SoC"; |
| |
| cpus { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| interrupt-parent = <&gic>; |
| |
| cpu@0 { |
| compatible = "arm,cortex-a15"; |
| device_type = "cpu"; |
| reg = <0>; |
| }; |
| |
| cpu@1 { |
| compatible = "arm,cortex-a15"; |
| device_type = "cpu"; |
| reg = <1>; |
| }; |
| }; |
| |
| aliases { |
| rproc0 = &dsp0; |
| rproc1 = &dsp1; |
| rproc2 = &dsp2; |
| rproc3 = &dsp3; |
| }; |
| |
| soc { |
| /include/ "keystone-k2l-clocks.dtsi" |
| |
| uart2: serial@2348400 { |
| compatible = "ti,da830-uart", "ns16550a"; |
| current-speed = <115200>; |
| reg-shift = <2>; |
| reg-io-width = <4>; |
| reg = <0x02348400 0x100>; |
| clocks = <&clkuart2>; |
| interrupts = <GIC_SPI 432 IRQ_TYPE_EDGE_RISING>; |
| }; |
| |
| uart3: serial@2348800 { |
| compatible = "ti,da830-uart", "ns16550a"; |
| current-speed = <115200>; |
| reg-shift = <2>; |
| reg-io-width = <4>; |
| reg = <0x02348800 0x100>; |
| clocks = <&clkuart3>; |
| interrupts = <GIC_SPI 435 IRQ_TYPE_EDGE_RISING>; |
| }; |
| |
| k2l_pmx: pinmux@2620690 { |
| compatible = "pinctrl-single"; |
| reg = <0x02620690 0xc>; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| #pinctrl-cells = <2>; |
| pinctrl-single,bit-per-mux; |
| pinctrl-single,register-width = <32>; |
| pinctrl-single,function-mask = <0x1>; |
| status = "disabled"; |
| |
| uart3_emifa_pins: pinmux_uart3_emifa_pins { |
| pinctrl-single,bits = < |
| /* UART3_EMIFA_SEL */ |
| 0x0 0x0 0xc0 |
| >; |
| }; |
| |
| uart2_emifa_pins: pinmux_uart2_emifa_pins { |
| pinctrl-single,bits = < |
| /* UART2_EMIFA_SEL */ |
| 0x0 0x0 0x30 |
| >; |
| }; |
| |
| uart01_spi2_pins: pinmux_uart01_spi2_pins { |
| pinctrl-single,bits = < |
| /* UART01_SPI2_SEL */ |
| 0x0 0x0 0x4 |
| >; |
| }; |
| |
| dfesync_rp1_pins: pinmux_dfesync_rp1_pins{ |
| pinctrl-single,bits = < |
| /* DFESYNC_RP1_SEL */ |
| 0x0 0x0 0x2 |
| >; |
| }; |
| |
| avsif_pins: pinmux_avsif_pins { |
| pinctrl-single,bits = < |
| /* AVSIF_SEL */ |
| 0x0 0x0 0x1 |
| >; |
| }; |
| |
| gpio_emu_pins: pinmux_gpio_emu_pins { |
| pinctrl-single,bits = < |
| /* |
| * GPIO_EMU_SEL[31]: 0-GPIO31, 1-EMU33 |
| * GPIO_EMU_SEL[30]: 0-GPIO30, 1-EMU32 |
| * GPIO_EMU_SEL[29]: 0-GPIO29, 1-EMU31 |
| * GPIO_EMU_SEL[28]: 0-GPIO28, 1-EMU30 |
| * GPIO_EMU_SEL[27]: 0-GPIO27, 1-EMU29 |
| * GPIO_EMU_SEL[26]: 0-GPIO26, 1-EMU28 |
| * GPIO_EMU_SEL[25]: 0-GPIO25, 1-EMU27 |
| * GPIO_EMU_SEL[24]: 0-GPIO24, 1-EMU26 |
| * GPIO_EMU_SEL[23]: 0-GPIO23, 1-EMU25 |
| * GPIO_EMU_SEL[22]: 0-GPIO22, 1-EMU24 |
| * GPIO_EMU_SEL[21]: 0-GPIO21, 1-EMU23 |
| * GPIO_EMU_SEL[20]: 0-GPIO20, 1-EMU22 |
| * GPIO_EMU_SEL[19]: 0-GPIO19, 1-EMU21 |
| * GPIO_EMU_SEL[18]: 0-GPIO18, 1-EMU20 |
| * GPIO_EMU_SEL[17]: 0-GPIO17, 1-EMU19 |
| */ |
| 0x4 0x0000 0xFFFE0000 |
| >; |
| }; |
| |
| gpio_timio_pins: pinmux_gpio_timio_pins { |
| pinctrl-single,bits = < |
| /* |
| * GPIO_TIMIO_SEL[15]: 0-GPIO15, 1-TIMO7 |
| * GPIO_TIMIO_SEL[14]: 0-GPIO14, 1-TIMO6 |
| * GPIO_TIMIO_SEL[13]: 0-GPIO13, 1-TIMO5 |
| * GPIO_TIMIO_SEL[12]: 0-GPIO12, 1-TIMO4 |
| * GPIO_TIMIO_SEL[11]: 0-GPIO11, 1-TIMO3 |
| * GPIO_TIMIO_SEL[10]: 0-GPIO10, 1-TIMO2 |
| * GPIO_TIMIO_SEL[9]: 0-GPIO9, 1-TIMI7 |
| * GPIO_TIMIO_SEL[8]: 0-GPIO8, 1-TIMI6 |
| * GPIO_TIMIO_SEL[7]: 0-GPIO7, 1-TIMI5 |
| * GPIO_TIMIO_SEL[6]: 0-GPIO6, 1-TIMI4 |
| * GPIO_TIMIO_SEL[5]: 0-GPIO5, 1-TIMI3 |
| * GPIO_TIMIO_SEL[4]: 0-GPIO4, 1-TIMI2 |
| */ |
| 0x4 0x0 0xFFF0 |
| >; |
| }; |
| |
| gpio_spi2cs_pins: pinmux_gpio_spi2cs_pins { |
| pinctrl-single,bits = < |
| /* |
| * GPIO_SPI2CS_SEL[3]: 0-GPIO3, 1-SPI2CS4 |
| * GPIO_SPI2CS_SEL[2]: 0-GPIO2, 1-SPI2CS3 |
| * GPIO_SPI2CS_SEL[1]: 0-GPIO1, 1-SPI2CS2 |
| * GPIO_SPI2CS_SEL[0]: 0-GPIO0, 1-SPI2CS1 |
| */ |
| 0x4 0x0 0xF |
| >; |
| }; |
| |
| gpio_dfeio_pins: pinmux_gpio_dfeio_pins { |
| pinctrl-single,bits = < |
| /* |
| * GPIO_DFEIO_SEL[31]: 0-DFEIO17, 1-GPIO63 |
| * GPIO_DFEIO_SEL[30]: 0-DFEIO16, 1-GPIO62 |
| * GPIO_DFEIO_SEL[29]: 0-DFEIO15, 1-GPIO61 |
| * GPIO_DFEIO_SEL[28]: 0-DFEIO14, 1-GPIO60 |
| * GPIO_DFEIO_SEL[27]: 0-DFEIO13, 1-GPIO59 |
| * GPIO_DFEIO_SEL[26]: 0-DFEIO12, 1-GPIO58 |
| * GPIO_DFEIO_SEL[25]: 0-DFEIO11, 1-GPIO57 |
| * GPIO_DFEIO_SEL[24]: 0-DFEIO10, 1-GPIO56 |
| * GPIO_DFEIO_SEL[23]: 0-DFEIO9, 1-GPIO55 |
| * GPIO_DFEIO_SEL[22]: 0-DFEIO8, 1-GPIO54 |
| * GPIO_DFEIO_SEL[21]: 0-DFEIO7, 1-GPIO53 |
| * GPIO_DFEIO_SEL[20]: 0-DFEIO6, 1-GPIO52 |
| * GPIO_DFEIO_SEL[19]: 0-DFEIO5, 1-GPIO51 |
| * GPIO_DFEIO_SEL[18]: 0-DFEIO4, 1-GPIO50 |
| * GPIO_DFEIO_SEL[17]: 0-DFEIO3, 1-GPIO49 |
| * GPIO_DFEIO_SEL[16]: 0-DFEIO2, 1-GPIO48 |
| */ |
| 0x8 0x0 0xFFFF0000 |
| >; |
| }; |
| |
| gpio_emifa_pins: pinmux_gpio_emifa_pins { |
| pinctrl-single,bits = < |
| /* |
| * GPIO_EMIFA_SEL[15]: 0-EMIFA17, 1-GPIO47 |
| * GPIO_EMIFA_SEL[14]: 0-EMIFA16, 1-GPIO46 |
| * GPIO_EMIFA_SEL[13]: 0-EMIFA15, 1-GPIO45 |
| * GPIO_EMIFA_SEL[12]: 0-EMIFA14, 1-GPIO44 |
| * GPIO_EMIFA_SEL[11]: 0-EMIFA13, 1-GPIO43 |
| * GPIO_EMIFA_SEL[10]: 0-EMIFA10, 1-GPIO42 |
| * GPIO_EMIFA_SEL[9]: 0-EMIFA9, 1-GPIO41 |
| * GPIO_EMIFA_SEL[8]: 0-EMIFA8, 1-GPIO40 |
| * GPIO_EMIFA_SEL[7]: 0-EMIFA7, 1-GPIO39 |
| * GPIO_EMIFA_SEL[6]: 0-EMIFA6, 1-GPIO38 |
| * GPIO_EMIFA_SEL[5]: 0-EMIFA5, 1-GPIO37 |
| * GPIO_EMIFA_SEL[4]: 0-EMIFA4, 1-GPIO36 |
| * GPIO_EMIFA_SEL[3]: 0-EMIFA3, 1-GPIO35 |
| * GPIO_EMIFA_SEL[2]: 0-EMIFA2, 1-GPIO34 |
| * GPIO_EMIFA_SEL[1]: 0-EMIFA1, 1-GPIO33 |
| * GPIO_EMIFA_SEL[0]: 0-EMIFA0, 1-GPIO32 |
| */ |
| 0x8 0x0 0xFFFF |
| >; |
| }; |
| }; |
| |
| msm_ram: msmram@c000000 { |
| compatible = "mmio-sram"; |
| reg = <0x0c000000 0x200000>; |
| ranges = <0x0 0x0c000000 0x200000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| |
| sram-bm@1f8000 { |
| reg = <0x001f8000 0x8000>; |
| }; |
| }; |
| |
| psc: power-sleep-controller@2350000 { |
| pscrst: reset-controller { |
| compatible = "ti,k2l-pscrst", "ti,syscon-reset"; |
| #reset-cells = <1>; |
| |
| ti,reset-bits = < |
| 0xa3c 8 0xa3c 8 0x83c 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 0: dsp0 */ |
| 0xa40 8 0xa40 8 0x840 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 1: dsp1 */ |
| 0xa44 8 0xa44 8 0x844 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 2: dsp2 */ |
| 0xa48 8 0xa48 8 0x848 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 3: dsp3 */ |
| >; |
| }; |
| }; |
| |
| osr: sram@70000000 { |
| compatible = "mmio-sram"; |
| reg = <0x70000000 0x10000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| clocks = <&clkosr>; |
| }; |
| |
| dspgpio0: keystone_dsp_gpio@2620240 { |
| compatible = "ti,keystone-dsp-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| gpio,syscon-dev = <&devctrl 0x240>; |
| }; |
| |
| dspgpio1: keystone_dsp_gpio@2620244 { |
| compatible = "ti,keystone-dsp-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| gpio,syscon-dev = <&devctrl 0x244>; |
| }; |
| |
| dspgpio2: keystone_dsp_gpio@2620248 { |
| compatible = "ti,keystone-dsp-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| gpio,syscon-dev = <&devctrl 0x248>; |
| }; |
| |
| dspgpio3: keystone_dsp_gpio@262024c { |
| compatible = "ti,keystone-dsp-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| gpio,syscon-dev = <&devctrl 0x24c>; |
| }; |
| |
| dsp0: dsp@10800000 { |
| compatible = "ti,k2l-dsp"; |
| reg = <0x10800000 0x00100000>, |
| <0x10e00000 0x00008000>, |
| <0x10f00000 0x00008000>; |
| reg-names = "l2sram", "l1pram", "l1dram"; |
| clocks = <&clkgem0>; |
| ti,syscon-dev = <&devctrl 0x844>; |
| resets = <&pscrst 0>; |
| interrupt-parent = <&kirq0>; |
| interrupts = <0 8>; |
| interrupt-names = "vring", "exception"; |
| kick-gpios = <&dspgpio0 27 0>; |
| status = "disabled"; |
| }; |
| |
| dsp1: dsp@11800000 { |
| compatible = "ti,k2l-dsp"; |
| reg = <0x11800000 0x00100000>, |
| <0x11e00000 0x00008000>, |
| <0x11f00000 0x00008000>; |
| reg-names = "l2sram", "l1pram", "l1dram"; |
| clocks = <&clkgem1>; |
| ti,syscon-dev = <&devctrl 0x848>; |
| resets = <&pscrst 1>; |
| interrupt-parent = <&kirq0>; |
| interrupts = <1 9>; |
| interrupt-names = "vring", "exception"; |
| kick-gpios = <&dspgpio1 27 0>; |
| status = "disabled"; |
| }; |
| |
| dsp2: dsp@12800000 { |
| compatible = "ti,k2l-dsp"; |
| reg = <0x12800000 0x00100000>, |
| <0x12e00000 0x00008000>, |
| <0x12f00000 0x00008000>; |
| reg-names = "l2sram", "l1pram", "l1dram"; |
| clocks = <&clkgem2>; |
| ti,syscon-dev = <&devctrl 0x84c>; |
| resets = <&pscrst 2>; |
| interrupt-parent = <&kirq0>; |
| interrupts = <2 10>; |
| interrupt-names = "vring", "exception"; |
| kick-gpios = <&dspgpio2 27 0>; |
| status = "disabled"; |
| }; |
| |
| dsp3: dsp@13800000 { |
| compatible = "ti,k2l-dsp"; |
| reg = <0x13800000 0x00100000>, |
| <0x13e00000 0x00008000>, |
| <0x13f00000 0x00008000>; |
| reg-names = "l2sram", "l1pram", "l1dram"; |
| clocks = <&clkgem3>; |
| ti,syscon-dev = <&devctrl 0x850>; |
| resets = <&pscrst 3>; |
| interrupt-parent = <&kirq0>; |
| interrupts = <3 11>; |
| interrupt-names = "vring", "exception"; |
| kick-gpios = <&dspgpio3 27 0>; |
| status = "disabled"; |
| }; |
| |
| mdio: mdio@26200f00 { |
| compatible = "ti,keystone_mdio", "ti,davinci_mdio"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| reg = <0x26200f00 0x100>; |
| status = "disabled"; |
| clocks = <&clkcpgmac>; |
| clock-names = "fck"; |
| bus_freq = <2500000>; |
| }; |
| /include/ "keystone-k2l-netcp.dtsi" |
| }; |
| }; |
| |
| &spi0 { |
| ti,davinci-spi-num-cs = <5>; |
| }; |
| |
| &spi1 { |
| ti,davinci-spi-num-cs = <3>; |
| }; |
| |
| &spi2 { |
| ti,davinci-spi-num-cs = <5>; |
| /* Pin muxed. Enabled and configured by Bootloader */ |
| status = "disabled"; |
| }; |