summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHarshal Gohel2025-07-14 09:11:47 +0000
committerHauke Mehrtens2025-08-07 16:40:30 +0000
commit56499702a3c8a0057568ea69442a53de80386fad (patch)
tree54495c37e1cb770d096e5185d40d39ec75285d69
parente45d783bce28c647c29a56f5be69da1b2a1db52c (diff)
downloadopenwrt-56499702a3c8a0057568ea69442a53de80386fad.tar.gz
realtek: rtl931x: Sync family parameters with RTL930x
Some of the parameters added to RTL9300_FAMILY_ID are missing for RTL9310_FAMILY_ID. Simply add the missing ones to keep sharing code between the two SoCs. Signed-off-by: Harshal Gohel <hg@simonwunderlich.de> Signed-off-by: Sharadanand Karanjkar <sk@simonwunderlich.de> Link: https://github.com/openwrt/openwrt/pull/19574 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
-rw-r--r--target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/common.c10
-rw-r--r--target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/rtl838x.h1
2 files changed, 11 insertions, 0 deletions
diff --git a/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/common.c b/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/common.c
index 069faf7ed9..2dd93de552 100644
--- a/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/common.c
+++ b/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/common.c
@@ -1536,6 +1536,9 @@ static int __init rtl83xx_sw_probe(struct platform_device *pdev)
priv->r = &rtl930x_reg;
priv->ds->num_ports = 29;
priv->fib_entries = 16384;
+ /* TODO A version based on CHIP_INFO and MODEL_NAME_INFO should
+ * be constructed. For now, just set it to a static 'A'
+ */
priv->version = RTL8390_VERSION_A;
priv->n_lags = 16;
sw_w32(1, RTL930X_ST_CTRL);
@@ -1553,9 +1556,16 @@ static int __init rtl83xx_sw_probe(struct platform_device *pdev)
priv->r = &rtl931x_reg;
priv->ds->num_ports = 57;
priv->fib_entries = 16384;
+ /* TODO A version based on CHIP_INFO and MODEL_NAME_INFO should
+ * be constructed. For now, just set it to a static 'A'
+ */
priv->version = RTL8390_VERSION_A;
priv->n_lags = 16;
+ sw_w32(1, RTL931x_ST_CTRL);
priv->l2_bucket_size = 8;
+ priv->n_pie_blocks = 16;
+ priv->port_ignore = 0x3f;
+ priv->n_counters = 2048;
break;
}
pr_debug("Chip version %c\n", priv->version);
diff --git a/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/rtl838x.h b/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/rtl838x.h
index 18405bdc02..b8f543bd9e 100644
--- a/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/rtl838x.h
+++ b/target/linux/realtek/files-6.12/drivers/net/dsa/rtl83xx/rtl838x.h
@@ -276,6 +276,7 @@
#define MV_ACT_COPY2CPU 3
#define RTL930X_ST_CTRL (0x8798)
+#define RTL931x_ST_CTRL (0x8000)
#define RTL930X_L2_PORT_SABLK_CTRL (0x905c)
#define RTL930X_L2_PORT_DABLK_CTRL (0x9060)