On 30.07.2015 09:06, Vladimir Zapolskiy wrote: > On 30.07.2015 02:37, Krzysztof Kozlowski wrote: >> 2015-07-30 5:15 GMT+09:00 Vladimir Zapolskiy <vz@xxxxxxxxx>: >>> The change fixes a bug introduced by 2be2a3ff42a5, memory allocated >>> by kstrdup_const() must be always deallocated with kfree_const(), >>> otherwise there is a risk of kfree'ing ro memory. >> >> This looks good. Can you provide also Cc-stable and fixes tags? > > Since the change fixes two independent issues I decided not to add a > particular commit to Fixes tag. I can split the commit of course, but I > feel reluctant to send a series in this particular case. > > Let me know your decision with respect to my comments. Although this is only error-path but still this applies for backporting to stable. Please split it up and add respective fixes tags. This helps companies/people using stable trees, including LTS. > >>> >>> Also remove unneeded of_node_put(), if for_each_compatible_node() body >>> execution is not terminated, this prevents from double kfree() in >>> OF_DYNAMIC build. >> >> Each iteration of for_each_compatible_node() has a check: >> (dn = of_find_compatible_node(dn, type, compatible)) >> this increases the references to 'np'. > > Correct. > >> If loop continues then previous 'np' is not of_node_put(). > > This I don't understand. The previous 'np' is of_node_put() on next > iteration of the loop, i.e. if and only if loop continues. Please elaborate. Step by step, if I get it right: 1. initialization: dn = of_find_compatible_node(NULL, type, compatible); 1a. if (!pd->base) then we want to drop that reference. 1b. if not, then loop itself 3. increase value: dn = of_find_compatible_node(dn, type, compatible) 4. next iteration of loop, now we have 'dn' from last 'increase value' 5. if (!pd->base) then we want to drop that reference. Best regards, Krzysztof > > -- > With best wishes, > Vladimir > >> >>> >>> Signed-off-by: Vladimir Zapolskiy <vz@xxxxxxxxx> >>> --- >>> arch/arm/mach-exynos/pm_domains.c | 3 +-- >>> 1 file changed, 1 insertion(+), 2 deletions(-) >>> >>> diff --git a/arch/arm/mach-exynos/pm_domains.c b/arch/arm/mach-exynos/pm_domains.c >>> index 6001f1c..4a87e86 100644 >>> --- a/arch/arm/mach-exynos/pm_domains.c >>> +++ b/arch/arm/mach-exynos/pm_domains.c >>> @@ -146,9 +146,8 @@ static __init int exynos4_pm_init_power_domain(void) >>> pd->base = of_iomap(np, 0); >>> if (!pd->base) { >>> pr_warn("%s: failed to map memory\n", __func__); >>> - kfree(pd->pd.name); >>> + kfree_const(pd->pd.name); >>> kfree(pd); >>> - of_node_put(np); >>> continue; >>> } >>> >>> -- >>> 2.1.4 >>> >>> >>> _______________________________________________ >>> linux-arm-kernel mailing list >>> linux-arm-kernel@xxxxxxxxxxxxxxxxxxx >>> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel > -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html