arm: mvebu: turris_mox: Change SERDES map depending on module topology
authorMarek Behún <marek.behun@nic.cz>
Mon, 17 Dec 2018 15:10:02 +0000 (16:10 +0100)
committerStefan Roese <sr@denx.de>
Mon, 21 Jan 2019 10:39:49 +0000 (11:39 +0100)
When SFP module is connected directly to CPU module we want the SGMII
lane speed at 1.25 Gbps.

This is a temporary solution till there is a comphy driver in the kernel
capable of changing SGMII speed at runtime.

Signed-off-by: Marek Behún <marek.behun@nic.cz>
Reviewed-by: Stefan Roese <sr@denx.de>
Signed-off-by: Stefan Roese <sr@denx.de>
board/CZ.NIC/turris_mox/turris_mox.c

index 415c462493b522073e49af22c08b4647b87fbf05..3c0ab58756e52b5d8ef09a1f776cb5d30f14b312 100644 (file)
@@ -8,6 +8,7 @@
 #include <dm.h>
 #include <clk.h>
 #include <spi.h>
+#include <mvebu/comphy.h>
 #include <linux/string.h>
 #include <linux/libfdt.h>
 #include <fdt_support.h>
@@ -206,6 +207,38 @@ static int mox_get_topology(const u8 **ptopology, int *psize, int *pis_sd)
        return 0;
 }
 
+int comphy_update_map(struct comphy_map *serdes_map, int count)
+{
+       int ret, i, size, sfpindex = -1, swindex = -1;
+       const u8 *topology;
+
+       ret = mox_get_topology(&topology, &size, NULL);
+       if (ret)
+               return ret;
+
+       for (i = 0; i < size; ++i) {
+               if (topology[i] == MOX_MODULE_SFP && sfpindex == -1)
+                       sfpindex = i;
+               else if ((topology[i] == MOX_MODULE_TOPAZ ||
+                         topology[i] == MOX_MODULE_PERIDOT) &&
+                        swindex == -1)
+                       swindex = i;
+       }
+
+       if (sfpindex >= 0 && swindex >= 0) {
+               if (sfpindex < swindex)
+                       serdes_map[0].speed = PHY_SPEED_1_25G;
+               else
+                       serdes_map[0].speed = PHY_SPEED_3_125G;
+       } else if (sfpindex >= 0) {
+               serdes_map[0].speed = PHY_SPEED_1_25G;
+       } else if (swindex >= 0) {
+               serdes_map[0].speed = PHY_SPEED_3_125G;
+       }
+
+       return 0;
+}
+
 int last_stage_init(void)
 {
        int ret, i;