board: traverse: ten64: fix allocation order of MAC addresses
authorMathew McBride <matt@traverse.com.au>
Fri, 21 Jul 2023 04:39:25 +0000 (04:39 +0000)
committerTom Rini <trini@konsulko.com>
Thu, 3 Aug 2023 13:40:50 +0000 (09:40 -0400)
On Ten64 boards, the "serial number" is the MAC address of the
first Gigabit Ethernet interface (labelled GE0 on the appliance),
and counted up from there.

The previous logic did not take into account U-Boot's ordering
of the network interfaces. By setting aliases/ethernetX in the device
tree we can ensure the U-Boot 'ethX' is the same as the labelled
port order on the unit, as well as the one adopted by Linux.

Signed-off-by: Mathew McBride <matt@traverse.com.au>
arch/arm/dts/fsl-ls1088a-ten64-u-boot.dtsi
board/traverse/ten64/ten64.c

index 89566bf84935bb007efb0672a9d99965865acf3a..4e6700d586e21cb9c4f52b47cdbf46057c77ae6c 100644 (file)
@@ -6,6 +6,16 @@
 /{
        aliases {
                spi0 = &qspi;
+               ethernet0 = &dpmac7;
+               ethernet1 = &dpmac8;
+               ethernet2 = &dpmac9;
+               ethernet3 = &dpmac10;
+               ethernet4 = &dpmac3;
+               ethernet5 = &dpmac4;
+               ethernet6 = &dpmac5;
+               ethernet7 = &dpmac6;
+               ethernet8 = &dpmac2;
+               ethernet9 = &dpmac1;
        };
 };
 
index 39f0d107cdd54cee83cf1715c0a9724b5ae3ad94..0febc0baf0393128d85485733929984b3177a528 100644 (file)
@@ -328,8 +328,8 @@ static void ten64_set_macaddrs_from_board_info(struct t64uc_board_info *boardinf
                this_dpmac_num = allocation_order[intfidx];
                printf("DPMAC%d: %s\n", this_dpmac_num, ethaddr);
                snprintf(enetvar, 10,
-                        (this_dpmac_num != 1) ? "eth%daddr" : "ethaddr",
-                        this_dpmac_num - 1);
+                        (intfidx != 0) ? "eth%daddr" : "ethaddr",
+                        intfidx);
                macaddr++;
 
                if (!env_get(enetvar))