* [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set
@ 2008-09-22 21:52 akpm
2008-09-23 23:45 ` Stephen Hemminger
2008-09-23 23:47 ` Stephen Hemminger
0 siblings, 2 replies; 4+ messages in thread
From: akpm @ 2008-09-22 21:52 UTC (permalink / raw)
To: jeff; +Cc: netdev, akpm, Xiaoming.Zhang, shemminger, xiaoming.zhang
From: "Xiaoming.Zhang" <Xiaoming.Zhang@resilience.com>
We have an issue of the skge driver: The card won't work when it's options
are changed. Here's the hardware info:
# lspci -v
05:04.0 Ethernet controller: Marvell Technology Group Ltd. 88E8001 Gigabit Ethernet Controller (rev 13)
Subsystem: Marvell Technology Group Ltd. Marvell RDK-8001
Flags: bus master, 66MHz, medium devsel, latency 32, IRQ 16
Memory at d042c000 (32-bit, non-prefetchable) [size=16K]
I/O ports at d000 [size=256]
[virtual] Expansion ROM at 20400000 [disabled] [size=128K]
Capabilities: [48] Power Management version 2
Capabilities: [50] Vital Product Data
The happens in both Linux-2.6.26(skge version 1.23) and RHEL5.2(skge
version 1.6).
For example, at first it is set to "speed 1000 duplex full auto-neg on" and
it works, then run
ethtool -s <ethx> autoneg off
or ethtool -s <ethx> speed 100 duplex full autoneg off
Then it will stop working. After that if we restart the interface:
ifconifg <ethx> down
ifconfig <ethx> up
It will work again. And `ethtool -A' has the same issue.
So we think after setting the options, the interface should be restarted.
Signed-off-by: Zhang Xiaoming <xiaoming.zhang@resilience.com>
Cc: Stephen Hemminger <shemminger@vyatta.com>
Cc: Jeff Garzik <jeff@garzik.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
---
drivers/net/skge.c | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff -puN drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-options-or-pauseparam-is-set drivers/net/skge.c
--- a/drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-options-or-pauseparam-is-set
+++ a/drivers/net/skge.c
@@ -353,8 +353,10 @@ static int skge_set_settings(struct net_
skge->autoneg = ecmd->autoneg;
skge->advertising = ecmd->advertising;
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ skge_up(dev);
+ }
return (0);
}
@@ -595,8 +597,10 @@ static int skge_set_pauseparam(struct ne
skge->flow_control = FLOW_MODE_NONE;
}
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ skge_up(dev);
+ }
return 0;
}
_
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set
2008-09-22 21:52 [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set akpm
@ 2008-09-23 23:45 ` Stephen Hemminger
2008-09-23 23:47 ` Stephen Hemminger
1 sibling, 0 replies; 4+ messages in thread
From: Stephen Hemminger @ 2008-09-23 23:45 UTC (permalink / raw)
To: akpm; +Cc: jeff, netdev, akpm, Xiaoming.Zhang
On Mon, 22 Sep 2008 14:52:17 -0700
akpm@linux-foundation.org wrote:
> From: "Xiaoming.Zhang" <Xiaoming.Zhang@resilience.com>
>
> We have an issue of the skge driver: The card won't work when it's options
> are changed. Here's the hardware info:
>
> # lspci -v
> 05:04.0 Ethernet controller: Marvell Technology Group Ltd. 88E8001 Gigabit Ethernet Controller (rev 13)
> Subsystem: Marvell Technology Group Ltd. Marvell RDK-8001
> Flags: bus master, 66MHz, medium devsel, latency 32, IRQ 16
> Memory at d042c000 (32-bit, non-prefetchable) [size=16K]
> I/O ports at d000 [size=256]
> [virtual] Expansion ROM at 20400000 [disabled] [size=128K]
> Capabilities: [48] Power Management version 2
> Capabilities: [50] Vital Product Data
>
> The happens in both Linux-2.6.26(skge version 1.23) and RHEL5.2(skge
> version 1.6).
>
> For example, at first it is set to "speed 1000 duplex full auto-neg on" and
> it works, then run
>
> ethtool -s <ethx> autoneg off
> or ethtool -s <ethx> speed 100 duplex full autoneg off
>
> Then it will stop working. After that if we restart the interface:
>
> ifconifg <ethx> down
> ifconfig <ethx> up
>
> It will work again. And `ethtool -A' has the same issue.
>
> So we think after setting the options, the interface should be restarted.
>
> Signed-off-by: Zhang Xiaoming <xiaoming.zhang@resilience.com>
> Cc: Stephen Hemminger <shemminger@vyatta.com>
> Cc: Jeff Garzik <jeff@garzik.org>
> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Acked-by: Stephen Hemminger <shemminger@vyatta.com>
Looks correct, don't have time or hardware setup right now to verify further.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set
2008-09-22 21:52 [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set akpm
2008-09-23 23:45 ` Stephen Hemminger
@ 2008-09-23 23:47 ` Stephen Hemminger
2008-09-26 6:28 ` Xiaoming.Zhang
1 sibling, 1 reply; 4+ messages in thread
From: Stephen Hemminger @ 2008-09-23 23:47 UTC (permalink / raw)
To: akpm; +Cc: jeff, netdev, akpm, Xiaoming.Zhang
On Mon, 22 Sep 2008 14:52:17 -0700
akpm@linux-foundation.org wrote:
> From: "Xiaoming.Zhang" <Xiaoming.Zhang@resilience.com>
>
> We have an issue of the skge driver: The card won't work when it's options
> are changed. Here's the hardware info:
>
> # lspci -v
> 05:04.0 Ethernet controller: Marvell Technology Group Ltd. 88E8001 Gigabit Ethernet Controller (rev 13)
> Subsystem: Marvell Technology Group Ltd. Marvell RDK-8001
> Flags: bus master, 66MHz, medium devsel, latency 32, IRQ 16
> Memory at d042c000 (32-bit, non-prefetchable) [size=16K]
> I/O ports at d000 [size=256]
> [virtual] Expansion ROM at 20400000 [disabled] [size=128K]
> Capabilities: [48] Power Management version 2
> Capabilities: [50] Vital Product Data
>
> The happens in both Linux-2.6.26(skge version 1.23) and RHEL5.2(skge
> version 1.6).
>
> For example, at first it is set to "speed 1000 duplex full auto-neg on" and
> it works, then run
>
> ethtool -s <ethx> autoneg off
> or ethtool -s <ethx> speed 100 duplex full autoneg off
>
> Then it will stop working. After that if we restart the interface:
>
> ifconifg <ethx> down
> ifconfig <ethx> up
>
> It will work again. And `ethtool -A' has the same issue.
>
> So we think after setting the options, the interface should be restarted.
>
> Signed-off-by: Zhang Xiaoming <xiaoming.zhang@resilience.com>
> Cc: Stephen Hemminger <shemminger@vyatta.com>
> Cc: Jeff Garzik <jeff@garzik.org>
> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
> ---
>
> drivers/net/skge.c | 12 ++++++++----
> 1 file changed, 8 insertions(+), 4 deletions(-)
>
> diff -puN drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-options-or-pauseparam-is-set drivers/net/skge.c
> --- a/drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-options-or-pauseparam-is-set
> +++ a/drivers/net/skge.c
> @@ -353,8 +353,10 @@ static int skge_set_settings(struct net_
> skge->autoneg = ecmd->autoneg;
> skge->advertising = ecmd->advertising;
>
> - if (netif_running(dev))
> - skge_phy_reset(skge);
> + if (netif_running(dev)) {
> + skge_down(dev);
> + skge_up(dev);
> + }
>
> return (0);
> }
> @@ -595,8 +597,10 @@ static int skge_set_pauseparam(struct ne
> skge->flow_control = FLOW_MODE_NONE;
> }
>
> - if (netif_running(dev))
> - skge_phy_reset(skge);
> + if (netif_running(dev)) {
> + skge_down(dev);
> + skge_up(dev);
> + }
>
> return 0;
> }
Since skge_up can fail because of out of memory, this code needs to
check the return value. And then if it fails the "limbo state" needs
to be handled in skge_down.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set
2008-09-23 23:47 ` Stephen Hemminger
@ 2008-09-26 6:28 ` Xiaoming.Zhang
0 siblings, 0 replies; 4+ messages in thread
From: Xiaoming.Zhang @ 2008-09-26 6:28 UTC (permalink / raw)
To: Stephen Hemminger; +Cc: akpm, jeff, netdev
[-- Attachment #1: Type: text/plain, Size: 4221 bytes --]
On Wednesday 24 September 2008 07:47, Stephen Hemminger wrote:
> On Mon, 22 Sep 2008 14:52:17 -0700
>
> akpm@linux-foundation.org wrote:
> > From: "Xiaoming.Zhang" <Xiaoming.Zhang@resilience.com>
> >
> > We have an issue of the skge driver: The card won't work when it's
> > options are changed. Here's the hardware info:
> >
> > # lspci -v
> > 05:04.0 Ethernet controller: Marvell Technology Group Ltd. 88E8001
> > Gigabit Ethernet Controller (rev 13) Subsystem: Marvell Technology Group
> > Ltd. Marvell RDK-8001 Flags: bus master, 66MHz, medium devsel, latency
> > 32, IRQ 16 Memory at d042c000 (32-bit, non-prefetchable) [size=16K] I/O
> > ports at d000 [size=256]
> > [virtual] Expansion ROM at 20400000 [disabled] [size=128K]
> > Capabilities: [48] Power Management version 2
> > Capabilities: [50] Vital Product Data
> >
> > The happens in both Linux-2.6.26(skge version 1.23) and RHEL5.2(skge
> > version 1.6).
> >
> > For example, at first it is set to "speed 1000 duplex full auto-neg on"
> > and it works, then run
> >
> > ethtool -s <ethx> autoneg off
> > or ethtool -s <ethx> speed 100 duplex full autoneg off
> >
> > Then it will stop working. After that if we restart the interface:
> >
> > ifconifg <ethx> down
> > ifconfig <ethx> up
> >
> > It will work again. And `ethtool -A' has the same issue.
> >
> > So we think after setting the options, the interface should be restarted.
> >
> > Signed-off-by: Zhang Xiaoming <xiaoming.zhang@resilience.com>
> > Cc: Stephen Hemminger <shemminger@vyatta.com>
> > Cc: Jeff Garzik <jeff@garzik.org>
> > Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
> > ---
> >
> > drivers/net/skge.c | 12 ++++++++----
> > 1 file changed, 8 insertions(+), 4 deletions(-)
> >
> > diff -puN
> > drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-option
> >s-or-pauseparam-is-set drivers/net/skge.c ---
> > a/drivers/net/skge.c~driver-net-skgec-restart-the-interface-when-its-opti
> >ons-or-pauseparam-is-set +++ a/drivers/net/skge.c
> > @@ -353,8 +353,10 @@ static int skge_set_settings(struct net_
> > skge->autoneg = ecmd->autoneg;
> > skge->advertising = ecmd->advertising;
> >
> > - if (netif_running(dev))
> > - skge_phy_reset(skge);
> > + if (netif_running(dev)) {
> > + skge_down(dev);
> > + skge_up(dev);
> > + }
> >
> > return (0);
> > }
> > @@ -595,8 +597,10 @@ static int skge_set_pauseparam(struct ne
> > skge->flow_control = FLOW_MODE_NONE;
> > }
> >
> > - if (netif_running(dev))
> > - skge_phy_reset(skge);
> > + if (netif_running(dev)) {
> > + skge_down(dev);
> > + skge_up(dev);
> > + }
> >
> > return 0;
> > }
>
> Since skge_up can fail because of out of memory, this code needs to
> check the return value. And then if it fails the "limbo state" needs
> to be handled in skge_down.
How about like this? It is tested.
Thank you.
Signed-off-by: Zhang Xiaoming <xiaoming.zhang@resilience.com>
--- drivers/net/skge.c.orig 2008-09-26 05:36:07.000000000 +0800
+++ drivers/net/skge.c 2008-09-26 05:35:50.000000000 +0800
@@ -319,6 +319,7 @@ static int skge_set_settings(struct net_
struct skge_port *skge = netdev_priv(dev);
const struct skge_hw *hw = skge->hw;
u32 supported = skge_supported_modes(hw);
+ int err = 0;
if (ecmd->autoneg == AUTONEG_ENABLE) {
ecmd->advertising = supported;
@@ -367,8 +368,14 @@ static int skge_set_settings(struct net_
skge->autoneg = ecmd->autoneg;
skge->advertising = ecmd->advertising;
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ err = skge_up(dev);
+ if (err) {
+ dev_close(dev);
+ return err;
+ }
+ }
return (0);
}
@@ -593,6 +600,7 @@ static int skge_set_pauseparam(struct ne
{
struct skge_port *skge = netdev_priv(dev);
struct ethtool_pauseparam old;
+ int err = 0;
skge_get_pauseparam(dev, &old);
@@ -609,8 +617,14 @@ static int skge_set_pauseparam(struct ne
skge->flow_control = FLOW_MODE_NONE;
}
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ err = skge_up(dev);
+ if (err) {
+ dev_close(dev);
+ return err;
+ }
+ }
return 0;
}
--
Have fun,
Xiaoming (Mark) Zhang
[-- Attachment #2: skge.patch --]
[-- Type: text/x-diff, Size: 1242 bytes --]
--- drivers/net/skge.c.orig 2008-09-26 05:36:07.000000000 +0800
+++ drivers/net/skge.c 2008-09-26 05:35:50.000000000 +0800
@@ -319,6 +319,7 @@ static int skge_set_settings(struct net_
struct skge_port *skge = netdev_priv(dev);
const struct skge_hw *hw = skge->hw;
u32 supported = skge_supported_modes(hw);
+ int err = 0;
if (ecmd->autoneg == AUTONEG_ENABLE) {
ecmd->advertising = supported;
@@ -367,8 +368,14 @@ static int skge_set_settings(struct net_
skge->autoneg = ecmd->autoneg;
skge->advertising = ecmd->advertising;
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ err = skge_up(dev);
+ if (err) {
+ dev_close(dev);
+ return err;
+ }
+ }
return (0);
}
@@ -593,6 +600,7 @@ static int skge_set_pauseparam(struct ne
{
struct skge_port *skge = netdev_priv(dev);
struct ethtool_pauseparam old;
+ int err = 0;
skge_get_pauseparam(dev, &old);
@@ -609,8 +617,14 @@ static int skge_set_pauseparam(struct ne
skge->flow_control = FLOW_MODE_NONE;
}
- if (netif_running(dev))
- skge_phy_reset(skge);
+ if (netif_running(dev)) {
+ skge_down(dev);
+ err = skge_up(dev);
+ if (err) {
+ dev_close(dev);
+ return err;
+ }
+ }
return 0;
}
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-09-26 6:44 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-22 21:52 [patch 10/21] driver/net/skge.c: restart the interface when it's options or pauseparam is set akpm
2008-09-23 23:45 ` Stephen Hemminger
2008-09-23 23:47 ` Stephen Hemminger
2008-09-26 6:28 ` Xiaoming.Zhang
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).