162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0 OR MIT) 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Device Tree file for SolidRun Armada 38x Microsom 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2015 Russell King 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci#include <dt-bindings/input/input.h> 862306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h> 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci/ { 1162306a36Sopenharmony_ci memory { 1262306a36Sopenharmony_ci device_type = "memory"; 1362306a36Sopenharmony_ci reg = <0x00000000 0x10000000>; /* 256 MB */ 1462306a36Sopenharmony_ci }; 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci soc { 1762306a36Sopenharmony_ci ranges = <MBUS_ID(0xf0, 0x01) 0 0xf1000000 0x100000 1862306a36Sopenharmony_ci MBUS_ID(0x01, 0x1d) 0 0xfff00000 0x100000 1962306a36Sopenharmony_ci MBUS_ID(0x09, 0x19) 0 0xf1100000 0x10000 2062306a36Sopenharmony_ci MBUS_ID(0x09, 0x15) 0 0xf1110000 0x10000 2162306a36Sopenharmony_ci MBUS_ID(0x0c, 0x04) 0 0xf1200000 0x100000>; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci internal-regs { 2462306a36Sopenharmony_ci rtc@a3800 { 2562306a36Sopenharmony_ci /* 2662306a36Sopenharmony_ci * If the rtc doesn't work, run "date reset" 2762306a36Sopenharmony_ci * twice in u-boot. 2862306a36Sopenharmony_ci */ 2962306a36Sopenharmony_ci status = "okay"; 3062306a36Sopenharmony_ci }; 3162306a36Sopenharmony_ci }; 3262306a36Sopenharmony_ci }; 3362306a36Sopenharmony_ci}; 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci&bm { 3662306a36Sopenharmony_ci status = "okay"; 3762306a36Sopenharmony_ci}; 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci&bm_bppi { 4062306a36Sopenharmony_ci status = "okay"; 4162306a36Sopenharmony_ci}; 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_cið0 { 4462306a36Sopenharmony_ci /* ethernet@70000 */ 4562306a36Sopenharmony_ci pinctrl-0 = <&ge0_rgmii_pins>; 4662306a36Sopenharmony_ci pinctrl-names = "default"; 4762306a36Sopenharmony_ci phy = <&phy_dedicated>; 4862306a36Sopenharmony_ci phy-mode = "rgmii-id"; 4962306a36Sopenharmony_ci buffer-manager = <&bm>; 5062306a36Sopenharmony_ci bm,pool-long = <0>; 5162306a36Sopenharmony_ci bm,pool-short = <1>; 5262306a36Sopenharmony_ci status = "okay"; 5362306a36Sopenharmony_ci}; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci&mdio { 5662306a36Sopenharmony_ci /* 5762306a36Sopenharmony_ci * Add the phy clock here, so the phy can be accessed to read its 5862306a36Sopenharmony_ci * IDs prior to binding with the driver. 5962306a36Sopenharmony_ci */ 6062306a36Sopenharmony_ci pinctrl-0 = <&mdio_pins µsom_phy_clk_pins>; 6162306a36Sopenharmony_ci pinctrl-names = "default"; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci phy_dedicated: ethernet-phy@0 { 6462306a36Sopenharmony_ci /* 6562306a36Sopenharmony_ci * Annoyingly, the marvell phy driver configures the LED 6662306a36Sopenharmony_ci * register, rather than preserving reset-loaded setting. 6762306a36Sopenharmony_ci * We undo that rubbish here. 6862306a36Sopenharmony_ci */ 6962306a36Sopenharmony_ci marvell,reg-init = <3 16 0 0x101e>; 7062306a36Sopenharmony_ci reg = <0>; 7162306a36Sopenharmony_ci }; 7262306a36Sopenharmony_ci}; 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci&i2c0 { 7562306a36Sopenharmony_ci clock-frequency = <400000>; 7662306a36Sopenharmony_ci pinctrl-0 = <&i2c0_pins>; 7762306a36Sopenharmony_ci pinctrl-names = "default"; 7862306a36Sopenharmony_ci status = "okay"; 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci eeprom@53 { 8162306a36Sopenharmony_ci compatible = "atmel,24c02"; 8262306a36Sopenharmony_ci reg = <0x53>; 8362306a36Sopenharmony_ci pagesize = <16>; 8462306a36Sopenharmony_ci }; 8562306a36Sopenharmony_ci}; 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci&pinctrl { 8862306a36Sopenharmony_ci microsom_phy_clk_pins: microsom-phy-clk-pins { 8962306a36Sopenharmony_ci marvell,pins = "mpp45"; 9062306a36Sopenharmony_ci marvell,function = "ref"; 9162306a36Sopenharmony_ci }; 9262306a36Sopenharmony_ci /* Optional eMMC */ 9362306a36Sopenharmony_ci microsom_sdhci_pins: microsom-sdhci-pins { 9462306a36Sopenharmony_ci marvell,pins = "mpp21", "mpp28", "mpp37", 9562306a36Sopenharmony_ci "mpp38", "mpp39", "mpp40"; 9662306a36Sopenharmony_ci marvell,function = "sd0"; 9762306a36Sopenharmony_ci }; 9862306a36Sopenharmony_ci}; 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_ci&spi1 { 10162306a36Sopenharmony_ci /* The microsom has an optional W25Q32 on board, connected to CS0 */ 10262306a36Sopenharmony_ci pinctrl-0 = <&spi1_pins>; 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci w25q32: flash@0 { 10562306a36Sopenharmony_ci #address-cells = <1>; 10662306a36Sopenharmony_ci #size-cells = <1>; 10762306a36Sopenharmony_ci compatible = "w25q32", "jedec,spi-nor"; 10862306a36Sopenharmony_ci reg = <0>; /* Chip select 0 */ 10962306a36Sopenharmony_ci spi-max-frequency = <3000000>; 11062306a36Sopenharmony_ci }; 11162306a36Sopenharmony_ci}; 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci&uart0 { 11462306a36Sopenharmony_ci pinctrl-0 = <&uart0_pins>; 11562306a36Sopenharmony_ci pinctrl-names = "default"; 11662306a36Sopenharmony_ci status = "okay"; 11762306a36Sopenharmony_ci}; 118