linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFC PATCH]  OF: fix of_find_node_by_path() assumption that of_allnodes is root
@ 2014-06-13  5:53 Frank Rowand
  2014-06-13  7:07 ` Pantelis Antoniou
  2014-06-13 13:52 ` Rob Herring
  0 siblings, 2 replies; 10+ messages in thread
From: Frank Rowand @ 2014-06-13  5:53 UTC (permalink / raw)
  To: Pantelis Antoniou, Grant Likely, Rob Herring, devicetree,
	Linux Kernel list

From: Frank Rowand <frank.rowand@sonymobile.com>

Pantelis Antoniou reports that of_find_node_by_path() is borked because
of_allnodes is not guaranteed to contain the root of the tree after using
any of the dynamic update functions because some other nodes ends up as
of_allnodes.

Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases

Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
---


Pantelis,

Can you test whether the problem you reported in irc?

This patch has not been tested, not even compile tested.


 drivers/of/base.c |    8 	6 +	2 -	0 !
 1 file changed, 6 insertions(+), 2 deletions(-)

Index: b/drivers/of/base.c
===================================================================
--- a/drivers/of/base.c
+++ b/drivers/of/base.c
@@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
 
 /**
  * of_attach_node - Plug a device node into the tree and global list.
+ *
+ * Put the device node after of_allnodes in the global list so that
+ * of_allnodes remains the root.
  */
 int of_attach_node(struct device_node *np)
 {
@@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
 	if (rc)
 		return rc;
 
+	BUG_ON(!of_allnodes);
 	raw_spin_lock_irqsave(&devtree_lock, flags);
 	np->sibling = np->parent->child;
-	np->allnext = of_allnodes;
+	np->allnext = of_allnodes->allnext;
 	np->parent->child = np;
-	of_allnodes = np;
+	of_allnodes->allnext = np;
 	of_node_clear_flag(np, OF_DETACHED);
 	raw_spin_unlock_irqrestore(&devtree_lock, flags);
 

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

* Re: [RFC PATCH]  OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13  5:53 [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root Frank Rowand
@ 2014-06-13  7:07 ` Pantelis Antoniou
  2014-06-13 13:52 ` Rob Herring
  1 sibling, 0 replies; 10+ messages in thread
From: Pantelis Antoniou @ 2014-06-13  7:07 UTC (permalink / raw)
  To: frowand.list; +Cc: Grant Likely, Rob Herring, devicetree, Linux Kernel list

Hi Frank,

On Jun 13, 2014, at 8:53 AM, Frank Rowand wrote:

> From: Frank Rowand <frank.rowand@sonymobile.com>
> 
> Pantelis Antoniou reports that of_find_node_by_path() is borked because
> of_allnodes is not guaranteed to contain the root of the tree after using
> any of the dynamic update functions because some other nodes ends up as
> of_allnodes.
> 
> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
> 
> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
> ---
> 
> 
> Pantelis,
> 
> Can you test whether the problem you reported in irc?
> 
> This patch has not been tested, not even compile tested.
> 

I can verify that this fixes the problem. Please make sure this gets 
applied to mainline otherwise every arch which updates DT on runtime
is going to break in subtle ways.

Regards

-- Pantelis

Tested-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com>

> 
> drivers/of/base.c |    8 	6 +	2 -	0 !
> 1 file changed, 6 insertions(+), 2 deletions(-)
> 
> Index: b/drivers/of/base.c
> ===================================================================
> --- a/drivers/of/base.c
> +++ b/drivers/of/base.c
> @@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
> 
> /**
>  * of_attach_node - Plug a device node into the tree and global list.
> + *
> + * Put the device node after of_allnodes in the global list so that
> + * of_allnodes remains the root.
>  */
> int of_attach_node(struct device_node *np)
> {
> @@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
> 	if (rc)
> 		return rc;
> 
> +	BUG_ON(!of_allnodes);
> 	raw_spin_lock_irqsave(&devtree_lock, flags);
> 	np->sibling = np->parent->child;
> -	np->allnext = of_allnodes;
> +	np->allnext = of_allnodes->allnext;
> 	np->parent->child = np;
> -	of_allnodes = np;
> +	of_allnodes->allnext = np;
> 	of_node_clear_flag(np, OF_DETACHED);
> 	raw_spin_unlock_irqrestore(&devtree_lock, flags);
> 
> --
> To unsubscribe from this list: send the line "unsubscribe devicetree" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html


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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13  5:53 [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root Frank Rowand
  2014-06-13  7:07 ` Pantelis Antoniou
@ 2014-06-13 13:52 ` Rob Herring
  2014-06-13 15:06   ` Grant Likely
  2014-06-13 16:49   ` Frank Rowand
  1 sibling, 2 replies; 10+ messages in thread
From: Rob Herring @ 2014-06-13 13:52 UTC (permalink / raw)
  To: Frank Rowand
  Cc: Pantelis Antoniou, Grant Likely, Rob Herring, devicetree,
	Linux Kernel list

On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
> From: Frank Rowand <frank.rowand@sonymobile.com>
>
> Pantelis Antoniou reports that of_find_node_by_path() is borked because
> of_allnodes is not guaranteed to contain the root of the tree after using
> any of the dynamic update functions because some other nodes ends up as
> of_allnodes.
>
> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases

Is it not possible to do a fix in of_find_node_by_path instead? I just
wonder if this could have any other unintended side-effects on
of_attach_node's behavior.

Rob

>
> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
> ---
>
>
> Pantelis,
>
> Can you test whether the problem you reported in irc?
>
> This patch has not been tested, not even compile tested.
>
>
>  drivers/of/base.c |    8       6 +     2 -     0 !
>  1 file changed, 6 insertions(+), 2 deletions(-)
>
> Index: b/drivers/of/base.c
> ===================================================================
> --- a/drivers/of/base.c
> +++ b/drivers/of/base.c
> @@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
>
>  /**
>   * of_attach_node - Plug a device node into the tree and global list.
> + *
> + * Put the device node after of_allnodes in the global list so that
> + * of_allnodes remains the root.
>   */
>  int of_attach_node(struct device_node *np)
>  {
> @@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
>         if (rc)
>                 return rc;
>
> +       BUG_ON(!of_allnodes);
>         raw_spin_lock_irqsave(&devtree_lock, flags);
>         np->sibling = np->parent->child;
> -       np->allnext = of_allnodes;
> +       np->allnext = of_allnodes->allnext;
>         np->parent->child = np;
> -       of_allnodes = np;
> +       of_allnodes->allnext = np;
>         of_node_clear_flag(np, OF_DETACHED);
>         raw_spin_unlock_irqrestore(&devtree_lock, flags);
>

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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13 13:52 ` Rob Herring
@ 2014-06-13 15:06   ` Grant Likely
  2014-06-14 15:00     ` Grant Likely
  2014-06-13 16:49   ` Frank Rowand
  1 sibling, 1 reply; 10+ messages in thread
From: Grant Likely @ 2014-06-13 15:06 UTC (permalink / raw)
  To: Rob Herring
  Cc: Frank Rowand, Pantelis Antoniou, Rob Herring, devicetree,
	Linux Kernel list

On Fri, Jun 13, 2014 at 2:52 PM, Rob Herring <robherring2@gmail.com> wrote:
> On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
>> From: Frank Rowand <frank.rowand@sonymobile.com>
>>
>> Pantelis Antoniou reports that of_find_node_by_path() is borked because
>> of_allnodes is not guaranteed to contain the root of the tree after using
>> any of the dynamic update functions because some other nodes ends up as
>> of_allnodes.
>>
>> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
>
> Is it not possible to do a fix in of_find_node_by_path instead? I just
> wonder if this could have any other unintended side-effects on
> of_attach_node's behavior.

Given that I'm going to replace the custom list with list_head which
makes this problem go away, I think this solution is fine.

Acked-by: Grant Likely <grant.likely@linaro.org>

g.

>
> Rob
>
>>
>> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
>> ---
>>
>>
>> Pantelis,
>>
>> Can you test whether the problem you reported in irc?
>>
>> This patch has not been tested, not even compile tested.
>>
>>
>>  drivers/of/base.c |    8       6 +     2 -     0 !
>>  1 file changed, 6 insertions(+), 2 deletions(-)
>>
>> Index: b/drivers/of/base.c
>> ===================================================================
>> --- a/drivers/of/base.c
>> +++ b/drivers/of/base.c
>> @@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
>>
>>  /**
>>   * of_attach_node - Plug a device node into the tree and global list.
>> + *
>> + * Put the device node after of_allnodes in the global list so that
>> + * of_allnodes remains the root.
>>   */
>>  int of_attach_node(struct device_node *np)
>>  {
>> @@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
>>         if (rc)
>>                 return rc;
>>
>> +       BUG_ON(!of_allnodes);
>>         raw_spin_lock_irqsave(&devtree_lock, flags);
>>         np->sibling = np->parent->child;
>> -       np->allnext = of_allnodes;
>> +       np->allnext = of_allnodes->allnext;
>>         np->parent->child = np;
>> -       of_allnodes = np;
>> +       of_allnodes->allnext = np;
>>         of_node_clear_flag(np, OF_DETACHED);
>>         raw_spin_unlock_irqrestore(&devtree_lock, flags);
>>

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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13 13:52 ` Rob Herring
  2014-06-13 15:06   ` Grant Likely
@ 2014-06-13 16:49   ` Frank Rowand
  2014-06-13 21:12     ` Rob Herring
  1 sibling, 1 reply; 10+ messages in thread
From: Frank Rowand @ 2014-06-13 16:49 UTC (permalink / raw)
  To: Rob Herring
  Cc: Pantelis Antoniou, Grant Likely, Rob Herring, devicetree,
	Linux Kernel list

On 6/13/2014 6:52 AM, Rob Herring wrote:
> On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
>> From: Frank Rowand <frank.rowand@sonymobile.com>
>>
>> Pantelis Antoniou reports that of_find_node_by_path() is borked because
>> of_allnodes is not guaranteed to contain the root of the tree after using
>> any of the dynamic update functions because some other nodes ends up as
>> of_allnodes.
>>
>> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
> 
> Is it not possible to do a fix in of_find_node_by_path instead? I just

Yes, the code for that is in https://lkml.org/lkml/2014/5/20/758

Or as Grant said in his reply, just use the fix in of_attach_node() for
now since he is going to replace the custom list.

> wonder if this could have any other unintended side-effects on
> of_attach_node's behavior.
> 
> Rob
> 
>>
>> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
>> ---
>>
>>
>> Pantelis,
>>
>> Can you test whether the problem you reported in irc?
>>
>> This patch has not been tested, not even compile tested.
>>
>>
>>  drivers/of/base.c |    8       6 +     2 -     0 !
>>  1 file changed, 6 insertions(+), 2 deletions(-)
>>
>> Index: b/drivers/of/base.c
>> ===================================================================
>> --- a/drivers/of/base.c
>> +++ b/drivers/of/base.c
>> @@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
>>
>>  /**
>>   * of_attach_node - Plug a device node into the tree and global list.
>> + *
>> + * Put the device node after of_allnodes in the global list so that
>> + * of_allnodes remains the root.
>>   */
>>  int of_attach_node(struct device_node *np)
>>  {
>> @@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
>>         if (rc)
>>                 return rc;
>>
>> +       BUG_ON(!of_allnodes);
>>         raw_spin_lock_irqsave(&devtree_lock, flags);
>>         np->sibling = np->parent->child;
>> -       np->allnext = of_allnodes;
>> +       np->allnext = of_allnodes->allnext;
>>         np->parent->child = np;
>> -       of_allnodes = np;
>> +       of_allnodes->allnext = np;
>>         of_node_clear_flag(np, OF_DETACHED);
>>         raw_spin_unlock_irqrestore(&devtree_lock, flags);
>>
> .
> 


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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13 16:49   ` Frank Rowand
@ 2014-06-13 21:12     ` Rob Herring
  0 siblings, 0 replies; 10+ messages in thread
From: Rob Herring @ 2014-06-13 21:12 UTC (permalink / raw)
  To: Frank Rowand
  Cc: Pantelis Antoniou, Grant Likely, Rob Herring, devicetree,
	Linux Kernel list

On Fri, Jun 13, 2014 at 11:49 AM, Frank Rowand <frowand.list@gmail.com> wrote:
> On 6/13/2014 6:52 AM, Rob Herring wrote:
>> On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
>>> From: Frank Rowand <frank.rowand@sonymobile.com>
>>>
>>> Pantelis Antoniou reports that of_find_node_by_path() is borked because
>>> of_allnodes is not guaranteed to contain the root of the tree after using
>>> any of the dynamic update functions because some other nodes ends up as
>>> of_allnodes.
>>>
>>> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
>>
>> Is it not possible to do a fix in of_find_node_by_path instead? I just
>
> Yes, the code for that is in https://lkml.org/lkml/2014/5/20/758
>
> Or as Grant said in his reply, just use the fix in of_attach_node() for
> now since he is going to replace the custom list.

Okay, I've applied.

Rob

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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-13 15:06   ` Grant Likely
@ 2014-06-14 15:00     ` Grant Likely
  2014-06-15  3:36       ` Frank Rowand
  0 siblings, 1 reply; 10+ messages in thread
From: Grant Likely @ 2014-06-14 15:00 UTC (permalink / raw)
  To: Rob Herring
  Cc: Frank Rowand, Pantelis Antoniou, Rob Herring, devicetree,
	Linux Kernel list

On Fri, Jun 13, 2014 at 4:06 PM, Grant Likely <grant.likely@linaro.org> wrote:
> On Fri, Jun 13, 2014 at 2:52 PM, Rob Herring <robherring2@gmail.com> wrote:
>> On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
>>> From: Frank Rowand <frank.rowand@sonymobile.com>
>>>
>>> Pantelis Antoniou reports that of_find_node_by_path() is borked because
>>> of_allnodes is not guaranteed to contain the root of the tree after using
>>> any of the dynamic update functions because some other nodes ends up as
>>> of_allnodes.
>>>
>>> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
>>
>> Is it not possible to do a fix in of_find_node_by_path instead? I just
>> wonder if this could have any other unintended side-effects on
>> of_attach_node's behavior.
>
> Given that I'm going to replace the custom list with list_head which
> makes this problem go away, I think this solution is fine.
>
> Acked-by: Grant Likely <grant.likely@linaro.org>

That said, the following might be better because it would guarantee
that children always appear after parents...

>> Rob
>>
>>>
>>> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
>>> ---
>>>
>>>
>>> Pantelis,
>>>
>>> Can you test whether the problem you reported in irc?
>>>
>>> This patch has not been tested, not even compile tested.
>>>
>>>
>>>  drivers/of/base.c |    8       6 +     2 -     0 !
>>>  1 file changed, 6 insertions(+), 2 deletions(-)
>>>
>>> Index: b/drivers/of/base.c
>>> ===================================================================
>>> --- a/drivers/of/base.c
>>> +++ b/drivers/of/base.c
>>> @@ -1948,6 +1948,9 @@ int of_reconfig_notify(unsigned long act
>>>
>>>  /**
>>>   * of_attach_node - Plug a device node into the tree and global list.
>>> + *
>>> + * Put the device node after of_allnodes in the global list so that
>>> + * of_allnodes remains the root.
>>>   */
>>>  int of_attach_node(struct device_node *np)
>>>  {
>>> @@ -1958,11 +1961,12 @@ int of_attach_node(struct device_node *n
>>>         if (rc)
>>>                 return rc;
>>>
>>> +       BUG_ON(!of_allnodes);
>>>         raw_spin_lock_irqsave(&devtree_lock, flags);
>>>         np->sibling = np->parent->child;
>>> -       np->allnext = of_allnodes;
>>> +       np->allnext = of_allnodes->allnext;

np->allnext = np->parent->allnext;
np->parent->allnext = np;

>>>         np->parent->child = np;
>>> -       of_allnodes = np;
>>> +       of_allnodes->allnext = np;
>>>         of_node_clear_flag(np, OF_DETACHED);
>>>         raw_spin_unlock_irqrestore(&devtree_lock, flags);
>>>

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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-14 15:00     ` Grant Likely
@ 2014-06-15  3:36       ` Frank Rowand
  2014-06-15  3:39         ` Frank Rowand
  0 siblings, 1 reply; 10+ messages in thread
From: Frank Rowand @ 2014-06-15  3:36 UTC (permalink / raw)
  To: Grant Likely, Pantelis Antoniou
  Cc: Rob Herring, Rob Herring, devicetree, Linux Kernel list

On 6/14/2014 8:00 AM, Grant Likely wrote:
> On Fri, Jun 13, 2014 at 4:06 PM, Grant Likely <grant.likely@linaro.org> wrote:
>> On Fri, Jun 13, 2014 at 2:52 PM, Rob Herring <robherring2@gmail.com> wrote:
>>> On Fri, Jun 13, 2014 at 12:53 AM, Frank Rowand <frowand.list@gmail.com> wrote:
>>>> From: Frank Rowand <frank.rowand@sonymobile.com>
>>>>
>>>> Pantelis Antoniou reports that of_find_node_by_path() is borked because
>>>> of_allnodes is not guaranteed to contain the root of the tree after using
>>>> any of the dynamic update functions because some other nodes ends up as
>>>> of_allnodes.
>>>>
>>>> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
>>>
>>> Is it not possible to do a fix in of_find_node_by_path instead? I just
>>> wonder if this could have any other unintended side-effects on
>>> of_attach_node's behavior.
>>
>> Given that I'm going to replace the custom list with list_head which
>> makes this problem go away, I think this solution is fine.
>>
>> Acked-by: Grant Likely <grant.likely@linaro.org>
> 
> That said, the following might be better because it would guarantee
> that children always appear after parents...

< snip >

I agree, I like that better.  Patch respun, v2 will be sent as a reply
to this email.

Pantelis, can you test v2 please?

Thanks,

Frank


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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-15  3:36       ` Frank Rowand
@ 2014-06-15  3:39         ` Frank Rowand
  2014-06-15  3:42           ` Frank Rowand
  0 siblings, 1 reply; 10+ messages in thread
From: Frank Rowand @ 2014-06-15  3:39 UTC (permalink / raw)
  To: frowand.list
  Cc: Grant Likely, Pantelis Antoniou, Rob Herring, Rob Herring,
	devicetree, Linux Kernel list

From: Frank Rowand <frank.rowand@sonymobile.com>

of_find_node_by_path() is borked because of_allnodes is not guaranteed to
contain the root of the tree after using any of the dynamic update functions
because some other nodes ends up as of_allnodes.

Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
Reported-by: pantelis.antoniou@konsulko.com
Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
---

v2:
  Remove change to function header, no longer needed.
  Remove BUG_ON(), no longer needed.
  Add np as np->parent->allnext instead of np->parent->allnext, as suggested
    by Grant Likely.


 drivers/of/base.c |    4 	2 +	2 -	0 !
 1 file changed, 2 insertions(+), 2 deletions(-)

Index: b/drivers/of/base.c
===================================================================
--- a/drivers/of/base.c
+++ b/drivers/of/base.c
@@ -1960,9 +1960,9 @@ int of_attach_node(struct device_node *n
 
 	raw_spin_lock_irqsave(&devtree_lock, flags);
 	np->sibling = np->parent->child;
-	np->allnext = of_allnodes;
+	np->allnext = np->parent->allnext;
+	np->parent->allnext = np;
 	np->parent->child = np;
-	of_allnodes = np;
 	of_node_clear_flag(np, OF_DETACHED);
 	raw_spin_unlock_irqrestore(&devtree_lock, flags);
 

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

* Re: [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root
  2014-06-15  3:39         ` Frank Rowand
@ 2014-06-15  3:42           ` Frank Rowand
  0 siblings, 0 replies; 10+ messages in thread
From: Frank Rowand @ 2014-06-15  3:42 UTC (permalink / raw)
  To: frowand.list
  Cc: Grant Likely, Pantelis Antoniou, Rob Herring, Rob Herring,
	devicetree, Linux Kernel list

On 6/14/2014 8:39 PM, Frank Rowand wrote:
> From: Frank Rowand <frank.rowand@sonymobile.com>
> 
> of_find_node_by_path() is borked because of_allnodes is not guaranteed to
> contain the root of the tree after using any of the dynamic update functions
> because some other nodes ends up as of_allnodes.
> 
> Fixes: c22e650e66b8 of: Make of_find_node_by_path() handle /aliases
> Reported-by: pantelis.antoniou@konsulko.com
> Signed-off-by: Frank Rowand <frank.rowand@sonymobile.com>
> ---
> 
> v2:
>   Remove change to function header, no longer needed.
>   Remove BUG_ON(), no longer needed.
>   Add np as np->parent->allnext instead of np->parent->allnext, as suggested

Aaaargh, cut and paste error, that should be:

    Add np as np->parent->allnext instead of of_allnodes->allnext, as suggested

>     by Grant Likely.
> 
> 
>  drivers/of/base.c |    4 	2 +	2 -	0 !
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> Index: b/drivers/of/base.c
> ===================================================================
> --- a/drivers/of/base.c
> +++ b/drivers/of/base.c
> @@ -1960,9 +1960,9 @@ int of_attach_node(struct device_node *n
>  
>  	raw_spin_lock_irqsave(&devtree_lock, flags);
>  	np->sibling = np->parent->child;
> -	np->allnext = of_allnodes;
> +	np->allnext = np->parent->allnext;
> +	np->parent->allnext = np;
>  	np->parent->child = np;
> -	of_allnodes = np;
>  	of_node_clear_flag(np, OF_DETACHED);
>  	raw_spin_unlock_irqrestore(&devtree_lock, flags);
>  
> 


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

end of thread, other threads:[~2014-06-15  3:42 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-06-13  5:53 [RFC PATCH] OF: fix of_find_node_by_path() assumption that of_allnodes is root Frank Rowand
2014-06-13  7:07 ` Pantelis Antoniou
2014-06-13 13:52 ` Rob Herring
2014-06-13 15:06   ` Grant Likely
2014-06-14 15:00     ` Grant Likely
2014-06-15  3:36       ` Frank Rowand
2014-06-15  3:39         ` Frank Rowand
2014-06-15  3:42           ` Frank Rowand
2014-06-13 16:49   ` Frank Rowand
2014-06-13 21:12     ` Rob Herring

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).