Commit 8d89afc6 authored by Marilene A Garcia's avatar Marilene A Garcia Committed by Lee Jones
Browse files

leds: tlc591xx: Replace of_node_put to __free



Use __free() for device_node values, and thus drop calls to
of_node_put().

The variable attribute __free() adds a scope based cleanup to
the device node. The goal is to reduce memory management issues
in the kernel code.

The for_each_available_child_of_node() was replaced to the equivalent
for_each_available_child_of_node_scoped() which uses the __free().

Suggested-by: default avatarJulia Lawall <julia.lawall@inria.fr>
Signed-off-by: default avatarMarilene A Garcia <marilene.agarcia@gmail.com>
Link: https://lore.kernel.org/r/20240611001740.10490-1-marilene.agarcia@gmail.com


Signed-off-by: default avatarLee Jones <lee@kernel.org>
parent 7e776e21
Loading
Loading
Loading
Loading
+7 −11
Original line number Diff line number Diff line
@@ -146,7 +146,7 @@ MODULE_DEVICE_TABLE(of, of_tlc591xx_leds_match);
static int
tlc591xx_probe(struct i2c_client *client)
{
	struct device_node *np, *child;
	struct device_node *np;
	struct device *dev = &client->dev;
	const struct tlc591xx *tlc591xx;
	struct tlc591xx_priv *priv;
@@ -182,22 +182,20 @@ tlc591xx_probe(struct i2c_client *client)
	if (err < 0)
		return err;

	for_each_available_child_of_node(np, child) {
	for_each_available_child_of_node_scoped(np, child) {
		struct tlc591xx_led *led;
		struct led_init_data init_data = {};

		init_data.fwnode = of_fwnode_handle(child);

		err = of_property_read_u32(child, "reg", &reg);
		if (err) {
			of_node_put(child);
		if (err)
			return err;
		}

		if (reg < 0 || reg >= tlc591xx->max_leds ||
		    priv->leds[reg].active) {
			of_node_put(child);
		    priv->leds[reg].active)
			return -EINVAL;
		}

		led = &priv->leds[reg];

		led->active = true;
@@ -207,13 +205,11 @@ tlc591xx_probe(struct i2c_client *client)
		led->ldev.max_brightness = TLC591XX_MAX_BRIGHTNESS;
		err = devm_led_classdev_register_ext(dev, &led->ldev,
						     &init_data);
		if (err < 0) {
			of_node_put(child);
		if (err < 0)
			return dev_err_probe(dev, err,
					     "couldn't register LED %s\n",
					     led->ldev.name);
	}
	}
	return 0;
}