* [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() @ 2018-11-22 15:23 Yangtao Li 2018-11-24 14:58 ` Frank Lee 0 siblings, 1 reply; 5+ messages in thread From: Yangtao Li @ 2018-11-22 15:23 UTC (permalink / raw) To: daniel.lezcano, tglx; +Cc: linux-kernel, Yangtao Li of_find_node_by_path() acquires a reference to the node returned by it and that reference needs to be dropped by its caller. integrator_ap_timer_init_of() doesn't do that, so fix it. Signed-off-by: Yangtao Li <tiny.windzz@gmail.com> --- drivers/clocksource/timer-integrator-ap.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/drivers/clocksource/timer-integrator-ap.c b/drivers/clocksource/timer-integrator-ap.c index 76e526f58620..1f04069470bb 100644 --- a/drivers/clocksource/timer-integrator-ap.c +++ b/drivers/clocksource/timer-integrator-ap.c @@ -177,7 +177,7 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) { const char *path; void __iomem *base; - int err; + int err,rc = 0; int irq; struct clk *clk; unsigned long rate; @@ -210,26 +210,34 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) "arm,timer-secondary", &path); if (err) { pr_warn("Failed to read property\n"); - return err; + rc = err; + goto out_put_pri_node; } sec_node = of_find_node_by_path(path); - if (node == pri_node) + if (node == pri_node){ /* The primary timer lacks IRQ, use as clocksource */ - return integrator_clocksource_init(rate, base); + rc = integrator_clocksource_init(rate, base); + goto out; + } if (node == sec_node) { /* The secondary timer will drive the clock event */ irq = irq_of_parse_and_map(node, 0); - return integrator_clockevent_init(rate, base, irq); + rc = integrator_clockevent_init(rate, base, irq); + goto out; } pr_info("Timer @%p unused\n", base); clk_disable_unprepare(clk); +out: + of_node_put(sec_node); +out_put_pri_node: + of_node_put(pri_node); - return 0; + return rc; } TIMER_OF_DECLARE(integrator_ap_timer, "arm,integrator-timer", -- 2.17.0 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() 2018-11-22 15:23 [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() Yangtao Li @ 2018-11-24 14:58 ` Frank Lee 2018-11-24 19:49 ` Daniel Lezcano 0 siblings, 1 reply; 5+ messages in thread From: Frank Lee @ 2018-11-24 14:58 UTC (permalink / raw) To: Daniel Lezcano, tglx; +Cc: linux-kernel On Thu, Nov 22, 2018 at 11:23 PM Yangtao Li <tiny.windzz@gmail.com> wrote: > > of_find_node_by_path() acquires a reference to the node > returned by it and that reference needs to be dropped by its caller. > integrator_ap_timer_init_of() doesn't do that, so fix it. > > Signed-off-by: Yangtao Li <tiny.windzz@gmail.com> > --- > drivers/clocksource/timer-integrator-ap.c | 20 ++++++++++++++------ > 1 file changed, 14 insertions(+), 6 deletions(-) > > diff --git a/drivers/clocksource/timer-integrator-ap.c b/drivers/clocksource/timer-integrator-ap.c > index 76e526f58620..1f04069470bb 100644 > --- a/drivers/clocksource/timer-integrator-ap.c > +++ b/drivers/clocksource/timer-integrator-ap.c > @@ -177,7 +177,7 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) > { > const char *path; > void __iomem *base; > - int err; > + int err,rc = 0; > int irq; > struct clk *clk; > unsigned long rate; > @@ -210,26 +210,34 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) > "arm,timer-secondary", &path); > if (err) { > pr_warn("Failed to read property\n"); > - return err; > + rc = err; > + goto out_put_pri_node; > } > > > sec_node = of_find_node_by_path(path); > > - if (node == pri_node) > + if (node == pri_node){ > /* The primary timer lacks IRQ, use as clocksource */ > - return integrator_clocksource_init(rate, base); > + rc = integrator_clocksource_init(rate, base); > + goto out; > + } > > if (node == sec_node) { > /* The secondary timer will drive the clock event */ > irq = irq_of_parse_and_map(node, 0); > - return integrator_clockevent_init(rate, base, irq); > + rc = integrator_clockevent_init(rate, base, irq); > + goto out; > } > > pr_info("Timer @%p unused\n", base); > clk_disable_unprepare(clk); > +out: > + of_node_put(sec_node); > +out_put_pri_node: > + of_node_put(pri_node); > > - return 0; > + return rc; > } > > TIMER_OF_DECLARE(integrator_ap_timer, "arm,integrator-timer", > -- > 2.17.0 > Hi Daniel: How about this? Thanks, Yangtao ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() 2018-11-24 14:58 ` Frank Lee @ 2018-11-24 19:49 ` Daniel Lezcano 2018-11-25 4:25 ` Frank Lee 0 siblings, 1 reply; 5+ messages in thread From: Daniel Lezcano @ 2018-11-24 19:49 UTC (permalink / raw) To: Frank Lee, tglx; +Cc: linux-kernel On 24/11/2018 15:58, Frank Lee wrote: > On Thu, Nov 22, 2018 at 11:23 PM Yangtao Li <tiny.windzz@gmail.com> wrote: >> >> of_find_node_by_path() acquires a reference to the node >> returned by it and that reference needs to be dropped by its caller. >> integrator_ap_timer_init_of() doesn't do that, so fix it. >> >> Signed-off-by: Yangtao Li <tiny.windzz@gmail.com> >> --- >> drivers/clocksource/timer-integrator-ap.c | 20 ++++++++++++++------ >> 1 file changed, 14 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/clocksource/timer-integrator-ap.c b/drivers/clocksource/timer-integrator-ap.c >> index 76e526f58620..1f04069470bb 100644 >> --- a/drivers/clocksource/timer-integrator-ap.c >> +++ b/drivers/clocksource/timer-integrator-ap.c >> @@ -177,7 +177,7 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) >> { >> const char *path; >> void __iomem *base; >> - int err; >> + int err,rc = 0; >> int irq; >> struct clk *clk; >> unsigned long rate; >> @@ -210,26 +210,34 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) >> "arm,timer-secondary", &path); >> if (err) { >> pr_warn("Failed to read property\n"); >> - return err; >> + rc = err; >> + goto out_put_pri_node; >> } >> >> >> sec_node = of_find_node_by_path(path); >> >> - if (node == pri_node) >> + if (node == pri_node){ >> /* The primary timer lacks IRQ, use as clocksource */ >> - return integrator_clocksource_init(rate, base); >> + rc = integrator_clocksource_init(rate, base); >> + goto out; >> + } >> >> if (node == sec_node) { >> /* The secondary timer will drive the clock event */ >> irq = irq_of_parse_and_map(node, 0); >> - return integrator_clockevent_init(rate, base, irq); >> + rc = integrator_clockevent_init(rate, base, irq); >> + goto out; >> } >> >> pr_info("Timer @%p unused\n", base); >> clk_disable_unprepare(clk); >> +out: >> + of_node_put(sec_node); >> +out_put_pri_node: >> + of_node_put(pri_node); >> >> - return 0; >> + return rc; >> } >> >> TIMER_OF_DECLARE(integrator_ap_timer, "arm,integrator-timer", >> -- >> 2.17.0 >> > Hi Daniel: > > How about this? Hi, I think there is a simpler fix. The pri_node and the sec_node are used as an identifier to compare against the current node, we can directly drop the refcount after getting the node from path as it is not used as pointer. In addition, a single variable is needed, so we end up with a fix like that. alias_node = of_find_node_by_path(path); of_node_put(alias_node); if (node == alias_node) return integrator_clocksource_init(rate, base); > > Thanks, > Yangtao > -- <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs Follow Linaro: <http://www.facebook.com/pages/Linaro> Facebook | <http://twitter.com/#!/linaroorg> Twitter | <http://www.linaro.org/linaro-blog/> Blog ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() 2018-11-24 19:49 ` Daniel Lezcano @ 2018-11-25 4:25 ` Frank Lee 2018-11-25 9:41 ` Daniel Lezcano 0 siblings, 1 reply; 5+ messages in thread From: Frank Lee @ 2018-11-25 4:25 UTC (permalink / raw) To: Daniel Lezcano; +Cc: tglx, linux-kernel On Sun, Nov 25, 2018 at 3:49 AM Daniel Lezcano <daniel.lezcano@linaro.org> wrote: > > On 24/11/2018 15:58, Frank Lee wrote: > > On Thu, Nov 22, 2018 at 11:23 PM Yangtao Li <tiny.windzz@gmail.com> wrote: > >> > >> of_find_node_by_path() acquires a reference to the node > >> returned by it and that reference needs to be dropped by its caller. > >> integrator_ap_timer_init_of() doesn't do that, so fix it. > >> > >> Signed-off-by: Yangtao Li <tiny.windzz@gmail.com> > >> --- > >> drivers/clocksource/timer-integrator-ap.c | 20 ++++++++++++++------ > >> 1 file changed, 14 insertions(+), 6 deletions(-) > >> > >> diff --git a/drivers/clocksource/timer-integrator-ap.c b/drivers/clocksource/timer-integrator-ap.c > >> index 76e526f58620..1f04069470bb 100644 > >> --- a/drivers/clocksource/timer-integrator-ap.c > >> +++ b/drivers/clocksource/timer-integrator-ap.c > >> @@ -177,7 +177,7 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) > >> { > >> const char *path; > >> void __iomem *base; > >> - int err; > >> + int err,rc = 0; > >> int irq; > >> struct clk *clk; > >> unsigned long rate; > >> @@ -210,26 +210,34 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) > >> "arm,timer-secondary", &path); > >> if (err) { > >> pr_warn("Failed to read property\n"); > >> - return err; > >> + rc = err; > >> + goto out_put_pri_node; > >> } > >> > >> > >> sec_node = of_find_node_by_path(path); > >> > >> - if (node == pri_node) > >> + if (node == pri_node){ > >> /* The primary timer lacks IRQ, use as clocksource */ > >> - return integrator_clocksource_init(rate, base); > >> + rc = integrator_clocksource_init(rate, base); > >> + goto out; > >> + } > >> > >> if (node == sec_node) { > >> /* The secondary timer will drive the clock event */ > >> irq = irq_of_parse_and_map(node, 0); > >> - return integrator_clockevent_init(rate, base, irq); > >> + rc = integrator_clockevent_init(rate, base, irq); > >> + goto out; > >> } > >> > >> pr_info("Timer @%p unused\n", base); > >> clk_disable_unprepare(clk); > >> +out: > >> + of_node_put(sec_node); > >> +out_put_pri_node: > >> + of_node_put(pri_node); > >> > >> - return 0; > >> + return rc; > >> } > >> > >> TIMER_OF_DECLARE(integrator_ap_timer, "arm,integrator-timer", > >> -- > >> 2.17.0 > >> > > Hi Daniel: > > > > How about this? > > Hi, > > I think there is a simpler fix. The pri_node and the sec_node are used > as an identifier to compare against the current node, we can directly > drop the refcount after getting the node from path as it is not used as > pointer. In addition, a single variable is needed, so we end up with a > fix like that. > > alias_node = of_find_node_by_path(path); > of_node_put(alias_node); > if (node == alias_node) > return integrator_clocksource_init(rate, base); Daniel, OK,I will simplify it like you said.Although I think of_node_put should be called after we don't use node. MBR, Yangtao > > > > > > > Thanks, > > Yangtao > > > > > -- > <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs > > Follow Linaro: <http://www.facebook.com/pages/Linaro> Facebook | > <http://twitter.com/#!/linaroorg> Twitter | > <http://www.linaro.org/linaro-blog/> Blog > ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() 2018-11-25 4:25 ` Frank Lee @ 2018-11-25 9:41 ` Daniel Lezcano 0 siblings, 0 replies; 5+ messages in thread From: Daniel Lezcano @ 2018-11-25 9:41 UTC (permalink / raw) To: Frank Lee; +Cc: tglx, linux-kernel On 25/11/2018 05:25, Frank Lee wrote: > On Sun, Nov 25, 2018 at 3:49 AM Daniel Lezcano > <daniel.lezcano@linaro.org> wrote: >> >> On 24/11/2018 15:58, Frank Lee wrote: >>> On Thu, Nov 22, 2018 at 11:23 PM Yangtao Li <tiny.windzz@gmail.com> wrote: >>>> >>>> of_find_node_by_path() acquires a reference to the node >>>> returned by it and that reference needs to be dropped by its caller. >>>> integrator_ap_timer_init_of() doesn't do that, so fix it. >>>> >>>> Signed-off-by: Yangtao Li <tiny.windzz@gmail.com> >>>> --- >>>> drivers/clocksource/timer-integrator-ap.c | 20 ++++++++++++++------ >>>> 1 file changed, 14 insertions(+), 6 deletions(-) >>>> >>>> diff --git a/drivers/clocksource/timer-integrator-ap.c b/drivers/clocksource/timer-integrator-ap.c >>>> index 76e526f58620..1f04069470bb 100644 >>>> --- a/drivers/clocksource/timer-integrator-ap.c >>>> +++ b/drivers/clocksource/timer-integrator-ap.c >>>> @@ -177,7 +177,7 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) >>>> { >>>> const char *path; >>>> void __iomem *base; >>>> - int err; >>>> + int err,rc = 0; >>>> int irq; >>>> struct clk *clk; >>>> unsigned long rate; >>>> @@ -210,26 +210,34 @@ static int __init integrator_ap_timer_init_of(struct device_node *node) >>>> "arm,timer-secondary", &path); >>>> if (err) { >>>> pr_warn("Failed to read property\n"); >>>> - return err; >>>> + rc = err; >>>> + goto out_put_pri_node; >>>> } >>>> >>>> >>>> sec_node = of_find_node_by_path(path); >>>> >>>> - if (node == pri_node) >>>> + if (node == pri_node){ >>>> /* The primary timer lacks IRQ, use as clocksource */ >>>> - return integrator_clocksource_init(rate, base); >>>> + rc = integrator_clocksource_init(rate, base); >>>> + goto out; >>>> + } >>>> >>>> if (node == sec_node) { >>>> /* The secondary timer will drive the clock event */ >>>> irq = irq_of_parse_and_map(node, 0); >>>> - return integrator_clockevent_init(rate, base, irq); >>>> + rc = integrator_clockevent_init(rate, base, irq); >>>> + goto out; >>>> } >>>> >>>> pr_info("Timer @%p unused\n", base); >>>> clk_disable_unprepare(clk); >>>> +out: >>>> + of_node_put(sec_node); >>>> +out_put_pri_node: >>>> + of_node_put(pri_node); >>>> >>>> - return 0; >>>> + return rc; >>>> } >>>> >>>> TIMER_OF_DECLARE(integrator_ap_timer, "arm,integrator-timer", >>>> -- >>>> 2.17.0 >>>> >>> Hi Daniel: >>> >>> How about this? >> >> Hi, >> >> I think there is a simpler fix. The pri_node and the sec_node are used >> as an identifier to compare against the current node, we can directly >> drop the refcount after getting the node from path as it is not used as >> pointer. In addition, a single variable is needed, so we end up with a >> fix like that. >> >> alias_node = of_find_node_by_path(path); >> of_node_put(alias_node); >> if (node == alias_node) >> return integrator_clocksource_init(rate, base); > > Daniel, > > OK,I will simplify it like you said.Although I think of_node_put > should be called > after we don't use node. Except I'm missing something, we don't use the alias_node at any time. The node itself has already a refcount which gives us the guarantee it is valid. I agree it can appear a bit strange to put the node right after getting it but in our case the alias_node is used as an ID, not a pointer, so it is fine. -- <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs Follow Linaro: <http://www.facebook.com/pages/Linaro> Facebook | <http://twitter.com/#!/linaroorg> Twitter | <http://www.linaro.org/linaro-blog/> Blog ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2018-11-25 9:41 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2018-11-22 15:23 [PATCH] clocksource/drivers/integrator-ap: add missing of_node_put() Yangtao Li 2018-11-24 14:58 ` Frank Lee 2018-11-24 19:49 ` Daniel Lezcano 2018-11-25 4:25 ` Frank Lee 2018-11-25 9:41 ` Daniel Lezcano
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox