162306a36Sopenharmony_ciNVIDIA Tegra PCIe controller 262306a36Sopenharmony_ci 362306a36Sopenharmony_ciRequired properties: 462306a36Sopenharmony_ci- compatible: Must be: 562306a36Sopenharmony_ci - "nvidia,tegra20-pcie": for Tegra20 662306a36Sopenharmony_ci - "nvidia,tegra30-pcie": for Tegra30 762306a36Sopenharmony_ci - "nvidia,tegra124-pcie": for Tegra124 and Tegra132 862306a36Sopenharmony_ci - "nvidia,tegra210-pcie": for Tegra210 962306a36Sopenharmony_ci - "nvidia,tegra186-pcie": for Tegra186 1062306a36Sopenharmony_ci- power-domains: To ungate power partition by BPMP powergate driver. Must 1162306a36Sopenharmony_ci contain BPMP phandle and PCIe power partition ID. This is required only 1262306a36Sopenharmony_ci for Tegra186. 1362306a36Sopenharmony_ci- device_type: Must be "pci" 1462306a36Sopenharmony_ci- reg: A list of physical base address and length for each set of controller 1562306a36Sopenharmony_ci registers. Must contain an entry for each entry in the reg-names property. 1662306a36Sopenharmony_ci- reg-names: Must include the following entries: 1762306a36Sopenharmony_ci "pads": PADS registers 1862306a36Sopenharmony_ci "afi": AFI registers 1962306a36Sopenharmony_ci "cs": configuration space region 2062306a36Sopenharmony_ci- interrupts: A list of interrupt outputs of the controller. Must contain an 2162306a36Sopenharmony_ci entry for each entry in the interrupt-names property. 2262306a36Sopenharmony_ci- interrupt-names: Must include the following entries: 2362306a36Sopenharmony_ci "intr": The Tegra interrupt that is asserted for controller interrupts 2462306a36Sopenharmony_ci "msi": The Tegra interrupt that is asserted when an MSI is received 2562306a36Sopenharmony_ci- bus-range: Range of bus numbers associated with this controller 2662306a36Sopenharmony_ci- #address-cells: Address representation for root ports (must be 3) 2762306a36Sopenharmony_ci - cell 0 specifies the bus and device numbers of the root port: 2862306a36Sopenharmony_ci [23:16]: bus number 2962306a36Sopenharmony_ci [15:11]: device number 3062306a36Sopenharmony_ci - cell 1 denotes the upper 32 address bits and should be 0 3162306a36Sopenharmony_ci - cell 2 contains the lower 32 address bits and is used to translate to the 3262306a36Sopenharmony_ci CPU address space 3362306a36Sopenharmony_ci- #size-cells: Size representation for root ports (must be 2) 3462306a36Sopenharmony_ci- ranges: Describes the translation of addresses for root ports and standard 3562306a36Sopenharmony_ci PCI regions. The entries must be 6 cells each, where the first three cells 3662306a36Sopenharmony_ci correspond to the address as described for the #address-cells property 3762306a36Sopenharmony_ci above, the fourth cell is the physical CPU address to translate to and the 3862306a36Sopenharmony_ci fifth and six cells are as described for the #size-cells property above. 3962306a36Sopenharmony_ci - The first two entries are expected to translate the addresses for the root 4062306a36Sopenharmony_ci port registers, which are referenced by the assigned-addresses property of 4162306a36Sopenharmony_ci the root port nodes (see below). 4262306a36Sopenharmony_ci - The remaining entries setup the mapping for the standard I/O, memory and 4362306a36Sopenharmony_ci prefetchable PCI regions. The first cell determines the type of region 4462306a36Sopenharmony_ci that is setup: 4562306a36Sopenharmony_ci - 0x81000000: I/O memory region 4662306a36Sopenharmony_ci - 0x82000000: non-prefetchable memory region 4762306a36Sopenharmony_ci - 0xc2000000: prefetchable memory region 4862306a36Sopenharmony_ci Please refer to the standard PCI bus binding document for a more detailed 4962306a36Sopenharmony_ci explanation. 5062306a36Sopenharmony_ci- #interrupt-cells: Size representation for interrupts (must be 1) 5162306a36Sopenharmony_ci- interrupt-map-mask and interrupt-map: Standard PCI IRQ mapping properties 5262306a36Sopenharmony_ci Please refer to the standard PCI bus binding document for a more detailed 5362306a36Sopenharmony_ci explanation. 5462306a36Sopenharmony_ci- clocks: Must contain an entry for each entry in clock-names. 5562306a36Sopenharmony_ci See ../clocks/clock-bindings.txt for details. 5662306a36Sopenharmony_ci- clock-names: Must include the following entries: 5762306a36Sopenharmony_ci - pex 5862306a36Sopenharmony_ci - afi 5962306a36Sopenharmony_ci - pll_e 6062306a36Sopenharmony_ci - cml (not required for Tegra20) 6162306a36Sopenharmony_ci- resets: Must contain an entry for each entry in reset-names. 6262306a36Sopenharmony_ci See ../reset/reset.txt for details. 6362306a36Sopenharmony_ci- reset-names: Must include the following entries: 6462306a36Sopenharmony_ci - pex 6562306a36Sopenharmony_ci - afi 6662306a36Sopenharmony_ci - pcie_x 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ciOptional properties: 6962306a36Sopenharmony_ci- pinctrl-names: A list of pinctrl state names. Must contain the following 7062306a36Sopenharmony_ci entries: 7162306a36Sopenharmony_ci - "default": active state, puts PCIe I/O out of deep power down state 7262306a36Sopenharmony_ci - "idle": puts PCIe I/O into deep power down state 7362306a36Sopenharmony_ci- pinctrl-0: phandle for the default/active state of pin configurations. 7462306a36Sopenharmony_ci- pinctrl-1: phandle for the idle state of pin configurations. 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ciRequired properties on Tegra124 and later (deprecated): 7762306a36Sopenharmony_ci- phys: Must contain an entry for each entry in phy-names. 7862306a36Sopenharmony_ci- phy-names: Must include the following entries: 7962306a36Sopenharmony_ci - pcie 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ciThese properties are deprecated in favour of per-lane PHYs define in each of 8262306a36Sopenharmony_cithe root ports (see below). 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ciPower supplies for Tegra20: 8562306a36Sopenharmony_ci- avdd-pex-supply: Power supply for analog PCIe logic. Must supply 1.05 V. 8662306a36Sopenharmony_ci- vdd-pex-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 8762306a36Sopenharmony_ci- avdd-pex-pll-supply: Power supply for dedicated (internal) PCIe PLL. Must 8862306a36Sopenharmony_ci supply 1.05 V. 8962306a36Sopenharmony_ci- avdd-plle-supply: Power supply for PLLE, which is shared with SATA. Must 9062306a36Sopenharmony_ci supply 1.05 V. 9162306a36Sopenharmony_ci- vddio-pex-clk-supply: Power supply for PCIe clock. Must supply 3.3 V. 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ciPower supplies for Tegra30: 9462306a36Sopenharmony_ci- Required: 9562306a36Sopenharmony_ci - avdd-pex-pll-supply: Power supply for dedicated (internal) PCIe PLL. Must 9662306a36Sopenharmony_ci supply 1.05 V. 9762306a36Sopenharmony_ci - avdd-plle-supply: Power supply for PLLE, which is shared with SATA. Must 9862306a36Sopenharmony_ci supply 1.05 V. 9962306a36Sopenharmony_ci - vddio-pex-ctl-supply: Power supply for PCIe control I/O partition. Must 10062306a36Sopenharmony_ci supply 1.8 V. 10162306a36Sopenharmony_ci - hvdd-pex-supply: High-voltage supply for PCIe I/O and PCIe output clocks. 10262306a36Sopenharmony_ci Must supply 3.3 V. 10362306a36Sopenharmony_ci- Optional: 10462306a36Sopenharmony_ci - If lanes 0 to 3 are used: 10562306a36Sopenharmony_ci - avdd-pexa-supply: Power supply for analog PCIe logic. Must supply 1.05 V. 10662306a36Sopenharmony_ci - vdd-pexa-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 10762306a36Sopenharmony_ci - If lanes 4 or 5 are used: 10862306a36Sopenharmony_ci - avdd-pexb-supply: Power supply for analog PCIe logic. Must supply 1.05 V. 10962306a36Sopenharmony_ci - vdd-pexb-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ciPower supplies for Tegra124: 11262306a36Sopenharmony_ci- Required: 11362306a36Sopenharmony_ci - avddio-pex-supply: Power supply for analog PCIe logic. Must supply 1.05 V. 11462306a36Sopenharmony_ci - dvddio-pex-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 11562306a36Sopenharmony_ci - hvdd-pex-supply: High-voltage supply for PCIe I/O and PCIe output clocks. 11662306a36Sopenharmony_ci Must supply 3.3 V. 11762306a36Sopenharmony_ci - vddio-pex-ctl-supply: Power supply for PCIe control I/O partition. Must 11862306a36Sopenharmony_ci supply 2.8-3.3 V. 11962306a36Sopenharmony_ci 12062306a36Sopenharmony_ciPower supplies for Tegra210: 12162306a36Sopenharmony_ci- Required: 12262306a36Sopenharmony_ci - hvddio-pex-supply: High-voltage supply for PCIe I/O and PCIe output 12362306a36Sopenharmony_ci clocks. Must supply 1.8 V. 12462306a36Sopenharmony_ci - dvddio-pex-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 12562306a36Sopenharmony_ci - vddio-pex-ctl-supply: Power supply for PCIe control I/O partition. Must 12662306a36Sopenharmony_ci supply 1.8 V. 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ciPower supplies for Tegra186: 12962306a36Sopenharmony_ci- Required: 13062306a36Sopenharmony_ci - dvdd-pex-supply: Power supply for digital PCIe I/O. Must supply 1.05 V. 13162306a36Sopenharmony_ci - hvdd-pex-pll-supply: High-voltage supply for PLLE (shared with USB3). Must 13262306a36Sopenharmony_ci supply 1.8 V. 13362306a36Sopenharmony_ci - hvdd-pex-supply: High-voltage supply for PCIe I/O and PCIe output clocks. 13462306a36Sopenharmony_ci Must supply 1.8 V. 13562306a36Sopenharmony_ci - vddio-pexctl-aud-supply: Power supply for PCIe side band signals. Must 13662306a36Sopenharmony_ci supply 1.8 V. 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ciRoot ports are defined as subnodes of the PCIe controller node. 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ciRequired properties: 14162306a36Sopenharmony_ci- device_type: Must be "pci" 14262306a36Sopenharmony_ci- assigned-addresses: Address and size of the port configuration registers 14362306a36Sopenharmony_ci- reg: PCI bus address of the root port 14462306a36Sopenharmony_ci- #address-cells: Must be 3 14562306a36Sopenharmony_ci- #size-cells: Must be 2 14662306a36Sopenharmony_ci- ranges: Sub-ranges distributed from the PCIe controller node. An empty 14762306a36Sopenharmony_ci property is sufficient. 14862306a36Sopenharmony_ci- nvidia,num-lanes: Number of lanes to use for this port. Valid combinations 14962306a36Sopenharmony_ci are: 15062306a36Sopenharmony_ci - Root port 0 uses 4 lanes, root port 1 is unused. 15162306a36Sopenharmony_ci - Both root ports use 2 lanes. 15262306a36Sopenharmony_ci 15362306a36Sopenharmony_ciRequired properties for Tegra124 and later: 15462306a36Sopenharmony_ci- phys: Must contain an phandle to a PHY for each entry in phy-names. 15562306a36Sopenharmony_ci- phy-names: Must include an entry for each active lane. Note that the number 15662306a36Sopenharmony_ci of entries does not have to (though usually will) be equal to the specified 15762306a36Sopenharmony_ci number of lanes in the nvidia,num-lanes property. Entries are of the form 15862306a36Sopenharmony_ci "pcie-N": where N ranges from 0 to the value specified in nvidia,num-lanes. 15962306a36Sopenharmony_ci 16062306a36Sopenharmony_ciExamples: 16162306a36Sopenharmony_ci========= 16262306a36Sopenharmony_ci 16362306a36Sopenharmony_ciTegra20: 16462306a36Sopenharmony_ci-------- 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_ciSoC DTSI: 16762306a36Sopenharmony_ci 16862306a36Sopenharmony_ci pcie-controller@80003000 { 16962306a36Sopenharmony_ci compatible = "nvidia,tegra20-pcie"; 17062306a36Sopenharmony_ci device_type = "pci"; 17162306a36Sopenharmony_ci reg = <0x80003000 0x00000800 /* PADS registers */ 17262306a36Sopenharmony_ci 0x80003800 0x00000200 /* AFI registers */ 17362306a36Sopenharmony_ci 0x90000000 0x10000000>; /* configuration space */ 17462306a36Sopenharmony_ci reg-names = "pads", "afi", "cs"; 17562306a36Sopenharmony_ci interrupts = <0 98 0x04 /* controller interrupt */ 17662306a36Sopenharmony_ci 0 99 0x04>; /* MSI interrupt */ 17762306a36Sopenharmony_ci interrupt-names = "intr", "msi"; 17862306a36Sopenharmony_ci 17962306a36Sopenharmony_ci #interrupt-cells = <1>; 18062306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 0>; 18162306a36Sopenharmony_ci interrupt-map = <0 0 0 0 &intc GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ci bus-range = <0x00 0xff>; 18462306a36Sopenharmony_ci #address-cells = <3>; 18562306a36Sopenharmony_ci #size-cells = <2>; 18662306a36Sopenharmony_ci 18762306a36Sopenharmony_ci ranges = <0x82000000 0 0x80000000 0x80000000 0 0x00001000 /* port 0 registers */ 18862306a36Sopenharmony_ci 0x82000000 0 0x80001000 0x80001000 0 0x00001000 /* port 1 registers */ 18962306a36Sopenharmony_ci 0x81000000 0 0 0x82000000 0 0x00010000 /* downstream I/O */ 19062306a36Sopenharmony_ci 0x82000000 0 0xa0000000 0xa0000000 0 0x10000000 /* non-prefetchable memory */ 19162306a36Sopenharmony_ci 0xc2000000 0 0xb0000000 0xb0000000 0 0x10000000>; /* prefetchable memory */ 19262306a36Sopenharmony_ci 19362306a36Sopenharmony_ci clocks = <&tegra_car 70>, <&tegra_car 72>, <&tegra_car 118>; 19462306a36Sopenharmony_ci clock-names = "pex", "afi", "pll_e"; 19562306a36Sopenharmony_ci resets = <&tegra_car 70>, <&tegra_car 72>, <&tegra_car 74>; 19662306a36Sopenharmony_ci reset-names = "pex", "afi", "pcie_x"; 19762306a36Sopenharmony_ci status = "disabled"; 19862306a36Sopenharmony_ci 19962306a36Sopenharmony_ci pci@1,0 { 20062306a36Sopenharmony_ci device_type = "pci"; 20162306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x80000000 0 0x1000>; 20262306a36Sopenharmony_ci reg = <0x000800 0 0 0 0>; 20362306a36Sopenharmony_ci status = "disabled"; 20462306a36Sopenharmony_ci 20562306a36Sopenharmony_ci #address-cells = <3>; 20662306a36Sopenharmony_ci #size-cells = <2>; 20762306a36Sopenharmony_ci 20862306a36Sopenharmony_ci ranges; 20962306a36Sopenharmony_ci 21062306a36Sopenharmony_ci nvidia,num-lanes = <2>; 21162306a36Sopenharmony_ci }; 21262306a36Sopenharmony_ci 21362306a36Sopenharmony_ci pci@2,0 { 21462306a36Sopenharmony_ci device_type = "pci"; 21562306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x80001000 0 0x1000>; 21662306a36Sopenharmony_ci reg = <0x001000 0 0 0 0>; 21762306a36Sopenharmony_ci status = "disabled"; 21862306a36Sopenharmony_ci 21962306a36Sopenharmony_ci #address-cells = <3>; 22062306a36Sopenharmony_ci #size-cells = <2>; 22162306a36Sopenharmony_ci 22262306a36Sopenharmony_ci ranges; 22362306a36Sopenharmony_ci 22462306a36Sopenharmony_ci nvidia,num-lanes = <2>; 22562306a36Sopenharmony_ci }; 22662306a36Sopenharmony_ci }; 22762306a36Sopenharmony_ci 22862306a36Sopenharmony_ciBoard DTS: 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ci pcie-controller@80003000 { 23162306a36Sopenharmony_ci status = "okay"; 23262306a36Sopenharmony_ci 23362306a36Sopenharmony_ci vdd-supply = <&pci_vdd_reg>; 23462306a36Sopenharmony_ci pex-clk-supply = <&pci_clk_reg>; 23562306a36Sopenharmony_ci 23662306a36Sopenharmony_ci /* root port 00:01.0 */ 23762306a36Sopenharmony_ci pci@1,0 { 23862306a36Sopenharmony_ci status = "okay"; 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_ci /* bridge 01:00.0 (optional) */ 24162306a36Sopenharmony_ci pci@0,0 { 24262306a36Sopenharmony_ci reg = <0x010000 0 0 0 0>; 24362306a36Sopenharmony_ci 24462306a36Sopenharmony_ci #address-cells = <3>; 24562306a36Sopenharmony_ci #size-cells = <2>; 24662306a36Sopenharmony_ci 24762306a36Sopenharmony_ci device_type = "pci"; 24862306a36Sopenharmony_ci 24962306a36Sopenharmony_ci /* endpoint 02:00.0 */ 25062306a36Sopenharmony_ci pci@0,0 { 25162306a36Sopenharmony_ci reg = <0x020000 0 0 0 0>; 25262306a36Sopenharmony_ci }; 25362306a36Sopenharmony_ci }; 25462306a36Sopenharmony_ci }; 25562306a36Sopenharmony_ci }; 25662306a36Sopenharmony_ci 25762306a36Sopenharmony_ciNote that devices on the PCI bus are dynamically discovered using PCI's bus 25862306a36Sopenharmony_cienumeration and therefore don't need corresponding device nodes in DT. However 25962306a36Sopenharmony_ciif a device on the PCI bus provides a non-probeable bus such as I2C or SPI, 26062306a36Sopenharmony_cidevice nodes need to be added in order to allow the bus' children to be 26162306a36Sopenharmony_ciinstantiated at the proper location in the operating system's device tree (as 26262306a36Sopenharmony_ciillustrated by the optional nodes in the example above). 26362306a36Sopenharmony_ci 26462306a36Sopenharmony_ciTegra30: 26562306a36Sopenharmony_ci-------- 26662306a36Sopenharmony_ci 26762306a36Sopenharmony_ciSoC DTSI: 26862306a36Sopenharmony_ci 26962306a36Sopenharmony_ci pcie-controller@3000 { 27062306a36Sopenharmony_ci compatible = "nvidia,tegra30-pcie"; 27162306a36Sopenharmony_ci device_type = "pci"; 27262306a36Sopenharmony_ci reg = <0x00003000 0x00000800 /* PADS registers */ 27362306a36Sopenharmony_ci 0x00003800 0x00000200 /* AFI registers */ 27462306a36Sopenharmony_ci 0x10000000 0x10000000>; /* configuration space */ 27562306a36Sopenharmony_ci reg-names = "pads", "afi", "cs"; 27662306a36Sopenharmony_ci interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH /* controller interrupt */ 27762306a36Sopenharmony_ci GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 27862306a36Sopenharmony_ci interrupt-names = "intr", "msi"; 27962306a36Sopenharmony_ci 28062306a36Sopenharmony_ci #interrupt-cells = <1>; 28162306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 0>; 28262306a36Sopenharmony_ci interrupt-map = <0 0 0 0 &intc GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 28362306a36Sopenharmony_ci 28462306a36Sopenharmony_ci bus-range = <0x00 0xff>; 28562306a36Sopenharmony_ci #address-cells = <3>; 28662306a36Sopenharmony_ci #size-cells = <2>; 28762306a36Sopenharmony_ci 28862306a36Sopenharmony_ci ranges = <0x82000000 0 0x00000000 0x00000000 0 0x00001000 /* port 0 configuration space */ 28962306a36Sopenharmony_ci 0x82000000 0 0x00001000 0x00001000 0 0x00001000 /* port 1 configuration space */ 29062306a36Sopenharmony_ci 0x82000000 0 0x00004000 0x00004000 0 0x00001000 /* port 2 configuration space */ 29162306a36Sopenharmony_ci 0x81000000 0 0 0x02000000 0 0x00010000 /* downstream I/O */ 29262306a36Sopenharmony_ci 0x82000000 0 0x20000000 0x20000000 0 0x08000000 /* non-prefetchable memory */ 29362306a36Sopenharmony_ci 0xc2000000 0 0x28000000 0x28000000 0 0x18000000>; /* prefetchable memory */ 29462306a36Sopenharmony_ci 29562306a36Sopenharmony_ci clocks = <&tegra_car TEGRA30_CLK_PCIE>, 29662306a36Sopenharmony_ci <&tegra_car TEGRA30_CLK_AFI>, 29762306a36Sopenharmony_ci <&tegra_car TEGRA30_CLK_PLL_E>, 29862306a36Sopenharmony_ci <&tegra_car TEGRA30_CLK_CML0>; 29962306a36Sopenharmony_ci clock-names = "pex", "afi", "pll_e", "cml"; 30062306a36Sopenharmony_ci resets = <&tegra_car 70>, 30162306a36Sopenharmony_ci <&tegra_car 72>, 30262306a36Sopenharmony_ci <&tegra_car 74>; 30362306a36Sopenharmony_ci reset-names = "pex", "afi", "pcie_x"; 30462306a36Sopenharmony_ci status = "disabled"; 30562306a36Sopenharmony_ci 30662306a36Sopenharmony_ci pci@1,0 { 30762306a36Sopenharmony_ci device_type = "pci"; 30862306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x00000000 0 0x1000>; 30962306a36Sopenharmony_ci reg = <0x000800 0 0 0 0>; 31062306a36Sopenharmony_ci status = "disabled"; 31162306a36Sopenharmony_ci 31262306a36Sopenharmony_ci #address-cells = <3>; 31362306a36Sopenharmony_ci #size-cells = <2>; 31462306a36Sopenharmony_ci ranges; 31562306a36Sopenharmony_ci 31662306a36Sopenharmony_ci nvidia,num-lanes = <2>; 31762306a36Sopenharmony_ci }; 31862306a36Sopenharmony_ci 31962306a36Sopenharmony_ci pci@2,0 { 32062306a36Sopenharmony_ci device_type = "pci"; 32162306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x00001000 0 0x1000>; 32262306a36Sopenharmony_ci reg = <0x001000 0 0 0 0>; 32362306a36Sopenharmony_ci status = "disabled"; 32462306a36Sopenharmony_ci 32562306a36Sopenharmony_ci #address-cells = <3>; 32662306a36Sopenharmony_ci #size-cells = <2>; 32762306a36Sopenharmony_ci ranges; 32862306a36Sopenharmony_ci 32962306a36Sopenharmony_ci nvidia,num-lanes = <2>; 33062306a36Sopenharmony_ci }; 33162306a36Sopenharmony_ci 33262306a36Sopenharmony_ci pci@3,0 { 33362306a36Sopenharmony_ci device_type = "pci"; 33462306a36Sopenharmony_ci assigned-addresses = <0x82001800 0 0x00004000 0 0x1000>; 33562306a36Sopenharmony_ci reg = <0x001800 0 0 0 0>; 33662306a36Sopenharmony_ci status = "disabled"; 33762306a36Sopenharmony_ci 33862306a36Sopenharmony_ci #address-cells = <3>; 33962306a36Sopenharmony_ci #size-cells = <2>; 34062306a36Sopenharmony_ci ranges; 34162306a36Sopenharmony_ci 34262306a36Sopenharmony_ci nvidia,num-lanes = <2>; 34362306a36Sopenharmony_ci }; 34462306a36Sopenharmony_ci }; 34562306a36Sopenharmony_ci 34662306a36Sopenharmony_ciBoard DTS: 34762306a36Sopenharmony_ci 34862306a36Sopenharmony_ci pcie-controller@3000 { 34962306a36Sopenharmony_ci status = "okay"; 35062306a36Sopenharmony_ci 35162306a36Sopenharmony_ci avdd-pexa-supply = <&ldo1_reg>; 35262306a36Sopenharmony_ci vdd-pexa-supply = <&ldo1_reg>; 35362306a36Sopenharmony_ci avdd-pexb-supply = <&ldo1_reg>; 35462306a36Sopenharmony_ci vdd-pexb-supply = <&ldo1_reg>; 35562306a36Sopenharmony_ci avdd-pex-pll-supply = <&ldo1_reg>; 35662306a36Sopenharmony_ci avdd-plle-supply = <&ldo1_reg>; 35762306a36Sopenharmony_ci vddio-pex-ctl-supply = <&sys_3v3_reg>; 35862306a36Sopenharmony_ci hvdd-pex-supply = <&sys_3v3_pexs_reg>; 35962306a36Sopenharmony_ci 36062306a36Sopenharmony_ci pci@1,0 { 36162306a36Sopenharmony_ci status = "okay"; 36262306a36Sopenharmony_ci }; 36362306a36Sopenharmony_ci 36462306a36Sopenharmony_ci pci@3,0 { 36562306a36Sopenharmony_ci status = "okay"; 36662306a36Sopenharmony_ci }; 36762306a36Sopenharmony_ci }; 36862306a36Sopenharmony_ci 36962306a36Sopenharmony_ciTegra124: 37062306a36Sopenharmony_ci--------- 37162306a36Sopenharmony_ci 37262306a36Sopenharmony_ciSoC DTSI: 37362306a36Sopenharmony_ci 37462306a36Sopenharmony_ci pcie-controller@1003000 { 37562306a36Sopenharmony_ci compatible = "nvidia,tegra124-pcie"; 37662306a36Sopenharmony_ci device_type = "pci"; 37762306a36Sopenharmony_ci reg = <0x0 0x01003000 0x0 0x00000800 /* PADS registers */ 37862306a36Sopenharmony_ci 0x0 0x01003800 0x0 0x00000800 /* AFI registers */ 37962306a36Sopenharmony_ci 0x0 0x02000000 0x0 0x10000000>; /* configuration space */ 38062306a36Sopenharmony_ci reg-names = "pads", "afi", "cs"; 38162306a36Sopenharmony_ci interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */ 38262306a36Sopenharmony_ci <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 38362306a36Sopenharmony_ci interrupt-names = "intr", "msi"; 38462306a36Sopenharmony_ci 38562306a36Sopenharmony_ci #interrupt-cells = <1>; 38662306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 0>; 38762306a36Sopenharmony_ci interrupt-map = <0 0 0 0 &gic GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 38862306a36Sopenharmony_ci 38962306a36Sopenharmony_ci bus-range = <0x00 0xff>; 39062306a36Sopenharmony_ci #address-cells = <3>; 39162306a36Sopenharmony_ci #size-cells = <2>; 39262306a36Sopenharmony_ci 39362306a36Sopenharmony_ci ranges = <0x82000000 0 0x01000000 0x0 0x01000000 0 0x00001000 /* port 0 configuration space */ 39462306a36Sopenharmony_ci 0x82000000 0 0x01001000 0x0 0x01001000 0 0x00001000 /* port 1 configuration space */ 39562306a36Sopenharmony_ci 0x81000000 0 0x0 0x0 0x12000000 0 0x00010000 /* downstream I/O (64 KiB) */ 39662306a36Sopenharmony_ci 0x82000000 0 0x13000000 0x0 0x13000000 0 0x0d000000 /* non-prefetchable memory (208 MiB) */ 39762306a36Sopenharmony_ci 0xc2000000 0 0x20000000 0x0 0x20000000 0 0x20000000>; /* prefetchable memory (512 MiB) */ 39862306a36Sopenharmony_ci 39962306a36Sopenharmony_ci clocks = <&tegra_car TEGRA124_CLK_PCIE>, 40062306a36Sopenharmony_ci <&tegra_car TEGRA124_CLK_AFI>, 40162306a36Sopenharmony_ci <&tegra_car TEGRA124_CLK_PLL_E>, 40262306a36Sopenharmony_ci <&tegra_car TEGRA124_CLK_CML0>; 40362306a36Sopenharmony_ci clock-names = "pex", "afi", "pll_e", "cml"; 40462306a36Sopenharmony_ci resets = <&tegra_car 70>, 40562306a36Sopenharmony_ci <&tegra_car 72>, 40662306a36Sopenharmony_ci <&tegra_car 74>; 40762306a36Sopenharmony_ci reset-names = "pex", "afi", "pcie_x"; 40862306a36Sopenharmony_ci status = "disabled"; 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_ci pci@1,0 { 41162306a36Sopenharmony_ci device_type = "pci"; 41262306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x01000000 0 0x1000>; 41362306a36Sopenharmony_ci reg = <0x000800 0 0 0 0>; 41462306a36Sopenharmony_ci status = "disabled"; 41562306a36Sopenharmony_ci 41662306a36Sopenharmony_ci #address-cells = <3>; 41762306a36Sopenharmony_ci #size-cells = <2>; 41862306a36Sopenharmony_ci ranges; 41962306a36Sopenharmony_ci 42062306a36Sopenharmony_ci nvidia,num-lanes = <2>; 42162306a36Sopenharmony_ci }; 42262306a36Sopenharmony_ci 42362306a36Sopenharmony_ci pci@2,0 { 42462306a36Sopenharmony_ci device_type = "pci"; 42562306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x01001000 0 0x1000>; 42662306a36Sopenharmony_ci reg = <0x001000 0 0 0 0>; 42762306a36Sopenharmony_ci status = "disabled"; 42862306a36Sopenharmony_ci 42962306a36Sopenharmony_ci #address-cells = <3>; 43062306a36Sopenharmony_ci #size-cells = <2>; 43162306a36Sopenharmony_ci ranges; 43262306a36Sopenharmony_ci 43362306a36Sopenharmony_ci nvidia,num-lanes = <1>; 43462306a36Sopenharmony_ci }; 43562306a36Sopenharmony_ci }; 43662306a36Sopenharmony_ci 43762306a36Sopenharmony_ciBoard DTS: 43862306a36Sopenharmony_ci 43962306a36Sopenharmony_ci pcie-controller@1003000 { 44062306a36Sopenharmony_ci status = "okay"; 44162306a36Sopenharmony_ci 44262306a36Sopenharmony_ci avddio-pex-supply = <&vdd_1v05_run>; 44362306a36Sopenharmony_ci dvddio-pex-supply = <&vdd_1v05_run>; 44462306a36Sopenharmony_ci avdd-pex-pll-supply = <&vdd_1v05_run>; 44562306a36Sopenharmony_ci hvdd-pex-supply = <&vdd_3v3_lp0>; 44662306a36Sopenharmony_ci hvdd-pex-pll-e-supply = <&vdd_3v3_lp0>; 44762306a36Sopenharmony_ci vddio-pex-ctl-supply = <&vdd_3v3_lp0>; 44862306a36Sopenharmony_ci avdd-pll-erefe-supply = <&avdd_1v05_run>; 44962306a36Sopenharmony_ci 45062306a36Sopenharmony_ci /* Mini PCIe */ 45162306a36Sopenharmony_ci pci@1,0 { 45262306a36Sopenharmony_ci phys = <&{/padctl@7009f000/pads/pcie/lanes/pcie-4}>; 45362306a36Sopenharmony_ci phy-names = "pcie-0"; 45462306a36Sopenharmony_ci status = "okay"; 45562306a36Sopenharmony_ci }; 45662306a36Sopenharmony_ci 45762306a36Sopenharmony_ci /* Gigabit Ethernet */ 45862306a36Sopenharmony_ci pci@2,0 { 45962306a36Sopenharmony_ci phys = <&{/padctl@7009f000/pads/pcie/lanes/pcie-2}>; 46062306a36Sopenharmony_ci phy-names = "pcie-0"; 46162306a36Sopenharmony_ci status = "okay"; 46262306a36Sopenharmony_ci }; 46362306a36Sopenharmony_ci }; 46462306a36Sopenharmony_ci 46562306a36Sopenharmony_ciTegra210: 46662306a36Sopenharmony_ci--------- 46762306a36Sopenharmony_ci 46862306a36Sopenharmony_ciSoC DTSI: 46962306a36Sopenharmony_ci 47062306a36Sopenharmony_ci pcie-controller@1003000 { 47162306a36Sopenharmony_ci compatible = "nvidia,tegra210-pcie"; 47262306a36Sopenharmony_ci device_type = "pci"; 47362306a36Sopenharmony_ci reg = <0x0 0x01003000 0x0 0x00000800 /* PADS registers */ 47462306a36Sopenharmony_ci 0x0 0x01003800 0x0 0x00000800 /* AFI registers */ 47562306a36Sopenharmony_ci 0x0 0x02000000 0x0 0x10000000>; /* configuration space */ 47662306a36Sopenharmony_ci reg-names = "pads", "afi", "cs"; 47762306a36Sopenharmony_ci interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */ 47862306a36Sopenharmony_ci <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 47962306a36Sopenharmony_ci interrupt-names = "intr", "msi"; 48062306a36Sopenharmony_ci 48162306a36Sopenharmony_ci #interrupt-cells = <1>; 48262306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 0>; 48362306a36Sopenharmony_ci interrupt-map = <0 0 0 0 &gic GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 48462306a36Sopenharmony_ci 48562306a36Sopenharmony_ci bus-range = <0x00 0xff>; 48662306a36Sopenharmony_ci #address-cells = <3>; 48762306a36Sopenharmony_ci #size-cells = <2>; 48862306a36Sopenharmony_ci 48962306a36Sopenharmony_ci ranges = <0x82000000 0 0x01000000 0x0 0x01000000 0 0x00001000 /* port 0 configuration space */ 49062306a36Sopenharmony_ci 0x82000000 0 0x01001000 0x0 0x01001000 0 0x00001000 /* port 1 configuration space */ 49162306a36Sopenharmony_ci 0x81000000 0 0x0 0x0 0x12000000 0 0x00010000 /* downstream I/O (64 KiB) */ 49262306a36Sopenharmony_ci 0x82000000 0 0x13000000 0x0 0x13000000 0 0x0d000000 /* non-prefetchable memory (208 MiB) */ 49362306a36Sopenharmony_ci 0xc2000000 0 0x20000000 0x0 0x20000000 0 0x20000000>; /* prefetchable memory (512 MiB) */ 49462306a36Sopenharmony_ci 49562306a36Sopenharmony_ci clocks = <&tegra_car TEGRA210_CLK_PCIE>, 49662306a36Sopenharmony_ci <&tegra_car TEGRA210_CLK_AFI>, 49762306a36Sopenharmony_ci <&tegra_car TEGRA210_CLK_PLL_E>, 49862306a36Sopenharmony_ci <&tegra_car TEGRA210_CLK_CML0>; 49962306a36Sopenharmony_ci clock-names = "pex", "afi", "pll_e", "cml"; 50062306a36Sopenharmony_ci resets = <&tegra_car 70>, 50162306a36Sopenharmony_ci <&tegra_car 72>, 50262306a36Sopenharmony_ci <&tegra_car 74>; 50362306a36Sopenharmony_ci reset-names = "pex", "afi", "pcie_x"; 50462306a36Sopenharmony_ci status = "disabled"; 50562306a36Sopenharmony_ci 50662306a36Sopenharmony_ci pci@1,0 { 50762306a36Sopenharmony_ci device_type = "pci"; 50862306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x01000000 0 0x1000>; 50962306a36Sopenharmony_ci reg = <0x000800 0 0 0 0>; 51062306a36Sopenharmony_ci status = "disabled"; 51162306a36Sopenharmony_ci 51262306a36Sopenharmony_ci #address-cells = <3>; 51362306a36Sopenharmony_ci #size-cells = <2>; 51462306a36Sopenharmony_ci ranges; 51562306a36Sopenharmony_ci 51662306a36Sopenharmony_ci nvidia,num-lanes = <4>; 51762306a36Sopenharmony_ci }; 51862306a36Sopenharmony_ci 51962306a36Sopenharmony_ci pci@2,0 { 52062306a36Sopenharmony_ci device_type = "pci"; 52162306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x01001000 0 0x1000>; 52262306a36Sopenharmony_ci reg = <0x001000 0 0 0 0>; 52362306a36Sopenharmony_ci status = "disabled"; 52462306a36Sopenharmony_ci 52562306a36Sopenharmony_ci #address-cells = <3>; 52662306a36Sopenharmony_ci #size-cells = <2>; 52762306a36Sopenharmony_ci ranges; 52862306a36Sopenharmony_ci 52962306a36Sopenharmony_ci nvidia,num-lanes = <1>; 53062306a36Sopenharmony_ci }; 53162306a36Sopenharmony_ci }; 53262306a36Sopenharmony_ci 53362306a36Sopenharmony_ciBoard DTS: 53462306a36Sopenharmony_ci 53562306a36Sopenharmony_ci pcie-controller@1003000 { 53662306a36Sopenharmony_ci status = "okay"; 53762306a36Sopenharmony_ci 53862306a36Sopenharmony_ci avdd-pll-uerefe-supply = <&avdd_1v05_pll>; 53962306a36Sopenharmony_ci hvddio-pex-supply = <&vdd_1v8>; 54062306a36Sopenharmony_ci dvddio-pex-supply = <&vdd_pex_1v05>; 54162306a36Sopenharmony_ci dvdd-pex-pll-supply = <&vdd_pex_1v05>; 54262306a36Sopenharmony_ci hvdd-pex-pll-e-supply = <&vdd_1v8>; 54362306a36Sopenharmony_ci vddio-pex-ctl-supply = <&vdd_1v8>; 54462306a36Sopenharmony_ci 54562306a36Sopenharmony_ci pci@1,0 { 54662306a36Sopenharmony_ci phys = <&{/padctl@7009f000/pads/pcie/lanes/pcie-0}>, 54762306a36Sopenharmony_ci <&{/padctl@7009f000/pads/pcie/lanes/pcie-1}>, 54862306a36Sopenharmony_ci <&{/padctl@7009f000/pads/pcie/lanes/pcie-2}>, 54962306a36Sopenharmony_ci <&{/padctl@7009f000/pads/pcie/lanes/pcie-3}>; 55062306a36Sopenharmony_ci phy-names = "pcie-0", "pcie-1", "pcie-2", "pcie-3"; 55162306a36Sopenharmony_ci status = "okay"; 55262306a36Sopenharmony_ci }; 55362306a36Sopenharmony_ci 55462306a36Sopenharmony_ci pci@2,0 { 55562306a36Sopenharmony_ci phys = <&{/padctl@7009f000/pads/pcie/lanes/pcie-4}>; 55662306a36Sopenharmony_ci phy-names = "pcie-0"; 55762306a36Sopenharmony_ci status = "okay"; 55862306a36Sopenharmony_ci }; 55962306a36Sopenharmony_ci }; 56062306a36Sopenharmony_ci 56162306a36Sopenharmony_ciTegra186: 56262306a36Sopenharmony_ci--------- 56362306a36Sopenharmony_ci 56462306a36Sopenharmony_ciSoC DTSI: 56562306a36Sopenharmony_ci 56662306a36Sopenharmony_ci pcie@10003000 { 56762306a36Sopenharmony_ci compatible = "nvidia,tegra186-pcie"; 56862306a36Sopenharmony_ci power-domains = <&bpmp TEGRA186_POWER_DOMAIN_PCX>; 56962306a36Sopenharmony_ci device_type = "pci"; 57062306a36Sopenharmony_ci reg = <0x0 0x10003000 0x0 0x00000800 /* PADS registers */ 57162306a36Sopenharmony_ci 0x0 0x10003800 0x0 0x00000800 /* AFI registers */ 57262306a36Sopenharmony_ci 0x0 0x40000000 0x0 0x10000000>; /* configuration space */ 57362306a36Sopenharmony_ci reg-names = "pads", "afi", "cs"; 57462306a36Sopenharmony_ci 57562306a36Sopenharmony_ci interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */ 57662306a36Sopenharmony_ci <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 57762306a36Sopenharmony_ci interrupt-names = "intr", "msi"; 57862306a36Sopenharmony_ci 57962306a36Sopenharmony_ci #interrupt-cells = <1>; 58062306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 0>; 58162306a36Sopenharmony_ci interrupt-map = <0 0 0 0 &gic GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>; 58262306a36Sopenharmony_ci 58362306a36Sopenharmony_ci bus-range = <0x00 0xff>; 58462306a36Sopenharmony_ci #address-cells = <3>; 58562306a36Sopenharmony_ci #size-cells = <2>; 58662306a36Sopenharmony_ci 58762306a36Sopenharmony_ci ranges = <0x82000000 0 0x10000000 0x0 0x10000000 0 0x00001000 /* port 0 configuration space */ 58862306a36Sopenharmony_ci 0x82000000 0 0x10001000 0x0 0x10001000 0 0x00001000 /* port 1 configuration space */ 58962306a36Sopenharmony_ci 0x82000000 0 0x10004000 0x0 0x10004000 0 0x00001000 /* port 2 configuration space */ 59062306a36Sopenharmony_ci 0x81000000 0 0x0 0x0 0x50000000 0 0x00010000 /* downstream I/O (64 KiB) */ 59162306a36Sopenharmony_ci 0x82000000 0 0x50100000 0x0 0x50100000 0 0x07F00000 /* non-prefetchable memory (127 MiB) */ 59262306a36Sopenharmony_ci 0xc2000000 0 0x58000000 0x0 0x58000000 0 0x28000000>; /* prefetchable memory (640 MiB) */ 59362306a36Sopenharmony_ci 59462306a36Sopenharmony_ci clocks = <&bpmp TEGRA186_CLK_AFI>, 59562306a36Sopenharmony_ci <&bpmp TEGRA186_CLK_PCIE>, 59662306a36Sopenharmony_ci <&bpmp TEGRA186_CLK_PLLE>; 59762306a36Sopenharmony_ci clock-names = "afi", "pex", "pll_e"; 59862306a36Sopenharmony_ci 59962306a36Sopenharmony_ci resets = <&bpmp TEGRA186_RESET_AFI>, 60062306a36Sopenharmony_ci <&bpmp TEGRA186_RESET_PCIE>, 60162306a36Sopenharmony_ci <&bpmp TEGRA186_RESET_PCIEXCLK>; 60262306a36Sopenharmony_ci reset-names = "afi", "pex", "pcie_x"; 60362306a36Sopenharmony_ci 60462306a36Sopenharmony_ci status = "disabled"; 60562306a36Sopenharmony_ci 60662306a36Sopenharmony_ci pci@1,0 { 60762306a36Sopenharmony_ci device_type = "pci"; 60862306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x10000000 0 0x1000>; 60962306a36Sopenharmony_ci reg = <0x000800 0 0 0 0>; 61062306a36Sopenharmony_ci status = "disabled"; 61162306a36Sopenharmony_ci 61262306a36Sopenharmony_ci #address-cells = <3>; 61362306a36Sopenharmony_ci #size-cells = <2>; 61462306a36Sopenharmony_ci ranges; 61562306a36Sopenharmony_ci 61662306a36Sopenharmony_ci nvidia,num-lanes = <2>; 61762306a36Sopenharmony_ci }; 61862306a36Sopenharmony_ci 61962306a36Sopenharmony_ci pci@2,0 { 62062306a36Sopenharmony_ci device_type = "pci"; 62162306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x10001000 0 0x1000>; 62262306a36Sopenharmony_ci reg = <0x001000 0 0 0 0>; 62362306a36Sopenharmony_ci status = "disabled"; 62462306a36Sopenharmony_ci 62562306a36Sopenharmony_ci #address-cells = <3>; 62662306a36Sopenharmony_ci #size-cells = <2>; 62762306a36Sopenharmony_ci ranges; 62862306a36Sopenharmony_ci 62962306a36Sopenharmony_ci nvidia,num-lanes = <1>; 63062306a36Sopenharmony_ci }; 63162306a36Sopenharmony_ci 63262306a36Sopenharmony_ci pci@3,0 { 63362306a36Sopenharmony_ci device_type = "pci"; 63462306a36Sopenharmony_ci assigned-addresses = <0x82001800 0 0x10004000 0 0x1000>; 63562306a36Sopenharmony_ci reg = <0x001800 0 0 0 0>; 63662306a36Sopenharmony_ci status = "disabled"; 63762306a36Sopenharmony_ci 63862306a36Sopenharmony_ci #address-cells = <3>; 63962306a36Sopenharmony_ci #size-cells = <2>; 64062306a36Sopenharmony_ci ranges; 64162306a36Sopenharmony_ci 64262306a36Sopenharmony_ci nvidia,num-lanes = <1>; 64362306a36Sopenharmony_ci }; 64462306a36Sopenharmony_ci }; 64562306a36Sopenharmony_ci 64662306a36Sopenharmony_ciBoard DTS: 64762306a36Sopenharmony_ci 64862306a36Sopenharmony_ci pcie@10003000 { 64962306a36Sopenharmony_ci status = "okay"; 65062306a36Sopenharmony_ci 65162306a36Sopenharmony_ci dvdd-pex-supply = <&vdd_pex>; 65262306a36Sopenharmony_ci hvdd-pex-pll-supply = <&vdd_1v8>; 65362306a36Sopenharmony_ci hvdd-pex-supply = <&vdd_1v8>; 65462306a36Sopenharmony_ci vddio-pexctl-aud-supply = <&vdd_1v8>; 65562306a36Sopenharmony_ci 65662306a36Sopenharmony_ci pci@1,0 { 65762306a36Sopenharmony_ci nvidia,num-lanes = <4>; 65862306a36Sopenharmony_ci status = "okay"; 65962306a36Sopenharmony_ci }; 66062306a36Sopenharmony_ci 66162306a36Sopenharmony_ci pci@2,0 { 66262306a36Sopenharmony_ci nvidia,num-lanes = <0>; 66362306a36Sopenharmony_ci status = "disabled"; 66462306a36Sopenharmony_ci }; 66562306a36Sopenharmony_ci 66662306a36Sopenharmony_ci pci@3,0 { 66762306a36Sopenharmony_ci nvidia,num-lanes = <1>; 66862306a36Sopenharmony_ci status = "disabled"; 66962306a36Sopenharmony_ci }; 67062306a36Sopenharmony_ci }; 671