All of lore.kernel.org
 help / color / mirror / Atom feed
* [RFC PATCH 3/3] net: dsa: exit probe if no switch were found
@ 2015-09-30  8:21 Neil Armstrong
  2015-10-01 15:27 ` Neil Armstrong
  0 siblings, 1 reply; 5+ messages in thread
From: Neil Armstrong @ 2015-09-30  8:21 UTC (permalink / raw)
  To: David S. Miller, Jesper Dangaard Brouer, netdev, linux-kernel

If no switch were found in dsa_setup_dst, return -ENODEV and
exit the dsa_probe cleanly.

Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
---
 net/dsa/dsa.c | 19 +++++++++++++++----
 1 file changed, 15 insertions(+), 4 deletions(-)

diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c
index 0c104af..6ae1ab9 100644
--- a/net/dsa/dsa.c
+++ b/net/dsa/dsa.c
@@ -844,10 +844,11 @@ static inline void dsa_of_remove(struct device *dev)
 }
 #endif

-static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
+static int dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
 			  struct device *parent, struct dsa_platform_data *pd)
 {
 	int i;
+	unsigned configured = 0;

 	dst->pd = pd;
 	dst->master_netdev = dev;
@@ -867,9 +868,17 @@ static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
 		dst->ds[i] = ds;
 		if (ds->drv->poll_link != NULL)
 			dst->link_poll_needed = 1;
+
+		++configured;
 	}

 	/*
+	 * If no switch was found, exit cleanly
+	 */
+	if (!configured)
+		return -ENODEV;
+
+	/*
 	 * If we use a tagging format that doesn't have an ethertype
 	 * field, make sure that all packets from this point on get
 	 * sent to the tag format's receive function.
@@ -885,6 +894,8 @@ static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
 		dst->link_poll_timer.expires = round_jiffies(jiffies + HZ);
 		add_timer(&dst->link_poll_timer);
 	}
+
+	return 0;
 }

 static int dsa_probe(struct platform_device *pdev)
@@ -934,9 +945,9 @@ static int dsa_probe(struct platform_device *pdev)

 	platform_set_drvdata(pdev, dst);

-	dsa_setup_dst(dst, dev, &pdev->dev, pd);
-
-	return 0;
+	ret = dsa_setup_dst(dst, dev, &pdev->dev, pd);
+	if (!ret)
+		return 0;

 out:
 	dsa_of_remove(&pdev->dev);
-- 
1.9.1

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

* Re: [RFC PATCH 3/3] net: dsa: exit probe if no switch were found
  2015-09-30  8:21 [RFC PATCH 3/3] net: dsa: exit probe if no switch were found Neil Armstrong
@ 2015-10-01 15:27 ` Neil Armstrong
  2015-10-01 16:32   ` Andrew Lunn
  0 siblings, 1 reply; 5+ messages in thread
From: Neil Armstrong @ 2015-10-01 15:27 UTC (permalink / raw)
  To: David S. Miller, Jesper Dangaard Brouer, netdev, linux-kernel

On 09/30/2015 10:21 AM, Neil Armstrong wrote:
> If no switch were found in dsa_setup_dst, return -ENODEV and
> exit the dsa_probe cleanly.
> 
> Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
> ---
>  net/dsa/dsa.c | 19 +++++++++++++++----
>  1 file changed, 15 insertions(+), 4 deletions(-)
> 
> diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c
> index 0c104af..6ae1ab9 100644
> --- a/net/dsa/dsa.c
> +++ b/net/dsa/dsa.c
> @@ -844,10 +844,11 @@ static inline void dsa_of_remove(struct device *dev)
>  }
>  #endif
> 
> -static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
> +static int dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
>  			  struct device *parent, struct dsa_platform_data *pd)
>  {
>  	int i;
> +	unsigned configured = 0;
> 
>  	dst->pd = pd;
>  	dst->master_netdev = dev;
> @@ -867,9 +868,17 @@ static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
>  		dst->ds[i] = ds;
>  		if (ds->drv->poll_link != NULL)
>  			dst->link_poll_needed = 1;
> +
> +		++configured;
>  	}
> 
>  	/*
> +	 * If no switch was found, exit cleanly
> +	 */
> +	if (!configured)
> +		return -ENODEV;
> +
> +	/*
>  	 * If we use a tagging format that doesn't have an ethertype
>  	 * field, make sure that all packets from this point on get
>  	 * sent to the tag format's receive function.
> @@ -885,6 +894,8 @@ static void dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
>  		dst->link_poll_timer.expires = round_jiffies(jiffies + HZ);
>  		add_timer(&dst->link_poll_timer);
>  	}
> +
> +	return 0;
>  }
> 
>  static int dsa_probe(struct platform_device *pdev)
> @@ -934,9 +945,9 @@ static int dsa_probe(struct platform_device *pdev)
> 
>  	platform_set_drvdata(pdev, dst);
> 
> -	dsa_setup_dst(dst, dev, &pdev->dev, pd);
> -
> -	return 0;
> +	ret = dsa_setup_dst(dst, dev, &pdev->dev, pd);
> +	if (!ret)
> +		return 0;
> 
>  out:
>  	dsa_of_remove(&pdev->dev);
> 

Couldn't we use the probe defer mechanism here ? (until complete rework is done)

How could we re-probe after a register_switch_driver ?

Neil

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

* Re: [RFC PATCH 3/3] net: dsa: exit probe if no switch were found
  2015-10-01 15:27 ` Neil Armstrong
@ 2015-10-01 16:32   ` Andrew Lunn
  2015-10-02 12:10     ` Neil Armstrong
  0 siblings, 1 reply; 5+ messages in thread
From: Andrew Lunn @ 2015-10-01 16:32 UTC (permalink / raw)
  To: Neil Armstrong
  Cc: David S. Miller, Jesper Dangaard Brouer, netdev, linux-kernel

On Thu, Oct 01, 2015 at 05:27:32PM +0200, Neil Armstrong wrote:
> On 09/30/2015 10:21 AM, Neil Armstrong wrote:
> > If no switch were found in dsa_setup_dst, return -ENODEV and
> > exit the dsa_probe cleanly.

...
 
> Couldn't we use the probe defer mechanism here ? (until complete rework is done)

Hi Neil

I was thinking the same last night. We know the switch should be
there, otherwise it would not be in DT. So returning -EPROBE_DEFER
would be valid.

      Andrew

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

* Re: [RFC PATCH 3/3] net: dsa: exit probe if no switch were found
  2015-10-01 16:32   ` Andrew Lunn
@ 2015-10-02 12:10     ` Neil Armstrong
  2015-10-02 17:39       ` Florian Fainelli
  0 siblings, 1 reply; 5+ messages in thread
From: Neil Armstrong @ 2015-10-02 12:10 UTC (permalink / raw)
  To: Andrew Lunn; +Cc: David S. Miller, Jesper Dangaard Brouer, netdev, linux-kernel

On 10/01/2015 06:32 PM, Andrew Lunn wrote:
> On Thu, Oct 01, 2015 at 05:27:32PM +0200, Neil Armstrong wrote:
>> On 09/30/2015 10:21 AM, Neil Armstrong wrote:
>>> If no switch were found in dsa_setup_dst, return -ENODEV and
>>> exit the dsa_probe cleanly.
> 
> ...
>  
>> Couldn't we use the probe defer mechanism here ? (until complete rework is done)
> 
> Hi Neil
> 
> I was thinking the same last night. We know the switch should be
> there, otherwise it would not be in DT. So returning -EPROBE_DEFER
> would be valid.
> 
>       Andrew
> 
Hi,

It makes sens but does a module insertion triggers the differed probe ?

I will still post this change in a next set of patch.

Neil

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

* Re: [RFC PATCH 3/3] net: dsa: exit probe if no switch were found
  2015-10-02 12:10     ` Neil Armstrong
@ 2015-10-02 17:39       ` Florian Fainelli
  0 siblings, 0 replies; 5+ messages in thread
From: Florian Fainelli @ 2015-10-02 17:39 UTC (permalink / raw)
  To: Neil Armstrong, Andrew Lunn
  Cc: David S. Miller, Jesper Dangaard Brouer, netdev, linux-kernel

On 02/10/15 05:10, Neil Armstrong wrote:
> On 10/01/2015 06:32 PM, Andrew Lunn wrote:
>> On Thu, Oct 01, 2015 at 05:27:32PM +0200, Neil Armstrong wrote:
>>> On 09/30/2015 10:21 AM, Neil Armstrong wrote:
>>>> If no switch were found in dsa_setup_dst, return -ENODEV and
>>>> exit the dsa_probe cleanly.
>>
>> ...
>>  
>>> Couldn't we use the probe defer mechanism here ? (until complete rework is done)
>>
>> Hi Neil
>>
>> I was thinking the same last night. We know the switch should be
>> there, otherwise it would not be in DT. So returning -EPROBE_DEFER
>> would be valid.
>>
>>       Andrew
>>
> Hi,
> 
> It makes sens but does a module insertion triggers the differed probe ?

That's a good question, I am not convinced this is the case. Even with
the EPROBE_DEFER returned if the list of drivers is empty, you would
still very likely run into the following circular dependency, if you
make everything built as a module:

- dsa provides register_switch_driver and unregister_switch_driver
- switch drivers in drivers/net/dsa/* depend on these two symbols, so
until these symbols are loaded, the module loader cannot complete their
load successfully
- dsa will not be able to make any progress, that is, its driver list
will be empty as long as no switch driver is loaded

If you build dsa into your kernel, you might be fine though, or in a
better shape at least.
-- 
Florian

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

end of thread, other threads:[~2015-10-02 17:39 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-09-30  8:21 [RFC PATCH 3/3] net: dsa: exit probe if no switch were found Neil Armstrong
2015-10-01 15:27 ` Neil Armstrong
2015-10-01 16:32   ` Andrew Lunn
2015-10-02 12:10     ` Neil Armstrong
2015-10-02 17:39       ` Florian Fainelli

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.