* [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3
@ 2026-01-30 2:27 Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
` (3 more replies)
0 siblings, 4 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-01-30 2:27 UTC (permalink / raw)
To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Russell King (Oracle), Yanteng Si, Yao Zi, Inochi Amaoto,
Lad Prabhakar, Shangjuan Wei, Maxime Chevallier, Chen-Yu Tsai,
Zhi Li, Boon Khai Ng, Quentin Schulz, Giuseppe Cavallaro,
Jose Abreu
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
Add initial support for ethernet controller of the Spacemit K3 SoC.
This ethernet controller is almost a standard Synopsys DesignWare
MAC (version 5.40a). This controller require a syscon device to
configure some basic features, like interface type and internal delay.
Change from v3:
- https://lore.kernel.org/netdev/20260128072931.875041-1-inochiama@gmail.com
patch 1:
1. fix the uncorrect compatible string postion
patch 3:
1. add "CTRL_" prefix to all ctrl register definition
2. only use delay config 0 to calculate delay code.
3. fix typo in the comment
Change from v2:
- https://lore.kernel.org/netdev/20260121071315.940130-1-inochiama@gmail.com
patch 1:
1. remove not needed compatible for select
2. drop empty line in "spacemit,apmu" properties
3. add spacemit,apmu properties to required.
patch 3:
1. remove misused phy_fix_phy_mode_for_mac_delays.
2. use local tx clock instead of the clk_tx_i in the dwmac.
Change from v1:
- https://lore.kernel.org/netdev/20260120043609.910302-1-inochiama@gmail.com
patch 1:
1. remove phy clock
patch 3:
1. improve comment and include something special about Spacmit K3 dwmac
2. reorder the included file
3. fix wrong delay macro used in spacemit_dwmac_set_delay.
4. add check for maximum supported delay.
5. use DIV_ROUND_CLOSEST to calculate best delay configuration.
6. use assign for the ctrl register initial value.
7. fix input when calling of_property_read_u32().
Inochi Amaoto (3):
dt-bindings: net: Add support for Spacemit K3 dwmac
net: stmmac: platform: Add snps,dwmac-5.40a IP compatible string
net: stmmac: Add glue layer for Spacemit K3 SoC
.../devicetree/bindings/net/snps,dwmac.yaml | 2 +
.../bindings/net/spacemit,k3-dwmac.yaml | 103 ++++++++++
drivers/net/ethernet/stmicro/stmmac/Kconfig | 12 ++
drivers/net/ethernet/stmicro/stmmac/Makefile | 1 +
.../ethernet/stmicro/stmmac/dwmac-spacemit.c | 194 ++++++++++++++++++
.../ethernet/stmicro/stmmac/stmmac_platform.c | 1 +
6 files changed, 313 insertions(+)
create mode 100644 Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml
create mode 100644 drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c
--
2.52.0
^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac
2026-01-30 2:27 [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Inochi Amaoto
@ 2026-01-30 2:27 ` Inochi Amaoto
2026-02-03 17:39 ` Russell King (Oracle)
2026-02-09 17:55 ` Rob Herring (Arm)
2026-01-30 2:27 ` [PATCH net-next v4 2/3] net: stmmac: platform: Add snps,dwmac-5.40a IP compatible string Inochi Amaoto
` (2 subsequent siblings)
3 siblings, 2 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-01-30 2:27 UTC (permalink / raw)
To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Russell King (Oracle), Yanteng Si, Yao Zi, Inochi Amaoto,
Lad Prabhakar, Shangjuan Wei, Maxime Chevallier, Chen-Yu Tsai,
Zhi Li, Boon Khai Ng, Quentin Schulz, Giuseppe Cavallaro,
Jose Abreu
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
The GMAC IP on Spacemit K3 is almost a standard Synopsys DesignWare
MAC (version 5.40a) with some extra clock.
Add necessary compatible string for this device.
Signed-off-by: Inochi Amaoto <inochiama@gmail.com>
---
.../devicetree/bindings/net/snps,dwmac.yaml | 2 +
.../bindings/net/spacemit,k3-dwmac.yaml | 103 ++++++++++++++++++
2 files changed, 105 insertions(+)
create mode 100644 Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml
diff --git a/Documentation/devicetree/bindings/net/snps,dwmac.yaml b/Documentation/devicetree/bindings/net/snps,dwmac.yaml
index dd3c72e8363e..faa598c19bf7 100644
--- a/Documentation/devicetree/bindings/net/snps,dwmac.yaml
+++ b/Documentation/devicetree/bindings/net/snps,dwmac.yaml
@@ -108,6 +108,7 @@ properties:
- snps,dwmac-5.10a
- snps,dwmac-5.20
- snps,dwmac-5.30a
+ - snps,dwmac-5.40a
- snps,dwxgmac
- snps,dwxgmac-2.10
- sophgo,sg2042-dwmac
@@ -653,6 +654,7 @@ allOf:
- snps,dwmac-5.10a
- snps,dwmac-5.20
- snps,dwmac-5.30a
+ - snps,dwmac-5.40a
- snps,dwxgmac
- snps,dwxgmac-2.10
- st,spear600-gmac
diff --git a/Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml b/Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml
new file mode 100644
index 000000000000..fc024a927fcc
--- /dev/null
+++ b/Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml
@@ -0,0 +1,103 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/net/spacemit,k3-dwmac.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Spacemit K3 DWMAC glue layer
+
+maintainers:
+ - Inochi Amaoto <inochiama@gmail.com>
+
+select:
+ properties:
+ compatible:
+ contains:
+ const: spacemit,k3-dwmac
+ required:
+ - compatible
+
+properties:
+ compatible:
+ items:
+ - const: spacemit,k3-dwmac
+ - const: snps,dwmac-5.40a
+
+ reg:
+ maxItems: 1
+
+ clocks:
+ items:
+ - description: GMAC main clock
+ - description: PTP clock
+ - description: TX clock
+
+ clock-names:
+ items:
+ - const: stmmaceth
+ - const: ptp_ref
+ - const: tx
+
+ interrupts:
+ minItems: 1
+ items:
+ - description: MAC interrupt
+ - description: MAC wake interrupt
+
+ interrupt-names:
+ minItems: 1
+ items:
+ - const: macirq
+ - const: eth_wake_irq
+
+ resets:
+ maxItems: 1
+
+ reset-names:
+ const: stmmaceth
+
+ spacemit,apmu:
+ $ref: /schemas/types.yaml#/definitions/phandle-array
+ items:
+ - items:
+ - description: phandle to the syscon node which control the glue register
+ - description: offset of the control register
+ - description: offset of the dline register
+ description:
+ A phandle to syscon with offset to control registers for this MAC
+
+required:
+ - compatible
+ - reg
+ - clocks
+ - clock-names
+ - interrupts
+ - interrupt-names
+ - resets
+ - reset-names
+ - spacemit,apmu
+
+allOf:
+ - $ref: snps,dwmac.yaml#
+
+unevaluatedProperties: false
+
+examples:
+ - |
+ #include <dt-bindings/interrupt-controller/irq.h>
+
+ ethernet@cac80000 {
+ compatible = "spacemit,k3-dwmac", "snps,dwmac-5.40a";
+ reg = <0xcac80000 0x2000>;
+ clocks = <&syscon_apmu 66>, <&syscon_apmu 68>,
+ <&syscon_apmu 69>;
+ clock-names = "stmmaceth", "ptp_ref", "tx";
+ interrupts = <131 IRQ_TYPE_LEVEL_HIGH>, <276 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-names = "macirq", "eth_wake_irq";
+ phy-mode = "rgmii-id";
+ phy-handle = <&phy0>;
+ resets = <&syscon_apmu 67>;
+ reset-names = "stmmaceth";
+ spacemit,apmu = <&syscon_apmu 0x384 0x38c>;
+ };
+
--
2.52.0
^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH net-next v4 2/3] net: stmmac: platform: Add snps,dwmac-5.40a IP compatible string
2026-01-30 2:27 [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
@ 2026-01-30 2:27 ` Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC Inochi Amaoto
2026-02-17 16:00 ` [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Emil Renner Berthing
3 siblings, 0 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-01-30 2:27 UTC (permalink / raw)
To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Russell King (Oracle), Yanteng Si, Yao Zi, Inochi Amaoto,
Lad Prabhakar, Shangjuan Wei, Maxime Chevallier, Chen-Yu Tsai,
Zhi Li, Boon Khai Ng, Quentin Schulz, Giuseppe Cavallaro,
Jose Abreu
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
Add compatible string for 5.40a version that can avoid to define some
platform data in the glue layer.
Signed-off-by: Inochi Amaoto <inochiama@gmail.com>
---
drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c
index 8979a50b5507..54c7b1537ab9 100644
--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c
+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c
@@ -396,6 +396,7 @@ static const char * const stmmac_gmac4_compats[] = {
"snps,dwmac-5.10a",
"snps,dwmac-5.20",
"snps,dwmac-5.30a",
+ "snps,dwmac-5.40a",
NULL
};
--
2.52.0
^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC
2026-01-30 2:27 [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 2/3] net: stmmac: platform: Add snps,dwmac-5.40a IP compatible string Inochi Amaoto
@ 2026-01-30 2:27 ` Inochi Amaoto
2026-02-03 17:48 ` Russell King (Oracle)
2026-02-17 16:00 ` [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Emil Renner Berthing
3 siblings, 1 reply; 11+ messages in thread
From: Inochi Amaoto @ 2026-01-30 2:27 UTC (permalink / raw)
To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Russell King (Oracle), Yanteng Si, Yao Zi, Inochi Amaoto,
Lad Prabhakar, Shangjuan Wei, Maxime Chevallier, Chen-Yu Tsai,
Zhi Li, Boon Khai Ng, Quentin Schulz, Giuseppe Cavallaro,
Jose Abreu
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
The ethernet controller on Spacemit K3 SoC is Synopsys DesignWare
MAC (version 5.40a), with the following special points:
1. The rate of the tx clock line is auto changed when the mac speed
rate is changed, and no need for changing the input tx clock.
2. This controller require a extra syscon device to configure the
interface type, enable wake up interrupt and delay configuration
if needed.
Add Spacemit dwmac driver support on the Spacemit K3 SoC.
Signed-off-by: Inochi Amaoto <inochiama@gmail.com>
---
drivers/net/ethernet/stmicro/stmmac/Kconfig | 12 ++
drivers/net/ethernet/stmicro/stmmac/Makefile | 1 +
.../ethernet/stmicro/stmmac/dwmac-spacemit.c | 194 ++++++++++++++++++
3 files changed, 207 insertions(+)
create mode 100644 drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c
diff --git a/drivers/net/ethernet/stmicro/stmmac/Kconfig b/drivers/net/ethernet/stmicro/stmmac/Kconfig
index 907fe2e927f0..583a4692f5da 100644
--- a/drivers/net/ethernet/stmicro/stmmac/Kconfig
+++ b/drivers/net/ethernet/stmicro/stmmac/Kconfig
@@ -216,6 +216,18 @@ config DWMAC_SOPHGO
for the stmmac device driver. This driver is used for the
ethernet controllers on various Sophgo SoCs.
+config DWMAC_SPACEMIT
+ tristate "Spacemit dwmac support"
+ depends on OF && (ARCH_SPACEMIT || COMPILE_TEST)
+ select MFD_SYSCON
+ default m if ARCH_SPACEMIT
+ help
+ Support for ethernet controllers on Spacemit RISC-V SoCs
+
+ This selects the Spacemit platform specific glue layer support
+ for the stmmac device driver. This driver is used for the
+ Spacemit K3 ethernet controllers.
+
config DWMAC_STARFIVE
tristate "StarFive dwmac support"
depends on OF && (ARCH_STARFIVE || COMPILE_TEST)
diff --git a/drivers/net/ethernet/stmicro/stmmac/Makefile b/drivers/net/ethernet/stmicro/stmmac/Makefile
index 7bf528731034..9e32045631d8 100644
--- a/drivers/net/ethernet/stmicro/stmmac/Makefile
+++ b/drivers/net/ethernet/stmicro/stmmac/Makefile
@@ -27,6 +27,7 @@ obj-$(CONFIG_DWMAC_RZN1) += dwmac-rzn1.o
obj-$(CONFIG_DWMAC_S32) += dwmac-s32.o
obj-$(CONFIG_DWMAC_SOCFPGA) += dwmac-altr-socfpga.o
obj-$(CONFIG_DWMAC_SOPHGO) += dwmac-sophgo.o
+obj-$(CONFIG_DWMAC_SPACEMIT) += dwmac-spacemit.o
obj-$(CONFIG_DWMAC_STARFIVE) += dwmac-starfive.o
obj-$(CONFIG_DWMAC_STI) += dwmac-sti.o
obj-$(CONFIG_DWMAC_STM32) += dwmac-stm32.o
diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c b/drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c
new file mode 100644
index 000000000000..25d497a54ff7
--- /dev/null
+++ b/drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c
@@ -0,0 +1,194 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Spacemit DWMAC platform driver
+ *
+ * Copyright (C) 2026 Inochi Amaoto <inochiama@gmail.com>
+ */
+
+#include <linux/clk.h>
+#include <linux/math.h>
+#include <linux/mod_devicetable.h>
+#include <linux/module.h>
+#include <linux/mfd/syscon.h>
+#include <linux/of.h>
+#include <linux/platform_device.h>
+#include <linux/property.h>
+#include <linux/regmap.h>
+
+#include "stmmac_platform.h"
+
+/* ctrl register bits */
+#define CTRL_PHY_INTF_RGMII BIT(3)
+#define CTRL_PHY_INTF_MII BIT(4)
+#define CTRL_WAKE_IRQ_EN BIT(9)
+#define CTRL_PHY_IRQ_EN BIT(12)
+
+/* dline register bits */
+#define RGMII_RX_DLINE_EN BIT(0)
+#define RGMII_RX_DLINE_STEP GENMASK(5, 4)
+#define RGMII_RX_DLINE_CODE GENMASK(15, 8)
+#define RGMII_TX_DLINE_EN BIT(16)
+#define RGMII_TX_DLINE_STEP GENMASK(21, 20)
+#define RGMII_TX_DLINE_CODE GENMASK(31, 24)
+
+#define MAX_DLINE_DELAY_CODE 0xff
+#define MAX_WORKED_DELAY 2800
+/* Note: the delay step value is at 0.1ps */
+#define K3_DELAY_STEP 367
+
+static int spacemit_dwmac_set_delay(struct regmap *apmu, unsigned int dline_offset,
+ unsigned int tx_code, unsigned int rx_code)
+{
+ unsigned int mask, val;
+
+ mask = RGMII_TX_DLINE_STEP | RGMII_TX_DLINE_CODE | RGMII_TX_DLINE_EN |
+ RGMII_RX_DLINE_STEP | RGMII_RX_DLINE_CODE | RGMII_RX_DLINE_EN;
+
+ /*
+ * Since the delay step provided by config 0 is small enough, and
+ * it can cover the range of the valid delay, so there is no needed
+ * to use other step config.
+ */
+ val = FIELD_PREP(RGMII_TX_DLINE_STEP, 0) |
+ FIELD_PREP(RGMII_TX_DLINE_CODE, tx_code) | RGMII_TX_DLINE_EN |
+ FIELD_PREP(RGMII_RX_DLINE_STEP, 0) |
+ FIELD_PREP(RGMII_RX_DLINE_CODE, rx_code) | RGMII_RX_DLINE_EN;
+
+ return regmap_update_bits(apmu, dline_offset, mask, val);
+}
+
+static int spacemit_dwmac_detected_delay_value(unsigned int delay)
+{
+ if (delay == 0)
+ return 0;
+
+ if (delay > MAX_WORKED_DELAY)
+ return -EINVAL;
+
+ /*
+ * Note K3 require a specific factor for calculate
+ * the delay, in this scenario it is 0.9. So the
+ * formula is code * step / 10 * 0.9
+ */
+ return DIV_ROUND_CLOSEST(delay * 10 * 10, K3_DELAY_STEP * 9);
+}
+
+static int spacemit_dwmac_fix_delay(struct plat_stmmacenet_data *plat_dat,
+ struct regmap *apmu,
+ unsigned int dline_offset,
+ unsigned int tx_delay, unsigned int rx_delay)
+{
+ int rx_code;
+ int tx_code;
+
+ rx_code = spacemit_dwmac_detected_delay_value(rx_delay);
+ if (rx_code < 0)
+ return rx_code;
+
+ tx_code = spacemit_dwmac_detected_delay_value(tx_delay);
+ if (tx_code < 0)
+ return tx_code;
+
+ return spacemit_dwmac_set_delay(apmu, dline_offset, tx_code, rx_code);
+}
+
+static int spacemit_dwmac_update_ifconfig(struct plat_stmmacenet_data *plat_dat,
+ struct stmmac_resources *stmmac_res,
+ struct regmap *apmu,
+ unsigned int ctrl_offset)
+{
+ unsigned int mask = CTRL_PHY_INTF_MII | CTRL_PHY_INTF_RGMII | CTRL_WAKE_IRQ_EN;
+ unsigned int val = 0;
+
+ switch (plat_dat->phy_interface) {
+ case PHY_INTERFACE_MODE_MII:
+ val = CTRL_PHY_INTF_MII;
+ break;
+
+ case PHY_INTERFACE_MODE_RMII:
+ break;
+
+ case PHY_INTERFACE_MODE_RGMII:
+ case PHY_INTERFACE_MODE_RGMII_ID:
+ case PHY_INTERFACE_MODE_RGMII_RXID:
+ case PHY_INTERFACE_MODE_RGMII_TXID:
+ val = CTRL_PHY_INTF_RGMII;
+ break;
+
+ default:
+ return -EOPNOTSUPP;
+ }
+
+ if (stmmac_res->wol_irq >= 0)
+ val |= CTRL_WAKE_IRQ_EN;
+
+ return regmap_update_bits(apmu, ctrl_offset, mask, val);
+}
+
+static int spacemit_dwmac_probe(struct platform_device *pdev)
+{
+ struct plat_stmmacenet_data *plat_dat;
+ struct stmmac_resources stmmac_res;
+ struct device *dev = &pdev->dev;
+ unsigned int offset[2];
+ struct regmap *apmu;
+ struct clk *clk_tx;
+ u32 rx_delay = 0;
+ u32 tx_delay = 0;
+ int ret;
+
+ ret = stmmac_get_platform_resources(pdev, &stmmac_res);
+ if (ret)
+ return dev_err_probe(dev, ret,
+ "failed to get platform resources\n");
+
+ plat_dat = devm_stmmac_probe_config_dt(pdev, stmmac_res.mac);
+ if (IS_ERR(plat_dat))
+ return dev_err_probe(dev, PTR_ERR(plat_dat),
+ "failed to parse DT parameters\n");
+
+ clk_tx = devm_clk_get_enabled(&pdev->dev, "tx");
+ if (IS_ERR(clk_tx))
+ return dev_err_probe(&pdev->dev, PTR_ERR(clk_tx),
+ "failed to get tx clock\n");
+
+ apmu = syscon_regmap_lookup_by_phandle_args(pdev->dev.of_node, "spacemit,apmu", 2, offset);
+ if (IS_ERR(apmu))
+ return dev_err_probe(dev, PTR_ERR(apmu),
+ "Failed to get apmu regmap\n");
+
+ ret = spacemit_dwmac_update_ifconfig(plat_dat, &stmmac_res,
+ apmu, offset[0]);
+ if (ret)
+ return dev_err_probe(dev, ret, "Failed to configure ifconfig\n");
+
+ of_property_read_u32(pdev->dev.of_node, "tx-internal-delay-ps", &tx_delay);
+ of_property_read_u32(pdev->dev.of_node, "rx-internal-delay-ps", &rx_delay);
+
+ ret = spacemit_dwmac_fix_delay(plat_dat, apmu, offset[1], tx_delay, rx_delay);
+ if (ret)
+ return dev_err_probe(dev, ret, "Failed to configure delay\n");
+
+ return stmmac_dvr_probe(dev, plat_dat, &stmmac_res);
+}
+
+static const struct of_device_id spacemit_dwmac_match[] = {
+ { .compatible = "spacemit,k3-dwmac" },
+ { /* sentinel */ }
+};
+MODULE_DEVICE_TABLE(of, spacemit_dwmac_match);
+
+static struct platform_driver spacemit_dwmac_driver = {
+ .probe = spacemit_dwmac_probe,
+ .remove = stmmac_pltfr_remove,
+ .driver = {
+ .name = "spacemit-dwmac",
+ .pm = &stmmac_pltfr_pm_ops,
+ .of_match_table = spacemit_dwmac_match,
+ },
+};
+module_platform_driver(spacemit_dwmac_driver);
+
+MODULE_AUTHOR("Inochi Amaoto <inochiama@gmail.com>");
+MODULE_DESCRIPTION("Spacemit DWMAC platform driver");
+MODULE_LICENSE("GPL");
--
2.52.0
^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
@ 2026-02-03 17:39 ` Russell King (Oracle)
2026-02-04 2:11 ` Inochi Amaoto
2026-02-09 17:55 ` Rob Herring (Arm)
1 sibling, 1 reply; 11+ messages in thread
From: Russell King (Oracle) @ 2026-02-03 17:39 UTC (permalink / raw)
To: Inochi Amaoto
Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Yanteng Si, Yao Zi, Lad Prabhakar, Shangjuan Wei,
Maxime Chevallier, Chen-Yu Tsai, Zhi Li, Boon Khai Ng,
Quentin Schulz, Giuseppe Cavallaro, Jose Abreu, netdev,
devicetree, linux-kernel, linux-riscv, spacemit, linux-stm32,
linux-arm-kernel, Longbin Li
On Fri, Jan 30, 2026 at 10:27:02AM +0800, Inochi Amaoto wrote:
> + clocks:
> + items:
> + - description: GMAC main clock
If you know what this is in terms of dwmac databook clock terms, it
would be helpful to use it here. I suspect "application clock" would
probably summarise it, that being the clock for the bus interfaces
that dwmac provides to the host.
--
RMK's Patch system: https://www.armlinux.org.uk/developer/patches/
FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC
2026-01-30 2:27 ` [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC Inochi Amaoto
@ 2026-02-03 17:48 ` Russell King (Oracle)
2026-02-04 2:14 ` Inochi Amaoto
0 siblings, 1 reply; 11+ messages in thread
From: Russell King (Oracle) @ 2026-02-03 17:48 UTC (permalink / raw)
To: Inochi Amaoto
Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Yanteng Si, Yao Zi, Lad Prabhakar, Shangjuan Wei,
Maxime Chevallier, Chen-Yu Tsai, Zhi Li, Boon Khai Ng,
Quentin Schulz, Giuseppe Cavallaro, Jose Abreu, netdev,
devicetree, linux-kernel, linux-riscv, spacemit, linux-stm32,
linux-arm-kernel, Longbin Li
On Fri, Jan 30, 2026 at 10:27:04AM +0800, Inochi Amaoto wrote:
> +/* ctrl register bits */
> +#define CTRL_PHY_INTF_RGMII BIT(3)
> +#define CTRL_PHY_INTF_MII BIT(4)
> +#define CTRL_WAKE_IRQ_EN BIT(9)
> +#define CTRL_PHY_IRQ_EN BIT(12)
Thanks for updating these.
> +static int spacemit_dwmac_update_ifconfig(struct plat_stmmacenet_data *plat_dat,
> + struct stmmac_resources *stmmac_res,
> + struct regmap *apmu,
> + unsigned int ctrl_offset)
> +{
> + unsigned int mask = CTRL_PHY_INTF_MII | CTRL_PHY_INTF_RGMII | CTRL_WAKE_IRQ_EN;
> + unsigned int val = 0;
> +
> + switch (plat_dat->phy_interface) {
> + case PHY_INTERFACE_MODE_MII:
> + val = CTRL_PHY_INTF_MII;
> + break;
> +
> + case PHY_INTERFACE_MODE_RMII:
> + break;
> +
> + case PHY_INTERFACE_MODE_RGMII:
> + case PHY_INTERFACE_MODE_RGMII_ID:
> + case PHY_INTERFACE_MODE_RGMII_RXID:
> + case PHY_INTERFACE_MODE_RGMII_TXID:
> + val = CTRL_PHY_INTF_RGMII;
> + break;
> +
> + default:
> + return -EOPNOTSUPP;
> + }
> +
> + if (stmmac_res->wol_irq >= 0)
> + val |= CTRL_WAKE_IRQ_EN;
> +
> + return regmap_update_bits(apmu, ctrl_offset, mask, val);
I would suggest that this is split into two parts - first, this is
renamed and reduced to just controlling CTRL_WAKE_IRQ_EN.
Next, a function hooked into plat_dat->set_phy_intf_sel which sets
the CTRL_PHY_INTF_RGMII and CTRL_PHY_INTF_MII bits as appropriate.
Note that this function is passed the dwmac's own phy_intf_sel
value from common.h which will be PHY_INTF_SEL_GMII_MII,
PHY_INTF_SEL_RGMII or PHY_INTF_SEL_RMII for you.
It would also be good to have plat_dat->get_interfaces populated
using phy_interface_set_rgmii(), and __set_bit(PHY_INTERFACE_MODE_MII)
and __set_bit(PHY_INTERFACE_MODE_RMII) to indicate to phylink which
interface modes are permissable.
Thanks.
--
RMK's Patch system: https://www.armlinux.org.uk/developer/patches/
FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac
2026-02-03 17:39 ` Russell King (Oracle)
@ 2026-02-04 2:11 ` Inochi Amaoto
0 siblings, 0 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-02-04 2:11 UTC (permalink / raw)
To: Russell King (Oracle), Inochi Amaoto
Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Yanteng Si, Yao Zi, Lad Prabhakar, Shangjuan Wei,
Maxime Chevallier, Chen-Yu Tsai, Zhi Li, Boon Khai Ng,
Quentin Schulz, Giuseppe Cavallaro, Jose Abreu, netdev,
devicetree, linux-kernel, linux-riscv, spacemit, linux-stm32,
linux-arm-kernel, Longbin Li
On Tue, Feb 03, 2026 at 05:39:06PM +0000, Russell King (Oracle) wrote:
> On Fri, Jan 30, 2026 at 10:27:02AM +0800, Inochi Amaoto wrote:
> > + clocks:
> > + items:
> > + - description: GMAC main clock
>
> If you know what this is in terms of dwmac databook clock terms, it
> would be helpful to use it here. I suspect "application clock" would
> probably summarise it, that being the clock for the bus interfaces
> that dwmac provides to the host.
>
> --
> RMK's Patch system: https://www.armlinux.org.uk/developer/patches/
> FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!
That's a good point, In fact, I have no dwmac databook now. So if you
think it is fine, I will change this description to the "application
clock". Thanks.
Regards,
Inochi
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC
2026-02-03 17:48 ` Russell King (Oracle)
@ 2026-02-04 2:14 ` Inochi Amaoto
0 siblings, 0 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-02-04 2:14 UTC (permalink / raw)
To: Russell King (Oracle), Inochi Amaoto
Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Maxime Coquelin, Alexandre Torgue, Richard Cochran,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Yanteng Si, Yao Zi, Lad Prabhakar, Shangjuan Wei,
Maxime Chevallier, Chen-Yu Tsai, Zhi Li, Boon Khai Ng,
Quentin Schulz, Giuseppe Cavallaro, Jose Abreu, netdev,
devicetree, linux-kernel, linux-riscv, spacemit, linux-stm32,
linux-arm-kernel, Longbin Li
On Tue, Feb 03, 2026 at 05:48:00PM +0000, Russell King (Oracle) wrote:
> On Fri, Jan 30, 2026 at 10:27:04AM +0800, Inochi Amaoto wrote:
> > +/* ctrl register bits */
> > +#define CTRL_PHY_INTF_RGMII BIT(3)
> > +#define CTRL_PHY_INTF_MII BIT(4)
> > +#define CTRL_WAKE_IRQ_EN BIT(9)
> > +#define CTRL_PHY_IRQ_EN BIT(12)
>
> Thanks for updating these.
>
> > +static int spacemit_dwmac_update_ifconfig(struct plat_stmmacenet_data *plat_dat,
> > + struct stmmac_resources *stmmac_res,
> > + struct regmap *apmu,
> > + unsigned int ctrl_offset)
> > +{
> > + unsigned int mask = CTRL_PHY_INTF_MII | CTRL_PHY_INTF_RGMII | CTRL_WAKE_IRQ_EN;
> > + unsigned int val = 0;
> > +
> > + switch (plat_dat->phy_interface) {
> > + case PHY_INTERFACE_MODE_MII:
> > + val = CTRL_PHY_INTF_MII;
> > + break;
> > +
> > + case PHY_INTERFACE_MODE_RMII:
> > + break;
> > +
> > + case PHY_INTERFACE_MODE_RGMII:
> > + case PHY_INTERFACE_MODE_RGMII_ID:
> > + case PHY_INTERFACE_MODE_RGMII_RXID:
> > + case PHY_INTERFACE_MODE_RGMII_TXID:
> > + val = CTRL_PHY_INTF_RGMII;
> > + break;
> > +
> > + default:
> > + return -EOPNOTSUPP;
> > + }
> > +
> > + if (stmmac_res->wol_irq >= 0)
> > + val |= CTRL_WAKE_IRQ_EN;
> > +
> > + return regmap_update_bits(apmu, ctrl_offset, mask, val);
>
> I would suggest that this is split into two parts - first, this is
> renamed and reduced to just controlling CTRL_WAKE_IRQ_EN.
>
> Next, a function hooked into plat_dat->set_phy_intf_sel which sets
> the CTRL_PHY_INTF_RGMII and CTRL_PHY_INTF_MII bits as appropriate.
> Note that this function is passed the dwmac's own phy_intf_sel
> value from common.h which will be PHY_INTF_SEL_GMII_MII,
> PHY_INTF_SEL_RGMII or PHY_INTF_SEL_RMII for you.
>
> It would also be good to have plat_dat->get_interfaces populated
> using phy_interface_set_rgmii(), and __set_bit(PHY_INTERFACE_MODE_MII)
> and __set_bit(PHY_INTERFACE_MODE_RMII) to indicate to phylink which
> interface modes are permissable.
>
> Thanks.
>
> --
> RMK's Patch system: https://www.armlinux.org.uk/developer/patches/
> FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!
Thanks for your detailed guide, I will try to switch to these helper
apis in the next version.
Regards,
Inochi
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
2026-02-03 17:39 ` Russell King (Oracle)
@ 2026-02-09 17:55 ` Rob Herring (Arm)
1 sibling, 0 replies; 11+ messages in thread
From: Rob Herring (Arm) @ 2026-02-09 17:55 UTC (permalink / raw)
To: Inochi Amaoto
Cc: Yanteng Si, devicetree, Jose Abreu, David S. Miller, linux-riscv,
Russell King (Oracle), Lad Prabhakar, Andrew Lunn, Yao Zi,
Maxime Chevallier, Giuseppe Cavallaro, Palmer Dabbelt, spacemit,
Richard Cochran, Alexandre Torgue, Paolo Abeni, Jakub Kicinski,
Boon Khai Ng, linux-arm-kernel, Zhi Li, Alexandre Ghiti,
Shangjuan Wei, linux-stm32, Longbin Li, Maxime Coquelin,
Quentin Schulz, linux-kernel, Yixun Lan, Krzysztof Kozlowski,
netdev, Chen-Yu Tsai, Conor Dooley, Eric Dumazet, Albert Ou,
Paul Walmsley
On Fri, 30 Jan 2026 10:27:02 +0800, Inochi Amaoto wrote:
> The GMAC IP on Spacemit K3 is almost a standard Synopsys DesignWare
> MAC (version 5.40a) with some extra clock.
>
> Add necessary compatible string for this device.
>
> Signed-off-by: Inochi Amaoto <inochiama@gmail.com>
> ---
> .../devicetree/bindings/net/snps,dwmac.yaml | 2 +
> .../bindings/net/spacemit,k3-dwmac.yaml | 103 ++++++++++++++++++
> 2 files changed, 105 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml
>
Reviewed-by: Rob Herring (Arm) <robh@kernel.org>
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3
2026-01-30 2:27 [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Inochi Amaoto
` (2 preceding siblings ...)
2026-01-30 2:27 ` [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC Inochi Amaoto
@ 2026-02-17 16:00 ` Emil Renner Berthing
2026-02-27 8:01 ` Inochi Amaoto
3 siblings, 1 reply; 11+ messages in thread
From: Emil Renner Berthing @ 2026-02-17 16:00 UTC (permalink / raw)
To: Russell King (Oracle), Albert Ou, Alexandre Ghiti,
Alexandre Torgue, Andrew Lunn, Boon Khai Ng, Chen-Yu Tsai,
Conor Dooley, David S. Miller, Eric Dumazet, Giuseppe Cavallaro,
Inochi Amaoto, Jakub Kicinski, Jose Abreu, Krzysztof Kozlowski,
Lad Prabhakar, Maxime Chevallier, Maxime Coquelin, Palmer Dabbelt,
Paolo Abeni, Paul Walmsley, Quentin Schulz, Richard Cochran,
Rob Herring, Shangjuan Wei, Yanteng Si, Yao Zi, Yixun Lan, Zhi Li
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
Quoting Inochi Amaoto (2026-01-30 03:27:01)
> Add initial support for ethernet controller of the Spacemit K3 SoC.
> This ethernet controller is almost a standard Synopsys DesignWare
> MAC (version 5.40a). This controller require a syscon device to
> configure some basic features, like interface type and internal delay.
Hi Inochi,
Do you have a tree that includes the dt entries?
Otherwise how are we going to test this?
/Emil
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3
2026-02-17 16:00 ` [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Emil Renner Berthing
@ 2026-02-27 8:01 ` Inochi Amaoto
0 siblings, 0 replies; 11+ messages in thread
From: Inochi Amaoto @ 2026-02-27 8:01 UTC (permalink / raw)
To: Emil Renner Berthing, Russell King (Oracle), Albert Ou,
Alexandre Ghiti, Alexandre Torgue, Andrew Lunn, Boon Khai Ng,
Chen-Yu Tsai, Conor Dooley, David S. Miller, Eric Dumazet,
Giuseppe Cavallaro, Inochi Amaoto, Jakub Kicinski, Jose Abreu,
Krzysztof Kozlowski, Lad Prabhakar, Maxime Chevallier,
Maxime Coquelin, Palmer Dabbelt, Paolo Abeni, Paul Walmsley,
Quentin Schulz, Richard Cochran, Rob Herring, Shangjuan Wei,
Yanteng Si, Yao Zi, Yixun Lan, Zhi Li
Cc: netdev, devicetree, linux-kernel, linux-riscv, spacemit,
linux-stm32, linux-arm-kernel, Longbin Li
On Tue, Feb 17, 2026 at 10:00:29AM -0600, Emil Renner Berthing wrote:
> Quoting Inochi Amaoto (2026-01-30 03:27:01)
> > Add initial support for ethernet controller of the Spacemit K3 SoC.
> > This ethernet controller is almost a standard Synopsys DesignWare
> > MAC (version 5.40a). This controller require a syscon device to
> > configure some basic features, like interface type and internal delay.
>
> Hi Inochi,
>
> Do you have a tree that includes the dt entries?
> Otherwise how are we going to test this?
>
Yes, I have one, but it is not opened as I was requested.
I will send the DTS patch, once the clock, gpio, and pinctrl
device is available. At least for now, I had no way to post
my DTS patch.
Regards,
Inochi
^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2026-02-27 8:01 UTC | newest]
Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-01-30 2:27 [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 1/3] dt-bindings: net: Add support for Spacemit K3 dwmac Inochi Amaoto
2026-02-03 17:39 ` Russell King (Oracle)
2026-02-04 2:11 ` Inochi Amaoto
2026-02-09 17:55 ` Rob Herring (Arm)
2026-01-30 2:27 ` [PATCH net-next v4 2/3] net: stmmac: platform: Add snps,dwmac-5.40a IP compatible string Inochi Amaoto
2026-01-30 2:27 ` [PATCH net-next v4 3/3] net: stmmac: Add glue layer for Spacemit K3 SoC Inochi Amaoto
2026-02-03 17:48 ` Russell King (Oracle)
2026-02-04 2:14 ` Inochi Amaoto
2026-02-17 16:00 ` [PATCH net-next v4 0/3] riscv: spacemit: Add ethernet support for K3 Emil Renner Berthing
2026-02-27 8:01 ` Inochi Amaoto
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox