diff mbox series

ASoC: simple-card: Fix refcount underflow

Message ID 20190216100927.10017-1-daniel.baluta@nxp.com (mailing list archive)
State Accepted
Commit 461d854c0dba3cdf63cce37ffb9423eca0793a47
Headers show
Series ASoC: simple-card: Fix refcount underflow | expand

Commit Message

Daniel Baluta Feb. 16, 2019, 10:09 a.m. UTC
of_get_child_by_name() takes a reference we'll need to drop
later so when we substitute in top we need to take a reference
as well as just assigning.

Without this patch we hit the following error:

[    1.246852] OF: ERROR: Bad of_node_put() on /sound-wm8524
[    1.262261] Hardware name: NXP i.MX8MQ EVK (DT)
[    1.266807] Workqueue: events deferred_probe_work_func
[    1.271950] Call trace:
[    1.274406]  dump_backtrace+0x0/0x158
[    1.278074]  show_stack+0x14/0x20
[    1.281396]  dump_stack+0xa8/0xcc
[    1.284717]  of_node_release+0xb0/0xc8
[    1.288474]  kobject_put+0x74/0xf0
[    1.291879]  of_node_put+0x14/0x28
[    1.295286]  __of_get_next_child+0x44/0x70
[    1.299387]  of_get_next_child+0x3c/0x60
[    1.303315]  simple_for_each_link+0x1dc/0x230
[    1.307676]  simple_probe+0x80/0x540
[    1.311256]  platform_drv_probe+0x50/0xa0

This patch is based on an earlier version posted by Kuninori Morimoto
and commit message includes explanations from Mark Brown.

https://patchwork.kernel.org/patch/10814255/

Reported-by: Vicente Bergas <vicencb@gmail.com>
Signed-off-by: Daniel Baluta <daniel.baluta@nxp.com>
---
 sound/soc/generic/simple-card.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Kuninori Morimoto Feb. 18, 2019, 1:37 a.m. UTC | #1
Hi Daniel, Mark, again

> > of_get_child_by_name() takes a reference we'll need to drop
> > later so when we substitute in top we need to take a reference
> > as well as just assigning.
> > 
> > Without this patch we hit the following error:
> > 
> > [    1.246852] OF: ERROR: Bad of_node_put() on /sound-wm8524
> > [    1.262261] Hardware name: NXP i.MX8MQ EVK (DT)
> > [    1.266807] Workqueue: events deferred_probe_work_func
> > [    1.271950] Call trace:
> > [    1.274406]  dump_backtrace+0x0/0x158
> > [    1.278074]  show_stack+0x14/0x20
> > [    1.281396]  dump_stack+0xa8/0xcc
> > [    1.284717]  of_node_release+0xb0/0xc8
> > [    1.288474]  kobject_put+0x74/0xf0
> > [    1.291879]  of_node_put+0x14/0x28
> > [    1.295286]  __of_get_next_child+0x44/0x70
> > [    1.299387]  of_get_next_child+0x3c/0x60
> > [    1.303315]  simple_for_each_link+0x1dc/0x230
> > [    1.307676]  simple_probe+0x80/0x540
> > [    1.311256]  platform_drv_probe+0x50/0xa0
> > 
> > This patch is based on an earlier version posted by Kuninori Morimoto
> > and commit message includes explanations from Mark Brown.
> > 
> > https://patchwork.kernel.org/patch/10814255/
> > 
> > Reported-by: Vicente Bergas <vicencb@gmail.com>
> > Signed-off-by: Daniel Baluta <daniel.baluta@nxp.com>
> > ---
> 
> I'm not sure which one is correct in this case
> 
> Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
> 
> or
> 
> Acked-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>

And we want to add

Fixes: commit da215354eb55c ("ASoC: simple-card: merge simple-scu-card")
Daniel Baluta Feb. 18, 2019, 7:06 a.m. UTC | #2
On Mon, 2019-02-18 at 10:37 +0900, Kuninori Morimoto wrote:
> Hi Daniel, Mark, again
> 
> > > of_get_child_by_name() takes a reference we'll need to drop
> > > later so when we substitute in top we need to take a reference
> > > as well as just assigning.
> > > 
> > > Without this patch we hit the following error:
> > > 
> > > [    1.246852] OF: ERROR: Bad of_node_put() on /sound-wm8524
> > > [    1.262261] Hardware name: NXP i.MX8MQ EVK (DT)
> > > [    1.266807] Workqueue: events deferred_probe_work_func
> > > [    1.271950] Call trace:
> > > [    1.274406]  dump_backtrace+0x0/0x158
> > > [    1.278074]  show_stack+0x14/0x20
> > > [    1.281396]  dump_stack+0xa8/0xcc
> > > [    1.284717]  of_node_release+0xb0/0xc8
> > > [    1.288474]  kobject_put+0x74/0xf0
> > > [    1.291879]  of_node_put+0x14/0x28
> > > [    1.295286]  __of_get_next_child+0x44/0x70
> > > [    1.299387]  of_get_next_child+0x3c/0x60
> > > [    1.303315]  simple_for_each_link+0x1dc/0x230
> > > [    1.307676]  simple_probe+0x80/0x540
> > > [    1.311256]  platform_drv_probe+0x50/0xa0
> > > 
> > > This patch is based on an earlier version posted by Kuninori
> > > Morimoto
> > > and commit message includes explanations from Mark Brown.
> > > 
> > > 
https://emea01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fpatchwork.kernel.org%2Fpatch%2F10814255%2F&amp;data=02%7C01%7Cdaniel.baluta%40nxp.com%7Ced1b7adc66a546c1bb4608d69541aaf8%7C686ea1d3bc2b4c6fa92cd99c5c301635%7C0%7C0%7C636860506617983174&amp;sdata=hTsurDLdtLAtTw0a5v%2FrSsleSawAP2yiVPl87%2BHCzTI%3D&amp;reserved=0
> > > 
> > > Reported-by: Vicente Bergas <vicencb@gmail.com>
> > > Signed-off-by: Daniel Baluta <daniel.baluta@nxp.com>
> > > ---
> > 
> > I'm not sure which one is correct in this case
> > 
> > Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
> > 
> > or
> > 
> > Acked-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
> 
> And we want to add
> 
> Fixes: commit da215354eb55c ("ASoC: simple-card: merge simple-scu-
> card")
> 

Thanks! I thought about adding this but the current patch will not
cleanly apply because of:

2d01a84605a55c ("ASoC: simple-card: reduce naming prefix")
Mark Brown Feb. 18, 2019, 5:50 p.m. UTC | #3
On Mon, Feb 18, 2019 at 08:52:26AM +0100, Takashi Iwai wrote:
> Daniel Baluta wrote:

> > > Fixes: commit da215354eb55c ("ASoC: simple-card: merge simple-scu-
> > > card")

> > Thanks! I thought about adding this but the current patch will not
> > cleanly apply because of:

> > 2d01a84605a55c ("ASoC: simple-card: reduce naming prefix")

That doesn't matter for fixes tags.  However...

> Yeah, it's a bit tricky because of the code change at this time.

> At best, send two patches, once for 5.0 and once for 5.1, and let Mark
> apply both of them and do the empty merge from 5.0 to 5.1, or let him
> resolve the merge conflict by applying manually the 5.1 patch.

...since this is something that needs to be fixed for v5.0 we need a
patch that can be applied on v5.0 (and has been tested by someone who
sees the issue there).  Takashi's plan seems like a good way to do that,
if you could send a patch against my for-5.0 branch (or just Linus'
tree) that'd be great.
Daniel Baluta Feb. 18, 2019, 6 p.m. UTC | #4
On Mon, Feb 18, 2019 at 7:50 PM Mark Brown <broonie@kernel.org> wrote:
>
> On Mon, Feb 18, 2019 at 08:52:26AM +0100, Takashi Iwai wrote:
> > Daniel Baluta wrote:
>
> > > > Fixes: commit da215354eb55c ("ASoC: simple-card: merge simple-scu-
> > > > card")
>
> > > Thanks! I thought about adding this but the current patch will not
> > > cleanly apply because of:
>
> > > 2d01a84605a55c ("ASoC: simple-card: reduce naming prefix")
>
> That doesn't matter for fixes tags.  However...
>
> > Yeah, it's a bit tricky because of the code change at this time.
>
> > At best, send two patches, once for 5.0 and once for 5.1, and let Mark
> > apply both of them and do the empty merge from 5.0 to 5.1, or let him
> > resolve the merge conflict by applying manually the 5.1 patch.
>
> ...since this is something that needs to be fixed for v5.0 we need a
> patch that can be applied on v5.0 (and has been tested by someone who
> sees the issue there).  Takashi's plan seems like a good way to do that,
> if you could send a patch against my for-5.0 branch (or just Linus'
> tree) that'd be great.

for-5.0 branch Kuninori's patch works fine:

https://patchwork.kernel.org/patch/10814255/

for-5.1 branch and later my patch works fine:

https://patchwork.kernel.org/patch/10817449/

Would you want me to change the patch for 5.0 to have an identical commit
message as the one for 5.1?
Mark Brown Feb. 18, 2019, 6:22 p.m. UTC | #5
On Mon, Feb 18, 2019 at 08:00:48PM +0200, Daniel Baluta wrote:

> Would you want me to change the patch for 5.0 to have an identical commit
> message as the one for 5.1?

No, that's fine - since Morimoto-san's patch has been tested I'll just use
that.
diff mbox series

Patch

diff --git a/sound/soc/generic/simple-card.c b/sound/soc/generic/simple-card.c
index 08df261024cf..dc18c4492955 100644
--- a/sound/soc/generic/simple-card.c
+++ b/sound/soc/generic/simple-card.c
@@ -445,7 +445,7 @@  static int simple_for_each_link(struct simple_priv *priv,
 	/* Check if it has dai-link */
 	node = of_get_child_by_name(top, PREFIX "dai-link");
 	if (!node) {
-		node = top;
+		node = of_node_get(top);
 		is_top = 1;
 	}