From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pl1-f171.google.com (mail-pl1-f171.google.com [209.85.214.171]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 0A163389108 for ; Wed, 4 Mar 2026 08:07:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.214.171 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772611676; cv=none; b=glx5w3I/iXoONX7SLiraWxhNBTd1yCdzsK+XL9WAuWcnAMDmpjFdMPVbEeA3r209Ax+ysruLlZ8uP9cU+Nxj8xCH3yt09TM9JUwxzwyGuapDm978uMAV8MEge99/W4b+Eko5rSgIvDtK0QSlZMdqN3q0lpmU2kYS+1nMRPGnNiM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772611676; c=relaxed/simple; bh=yoFyqYOAA4V1mwjmMpadIWCZZH1mrEKSXgbeTXxIp64=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=kZzva4cFv5/XgxoVXlE4R5FGoTGhPTVmgwltJDZUT+TtnD3GBLnt1w2G6fNrIY5pAAEJAGvdtNmYwi78rGtinknMWp7Afjz1syMAlzOlL4NyO2/LQvMPx91Xxsfsvf3NBfekGXjg9ql6xzTNqCz4rygMvaW6oCJwg8tNwrztfuw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=fZK/+lyK; arc=none smtp.client-ip=209.85.214.171 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="fZK/+lyK" Received: by mail-pl1-f171.google.com with SMTP id d9443c01a7336-2ad9516a653so27571205ad.0 for ; Wed, 04 Mar 2026 00:07:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1772611673; x=1773216473; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=umiDmXimKnwg21TsfCEQ72OkpzfSgk0ygJP0kl6mnKQ=; b=fZK/+lyK8Y+t1A/xay9jfY42UW0H+sohhnwZfyfpvWje7MWYr5T/YY7w9MhhGPwEvq BvF9VbiW0235TzHObM3bC5Fy4RdzswCBT7n5ADOM2v2VNMqk/aYnhPPrTWBL55wzXPBb DycAdmCAOXRxnAEG6XwIx5cAXZOncqabNo6hK4cCSL2tNYAqs4IlEkdqNqFYdoLZ3Ag4 FSoISGnOCte/X4ZlWgPvW3KdnhLrDeQh9Edzsjwc4jBmAF0npMll5G6bw7DVvdN7rJCU E7hVZCnN+KUODglNHY+2IbS2WFsA5Obzu6CjVV/omzMJ+bqGU6OZgLj/hbLmBhw1JHnF e1lg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772611673; x=1773216473; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=umiDmXimKnwg21TsfCEQ72OkpzfSgk0ygJP0kl6mnKQ=; b=YIB4at3uebDGQOzUzookHj8Y+GH2AP2KhU3O2KrmNUVSN+4AL1LJ8Ej33AVKObweNq idQ9FMnfw5CmkYQSvABFrlDbuFUrDfub8z/Z9bK8UeHDggnh08txjhDS5yjb4avjoo1F /0uMY/QOEYXw3kPgKDHG99xgAdbDe5WfxDOmgG6F9VWIeLIfypDIN0TZej5FygwIoz8J IbsCHuwfgnCBEPWVZgZJkSu5qqzaW2Oxw50JDzUVebO8J0UTG1IJA6Y/BHgUZKf4XlYN o7nI/QmGgwI56nheY1uNrLUcopsWV6Ojo+lZwFbn5vr1TP7CCkKILyUz7zSs8yVk0Um8 kxWA== X-Gm-Message-State: AOJu0Yxm83UYhBE05V5IPGLO7EkK6Aqia/3jwE8XqKg1+wJdXfJKV9Gf L3nqA4Ouvk1zA6NcoVwuefJoZ+h00ju7gpqE/InLXrwbZVy2PrhUvxiZ X-Gm-Gg: ATEYQzwhjghGg8nkCoiTpDUDE0Syk5OZ56Ck/klG6imNsPlHiDfkSzjiZLXJe3lOdBw QNTA3kQ//oWe8Swhqv6ZB9Ia+0LSTamuIghneRWTKMFV2iS01pIvx37OyNJkJ0TBDM/n4BAQODe fQqy2sCQC/YeDGXXbd3EIJYDMmBYtCFyJ2/hSqEpjaZ0UE7YYN/tkT3e/2ym3P3HGb+oWlT362n EZ8Q7nTytrFxuIbDFpVaSjZnVM5dEnrZI6wTQ6z+ckh8wjtXmAYQBXc3vOfjLa9etsj22t4SGg1 WFrZcJZn3ssi1M4sRMrTss2Z8E/iyFNdFsE9nYO0aXoI2OKOfQFODx/2sDT77g6HOUIsamdInVX OKJxp2BwNRh1o0Mu65A6ByibQtK5Bn/h1dqDpkbbjo7hY6E2QOkLE+WDaiYLFEcfiKJioHMr7Hq MZSgWpv/b+Sr1nx7vew/iVST6DjGlhaw0H7w== X-Received: by 2002:a17:902:cecf:b0:2ae:665c:8b16 with SMTP id d9443c01a7336-2ae6ab5ac69mr13854625ad.53.1772611673352; Wed, 04 Mar 2026 00:07:53 -0800 (PST) Received: from localhost ([2001:19f0:8001:1b2d:5400:5ff:fefa:a95d]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-2ae489c3626sm94364275ad.8.2026.03.04.00.07.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 04 Mar 2026 00:07:52 -0800 (PST) From: Inochi Amaoto 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)" , Yao Zi , Yanteng Si , Inochi Amaoto , Lad Prabhakar , Vladimir Oltean , Chen-Yu Tsai , Shangjuan Wei , Boon Khai Ng , Maxime Chevallier , Quentin Schulz , Giuseppe Cavallaro , Jose Abreu Cc: netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, spacemit@lists.linux.dev, linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, Yixun Lan , Longbin Li Subject: [PATCH net-next v7 0/3] riscv: spacemit: Add ethernet support for K3 Date: Wed, 4 Mar 2026 16:07:17 +0800 Message-ID: <20260304080721.1658224-1-inochiama@gmail.com> X-Mailer: git-send-email 2.53.0 Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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 v6: - https://lore.kernel.org/netdev/20260303010630.567674-1-inochiama@gmail.com patch 1: 1. Drop the extra blank line at the last Change from v5: - https://lore.kernel.org/netdev/20260227075718.2243818-1-inochiama@gmail.com patch 3: 1. fix error from checkpatch Change from v4: - https://lore.kernel.org/netdev/20260130022705.1059214-1-inochiama@gmail.com patch 1: 1 Apply Rob's tag. 2 Adjust clock description according to Russell's suggestion. patch 3: 1. Add set_phy_intf_sel() and get_interfaces() hook, suggested by Russell. 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 | 102 ++++++++ drivers/net/ethernet/stmicro/stmmac/Kconfig | 12 + drivers/net/ethernet/stmicro/stmmac/Makefile | 1 + .../ethernet/stmicro/stmmac/dwmac-spacemit.c | 228 ++++++++++++++++++ .../ethernet/stmicro/stmmac/stmmac_platform.c | 1 + 6 files changed, 346 insertions(+) create mode 100644 Documentation/devicetree/bindings/net/spacemit,k3-dwmac.yaml create mode 100644 drivers/net/ethernet/stmicro/stmmac/dwmac-spacemit.c -- 2.53.0