Home | History | Annotate | Line # | Download | only in dts
      1 // SPDX-License-Identifier: GPL-2.0+
      2 /*
      3  * Copyright (C) 2013 Steffen Trumtrar <s.trumtrar (a] pengutronix.de>
      4  */
      5 
      6 #include "socfpga_cyclone5.dtsi"
      7 
      8 / {
      9 	model = "Terasic SoCkit";
     10 	compatible = "terasic,socfpga-cyclone5-sockit", "altr,socfpga-cyclone5", "altr,socfpga";
     11 
     12 	chosen {
     13 		bootargs = "earlyprintk";
     14 		stdout-path = "serial0:115200n8";
     15 	};
     16 
     17 	memory@0 {
     18 		name = "memory";
     19 		device_type = "memory";
     20 		reg = <0x0 0x40000000>; /* 1GB */
     21 	};
     22 
     23 	aliases {
     24 		/* this allow the ethaddr uboot environmnet variable contents
     25 		 * to be added to the gmac1 device tree blob.
     26 		 */
     27 		ethernet0 = &gmac1;
     28 	};
     29 
     30 	leds {
     31 		compatible = "gpio-leds";
     32 
     33 		hps_led0 {
     34 			label = "hps:blue:led0";
     35 			gpios = <&portb 24 0>;	/* HPS_GPIO53 */
     36 			linux,default-trigger = "heartbeat";
     37 		};
     38 
     39 		hps_led1 {
     40 			label = "hps:blue:led1";
     41 			gpios = <&portb 25 0>;	/* HPS_GPIO54 */
     42 			linux,default-trigger = "heartbeat";
     43 		};
     44 
     45 		hps_led2 {
     46 			label = "hps:blue:led2";
     47 			gpios = <&portb 26 0>;	/* HPS_GPIO55 */
     48 			linux,default-trigger = "heartbeat";
     49 		};
     50 
     51 		hps_led3 {
     52 			label = "hps:blue:led3";
     53 			gpios = <&portb 27 0>;	/* HPS_GPIO56 */
     54 			linux,default-trigger = "heartbeat";
     55 		};
     56 	};
     57 
     58 	gpio-keys {
     59 		compatible = "gpio-keys";
     60 
     61 		hps_sw0 {
     62 			label = "hps_sw0";
     63 			gpios = <&portc 20 0>;	/* HPS_GPI7 */
     64 			linux,input-type = <5>;	/* EV_SW */
     65 			linux,code = <0x0>;	/* SW_LID */
     66 		};
     67 
     68 		hps_sw1 {
     69 			label = "hps_sw1";
     70 			gpios = <&portc 19 0>;	/* HPS_GPI6 */
     71 			linux,input-type = <5>;	/* EV_SW */
     72 			linux,code = <0x5>;	/* SW_DOCK */
     73 		};
     74 
     75 		hps_sw2 {
     76 			label = "hps_sw2";
     77 			gpios = <&portc 18 0>;	/* HPS_GPI5 */
     78 			linux,input-type = <5>;	/* EV_SW */
     79 			linux,code = <0xa>;	/* SW_KEYPAD_SLIDE */
     80 		};
     81 
     82 		hps_sw3 {
     83 			label = "hps_sw3";
     84 			gpios = <&portc 17 0>;	/* HPS_GPI4 */
     85 			linux,input-type = <5>;	/* EV_SW */
     86 			linux,code = <0xc>;	/* SW_ROTATE_LOCK */
     87 		};
     88 
     89 		hps_hkey0 {
     90 			label = "hps_hkey0";
     91 			gpios = <&portc 21 1>;	/* HPS_GPI8 */
     92 			linux,code = <187>;	/* KEY_F17 */
     93 		};
     94 
     95 		hps_hkey1 {
     96 			label = "hps_hkey1";
     97 			gpios = <&portc 22 1>;	/* HPS_GPI9 */
     98 			linux,code = <188>;	/* KEY_F18 */
     99 		};
    100 
    101 		hps_hkey2 {
    102 			label = "hps_hkey2";
    103 			gpios = <&portc 23 1>;	/* HPS_GPI10 */
    104 			linux,code = <189>;	/* KEY_F19 */
    105 		};
    106 
    107 		hps_hkey3 {
    108 			label = "hps_hkey3";
    109 			gpios = <&portc 24 1>;	/* HPS_GPI11 */
    110 			linux,code = <190>;	/* KEY_F20 */
    111 		};
    112 	};
    113 
    114 	regulator_3_3v: vcc3p3-regulator {
    115 		compatible = "regulator-fixed";
    116 		regulator-name = "VCC3P3";
    117 		regulator-min-microvolt = <3300000>;
    118 		regulator-max-microvolt = <3300000>;
    119 	};
    120 };
    121 
    122 &gmac1 {
    123 	status = "okay";
    124 	phy-mode = "rgmii";
    125 
    126 	rxd0-skew-ps = <0>;
    127 	rxd1-skew-ps = <0>;
    128 	rxd2-skew-ps = <0>;
    129 	rxd3-skew-ps = <0>;
    130 	txen-skew-ps = <0>;
    131 	txc-skew-ps = <2600>;
    132 	rxdv-skew-ps = <0>;
    133 	rxc-skew-ps = <2000>;
    134 };
    135 
    136 &gpio0 {	/* GPIO 0..29 */
    137 	status = "okay";
    138 };
    139 
    140 &gpio1 {	/* GPIO 30..57 */
    141 	status = "okay";
    142 };
    143 
    144 &gpio2 {	/* GPIO 58..66 (HLGPI 0..13 at offset 13) */
    145 	status = "okay";
    146 };
    147 
    148 &i2c1 {
    149 	status = "okay";
    150 
    151 	accel1: accelerometer@53 {
    152 		compatible = "adi,adxl345";
    153 		reg = <0x53>;
    154 
    155 		interrupt-parent = <&portc>;
    156 		interrupts = <3 2>;
    157 	};
    158 };
    159 
    160 &mmc0 {
    161 	vmmc-supply = <&regulator_3_3v>;
    162 	vqmmc-supply = <&regulator_3_3v>;
    163 	status = "okay";
    164 };
    165 
    166 &qspi {
    167 	status = "okay";
    168 
    169 	flash: flash@0 {
    170 		#address-cells = <1>;
    171 		#size-cells = <1>;
    172 		compatible = "n25q00";
    173 		reg = <0>;
    174 		spi-max-frequency = <100000000>;
    175 
    176 		m25p,fast-read;
    177 		cdns,page-size = <256>;
    178 		cdns,block-size = <16>;
    179 		cdns,read-delay = <4>;
    180 		cdns,tshsl-ns = <50>;
    181 		cdns,tsd2d-ns = <50>;
    182 		cdns,tchsh-ns = <4>;
    183 		cdns,tslch-ns = <4>;
    184 	};
    185 };
    186 
    187 &usb1 {
    188 	status = "okay";
    189 };
    190