// SPDX-License-Identifier: GPL-2.0-only OR MIT /* * Device Tree file for the J722S MAIN domain peripherals * * Copyright (C) 2023-2024 Texas Instruments Incorporated - https://www.ti.com/ */ #include #include / { serdes_refclk: clk-0 { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <0>; }; }; &cbass_main { serdes_wiz0: phy@f000000 { compatible = "ti,am64-wiz-10g"; ranges = <0x0f000000 0x0 0x0f000000 0x00010000>; #address-cells = <1>; #size-cells = <1>; power-domains = <&k3_pds 279 TI_SCI_PD_EXCLUSIVE>; clocks = <&k3_clks 279 0>, <&k3_clks 279 1>, <&serdes_refclk>; clock-names = "fck", "core_ref_clk", "ext_ref_clk"; num-lanes = <1>; #reset-cells = <1>; #clock-cells = <1>; assigned-clocks = <&k3_clks 279 1>; assigned-clock-parents = <&k3_clks 279 5>; serdes0: serdes@f000000 { compatible = "ti,j721e-serdes-10g"; reg = <0x0f000000 0x00010000>; reg-names = "torrent_phy"; resets = <&serdes_wiz0 0>; reset-names = "torrent_reset"; clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>, <&serdes_wiz0 TI_WIZ_PHY_EN_REFCLK>; clock-names = "refclk", "phy_en_refclk"; assigned-clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>, <&serdes_wiz0 TI_WIZ_PLL1_REFCLK>, <&serdes_wiz0 TI_WIZ_REFCLK_DIG>; assigned-clock-parents = <&k3_clks 279 1>, <&k3_clks 279 1>, <&k3_clks 279 1>; #address-cells = <1>; #size-cells = <0>; #clock-cells = <1>; status = "disabled"; /* Needs lane config */ }; }; serdes_wiz1: phy@f010000 { compatible = "ti,am64-wiz-10g"; ranges = <0x0f010000 0x0 0x0f010000 0x00010000>; #address-cells = <1>; #size-cells = <1>; power-domains = <&k3_pds 280 TI_SCI_PD_EXCLUSIVE>; clocks = <&k3_clks 280 0>, <&k3_clks 280 1>, <&serdes_refclk>; clock-names = "fck", "core_ref_clk", "ext_ref_clk"; num-lanes = <1>; #reset-cells = <1>; #clock-cells = <1>; assigned-clocks = <&k3_clks 280 1>; assigned-clock-parents = <&k3_clks 280 5>; serdes1: serdes@f010000 { compatible = "ti,j721e-serdes-10g"; reg = <0x0f010000 0x00010000>; reg-names = "torrent_phy"; resets = <&serdes_wiz1 0>; reset-names = "torrent_reset"; clocks = <&serdes_wiz1 TI_WIZ_PLL0_REFCLK>, <&serdes_wiz1 TI_WIZ_PHY_EN_REFCLK>; clock-names = "refclk", "phy_en_refclk"; assigned-clocks = <&serdes_wiz1 TI_WIZ_PLL0_REFCLK>, <&serdes_wiz1 TI_WIZ_PLL1_REFCLK>, <&serdes_wiz1 TI_WIZ_REFCLK_DIG>; assigned-clock-parents = <&k3_clks 280 1>, <&k3_clks 280 1>, <&k3_clks 280 1>; #address-cells = <1>; #size-cells = <0>; #clock-cells = <1>; status = "disabled"; /* Needs lane config */ }; }; pcie0_rc: pcie@f102000 { compatible = "ti,j722s-pcie-host", "ti,j721e-pcie-host"; reg = <0x00 0x0f102000 0x00 0x1000>, <0x00 0x0f100000 0x00 0x400>, <0x00 0x0d000000 0x00 0x00800000>, <0x00 0x68000000 0x00 0x00001000>; reg-names = "intd_cfg", "user_cfg", "reg", "cfg"; ranges = <0x01000000 0x00 0x68001000 0x00 0x68001000 0x00 0x0010000>, <0x02000000 0x00 0x68011000 0x00 0x68011000 0x00 0x7fef000>; dma-ranges = <0x02000000 0x0 0x0 0x0 0x0 0x10000 0x0>; interrupt-names = "link_state"; interrupts = ; device_type = "pci"; max-link-speed = <3>; num-lanes = <1>; power-domains = <&k3_pds 259 TI_SCI_PD_EXCLUSIVE>; clocks = <&k3_clks 259 0>, <&serdes1 CDNS_TORRENT_REFCLK_DRIVER>; clock-names = "fck", "pcie_refclk"; #address-cells = <3>; #size-cells = <2>; bus-range = <0x0 0xff>; vendor-id = <0x104c>; device-id = <0xb010>; cdns,no-bar-match-nbits = <64>; ti,syscon-pcie-ctrl = <&pcie0_ctrl 0x0>; msi-map = <0x0 &gic_its 0x0 0x10000>; status = "disabled"; }; usbss1: usb@f920000 { compatible = "ti,j721e-usb"; reg = <0x00 0x0f920000 0x00 0x100>; power-domains = <&k3_pds 278 TI_SCI_PD_EXCLUSIVE>; clocks = <&k3_clks 278 3>, <&k3_clks 278 1>; clock-names = "ref", "lpm"; assigned-clocks = <&k3_clks 278 3>; /* USB2_REFCLK */ assigned-clock-parents = <&k3_clks 278 4>; /* HF0SC0 */ #address-cells = <2>; #size-cells = <2>; ranges; status = "disabled"; usb1: usb@31200000{ compatible = "cdns,usb3"; reg = <0x00 0x31200000 0x00 0x10000>, <0x00 0x31210000 0x00 0x10000>, <0x00 0x31220000 0x00 0x10000>; reg-names = "otg", "xhci", "dev"; interrupts = , /* irq.0 */ , /* irq.6 */ ; /* otgirq */ interrupt-names = "host", "peripheral", "otg"; maximum-speed = "super-speed"; dr_mode = "otg"; }; }; }; &main_conf { serdes_ln_ctrl: mux-controller@4080 { compatible = "reg-mux"; reg = <0x4080 0x14>; #mux-control-cells = <1>; mux-reg-masks = <0x00 0x3>, /* SERDES0 lane0 select */ <0x10 0x3>; /* SERDES1 lane0 select */ }; audio_refclk1: clock@82e4 { compatible = "ti,am62-audio-refclk"; reg = <0x82e4 0x4>; clocks = <&k3_clks 157 18>; assigned-clocks = <&k3_clks 157 18>; assigned-clock-parents = <&k3_clks 157 33>; #clock-cells = <0>; }; }; &wkup_conf { pcie0_ctrl: pcie0-ctrl@4070 { compatible = "ti,j784s4-pcie-ctrl", "syscon"; reg = <0x4070 0x4>; }; }; &oc_sram { reg = <0x00 0x70000000 0x00 0x40000>; ranges = <0x00 0x00 0x70000000 0x40000>; }; &inta_main_dmss { ti,interrupt-ranges = <7 71 21>; }; &main_pmx0 { pinctrl-single,gpio-range = <&main_pmx0_range 0 32 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 33 38 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 72 17 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 101 25 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 137 5 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 143 3 PIN_GPIO_RANGE_IOPAD>, <&main_pmx0_range 149 2 PIN_GPIO_RANGE_IOPAD>; main_pmx0_range: gpio-range { #pinctrl-single,gpio-range-cells = <3>; }; }; &main_gpio0 { gpio-ranges = <&main_pmx0 0 0 32>, <&main_pmx0 32 33 38>, <&main_pmx0 70 72 17>; ti,ngpio = <87>; }; &main_gpio1 { gpio-ranges = <&main_pmx0 7 101 25>, <&main_pmx0 42 137 5>, <&main_pmx0 47 143 3>, <&main_pmx0 50 149 2>; ti,ngpio = <73>; };