162306a36Sopenharmony_ci/* 262306a36Sopenharmony_ci * BSD LICENSE 362306a36Sopenharmony_ci * 462306a36Sopenharmony_ci * Copyright(c) 2015 Broadcom Corporation. All rights reserved. 562306a36Sopenharmony_ci * 662306a36Sopenharmony_ci * Redistribution and use in source and binary forms, with or without 762306a36Sopenharmony_ci * modification, are permitted provided that the following conditions 862306a36Sopenharmony_ci * are met: 962306a36Sopenharmony_ci * 1062306a36Sopenharmony_ci * * Redistributions of source code must retain the above copyright 1162306a36Sopenharmony_ci * notice, this list of conditions and the following disclaimer. 1262306a36Sopenharmony_ci * * Redistributions in binary form must reproduce the above copyright 1362306a36Sopenharmony_ci * notice, this list of conditions and the following disclaimer in 1462306a36Sopenharmony_ci * the documentation and/or other materials provided with the 1562306a36Sopenharmony_ci * distribution. 1662306a36Sopenharmony_ci * * Neither the name of Broadcom Corporation nor the names of its 1762306a36Sopenharmony_ci * contributors may be used to endorse or promote products derived 1862306a36Sopenharmony_ci * from this software without specific prior written permission. 1962306a36Sopenharmony_ci * 2062306a36Sopenharmony_ci * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 2162306a36Sopenharmony_ci * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 2262306a36Sopenharmony_ci * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 2362306a36Sopenharmony_ci * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 2462306a36Sopenharmony_ci * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 2562306a36Sopenharmony_ci * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 2662306a36Sopenharmony_ci * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2762306a36Sopenharmony_ci * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2862306a36Sopenharmony_ci * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2962306a36Sopenharmony_ci * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 3062306a36Sopenharmony_ci * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 3162306a36Sopenharmony_ci */ 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci/dts-v1/; 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci#include "bcm-nsp.dtsi" 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci/ { 3862306a36Sopenharmony_ci model = "NorthStar Plus SVK (BCM958625K)"; 3962306a36Sopenharmony_ci compatible = "brcm,bcm958625k", "brcm,bcm58625", "brcm,nsp"; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci chosen { 4262306a36Sopenharmony_ci stdout-path = "serial0:115200n8"; 4362306a36Sopenharmony_ci }; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci memory@60000000 { 4662306a36Sopenharmony_ci device_type = "memory"; 4762306a36Sopenharmony_ci reg = <0x60000000 0x80000000>; 4862306a36Sopenharmony_ci }; 4962306a36Sopenharmony_ci}; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci&dma { 5262306a36Sopenharmony_ci status = "okay"; 5362306a36Sopenharmony_ci}; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci&amac0 { 5662306a36Sopenharmony_ci status = "okay"; 5762306a36Sopenharmony_ci}; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci&amac1 { 6062306a36Sopenharmony_ci status = "okay"; 6162306a36Sopenharmony_ci}; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci&amac2 { 6462306a36Sopenharmony_ci status = "okay"; 6562306a36Sopenharmony_ci}; 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_ci&ehci0 { 6862306a36Sopenharmony_ci status = "okay"; 6962306a36Sopenharmony_ci}; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci&nand_controller { 7262306a36Sopenharmony_ci nand@0 { 7362306a36Sopenharmony_ci compatible = "brcm,nandcs"; 7462306a36Sopenharmony_ci reg = <0>; 7562306a36Sopenharmony_ci nand-on-flash-bbt; 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci #address-cells = <1>; 7862306a36Sopenharmony_ci #size-cells = <1>; 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci nand-ecc-strength = <24>; 8162306a36Sopenharmony_ci nand-ecc-step-size = <1024>; 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci brcm,nand-oob-sector-size = <27>; 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci partition@0 { 8662306a36Sopenharmony_ci label = "nboot"; 8762306a36Sopenharmony_ci reg = <0x00000000 0x00200000>; 8862306a36Sopenharmony_ci read-only; 8962306a36Sopenharmony_ci }; 9062306a36Sopenharmony_ci partition@200000 { 9162306a36Sopenharmony_ci label = "nenv"; 9262306a36Sopenharmony_ci reg = <0x00200000 0x00400000>; 9362306a36Sopenharmony_ci }; 9462306a36Sopenharmony_ci partition@600000 { 9562306a36Sopenharmony_ci label = "nsystem"; 9662306a36Sopenharmony_ci reg = <0x00600000 0x00a00000>; 9762306a36Sopenharmony_ci }; 9862306a36Sopenharmony_ci partition@1000000 { 9962306a36Sopenharmony_ci label = "nrootfs"; 10062306a36Sopenharmony_ci reg = <0x01000000 0x03000000>; 10162306a36Sopenharmony_ci }; 10262306a36Sopenharmony_ci partition@4000000 { 10362306a36Sopenharmony_ci label = "ncustfs"; 10462306a36Sopenharmony_ci reg = <0x04000000 0x3c000000>; 10562306a36Sopenharmony_ci }; 10662306a36Sopenharmony_ci }; 10762306a36Sopenharmony_ci}; 10862306a36Sopenharmony_ci 10962306a36Sopenharmony_ci&ohci0 { 11062306a36Sopenharmony_ci status = "okay"; 11162306a36Sopenharmony_ci}; 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci&pcie0 { 11462306a36Sopenharmony_ci status = "okay"; 11562306a36Sopenharmony_ci}; 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_ci&pcie1 { 11862306a36Sopenharmony_ci status = "okay"; 11962306a36Sopenharmony_ci}; 12062306a36Sopenharmony_ci 12162306a36Sopenharmony_ci&pcie2 { 12262306a36Sopenharmony_ci status = "okay"; 12362306a36Sopenharmony_ci}; 12462306a36Sopenharmony_ci 12562306a36Sopenharmony_ci&pinctrl { 12662306a36Sopenharmony_ci pinctrl-names = "default"; 12762306a36Sopenharmony_ci pinctrl-0 = <&nand_sel>, <&gpiobs>, <&pwmc>; 12862306a36Sopenharmony_ci 12962306a36Sopenharmony_ci nand_sel: nand_sel { 13062306a36Sopenharmony_ci function = "nand"; 13162306a36Sopenharmony_ci groups = "nand_grp"; 13262306a36Sopenharmony_ci }; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci gpiobs: gpiobs { 13562306a36Sopenharmony_ci function = "gpio_b"; 13662306a36Sopenharmony_ci groups = "gpio_b_0_grp", "gpio_b_1_grp", "gpio_b_2_grp", 13762306a36Sopenharmony_ci "gpio_b_3_grp"; 13862306a36Sopenharmony_ci }; 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci pwmc: pwmc { 14162306a36Sopenharmony_ci function = "pwm"; 14262306a36Sopenharmony_ci groups = "pwm0_grp", "pwm1_grp", "pwm2_grp", "pwm3_grp"; 14362306a36Sopenharmony_ci }; 14462306a36Sopenharmony_ci 14562306a36Sopenharmony_ci emmc_sel: emmc_sel { 14662306a36Sopenharmony_ci function = "emmc"; 14762306a36Sopenharmony_ci groups = "emmc_grp"; 14862306a36Sopenharmony_ci }; 14962306a36Sopenharmony_ci}; 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci&pwm { 15262306a36Sopenharmony_ci status = "okay"; 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_ci&qspi { 15662306a36Sopenharmony_ci status = "okay"; 15762306a36Sopenharmony_ci bspi-sel = <0>; 15862306a36Sopenharmony_ci flash: flash@0 { 15962306a36Sopenharmony_ci #address-cells = <1>; 16062306a36Sopenharmony_ci #size-cells = <1>; 16162306a36Sopenharmony_ci compatible = "m25p80"; 16262306a36Sopenharmony_ci reg = <0x0>; 16362306a36Sopenharmony_ci spi-max-frequency = <12500000>; 16462306a36Sopenharmony_ci m25p,fast-read; 16562306a36Sopenharmony_ci spi-cpol; 16662306a36Sopenharmony_ci spi-cpha; 16762306a36Sopenharmony_ci 16862306a36Sopenharmony_ci partition@0 { 16962306a36Sopenharmony_ci label = "boot"; 17062306a36Sopenharmony_ci reg = <0x00000000 0x000a0000>; 17162306a36Sopenharmony_ci }; 17262306a36Sopenharmony_ci 17362306a36Sopenharmony_ci partition@a0000 { 17462306a36Sopenharmony_ci label = "env"; 17562306a36Sopenharmony_ci reg = <0x000a0000 0x00060000>; 17662306a36Sopenharmony_ci }; 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci partition@100000 { 17962306a36Sopenharmony_ci label = "system"; 18062306a36Sopenharmony_ci reg = <0x00100000 0x00600000>; 18162306a36Sopenharmony_ci }; 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ci partition@700000 { 18462306a36Sopenharmony_ci label = "rootfs"; 18562306a36Sopenharmony_ci reg = <0x00700000 0x01900000>; 18662306a36Sopenharmony_ci }; 18762306a36Sopenharmony_ci }; 18862306a36Sopenharmony_ci}; 18962306a36Sopenharmony_ci 19062306a36Sopenharmony_ci&sata_phy0 { 19162306a36Sopenharmony_ci status = "okay"; 19262306a36Sopenharmony_ci}; 19362306a36Sopenharmony_ci 19462306a36Sopenharmony_ci&sata_phy1 { 19562306a36Sopenharmony_ci status = "okay"; 19662306a36Sopenharmony_ci}; 19762306a36Sopenharmony_ci 19862306a36Sopenharmony_ci&sata { 19962306a36Sopenharmony_ci status = "okay"; 20062306a36Sopenharmony_ci}; 20162306a36Sopenharmony_ci 20262306a36Sopenharmony_ci/* 20362306a36Sopenharmony_ci * By default the sd slot is functional. For emmc to work add "<&emmc_sel>" 20462306a36Sopenharmony_ci * and delete "<&nand_sel>" in "pinctrl-0" property of pinctrl node. Remove the 20562306a36Sopenharmony_ci * bus-width property here and disable the nand node with status = "disabled";. 20662306a36Sopenharmony_ci * 20762306a36Sopenharmony_ci * Ex: pinctrl-0 = <&emmc_sel>, <&gpiobs>, <&pwmc>; 20862306a36Sopenharmony_ci */ 20962306a36Sopenharmony_ci&sdio { 21062306a36Sopenharmony_ci bus-width = <4>; 21162306a36Sopenharmony_ci no-1-8-v; 21262306a36Sopenharmony_ci status = "okay"; 21362306a36Sopenharmony_ci}; 21462306a36Sopenharmony_ci 21562306a36Sopenharmony_ci&srab { 21662306a36Sopenharmony_ci compatible = "brcm,bcm58625-srab", "brcm,nsp-srab"; 21762306a36Sopenharmony_ci status = "okay"; 21862306a36Sopenharmony_ci 21962306a36Sopenharmony_ci ports { 22062306a36Sopenharmony_ci port@0 { 22162306a36Sopenharmony_ci label = "port0"; 22262306a36Sopenharmony_ci reg = <0>; 22362306a36Sopenharmony_ci }; 22462306a36Sopenharmony_ci 22562306a36Sopenharmony_ci port@1 { 22662306a36Sopenharmony_ci label = "port1"; 22762306a36Sopenharmony_ci reg = <1>; 22862306a36Sopenharmony_ci }; 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ci port@2 { 23162306a36Sopenharmony_ci label = "port2"; 23262306a36Sopenharmony_ci reg = <2>; 23362306a36Sopenharmony_ci }; 23462306a36Sopenharmony_ci 23562306a36Sopenharmony_ci port@3 { 23662306a36Sopenharmony_ci label = "port3"; 23762306a36Sopenharmony_ci reg = <3>; 23862306a36Sopenharmony_ci }; 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_ci port@4 { 24162306a36Sopenharmony_ci label = "port4"; 24262306a36Sopenharmony_ci reg = <4>; 24362306a36Sopenharmony_ci }; 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_ci port@8 { 24662306a36Sopenharmony_ci ethernet = <&amac2>; 24762306a36Sopenharmony_ci label = "cpu"; 24862306a36Sopenharmony_ci reg = <8>; 24962306a36Sopenharmony_ci fixed-link { 25062306a36Sopenharmony_ci speed = <1000>; 25162306a36Sopenharmony_ci full-duplex; 25262306a36Sopenharmony_ci }; 25362306a36Sopenharmony_ci }; 25462306a36Sopenharmony_ci }; 25562306a36Sopenharmony_ci}; 25662306a36Sopenharmony_ci 25762306a36Sopenharmony_ci&uart0 { 25862306a36Sopenharmony_ci status = "okay"; 25962306a36Sopenharmony_ci}; 26062306a36Sopenharmony_ci 26162306a36Sopenharmony_ci&uart1 { 26262306a36Sopenharmony_ci status = "okay"; 26362306a36Sopenharmony_ci}; 26462306a36Sopenharmony_ci 26562306a36Sopenharmony_ci&usb3_phy { 26662306a36Sopenharmony_ci status = "okay"; 26762306a36Sopenharmony_ci}; 26862306a36Sopenharmony_ci 26962306a36Sopenharmony_ci&xhci { 27062306a36Sopenharmony_ci status = "okay"; 27162306a36Sopenharmony_ci}; 272