/*
 * Device Tree file for the Linksys E1700
 *
 * Copyright (C) 2014 Imre Kaloz <kaloz@openwrt.org>
 *
 * This file is licensed under the terms of the GNU General Public
 * License version 2.  This program is licensed "as is" without any
 * warranty of any kind, whether express or implied.
 */

/dts-v1/;

/include/ "mt7620a.dtsi"

/ {
	compatible = "linksys,e1700", "ralink,mt7620a-soc";
	model = "Linksys E1700";

	palmbus@10000000 {
		spi@b00 {
			status = "okay";

			m25p80@0 {
				#address-cells = <1>;
				#size-cells = <1>;
				compatible = "mx25l6405d";
				reg = <0 0>;
				linux,modalias = "m25p80", "mx25l6405d";
				spi-max-frequency = <10000000>;

				partition@0 {
					label = "u-boot";
					reg = <0x0 0x30000>;
					read-only;
				};

				partition@30000 {
					label = "config";
					reg = <0x30000 0x10000>;
					read-only;
				};

				factory: partition@40000 {
					label = "factory";
					reg = <0x40000 0x10000>;
					read-only;
				};

				partition@50000 {
					label = "firmware";
					reg = <0x50000 0x7b0000>;
				};
			};
		};
	};

	pinctrl {
		state_default: pinctrl0 {
			gpio {
				ralink,group = "i2c", "uartf";
				ralink,function = "gpio";
			};
		};
	};

	ethernet@10100000 {
		status = "okay";

		mtd-mac-address = <&factory 0x28>;

		pinctrl-names = "default";
		pinctrl-0 = <&rgmii1_pins &rgmii2_pins &mdio_pins>;

		port@5 {
			status = "okay";
			ralink,fixed-link = <1000 1 1 1>;
			phy-mode = "rgmii";
		};

		mdio-bus {
			status = "okay";

			phy0: ethernet-phy@0 {
				reg = <0>;
				phy-mode = "rgmii";
			};
			phy1: ethernet-phy@1 {
				reg = <1>;
				phy-mode = "rgmii";
			};
			phy2: ethernet-phy@2 {
				reg = <2>;
				phy-mode = "rgmii";
			};
			phy3: ethernet-phy@3 {
				reg = <3>;
				phy-mode = "rgmii";
			};
			phy4: ethernet-phy@4 {
				reg = <4>;
				phy-mode = "rgmii";
			};
			phy1f: ethernet-phy@1f {
				reg = <0x1f>;
				phy-mode = "rgmii";
			};
		};
	};

	gsw@10110000 {
		ralink,port4 = "gmac";
		mediatek,mt7530 = <1>;
	};

	wmac@10180000 {
		ralink,mtd-eeprom = <&factory 0>;
	};

	gpio-keys-polled {
		compatible = "gpio-keys-polled";
		#address-cells = <1>;
		#size-cells = <0>;
		poll-interval = <20>;
		reset {
			label = "reset";
			gpios = <&gpio0 1 0>;
			linux,code = <0x198>;
		};
		wps {
			label = "wps";
			gpios = <&gpio0 2 0>;
			linux,code = <0x211>;
		};
	};

	gpio-leds {
		compatible = "gpio-leds";
		power {
			label = "linksys:green:power";
			gpios = <&gpio0 10 1>;
		};
		wan {
			label = "linksys:green:wps";
			gpios = <&gpio0 12 1>;
		};
	};
};