|
@@ -0,0 +1,743 @@
|
|
|
+// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
|
+
|
|
|
+#include "qcom-ipq8062-smb208.dtsi"
|
|
|
+#include <dt-bindings/input/input.h>
|
|
|
+#include <dt-bindings/leds/common.h>
|
|
|
+
|
|
|
+/ {
|
|
|
+ model = "NEC Platforms Aterm WG2600HP3";
|
|
|
+ compatible = "nec,wg2600hp3", "qcom,ipq8062", "qcom,ipq8064";
|
|
|
+
|
|
|
+ memory {
|
|
|
+ device_type = "memory";
|
|
|
+ reg = <0x42000000 0x1e000000>;
|
|
|
+ };
|
|
|
+
|
|
|
+ aliases {
|
|
|
+ label-mac-device = &gmac2;
|
|
|
+
|
|
|
+ led-boot = &led_power_green;
|
|
|
+ led-failsafe = &led_power_red;
|
|
|
+ led-running = &led_power_green;
|
|
|
+ led-upgrade = &led_power_red;
|
|
|
+ };
|
|
|
+
|
|
|
+ keys {
|
|
|
+ compatible = "gpio-keys";
|
|
|
+
|
|
|
+ pinctrl-0 = <&buttons_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ reset {
|
|
|
+ label = "reset";
|
|
|
+ gpios = <&qcom_pinmux 24 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,code = <KEY_RESTART>;
|
|
|
+ debounce-interval = <60>;
|
|
|
+ wakeup-source;
|
|
|
+ };
|
|
|
+
|
|
|
+ wps {
|
|
|
+ label = "wps";
|
|
|
+ gpios = <&qcom_pinmux 22 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,code = <KEY_WPS_BUTTON>;
|
|
|
+ debounce-interval = <60>;
|
|
|
+ wakeup-source;
|
|
|
+ };
|
|
|
+
|
|
|
+ mode0 {
|
|
|
+ label = "mode0";
|
|
|
+ gpios = <&qcom_pinmux 40 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,code = <BTN_0>;
|
|
|
+ linux,input-type = <EV_SW>;
|
|
|
+ debounce-interval = <60>;
|
|
|
+ wakeup-source;
|
|
|
+ };
|
|
|
+
|
|
|
+ mode1 {
|
|
|
+ label = "mode1";
|
|
|
+ gpios = <&qcom_pinmux 41 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,code = <BTN_1>;
|
|
|
+ linux,input-type = <EV_SW>;
|
|
|
+ debounce-interval = <60>;
|
|
|
+ wakeup-source;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ leds {
|
|
|
+ compatible = "gpio-leds";
|
|
|
+
|
|
|
+ pinctrl-0 = <&leds_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ led_power_green: power_green {
|
|
|
+ function = LED_FUNCTION_POWER;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ gpios = <&qcom_pinmux 14 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ led_power_red: power_red {
|
|
|
+ function = LED_FUNCTION_POWER;
|
|
|
+ color = <LED_COLOR_ID_RED>;
|
|
|
+ gpios = <&qcom_pinmux 35 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ active_green {
|
|
|
+ label = "green:active";
|
|
|
+ gpios = <&qcom_pinmux 42 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ active_red {
|
|
|
+ label = "red:active";
|
|
|
+ gpios = <&qcom_pinmux 38 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ wlan2g_green {
|
|
|
+ label = "green:wlan2g";
|
|
|
+ gpios = <&qcom_pinmux 55 GPIO_ACTIVE_HIGH>;
|
|
|
+ linux,default-trigger = "phy1tpt";
|
|
|
+ };
|
|
|
+
|
|
|
+ wlan2g_red {
|
|
|
+ label = "red:wlan2g";
|
|
|
+ gpios = <&qcom_pinmux 56 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ wlan5g_green {
|
|
|
+ label = "green:wlan5g";
|
|
|
+ gpios = <&qcom_pinmux 57 GPIO_ACTIVE_HIGH>;
|
|
|
+ linux,default-trigger = "phy0tpt";
|
|
|
+ };
|
|
|
+
|
|
|
+ wlan5g_red {
|
|
|
+ label = "red:wlan5g";
|
|
|
+ gpios = <&qcom_pinmux 58 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ tv_green {
|
|
|
+ label = "green:tv";
|
|
|
+ gpios = <&qcom_pinmux 46 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ tv_red {
|
|
|
+ label = "red:tv";
|
|
|
+ gpios = <&qcom_pinmux 36 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ converter_green {
|
|
|
+ label = "green:converter";
|
|
|
+ gpios = <&qcom_pinmux 43 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+
|
|
|
+ converter_red {
|
|
|
+ label = "red:converter";
|
|
|
+ gpios = <&qcom_pinmux 15 GPIO_ACTIVE_HIGH>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+/* nand_pins are used for leds_pins, empty the node
|
|
|
+ * from ipq8064.dtsi
|
|
|
+ */
|
|
|
+&nand_pins {
|
|
|
+ /delete-property/ disable;
|
|
|
+ /delete-property/ pullups;
|
|
|
+ /delete-property/ hold;
|
|
|
+};
|
|
|
+
|
|
|
+&qcom_pinmux {
|
|
|
+ pinctrl-0 = <&akro_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ spi_pins: spi_pins {
|
|
|
+ mux {
|
|
|
+ pins = "gpio18", "gpio19", "gpio21";
|
|
|
+ function = "gsbi5";
|
|
|
+ bias-pull-down;
|
|
|
+ };
|
|
|
+
|
|
|
+ data {
|
|
|
+ pins = "gpio18", "gpio19";
|
|
|
+ drive-strength = <10>;
|
|
|
+ };
|
|
|
+
|
|
|
+ cs {
|
|
|
+ pins = "gpio20";
|
|
|
+ drive-strength = <10>;
|
|
|
+ };
|
|
|
+
|
|
|
+ clk {
|
|
|
+ pins = "gpio21";
|
|
|
+ drive-strength = <12>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ buttons_pins: buttons_pins {
|
|
|
+ mux {
|
|
|
+ pins = "gpio22", "gpio24", "gpio40",
|
|
|
+ "gpio41";
|
|
|
+ function = "gpio";
|
|
|
+ drive-strength = <2>;
|
|
|
+ bias-pull-up;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ leds_pins: leds_pins {
|
|
|
+ mux {
|
|
|
+ pins = "gpio14", "gpio15", "gpio35",
|
|
|
+ "gpio36", "gpio38", "gpio42",
|
|
|
+ "gpio43", "gpio46", "gpio55",
|
|
|
+ "gpio56", "gpio57", "gpio58";
|
|
|
+ function = "gpio";
|
|
|
+ bias-pull-down;
|
|
|
+ };
|
|
|
+
|
|
|
+ akro2 {
|
|
|
+ pins = "gpio15", "gpio35", "gpio38",
|
|
|
+ "gpio42", "gpio43", "gpio46",
|
|
|
+ "gpio55", "gpio56", "gpio57",
|
|
|
+ "gpio58";
|
|
|
+ drive-strength = <2>;
|
|
|
+ };
|
|
|
+
|
|
|
+ akro4 {
|
|
|
+ pins = "gpio14", "gpio36";
|
|
|
+ drive-strength = <4>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Stock firmware has the following settings, so let's do the same.
|
|
|
+ * I don't sure why these are required.
|
|
|
+ */
|
|
|
+ akro_pins: akro_pinmux {
|
|
|
+ akro {
|
|
|
+ pins = "gpio17", "gpio26", "gpio47";
|
|
|
+ function = "gpio";
|
|
|
+ drive-strength = <2>;
|
|
|
+ bias-pull-down;
|
|
|
+ };
|
|
|
+
|
|
|
+ reset {
|
|
|
+ pins = "gpio45";
|
|
|
+ function = "gpio";
|
|
|
+ drive-strength = <2>;
|
|
|
+ bias-disable;
|
|
|
+ output-low;
|
|
|
+ };
|
|
|
+
|
|
|
+ gmac0_rgmii {
|
|
|
+ pins = "gpio25";
|
|
|
+ function = "gpio";
|
|
|
+ drive-strength = <8>;
|
|
|
+ bias-disable;
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&gsbi5 {
|
|
|
+ status = "okay";
|
|
|
+ qcom,mode = <GSBI_PROT_SPI>;
|
|
|
+
|
|
|
+ spi@1a280000 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ pinctrl-0 = <&spi_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ cs-gpios = <&qcom_pinmux 20 GPIO_ACTIVE_HIGH>;
|
|
|
+
|
|
|
+ flash@0 {
|
|
|
+ compatible = "jedec,spi-nor";
|
|
|
+ reg = <0>;
|
|
|
+ spi-max-frequency = <50000000>;
|
|
|
+ m25p,fast-read;
|
|
|
+
|
|
|
+ partitions {
|
|
|
+ compatible = "fixed-partitions";
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <1>;
|
|
|
+
|
|
|
+ partition@0 {
|
|
|
+ label = "SBL1";
|
|
|
+ reg = <0x0000000 0x0020000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@20000 {
|
|
|
+ label = "MIBIB";
|
|
|
+ reg = <0x0020000 0x0020000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@40000 {
|
|
|
+ label = "SBL2";
|
|
|
+ reg = <0x0040000 0x0040000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@80000 {
|
|
|
+ label = "SBL3";
|
|
|
+ reg = <0x0080000 0x0080000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@100000 {
|
|
|
+ label = "DDRCONFIG";
|
|
|
+ reg = <0x0100000 0x0010000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@110000 {
|
|
|
+ label = "SSD";
|
|
|
+ reg = <0x0110000 0x0010000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@120000 {
|
|
|
+ label = "TZ";
|
|
|
+ reg = <0x0120000 0x0080000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@1a0000 {
|
|
|
+ label = "RPM";
|
|
|
+ reg = <0x01a0000 0x0080000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@220000 {
|
|
|
+ label = "APPSBL";
|
|
|
+ reg = <0x0220000 0x0080000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@2a0000 {
|
|
|
+ label = "APPSBLENV";
|
|
|
+ reg = <0x02a0000 0x0010000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ factory: partition@2b0000 {
|
|
|
+ label = "PRODUCTDATA";
|
|
|
+ reg = <0x02b0000 0x0030000>;
|
|
|
+ read-only;
|
|
|
+
|
|
|
+ nvmem-layout {
|
|
|
+ compatible = "fixed-layout";
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <1>;
|
|
|
+
|
|
|
+ macaddr_factory_0: macaddr@0 {
|
|
|
+ reg = <0x0 0x6>;
|
|
|
+ };
|
|
|
+
|
|
|
+ macaddr_factory_6: macaddr@6 {
|
|
|
+ reg = <0x6 0x6>;
|
|
|
+ };
|
|
|
+
|
|
|
+ macaddr_PRODUCTDATA_c: macaddr@c {
|
|
|
+ reg = <0xc 0x6>;
|
|
|
+ };
|
|
|
+
|
|
|
+ macaddr_PRODUCTDATA_12: macaddr@12 {
|
|
|
+ reg = <0x12 0x6>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@2e0000 {
|
|
|
+ label = "ART";
|
|
|
+ reg = <0x02e0000 0x0040000>;
|
|
|
+ read-only;
|
|
|
+
|
|
|
+ nvmem-layout {
|
|
|
+ compatible = "fixed-layout";
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <1>;
|
|
|
+
|
|
|
+ precal_ART_1000: precal@1000 {
|
|
|
+ reg = <0x1000 0x2f20>;
|
|
|
+ };
|
|
|
+
|
|
|
+ precal_ART_5000: precal@5000 {
|
|
|
+ reg = <0x5000 0x2f20>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@320000 {
|
|
|
+ label = "TP";
|
|
|
+ reg = <0x0320000 0x0040000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@360000 {
|
|
|
+ label = "TINY";
|
|
|
+ reg = <0x0360000 0x0500000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@860000 {
|
|
|
+ compatible = "denx,uimage";
|
|
|
+ label = "firmware";
|
|
|
+ reg = <0x0860000 0x17a0000>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&adm_dma {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&pcie0 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ bridge@0,0 {
|
|
|
+ reg = <0x00000000 0 0 0 0>;
|
|
|
+ #address-cells = <3>;
|
|
|
+ #size-cells = <2>;
|
|
|
+ ranges;
|
|
|
+
|
|
|
+ wifi@1,0 {
|
|
|
+ compatible = "qcom,ath10k";
|
|
|
+ reg = <0x00010000 0 0 0 0>;
|
|
|
+
|
|
|
+ qcom,ath10k-calibration-variant = "NEC-Platforms-WG2600HP3";
|
|
|
+
|
|
|
+ nvmem-cells = <&macaddr_PRODUCTDATA_12>, <&precal_ART_1000>;
|
|
|
+ nvmem-cell-names = "mac-address", "pre-calibration";
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&pcie1 {
|
|
|
+ status = "okay";
|
|
|
+ force_gen1 = <1>;
|
|
|
+
|
|
|
+ bridge@0,0 {
|
|
|
+ reg = <0x00000000 0 0 0 0>;
|
|
|
+ #address-cells = <3>;
|
|
|
+ #size-cells = <2>;
|
|
|
+ ranges;
|
|
|
+
|
|
|
+ wifi@1,0 {
|
|
|
+ compatible = "qcom,ath10k";
|
|
|
+ reg = <0x00010000 0 0 0 0>;
|
|
|
+
|
|
|
+ ieee80211-freq-limit = <2400000 2483000>;
|
|
|
+ qcom,ath10k-calibration-variant = "NEC-Platforms-WG2600HP3";
|
|
|
+
|
|
|
+ nvmem-cells = <&macaddr_PRODUCTDATA_c>, <&precal_ART_5000>;
|
|
|
+ nvmem-cell-names = "mac-address", "pre-calibration";
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&mdio0 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ pinctrl-0 = <&mdio0_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ switch@10 {
|
|
|
+ compatible = "qca,qca8337";
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+ reg = <0x10>;
|
|
|
+
|
|
|
+ ports {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ port@0 {
|
|
|
+ reg = <0>;
|
|
|
+ label = "cpu";
|
|
|
+ ethernet = <&gmac1>;
|
|
|
+ phy-mode = "rgmii";
|
|
|
+ tx-internal-delay-ps = <1000>;
|
|
|
+
|
|
|
+ fixed-link {
|
|
|
+ speed = <1000>;
|
|
|
+ full-duplex;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@1 {
|
|
|
+ reg = <1>;
|
|
|
+ label = "wan";
|
|
|
+ phy-mode = "internal";
|
|
|
+ phy-handle = <&phy_port1>;
|
|
|
+
|
|
|
+ leds {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ led@0 {
|
|
|
+ reg = <0>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_WAN;
|
|
|
+ function-enumerator = <1>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@1 {
|
|
|
+ reg = <1>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_WAN;
|
|
|
+ function-enumerator = <2>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@2 {
|
|
|
+ reg = <2>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_WAN;
|
|
|
+ function-enumerator = <3>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@2 {
|
|
|
+ reg = <2>;
|
|
|
+ label = "lan1";
|
|
|
+ phy-mode = "internal";
|
|
|
+ phy-handle = <&phy_port2>;
|
|
|
+
|
|
|
+ leds {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ led@0 {
|
|
|
+ reg = <0>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <1>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@1 {
|
|
|
+ reg = <1>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <2>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@2 {
|
|
|
+ reg = <2>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <3>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@3 {
|
|
|
+ reg = <3>;
|
|
|
+ label = "lan2";
|
|
|
+ phy-mode = "internal";
|
|
|
+ phy-handle = <&phy_port3>;
|
|
|
+
|
|
|
+ leds {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ led@0 {
|
|
|
+ reg = <0>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <1>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@1 {
|
|
|
+ reg = <1>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <2>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@2 {
|
|
|
+ reg = <2>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <3>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@4 {
|
|
|
+ reg = <4>;
|
|
|
+ label = "lan3";
|
|
|
+ phy-mode = "internal";
|
|
|
+ phy-handle = <&phy_port4>;
|
|
|
+
|
|
|
+ leds {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ led@0 {
|
|
|
+ reg = <0>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <1>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@1 {
|
|
|
+ reg = <1>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <2>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@2 {
|
|
|
+ reg = <2>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <3>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@5 {
|
|
|
+ reg = <5>;
|
|
|
+ label = "lan4";
|
|
|
+ phy-mode = "internal";
|
|
|
+ phy-handle = <&phy_port5>;
|
|
|
+
|
|
|
+ leds {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ led@0 {
|
|
|
+ reg = <0>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <1>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@1 {
|
|
|
+ reg = <1>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <2>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+
|
|
|
+ led@2 {
|
|
|
+ reg = <2>;
|
|
|
+ color = <LED_COLOR_ID_GREEN>;
|
|
|
+ function = LED_FUNCTION_LAN;
|
|
|
+ function-enumerator = <3>;
|
|
|
+ default-state = "keep";
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ port@6 {
|
|
|
+ reg = <6>;
|
|
|
+ label = "cpu";
|
|
|
+ ethernet = <&gmac2>;
|
|
|
+ phy-mode = "sgmii";
|
|
|
+ qca,sgmii-enable-pll;
|
|
|
+ qca,sgmii-rxclk-falling-edge;
|
|
|
+
|
|
|
+ fixed-link {
|
|
|
+ speed = <1000>;
|
|
|
+ full-duplex;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ mdio {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+
|
|
|
+ phy_port1: phy@0 {
|
|
|
+ reg = <0>;
|
|
|
+ };
|
|
|
+
|
|
|
+ phy_port2: phy@1 {
|
|
|
+ reg = <1>;
|
|
|
+ };
|
|
|
+
|
|
|
+ phy_port3: phy@2 {
|
|
|
+ reg = <2>;
|
|
|
+ };
|
|
|
+
|
|
|
+ phy_port4: phy@3 {
|
|
|
+ reg = <3>;
|
|
|
+ };
|
|
|
+
|
|
|
+ phy_port5: phy@4 {
|
|
|
+ reg = <4>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&gmac1 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ pinctrl-0 = <&rgmii2_pins>;
|
|
|
+ pinctrl-names = "default";
|
|
|
+
|
|
|
+ phy-mode = "rgmii";
|
|
|
+ qcom,id = <1>;
|
|
|
+ mdiobus = <&mdio0>;
|
|
|
+ nvmem-cells = <&macaddr_factory_0>;
|
|
|
+ nvmem-cell-names = "mac-address";
|
|
|
+
|
|
|
+ fixed-link {
|
|
|
+ speed = <1000>;
|
|
|
+ full-duplex;
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&gmac2 {
|
|
|
+ status = "okay";
|
|
|
+ phy-mode = "sgmii";
|
|
|
+ qcom,id = <2>;
|
|
|
+ mdiobus = <&mdio0>;
|
|
|
+ nvmem-cells = <&macaddr_factory_6>;
|
|
|
+ nvmem-cell-names = "mac-address";
|
|
|
+
|
|
|
+ fixed-link {
|
|
|
+ speed = <1000>;
|
|
|
+ full-duplex;
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&hs_phy_0 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&ss_phy_0 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&usb3_0 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&hs_phy_1 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&ss_phy_1 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&usb3_1 {
|
|
|
+ status = "okay";
|
|
|
+};
|