* [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access
@ 2017-08-10 7:47 Max Uvarov
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
` (3 more replies)
0 siblings, 4 replies; 7+ messages in thread
From: Max Uvarov @ 2017-08-10 7:47 UTC (permalink / raw)
To: netdev; +Cc: linux-omap, grygorii.strashko, Max Uvarov
Polling 14 mdio devices on single mdio bus eats 30% of 1Ghz cpu time
due to busy loop in wait(). Add small delay to relax cpu.
Signed-off-by: Max Uvarov <muvarov@gmail.com>
---
v2: fix spelling in commit description.
drivers/net/ethernet/ti/davinci_mdio.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/net/ethernet/ti/davinci_mdio.c b/drivers/net/ethernet/ti/davinci_mdio.c
index 33df340..611e7cc 100644
--- a/drivers/net/ethernet/ti/davinci_mdio.c
+++ b/drivers/net/ethernet/ti/davinci_mdio.c
@@ -198,8 +198,10 @@ static inline int wait_for_user_access(struct davinci_mdio_data *data)
return 0;
reg = __raw_readl(®s->control);
- if ((reg & CONTROL_IDLE) == 0)
+ if ((reg & CONTROL_IDLE) == 0) {
+ usleep_range(100, 200);
continue;
+ }
/*
* An emac soft_reset may have clobbered the mdio controller's
--
2.5.0
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency
2017-08-10 7:47 [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Max Uvarov
@ 2017-08-10 7:47 ` Max Uvarov
2017-08-10 16:18 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
2017-08-10 14:40 ` [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Andrew Lunn
` (2 subsequent siblings)
3 siblings, 2 replies; 7+ messages in thread
From: Max Uvarov @ 2017-08-10 7:47 UTC (permalink / raw)
To: netdev; +Cc: linux-omap, grygorii.strashko, Max Uvarov
Frequency can be adjusted in DT it make sense to
print current used value on driver init.
Signed-off-by: Max Uvarov <muvarov@gmail.com>
---
drivers/net/ethernet/ti/davinci_mdio.c | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/drivers/net/ethernet/ti/davinci_mdio.c b/drivers/net/ethernet/ti/davinci_mdio.c
index 611e7cc..3c33f45 100644
--- a/drivers/net/ethernet/ti/davinci_mdio.c
+++ b/drivers/net/ethernet/ti/davinci_mdio.c
@@ -159,8 +159,10 @@ static int davinci_mdio_reset(struct mii_bus *bus)
/* dump hardware version info */
ver = __raw_readl(&data->regs->version);
- dev_info(data->dev, "davinci mdio revision %d.%d\n",
- (ver >> 8) & 0xff, ver & 0xff);
+ dev_info(data->dev,
+ "davinci mdio revision %d.%d, bus freq %ld\n",
+ (ver >> 8) & 0xff, ver & 0xff,
+ data->pdata.bus_freq);
if (data->skip_scan)
goto done;
--
2.5.0
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access
2017-08-10 7:47 [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Max Uvarov
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
@ 2017-08-10 14:40 ` Andrew Lunn
2017-08-10 16:24 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
3 siblings, 0 replies; 7+ messages in thread
From: Andrew Lunn @ 2017-08-10 14:40 UTC (permalink / raw)
To: Max Uvarov; +Cc: netdev, linux-omap, grygorii.strashko
On Thu, Aug 10, 2017 at 10:47:46AM +0300, Max Uvarov wrote:
> Polling 14 mdio devices on single mdio bus eats 30% of 1Ghz cpu time
> due to busy loop in wait(). Add small delay to relax cpu.
Hi Max
Please include a cover note when you have multiple patches in a
series.
With 14 devices, it makes sense to swap to using PHY interrupts if you
can. That should prevent the PHY state machine polling the PHYs every
second.
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Andrew
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
@ 2017-08-10 16:18 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
1 sibling, 0 replies; 7+ messages in thread
From: Grygorii Strashko @ 2017-08-10 16:18 UTC (permalink / raw)
To: Max Uvarov, netdev; +Cc: linux-omap
On 08/10/2017 02:47 AM, Max Uvarov wrote:
> Frequency can be adjusted in DT it make sense to
> print current used value on driver init.
>
> Signed-off-by: Max Uvarov <muvarov@gmail.com>
Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>
> ---
> drivers/net/ethernet/ti/davinci_mdio.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/net/ethernet/ti/davinci_mdio.c b/drivers/net/ethernet/ti/davinci_mdio.c
> index 611e7cc..3c33f45 100644
> --- a/drivers/net/ethernet/ti/davinci_mdio.c
> +++ b/drivers/net/ethernet/ti/davinci_mdio.c
> @@ -159,8 +159,10 @@ static int davinci_mdio_reset(struct mii_bus *bus)
>
> /* dump hardware version info */
> ver = __raw_readl(&data->regs->version);
> - dev_info(data->dev, "davinci mdio revision %d.%d\n",
> - (ver >> 8) & 0xff, ver & 0xff);
> + dev_info(data->dev,
> + "davinci mdio revision %d.%d, bus freq %ld\n",
> + (ver >> 8) & 0xff, ver & 0xff,
> + data->pdata.bus_freq);
>
> if (data->skip_scan)
> goto done;
>
--
regards,
-grygorii
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access
2017-08-10 7:47 [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Max Uvarov
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
2017-08-10 14:40 ` [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Andrew Lunn
@ 2017-08-10 16:24 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
3 siblings, 0 replies; 7+ messages in thread
From: Grygorii Strashko @ 2017-08-10 16:24 UTC (permalink / raw)
To: Max Uvarov, netdev; +Cc: linux-omap
On 08/10/2017 02:47 AM, Max Uvarov wrote:
> Polling 14 mdio devices on single mdio bus eats 30% of 1Ghz cpu time
> due to busy loop in wait(). Add small delay to relax cpu.
>
> Signed-off-by: Max Uvarov <muvarov@gmail.com>
yep. cover letter is good to have.
Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>
> ---
> v2: fix spelling in commit description.
>
> drivers/net/ethernet/ti/davinci_mdio.c | 4 +++-
> 1 file changed, 3 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/net/ethernet/ti/davinci_mdio.c b/drivers/net/ethernet/ti/davinci_mdio.c
> index 33df340..611e7cc 100644
> --- a/drivers/net/ethernet/ti/davinci_mdio.c
> +++ b/drivers/net/ethernet/ti/davinci_mdio.c
> @@ -198,8 +198,10 @@ static inline int wait_for_user_access(struct davinci_mdio_data *data)
> return 0;
>
> reg = __raw_readl(®s->control);
> - if ((reg & CONTROL_IDLE) == 0)
> + if ((reg & CONTROL_IDLE) == 0) {
> + usleep_range(100, 200);
> continue;
> + }
>
> /*
> * An emac soft_reset may have clobbered the mdio controller's
>
--
regards,
-grygorii
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access
2017-08-10 7:47 [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Max Uvarov
` (2 preceding siblings ...)
2017-08-10 16:24 ` Grygorii Strashko
@ 2017-08-11 21:24 ` David Miller
3 siblings, 0 replies; 7+ messages in thread
From: David Miller @ 2017-08-11 21:24 UTC (permalink / raw)
To: muvarov; +Cc: netdev, linux-omap, grygorii.strashko
From: Max Uvarov <muvarov@gmail.com>
Date: Thu, 10 Aug 2017 10:47:46 +0300
> Polling 14 mdio devices on single mdio bus eats 30% of 1Ghz cpu time
> due to busy loop in wait(). Add small delay to relax cpu.
>
> Signed-off-by: Max Uvarov <muvarov@gmail.com>
Applied to net-next.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
2017-08-10 16:18 ` Grygorii Strashko
@ 2017-08-11 21:24 ` David Miller
1 sibling, 0 replies; 7+ messages in thread
From: David Miller @ 2017-08-11 21:24 UTC (permalink / raw)
To: muvarov; +Cc: netdev, linux-omap, grygorii.strashko
From: Max Uvarov <muvarov@gmail.com>
Date: Thu, 10 Aug 2017 10:47:47 +0300
> Frequency can be adjusted in DT it make sense to
> print current used value on driver init.
>
> Signed-off-by: Max Uvarov <muvarov@gmail.com>
Applied to net-next.
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2017-08-11 21:24 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-08-10 7:47 [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Max Uvarov
2017-08-10 7:47 ` [PATCHv2 2/2] drivers: net: davinci_mdio: print bus frequency Max Uvarov
2017-08-10 16:18 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
2017-08-10 14:40 ` [PATCHv2 1/2] drivers: net: davinci_mdio: remove busy loop on wait user access Andrew Lunn
2017-08-10 16:24 ` Grygorii Strashko
2017-08-11 21:24 ` David Miller
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).