All of lore.kernel.org
 help / color / mirror / Atom feed
From: Claudiu <claudiu.beznea@tuxon.dev>
To: s.shtylyov@omp.ru, davem@davemloft.net, edumazet@google.com,
	kuba@kernel.org, pabeni@redhat.com, richardcochran@gmail.com,
	p.zabel@pengutronix.de, yoshihiro.shimoda.uh@renesas.com,
	wsa+renesas@sang-engineering.com
Cc: netdev@vger.kernel.org, linux-renesas-soc@vger.kernel.org,
	linux-kernel@vger.kernel.org, claudiu.beznea@tuxon.dev,
	geert+renesas@glider.be,
	Claudiu Beznea <claudiu.beznea.uj@bp.renesas.com>
Subject: [PATCH net-next v3 00/19] net: ravb: Add suspend to RAM and runtime PM support for RZ/G3S
Date: Fri,  5 Jan 2024 10:23:20 +0200	[thread overview]
Message-ID: <20240105082339.1468817-1-claudiu.beznea.uj@bp.renesas.com> (raw)

From: Claudiu Beznea <claudiu.beznea.uj@bp.renesas.com>

Hi,

This series adds suspend to RAM and runtime PM support for Ethernet
IP available on the RZ/G3S (R9A08G045) SoC.

As there are IP versions that switch to module standby when disabling
the clocks, and because of module standby IP switches to reset and
the register content is lost, to be able to have runtime PM supported
for all IP variants, the configuration operations were moved all to
ravb_open()/ravb_close() letting the ravb_probe() and ravb_remove()
to deal with resource parsing and allocation/free.

The ethtool and IOCTL APIs that could have been run asyncronously
were adapted to return if the interface is down. As explained in
each individual commits description, this should be harmless.

Along with it, the series contains preparatory cleanups.

The series has been tested on the boards with the following device trees:
- r8a7742-iwg21d-q7.dts
- r8a774a1-hihope-rzg2m-ex.dts 
- r9a07g043u11-smarc-rzg2ul.dts
- r9a07g054l2-smarc-rzv2l.dts
- r9a07g044l2-smarc-rzg2l.dts

Thank you,
Claudiu Beznea

Changes in v3:
- collected tags
- addressed review comments
- squashed patch 17/21 ("net: ravb: Keep clock request operations grouped
  together") from v2 in patch 07/19 ("net: ravb: Move reference clock
  enable/disable on runtime PM APIs") from v3
- check for ndev->flags & IFF_UP in patch 17/19 and 18/19 instead of
  checking netif_running()
- dropped patch 19/21 ("net: ravb: Do not set promiscuous mode if the
  interface is down") as the changes there are not necessary as
  ndev->flags & IFF_UP is already checked at the beginning of
  __dev_set_rx_mode()
- remove code from ravb_open() introduced by patch 20/21
  ("net: ravb: Do not apply RX CSUM settings to hardware if the interface
  is down") from v2 as this is not necessary; driver already takes
  care of this in ravb_emac_init_rcar()

Changes in v2:
- rework the driver (mainly, ravb_open() contains now only resource
  allocation and parsing leaving the settings to ravb_open(); ravb_remove()
  has been adapted accordingly) to be able to use runtime PM for all
  IP variants; due to this number of patches increased
- adjust previous series to review comments
- collected tags
- populated driver's own runtime PM ops with enable/disable of reference
  clock

Claudiu Beznea (19):
  net: ravb: Let IP-specific receive function to interrogate descriptors
  net: ravb: Rely on PM domain to enable gptp_clk
  net: ravb: Make reset controller support mandatory
  net: ravb: Switch to SYSTEM_SLEEP_PM_OPS()/RUNTIME_PM_OPS() and
    pm_ptr()
  net: ravb: Use tabs instead of spaces
  net: ravb: Assert/de-assert reset on suspend/resume
  net: ravb: Move reference clock enable/disable on runtime PM APIs
  net: ravb: Move the IRQs get and request in the probe function
  net: ravb: Split GTI computation and set operations
  net: ravb: Move delay mode set in the driver's ndo_open API
  net: ravb: Move DBAT configuration to the driver's ndo_open API
  net: ravb: Move PTP initialization in the driver's ndo_open API for
    ccc_gac platorms
  net: ravb: Set config mode in ndo_open and reset mode in ndo_close
  net: ravb: Simplify ravb_suspend()
  net: ravb: Simplify ravb_resume()
  net: ravb: Keep the reverse order of operations in ravb_close()
  net: ravb: Return cached statistics if the interface is down
  net: ravb: Do not apply RX CSUM settings to hardware if the interface
    is down
  net: ravb: Add runtime PM support

 drivers/net/ethernet/renesas/ravb.h      |   6 +-
 drivers/net/ethernet/renesas/ravb_main.c | 760 +++++++++++------------
 2 files changed, 370 insertions(+), 396 deletions(-)

-- 
2.39.2


             reply	other threads:[~2024-01-05  8:24 UTC|newest]

Thread overview: 48+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-01-05  8:23 Claudiu [this message]
2024-01-05  8:23 ` [PATCH net-next v3 01/19] net: ravb: Let IP-specific receive function to interrogate descriptors Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 02/19] net: ravb: Rely on PM domain to enable gptp_clk Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 03/19] net: ravb: Make reset controller support mandatory Claudiu
2024-01-05  9:38   ` Geert Uytterhoeven
2024-01-08  7:05     ` claudiu beznea
2024-01-05  8:23 ` [PATCH net-next v3 04/19] net: ravb: Switch to SYSTEM_SLEEP_PM_OPS()/RUNTIME_PM_OPS() and pm_ptr() Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 05/19] net: ravb: Use tabs instead of spaces Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 06/19] net: ravb: Assert/de-assert reset on suspend/resume Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 07/19] net: ravb: Move reference clock enable/disable on runtime PM APIs Claudiu
2024-01-05 19:52   ` Sergey Shtylyov
2024-01-08  8:03     ` claudiu beznea
2024-01-23 20:06       ` Sergey Shtylyov
2024-01-05  8:23 ` [PATCH net-next v3 08/19] net: ravb: Move the IRQs get and request in the probe function Claudiu
2024-01-05 20:57   ` Sergey Shtylyov
2024-01-08  8:23     ` claudiu beznea
2024-01-07 18:24   ` Sergey Shtylyov
2024-01-08  8:58     ` claudiu beznea
2024-01-09 20:47       ` Sergey Shtylyov
2024-01-10 11:55         ` claudiu beznea
2024-01-14 18:07           ` Sergey Shtylyov
2024-01-15  7:10             ` claudiu beznea
2024-01-05  8:23 ` [PATCH net-next v3 09/19] net: ravb: Split GTI computation and set operations Claudiu
2024-01-06 19:58   ` Sergey Shtylyov
2024-01-05  8:23 ` [PATCH net-next v3 10/19] net: ravb: Move delay mode set in the driver's ndo_open API Claudiu
2024-01-06 20:26   ` Sergey Shtylyov
2024-01-05  8:23 ` [PATCH net-next v3 11/19] net: ravb: Move DBAT configuration to " Claudiu
2024-01-06 20:34   ` Sergey Shtylyov
2024-01-05  8:23 ` [PATCH net-next v3 12/19] net: ravb: Move PTP initialization in the driver's ndo_open API for ccc_gac platorms Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 13/19] net: ravb: Set config mode in ndo_open and reset mode in ndo_close Claudiu
2024-01-08 19:28   ` Sergey Shtylyov
2024-01-09  5:42     ` claudiu beznea
2024-01-05  8:23 ` [PATCH net-next v3 14/19] net: ravb: Simplify ravb_suspend() Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 15/19] net: ravb: Simplify ravb_resume() Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 16/19] net: ravb: Keep the reverse order of operations in ravb_close() Claudiu
2024-01-05  8:23 ` [PATCH net-next v3 17/19] net: ravb: Return cached statistics if the interface is down Claudiu
2024-01-08 20:22   ` Sergey Shtylyov
2024-01-10 13:17     ` claudiu beznea
2024-01-14 12:22       ` Sergey Shtylyov
2024-01-15  6:08         ` claudiu beznea
2024-01-05  8:23 ` [PATCH net-next v3 18/19] net: ravb: Do not apply RX CSUM settings to hardware " Claudiu
2024-01-08 20:34   ` Sergey Shtylyov
2024-01-08 20:36     ` Sergey Shtylyov
2024-01-08 20:49   ` Sergey Shtylyov
2024-01-05  8:23 ` [PATCH net-next v3 19/19] net: ravb: Add runtime PM support Claudiu
2024-01-09 19:53   ` Sergey Shtylyov
2024-01-10 13:23     ` claudiu beznea
2024-01-05  9:58 ` [PATCH net-next v3 00/19] net: ravb: Add suspend to RAM and runtime PM support for RZ/G3S Jiri Pirko

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=20240105082339.1468817-1-claudiu.beznea.uj@bp.renesas.com \
    --to=claudiu.beznea@tuxon.dev \
    --cc=claudiu.beznea.uj@bp.renesas.com \
    --cc=davem@davemloft.net \
    --cc=edumazet@google.com \
    --cc=geert+renesas@glider.be \
    --cc=kuba@kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-renesas-soc@vger.kernel.org \
    --cc=netdev@vger.kernel.org \
    --cc=p.zabel@pengutronix.de \
    --cc=pabeni@redhat.com \
    --cc=richardcochran@gmail.com \
    --cc=s.shtylyov@omp.ru \
    --cc=wsa+renesas@sang-engineering.com \
    --cc=yoshihiro.shimoda.uh@renesas.com \
    /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
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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.