// SPDX-License-Identifier: GPL-2.0 /* * Device Tree Source for K2G SOC * * Copyright (C) 2016-2017 Texas Instruments Incorporated - http://www.ti.com/ */ #include #include #include / { compatible = "ti,k2g","ti,keystone"; model = "Texas Instruments K2G SoC"; #address-cells = <2>; #size-cells = <2>; interrupt-parent = <&gic>; chosen { }; aliases { serial0 = &uart0; serial1 = &uart1; serial2 = &uart2; i2c0 = &i2c0; i2c1 = &i2c1; i2c2 = &i2c2; rproc0 = &dsp0; }; cpus { #address-cells = <1>; #size-cells = <0>; cpu@0 { compatible = "arm,cortex-a15"; device_type = "cpu"; reg = <0>; }; }; gic: interrupt-controller@2561000 { compatible = "arm,gic-400", "arm,cortex-a15-gic"; #interrupt-cells = <3>; interrupt-controller; reg = <0x0 0x02561000 0x0 0x1000>, <0x0 0x02562000 0x0 0x2000>, <0x0 0x02564000 0x0 0x2000>, <0x0 0x02566000 0x0 0x2000>; interrupts = ; }; timer { compatible = "arm,armv7-timer"; interrupts = , , , ; }; pmu { compatible = "arm,cortex-a15-pmu"; interrupts = ; }; soc0: soc@0 { #address-cells = <1>; #size-cells = <1>; #pinctrl-cells = <1>; compatible = "ti,keystone","simple-bus"; ranges = <0x0 0x0 0x0 0xc0000000>; dma-ranges = <0x80000000 0x8 0x00000000 0x80000000>; msm_ram: msmram@c000000 { compatible = "mmio-sram"; reg = <0x0c000000 0x100000>; ranges = <0x0 0x0c000000 0x100000>; #address-cells = <1>; #size-cells = <1>; sram-bm@f7000 { reg = <0x000f7000 0x8000>; }; }; k2g_pinctrl: pinmux@2621000 { compatible = "pinctrl-single"; reg = <0x02621000 0x410>; pinctrl-single,register-width = <32>; pinctrl-single,function-mask = <0x001b0007>; }; devctrl: device-state-control@2620000 { compatible = "ti,keystone-devctrl", "syscon"; reg = <0x02620000 0x1000>; }; uart0: serial@2530c00 { compatible = "ti,da830-uart", "ns16550a"; current-speed = <115200>; reg-shift = <2>; reg-io-width = <4>; reg = <0x02530c00 0x100>; interrupts = ; clocks = <&k2g_clks 0x2c 0>; power-domains = <&k2g_pds 0x2c>; status = "disabled"; }; uart1: serial@02531000 { compatible = "ti,da830-uart", "ns16550a"; current-speed = <115200>; reg-shift = <2>; reg-io-width = <4>; reg = <0x02531000 0x100>; interrupts = ; clocks = <&k2g_clks 0x2d 0>; power-domains = <&k2g_pds 0x2d>; status = "disabled"; }; uart2: serial@02531400 { compatible = "ti,da830-uart", "ns16550a"; current-speed = <115200>; reg-shift = <2>; reg-io-width = <4>; reg = <0x02531400 0x100>; interrupts = ; clocks = <&k2g_clks 0x2e 0>; power-domains = <&k2g_pds 0x2e>; status = "disabled"; }; dcan0: can@260b200 { compatible = "ti,am4372-d_can", "ti,am3352-d_can"; reg = <0x0260B200 0x200>; interrupts = ; status = "disabled"; power-domains = <&k2g_pds 0x0008>; clocks = <&k2g_clks 0x0008 1>; }; dcan1: can@260b400 { compatible = "ti,am4372-d_can", "ti,am3352-d_can"; reg = <0x0260B400 0x200>; interrupts = ; status = "disabled"; power-domains = <&k2g_pds 0x0009>; clocks = <&k2g_clks 0x0009 1>; }; i2c0: i2c@2530000 { compatible = "ti,keystone-i2c"; reg = <0x02530000 0x400>; clocks = <&k2g_clks 0x003a 0>; power-domains = <&k2g_pds 0x003a>; interrupts = ; #address-cells = <1>; #size-cells = <0>; status = "disabled"; }; i2c1: i2c@2530400 { compatible = "ti,keystone-i2c"; reg = <0x02530400 0x400>; clocks = <&k2g_clks 0x003b 0>; power-domains = <&k2g_pds 0x003b>; interrupts = ; #address-cells = <1>; #size-cells = <0>; status = "disabled"; }; i2c2: i2c@2530800 { compatible = "ti,keystone-i2c"; reg = <0x02530800 0x400>; clocks = <&k2g_clks 0x003c 0>; power-domains = <&k2g_pds 0x003c>; interrupts = ; #address-cells = <1>; #size-cells = <0>; status = "disabled"; }; kirq0: keystone_irq@26202a0 { compatible = "ti,keystone-irq"; interrupts = ; interrupt-controller; #interrupt-cells = <1>; ti,syscon-dev = <&devctrl 0x2a0>; }; dspgpio0: keystone_dsp_gpio@2620240 { compatible = "ti,keystone-dsp-gpio"; gpio-controller; #gpio-cells = <2>; gpio,syscon-dev = <&devctrl 0x240>; }; dsp0: dsp@10800000 { compatible = "ti,k2g-dsp"; reg = <0x10800000 0x00100000>, <0x10e00000 0x00008000>, <0x10f00000 0x00008000>; reg-names = "l2sram", "l1pram", "l1dram"; power-domains = <&k2g_pds 0x0046>; ti,syscon-dev = <&devctrl 0x844>; resets = <&k2g_reset 0x0046 0x1>; interrupt-parent = <&kirq0>; interrupts = <0 8>; interrupt-names = "vring", "exception"; kick-gpios = <&dspgpio0 27 0>; status = "disabled"; }; msgmgr: msgmgr@2a00000 { compatible = "ti,k2g-message-manager"; #mbox-cells = <2>; reg-names = "queue_proxy_region", "queue_state_debug_region"; reg = <0x02a00000 0x400000>, <0x028c3400 0x400>; interrupt-names = "rx_005", "rx_057"; interrupts = , ; }; pmmc: pmmc@2921c00 { compatible = "ti,k2g-sci"; /* * In case of rare platforms that does not use k2g as * system master, use /delete-property/ */ ti,system-reboot-controller; mbox-names = "rx", "tx"; mboxes= <&msgmgr 5 2>, <&msgmgr 0 0>; reg-names = "debug_messages"; reg = <0x02921c00 0x400>; k2g_pds: power-controller { compatible = "ti,sci-pm-domain"; #power-domain-cells = <1>; }; k2g_clks: clocks { compatible = "ti,k2g-sci-clk"; #clock-cells = <2>; }; k2g_reset: reset-controller { compatible = "ti,sci-reset"; #reset-cells = <2>; }; }; gpio0: gpio@2603000 { compatible = "ti,k2g-gpio", "ti,keystone-gpio"; reg = <0x02603000 0x100>; gpio-controller; #gpio-cells = <2>; interrupts = , , , , , , , , ; interrupt-controller; #interrupt-cells = <2>; ti,ngpio = <144>; ti,davinci-gpio-unbanked = <0>; clocks = <&k2g_clks 0x001b 0x0>; clock-names = "gpio"; }; gpio1: gpio@260a000 { compatible = "ti,k2g-gpio", "ti,keystone-gpio"; reg = <0x0260a000 0x100>; gpio-controller; #gpio-cells = <2>; interrupts = , , , , ; interrupt-controller; #interrupt-cells = <2>; ti,ngpio = <68>; ti,davinci-gpio-unbanked = <0>; clocks = <&k2g_clks 0x001c 0x0>; clock-names = "gpio"; }; edma0: edma@2700000 { compatible = "ti,k2g-edma3-tpcc", "ti,edma3-tpcc"; reg = <0x02700000 0x8000>; reg-names = "edma3_cc"; interrupts = , , ; interrupt-names = "edma3_ccint", "emda3_mperr", "edma3_ccerrint"; dma-requests = <64>; #dma-cells = <2>; ti,tptcs = <&edma0_tptc0 7>, <&edma0_tptc1 0>; ti,edma-memcpy-channels = <32 33 34 35>; power-domains = <&k2g_pds 0x3f>; }; edma0_tptc0: tptc@2760000 { compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc"; reg = <0x02760000 0x400>; power-domains = <&k2g_pds 0x3f>; }; edma0_tptc1: tptc@2768000 { compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc"; reg = <0x02768000 0x400>; power-domains = <&k2g_pds 0x3f>; }; edma1: edma@2728000 { compatible = "ti,k2g-edma3-tpcc", "ti,edma3-tpcc"; reg = <0x02728000 0x8000>; reg-names = "edma3_cc"; interrupts = , , ; interrupt-names = "edma3_ccint", "emda3_mperr", "edma3_ccerrint"; dma-requests = <64>; #dma-cells = <2>; ti,tptcs = <&edma1_tptc0 7>, <&edma1_tptc1 0>; /* * memcpy is disabled, can be enabled with: * ti,edma-memcpy-channels = <12 13 14 15>; * for example. */ power-domains = <&k2g_pds 0x4f>; }; edma1_tptc0: tptc@27b0000 { compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc"; reg = <0x027b0000 0x400>; power-domains = <&k2g_pds 0x4f>; }; edma1_tptc1: tptc@27b8000 { compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc"; reg = <0x027b8000 0x400>; power-domains = <&k2g_pds 0x4f>; }; mmc0: mmc@23000000 { compatible = "ti,k2g-hsmmc", "ti,omap4-hsmmc"; reg = <0x23000000 0x400>; interrupts = ; dmas = <&edma1 24 0>, <&edma1 25 0>; dma-names = "tx", "rx"; bus-width = <4>; ti,needs-special-reset; no-1-8-v; max-frequency = <96000000>; power-domains = <&k2g_pds 0xb>; clocks = <&k2g_clks 0xb 1>, <&k2g_clks 0xb 2>; clock-names = "fck", "mmchsdb_fck"; status = "disabled"; }; mmc1: mmc@23100000 { compatible = "ti,k2g-hsmmc", "ti,omap4-hsmmc"; reg = <0x23100000 0x400>; interrupts = ; dmas = <&edma1 26 0>, <&edma1 27 0>; dma-names = "tx", "rx"; bus-width = <8>; ti,needs-special-reset; max-frequency = <96000000>; power-domains = <&k2g_pds 0xc>; clocks = <&k2g_clks 0xc 1>, <&k2g_clks 0xc 2>; clock-names = "fck", "mmchsdb_fck"; }; qspi: qspi@2940000 { compatible = "ti,k2g-qspi", "cdns,qspi-nor"; #address-cells = <1>; #size-cells = <0>; reg = <0x02940000 0x1000>, <0x24000000 0x4000000>; interrupts = ; cdns,fifo-depth = <256>; cdns,fifo-width = <4>; cdns,trigger-address = <0x24000000>; clocks = <&k2g_clks 0x43 0x0>; power-domains = <&k2g_pds 0x43>; status = "disabled"; }; mcasp0: mcasp@2340000 { compatible = "ti,am33xx-mcasp-audio"; reg = <0x02340000 0x2000>, <0x21804000 0x1000>; reg-names = "mpu","dat"; interrupts = , ; interrupt-names = "tx", "rx"; dmas = <&edma0 24 1>, <&edma0 25 1>; dma-names = "tx", "rx"; power-domains = <&k2g_pds 0x4>; clocks = <&k2g_clks 0x4 0>; clock-names = "fck"; status = "disabled"; }; mcasp1: mcasp@2342000 { compatible = "ti,am33xx-mcasp-audio"; reg = <0x02342000 0x2000>, <0x21804400 0x1000>; reg-names = "mpu","dat"; interrupts = , ; interrupt-names = "tx", "rx"; dmas = <&edma1 48 1>, <&edma1 49 1>; dma-names = "tx", "rx"; power-domains = <&k2g_pds 0x5>; clocks = <&k2g_clks 0x5 0>; clock-names = "fck"; status = "disabled"; }; mcasp2: mcasp@2344000 { compatible = "ti,am33xx-mcasp-audio"; reg = <0x02344000 0x2000>, <0x21804800 0x1000>; reg-names = "mpu","dat"; interrupts = , ; interrupt-names = "tx", "rx"; dmas = <&edma1 50 1>, <&edma1 51 1>; dma-names = "tx", "rx"; power-domains = <&k2g_pds 0x6>; clocks = <&k2g_clks 0x6 0>; clock-names = "fck"; status = "disabled"; }; usb0_phy: usb-phy@0 { compatible = "usb-nop-xceiv"; status = "disabled"; }; keystone_usb0: keystone-dwc3@2680000 { compatible = "ti,keystone-dwc3"; #address-cells = <1>; #size-cells = <1>; reg = <0x2680000 0x10000>; interrupts = ; ranges; dma-coherent; dma-ranges; status = "disabled"; power-domains = <&k2g_pds 0x0016>; usb0: usb@2690000 { compatible = "snps,dwc3"; reg = <0x2690000 0x10000>; interrupts = ; maximum-speed = "high-speed"; dr_mode = "otg"; usb-phy = <&usb0_phy>; status = "disabled"; }; }; usb1_phy: usb-phy@1 { compatible = "usb-nop-xceiv"; status = "disabled"; }; keystone_usb1: keystone-dwc3@2580000 { compatible = "ti,keystone-dwc3"; #address-cells = <1>; #size-cells = <1>; reg = <0x2580000 0x10000>; interrupts = ; ranges; dma-coherent; dma-ranges; status = "disabled"; power-domains = <&k2g_pds 0x0017>; usb1: usb@2590000 { compatible = "snps,dwc3"; reg = <0x2590000 0x10000>; interrupts = ; maximum-speed = "high-speed"; dr_mode = "otg"; usb-phy = <&usb1_phy>; status = "disabled"; }; }; ecap0: pwm@21d1800 { compatible = "ti,k2g-ecap", "ti,am3352-ecap"; #pwm-cells = <3>; reg = <0x021d1800 0x60>; power-domains = <&k2g_pds 0x38>; clocks = <&k2g_clks 0x38 0>; clock-names = "fck"; status = "disabled"; }; ecap1: pwm@21d1c00 { compatible = "ti,k2g-ecap", "ti,am3352-ecap"; #pwm-cells = <3>; reg = <0x021d1c00 0x60>; power-domains = <&k2g_pds 0x39>; clocks = <&k2g_clks 0x39 0x0>; clock-names = "fck"; status = "disabled"; }; spi0: spi@21805400 { compatible = "ti,keystone-spi"; reg = <0x21805400 0x200>; num-cs = <4>; ti,davinci-spi-intr-line = <0>; interrupts = ; #address-cells = <1>; #size-cells = <0>; power-domains = <&k2g_pds 0x0010>; clocks = <&k2g_clks 0x0010 0>; }; spi1: spi@21805800 { compatible = "ti,keystone-spi"; reg = <0x21805800 0x200>; num-cs = <4>; ti,davinci-spi-intr-line = <0>; interrupts = ; #address-cells = <1>; #size-cells = <0>; power-domains = <&k2g_pds 0x0011>; clocks = <&k2g_clks 0x0011 0>; }; spi2: spi@21805c00 { compatible = "ti,keystone-spi"; reg = <0x21805C00 0x200>; num-cs = <4>; ti,davinci-spi-intr-line = <0>; interrupts = ; #address-cells = <1>; #size-cells = <0>; power-domains = <&k2g_pds 0x0012>; clocks = <&k2g_clks 0x0012 0>; }; spi3: spi@21806000 { compatible = "ti,keystone-spi"; reg = <0x21806000 0x200>; num-cs = <4>; ti,davinci-spi-intr-line = <0>; interrupts = ; #address-cells = <1>; #size-cells = <0>; power-domains = <&k2g_pds 0x0013>; clocks = <&k2g_clks 0x0013 0>; }; }; };