From: Corentin Labbe <clabbe.montjoie@gmail.com> To: robh+dt@kernel.org, mark.rutland@arm.com, maxime.ripard@free-electrons.com, wens@csie.org, linux@armlinux.org.uk, catalin.marinas@arm.com, will.deacon@arm.com, peppe.cavallaro@st.com, alexandre.torgue@st.com Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Corentin Labbe <clabbe.montjoie@gmail.com> Subject: [PATCH v5 00/20] net-next: stmmac: add dwmac-sun8i ethernet driver Date: Mon, 1 May 2017 14:45:00 +0200 [thread overview] Message-ID: <20170501124520.3769-1-clabbe.montjoie@gmail.com> (raw) Hello This patch series add the driver for dwmac-sun8i which handle the Ethernet MAC present on Allwinner H3/H5/A83T/A64 SoCs. This driver is the continuation of the sun8i-emac driver. During the development, it appeared that in fact the hardware was a modified version of some dwmac. So the driver is now written as a glue driver for stmmac. It supports 10/100/1000 Mbit/s speed with half/full duplex. It can use an internal PHY (MII 10/100) or an external PHY via RGMII/RMII. This patch series enable the driver only for the H3/A64/H5 SoC since A83T doesn't have the necessary clocks present in mainline. The driver have been tested on the following boards: - H3 Orange PI PC, BananaPI-M2+ - A64 Pine64, BananaPi-M64 - A83T BananaPI-M3 The first two patchs are some mandatory changes for letting dwmac-sun8i be used. The following three patchs add the driver and its documentation. The remaining are DT patch enabling it. Regards Corentin Labbe Changes since v4: - Re-ordered by alphabetical order some DT nodes - Fixed arm64 patch prefix - Simplified power/unpower_phy functions by testing the use of internal_phy - Added a patch for adding dwmac-sun8i to arm64 defconfig - Fix a typo in sun50i-a64-system-controller (wrongly used sun8i) - Reworked uc/mc filter address setting Changes since v3: - Renamed tx-delay/rx-delay to tx-delay-ps/rx-delay-ps - fix syscon compatible example - Changed parameter type for setup() function - Dropped some DT patchs for boards which I could not test further Changes since v2: - corrected order of syscon compatible - added compatible = "ethernet-phy-ieee802.3-c22 to PHY - added set_mac function Changes since v1: - added TX/RX delay units - splitted syscon documentation in its own patch - regulator is now disabled after clk_prepare_enable(gmac->tx_clk) error - Fixed a memory leak on mac_device_info - Use now generic pin config for all DT stuff - CONFIG_DWMAC_SUN8I is now set to y in defconfigs Corentin Labbe (20): net: stmmac: export stmmac_set_mac_addr/stmmac_get_mac_addr net: stmmac: add optional setup function dt-bindings: net: Add DT bindings documentation for Allwinner dwmac-sun8i dt-bindings: syscon: Add DT bindings documentation for Allwinner syscon net: stmmac: Add dwmac-sun8i arm: sun8i: sunxi-h3-h5: Add dt node for the syscon control module arm: sun8i: sunxi-h3-h5: add dwmac-sun8i ethernet driver arm: sun8i: orangepi-pc: Enable dwmac-sun8i arm: sun8i: orangepi-zero: Enable dwmac-sun8i arm: sun8i: orangepi-one: Enable dwmac-sun8i arm: sun8i: orangepi-2: Enable dwmac-sun8i arm: sun8i: orangepi-pc-plus: Set EMAC activity LEDs to active high arm64: allwinner: sun50i-a64: Add dt node for the syscon control module arm64: allwinner: sun50i-a64: add dwmac-sun8i Ethernet driver arm64: allwinner: pine64: Enable dwmac-sun8i arm64: allwinner: pine64-plus: Enable dwmac-sun8i arm64: allwinner: bananapi-m64: Enable dwmac-sun8i arm: sunxi: Enable dwmac-sun8i driver on sunxi_defconfig arm: multi_v7: Enable dwmac-sun8i driver on multi_v7_defconfig arm64: defconfig: Enable dwmac-sun8i driver on defconfig .../devicetree/bindings/misc/allwinner,syscon.txt | 19 + .../devicetree/bindings/net/dwmac-sun8i.txt | 77 ++ arch/arm/boot/dts/sun8i-h2-plus-orangepi-zero.dts | 8 + arch/arm/boot/dts/sun8i-h3-orangepi-2.dts | 8 + arch/arm/boot/dts/sun8i-h3-orangepi-one.dts | 8 + arch/arm/boot/dts/sun8i-h3-orangepi-pc-plus.dts | 5 + arch/arm/boot/dts/sun8i-h3-orangepi-pc.dts | 8 + arch/arm/boot/dts/sunxi-h3-h5.dtsi | 40 + arch/arm/configs/multi_v7_defconfig | 1 + arch/arm/configs/sunxi_defconfig | 1 + .../boot/dts/allwinner/sun50i-a64-bananapi-m64.dts | 15 + .../boot/dts/allwinner/sun50i-a64-pine64-plus.dts | 17 +- .../arm64/boot/dts/allwinner/sun50i-a64-pine64.dts | 16 + arch/arm64/boot/dts/allwinner/sun50i-a64.dtsi | 41 + arch/arm64/configs/defconfig | 1 + drivers/net/ethernet/stmicro/stmmac/Kconfig | 11 + drivers/net/ethernet/stmicro/stmmac/Makefile | 1 + drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c | 973 +++++++++++++++++++++ drivers/net/ethernet/stmicro/stmmac/dwmac_lib.c | 3 +- drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 33 +- .../net/ethernet/stmicro/stmmac/stmmac_platform.c | 9 +- include/linux/stmmac.h | 2 + 22 files changed, 1292 insertions(+), 5 deletions(-) create mode 100644 Documentation/devicetree/bindings/misc/allwinner,syscon.txt create mode 100644 Documentation/devicetree/bindings/net/dwmac-sun8i.txt create mode 100644 drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c -- 2.10.2
next reply other threads:[~2017-05-01 12:48 UTC|newest] Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top 2017-05-01 12:45 Corentin Labbe [this message] 2017-05-01 12:45 ` [PATCH v5 01/20] net: stmmac: export stmmac_set_mac_addr/stmmac_get_mac_addr Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 02/20] net: stmmac: add optional setup function Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 03/20] dt-bindings: net: Add DT bindings documentation for Allwinner dwmac-sun8i Corentin Labbe 2017-05-01 13:45 ` Andrew Lunn 2017-05-01 12:45 ` [PATCH v5 04/20] dt-bindings: syscon: Add DT bindings documentation for Allwinner syscon Corentin Labbe 2017-05-05 20:20 ` Rob Herring 2017-05-01 12:45 ` [PATCH v5 05/20] net: stmmac: Add dwmac-sun8i Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 06/20] arm: sun8i: sunxi-h3-h5: Add dt node for the syscon control module Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 07/20] arm: sun8i: sunxi-h3-h5: add dwmac-sun8i ethernet driver Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 08/20] arm: sun8i: orangepi-pc: Enable dwmac-sun8i Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 09/20] arm: sun8i: orangepi-zero: " Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 10/20] arm: sun8i: orangepi-one: " Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 11/20] arm: sun8i: orangepi-2: " Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 12/20] arm: sun8i: orangepi-pc-plus: Set EMAC activity LEDs to active high Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 13/20] arm64: allwinner: sun50i-a64: Add dt node for the syscon control module Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 14/20] arm64: allwinner: sun50i-a64: add dwmac-sun8i Ethernet driver Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 15/20] arm64: allwinner: pine64: Enable dwmac-sun8i Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 16/20] arm64: allwinner: pine64-plus: " Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 17/20] arm64: allwinner: bananapi-m64: " Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 18/20] arm: sunxi: Enable dwmac-sun8i driver on sunxi_defconfig Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 19/20] arm: multi_v7: Enable dwmac-sun8i driver on multi_v7_defconfig Corentin Labbe 2017-05-01 12:45 ` [PATCH v5 20/20] arm64: defconfig: Enable dwmac-sun8i driver on defconfig Corentin Labbe 2017-05-01 14:01 ` [PATCH v5 00/20] net-next: stmmac: add dwmac-sun8i ethernet driver Andrew Lunn 2017-05-01 14:28 ` Chen-Yu Tsai 2017-05-01 14:45 ` Andrew Lunn 2017-05-01 15:58 ` Corentin Labbe 2017-05-01 16:10 ` Andrew Lunn 2017-05-05 12:13 ` Corentin Labbe
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20170501124520.3769-1-clabbe.montjoie@gmail.com \ --to=clabbe.montjoie@gmail.com \ --cc=alexandre.torgue@st.com \ --cc=catalin.marinas@arm.com \ --cc=devicetree@vger.kernel.org \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux@armlinux.org.uk \ --cc=mark.rutland@arm.com \ --cc=maxime.ripard@free-electrons.com \ --cc=netdev@vger.kernel.org \ --cc=peppe.cavallaro@st.com \ --cc=robh+dt@kernel.org \ --cc=wens@csie.org \ --cc=will.deacon@arm.com \ --subject='Re: [PATCH v5 00/20] net-next: stmmac: add dwmac-sun8i ethernet driver' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).