#include "bcm6328.dtsi"

/ {
	model = "D-Link DSL-2750B rev B1/DSL-2740B rev F1/DSL-2741B rev F1";
	compatible = "dlink,dsl-2750b-b1", "brcm,bcm6328";

	aliases {
		led-boot = &led_power_green;
		led-failsafe = &led_power_red;
		led-running = &led_power_green;
		led-upgrade = &led_power_green;
	};

	keys {
		compatible = "gpio-keys-polled";
		poll-interval = <100>;

		wifi {
			label = "wifi";
			gpios = <&gpio 10 GPIO_ACTIVE_LOW>;
			linux,code = <KEY_WLAN>;
			debounce-interval = <60>;
		};

		reset {
			label = "reset";
			gpios = <&gpio 23 GPIO_ACTIVE_LOW>;
			linux,code = <KEY_RESTART>;
			debounce-interval = <60>;
		};

		wps {
			label = "wps";
			gpios = <&gpio 24 GPIO_ACTIVE_LOW>;
			linux,code = <KEY_WPS_BUTTON>;
			debounce-interval = <60>;
		};
	};

	leds {
		compatible = "gpio-leds";

		led-31 {
			function = LED_FUNCTION_USB;
			color = <LED_COLOR_ID_GREEN>;
			gpios = <&gpio 31 GPIO_ACTIVE_LOW>;
			trigger-sources = <&ehci_port1>;
			linux,default-trigger = "usbport";
		};
	};

	ath9k-leds {
		compatible = "gpio-leds";

		led-8 {
			function = LED_FUNCTION_WLAN;
			color = <LED_COLOR_ID_GREEN>;
			gpios = <&ath9k 8 GPIO_ACTIVE_HIGH>;
			linux,default-trigger = "phy0tpt";
		};
	};
};

&leds {
	status = "okay";
	
	pinctrl-names = "default";
	pinctrl-0 = <&pinctrl_leds>;

	led@2 {
		reg = <2>;
		active-low;
		label = "red:internet";
	};

	led@3 {
		reg = <3>;
		active-low;
		label = "green:dsl";
	};

	led_power_green: led@4 {
		reg = <4>;
		active-low;
		function = LED_FUNCTION_POWER;
		color = <LED_COLOR_ID_GREEN>;
	};

	led_power_red: led@8 {
		reg = <8>;
		active-low;
		function = LED_FUNCTION_POWER;
		color = <LED_COLOR_ID_RED>;
		panic-indicator;
	};

	led@9 {
		reg = <9>;
		active-low;
		function = LED_FUNCTION_WPS;
		color = <LED_COLOR_ID_BLUE>;
	};

	led@11 {
		reg = <11>;
		active-low;
		label = "green:internet";
	};
};

&ehci {
	status = "okay";

	#address-cells = <1>;
	#size-cells = <0>;

	ehci_port1: port@1 {
		reg = <1>;
		#trigger-source-cells = <0>;
	};
};

&ethernet {
	status = "okay";

	nvmem-cells = <&macaddr_cfe_6a0 0>;
	nvmem-cell-names = "mac-address";
};

&hsspi {
	status = "okay";

	flash@0 {
		compatible = "jedec,spi-nor";
		spi-max-frequency = <16666667>;
		spi-tx-bus-width = <2>;
		spi-rx-bus-width = <2>;
		reg = <0>;

		#address-cells = <1>;
		#size-cells = <1>;

		partitions {
			compatible = "fixed-partitions";
			#address-cells = <1>;
			#size-cells = <1>;

			partition@0 {
				reg = <0x000000 0x010000>;
				label = "cfe";
				read-only;

				nvmem-layout {
					compatible = "fixed-layout";
					#address-cells = <1>;
					#size-cells = <1>;

					macaddr_cfe_6a0: macaddr@6a0 {
						compatible = "mac-base";
						reg = <0x6a0 0x6>;
						#nvmem-cell-cells = <1>;
					};
				};
			};

			partition@10000 {
				reg = <0x010000 0x7c0000>;
				label = "linux";
				compatible = "brcm,bcm963xx-imagetag";
			};

			partition@7d0000 {
				reg = <0x7d0000 0x010000>;
				label = "cal_data";
				read-only;

				nvmem-layout {
					compatible = "fixed-layout";
					#address-cells = <1>;
					#size-cells = <1>;

					cal_data_1000: calibration@1000 {
						reg = <0x1000 0x440>;
					};
				};
			};

			partition@7e0000 {
				reg = <0x7e0000 0x020000>;
				label = "nvram";
			};
		};
	};
};

&ohci {
	status = "okay";
};

&pcie {
	status = "okay";

	pcie@0 {
		reg = <0 0 0 0 0>;
		#interrupt-cells = <1>;
		#size-cells = <2>;
		#address-cells = <3>;
		device_type = "pci";

		ath9k: wifi@168c,002e {
			compatible = "pci168c,002e";
			reg = <0 0 0 0 0>;

			nvmem-cells = <&macaddr_cfe_6a0 1>, <&cal_data_1000>;
			nvmem-cell-names = "mac-address", "calibration";
			
			#gpio-cells = <2>;
			gpio-controller;
		};
	};
};

&pinctrl {
	pinctrl_leds: leds {
		function = "led";
		pins = "gpio2", "gpio3", "gpio4",
		       "gpio8", "gpio9", "gpio11";
	};
};

&switch0 {
	ports {
		port@0 {
			reg = <0>;
			label = "lan1";

			phy-handle = <&phy1>;
			phy-mode = "mii";
		};

		port@1 {
			reg = <1>;
			label = "lan2";

			phy-handle = <&phy2>;
			phy-mode = "mii";
		};

		port@2 {
			reg = <2>;
			label = "lan3";

			phy-handle = <&phy3>;
			phy-mode = "mii";
		};

		port@3 {
			reg = <3>;
			label = "lan4";

			phy-handle = <&phy4>;
			phy-mode = "mii";
		};
	};
};

&uart0 {
	status = "okay";
};

&usbh {
	status = "okay";
};