All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v6 00/21] net-next: stmmac: add dwmac-sun8i ethernet driver
@ 2017-05-31  7:18 ` Corentin Labbe
  0 siblings, 0 replies; 148+ messages in thread
From: Corentin Labbe @ 2017-05-31  7:18 UTC (permalink / raw)
  To: robh+dt, mark.rutland, maxime.ripard, wens, linux,
	catalin.marinas, will.deacon, peppe.cavallaro, alexandre.torgue
  Cc: devicetree, linux-kernel, netdev, linux-arm-kernel, linux-sunxi,
	Corentin Labbe

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 v5:
- Added DT patch for NanoPi neo
- Use the new adjust_link variables (speedxxx/speedmask)
- Made the timeout of readl_poll_timeout from 10 to 100ms
- Fix sun8i_unpower_phy that could be called twice
- Replace phy by phy-handle in doc/dwmac-sun8i.txt

Changes since v4:
- Re-ordered by alphabetical order some DT nodes
- 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 (21):
  net-next: stmmac: export stmmac_set_mac_addr/stmmac_get_mac_addr
  net-next: stmmac: add optional setup function
  dt-bindings: net-next: Add DT bindings documentation for Allwinner
    dwmac-sun8i
  dt-bindings: syscon: Add DT bindings documentation for Allwinner
    syscon
  net-next: 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
  arm: sun8i: nanopi-neo: Enable dwmac-sun8i
  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        |  78 ++
 arch/arm/boot/dts/sun8i-h2-plus-orangepi-zero.dts  |   8 +
 arch/arm/boot/dts/sun8i-h3-nanopi-neo.dts          |   7 +
 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  | 990 +++++++++++++++++++++
 drivers/net/ethernet/stmicro/stmmac/dwmac_lib.c    |   3 +-
 drivers/net/ethernet/stmicro/stmmac/stmmac_main.c  |  19 +-
 .../net/ethernet/stmicro/stmmac/stmmac_platform.c  |   9 +-
 include/linux/stmmac.h                             |   2 +
 23 files changed, 1303 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.13.0

^ permalink raw reply	[flat|nested] 148+ messages in thread

end of thread, other threads:[~2017-07-02  8:36 UTC | newest]

Thread overview: 148+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-05-31  7:18 [PATCH v6 00/21] net-next: stmmac: add dwmac-sun8i ethernet driver Corentin Labbe
2017-05-31  7:18 ` Corentin Labbe
2017-05-31  7:18 ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 01/21] net-next: stmmac: export stmmac_set_mac_addr/stmmac_get_mac_addr Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 02/21] net-next: stmmac: add optional setup function Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 03/21] dt-bindings: net-next: Add DT bindings documentation for Allwinner dwmac-sun8i Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 04/21] dt-bindings: syscon: Add DT bindings documentation for Allwinner syscon Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 05/21] net-next: stmmac: Add dwmac-sun8i Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-06-26  0:18   ` André Przywara
2017-06-26  0:18     ` André Przywara
2017-06-26  0:18     ` André Przywara
2017-06-27  8:05     ` Corentin Labbe
2017-06-27  8:05       ` Corentin Labbe
2017-06-27  8:05       ` Corentin Labbe
2017-06-27  8:11       ` Chen-Yu Tsai
2017-06-27  8:11         ` Chen-Yu Tsai
2017-06-27  8:11         ` Chen-Yu Tsai
2017-06-27  8:21         ` Corentin Labbe
2017-06-27  8:21           ` Corentin Labbe
2017-06-27  8:21           ` Corentin Labbe
2017-06-27  9:02           ` Andre Przywara
2017-06-27  9:02             ` Andre Przywara
2017-06-27  9:02             ` Andre Przywara
2017-06-27  9:41             ` Maxime Ripard
2017-06-27  9:41               ` Maxime Ripard
2017-06-27  9:41               ` Maxime Ripard
2017-06-27 10:11               ` Chen-Yu Tsai
2017-06-27 10:11                 ` Chen-Yu Tsai
2017-06-27 10:11                 ` Chen-Yu Tsai
2017-06-27 10:17                 ` [linux-sunxi] " Icenowy Zheng
2017-06-27 10:17                   ` Icenowy Zheng
2017-06-27 10:17                   ` Icenowy Zheng
2017-06-27 10:20                   ` Chen-Yu Tsai
2017-06-27 10:20                     ` Chen-Yu Tsai
2017-06-27 10:20                     ` Chen-Yu Tsai
2017-06-27 10:15               ` Andre Przywara
2017-06-27 10:15                 ` Andre Przywara
2017-06-27 10:22                 ` Chen-Yu Tsai
2017-06-27 10:22                   ` Chen-Yu Tsai
2017-06-27 10:22                   ` Chen-Yu Tsai
2017-06-27 10:23                 ` Icenowy Zheng
2017-06-27 10:23                   ` Icenowy Zheng
2017-06-27 10:23                   ` Icenowy Zheng
2017-06-27 10:33                   ` Andre Przywara
2017-06-27 10:33                     ` Andre Przywara
2017-06-27 12:37                     ` Corentin Labbe
2017-06-27 12:37                       ` Corentin Labbe
2017-06-27 12:37                       ` Corentin Labbe
2017-06-27 17:29                       ` Maxime Ripard
2017-06-27 17:29                         ` Maxime Ripard
2017-06-27 17:29                         ` Maxime Ripard
2017-06-27 17:37                         ` Corentin Labbe
2017-06-27 17:37                           ` Corentin Labbe
2017-06-27 17:37                           ` Corentin Labbe
2017-06-27 17:37                         ` Florian Fainelli
2017-06-27 17:37                           ` Florian Fainelli
2017-06-27 17:37                           ` Florian Fainelli
2017-07-01  6:53                           ` Corentin Labbe
2017-07-01  6:53                             ` Corentin Labbe
2017-07-01  6:53                             ` Corentin Labbe
2017-07-01 21:42                             ` Florian Fainelli
2017-07-01 21:42                               ` Florian Fainelli
2017-07-01 21:42                               ` Florian Fainelli
2017-07-02  8:36                               ` Corentin Labbe
2017-07-02  8:36                                 ` Corentin Labbe
2017-07-02  8:36                                 ` Corentin Labbe
2017-06-27 16:00                     ` Maxime Ripard
2017-06-27 16:00                       ` Maxime Ripard
2017-06-27 16:00                       ` Maxime Ripard
2017-05-31  7:18 ` [PATCH v6 06/21] arm: sun8i: sunxi-h3-h5: Add dt node for the syscon control module Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 07/21] arm: sun8i: sunxi-h3-h5: add dwmac-sun8i ethernet driver Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 08/21] arm: sun8i: orangepi-pc: Enable dwmac-sun8i Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 09/21] arm: sun8i: orangepi-zero: " Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 10/21] arm: sun8i: orangepi-one: " Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 11/21] arm: sun8i: orangepi-2: " Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 12/21] arm: sun8i: orangepi-pc-plus: Set EMAC activity LEDs to active high Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 13/21] arm: sun8i: nanopi-neo: Enable dwmac-sun8i Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 14/21] arm64: allwinner: sun50i-a64: Add dt node for the syscon control module Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 15/21] arm64: allwinner: sun50i-a64: add dwmac-sun8i Ethernet driver Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 16/21] arm64: allwinner: pine64: Enable dwmac-sun8i Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 17/21] arm64: allwinner: pine64-plus: " Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 18/21] arm64: allwinner: bananapi-m64: " Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 19/21] arm: sunxi: Enable dwmac-sun8i driver on sunxi_defconfig Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 20/21] arm: multi_v7: Enable dwmac-sun8i driver on multi_v7_defconfig Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18 ` [PATCH v6 21/21] arm64: defconfig: Enable dwmac-sun8i driver on defconfig Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-05-31  7:18   ` Corentin Labbe
2017-06-01 18:58 ` [PATCH v6 00/21] net-next: stmmac: add dwmac-sun8i ethernet driver David Miller
2017-06-01 18:58   ` David Miller
2017-06-01 18:58   ` David Miller
2017-06-02  6:37   ` Maxime Ripard
2017-06-02  6:37     ` Maxime Ripard
2017-06-02  6:37     ` Maxime Ripard
2017-06-02  9:13     ` Maxime Ripard
2017-06-02  9:13       ` Maxime Ripard
2017-06-02  9:13       ` Maxime Ripard
2017-06-02 14:22       ` David Miller
2017-06-02 14:22         ` David Miller
2017-06-02 14:22         ` David Miller
2017-06-02 22:24         ` Maxime Ripard
2017-06-02 22:24           ` Maxime Ripard
2017-06-02 22:24           ` Maxime Ripard
2017-06-09 12:50           ` Maxime Ripard
2017-06-09 12:50             ` Maxime Ripard
2017-06-09 12:50             ` Maxime Ripard
2017-06-02 14:08     ` David Miller
2017-06-02 14:08       ` David Miller
2017-06-02 14:08       ` David Miller

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.