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

/dts-v1/;

#include "bcm63268.dtsi"

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

/ {
	model = "Comtrend VG-8050";
	compatible = "comtrend,vg-8050", "brcm,bcm63169", "brcm,bcm63268";

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

	chosen {
		bootargs = "rootfstype=squashfs,ubifs noinitrd console=ttyS0,115200";
		stdout-path = "serial0:115200n8";
	};

	keys {
		compatible = "gpio-keys-polled";
		#address-cells = <1>;
		#size-cells = <0>;
		poll-interval = <20>;

		reset {
			label = "reset";
			gpios = <&pinctrl 33 1>;
			linux,code = <KEY_RESTART>;
			debounce-interval = <60>;
		};

		wps {
			label = "wps";
			gpios = <&pinctrl 34 1>;
			linux,code = <KEY_WPS_BUTTON>;
			debounce-interval = <60>;
		};
	};
};

&leds {
	status = "okay";
	brcm,serial-leds;
	brcm,serial-dat-low;
	brcm,serial-shift-inv;

	pinctrl-names = "default";
	pinctrl-0 = <&pinctrl_serial_led>;

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

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

	led_power_green: led@6 {
		reg = <6>;
		active-low;
		label = "green:power";
		default-state = "on";
	};

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

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

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

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

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

&hsspi {
	pinctrl-names = "default";
	pinctrl-0 = <&pinctrl_hsspi_cs5>;

	switch@5 {
		compatible = "brcm,bcm53125";
		reg = <5>;
		spi-max-frequency = <781000>;
		spi-cpha;
		spi-cpol;

		lede,alias = "eth0";

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

			lan@0 {
				reg = <0>;
				label = "lan4";
			};

			lan@1 {
				reg = <1>;
				label = "lan3";
			};

			lan@2 {
				reg = <2>;
				label = "lan2";
			};

			lan@3 {
				reg = <3>;
				label = "lan1";
			};

			wan@4 {
				reg = <4>;
				label = "wan";
			};

			cpu@8 {
				reg = <8>;
				label = "cpu";

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

&nflash {
	status = "okay";

	nandcs@0 {
		compatible = "brcm,nandcs";
		#size-cells = <1>;
		#address-cells = <1>;
		reg = <0>;
		nand-ecc-step-size = <512>;
		nand-ecc-strength = <15>;
		nand-on-flash-bbt;
		brcm,nand-oob-sector-size = <64>;

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

			partition@0 {
				label = "cferom";
				reg = <0x0000000 0x0020000>;
				read-only;
			};

			partition@20000 {
				compatible = "brcm,wfi-split";
				label = "wfi";
				reg = <0x0020000 0x7ac0000>;
			};
		};
	};
};

&uart0 {
	status = "okay";
};