1// SPDX-License-Identifier: (GPL-2.0+ OR X11) 2/* 3 * Copyright (C) 2015 Marek Vasut <marex@denx.de> 4 */ 5 6#include "socfpga_cyclone5.dtsi" 7#include <dt-bindings/gpio/gpio.h> 8#include <dt-bindings/input/input.h> 9 10/ { 11 model = "samtec VIN|ING FPGA"; 12 compatible = "samtec,vining", "altr,socfpga-cyclone5", "altr,socfpga"; 13 14 chosen { 15 bootargs = "earlyprintk"; 16 stdout-path = "serial0:115200n8"; 17 }; 18 19 memory@0 { 20 name = "memory"; 21 device_type = "memory"; 22 reg = <0x0 0x40000000>; /* 1GB */ 23 }; 24 25 aliases { 26 /* 27 * This allow the ethaddr uboot environment variable contents 28 * to be added to the gmac1 device tree blob. 29 */ 30 ethernet0 = &gmac1; 31 ethernet1 = &gmac0; 32 }; 33 34 gpio-keys { 35 compatible = "gpio-keys"; 36 37 hps_temp0 { 38 label = "BTN_0"; /* TEMP_OS */ 39 gpios = <&portc 18 GPIO_ACTIVE_LOW>; /* HPS_GPI5 */ 40 linux,code = <BTN_0>; 41 }; 42 43 hps_hkey0 { 44 label = "GP_SWITCH"; /* GP_SWITCH */ 45 gpios = <&portc 19 GPIO_ACTIVE_LOW>; /* HPS_GPI6 */ 46 linux,code = <BTN_1>; 47 }; 48 49 hps_hkey1 { 50 label = "RESET_SWITCH"; /* RESET_SWITCH */ 51 gpios = <&portc 20 GPIO_ACTIVE_LOW>; /* HPS_GPI7 */ 52 linux,code = <BTN_2>; 53 }; 54 55 hps_hkey2 { 56 label = "POWER_DOWN"; /* POWER_DOWN */ 57 gpios = <&portc 4 GPIO_ACTIVE_LOW>; /* HPS_GPIO62 */ 58 linux,code = <KEY_POWER>; 59 }; 60 61 hps_hkey3 { 62 label = "SENSE"; /* SENSE */ 63 gpios = <&porta 9 GPIO_ACTIVE_LOW>; /* HPS_GPIO9 */ 64 linux,code = <BTN_3>; 65 }; 66 }; 67 68 regulator-usb-nrst { 69 compatible = "regulator-fixed"; 70 regulator-name = "usb_nrst"; 71 regulator-min-microvolt = <5000000>; 72 regulator-max-microvolt = <5000000>; 73 gpio = <&portb 5 GPIO_ACTIVE_HIGH>; 74 startup-delay-us = <70000>; 75 enable-active-high; 76 regulator-always-on; 77 }; 78}; 79 80&gmac1 { 81 status = "okay"; 82 phy-mode = "rgmii"; 83 phy-handle = <&phy1>; 84 85 snps,reset-gpio = <&porta 0 GPIO_ACTIVE_LOW>; 86 snps,reset-active-low; 87 snps,reset-delays-us = <10000 10000 10000>; 88 89 mdio0 { 90 #address-cells = <1>; 91 #size-cells = <0>; 92 compatible = "snps,dwmac-mdio"; 93 phy1: ethernet-phy@1 { 94 reg = <1>; 95 rxd0-skew-ps = <0>; 96 rxd1-skew-ps = <0>; 97 rxd2-skew-ps = <0>; 98 rxd3-skew-ps = <0>; 99 txd0-skew-ps = <0>; 100 txd1-skew-ps = <0>; 101 txd2-skew-ps = <0>; 102 txd3-skew-ps = <0>; 103 txen-skew-ps = <0>; 104 txc-skew-ps = <1860>; 105 rxdv-skew-ps = <0>; 106 rxc-skew-ps = <1860>; 107 }; 108 }; 109}; 110 111&gpio0 { /* GPIO 0..29 */ 112 status = "okay"; 113}; 114 115&gpio1 { /* GPIO 30..57 */ 116 status = "okay"; 117}; 118 119&gpio2 { /* GPIO 58..66 (HLGPI 0..13 at offset 13) */ 120 status = "okay"; 121}; 122 123&i2c0 { 124 status = "okay"; 125 126 gpio: pca9557@1f { 127 compatible = "nxp,pca9557"; 128 reg = <0x1f>; 129 gpio-controller; 130 #gpio-cells = <2>; 131 }; 132 133 temp: lm75@48 { 134 compatible = "lm75"; 135 reg = <0x48>; 136 }; 137 138 at24@50 { 139 compatible = "atmel,24c01"; 140 pagesize = <8>; 141 reg = <0x50>; 142 }; 143 144 i2cswitch@70 { 145 compatible = "nxp,pca9548"; 146 #address-cells = <1>; 147 #size-cells = <0>; 148 reg = <0x70>; 149 150 i2c@0 { 151 #address-cells = <1>; 152 #size-cells = <0>; 153 reg = <0>; 154 }; 155 156 i2c@1 { 157 #address-cells = <1>; 158 #size-cells = <0>; 159 reg = <1>; 160 }; 161 162 i2c@2 { 163 #address-cells = <1>; 164 #size-cells = <0>; 165 reg = <2>; 166 }; 167 168 i2c@3 { 169 #address-cells = <1>; 170 #size-cells = <0>; 171 reg = <3>; 172 }; 173 174 i2c@4 { 175 #address-cells = <1>; 176 #size-cells = <0>; 177 reg = <4>; 178 }; 179 180 i2c@5 { 181 #address-cells = <1>; 182 #size-cells = <0>; 183 reg = <5>; 184 }; 185 186 i2c@6 { /* Backplane EEPROM */ 187 #address-cells = <1>; 188 #size-cells = <0>; 189 reg = <6>; 190 eeprom@51 { 191 compatible = "atmel,24c01"; 192 pagesize = <8>; 193 reg = <0x51>; 194 }; 195 }; 196 197 i2c@7 { /* Power board EEPROM */ 198 #address-cells = <1>; 199 #size-cells = <0>; 200 reg = <7>; 201 eeprom@51 { 202 compatible = "atmel,24c01"; 203 pagesize = <8>; 204 reg = <0x51>; 205 }; 206 }; 207 }; 208}; 209 210&i2c1 { 211 status = "okay"; 212 clock-frequency = <100000>; 213 214 at24@50 { 215 compatible = "atmel,24c02"; 216 pagesize = <8>; 217 reg = <0x50>; 218 }; 219}; 220 221&qspi { 222 status = "okay"; 223 224 n25q128@0 { 225 #address-cells = <1>; 226 #size-cells = <1>; 227 compatible = "n25q128"; 228 reg = <0>; /* chip select */ 229 spi-max-frequency = <100000000>; 230 m25p,fast-read; 231 232 cdns,page-size = <256>; 233 cdns,block-size = <16>; 234 cdns,read-delay = <4>; 235 cdns,tshsl-ns = <50>; 236 cdns,tsd2d-ns = <50>; 237 cdns,tchsh-ns = <4>; 238 cdns,tslch-ns = <4>; 239 }; 240 241 n25q00@1 { 242 #address-cells = <1>; 243 #size-cells = <1>; 244 compatible = "n25q00"; 245 reg = <1>; /* chip select */ 246 spi-max-frequency = <100000000>; 247 m25p,fast-read; 248 249 cdns,page-size = <256>; 250 cdns,block-size = <16>; 251 cdns,read-delay = <4>; 252 cdns,tshsl-ns = <50>; 253 cdns,tsd2d-ns = <50>; 254 cdns,tchsh-ns = <4>; 255 cdns,tslch-ns = <4>; 256 }; 257}; 258 259&usb0 { 260 dr_mode = "host"; 261 status = "okay"; 262}; 263 264&usb1 { 265 dr_mode = "peripheral"; 266 status = "okay"; 267}; 268