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

#include "bcm6328.dtsi"

/ {
	model = "NuCom R5010UNv2";
	compatible = "nucom,r5010unv2", "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>;

		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>;
		};
	};

	bcm43217-sprom {
		compatible = "brcm,bcma-sprom";

		pci-bus = <1>;
		pci-dev = <0>;

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

		brcm,sprom = "brcm/bcm43217-sprom.bin";
	};
};

&ehci {
	status = "okay";
};

&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>;

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

			partition@0 {
				label = "cfe";
				reg = <0x000000 0x010000>;
				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 {
				compatible = "brcm,bcm963xx-imagetag";
				label = "firmware";
				reg = <0x010000 0xfe0000>;
			};

			partition@ff0000 {
				label = "nvram";
				reg = <0xff0000 0x010000>;
			};
		};
	};
};

&leds {
	status = "okay";

	pinctrl-names = "default";
	pinctrl-0 = <&pinctrl_ephy0_act_led &pinctrl_ephy1_act_led
		     &pinctrl_ephy2_act_led &pinctrl_ephy3_act_led
		     &pinctrl_leds>;

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

	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@5 {
		reg = <5>;
		active-low;
		function = LED_FUNCTION_POWER;
		color = <LED_COLOR_ID_RED>;
		panic-indicator;
	};

	led@10 {
		reg = <10>;
		active-low;
		function = LED_FUNCTION_WPS;
		color = <LED_COLOR_ID_GREEN>;
	};

	led@11 {
		reg = <11>;
		active-low;
		function = LED_FUNCTION_USB;
		color = <LED_COLOR_ID_GREEN>;
	};
};

&ohci {
	status = "okay";
};

&pcie {
	status = "okay";
};

&pinctrl {
	pinctrl_leds: leds {
		function = "led";
		pins = "gpio1", "gpio2", "gpio3",
		       "gpio4", "gpio5", "gpio10",
		       "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";
};