Commit 5696e4aa authored by Guenter Roeck's avatar Guenter Roeck

hwmon: (pwm-fan) Check return value from devm_add_action_or_reset

devm_add_action_or_reset() can fail due to a memory allocation failure.
Check for it and return the error if that happens.

Fixes: 37bcec5d ("hwmon: (pwm-fan) Use devm_thermal_of_cooling_device_register")
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
parent b9bb92e1
...@@ -320,8 +320,10 @@ static int pwm_fan_probe(struct platform_device *pdev) ...@@ -320,8 +320,10 @@ static int pwm_fan_probe(struct platform_device *pdev)
dev_err(dev, "Failed to enable fan supply: %d\n", ret); dev_err(dev, "Failed to enable fan supply: %d\n", ret);
return ret; return ret;
} }
devm_add_action_or_reset(dev, pwm_fan_regulator_disable, ret = devm_add_action_or_reset(dev, pwm_fan_regulator_disable,
ctx->reg_en); ctx->reg_en);
if (ret)
return ret;
} }
ctx->pwm_value = MAX_PWM; ctx->pwm_value = MAX_PWM;
...@@ -337,7 +339,9 @@ static int pwm_fan_probe(struct platform_device *pdev) ...@@ -337,7 +339,9 @@ static int pwm_fan_probe(struct platform_device *pdev)
return ret; return ret;
} }
timer_setup(&ctx->rpm_timer, sample_timer, 0); timer_setup(&ctx->rpm_timer, sample_timer, 0);
devm_add_action_or_reset(dev, pwm_fan_pwm_disable, ctx); ret = devm_add_action_or_reset(dev, pwm_fan_pwm_disable, ctx);
if (ret)
return ret;
of_property_read_u32(dev->of_node, "pulses-per-revolution", &ppr); of_property_read_u32(dev->of_node, "pulses-per-revolution", &ppr);
ctx->pulses_per_revolution = ppr; ctx->pulses_per_revolution = ppr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment