aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon/pwm-fan.c
diff options
context:
space:
mode:
authorLukasz Majewski <l.majewski@samsung.com>2015-02-26 08:59:35 -0500
committerGuenter Roeck <linux@roeck-us.net>2015-03-09 12:59:36 -0400
commitcb85ca332f4d72ca68464c55f63af0387f6bbdb1 (patch)
tree1deaaab9338faebcaf9f920cd8021724ac202485 /drivers/hwmon/pwm-fan.c
parent73ef85f42da2df8b567fea109c67ed53db937bcc (diff)
hwmon: (pwm-fan) Extract __set_pwm() function to only modify PWM duty cycle
It was necessary to decouple code handling writing to sysfs from the one responsible for setting PWM of the fan. Due to that, new __set_pwm() method was extracted, which is responsible for only setting new PWM duty cycle. Signed-off-by: Lukasz Majewski <l.majewski@samsung.com> Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Diffstat (limited to 'drivers/hwmon/pwm-fan.c')
-rw-r--r--drivers/hwmon/pwm-fan.c33
1 files changed, 21 insertions, 12 deletions
diff --git a/drivers/hwmon/pwm-fan.c b/drivers/hwmon/pwm-fan.c
index 1991d9032c38..bd42d3996a86 100644
--- a/drivers/hwmon/pwm-fan.c
+++ b/drivers/hwmon/pwm-fan.c
@@ -33,20 +33,14 @@ struct pwm_fan_ctx {
33 unsigned char pwm_value; 33 unsigned char pwm_value;
34}; 34};
35 35
36static ssize_t set_pwm(struct device *dev, struct device_attribute *attr, 36static int __set_pwm(struct pwm_fan_ctx *ctx, unsigned long pwm)
37 const char *buf, size_t count)
38{ 37{
39 struct pwm_fan_ctx *ctx = dev_get_drvdata(dev); 38 unsigned long duty;
40 unsigned long pwm, duty; 39 int ret = 0;
41 ssize_t ret;
42
43 if (kstrtoul(buf, 10, &pwm) || pwm > MAX_PWM)
44 return -EINVAL;
45 40
46 mutex_lock(&ctx->lock); 41 mutex_lock(&ctx->lock);
47
48 if (ctx->pwm_value == pwm) 42 if (ctx->pwm_value == pwm)
49 goto exit_set_pwm_no_change; 43 goto exit_set_pwm_err;
50 44
51 if (pwm == 0) { 45 if (pwm == 0) {
52 pwm_disable(ctx->pwm); 46 pwm_disable(ctx->pwm);
@@ -66,13 +60,28 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
66 60
67exit_set_pwm: 61exit_set_pwm:
68 ctx->pwm_value = pwm; 62 ctx->pwm_value = pwm;
69exit_set_pwm_no_change:
70 ret = count;
71exit_set_pwm_err: 63exit_set_pwm_err:
72 mutex_unlock(&ctx->lock); 64 mutex_unlock(&ctx->lock);
73 return ret; 65 return ret;
74} 66}
75 67
68static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
69 const char *buf, size_t count)
70{
71 struct pwm_fan_ctx *ctx = dev_get_drvdata(dev);
72 unsigned long pwm;
73 int ret;
74
75 if (kstrtoul(buf, 10, &pwm) || pwm > MAX_PWM)
76 return -EINVAL;
77
78 ret = __set_pwm(ctx, pwm);
79 if (ret)
80 return ret;
81
82 return count;
83}
84
76static ssize_t show_pwm(struct device *dev, 85static ssize_t show_pwm(struct device *dev,
77 struct device_attribute *attr, char *buf) 86 struct device_attribute *attr, char *buf)
78{ 87{