Skip to content

Commit d59c239

Browse files
MrVankrzk
authored andcommitted
pinctrl: samsung: Use scope based of_node_put() cleanups
Use scope based of_node_put() cleanup to simplify code. Signed-off-by: Peng Fan <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Krzysztof Kozlowski <[email protected]>
1 parent aa85d45 commit d59c239

File tree

2 files changed

+9
-26
lines changed

2 files changed

+9
-26
lines changed

drivers/pinctrl/samsung/pinctrl-exynos.c

Lines changed: 4 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -662,7 +662,7 @@ static void exynos_irq_demux_eint16_31(struct irq_desc *desc)
662662
__init int exynos_eint_wkup_init(struct samsung_pinctrl_drv_data *d)
663663
{
664664
struct device *dev = d->dev;
665-
struct device_node *wkup_np = NULL;
665+
struct device_node *wkup_np __free(device_node) = NULL;
666666
struct device_node *np;
667667
struct samsung_pin_bank *bank;
668668
struct exynos_weint_data *weint_data;
@@ -692,17 +692,14 @@ __init int exynos_eint_wkup_init(struct samsung_pinctrl_drv_data *d)
692692

693693
bank->irq_chip = devm_kmemdup(dev, irq_chip, sizeof(*irq_chip),
694694
GFP_KERNEL);
695-
if (!bank->irq_chip) {
696-
of_node_put(wkup_np);
695+
if (!bank->irq_chip)
697696
return -ENOMEM;
698-
}
699697
bank->irq_chip->chip.name = bank->name;
700698

701699
bank->irq_domain = irq_domain_create_linear(bank->fwnode,
702700
bank->nr_pins, &exynos_eint_irqd_ops, bank);
703701
if (!bank->irq_domain) {
704702
dev_err(dev, "wkup irq domain add failed\n");
705-
of_node_put(wkup_np);
706703
return -ENXIO;
707704
}
708705

@@ -715,10 +712,8 @@ __init int exynos_eint_wkup_init(struct samsung_pinctrl_drv_data *d)
715712
weint_data = devm_kcalloc(dev,
716713
bank->nr_pins, sizeof(*weint_data),
717714
GFP_KERNEL);
718-
if (!weint_data) {
719-
of_node_put(wkup_np);
715+
if (!weint_data)
720716
return -ENOMEM;
721-
}
722717

723718
for (idx = 0; idx < bank->nr_pins; ++idx) {
724719
irq = irq_of_parse_and_map(to_of_node(bank->fwnode), idx);
@@ -735,13 +730,10 @@ __init int exynos_eint_wkup_init(struct samsung_pinctrl_drv_data *d)
735730
}
736731
}
737732

738-
if (!muxed_banks) {
739-
of_node_put(wkup_np);
733+
if (!muxed_banks)
740734
return 0;
741-
}
742735

743736
irq = irq_of_parse_and_map(wkup_np, 0);
744-
of_node_put(wkup_np);
745737
if (!irq) {
746738
dev_err(dev, "irq number for muxed EINTs not found\n");
747739
return 0;

drivers/pinctrl/samsung/pinctrl-samsung.c

Lines changed: 5 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -251,7 +251,6 @@ static int samsung_dt_node_to_map(struct pinctrl_dev *pctldev,
251251
{
252252
struct samsung_pinctrl_drv_data *drvdata;
253253
unsigned reserved_maps;
254-
struct device_node *np;
255254
int ret;
256255

257256
drvdata = pinctrl_dev_get_drvdata(pctldev);
@@ -266,12 +265,11 @@ static int samsung_dt_node_to_map(struct pinctrl_dev *pctldev,
266265
&reserved_maps,
267266
num_maps);
268267

269-
for_each_child_of_node(np_config, np) {
268+
for_each_child_of_node_scoped(np_config, np) {
270269
ret = samsung_dt_subnode_to_map(drvdata, pctldev->dev, np, map,
271270
&reserved_maps, num_maps);
272271
if (ret < 0) {
273272
samsung_dt_free_map(pctldev, *map, *num_maps);
274-
of_node_put(np);
275273
return ret;
276274
}
277275
}
@@ -849,31 +847,24 @@ static struct samsung_pmx_func *samsung_pinctrl_create_functions(
849847
* and create pin groups and pin function lists.
850848
*/
851849
func_cnt = 0;
852-
for_each_child_of_node(dev_np, cfg_np) {
853-
struct device_node *func_np;
854-
850+
for_each_child_of_node_scoped(dev_np, cfg_np) {
855851
if (!of_get_child_count(cfg_np)) {
856852
ret = samsung_pinctrl_create_function(dev, drvdata,
857853
cfg_np, func);
858-
if (ret < 0) {
859-
of_node_put(cfg_np);
854+
if (ret < 0)
860855
return ERR_PTR(ret);
861-
}
862856
if (ret > 0) {
863857
++func;
864858
++func_cnt;
865859
}
866860
continue;
867861
}
868862

869-
for_each_child_of_node(cfg_np, func_np) {
863+
for_each_child_of_node_scoped(cfg_np, func_np) {
870864
ret = samsung_pinctrl_create_function(dev, drvdata,
871865
func_np, func);
872-
if (ret < 0) {
873-
of_node_put(func_np);
874-
of_node_put(cfg_np);
866+
if (ret < 0)
875867
return ERR_PTR(ret);
876-
}
877868
if (ret > 0) {
878869
++func;
879870
++func_cnt;

0 commit comments

Comments
 (0)