// SPDX-License-Identifier: GPL-2.0-or-later OR MIT

#include "ar7100.dtsi"

#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/input/input.h>

/ {
	aliases {
		led-boot = &led_diag;
		led-failsafe = &led_diag;
		led-upgrade = &led_diag;
	};

	extosc: ref {
		compatible = "fixed-clock";
		#clock-cells = <0>;
		clock-output-names = "ref";
		clock-frequency = <40000000>;
	};

	leds {
		compatible = "gpio-leds";

		led_diag: diag {
			label = "red:diag";
			gpios = <&gpio 1 GPIO_ACTIVE_LOW>;
		};
	};

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

		band2g_a {
			label = "amber:band2g";
			gpios = <&ath9k0 1 GPIO_ACTIVE_LOW>;
		};

		usb {
			label = "green:usb";
			gpios = <&ath9k0 3 GPIO_ACTIVE_LOW>;
			trigger-sources = <&usb_ohci_port>, <&usb_ehci_port>;
			linux,default-trigger = "usbport";
		};

		band2g_g {
			label = "green:band2g";
			gpios = <&ath9k0 5 GPIO_ACTIVE_LOW>;
			linux,default-trigger = "phy0tpt";
		};

		band5g_g {
			label = "green:band5g";
			gpios = <&ath9k1 1 GPIO_ACTIVE_LOW>;
			linux,default-trigger = "phy1tpt";
		};

		router {
			label = "green:router";
			gpios = <&ath9k1 3 GPIO_ACTIVE_LOW>;
		};

		movie_engine {
			label = "blue:movie_engine";
			gpios = <&ath9k1 4 GPIO_ACTIVE_LOW>;
		};

		band5g_a {
			label = "amber:band5g";
			gpios = <&ath9k1 5 GPIO_ACTIVE_LOW>;
		};
	};

	keys {
		compatible = "gpio-keys";

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

		usb {
			label = "usb";
			linux,code = <BTN_2>;
			gpios = <&gpio 3 GPIO_ACTIVE_LOW>;
			debounce-interval = <60>;
		};

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

		router_auto {
			label = "router_auto";
			linux,code = <BTN_6>;
			linux,input-type = <EV_SW>;
			gpios = <&gpio 6 GPIO_ACTIVE_LOW>;
			debounce-interval = <60>;
		};

		router_off {
			label = "router_off";
			linux,code = <BTN_5>;
			linux,input-type = <EV_SW>;
			gpios = <&gpio 7 GPIO_ACTIVE_LOW>;
			debounce-interval = <60>;
		};

		movie_engine {
			label = "movie_engine";
			linux,code = <BTN_7>;
			linux,input-type = <EV_SW>;
			gpios = <&gpio 8 GPIO_ACTIVE_LOW>;
			debounce-interval = <60>;
		};
	};

	gpio-export {
		compatible = "gpio-export";

		gpio_usb_power {
			gpio-export,name = "buffalo:power:usb";
			gpio-export,output = <1>;
			gpios = <&gpio 2 GPIO_ACTIVE_HIGH>;
		};
	};

	flash {
		compatible = "mtd-concat";

		devices = <&flash0 &flash1>;

		partitions {
			compatible = "fixed-partitions";
			#address-cells = <1>;
			#size-cells = <1>;
			partition@0 {
				label = "u-boot";
				reg = <0x0000000 0x0040000>;
				read-only;
			};

			partition@40000 {
				label = "u-boot-env";
				reg = <0x0040000 0x0010000>;
				read-only;
			};

			art: partition@50000 {
				label = "art";
				reg = <0x0050000 0x0010000>;
				read-only;
			};

			partition@60000 {
				compatible = "denx,uimage";
				label = "firmware";
				reg = <0x0060000 0x1f90000>;
			};

			partition@1ff0000 {
				label = "user_property";
				reg = <0x1ff0000 0x0010000>;
				read-only;
			};
		};
	};
};

&usb_phy {
	status = "okay";
};

&usb1 {
	#address-cells = <1>;
	#size-cells = <0>;
	status = "okay";

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

&usb2 {
	#address-cells = <1>;
	#size-cells = <0>;
	status = "okay";

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

&pcie0 {
	status = "okay";

	ath9k0: wifi@0,11 {
		compatible = "pci168c,0029";
		reg = <0x8800 0 0 0 0>;
		qca,no-eeprom;
		#gpio-cells = <2>;
		gpio-controller;
	};

	ath9k1: wifi@0,12 {
		compatible = "pci168c,0029";
		reg = <0x9000 0 0 0 0>;
		qca,no-eeprom;
		#gpio-cells = <2>;
		gpio-controller;
	};
};

&pll {
	clocks = <&extosc>;
};

&spi {
	status = "okay";


	flash0: flash@0 {
		compatible = "jedec,spi-nor";
		reg = <0>;
		spi-max-frequency = <50000000>;
		m25p,fast-read;
	};

	flash1: flash@1 {
		compatible = "jedec,spi-nor";
		reg = <1>;
		spi-max-frequency = <50000000>;
		m25p,fast-read;
	};
};

&mdio0 {
	status = "okay";

	phy4: ethernet-phy@4 {
		reg = <4>;
		phy-mode = "rgmii";
	};
};

&eth0 {
	status = "okay";

	nvmem-cells = <&macaddr_art_120c>;
	nvmem-cell-names = "mac-address";

	fixed-link {
		speed = <1000>;
		full-duplex;
	};
};

&eth1 {
	status = "okay";

	nvmem-cells = <&macaddr_art_520c>;
	nvmem-cell-names = "mac-address";
	mac-address-increment = <1>;

	phy-handle = <&phy4>;
};

&art {
	compatible = "nvmem-cells";
	#address-cells = <1>;
	#size-cells = <1>;

	macaddr_art_120c: macaddr@120c {
		reg = <0x120c 0x6>;
	};

	macaddr_art_520c: macaddr@520c {
		reg = <0x520c 0x6>;
	};
};