aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorGuenter Roeck <linux@roeck-us.net>2013-01-09 11:09:34 -0500
committerGuenter Roeck <linux@roeck-us.net>2013-01-26 00:03:54 -0500
commit2a844c148e1f714ebf42cb96e1b172ce394c36c9 (patch)
treeeb68eb8438f0470e7a81b022199abe5f6d866879 /drivers
parent142c090184ac7f9763c5d22509405da3486f9801 (diff)
hwmon: Replace SENSORS_LIMIT with clamp_val
SENSORS_LIMIT and the generic clamp_val have the same functionality, and clamp_val is more efficient. This patch reduces text size by 9052 bytes and bss size by 11624 bytes for x86_64 builds. Signed-off-by: Guenter Roeck <linux@roeck-us.net> Acked-by: George Joseph <george.joseph@fairview5.com> Acked-by: Jean Delvare <khali@linux-fr.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/hwmon/ad7414.c2
-rw-r--r--drivers/hwmon/adm1021.c4
-rw-r--r--drivers/hwmon/adm1026.c16
-rw-r--r--drivers/hwmon/adm1031.c12
-rw-r--r--drivers/hwmon/adm9240.c6
-rw-r--r--drivers/hwmon/ads7828.c6
-rw-r--r--drivers/hwmon/adt7410.c10
-rw-r--r--drivers/hwmon/adt7462.c20
-rw-r--r--drivers/hwmon/adt7470.c20
-rw-r--r--drivers/hwmon/adt7475.c18
-rw-r--r--drivers/hwmon/amc6821.c32
-rw-r--r--drivers/hwmon/asb100.c10
-rw-r--r--drivers/hwmon/asc7621.c26
-rw-r--r--drivers/hwmon/dme1737.c15
-rw-r--r--drivers/hwmon/emc2103.c2
-rw-r--r--drivers/hwmon/emc6w201.c6
-rw-r--r--drivers/hwmon/f71882fg.c25
-rw-r--r--drivers/hwmon/f75375s.c12
-rw-r--r--drivers/hwmon/fschmd.c4
-rw-r--r--drivers/hwmon/g760a.c2
-rw-r--r--drivers/hwmon/gl518sm.c10
-rw-r--r--drivers/hwmon/gl520sm.c9
-rw-r--r--drivers/hwmon/it87.c13
-rw-r--r--drivers/hwmon/jc42.c6
-rw-r--r--drivers/hwmon/lm63.c8
-rw-r--r--drivers/hwmon/lm73.c4
-rw-r--r--drivers/hwmon/lm75.h2
-rw-r--r--drivers/hwmon/lm77.c2
-rw-r--r--drivers/hwmon/lm78.c6
-rw-r--r--drivers/hwmon/lm80.c8
-rw-r--r--drivers/hwmon/lm85.c10
-rw-r--r--drivers/hwmon/lm90.c2
-rw-r--r--drivers/hwmon/lm93.c28
-rw-r--r--drivers/hwmon/lm95245.c4
-rw-r--r--drivers/hwmon/max16065.c2
-rw-r--r--drivers/hwmon/max1668.c4
-rw-r--r--drivers/hwmon/max6639.c4
-rw-r--r--drivers/hwmon/max6642.c2
-rw-r--r--drivers/hwmon/max6650.c4
-rw-r--r--drivers/hwmon/pmbus/pmbus_core.c2
-rw-r--r--drivers/hwmon/sis5595.c6
-rw-r--r--drivers/hwmon/smsc47m1.c2
-rw-r--r--drivers/hwmon/smsc47m192.c4
-rw-r--r--drivers/hwmon/thmc50.c6
-rw-r--r--drivers/hwmon/tmp102.c2
-rw-r--r--drivers/hwmon/tmp401.c14
-rw-r--r--drivers/hwmon/via686a.c17
-rw-r--r--drivers/hwmon/vt1211.c10
-rw-r--r--drivers/hwmon/vt8231.c22
-rw-r--r--drivers/hwmon/w83627ehf.c17
-rw-r--r--drivers/hwmon/w83627hf.c23
-rw-r--r--drivers/hwmon/w83781d.c17
-rw-r--r--drivers/hwmon/w83791d.c10
-rw-r--r--drivers/hwmon/w83792d.c25
-rw-r--r--drivers/hwmon/w83793.c18
-rw-r--r--drivers/hwmon/w83795.c28
-rw-r--r--drivers/hwmon/w83l786ng.c17
57 files changed, 297 insertions, 319 deletions
diff --git a/drivers/hwmon/ad7414.c b/drivers/hwmon/ad7414.c
index f3a5d4764eb9..5d501adc3e54 100644
--- a/drivers/hwmon/ad7414.c
+++ b/drivers/hwmon/ad7414.c
@@ -137,7 +137,7 @@ static ssize_t set_max_min(struct device *dev,
137 if (ret < 0) 137 if (ret < 0)
138 return ret; 138 return ret;
139 139
140 temp = SENSORS_LIMIT(temp, -40000, 85000); 140 temp = clamp_val(temp, -40000, 85000);
141 temp = (temp + (temp < 0 ? -500 : 500)) / 1000; 141 temp = (temp + (temp < 0 ? -500 : 500)) / 1000;
142 142
143 mutex_lock(&data->lock); 143 mutex_lock(&data->lock);
diff --git a/drivers/hwmon/adm1021.c b/drivers/hwmon/adm1021.c
index fd1d1b15854e..71bcba8abfc0 100644
--- a/drivers/hwmon/adm1021.c
+++ b/drivers/hwmon/adm1021.c
@@ -193,7 +193,7 @@ static ssize_t set_temp_max(struct device *dev,
193 temp /= 1000; 193 temp /= 1000;
194 194
195 mutex_lock(&data->update_lock); 195 mutex_lock(&data->update_lock);
196 data->temp_max[index] = SENSORS_LIMIT(temp, -128, 127); 196 data->temp_max[index] = clamp_val(temp, -128, 127);
197 if (!read_only) 197 if (!read_only)
198 i2c_smbus_write_byte_data(client, ADM1021_REG_TOS_W(index), 198 i2c_smbus_write_byte_data(client, ADM1021_REG_TOS_W(index),
199 data->temp_max[index]); 199 data->temp_max[index]);
@@ -218,7 +218,7 @@ static ssize_t set_temp_min(struct device *dev,
218 temp /= 1000; 218 temp /= 1000;
219 219
220 mutex_lock(&data->update_lock); 220 mutex_lock(&data->update_lock);
221 data->temp_min[index] = SENSORS_LIMIT(temp, -128, 127); 221 data->temp_min[index] = clamp_val(temp, -128, 127);
222 if (!read_only) 222 if (!read_only)
223 i2c_smbus_write_byte_data(client, ADM1021_REG_THYST_W(index), 223 i2c_smbus_write_byte_data(client, ADM1021_REG_THYST_W(index),
224 data->temp_min[index]); 224 data->temp_min[index]);
diff --git a/drivers/hwmon/adm1026.c b/drivers/hwmon/adm1026.c
index 0f068e7297ee..ea09046e651d 100644
--- a/drivers/hwmon/adm1026.c
+++ b/drivers/hwmon/adm1026.c
@@ -197,7 +197,7 @@ static int adm1026_scaling[] = { /* .001 Volts */
197 }; 197 };
198#define NEG12_OFFSET 16000 198#define NEG12_OFFSET 16000
199#define SCALE(val, from, to) (((val)*(to) + ((from)/2))/(from)) 199#define SCALE(val, from, to) (((val)*(to) + ((from)/2))/(from))
200#define INS_TO_REG(n, val) (SENSORS_LIMIT(SCALE(val, adm1026_scaling[n], 192),\ 200#define INS_TO_REG(n, val) (clamp_val(SCALE(val, adm1026_scaling[n], 192),\
201 0, 255)) 201 0, 255))
202#define INS_FROM_REG(n, val) (SCALE(val, 192, adm1026_scaling[n])) 202#define INS_FROM_REG(n, val) (SCALE(val, 192, adm1026_scaling[n]))
203 203
@@ -207,7 +207,7 @@ static int adm1026_scaling[] = { /* .001 Volts */
207 * 22500 kHz * 60 (sec/min) * 2 (pulse) / 2 (pulse/rev) == 1350000 207 * 22500 kHz * 60 (sec/min) * 2 (pulse) / 2 (pulse/rev) == 1350000
208 */ 208 */
209#define FAN_TO_REG(val, div) ((val) <= 0 ? 0xff : \ 209#define FAN_TO_REG(val, div) ((val) <= 0 ? 0xff : \
210 SENSORS_LIMIT(1350000 / ((val) * (div)), \ 210 clamp_val(1350000 / ((val) * (div)), \
211 1, 254)) 211 1, 254))
212#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : (val) == 0xff ? 0 : \ 212#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : (val) == 0xff ? 0 : \
213 1350000 / ((val) * (div))) 213 1350000 / ((val) * (div)))
@@ -215,14 +215,14 @@ static int adm1026_scaling[] = { /* .001 Volts */
215#define DIV_TO_REG(val) ((val) >= 8 ? 3 : (val) >= 4 ? 2 : (val) >= 2 ? 1 : 0) 215#define DIV_TO_REG(val) ((val) >= 8 ? 3 : (val) >= 4 ? 2 : (val) >= 2 ? 1 : 0)
216 216
217/* Temperature is reported in 1 degC increments */ 217/* Temperature is reported in 1 degC increments */
218#define TEMP_TO_REG(val) (SENSORS_LIMIT(((val) + ((val) < 0 ? -500 : 500)) \ 218#define TEMP_TO_REG(val) (clamp_val(((val) + ((val) < 0 ? -500 : 500)) \
219 / 1000, -127, 127)) 219 / 1000, -127, 127))
220#define TEMP_FROM_REG(val) ((val) * 1000) 220#define TEMP_FROM_REG(val) ((val) * 1000)
221#define OFFSET_TO_REG(val) (SENSORS_LIMIT(((val) + ((val) < 0 ? -500 : 500)) \ 221#define OFFSET_TO_REG(val) (clamp_val(((val) + ((val) < 0 ? -500 : 500)) \
222 / 1000, -127, 127)) 222 / 1000, -127, 127))
223#define OFFSET_FROM_REG(val) ((val) * 1000) 223#define OFFSET_FROM_REG(val) ((val) * 1000)
224 224
225#define PWM_TO_REG(val) (SENSORS_LIMIT(val, 0, 255)) 225#define PWM_TO_REG(val) (clamp_val(val, 0, 255))
226#define PWM_FROM_REG(val) (val) 226#define PWM_FROM_REG(val) (val)
227 227
228#define PWM_MIN_TO_REG(val) ((val) & 0xf0) 228#define PWM_MIN_TO_REG(val) ((val) & 0xf0)
@@ -233,7 +233,7 @@ static int adm1026_scaling[] = { /* .001 Volts */
233 * indicates that the DAC could be used to drive the fans, but in our 233 * indicates that the DAC could be used to drive the fans, but in our
234 * example board (Arima HDAMA) it isn't connected to the fans at all. 234 * example board (Arima HDAMA) it isn't connected to the fans at all.
235 */ 235 */
236#define DAC_TO_REG(val) (SENSORS_LIMIT(((((val) * 255) + 500) / 2500), 0, 255)) 236#define DAC_TO_REG(val) (clamp_val(((((val) * 255) + 500) / 2500), 0, 255))
237#define DAC_FROM_REG(val) (((val) * 2500) / 255) 237#define DAC_FROM_REG(val) (((val) * 2500) / 255)
238 238
239/* 239/*
@@ -933,7 +933,7 @@ static void fixup_fan_min(struct device *dev, int fan, int old_div)
933 return; 933 return;
934 934
935 new_min = data->fan_min[fan] * old_div / new_div; 935 new_min = data->fan_min[fan] * old_div / new_div;
936 new_min = SENSORS_LIMIT(new_min, 1, 254); 936 new_min = clamp_val(new_min, 1, 254);
937 data->fan_min[fan] = new_min; 937 data->fan_min[fan] = new_min;
938 adm1026_write_value(client, ADM1026_REG_FAN_MIN(fan), new_min); 938 adm1026_write_value(client, ADM1026_REG_FAN_MIN(fan), new_min);
939} 939}
@@ -1527,7 +1527,7 @@ static ssize_t set_auto_pwm_min(struct device *dev,
1527 return err; 1527 return err;
1528 1528
1529 mutex_lock(&data->update_lock); 1529 mutex_lock(&data->update_lock);
1530 data->pwm1.auto_pwm_min = SENSORS_LIMIT(val, 0, 255); 1530 data->pwm1.auto_pwm_min = clamp_val(val, 0, 255);
1531 if (data->pwm1.enable == 2) { /* apply immediately */ 1531 if (data->pwm1.enable == 2) { /* apply immediately */
1532 data->pwm1.pwm = PWM_TO_REG((data->pwm1.pwm & 0x0f) | 1532 data->pwm1.pwm = PWM_TO_REG((data->pwm1.pwm & 0x0f) |
1533 PWM_MIN_TO_REG(data->pwm1.auto_pwm_min)); 1533 PWM_MIN_TO_REG(data->pwm1.auto_pwm_min));
diff --git a/drivers/hwmon/adm1031.c b/drivers/hwmon/adm1031.c
index c6a4631e833f..253ea396106d 100644
--- a/drivers/hwmon/adm1031.c
+++ b/drivers/hwmon/adm1031.c
@@ -162,13 +162,13 @@ adm1031_write_value(struct i2c_client *client, u8 reg, unsigned int value)
162static int FAN_TO_REG(int reg, int div) 162static int FAN_TO_REG(int reg, int div)
163{ 163{
164 int tmp; 164 int tmp;
165 tmp = FAN_FROM_REG(SENSORS_LIMIT(reg, 0, 65535), div); 165 tmp = FAN_FROM_REG(clamp_val(reg, 0, 65535), div);
166 return tmp > 255 ? 255 : tmp; 166 return tmp > 255 ? 255 : tmp;
167} 167}
168 168
169#define FAN_DIV_FROM_REG(reg) (1<<(((reg)&0xc0)>>6)) 169#define FAN_DIV_FROM_REG(reg) (1<<(((reg)&0xc0)>>6))
170 170
171#define PWM_TO_REG(val) (SENSORS_LIMIT((val), 0, 255) >> 4) 171#define PWM_TO_REG(val) (clamp_val((val), 0, 255) >> 4)
172#define PWM_FROM_REG(val) ((val) << 4) 172#define PWM_FROM_REG(val) ((val) << 4)
173 173
174#define FAN_CHAN_FROM_REG(reg) (((reg) >> 5) & 7) 174#define FAN_CHAN_FROM_REG(reg) (((reg) >> 5) & 7)
@@ -675,7 +675,7 @@ static ssize_t set_temp_offset(struct device *dev,
675 if (ret) 675 if (ret)
676 return ret; 676 return ret;
677 677
678 val = SENSORS_LIMIT(val, -15000, 15000); 678 val = clamp_val(val, -15000, 15000);
679 mutex_lock(&data->update_lock); 679 mutex_lock(&data->update_lock);
680 data->temp_offset[nr] = TEMP_OFFSET_TO_REG(val); 680 data->temp_offset[nr] = TEMP_OFFSET_TO_REG(val);
681 adm1031_write_value(client, ADM1031_REG_TEMP_OFFSET(nr), 681 adm1031_write_value(client, ADM1031_REG_TEMP_OFFSET(nr),
@@ -696,7 +696,7 @@ static ssize_t set_temp_min(struct device *dev, struct device_attribute *attr,
696 if (ret) 696 if (ret)
697 return ret; 697 return ret;
698 698
699 val = SENSORS_LIMIT(val, -55000, nr == 0 ? 127750 : 127875); 699 val = clamp_val(val, -55000, nr == 0 ? 127750 : 127875);
700 mutex_lock(&data->update_lock); 700 mutex_lock(&data->update_lock);
701 data->temp_min[nr] = TEMP_TO_REG(val); 701 data->temp_min[nr] = TEMP_TO_REG(val);
702 adm1031_write_value(client, ADM1031_REG_TEMP_MIN(nr), 702 adm1031_write_value(client, ADM1031_REG_TEMP_MIN(nr),
@@ -717,7 +717,7 @@ static ssize_t set_temp_max(struct device *dev, struct device_attribute *attr,
717 if (ret) 717 if (ret)
718 return ret; 718 return ret;
719 719
720 val = SENSORS_LIMIT(val, -55000, nr == 0 ? 127750 : 127875); 720 val = clamp_val(val, -55000, nr == 0 ? 127750 : 127875);
721 mutex_lock(&data->update_lock); 721 mutex_lock(&data->update_lock);
722 data->temp_max[nr] = TEMP_TO_REG(val); 722 data->temp_max[nr] = TEMP_TO_REG(val);
723 adm1031_write_value(client, ADM1031_REG_TEMP_MAX(nr), 723 adm1031_write_value(client, ADM1031_REG_TEMP_MAX(nr),
@@ -738,7 +738,7 @@ static ssize_t set_temp_crit(struct device *dev, struct device_attribute *attr,
738 if (ret) 738 if (ret)
739 return ret; 739 return ret;
740 740
741 val = SENSORS_LIMIT(val, -55000, nr == 0 ? 127750 : 127875); 741 val = clamp_val(val, -55000, nr == 0 ? 127750 : 127875);
742 mutex_lock(&data->update_lock); 742 mutex_lock(&data->update_lock);
743 data->temp_crit[nr] = TEMP_TO_REG(val); 743 data->temp_crit[nr] = TEMP_TO_REG(val);
744 adm1031_write_value(client, ADM1031_REG_TEMP_CRIT(nr), 744 adm1031_write_value(client, ADM1031_REG_TEMP_CRIT(nr),
diff --git a/drivers/hwmon/adm9240.c b/drivers/hwmon/adm9240.c
index dafa477715e3..2416628e0ab1 100644
--- a/drivers/hwmon/adm9240.c
+++ b/drivers/hwmon/adm9240.c
@@ -98,13 +98,13 @@ static inline unsigned int IN_FROM_REG(u8 reg, int n)
98 98
99static inline u8 IN_TO_REG(unsigned long val, int n) 99static inline u8 IN_TO_REG(unsigned long val, int n)
100{ 100{
101 return SENSORS_LIMIT(SCALE(val, 192, nom_mv[n]), 0, 255); 101 return clamp_val(SCALE(val, 192, nom_mv[n]), 0, 255);
102} 102}
103 103
104/* temperature range: -40..125, 127 disables temperature alarm */ 104/* temperature range: -40..125, 127 disables temperature alarm */
105static inline s8 TEMP_TO_REG(long val) 105static inline s8 TEMP_TO_REG(long val)
106{ 106{
107 return SENSORS_LIMIT(SCALE(val, 1, 1000), -40, 127); 107 return clamp_val(SCALE(val, 1, 1000), -40, 127);
108} 108}
109 109
110/* two fans, each with low fan speed limit */ 110/* two fans, each with low fan speed limit */
@@ -122,7 +122,7 @@ static inline unsigned int FAN_FROM_REG(u8 reg, u8 div)
122/* analog out 0..1250mV */ 122/* analog out 0..1250mV */
123static inline u8 AOUT_TO_REG(unsigned long val) 123static inline u8 AOUT_TO_REG(unsigned long val)
124{ 124{
125 return SENSORS_LIMIT(SCALE(val, 255, 1250), 0, 255); 125 return clamp_val(SCALE(val, 255, 1250), 0, 255);
126} 126}
127 127
128static inline unsigned int AOUT_FROM_REG(u8 reg) 128static inline unsigned int AOUT_FROM_REG(u8 reg)
diff --git a/drivers/hwmon/ads7828.c b/drivers/hwmon/ads7828.c
index 409b5c16defb..ba962ac4b81f 100644
--- a/drivers/hwmon/ads7828.c
+++ b/drivers/hwmon/ads7828.c
@@ -163,9 +163,9 @@ static int ads7828_probe(struct i2c_client *client,
163 163
164 /* Bound Vref with min/max values if it was provided */ 164 /* Bound Vref with min/max values if it was provided */
165 if (data->vref_mv) 165 if (data->vref_mv)
166 data->vref_mv = SENSORS_LIMIT(data->vref_mv, 166 data->vref_mv = clamp_val(data->vref_mv,
167 ADS7828_EXT_VREF_MV_MIN, 167 ADS7828_EXT_VREF_MV_MIN,
168 ADS7828_EXT_VREF_MV_MAX); 168 ADS7828_EXT_VREF_MV_MAX);
169 else 169 else
170 data->vref_mv = ADS7828_INT_VREF_MV; 170 data->vref_mv = ADS7828_INT_VREF_MV;
171 171
diff --git a/drivers/hwmon/adt7410.c b/drivers/hwmon/adt7410.c
index 030c8d7c33a5..797c2b85c483 100644
--- a/drivers/hwmon/adt7410.c
+++ b/drivers/hwmon/adt7410.c
@@ -173,8 +173,8 @@ abort:
173 173
174static s16 ADT7410_TEMP_TO_REG(long temp) 174static s16 ADT7410_TEMP_TO_REG(long temp)
175{ 175{
176 return DIV_ROUND_CLOSEST(SENSORS_LIMIT(temp, ADT7410_TEMP_MIN, 176 return DIV_ROUND_CLOSEST(clamp_val(temp, ADT7410_TEMP_MIN,
177 ADT7410_TEMP_MAX) * 128, 1000); 177 ADT7410_TEMP_MAX) * 128, 1000);
178} 178}
179 179
180static int ADT7410_REG_TO_TEMP(struct adt7410_data *data, s16 reg) 180static int ADT7410_REG_TO_TEMP(struct adt7410_data *data, s16 reg)
@@ -269,9 +269,9 @@ static ssize_t adt7410_set_t_hyst(struct device *dev,
269 return ret; 269 return ret;
270 /* convert absolute hysteresis value to a 4 bit delta value */ 270 /* convert absolute hysteresis value to a 4 bit delta value */
271 limit = ADT7410_REG_TO_TEMP(data, data->temp[1]); 271 limit = ADT7410_REG_TO_TEMP(data, data->temp[1]);
272 hyst = SENSORS_LIMIT(hyst, ADT7410_TEMP_MIN, ADT7410_TEMP_MAX); 272 hyst = clamp_val(hyst, ADT7410_TEMP_MIN, ADT7410_TEMP_MAX);
273 data->hyst = SENSORS_LIMIT(DIV_ROUND_CLOSEST(limit - hyst, 1000), 273 data->hyst = clamp_val(DIV_ROUND_CLOSEST(limit - hyst, 1000), 0,
274 0, ADT7410_T_HYST_MASK); 274 ADT7410_T_HYST_MASK);
275 ret = i2c_smbus_write_byte_data(client, ADT7410_T_HYST, data->hyst); 275 ret = i2c_smbus_write_byte_data(client, ADT7410_T_HYST, data->hyst);
276 if (ret) 276 if (ret)
277 return ret; 277 return ret;
diff --git a/drivers/hwmon/adt7462.c b/drivers/hwmon/adt7462.c
index 98a7d81e25c5..69481d3a3d23 100644
--- a/drivers/hwmon/adt7462.c
+++ b/drivers/hwmon/adt7462.c
@@ -836,7 +836,7 @@ static ssize_t set_temp_min(struct device *dev,
836 return -EINVAL; 836 return -EINVAL;
837 837
838 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64; 838 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64;
839 temp = SENSORS_LIMIT(temp, 0, 255); 839 temp = clamp_val(temp, 0, 255);
840 840
841 mutex_lock(&data->lock); 841 mutex_lock(&data->lock);
842 data->temp_min[attr->index] = temp; 842 data->temp_min[attr->index] = temp;
@@ -874,7 +874,7 @@ static ssize_t set_temp_max(struct device *dev,
874 return -EINVAL; 874 return -EINVAL;
875 875
876 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64; 876 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64;
877 temp = SENSORS_LIMIT(temp, 0, 255); 877 temp = clamp_val(temp, 0, 255);
878 878
879 mutex_lock(&data->lock); 879 mutex_lock(&data->lock);
880 data->temp_max[attr->index] = temp; 880 data->temp_max[attr->index] = temp;
@@ -939,7 +939,7 @@ static ssize_t set_volt_max(struct device *dev,
939 939
940 temp *= 1000; /* convert mV to uV */ 940 temp *= 1000; /* convert mV to uV */
941 temp = DIV_ROUND_CLOSEST(temp, x); 941 temp = DIV_ROUND_CLOSEST(temp, x);
942 temp = SENSORS_LIMIT(temp, 0, 255); 942 temp = clamp_val(temp, 0, 255);
943 943
944 mutex_lock(&data->lock); 944 mutex_lock(&data->lock);
945 data->volt_max[attr->index] = temp; 945 data->volt_max[attr->index] = temp;
@@ -981,7 +981,7 @@ static ssize_t set_volt_min(struct device *dev,
981 981
982 temp *= 1000; /* convert mV to uV */ 982 temp *= 1000; /* convert mV to uV */
983 temp = DIV_ROUND_CLOSEST(temp, x); 983 temp = DIV_ROUND_CLOSEST(temp, x);
984 temp = SENSORS_LIMIT(temp, 0, 255); 984 temp = clamp_val(temp, 0, 255);
985 985
986 mutex_lock(&data->lock); 986 mutex_lock(&data->lock);
987 data->volt_min[attr->index] = temp; 987 data->volt_min[attr->index] = temp;
@@ -1071,7 +1071,7 @@ static ssize_t set_fan_min(struct device *dev,
1071 1071
1072 temp = FAN_RPM_TO_PERIOD(temp); 1072 temp = FAN_RPM_TO_PERIOD(temp);
1073 temp >>= 8; 1073 temp >>= 8;
1074 temp = SENSORS_LIMIT(temp, 1, 255); 1074 temp = clamp_val(temp, 1, 255);
1075 1075
1076 mutex_lock(&data->lock); 1076 mutex_lock(&data->lock);
1077 data->fan_min[attr->index] = temp; 1077 data->fan_min[attr->index] = temp;
@@ -1149,7 +1149,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *devattr,
1149 if (kstrtol(buf, 10, &temp)) 1149 if (kstrtol(buf, 10, &temp))
1150 return -EINVAL; 1150 return -EINVAL;
1151 1151
1152 temp = SENSORS_LIMIT(temp, 0, 255); 1152 temp = clamp_val(temp, 0, 255);
1153 1153
1154 mutex_lock(&data->lock); 1154 mutex_lock(&data->lock);
1155 data->pwm[attr->index] = temp; 1155 data->pwm[attr->index] = temp;
@@ -1179,7 +1179,7 @@ static ssize_t set_pwm_max(struct device *dev,
1179 if (kstrtol(buf, 10, &temp)) 1179 if (kstrtol(buf, 10, &temp))
1180 return -EINVAL; 1180 return -EINVAL;
1181 1181
1182 temp = SENSORS_LIMIT(temp, 0, 255); 1182 temp = clamp_val(temp, 0, 255);
1183 1183
1184 mutex_lock(&data->lock); 1184 mutex_lock(&data->lock);
1185 data->pwm_max = temp; 1185 data->pwm_max = temp;
@@ -1211,7 +1211,7 @@ static ssize_t set_pwm_min(struct device *dev,
1211 if (kstrtol(buf, 10, &temp)) 1211 if (kstrtol(buf, 10, &temp))
1212 return -EINVAL; 1212 return -EINVAL;
1213 1213
1214 temp = SENSORS_LIMIT(temp, 0, 255); 1214 temp = clamp_val(temp, 0, 255);
1215 1215
1216 mutex_lock(&data->lock); 1216 mutex_lock(&data->lock);
1217 data->pwm_min[attr->index] = temp; 1217 data->pwm_min[attr->index] = temp;
@@ -1246,7 +1246,7 @@ static ssize_t set_pwm_hyst(struct device *dev,
1246 return -EINVAL; 1246 return -EINVAL;
1247 1247
1248 temp = DIV_ROUND_CLOSEST(temp, 1000); 1248 temp = DIV_ROUND_CLOSEST(temp, 1000);
1249 temp = SENSORS_LIMIT(temp, 0, 15); 1249 temp = clamp_val(temp, 0, 15);
1250 1250
1251 /* package things up */ 1251 /* package things up */
1252 temp &= ADT7462_PWM_HYST_MASK; 1252 temp &= ADT7462_PWM_HYST_MASK;
@@ -1333,7 +1333,7 @@ static ssize_t set_pwm_tmin(struct device *dev,
1333 return -EINVAL; 1333 return -EINVAL;
1334 1334
1335 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64; 1335 temp = DIV_ROUND_CLOSEST(temp, 1000) + 64;
1336 temp = SENSORS_LIMIT(temp, 0, 255); 1336 temp = clamp_val(temp, 0, 255);
1337 1337
1338 mutex_lock(&data->lock); 1338 mutex_lock(&data->lock);
1339 data->pwm_tmin[attr->index] = temp; 1339 data->pwm_tmin[attr->index] = temp;
diff --git a/drivers/hwmon/adt7470.c b/drivers/hwmon/adt7470.c
index 39ecb1a3b9ef..b83bf4bb95eb 100644
--- a/drivers/hwmon/adt7470.c
+++ b/drivers/hwmon/adt7470.c
@@ -452,7 +452,7 @@ static ssize_t set_auto_update_interval(struct device *dev,
452 if (kstrtol(buf, 10, &temp)) 452 if (kstrtol(buf, 10, &temp))
453 return -EINVAL; 453 return -EINVAL;
454 454
455 temp = SENSORS_LIMIT(temp, 0, 60000); 455 temp = clamp_val(temp, 0, 60000);
456 456
457 mutex_lock(&data->lock); 457 mutex_lock(&data->lock);
458 data->auto_update_interval = temp; 458 data->auto_update_interval = temp;
@@ -481,7 +481,7 @@ static ssize_t set_num_temp_sensors(struct device *dev,
481 if (kstrtol(buf, 10, &temp)) 481 if (kstrtol(buf, 10, &temp))
482 return -EINVAL; 482 return -EINVAL;
483 483
484 temp = SENSORS_LIMIT(temp, -1, 10); 484 temp = clamp_val(temp, -1, 10);
485 485
486 mutex_lock(&data->lock); 486 mutex_lock(&data->lock);
487 data->num_temp_sensors = temp; 487 data->num_temp_sensors = temp;
@@ -515,7 +515,7 @@ static ssize_t set_temp_min(struct device *dev,
515 return -EINVAL; 515 return -EINVAL;
516 516
517 temp = DIV_ROUND_CLOSEST(temp, 1000); 517 temp = DIV_ROUND_CLOSEST(temp, 1000);
518 temp = SENSORS_LIMIT(temp, 0, 255); 518 temp = clamp_val(temp, 0, 255);
519 519
520 mutex_lock(&data->lock); 520 mutex_lock(&data->lock);
521 data->temp_min[attr->index] = temp; 521 data->temp_min[attr->index] = temp;
@@ -549,7 +549,7 @@ static ssize_t set_temp_max(struct device *dev,
549 return -EINVAL; 549 return -EINVAL;
550 550
551 temp = DIV_ROUND_CLOSEST(temp, 1000); 551 temp = DIV_ROUND_CLOSEST(temp, 1000);
552 temp = SENSORS_LIMIT(temp, 0, 255); 552 temp = clamp_val(temp, 0, 255);
553 553
554 mutex_lock(&data->lock); 554 mutex_lock(&data->lock);
555 data->temp_max[attr->index] = temp; 555 data->temp_max[attr->index] = temp;
@@ -604,7 +604,7 @@ static ssize_t set_fan_max(struct device *dev,
604 return -EINVAL; 604 return -EINVAL;
605 605
606 temp = FAN_RPM_TO_PERIOD(temp); 606 temp = FAN_RPM_TO_PERIOD(temp);
607 temp = SENSORS_LIMIT(temp, 1, 65534); 607 temp = clamp_val(temp, 1, 65534);
608 608
609 mutex_lock(&data->lock); 609 mutex_lock(&data->lock);
610 data->fan_max[attr->index] = temp; 610 data->fan_max[attr->index] = temp;
@@ -641,7 +641,7 @@ static ssize_t set_fan_min(struct device *dev,
641 return -EINVAL; 641 return -EINVAL;
642 642
643 temp = FAN_RPM_TO_PERIOD(temp); 643 temp = FAN_RPM_TO_PERIOD(temp);
644 temp = SENSORS_LIMIT(temp, 1, 65534); 644 temp = clamp_val(temp, 1, 65534);
645 645
646 mutex_lock(&data->lock); 646 mutex_lock(&data->lock);
647 data->fan_min[attr->index] = temp; 647 data->fan_min[attr->index] = temp;
@@ -717,7 +717,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *devattr,
717 if (kstrtol(buf, 10, &temp)) 717 if (kstrtol(buf, 10, &temp))
718 return -EINVAL; 718 return -EINVAL;
719 719
720 temp = SENSORS_LIMIT(temp, 0, 255); 720 temp = clamp_val(temp, 0, 255);
721 721
722 mutex_lock(&data->lock); 722 mutex_lock(&data->lock);
723 data->pwm[attr->index] = temp; 723 data->pwm[attr->index] = temp;
@@ -749,7 +749,7 @@ static ssize_t set_pwm_max(struct device *dev,
749 if (kstrtol(buf, 10, &temp)) 749 if (kstrtol(buf, 10, &temp))
750 return -EINVAL; 750 return -EINVAL;
751 751
752 temp = SENSORS_LIMIT(temp, 0, 255); 752 temp = clamp_val(temp, 0, 255);
753 753
754 mutex_lock(&data->lock); 754 mutex_lock(&data->lock);
755 data->pwm_max[attr->index] = temp; 755 data->pwm_max[attr->index] = temp;
@@ -782,7 +782,7 @@ static ssize_t set_pwm_min(struct device *dev,
782 if (kstrtol(buf, 10, &temp)) 782 if (kstrtol(buf, 10, &temp))
783 return -EINVAL; 783 return -EINVAL;
784 784
785 temp = SENSORS_LIMIT(temp, 0, 255); 785 temp = clamp_val(temp, 0, 255);
786 786
787 mutex_lock(&data->lock); 787 mutex_lock(&data->lock);
788 data->pwm_min[attr->index] = temp; 788 data->pwm_min[attr->index] = temp;
@@ -826,7 +826,7 @@ static ssize_t set_pwm_tmin(struct device *dev,
826 return -EINVAL; 826 return -EINVAL;
827 827
828 temp = DIV_ROUND_CLOSEST(temp, 1000); 828 temp = DIV_ROUND_CLOSEST(temp, 1000);
829 temp = SENSORS_LIMIT(temp, 0, 255); 829 temp = clamp_val(temp, 0, 255);
830 830
831 mutex_lock(&data->lock); 831 mutex_lock(&data->lock);
832 data->pwm_tmin[attr->index] = temp; 832 data->pwm_tmin[attr->index] = temp;
diff --git a/drivers/hwmon/adt7475.c b/drivers/hwmon/adt7475.c
index 989e54c39252..22d008bbdc10 100644
--- a/drivers/hwmon/adt7475.c
+++ b/drivers/hwmon/adt7475.c
@@ -201,10 +201,10 @@ static inline u16 temp2reg(struct adt7475_data *data, long val)
201 u16 ret; 201 u16 ret;
202 202
203 if (!(data->config5 & CONFIG5_TWOSCOMP)) { 203 if (!(data->config5 & CONFIG5_TWOSCOMP)) {
204 val = SENSORS_LIMIT(val, -64000, 191000); 204 val = clamp_val(val, -64000, 191000);
205 ret = (val + 64500) / 1000; 205 ret = (val + 64500) / 1000;
206 } else { 206 } else {
207 val = SENSORS_LIMIT(val, -128000, 127000); 207 val = clamp_val(val, -128000, 127000);
208 if (val < -500) 208 if (val < -500)
209 ret = (256500 + val) / 1000; 209 ret = (256500 + val) / 1000;
210 else 210 else
@@ -240,7 +240,7 @@ static inline u16 rpm2tach(unsigned long rpm)
240 if (rpm == 0) 240 if (rpm == 0)
241 return 0; 241 return 0;
242 242
243 return SENSORS_LIMIT((90000 * 60) / rpm, 1, 0xFFFF); 243 return clamp_val((90000 * 60) / rpm, 1, 0xFFFF);
244} 244}
245 245
246/* Scaling factors for voltage inputs, taken from the ADT7490 datasheet */ 246/* Scaling factors for voltage inputs, taken from the ADT7490 datasheet */
@@ -271,7 +271,7 @@ static inline u16 volt2reg(int channel, long volt, u8 bypass_attn)
271 reg = (volt * 1024) / 2250; 271 reg = (volt * 1024) / 2250;
272 else 272 else
273 reg = (volt * r[1] * 1024) / ((r[0] + r[1]) * 2250); 273 reg = (volt * r[1] * 1024) / ((r[0] + r[1]) * 2250);
274 return SENSORS_LIMIT(reg, 0, 1023) & (0xff << 2); 274 return clamp_val(reg, 0, 1023) & (0xff << 2);
275} 275}
276 276
277static u16 adt7475_read_word(struct i2c_client *client, int reg) 277static u16 adt7475_read_word(struct i2c_client *client, int reg)
@@ -451,10 +451,10 @@ static ssize_t set_temp(struct device *dev, struct device_attribute *attr,
451 switch (sattr->nr) { 451 switch (sattr->nr) {
452 case OFFSET: 452 case OFFSET:
453 if (data->config5 & CONFIG5_TEMPOFFSET) { 453 if (data->config5 & CONFIG5_TEMPOFFSET) {
454 val = SENSORS_LIMIT(val, -63000, 127000); 454 val = clamp_val(val, -63000, 127000);
455 out = data->temp[OFFSET][sattr->index] = val / 1000; 455 out = data->temp[OFFSET][sattr->index] = val / 1000;
456 } else { 456 } else {
457 val = SENSORS_LIMIT(val, -63000, 64000); 457 val = clamp_val(val, -63000, 64000);
458 out = data->temp[OFFSET][sattr->index] = val / 500; 458 out = data->temp[OFFSET][sattr->index] = val / 500;
459 } 459 }
460 break; 460 break;
@@ -471,7 +471,7 @@ static ssize_t set_temp(struct device *dev, struct device_attribute *attr,
471 adt7475_read_hystersis(client); 471 adt7475_read_hystersis(client);
472 472
473 temp = reg2temp(data, data->temp[THERM][sattr->index]); 473 temp = reg2temp(data, data->temp[THERM][sattr->index]);
474 val = SENSORS_LIMIT(val, temp - 15000, temp); 474 val = clamp_val(val, temp - 15000, temp);
475 val = (temp - val) / 1000; 475 val = (temp - val) / 1000;
476 476
477 if (sattr->index != 1) { 477 if (sattr->index != 1) {
@@ -577,7 +577,7 @@ static ssize_t set_point2(struct device *dev, struct device_attribute *attr,
577 * to figure the range 577 * to figure the range
578 */ 578 */
579 temp = reg2temp(data, data->temp[AUTOMIN][sattr->index]); 579 temp = reg2temp(data, data->temp[AUTOMIN][sattr->index]);
580 val = SENSORS_LIMIT(val, temp + autorange_table[0], 580 val = clamp_val(val, temp + autorange_table[0],
581 temp + autorange_table[ARRAY_SIZE(autorange_table) - 1]); 581 temp + autorange_table[ARRAY_SIZE(autorange_table) - 1]);
582 val -= temp; 582 val -= temp;
583 583
@@ -701,7 +701,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
701 break; 701 break;
702 } 702 }
703 703
704 data->pwm[sattr->nr][sattr->index] = SENSORS_LIMIT(val, 0, 0xFF); 704 data->pwm[sattr->nr][sattr->index] = clamp_val(val, 0, 0xFF);
705 i2c_smbus_write_byte_data(client, reg, 705 i2c_smbus_write_byte_data(client, reg,
706 data->pwm[sattr->nr][sattr->index]); 706 data->pwm[sattr->nr][sattr->index]);
707 707
diff --git a/drivers/hwmon/amc6821.c b/drivers/hwmon/amc6821.c
index ae482e3afdac..4fe49d2bfe1d 100644
--- a/drivers/hwmon/amc6821.c
+++ b/drivers/hwmon/amc6821.c
@@ -241,7 +241,7 @@ static ssize_t set_temp(
241 int ret = kstrtol(buf, 10, &val); 241 int ret = kstrtol(buf, 10, &val);
242 if (ret) 242 if (ret)
243 return ret; 243 return ret;
244 val = SENSORS_LIMIT(val / 1000, -128, 127); 244 val = clamp_val(val / 1000, -128, 127);
245 245
246 mutex_lock(&data->update_lock); 246 mutex_lock(&data->update_lock);
247 data->temp[ix] = val; 247 data->temp[ix] = val;
@@ -332,7 +332,7 @@ static ssize_t set_pwm1(
332 return ret; 332 return ret;
333 333
334 mutex_lock(&data->update_lock); 334 mutex_lock(&data->update_lock);
335 data->pwm1 = SENSORS_LIMIT(val , 0, 255); 335 data->pwm1 = clamp_val(val , 0, 255);
336 i2c_smbus_write_byte_data(client, AMC6821_REG_DCY, data->pwm1); 336 i2c_smbus_write_byte_data(client, AMC6821_REG_DCY, data->pwm1);
337 mutex_unlock(&data->update_lock); 337 mutex_unlock(&data->update_lock);
338 return count; 338 return count;
@@ -499,11 +499,11 @@ static ssize_t set_temp_auto_point_temp(
499 mutex_lock(&data->update_lock); 499 mutex_lock(&data->update_lock);
500 switch (ix) { 500 switch (ix) {
501 case 0: 501 case 0:
502 ptemp[0] = SENSORS_LIMIT(val / 1000, 0, 502 ptemp[0] = clamp_val(val / 1000, 0,
503 data->temp1_auto_point_temp[1]); 503 data->temp1_auto_point_temp[1]);
504 ptemp[0] = SENSORS_LIMIT(ptemp[0], 0, 504 ptemp[0] = clamp_val(ptemp[0], 0,
505 data->temp2_auto_point_temp[1]); 505 data->temp2_auto_point_temp[1]);
506 ptemp[0] = SENSORS_LIMIT(ptemp[0], 0, 63); 506 ptemp[0] = clamp_val(ptemp[0], 0, 63);
507 if (i2c_smbus_write_byte_data( 507 if (i2c_smbus_write_byte_data(
508 client, 508 client,
509 AMC6821_REG_PSV_TEMP, 509 AMC6821_REG_PSV_TEMP,
@@ -515,20 +515,12 @@ static ssize_t set_temp_auto_point_temp(
515 goto EXIT; 515 goto EXIT;
516 break; 516 break;
517 case 1: 517 case 1:
518 ptemp[1] = SENSORS_LIMIT( 518 ptemp[1] = clamp_val(val / 1000, (ptemp[0] & 0x7C) + 4, 124);
519 val / 1000,
520 (ptemp[0] & 0x7C) + 4,
521 124);
522 ptemp[1] &= 0x7C; 519 ptemp[1] &= 0x7C;
523 ptemp[2] = SENSORS_LIMIT( 520 ptemp[2] = clamp_val(ptemp[2], ptemp[1] + 1, 255);
524 ptemp[2], ptemp[1] + 1,
525 255);
526 break; 521 break;
527 case 2: 522 case 2:
528 ptemp[2] = SENSORS_LIMIT( 523 ptemp[2] = clamp_val(val / 1000, ptemp[1]+1, 255);
529 val / 1000,
530 ptemp[1]+1,
531 255);
532 break; 524 break;
533 default: 525 default:
534 dev_dbg(dev, "Unknown attr->index (%d).\n", ix); 526 dev_dbg(dev, "Unknown attr->index (%d).\n", ix);
@@ -561,7 +553,7 @@ static ssize_t set_pwm1_auto_point_pwm(
561 return ret; 553 return ret;
562 554
563 mutex_lock(&data->update_lock); 555 mutex_lock(&data->update_lock);
564 data->pwm1_auto_point_pwm[1] = SENSORS_LIMIT(val, 0, 254); 556 data->pwm1_auto_point_pwm[1] = clamp_val(val, 0, 254);
565 if (i2c_smbus_write_byte_data(client, AMC6821_REG_DCY_LOW_TEMP, 557 if (i2c_smbus_write_byte_data(client, AMC6821_REG_DCY_LOW_TEMP,
566 data->pwm1_auto_point_pwm[1])) { 558 data->pwm1_auto_point_pwm[1])) {
567 dev_err(&client->dev, "Register write error, aborting.\n"); 559 dev_err(&client->dev, "Register write error, aborting.\n");
@@ -629,7 +621,7 @@ static ssize_t set_fan(
629 val = 1 > val ? 0xFFFF : 6000000/val; 621 val = 1 > val ? 0xFFFF : 6000000/val;
630 622
631 mutex_lock(&data->update_lock); 623 mutex_lock(&data->update_lock);
632 data->fan[ix] = (u16) SENSORS_LIMIT(val, 1, 0xFFFF); 624 data->fan[ix] = (u16) clamp_val(val, 1, 0xFFFF);
633 if (i2c_smbus_write_byte_data(client, fan_reg_low[ix], 625 if (i2c_smbus_write_byte_data(client, fan_reg_low[ix],
634 data->fan[ix] & 0xFF)) { 626 data->fan[ix] & 0xFF)) {
635 dev_err(&client->dev, "Register write error, aborting.\n"); 627 dev_err(&client->dev, "Register write error, aborting.\n");
diff --git a/drivers/hwmon/asb100.c b/drivers/hwmon/asb100.c
index 520e5bf4f76d..6ac612cabda1 100644
--- a/drivers/hwmon/asb100.c
+++ b/drivers/hwmon/asb100.c
@@ -114,7 +114,7 @@ static const u16 asb100_reg_temp_hyst[] = {0, 0x3a, 0x153, 0x253, 0x19};
114 */ 114 */
115static u8 IN_TO_REG(unsigned val) 115static u8 IN_TO_REG(unsigned val)
116{ 116{
117 unsigned nval = SENSORS_LIMIT(val, ASB100_IN_MIN, ASB100_IN_MAX); 117 unsigned nval = clamp_val(val, ASB100_IN_MIN, ASB100_IN_MAX);
118 return (nval + 8) / 16; 118 return (nval + 8) / 16;
119} 119}
120 120
@@ -129,8 +129,8 @@ static u8 FAN_TO_REG(long rpm, int div)
129 return 0; 129 return 0;
130 if (rpm == 0) 130 if (rpm == 0)
131 return 255; 131 return 255;
132 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 132 rpm = clamp_val(rpm, 1, 1000000);
133 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 133 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
134} 134}
135 135
136static int FAN_FROM_REG(u8 val, int div) 136static int FAN_FROM_REG(u8 val, int div)
@@ -148,7 +148,7 @@ static int FAN_FROM_REG(u8 val, int div)
148 */ 148 */
149static u8 TEMP_TO_REG(long temp) 149static u8 TEMP_TO_REG(long temp)
150{ 150{
151 int ntemp = SENSORS_LIMIT(temp, ASB100_TEMP_MIN, ASB100_TEMP_MAX); 151 int ntemp = clamp_val(temp, ASB100_TEMP_MIN, ASB100_TEMP_MAX);
152 ntemp += (ntemp < 0 ? -500 : 500); 152 ntemp += (ntemp < 0 ? -500 : 500);
153 return (u8)(ntemp / 1000); 153 return (u8)(ntemp / 1000);
154} 154}
@@ -164,7 +164,7 @@ static int TEMP_FROM_REG(u8 reg)
164 */ 164 */
165static u8 ASB100_PWM_TO_REG(int pwm) 165static u8 ASB100_PWM_TO_REG(int pwm)
166{ 166{
167 pwm = SENSORS_LIMIT(pwm, 0, 255); 167 pwm = clamp_val(pwm, 0, 255);
168 return (u8)(pwm / 16); 168 return (u8)(pwm / 16);
169} 169}
170 170
diff --git a/drivers/hwmon/asc7621.c b/drivers/hwmon/asc7621.c
index b867aab78049..da7f5b5d5db5 100644
--- a/drivers/hwmon/asc7621.c
+++ b/drivers/hwmon/asc7621.c
@@ -191,7 +191,7 @@ static ssize_t store_u8(struct device *dev, struct device_attribute *attr,
191 if (kstrtol(buf, 10, &reqval)) 191 if (kstrtol(buf, 10, &reqval))
192 return -EINVAL; 192 return -EINVAL;
193 193
194 reqval = SENSORS_LIMIT(reqval, 0, 255); 194 reqval = clamp_val(reqval, 0, 255);
195 195
196 mutex_lock(&data->update_lock); 196 mutex_lock(&data->update_lock);
197 data->reg[param->msb[0]] = reqval; 197 data->reg[param->msb[0]] = reqval;
@@ -224,7 +224,7 @@ static ssize_t store_bitmask(struct device *dev,
224 if (kstrtol(buf, 10, &reqval)) 224 if (kstrtol(buf, 10, &reqval))
225 return -EINVAL; 225 return -EINVAL;
226 226
227 reqval = SENSORS_LIMIT(reqval, 0, param->mask[0]); 227 reqval = clamp_val(reqval, 0, param->mask[0]);
228 228
229 reqval = (reqval & param->mask[0]) << param->shift[0]; 229 reqval = (reqval & param->mask[0]) << param->shift[0];
230 230
@@ -274,7 +274,7 @@ static ssize_t store_fan16(struct device *dev,
274 * generating an alarm. 274 * generating an alarm.
275 */ 275 */
276 reqval = 276 reqval =
277 (reqval <= 0 ? 0xffff : SENSORS_LIMIT(5400000 / reqval, 0, 0xfffe)); 277 (reqval <= 0 ? 0xffff : clamp_val(5400000 / reqval, 0, 0xfffe));
278 278
279 mutex_lock(&data->update_lock); 279 mutex_lock(&data->update_lock);
280 data->reg[param->msb[0]] = (reqval >> 8) & 0xff; 280 data->reg[param->msb[0]] = (reqval >> 8) & 0xff;
@@ -343,11 +343,11 @@ static ssize_t store_in8(struct device *dev, struct device_attribute *attr,
343 if (kstrtol(buf, 10, &reqval)) 343 if (kstrtol(buf, 10, &reqval))
344 return -EINVAL; 344 return -EINVAL;
345 345
346 reqval = SENSORS_LIMIT(reqval, 0, 0xffff); 346 reqval = clamp_val(reqval, 0, 0xffff);
347 347
348 reqval = reqval * 0xc0 / asc7621_in_scaling[nr]; 348 reqval = reqval * 0xc0 / asc7621_in_scaling[nr];
349 349
350 reqval = SENSORS_LIMIT(reqval, 0, 0xff); 350 reqval = clamp_val(reqval, 0, 0xff);
351 351
352 mutex_lock(&data->update_lock); 352 mutex_lock(&data->update_lock);
353 data->reg[param->msb[0]] = reqval; 353 data->reg[param->msb[0]] = reqval;
@@ -376,7 +376,7 @@ static ssize_t store_temp8(struct device *dev,
376 if (kstrtol(buf, 10, &reqval)) 376 if (kstrtol(buf, 10, &reqval))
377 return -EINVAL; 377 return -EINVAL;
378 378
379 reqval = SENSORS_LIMIT(reqval, -127000, 127000); 379 reqval = clamp_val(reqval, -127000, 127000);
380 380
381 temp = reqval / 1000; 381 temp = reqval / 1000;
382 382
@@ -432,7 +432,7 @@ static ssize_t store_temp62(struct device *dev,
432 if (kstrtol(buf, 10, &reqval)) 432 if (kstrtol(buf, 10, &reqval))
433 return -EINVAL; 433 return -EINVAL;
434 434
435 reqval = SENSORS_LIMIT(reqval, -32000, 31750); 435 reqval = clamp_val(reqval, -32000, 31750);
436 i = reqval / 1000; 436 i = reqval / 1000;
437 f = reqval - (i * 1000); 437 f = reqval - (i * 1000);
438 temp = i << 2; 438 temp = i << 2;
@@ -468,7 +468,7 @@ static ssize_t show_ap2_temp(struct device *dev,
468 auto_point1 = ((s8) data->reg[param->msb[1]]) * 1000; 468 auto_point1 = ((s8) data->reg[param->msb[1]]) * 1000;
469 regval = 469 regval =
470 ((data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0]); 470 ((data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0]);
471 temp = auto_point1 + asc7621_range_map[SENSORS_LIMIT(regval, 0, 15)]; 471 temp = auto_point1 + asc7621_range_map[clamp_val(regval, 0, 15)];
472 mutex_unlock(&data->update_lock); 472 mutex_unlock(&data->update_lock);
473 473
474 return sprintf(buf, "%d\n", temp); 474 return sprintf(buf, "%d\n", temp);
@@ -489,7 +489,7 @@ static ssize_t store_ap2_temp(struct device *dev,
489 489
490 mutex_lock(&data->update_lock); 490 mutex_lock(&data->update_lock);
491 auto_point1 = data->reg[param->msb[1]] * 1000; 491 auto_point1 = data->reg[param->msb[1]] * 1000;
492 reqval = SENSORS_LIMIT(reqval, auto_point1 + 2000, auto_point1 + 80000); 492 reqval = clamp_val(reqval, auto_point1 + 2000, auto_point1 + 80000);
493 493
494 for (i = ARRAY_SIZE(asc7621_range_map) - 1; i >= 0; i--) { 494 for (i = ARRAY_SIZE(asc7621_range_map) - 1; i >= 0; i--) {
495 if (reqval >= auto_point1 + asc7621_range_map[i]) { 495 if (reqval >= auto_point1 + asc7621_range_map[i]) {
@@ -523,7 +523,7 @@ static ssize_t show_pwm_ac(struct device *dev,
523 regval = config | (altbit << 3); 523 regval = config | (altbit << 3);
524 mutex_unlock(&data->update_lock); 524 mutex_unlock(&data->update_lock);
525 525
526 return sprintf(buf, "%u\n", map[SENSORS_LIMIT(regval, 0, 15)]); 526 return sprintf(buf, "%u\n", map[clamp_val(regval, 0, 15)]);
527} 527}
528 528
529static ssize_t store_pwm_ac(struct device *dev, 529static ssize_t store_pwm_ac(struct device *dev,
@@ -663,7 +663,7 @@ static ssize_t show_pwm_freq(struct device *dev,
663 u8 regval = 663 u8 regval =
664 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0]; 664 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0];
665 665
666 regval = SENSORS_LIMIT(regval, 0, 15); 666 regval = clamp_val(regval, 0, 15);
667 667
668 return sprintf(buf, "%u\n", asc7621_pwm_freq_map[regval]); 668 return sprintf(buf, "%u\n", asc7621_pwm_freq_map[regval]);
669} 669}
@@ -711,7 +711,7 @@ static ssize_t show_pwm_ast(struct device *dev,
711 u8 regval = 711 u8 regval =
712 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0]; 712 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0];
713 713
714 regval = SENSORS_LIMIT(regval, 0, 7); 714 regval = clamp_val(regval, 0, 7);
715 715
716 return sprintf(buf, "%u\n", asc7621_pwm_auto_spinup_map[regval]); 716 return sprintf(buf, "%u\n", asc7621_pwm_auto_spinup_map[regval]);
717 717
@@ -759,7 +759,7 @@ static ssize_t show_temp_st(struct device *dev,
759 SETUP_SHOW_data_param(dev, attr); 759 SETUP_SHOW_data_param(dev, attr);
760 u8 regval = 760 u8 regval =
761 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0]; 761 (data->reg[param->msb[0]] >> param->shift[0]) & param->mask[0];
762 regval = SENSORS_LIMIT(regval, 0, 7); 762 regval = clamp_val(regval, 0, 7);
763 763
764 return sprintf(buf, "%u\n", asc7621_temp_smoothing_time_map[regval]); 764 return sprintf(buf, "%u\n", asc7621_temp_smoothing_time_map[regval]);
765} 765}
diff --git a/drivers/hwmon/dme1737.c b/drivers/hwmon/dme1737.c
index 7430f70ae452..c347c94f2f73 100644
--- a/drivers/hwmon/dme1737.c
+++ b/drivers/hwmon/dme1737.c
@@ -277,7 +277,7 @@ static inline int IN_FROM_REG(int reg, int nominal, int res)
277 277
278static inline int IN_TO_REG(int val, int nominal) 278static inline int IN_TO_REG(int val, int nominal)
279{ 279{
280 return SENSORS_LIMIT((val * 192 + nominal / 2) / nominal, 0, 255); 280 return clamp_val((val * 192 + nominal / 2) / nominal, 0, 255);
281} 281}
282 282
283/* 283/*
@@ -293,8 +293,7 @@ static inline int TEMP_FROM_REG(int reg, int res)
293 293
294static inline int TEMP_TO_REG(int val) 294static inline int TEMP_TO_REG(int val)
295{ 295{
296 return SENSORS_LIMIT((val < 0 ? val - 500 : val + 500) / 1000, 296 return clamp_val((val < 0 ? val - 500 : val + 500) / 1000, -128, 127);
297 -128, 127);
298} 297}
299 298
300/* Temperature range */ 299/* Temperature range */
@@ -332,7 +331,7 @@ static inline int TEMP_HYST_FROM_REG(int reg, int ix)
332 331
333static inline int TEMP_HYST_TO_REG(int val, int ix, int reg) 332static inline int TEMP_HYST_TO_REG(int val, int ix, int reg)
334{ 333{
335 int hyst = SENSORS_LIMIT((val + 500) / 1000, 0, 15); 334 int hyst = clamp_val((val + 500) / 1000, 0, 15);
336 335
337 return (ix == 1) ? (reg & 0xf0) | hyst : (reg & 0x0f) | (hyst << 4); 336 return (ix == 1) ? (reg & 0xf0) | hyst : (reg & 0x0f) | (hyst << 4);
338} 337}
@@ -349,10 +348,10 @@ static inline int FAN_FROM_REG(int reg, int tpc)
349static inline int FAN_TO_REG(int val, int tpc) 348static inline int FAN_TO_REG(int val, int tpc)
350{ 349{
351 if (tpc) { 350 if (tpc) {
352 return SENSORS_LIMIT(val / tpc, 0, 0xffff); 351 return clamp_val(val / tpc, 0, 0xffff);
353 } else { 352 } else {
354 return (val <= 0) ? 0xffff : 353 return (val <= 0) ? 0xffff :
355 SENSORS_LIMIT(90000 * 60 / val, 0, 0xfffe); 354 clamp_val(90000 * 60 / val, 0, 0xfffe);
356 } 355 }
357} 356}
358 357
@@ -1282,7 +1281,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
1282 mutex_lock(&data->update_lock); 1281 mutex_lock(&data->update_lock);
1283 switch (fn) { 1282 switch (fn) {
1284 case SYS_PWM: 1283 case SYS_PWM:
1285 data->pwm[ix] = SENSORS_LIMIT(val, 0, 255); 1284 data->pwm[ix] = clamp_val(val, 0, 255);
1286 dme1737_write(data, DME1737_REG_PWM(ix), data->pwm[ix]); 1285 dme1737_write(data, DME1737_REG_PWM(ix), data->pwm[ix]);
1287 break; 1286 break;
1288 case SYS_PWM_FREQ: 1287 case SYS_PWM_FREQ:
@@ -1450,7 +1449,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
1450 break; 1449 break;
1451 case SYS_PWM_AUTO_POINT1_PWM: 1450 case SYS_PWM_AUTO_POINT1_PWM:
1452 /* Only valid for pwm[1-3] */ 1451 /* Only valid for pwm[1-3] */
1453 data->pwm_min[ix] = SENSORS_LIMIT(val, 0, 255); 1452 data->pwm_min[ix] = clamp_val(val, 0, 255);
1454 dme1737_write(data, DME1737_REG_PWM_MIN(ix), 1453 dme1737_write(data, DME1737_REG_PWM_MIN(ix),
1455 data->pwm_min[ix]); 1454 data->pwm_min[ix]);
1456 break; 1455 break;
diff --git a/drivers/hwmon/emc2103.c b/drivers/hwmon/emc2103.c
index 77f434c58236..b07305622087 100644
--- a/drivers/hwmon/emc2103.c
+++ b/drivers/hwmon/emc2103.c
@@ -405,7 +405,7 @@ static ssize_t set_fan_target(struct device *dev, struct device_attribute *da,
405 if (rpm_target == 0) 405 if (rpm_target == 0)
406 data->fan_target = 0x1fff; 406 data->fan_target = 0x1fff;
407 else 407 else
408 data->fan_target = SENSORS_LIMIT( 408 data->fan_target = clamp_val(
409 (FAN_RPM_FACTOR * data->fan_multiplier) / rpm_target, 409 (FAN_RPM_FACTOR * data->fan_multiplier) / rpm_target,
410 0, 0x1fff); 410 0, 0x1fff);
411 411
diff --git a/drivers/hwmon/emc6w201.c b/drivers/hwmon/emc6w201.c
index 789bd4fb329b..936898f82f94 100644
--- a/drivers/hwmon/emc6w201.c
+++ b/drivers/hwmon/emc6w201.c
@@ -220,7 +220,7 @@ static ssize_t set_in(struct device *dev, struct device_attribute *devattr,
220 : EMC6W201_REG_IN_HIGH(nr); 220 : EMC6W201_REG_IN_HIGH(nr);
221 221
222 mutex_lock(&data->update_lock); 222 mutex_lock(&data->update_lock);
223 data->in[sf][nr] = SENSORS_LIMIT(val, 0, 255); 223 data->in[sf][nr] = clamp_val(val, 0, 255);
224 err = emc6w201_write8(client, reg, data->in[sf][nr]); 224 err = emc6w201_write8(client, reg, data->in[sf][nr]);
225 mutex_unlock(&data->update_lock); 225 mutex_unlock(&data->update_lock);
226 226
@@ -257,7 +257,7 @@ static ssize_t set_temp(struct device *dev, struct device_attribute *devattr,
257 : EMC6W201_REG_TEMP_HIGH(nr); 257 : EMC6W201_REG_TEMP_HIGH(nr);
258 258
259 mutex_lock(&data->update_lock); 259 mutex_lock(&data->update_lock);
260 data->temp[sf][nr] = SENSORS_LIMIT(val, -127, 128); 260 data->temp[sf][nr] = clamp_val(val, -127, 128);
261 err = emc6w201_write8(client, reg, data->temp[sf][nr]); 261 err = emc6w201_write8(client, reg, data->temp[sf][nr]);
262 mutex_unlock(&data->update_lock); 262 mutex_unlock(&data->update_lock);
263 263
@@ -298,7 +298,7 @@ static ssize_t set_fan(struct device *dev, struct device_attribute *devattr,
298 val = 0xFFFF; 298 val = 0xFFFF;
299 } else { 299 } else {
300 val = DIV_ROUND_CLOSEST(5400000U, val); 300 val = DIV_ROUND_CLOSEST(5400000U, val);
301 val = SENSORS_LIMIT(val, 0, 0xFFFE); 301 val = clamp_val(val, 0, 0xFFFE);
302 } 302 }
303 303
304 mutex_lock(&data->update_lock); 304 mutex_lock(&data->update_lock);
diff --git a/drivers/hwmon/f71882fg.c b/drivers/hwmon/f71882fg.c
index bb7275cc47f3..cfb02dd91aad 100644
--- a/drivers/hwmon/f71882fg.c
+++ b/drivers/hwmon/f71882fg.c
@@ -1350,7 +1350,7 @@ static ssize_t store_fan_full_speed(struct device *dev,
1350 if (err) 1350 if (err)
1351 return err; 1351 return err;
1352 1352
1353 val = SENSORS_LIMIT(val, 23, 1500000); 1353 val = clamp_val(val, 23, 1500000);
1354 val = fan_to_reg(val); 1354 val = fan_to_reg(val);
1355 1355
1356 mutex_lock(&data->update_lock); 1356 mutex_lock(&data->update_lock);
@@ -1438,7 +1438,7 @@ static ssize_t store_in_max(struct device *dev, struct device_attribute
1438 return err; 1438 return err;
1439 1439
1440 val /= 8; 1440 val /= 8;
1441 val = SENSORS_LIMIT(val, 0, 255); 1441 val = clamp_val(val, 0, 255);
1442 1442
1443 mutex_lock(&data->update_lock); 1443 mutex_lock(&data->update_lock);
1444 f71882fg_write8(data, F71882FG_REG_IN1_HIGH, val); 1444 f71882fg_write8(data, F71882FG_REG_IN1_HIGH, val);
@@ -1542,7 +1542,7 @@ static ssize_t store_temp_max(struct device *dev, struct device_attribute
1542 return err; 1542 return err;
1543 1543
1544 val /= 1000; 1544 val /= 1000;
1545 val = SENSORS_LIMIT(val, 0, 255); 1545 val = clamp_val(val, 0, 255);
1546 1546
1547 mutex_lock(&data->update_lock); 1547 mutex_lock(&data->update_lock);
1548 f71882fg_write8(data, F71882FG_REG_TEMP_HIGH(nr), val); 1548 f71882fg_write8(data, F71882FG_REG_TEMP_HIGH(nr), val);
@@ -1589,8 +1589,7 @@ static ssize_t store_temp_max_hyst(struct device *dev, struct device_attribute
1589 1589
1590 /* convert abs to relative and check */ 1590 /* convert abs to relative and check */
1591 data->temp_high[nr] = f71882fg_read8(data, F71882FG_REG_TEMP_HIGH(nr)); 1591 data->temp_high[nr] = f71882fg_read8(data, F71882FG_REG_TEMP_HIGH(nr));
1592 val = SENSORS_LIMIT(val, data->temp_high[nr] - 15, 1592 val = clamp_val(val, data->temp_high[nr] - 15, data->temp_high[nr]);
1593 data->temp_high[nr]);
1594 val = data->temp_high[nr] - val; 1593 val = data->temp_high[nr] - val;
1595 1594
1596 /* convert value to register contents */ 1595 /* convert value to register contents */
@@ -1627,7 +1626,7 @@ static ssize_t store_temp_crit(struct device *dev, struct device_attribute
1627 return err; 1626 return err;
1628 1627
1629 val /= 1000; 1628 val /= 1000;
1630 val = SENSORS_LIMIT(val, 0, 255); 1629 val = clamp_val(val, 0, 255);
1631 1630
1632 mutex_lock(&data->update_lock); 1631 mutex_lock(&data->update_lock);
1633 f71882fg_write8(data, F71882FG_REG_TEMP_OVT(nr), val); 1632 f71882fg_write8(data, F71882FG_REG_TEMP_OVT(nr), val);
@@ -1754,7 +1753,7 @@ static ssize_t store_pwm(struct device *dev,
1754 if (err) 1753 if (err)
1755 return err; 1754 return err;
1756 1755
1757 val = SENSORS_LIMIT(val, 0, 255); 1756 val = clamp_val(val, 0, 255);
1758 1757
1759 mutex_lock(&data->update_lock); 1758 mutex_lock(&data->update_lock);
1760 data->pwm_enable = f71882fg_read8(data, F71882FG_REG_PWM_ENABLE); 1759 data->pwm_enable = f71882fg_read8(data, F71882FG_REG_PWM_ENABLE);
@@ -1805,7 +1804,7 @@ static ssize_t store_simple_pwm(struct device *dev,
1805 if (err) 1804 if (err)
1806 return err; 1805 return err;
1807 1806
1808 val = SENSORS_LIMIT(val, 0, 255); 1807 val = clamp_val(val, 0, 255);
1809 1808
1810 mutex_lock(&data->update_lock); 1809 mutex_lock(&data->update_lock);
1811 f71882fg_write8(data, F71882FG_REG_PWM(nr), val); 1810 f71882fg_write8(data, F71882FG_REG_PWM(nr), val);
@@ -1932,7 +1931,7 @@ static ssize_t store_pwm_auto_point_pwm(struct device *dev,
1932 if (err) 1931 if (err)
1933 return err; 1932 return err;
1934 1933
1935 val = SENSORS_LIMIT(val, 0, 255); 1934 val = clamp_val(val, 0, 255);
1936 1935
1937 mutex_lock(&data->update_lock); 1936 mutex_lock(&data->update_lock);
1938 data->pwm_enable = f71882fg_read8(data, F71882FG_REG_PWM_ENABLE); 1937 data->pwm_enable = f71882fg_read8(data, F71882FG_REG_PWM_ENABLE);
@@ -1991,8 +1990,8 @@ static ssize_t store_pwm_auto_point_temp_hyst(struct device *dev,
1991 mutex_lock(&data->update_lock); 1990 mutex_lock(&data->update_lock);
1992 data->pwm_auto_point_temp[nr][point] = 1991 data->pwm_auto_point_temp[nr][point] =
1993 f71882fg_read8(data, F71882FG_REG_POINT_TEMP(nr, point)); 1992 f71882fg_read8(data, F71882FG_REG_POINT_TEMP(nr, point));
1994 val = SENSORS_LIMIT(val, data->pwm_auto_point_temp[nr][point] - 15, 1993 val = clamp_val(val, data->pwm_auto_point_temp[nr][point] - 15,
1995 data->pwm_auto_point_temp[nr][point]); 1994 data->pwm_auto_point_temp[nr][point]);
1996 val = data->pwm_auto_point_temp[nr][point] - val; 1995 val = data->pwm_auto_point_temp[nr][point] - val;
1997 1996
1998 reg = f71882fg_read8(data, F71882FG_REG_FAN_HYST(nr / 2)); 1997 reg = f71882fg_read8(data, F71882FG_REG_FAN_HYST(nr / 2));
@@ -2126,9 +2125,9 @@ static ssize_t store_pwm_auto_point_temp(struct device *dev,
2126 val /= 1000; 2125 val /= 1000;
2127 2126
2128 if (data->auto_point_temp_signed) 2127 if (data->auto_point_temp_signed)
2129 val = SENSORS_LIMIT(val, -128, 127); 2128 val = clamp_val(val, -128, 127);
2130 else 2129 else
2131 val = SENSORS_LIMIT(val, 0, 127); 2130 val = clamp_val(val, 0, 127);
2132 2131
2133 mutex_lock(&data->update_lock); 2132 mutex_lock(&data->update_lock);
2134 f71882fg_write8(data, F71882FG_REG_POINT_TEMP(pwm, point), val); 2133 f71882fg_write8(data, F71882FG_REG_POINT_TEMP(pwm, point), val);
diff --git a/drivers/hwmon/f75375s.c b/drivers/hwmon/f75375s.c
index f7dba229395f..9e300e567f15 100644
--- a/drivers/hwmon/f75375s.c
+++ b/drivers/hwmon/f75375s.c
@@ -359,7 +359,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
359 return -EINVAL; 359 return -EINVAL;
360 360
361 mutex_lock(&data->update_lock); 361 mutex_lock(&data->update_lock);
362 data->pwm[nr] = SENSORS_LIMIT(val, 0, 255); 362 data->pwm[nr] = clamp_val(val, 0, 255);
363 f75375_write_pwm(client, nr); 363 f75375_write_pwm(client, nr);
364 mutex_unlock(&data->update_lock); 364 mutex_unlock(&data->update_lock);
365 return count; 365 return count;
@@ -556,7 +556,7 @@ static ssize_t set_in_max(struct device *dev, struct device_attribute *attr,
556 if (err < 0) 556 if (err < 0)
557 return err; 557 return err;
558 558
559 val = SENSORS_LIMIT(VOLT_TO_REG(val), 0, 0xff); 559 val = clamp_val(VOLT_TO_REG(val), 0, 0xff);
560 mutex_lock(&data->update_lock); 560 mutex_lock(&data->update_lock);
561 data->in_max[nr] = val; 561 data->in_max[nr] = val;
562 f75375_write8(client, F75375_REG_VOLT_HIGH(nr), data->in_max[nr]); 562 f75375_write8(client, F75375_REG_VOLT_HIGH(nr), data->in_max[nr]);
@@ -577,7 +577,7 @@ static ssize_t set_in_min(struct device *dev, struct device_attribute *attr,
577 if (err < 0) 577 if (err < 0)
578 return err; 578 return err;
579 579
580 val = SENSORS_LIMIT(VOLT_TO_REG(val), 0, 0xff); 580 val = clamp_val(VOLT_TO_REG(val), 0, 0xff);
581 mutex_lock(&data->update_lock); 581 mutex_lock(&data->update_lock);
582 data->in_min[nr] = val; 582 data->in_min[nr] = val;
583 f75375_write8(client, F75375_REG_VOLT_LOW(nr), data->in_min[nr]); 583 f75375_write8(client, F75375_REG_VOLT_LOW(nr), data->in_min[nr]);
@@ -625,7 +625,7 @@ static ssize_t set_temp_max(struct device *dev, struct device_attribute *attr,
625 if (err < 0) 625 if (err < 0)
626 return err; 626 return err;
627 627
628 val = SENSORS_LIMIT(TEMP_TO_REG(val), 0, 127); 628 val = clamp_val(TEMP_TO_REG(val), 0, 127);
629 mutex_lock(&data->update_lock); 629 mutex_lock(&data->update_lock);
630 data->temp_high[nr] = val; 630 data->temp_high[nr] = val;
631 f75375_write8(client, F75375_REG_TEMP_HIGH(nr), data->temp_high[nr]); 631 f75375_write8(client, F75375_REG_TEMP_HIGH(nr), data->temp_high[nr]);
@@ -646,7 +646,7 @@ static ssize_t set_temp_max_hyst(struct device *dev,
646 if (err < 0) 646 if (err < 0)
647 return err; 647 return err;
648 648
649 val = SENSORS_LIMIT(TEMP_TO_REG(val), 0, 127); 649 val = clamp_val(TEMP_TO_REG(val), 0, 127);
650 mutex_lock(&data->update_lock); 650 mutex_lock(&data->update_lock);
651 data->temp_max_hyst[nr] = val; 651 data->temp_max_hyst[nr] = val;
652 f75375_write8(client, F75375_REG_TEMP_HYST(nr), 652 f75375_write8(client, F75375_REG_TEMP_HYST(nr),
@@ -822,7 +822,7 @@ static void f75375_init(struct i2c_client *client, struct f75375_data *data,
822 if (auto_mode_enabled(f75375s_pdata->pwm_enable[nr]) || 822 if (auto_mode_enabled(f75375s_pdata->pwm_enable[nr]) ||
823 !duty_mode_enabled(f75375s_pdata->pwm_enable[nr])) 823 !duty_mode_enabled(f75375s_pdata->pwm_enable[nr]))
824 continue; 824 continue;
825 data->pwm[nr] = SENSORS_LIMIT(f75375s_pdata->pwm[nr], 0, 255); 825 data->pwm[nr] = clamp_val(f75375s_pdata->pwm[nr], 0, 255);
826 f75375_write_pwm(client, nr); 826 f75375_write_pwm(client, nr);
827 } 827 }
828 828
diff --git a/drivers/hwmon/fschmd.c b/drivers/hwmon/fschmd.c
index 519ce8b9c142..8af2755cdb87 100644
--- a/drivers/hwmon/fschmd.c
+++ b/drivers/hwmon/fschmd.c
@@ -379,7 +379,7 @@ static ssize_t store_temp_max(struct device *dev, struct device_attribute
379 if (err) 379 if (err)
380 return err; 380 return err;
381 381
382 v = SENSORS_LIMIT(v / 1000, -128, 127) + 128; 382 v = clamp_val(v / 1000, -128, 127) + 128;
383 383
384 mutex_lock(&data->update_lock); 384 mutex_lock(&data->update_lock);
385 i2c_smbus_write_byte_data(to_i2c_client(dev), 385 i2c_smbus_write_byte_data(to_i2c_client(dev),
@@ -540,7 +540,7 @@ static ssize_t store_pwm_auto_point1_pwm(struct device *dev,
540 540
541 /* reg: 0 = allow turning off (except on the syl), 1-255 = 50-100% */ 541 /* reg: 0 = allow turning off (except on the syl), 1-255 = 50-100% */
542 if (v || data->kind == fscsyl) { 542 if (v || data->kind == fscsyl) {
543 v = SENSORS_LIMIT(v, 128, 255); 543 v = clamp_val(v, 128, 255);
544 v = (v - 128) * 2 + 1; 544 v = (v - 128) * 2 + 1;
545 } 545 }
546 546
diff --git a/drivers/hwmon/g760a.c b/drivers/hwmon/g760a.c
index 8b2106f60eda..ea6480b80e7f 100644
--- a/drivers/hwmon/g760a.c
+++ b/drivers/hwmon/g760a.c
@@ -171,7 +171,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *da,
171 return -EINVAL; 171 return -EINVAL;
172 172
173 mutex_lock(&data->update_lock); 173 mutex_lock(&data->update_lock);
174 data->set_cnt = PWM_TO_CNT(SENSORS_LIMIT(val, 0, 255)); 174 data->set_cnt = PWM_TO_CNT(clamp_val(val, 0, 255));
175 g760a_write_value(client, G760A_REG_SET_CNT, data->set_cnt); 175 g760a_write_value(client, G760A_REG_SET_CNT, data->set_cnt);
176 mutex_unlock(&data->update_lock); 176 mutex_unlock(&data->update_lock);
177 177
diff --git a/drivers/hwmon/gl518sm.c b/drivers/hwmon/gl518sm.c
index 2c74673f48e5..e2e5909a34df 100644
--- a/drivers/hwmon/gl518sm.c
+++ b/drivers/hwmon/gl518sm.c
@@ -86,7 +86,7 @@ enum chips { gl518sm_r00, gl518sm_r80 };
86#define BOOL_FROM_REG(val) ((val) ? 0 : 1) 86#define BOOL_FROM_REG(val) ((val) ? 0 : 1)
87#define BOOL_TO_REG(val) ((val) ? 0 : 1) 87#define BOOL_TO_REG(val) ((val) ? 0 : 1)
88 88
89#define TEMP_TO_REG(val) SENSORS_LIMIT(((((val) < 0 ? \ 89#define TEMP_TO_REG(val) clamp_val(((((val) < 0 ? \
90 (val) - 500 : \ 90 (val) - 500 : \
91 (val) + 500) / 1000) + 119), 0, 255) 91 (val) + 500) / 1000) + 119), 0, 255)
92#define TEMP_FROM_REG(val) (((val) - 119) * 1000) 92#define TEMP_FROM_REG(val) (((val) - 119) * 1000)
@@ -96,15 +96,15 @@ static inline u8 FAN_TO_REG(long rpm, int div)
96 long rpmdiv; 96 long rpmdiv;
97 if (rpm == 0) 97 if (rpm == 0)
98 return 0; 98 return 0;
99 rpmdiv = SENSORS_LIMIT(rpm, 1, 960000) * div; 99 rpmdiv = clamp_val(rpm, 1, 960000) * div;
100 return SENSORS_LIMIT((480000 + rpmdiv / 2) / rpmdiv, 1, 255); 100 return clamp_val((480000 + rpmdiv / 2) / rpmdiv, 1, 255);
101} 101}
102#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (480000 / ((val) * (div)))) 102#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (480000 / ((val) * (div))))
103 103
104#define IN_TO_REG(val) SENSORS_LIMIT((((val) + 9) / 19), 0, 255) 104#define IN_TO_REG(val) clamp_val((((val) + 9) / 19), 0, 255)
105#define IN_FROM_REG(val) ((val) * 19) 105#define IN_FROM_REG(val) ((val) * 19)
106 106
107#define VDD_TO_REG(val) SENSORS_LIMIT((((val) * 4 + 47) / 95), 0, 255) 107#define VDD_TO_REG(val) clamp_val((((val) * 4 + 47) / 95), 0, 255)
108#define VDD_FROM_REG(val) (((val) * 95 + 2) / 4) 108#define VDD_FROM_REG(val) (((val) * 95 + 2) / 4)
109 109
110#define DIV_FROM_REG(val) (1 << (val)) 110#define DIV_FROM_REG(val) (1 << (val))
diff --git a/drivers/hwmon/gl520sm.c b/drivers/hwmon/gl520sm.c
index a21ff252f2f1..ed56e09c3dd7 100644
--- a/drivers/hwmon/gl520sm.c
+++ b/drivers/hwmon/gl520sm.c
@@ -144,10 +144,10 @@ static ssize_t get_cpu_vid(struct device *dev, struct device_attribute *attr,
144static DEVICE_ATTR(cpu0_vid, S_IRUGO, get_cpu_vid, NULL); 144static DEVICE_ATTR(cpu0_vid, S_IRUGO, get_cpu_vid, NULL);
145 145
146#define VDD_FROM_REG(val) (((val) * 95 + 2) / 4) 146#define VDD_FROM_REG(val) (((val) * 95 + 2) / 4)
147#define VDD_TO_REG(val) SENSORS_LIMIT((((val) * 4 + 47) / 95), 0, 255) 147#define VDD_TO_REG(val) clamp_val((((val) * 4 + 47) / 95), 0, 255)
148 148
149#define IN_FROM_REG(val) ((val) * 19) 149#define IN_FROM_REG(val) ((val) * 19)
150#define IN_TO_REG(val) SENSORS_LIMIT((((val) + 9) / 19), 0, 255) 150#define IN_TO_REG(val) clamp_val((((val) + 9) / 19), 0, 255)
151 151
152static ssize_t get_in_input(struct device *dev, struct device_attribute *attr, 152static ssize_t get_in_input(struct device *dev, struct device_attribute *attr,
153 char *buf) 153 char *buf)
@@ -285,8 +285,7 @@ static SENSOR_DEVICE_ATTR(in4_max, S_IRUGO | S_IWUSR,
285#define DIV_FROM_REG(val) (1 << (val)) 285#define DIV_FROM_REG(val) (1 << (val))
286#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (480000 / ((val) << (div)))) 286#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (480000 / ((val) << (div))))
287#define FAN_TO_REG(val, div) ((val) <= 0 ? 0 : \ 287#define FAN_TO_REG(val, div) ((val) <= 0 ? 0 : \
288 SENSORS_LIMIT((480000 + ((val) << ((div)-1))) / ((val) << (div)), 1, \ 288 clamp_val((480000 + ((val) << ((div)-1))) / ((val) << (div)), 1, 255))
289 255))
290 289
291static ssize_t get_fan_input(struct device *dev, struct device_attribute *attr, 290static ssize_t get_fan_input(struct device *dev, struct device_attribute *attr,
292 char *buf) 291 char *buf)
@@ -450,7 +449,7 @@ static DEVICE_ATTR(fan1_off, S_IRUGO | S_IWUSR,
450 get_fan_off, set_fan_off); 449 get_fan_off, set_fan_off);
451 450
452#define TEMP_FROM_REG(val) (((val) - 130) * 1000) 451#define TEMP_FROM_REG(val) (((val) - 130) * 1000)
453#define TEMP_TO_REG(val) SENSORS_LIMIT(((((val) < 0 ? \ 452#define TEMP_TO_REG(val) clamp_val(((((val) < 0 ? \
454 (val) - 500 : (val) + 500) / 1000) + 130), 0, 255) 453 (val) - 500 : (val) + 500) / 1000) + 130), 0, 255)
455 454
456static ssize_t get_temp_input(struct device *dev, struct device_attribute *attr, 455static ssize_t get_temp_input(struct device *dev, struct device_attribute *attr,
diff --git a/drivers/hwmon/it87.c b/drivers/hwmon/it87.c
index 117d66fcded6..29632e849285 100644
--- a/drivers/hwmon/it87.c
+++ b/drivers/hwmon/it87.c
@@ -384,7 +384,7 @@ static int adc_lsb(const struct it87_data *data, int nr)
384static u8 in_to_reg(const struct it87_data *data, int nr, long val) 384static u8 in_to_reg(const struct it87_data *data, int nr, long val)
385{ 385{
386 val = DIV_ROUND_CLOSEST(val, adc_lsb(data, nr)); 386 val = DIV_ROUND_CLOSEST(val, adc_lsb(data, nr));
387 return SENSORS_LIMIT(val, 0, 255); 387 return clamp_val(val, 0, 255);
388} 388}
389 389
390static int in_from_reg(const struct it87_data *data, int nr, int val) 390static int in_from_reg(const struct it87_data *data, int nr, int val)
@@ -396,16 +396,15 @@ static inline u8 FAN_TO_REG(long rpm, int div)
396{ 396{
397 if (rpm == 0) 397 if (rpm == 0)
398 return 255; 398 return 255;
399 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 399 rpm = clamp_val(rpm, 1, 1000000);
400 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 400 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
401 254);
402} 401}
403 402
404static inline u16 FAN16_TO_REG(long rpm) 403static inline u16 FAN16_TO_REG(long rpm)
405{ 404{
406 if (rpm == 0) 405 if (rpm == 0)
407 return 0xffff; 406 return 0xffff;
408 return SENSORS_LIMIT((1350000 + rpm) / (rpm * 2), 1, 0xfffe); 407 return clamp_val((1350000 + rpm) / (rpm * 2), 1, 0xfffe);
409} 408}
410 409
411#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : (val) == 255 ? 0 : \ 410#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : (val) == 255 ? 0 : \
@@ -414,8 +413,8 @@ static inline u16 FAN16_TO_REG(long rpm)
414#define FAN16_FROM_REG(val) ((val) == 0 ? -1 : (val) == 0xffff ? 0 : \ 413#define FAN16_FROM_REG(val) ((val) == 0 ? -1 : (val) == 0xffff ? 0 : \
415 1350000 / ((val) * 2)) 414 1350000 / ((val) * 2))
416 415
417#define TEMP_TO_REG(val) (SENSORS_LIMIT(((val) < 0 ? (((val) - 500) / 1000) : \ 416#define TEMP_TO_REG(val) (clamp_val(((val) < 0 ? (((val) - 500) / 1000) : \
418 ((val) + 500) / 1000), -128, 127)) 417 ((val) + 500) / 1000), -128, 127))
419#define TEMP_FROM_REG(val) ((val) * 1000) 418#define TEMP_FROM_REG(val) ((val) * 1000)
420 419
421static u8 pwm_to_reg(const struct it87_data *data, long val) 420static u8 pwm_to_reg(const struct it87_data *data, long val)
diff --git a/drivers/hwmon/jc42.c b/drivers/hwmon/jc42.c
index e21e43c13156..82d962488f55 100644
--- a/drivers/hwmon/jc42.c
+++ b/drivers/hwmon/jc42.c
@@ -237,9 +237,9 @@ static struct i2c_driver jc42_driver = {
237 237
238static u16 jc42_temp_to_reg(int temp, bool extended) 238static u16 jc42_temp_to_reg(int temp, bool extended)
239{ 239{
240 int ntemp = SENSORS_LIMIT(temp, 240 int ntemp = clamp_val(temp,
241 extended ? JC42_TEMP_MIN_EXTENDED : 241 extended ? JC42_TEMP_MIN_EXTENDED :
242 JC42_TEMP_MIN, JC42_TEMP_MAX); 242 JC42_TEMP_MIN, JC42_TEMP_MAX);
243 243
244 /* convert from 0.001 to 0.0625 resolution */ 244 /* convert from 0.001 to 0.0625 resolution */
245 return (ntemp * 2 / 125) & 0x1fff; 245 return (ntemp * 2 / 125) & 0x1fff;
diff --git a/drivers/hwmon/lm63.c b/drivers/hwmon/lm63.c
index eed4d9401788..f644a2e57599 100644
--- a/drivers/hwmon/lm63.c
+++ b/drivers/hwmon/lm63.c
@@ -209,9 +209,9 @@ static inline int lut_temp_to_reg(struct lm63_data *data, long val)
209{ 209{
210 val -= data->temp2_offset; 210 val -= data->temp2_offset;
211 if (data->lut_temp_highres) 211 if (data->lut_temp_highres)
212 return DIV_ROUND_CLOSEST(SENSORS_LIMIT(val, 0, 127500), 500); 212 return DIV_ROUND_CLOSEST(clamp_val(val, 0, 127500), 500);
213 else 213 else
214 return DIV_ROUND_CLOSEST(SENSORS_LIMIT(val, 0, 127000), 1000); 214 return DIV_ROUND_CLOSEST(clamp_val(val, 0, 127000), 1000);
215} 215}
216 216
217/* 217/*
@@ -415,7 +415,7 @@ static ssize_t set_pwm1(struct device *dev, struct device_attribute *devattr,
415 return err; 415 return err;
416 416
417 reg = nr ? LM63_REG_LUT_PWM(nr - 1) : LM63_REG_PWM_VALUE; 417 reg = nr ? LM63_REG_LUT_PWM(nr - 1) : LM63_REG_PWM_VALUE;
418 val = SENSORS_LIMIT(val, 0, 255); 418 val = clamp_val(val, 0, 255);
419 419
420 mutex_lock(&data->update_lock); 420 mutex_lock(&data->update_lock);
421 data->pwm1[nr] = data->pwm_highres ? val : 421 data->pwm1[nr] = data->pwm_highres ? val :
@@ -700,7 +700,7 @@ static ssize_t set_update_interval(struct device *dev,
700 return err; 700 return err;
701 701
702 mutex_lock(&data->update_lock); 702 mutex_lock(&data->update_lock);
703 lm63_set_convrate(client, data, SENSORS_LIMIT(val, 0, 100000)); 703 lm63_set_convrate(client, data, clamp_val(val, 0, 100000));
704 mutex_unlock(&data->update_lock); 704 mutex_unlock(&data->update_lock);
705 705
706 return count; 706 return count;
diff --git a/drivers/hwmon/lm73.c b/drivers/hwmon/lm73.c
index 7272176a9ec7..5166a8e3a061 100644
--- a/drivers/hwmon/lm73.c
+++ b/drivers/hwmon/lm73.c
@@ -56,8 +56,8 @@ static ssize_t set_temp(struct device *dev, struct device_attribute *da,
56 return status; 56 return status;
57 57
58 /* Write value */ 58 /* Write value */
59 value = (short) SENSORS_LIMIT(temp/250, (LM73_TEMP_MIN*4), 59 value = (short) clamp_val(temp / 250, LM73_TEMP_MIN * 4,
60 (LM73_TEMP_MAX*4)) << 5; 60 LM73_TEMP_MAX * 4) << 5;
61 err = i2c_smbus_write_word_swapped(client, attr->index, value); 61 err = i2c_smbus_write_word_swapped(client, attr->index, value);
62 return (err < 0) ? err : count; 62 return (err < 0) ? err : count;
63} 63}
diff --git a/drivers/hwmon/lm75.h b/drivers/hwmon/lm75.h
index 89aa9098ba5b..668ff4721323 100644
--- a/drivers/hwmon/lm75.h
+++ b/drivers/hwmon/lm75.h
@@ -36,7 +36,7 @@
36 REG: (0.5C/bit, two's complement) << 7 */ 36 REG: (0.5C/bit, two's complement) << 7 */
37static inline u16 LM75_TEMP_TO_REG(long temp) 37static inline u16 LM75_TEMP_TO_REG(long temp)
38{ 38{
39 int ntemp = SENSORS_LIMIT(temp, LM75_TEMP_MIN, LM75_TEMP_MAX); 39 int ntemp = clamp_val(temp, LM75_TEMP_MIN, LM75_TEMP_MAX);
40 ntemp += (ntemp < 0 ? -250 : 250); 40 ntemp += (ntemp < 0 ? -250 : 250);
41 return (u16)((ntemp / 500) << 7); 41 return (u16)((ntemp / 500) << 7);
42} 42}
diff --git a/drivers/hwmon/lm77.c b/drivers/hwmon/lm77.c
index f82acf67acf5..f17beb5e6dd6 100644
--- a/drivers/hwmon/lm77.c
+++ b/drivers/hwmon/lm77.c
@@ -101,7 +101,7 @@ static struct i2c_driver lm77_driver = {
101 */ 101 */
102static inline s16 LM77_TEMP_TO_REG(int temp) 102static inline s16 LM77_TEMP_TO_REG(int temp)
103{ 103{
104 int ntemp = SENSORS_LIMIT(temp, LM77_TEMP_MIN, LM77_TEMP_MAX); 104 int ntemp = clamp_val(temp, LM77_TEMP_MIN, LM77_TEMP_MAX);
105 return (ntemp / 500) * 8; 105 return (ntemp / 500) * 8;
106} 106}
107 107
diff --git a/drivers/hwmon/lm78.c b/drivers/hwmon/lm78.c
index 53d6ee8ffa33..483538fa1bd5 100644
--- a/drivers/hwmon/lm78.c
+++ b/drivers/hwmon/lm78.c
@@ -85,7 +85,7 @@ enum chips { lm78, lm79 };
85 */ 85 */
86static inline u8 IN_TO_REG(unsigned long val) 86static inline u8 IN_TO_REG(unsigned long val)
87{ 87{
88 unsigned long nval = SENSORS_LIMIT(val, 0, 4080); 88 unsigned long nval = clamp_val(val, 0, 4080);
89 return (nval + 8) / 16; 89 return (nval + 8) / 16;
90} 90}
91#define IN_FROM_REG(val) ((val) * 16) 91#define IN_FROM_REG(val) ((val) * 16)
@@ -94,7 +94,7 @@ static inline u8 FAN_TO_REG(long rpm, int div)
94{ 94{
95 if (rpm <= 0) 95 if (rpm <= 0)
96 return 255; 96 return 255;
97 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 97 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
98} 98}
99 99
100static inline int FAN_FROM_REG(u8 val, int div) 100static inline int FAN_FROM_REG(u8 val, int div)
@@ -108,7 +108,7 @@ static inline int FAN_FROM_REG(u8 val, int div)
108 */ 108 */
109static inline s8 TEMP_TO_REG(int val) 109static inline s8 TEMP_TO_REG(int val)
110{ 110{
111 int nval = SENSORS_LIMIT(val, -128000, 127000) ; 111 int nval = clamp_val(val, -128000, 127000) ;
112 return nval < 0 ? (nval - 500) / 1000 : (nval + 500) / 1000; 112 return nval < 0 ? (nval - 500) / 1000 : (nval + 500) / 1000;
113} 113}
114 114
diff --git a/drivers/hwmon/lm80.c b/drivers/hwmon/lm80.c
index 28a8b71f4571..357fbb998728 100644
--- a/drivers/hwmon/lm80.c
+++ b/drivers/hwmon/lm80.c
@@ -72,15 +72,15 @@ static const unsigned short normal_i2c[] = { 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d,
72 * Fixing this is just not worth it. 72 * Fixing this is just not worth it.
73 */ 73 */
74 74
75#define IN_TO_REG(val) (SENSORS_LIMIT(((val) + 5) / 10, 0, 255)) 75#define IN_TO_REG(val) (clamp_val(((val) + 5) / 10, 0, 255))
76#define IN_FROM_REG(val) ((val) * 10) 76#define IN_FROM_REG(val) ((val) * 10)
77 77
78static inline unsigned char FAN_TO_REG(unsigned rpm, unsigned div) 78static inline unsigned char FAN_TO_REG(unsigned rpm, unsigned div)
79{ 79{
80 if (rpm == 0) 80 if (rpm == 0)
81 return 255; 81 return 255;
82 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 82 rpm = clamp_val(rpm, 1, 1000000);
83 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 83 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
84} 84}
85 85
86#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \ 86#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \
@@ -102,7 +102,7 @@ static inline long TEMP_FROM_REG(u16 temp)
102#define TEMP_LIMIT_FROM_REG(val) (((val) > 0x80 ? \ 102#define TEMP_LIMIT_FROM_REG(val) (((val) > 0x80 ? \
103 (val) - 0x100 : (val)) * 1000) 103 (val) - 0x100 : (val)) * 1000)
104 104
105#define TEMP_LIMIT_TO_REG(val) SENSORS_LIMIT((val) < 0 ? \ 105#define TEMP_LIMIT_TO_REG(val) clamp_val((val) < 0 ? \
106 ((val) - 500) / 1000 : ((val) + 500) / 1000, 0, 255) 106 ((val) - 500) / 1000 : ((val) + 500) / 1000, 0, 255)
107 107
108#define DIV_FROM_REG(val) (1 << (val)) 108#define DIV_FROM_REG(val) (1 << (val))
diff --git a/drivers/hwmon/lm85.c b/drivers/hwmon/lm85.c
index 9f2dd77e1e0e..47ade8ba152d 100644
--- a/drivers/hwmon/lm85.c
+++ b/drivers/hwmon/lm85.c
@@ -139,7 +139,7 @@ static const int lm85_scaling[] = { /* .001 Volts */
139#define SCALE(val, from, to) (((val) * (to) + ((from) / 2)) / (from)) 139#define SCALE(val, from, to) (((val) * (to) + ((from) / 2)) / (from))
140 140
141#define INS_TO_REG(n, val) \ 141#define INS_TO_REG(n, val) \
142 SENSORS_LIMIT(SCALE(val, lm85_scaling[n], 192), 0, 255) 142 clamp_val(SCALE(val, lm85_scaling[n], 192), 0, 255)
143 143
144#define INSEXT_FROM_REG(n, val, ext) \ 144#define INSEXT_FROM_REG(n, val, ext) \
145 SCALE(((val) << 4) + (ext), 192 << 4, lm85_scaling[n]) 145 SCALE(((val) << 4) + (ext), 192 << 4, lm85_scaling[n])
@@ -151,19 +151,19 @@ static inline u16 FAN_TO_REG(unsigned long val)
151{ 151{
152 if (!val) 152 if (!val)
153 return 0xffff; 153 return 0xffff;
154 return SENSORS_LIMIT(5400000 / val, 1, 0xfffe); 154 return clamp_val(5400000 / val, 1, 0xfffe);
155} 155}
156#define FAN_FROM_REG(val) ((val) == 0 ? -1 : (val) == 0xffff ? 0 : \ 156#define FAN_FROM_REG(val) ((val) == 0 ? -1 : (val) == 0xffff ? 0 : \
157 5400000 / (val)) 157 5400000 / (val))
158 158
159/* Temperature is reported in .001 degC increments */ 159/* Temperature is reported in .001 degC increments */
160#define TEMP_TO_REG(val) \ 160#define TEMP_TO_REG(val) \
161 SENSORS_LIMIT(SCALE(val, 1000, 1), -127, 127) 161 clamp_val(SCALE(val, 1000, 1), -127, 127)
162#define TEMPEXT_FROM_REG(val, ext) \ 162#define TEMPEXT_FROM_REG(val, ext) \
163 SCALE(((val) << 4) + (ext), 16, 1000) 163 SCALE(((val) << 4) + (ext), 16, 1000)
164#define TEMP_FROM_REG(val) ((val) * 1000) 164#define TEMP_FROM_REG(val) ((val) * 1000)
165 165
166#define PWM_TO_REG(val) SENSORS_LIMIT(val, 0, 255) 166#define PWM_TO_REG(val) clamp_val(val, 0, 255)
167#define PWM_FROM_REG(val) (val) 167#define PWM_FROM_REG(val) (val)
168 168
169 169
@@ -258,7 +258,7 @@ static int ZONE_TO_REG(int zone)
258 return i << 5; 258 return i << 5;
259} 259}
260 260
261#define HYST_TO_REG(val) SENSORS_LIMIT(((val) + 500) / 1000, 0, 15) 261#define HYST_TO_REG(val) clamp_val(((val) + 500) / 1000, 0, 15)
262#define HYST_FROM_REG(val) ((val) * 1000) 262#define HYST_FROM_REG(val) ((val) * 1000)
263 263
264/* 264/*
diff --git a/drivers/hwmon/lm90.c b/drivers/hwmon/lm90.c
index 863412a02bdd..8eeb141c85ac 100644
--- a/drivers/hwmon/lm90.c
+++ b/drivers/hwmon/lm90.c
@@ -931,7 +931,7 @@ static ssize_t set_update_interval(struct device *dev,
931 return err; 931 return err;
932 932
933 mutex_lock(&data->update_lock); 933 mutex_lock(&data->update_lock);
934 lm90_set_convrate(client, data, SENSORS_LIMIT(val, 0, 100000)); 934 lm90_set_convrate(client, data, clamp_val(val, 0, 100000));
935 mutex_unlock(&data->update_lock); 935 mutex_unlock(&data->update_lock);
936 936
937 return count; 937 return count;
diff --git a/drivers/hwmon/lm93.c b/drivers/hwmon/lm93.c
index 1a003f73e4e4..b40f34cdb3ca 100644
--- a/drivers/hwmon/lm93.c
+++ b/drivers/hwmon/lm93.c
@@ -371,8 +371,8 @@ static unsigned LM93_IN_FROM_REG(int nr, u8 reg)
371static u8 LM93_IN_TO_REG(int nr, unsigned val) 371static u8 LM93_IN_TO_REG(int nr, unsigned val)
372{ 372{
373 /* range limit */ 373 /* range limit */
374 const long mV = SENSORS_LIMIT(val, 374 const long mV = clamp_val(val,
375 lm93_vin_val_min[nr], lm93_vin_val_max[nr]); 375 lm93_vin_val_min[nr], lm93_vin_val_max[nr]);
376 376
377 /* try not to lose too much precision here */ 377 /* try not to lose too much precision here */
378 const long uV = mV * 1000; 378 const long uV = mV * 1000;
@@ -385,8 +385,8 @@ static u8 LM93_IN_TO_REG(int nr, unsigned val)
385 const long intercept = uV_min - slope * lm93_vin_reg_min[nr]; 385 const long intercept = uV_min - slope * lm93_vin_reg_min[nr];
386 386
387 u8 result = ((uV - intercept + (slope/2)) / slope); 387 u8 result = ((uV - intercept + (slope/2)) / slope);
388 result = SENSORS_LIMIT(result, 388 result = clamp_val(result,
389 lm93_vin_reg_min[nr], lm93_vin_reg_max[nr]); 389 lm93_vin_reg_min[nr], lm93_vin_reg_max[nr]);
390 return result; 390 return result;
391} 391}
392 392
@@ -411,10 +411,10 @@ static u8 LM93_IN_REL_TO_REG(unsigned val, int upper, int vid)
411{ 411{
412 long uV_offset = vid * 1000 - val * 10000; 412 long uV_offset = vid * 1000 - val * 10000;
413 if (upper) { 413 if (upper) {
414 uV_offset = SENSORS_LIMIT(uV_offset, 12500, 200000); 414 uV_offset = clamp_val(uV_offset, 12500, 200000);
415 return (u8)((uV_offset / 12500 - 1) << 4); 415 return (u8)((uV_offset / 12500 - 1) << 4);
416 } else { 416 } else {
417 uV_offset = SENSORS_LIMIT(uV_offset, -400000, -25000); 417 uV_offset = clamp_val(uV_offset, -400000, -25000);
418 return (u8)((uV_offset / -25000 - 1) << 0); 418 return (u8)((uV_offset / -25000 - 1) << 0);
419 } 419 }
420} 420}
@@ -437,7 +437,7 @@ static int LM93_TEMP_FROM_REG(u8 reg)
437 */ 437 */
438static u8 LM93_TEMP_TO_REG(long temp) 438static u8 LM93_TEMP_TO_REG(long temp)
439{ 439{
440 int ntemp = SENSORS_LIMIT(temp, LM93_TEMP_MIN, LM93_TEMP_MAX); 440 int ntemp = clamp_val(temp, LM93_TEMP_MIN, LM93_TEMP_MAX);
441 ntemp += (ntemp < 0 ? -500 : 500); 441 ntemp += (ntemp < 0 ? -500 : 500);
442 return (u8)(ntemp / 1000); 442 return (u8)(ntemp / 1000);
443} 443}
@@ -472,7 +472,7 @@ static u8 LM93_TEMP_OFFSET_TO_REG(int off, int mode)
472{ 472{
473 int factor = mode ? 5 : 10; 473 int factor = mode ? 5 : 10;
474 474
475 off = SENSORS_LIMIT(off, LM93_TEMP_OFFSET_MIN, 475 off = clamp_val(off, LM93_TEMP_OFFSET_MIN,
476 mode ? LM93_TEMP_OFFSET_MAX1 : LM93_TEMP_OFFSET_MAX0); 476 mode ? LM93_TEMP_OFFSET_MAX1 : LM93_TEMP_OFFSET_MAX0);
477 return (u8)((off + factor/2) / factor); 477 return (u8)((off + factor/2) / factor);
478} 478}
@@ -620,8 +620,8 @@ static u16 LM93_FAN_TO_REG(long rpm)
620 if (rpm == 0) { 620 if (rpm == 0) {
621 count = 0x3fff; 621 count = 0x3fff;
622 } else { 622 } else {
623 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 623 rpm = clamp_val(rpm, 1, 1000000);
624 count = SENSORS_LIMIT((1350000 + rpm) / rpm, 1, 0x3ffe); 624 count = clamp_val((1350000 + rpm) / rpm, 1, 0x3ffe);
625 } 625 }
626 626
627 regs = count << 2; 627 regs = count << 2;
@@ -692,7 +692,7 @@ static int LM93_RAMP_FROM_REG(u8 reg)
692 */ 692 */
693static u8 LM93_RAMP_TO_REG(int ramp) 693static u8 LM93_RAMP_TO_REG(int ramp)
694{ 694{
695 ramp = SENSORS_LIMIT(ramp, LM93_RAMP_MIN, LM93_RAMP_MAX); 695 ramp = clamp_val(ramp, LM93_RAMP_MIN, LM93_RAMP_MAX);
696 return (u8)((ramp + 2) / 5); 696 return (u8)((ramp + 2) / 5);
697} 697}
698 698
@@ -702,7 +702,7 @@ static u8 LM93_RAMP_TO_REG(int ramp)
702 */ 702 */
703static u8 LM93_PROCHOT_TO_REG(long prochot) 703static u8 LM93_PROCHOT_TO_REG(long prochot)
704{ 704{
705 prochot = SENSORS_LIMIT(prochot, 0, 255); 705 prochot = clamp_val(prochot, 0, 255);
706 return (u8)prochot; 706 return (u8)prochot;
707} 707}
708 708
@@ -2052,7 +2052,7 @@ static ssize_t store_pwm_auto_channels(struct device *dev,
2052 return err; 2052 return err;
2053 2053
2054 mutex_lock(&data->update_lock); 2054 mutex_lock(&data->update_lock);
2055 data->block9[nr][LM93_PWM_CTL1] = SENSORS_LIMIT(val, 0, 255); 2055 data->block9[nr][LM93_PWM_CTL1] = clamp_val(val, 0, 255);
2056 lm93_write_byte(client, LM93_REG_PWM_CTL(nr, LM93_PWM_CTL1), 2056 lm93_write_byte(client, LM93_REG_PWM_CTL(nr, LM93_PWM_CTL1),
2057 data->block9[nr][LM93_PWM_CTL1]); 2057 data->block9[nr][LM93_PWM_CTL1]);
2058 mutex_unlock(&data->update_lock); 2058 mutex_unlock(&data->update_lock);
@@ -2397,7 +2397,7 @@ static ssize_t store_prochot_override_duty_cycle(struct device *dev,
2397 2397
2398 mutex_lock(&data->update_lock); 2398 mutex_lock(&data->update_lock);
2399 data->prochot_override = (data->prochot_override & 0xf0) | 2399 data->prochot_override = (data->prochot_override & 0xf0) |
2400 SENSORS_LIMIT(val, 0, 15); 2400 clamp_val(val, 0, 15);
2401 lm93_write_byte(client, LM93_REG_PROCHOT_OVERRIDE, 2401 lm93_write_byte(client, LM93_REG_PROCHOT_OVERRIDE,
2402 data->prochot_override); 2402 data->prochot_override);
2403 mutex_unlock(&data->update_lock); 2403 mutex_unlock(&data->update_lock);
diff --git a/drivers/hwmon/lm95245.c b/drivers/hwmon/lm95245.c
index 2915fd908364..a6c85f0ff8f3 100644
--- a/drivers/hwmon/lm95245.c
+++ b/drivers/hwmon/lm95245.c
@@ -259,7 +259,7 @@ static ssize_t set_limit(struct device *dev, struct device_attribute *attr,
259 259
260 val /= 1000; 260 val /= 1000;
261 261
262 val = SENSORS_LIMIT(val, 0, (index == 6 ? 127 : 255)); 262 val = clamp_val(val, 0, (index == 6 ? 127 : 255));
263 263
264 mutex_lock(&data->update_lock); 264 mutex_lock(&data->update_lock);
265 265
@@ -284,7 +284,7 @@ static ssize_t set_crit_hyst(struct device *dev, struct device_attribute *attr,
284 284
285 val /= 1000; 285 val /= 1000;
286 286
287 val = SENSORS_LIMIT(val, 0, 31); 287 val = clamp_val(val, 0, 31);
288 288
289 mutex_lock(&data->update_lock); 289 mutex_lock(&data->update_lock);
290 290
diff --git a/drivers/hwmon/max16065.c b/drivers/hwmon/max16065.c
index e0019c69d1bb..2fa2c02f5569 100644
--- a/drivers/hwmon/max16065.c
+++ b/drivers/hwmon/max16065.c
@@ -118,7 +118,7 @@ static inline int LIMIT_TO_MV(int limit, int range)
118 118
119static inline int MV_TO_LIMIT(int mv, int range) 119static inline int MV_TO_LIMIT(int mv, int range)
120{ 120{
121 return SENSORS_LIMIT(DIV_ROUND_CLOSEST(mv * 256, range), 0, 255); 121 return clamp_val(DIV_ROUND_CLOSEST(mv * 256, range), 0, 255);
122} 122}
123 123
124static inline int ADC_TO_CURR(int adc, int gain) 124static inline int ADC_TO_CURR(int adc, int gain)
diff --git a/drivers/hwmon/max1668.c b/drivers/hwmon/max1668.c
index 666d9f6263eb..a7626358c95d 100644
--- a/drivers/hwmon/max1668.c
+++ b/drivers/hwmon/max1668.c
@@ -215,7 +215,7 @@ static ssize_t set_temp_max(struct device *dev,
215 return ret; 215 return ret;
216 216
217 mutex_lock(&data->update_lock); 217 mutex_lock(&data->update_lock);
218 data->temp_max[index] = SENSORS_LIMIT(temp/1000, -128, 127); 218 data->temp_max[index] = clamp_val(temp/1000, -128, 127);
219 if (i2c_smbus_write_byte_data(client, 219 if (i2c_smbus_write_byte_data(client,
220 MAX1668_REG_LIMH_WR(index), 220 MAX1668_REG_LIMH_WR(index),
221 data->temp_max[index])) 221 data->temp_max[index]))
@@ -240,7 +240,7 @@ static ssize_t set_temp_min(struct device *dev,
240 return ret; 240 return ret;
241 241
242 mutex_lock(&data->update_lock); 242 mutex_lock(&data->update_lock);
243 data->temp_min[index] = SENSORS_LIMIT(temp/1000, -128, 127); 243 data->temp_min[index] = clamp_val(temp/1000, -128, 127);
244 if (i2c_smbus_write_byte_data(client, 244 if (i2c_smbus_write_byte_data(client,
245 MAX1668_REG_LIML_WR(index), 245 MAX1668_REG_LIML_WR(index),
246 data->temp_max[index])) 246 data->temp_max[index]))
diff --git a/drivers/hwmon/max6639.c b/drivers/hwmon/max6639.c
index 6e60036abfa7..3e7b4269f5b9 100644
--- a/drivers/hwmon/max6639.c
+++ b/drivers/hwmon/max6639.c
@@ -74,7 +74,7 @@ static const int rpm_ranges[] = { 2000, 4000, 8000, 16000 };
74 74
75#define FAN_FROM_REG(val, rpm_range) ((val) == 0 || (val) == 255 ? \ 75#define FAN_FROM_REG(val, rpm_range) ((val) == 0 || (val) == 255 ? \
76 0 : (rpm_ranges[rpm_range] * 30) / (val)) 76 0 : (rpm_ranges[rpm_range] * 30) / (val))
77#define TEMP_LIMIT_TO_REG(val) SENSORS_LIMIT((val) / 1000, 0, 255) 77#define TEMP_LIMIT_TO_REG(val) clamp_val((val) / 1000, 0, 255)
78 78
79/* 79/*
80 * Client data (each client gets its own) 80 * Client data (each client gets its own)
@@ -312,7 +312,7 @@ static ssize_t set_pwm(struct device *dev,
312 if (res) 312 if (res)
313 return res; 313 return res;
314 314
315 val = SENSORS_LIMIT(val, 0, 255); 315 val = clamp_val(val, 0, 255);
316 316
317 mutex_lock(&data->update_lock); 317 mutex_lock(&data->update_lock);
318 data->pwm[attr->index] = (u8)(val * 120 / 255); 318 data->pwm[attr->index] = (u8)(val * 120 / 255);
diff --git a/drivers/hwmon/max6642.c b/drivers/hwmon/max6642.c
index 223461a6d70f..57d58cd32206 100644
--- a/drivers/hwmon/max6642.c
+++ b/drivers/hwmon/max6642.c
@@ -239,7 +239,7 @@ static ssize_t set_temp_max(struct device *dev, struct device_attribute *attr,
239 return err; 239 return err;
240 240
241 mutex_lock(&data->update_lock); 241 mutex_lock(&data->update_lock);
242 data->temp_high[attr2->nr] = SENSORS_LIMIT(temp_to_reg(val), 0, 255); 242 data->temp_high[attr2->nr] = clamp_val(temp_to_reg(val), 0, 255);
243 i2c_smbus_write_byte_data(client, attr2->index, 243 i2c_smbus_write_byte_data(client, attr2->index,
244 data->temp_high[attr2->nr]); 244 data->temp_high[attr2->nr]);
245 mutex_unlock(&data->update_lock); 245 mutex_unlock(&data->update_lock);
diff --git a/drivers/hwmon/max6650.c b/drivers/hwmon/max6650.c
index f739f83bafb9..3c16cbd4c002 100644
--- a/drivers/hwmon/max6650.c
+++ b/drivers/hwmon/max6650.c
@@ -245,7 +245,7 @@ static ssize_t set_target(struct device *dev, struct device_attribute *devattr,
245 if (err) 245 if (err)
246 return err; 246 return err;
247 247
248 rpm = SENSORS_LIMIT(rpm, FAN_RPM_MIN, FAN_RPM_MAX); 248 rpm = clamp_val(rpm, FAN_RPM_MIN, FAN_RPM_MAX);
249 249
250 /* 250 /*
251 * Divide the required speed by 60 to get from rpm to rps, then 251 * Divide the required speed by 60 to get from rpm to rps, then
@@ -313,7 +313,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *devattr,
313 if (err) 313 if (err)
314 return err; 314 return err;
315 315
316 pwm = SENSORS_LIMIT(pwm, 0, 255); 316 pwm = clamp_val(pwm, 0, 255);
317 317
318 mutex_lock(&data->update_lock); 318 mutex_lock(&data->update_lock);
319 319
diff --git a/drivers/hwmon/pmbus/pmbus_core.c b/drivers/hwmon/pmbus/pmbus_core.c
index 7d19b1bb9ce6..dbacde6abaa8 100644
--- a/drivers/hwmon/pmbus/pmbus_core.c
+++ b/drivers/hwmon/pmbus/pmbus_core.c
@@ -657,7 +657,7 @@ static u16 pmbus_data2reg_direct(struct pmbus_data *data,
657static u16 pmbus_data2reg_vid(struct pmbus_data *data, 657static u16 pmbus_data2reg_vid(struct pmbus_data *data,
658 enum pmbus_sensor_classes class, long val) 658 enum pmbus_sensor_classes class, long val)
659{ 659{
660 val = SENSORS_LIMIT(val, 500, 1600); 660 val = clamp_val(val, 500, 1600);
661 661
662 return 2 + DIV_ROUND_CLOSEST((1600 - val) * 100, 625); 662 return 2 + DIV_ROUND_CLOSEST((1600 - val) * 100, 625);
663} 663}
diff --git a/drivers/hwmon/sis5595.c b/drivers/hwmon/sis5595.c
index 06ce3c911db9..c35847a1a0a3 100644
--- a/drivers/hwmon/sis5595.c
+++ b/drivers/hwmon/sis5595.c
@@ -132,7 +132,7 @@ static struct platform_device *pdev;
132 */ 132 */
133static inline u8 IN_TO_REG(unsigned long val) 133static inline u8 IN_TO_REG(unsigned long val)
134{ 134{
135 unsigned long nval = SENSORS_LIMIT(val, 0, 4080); 135 unsigned long nval = clamp_val(val, 0, 4080);
136 return (nval + 8) / 16; 136 return (nval + 8) / 16;
137} 137}
138#define IN_FROM_REG(val) ((val) * 16) 138#define IN_FROM_REG(val) ((val) * 16)
@@ -141,7 +141,7 @@ static inline u8 FAN_TO_REG(long rpm, int div)
141{ 141{
142 if (rpm <= 0) 142 if (rpm <= 0)
143 return 255; 143 return 255;
144 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 144 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
145} 145}
146 146
147static inline int FAN_FROM_REG(u8 val, int div) 147static inline int FAN_FROM_REG(u8 val, int div)
@@ -159,7 +159,7 @@ static inline int TEMP_FROM_REG(s8 val)
159} 159}
160static inline s8 TEMP_TO_REG(int val) 160static inline s8 TEMP_TO_REG(int val)
161{ 161{
162 int nval = SENSORS_LIMIT(val, -54120, 157530) ; 162 int nval = clamp_val(val, -54120, 157530) ;
163 return nval < 0 ? (nval - 5212 - 415) / 830 : (nval - 5212 + 415) / 830; 163 return nval < 0 ? (nval - 5212 - 415) / 830 : (nval - 5212 + 415) / 830;
164} 164}
165 165
diff --git a/drivers/hwmon/smsc47m1.c b/drivers/hwmon/smsc47m1.c
index dba0c567e7a1..6d8255ccf07a 100644
--- a/drivers/hwmon/smsc47m1.c
+++ b/drivers/hwmon/smsc47m1.c
@@ -326,7 +326,7 @@ static ssize_t set_fan_div(struct device *dev, struct device_attribute
326 /* Preserve fan min */ 326 /* Preserve fan min */
327 tmp = 192 - (old_div * (192 - data->fan_preload[nr]) 327 tmp = 192 - (old_div * (192 - data->fan_preload[nr])
328 + new_div / 2) / new_div; 328 + new_div / 2) / new_div;
329 data->fan_preload[nr] = SENSORS_LIMIT(tmp, 0, 191); 329 data->fan_preload[nr] = clamp_val(tmp, 0, 191);
330 smsc47m1_write_value(data, SMSC47M1_REG_FAN_PRELOAD[nr], 330 smsc47m1_write_value(data, SMSC47M1_REG_FAN_PRELOAD[nr],
331 data->fan_preload[nr]); 331 data->fan_preload[nr]);
332 mutex_unlock(&data->update_lock); 332 mutex_unlock(&data->update_lock);
diff --git a/drivers/hwmon/smsc47m192.c b/drivers/hwmon/smsc47m192.c
index 36a3478d0799..efee4c59239f 100644
--- a/drivers/hwmon/smsc47m192.c
+++ b/drivers/hwmon/smsc47m192.c
@@ -77,7 +77,7 @@ static inline unsigned int IN_FROM_REG(u8 reg, int n)
77 77
78static inline u8 IN_TO_REG(unsigned long val, int n) 78static inline u8 IN_TO_REG(unsigned long val, int n)
79{ 79{
80 return SENSORS_LIMIT(SCALE(val, 192, nom_mv[n]), 0, 255); 80 return clamp_val(SCALE(val, 192, nom_mv[n]), 0, 255);
81} 81}
82 82
83/* 83/*
@@ -86,7 +86,7 @@ static inline u8 IN_TO_REG(unsigned long val, int n)
86 */ 86 */
87static inline s8 TEMP_TO_REG(int val) 87static inline s8 TEMP_TO_REG(int val)
88{ 88{
89 return SENSORS_LIMIT(SCALE(val, 1, 1000), -128000, 127000); 89 return clamp_val(SCALE(val, 1, 1000), -128000, 127000);
90} 90}
91 91
92static inline int TEMP_FROM_REG(s8 val) 92static inline int TEMP_FROM_REG(s8 val)
diff --git a/drivers/hwmon/thmc50.c b/drivers/hwmon/thmc50.c
index 3c2c48d904e6..4b59eb53b18a 100644
--- a/drivers/hwmon/thmc50.c
+++ b/drivers/hwmon/thmc50.c
@@ -134,7 +134,7 @@ static ssize_t set_analog_out(struct device *dev,
134 return err; 134 return err;
135 135
136 mutex_lock(&data->update_lock); 136 mutex_lock(&data->update_lock);
137 data->analog_out = SENSORS_LIMIT(tmp, 0, 255); 137 data->analog_out = clamp_val(tmp, 0, 255);
138 i2c_smbus_write_byte_data(client, THMC50_REG_ANALOG_OUT, 138 i2c_smbus_write_byte_data(client, THMC50_REG_ANALOG_OUT,
139 data->analog_out); 139 data->analog_out);
140 140
@@ -187,7 +187,7 @@ static ssize_t set_temp_min(struct device *dev, struct device_attribute *attr,
187 return err; 187 return err;
188 188
189 mutex_lock(&data->update_lock); 189 mutex_lock(&data->update_lock);
190 data->temp_min[nr] = SENSORS_LIMIT(val / 1000, -128, 127); 190 data->temp_min[nr] = clamp_val(val / 1000, -128, 127);
191 i2c_smbus_write_byte_data(client, THMC50_REG_TEMP_MIN[nr], 191 i2c_smbus_write_byte_data(client, THMC50_REG_TEMP_MIN[nr],
192 data->temp_min[nr]); 192 data->temp_min[nr]);
193 mutex_unlock(&data->update_lock); 193 mutex_unlock(&data->update_lock);
@@ -216,7 +216,7 @@ static ssize_t set_temp_max(struct device *dev, struct device_attribute *attr,
216 return err; 216 return err;
217 217
218 mutex_lock(&data->update_lock); 218 mutex_lock(&data->update_lock);
219 data->temp_max[nr] = SENSORS_LIMIT(val / 1000, -128, 127); 219 data->temp_max[nr] = clamp_val(val / 1000, -128, 127);
220 i2c_smbus_write_byte_data(client, THMC50_REG_TEMP_MAX[nr], 220 i2c_smbus_write_byte_data(client, THMC50_REG_TEMP_MAX[nr],
221 data->temp_max[nr]); 221 data->temp_max[nr]);
222 mutex_unlock(&data->update_lock); 222 mutex_unlock(&data->update_lock);
diff --git a/drivers/hwmon/tmp102.c b/drivers/hwmon/tmp102.c
index b10c3d36ccbc..523dd89ba498 100644
--- a/drivers/hwmon/tmp102.c
+++ b/drivers/hwmon/tmp102.c
@@ -115,7 +115,7 @@ static ssize_t tmp102_set_temp(struct device *dev,
115 115
116 if (kstrtol(buf, 10, &val) < 0) 116 if (kstrtol(buf, 10, &val) < 0)
117 return -EINVAL; 117 return -EINVAL;
118 val = SENSORS_LIMIT(val, -256000, 255000); 118 val = clamp_val(val, -256000, 255000);
119 119
120 mutex_lock(&tmp102->lock); 120 mutex_lock(&tmp102->lock);
121 tmp102->temp[sda->index] = val; 121 tmp102->temp[sda->index] = val;
diff --git a/drivers/hwmon/tmp401.c b/drivers/hwmon/tmp401.c
index e62054875164..c85f6967ccc3 100644
--- a/drivers/hwmon/tmp401.c
+++ b/drivers/hwmon/tmp401.c
@@ -142,10 +142,10 @@ static int tmp401_register_to_temp(u16 reg, u8 config)
142static u16 tmp401_temp_to_register(long temp, u8 config) 142static u16 tmp401_temp_to_register(long temp, u8 config)
143{ 143{
144 if (config & TMP401_CONFIG_RANGE) { 144 if (config & TMP401_CONFIG_RANGE) {
145 temp = SENSORS_LIMIT(temp, -64000, 191000); 145 temp = clamp_val(temp, -64000, 191000);
146 temp += 64000; 146 temp += 64000;
147 } else 147 } else
148 temp = SENSORS_LIMIT(temp, 0, 127000); 148 temp = clamp_val(temp, 0, 127000);
149 149
150 return (temp * 160 + 312) / 625; 150 return (temp * 160 + 312) / 625;
151} 151}
@@ -163,10 +163,10 @@ static int tmp401_crit_register_to_temp(u8 reg, u8 config)
163static u8 tmp401_crit_temp_to_register(long temp, u8 config) 163static u8 tmp401_crit_temp_to_register(long temp, u8 config)
164{ 164{
165 if (config & TMP401_CONFIG_RANGE) { 165 if (config & TMP401_CONFIG_RANGE) {
166 temp = SENSORS_LIMIT(temp, -64000, 191000); 166 temp = clamp_val(temp, -64000, 191000);
167 temp += 64000; 167 temp += 64000;
168 } else 168 } else
169 temp = SENSORS_LIMIT(temp, 0, 127000); 169 temp = clamp_val(temp, 0, 127000);
170 170
171 return (temp + 500) / 1000; 171 return (temp + 500) / 1000;
172} 172}
@@ -417,14 +417,14 @@ static ssize_t store_temp_crit_hyst(struct device *dev, struct device_attribute
417 return -EINVAL; 417 return -EINVAL;
418 418
419 if (data->config & TMP401_CONFIG_RANGE) 419 if (data->config & TMP401_CONFIG_RANGE)
420 val = SENSORS_LIMIT(val, -64000, 191000); 420 val = clamp_val(val, -64000, 191000);
421 else 421 else
422 val = SENSORS_LIMIT(val, 0, 127000); 422 val = clamp_val(val, 0, 127000);
423 423
424 mutex_lock(&data->update_lock); 424 mutex_lock(&data->update_lock);
425 temp = tmp401_crit_register_to_temp(data->temp_crit[index], 425 temp = tmp401_crit_register_to_temp(data->temp_crit[index],
426 data->config); 426 data->config);
427 val = SENSORS_LIMIT(val, temp - 255000, temp); 427 val = clamp_val(val, temp - 255000, temp);
428 reg = ((temp - val) + 500) / 1000; 428 reg = ((temp - val) + 500) / 1000;
429 429
430 i2c_smbus_write_byte_data(to_i2c_client(dev), 430 i2c_smbus_write_byte_data(to_i2c_client(dev),
diff --git a/drivers/hwmon/via686a.c b/drivers/hwmon/via686a.c
index e0e14a9f1658..3123b30208c5 100644
--- a/drivers/hwmon/via686a.c
+++ b/drivers/hwmon/via686a.c
@@ -135,17 +135,14 @@ static inline u8 IN_TO_REG(long val, int inNum)
135 * for the constants. 135 * for the constants.
136 */ 136 */
137 if (inNum <= 1) 137 if (inNum <= 1)
138 return (u8) 138 return (u8) clamp_val((val * 21024 - 1205000) / 250000, 0, 255);
139 SENSORS_LIMIT((val * 21024 - 1205000) / 250000, 0, 255);
140 else if (inNum == 2) 139 else if (inNum == 2)
141 return (u8) 140 return (u8) clamp_val((val * 15737 - 1205000) / 250000, 0, 255);
142 SENSORS_LIMIT((val * 15737 - 1205000) / 250000, 0, 255);
143 else if (inNum == 3) 141 else if (inNum == 3)
144 return (u8) 142 return (u8) clamp_val((val * 10108 - 1205000) / 250000, 0, 255);
145 SENSORS_LIMIT((val * 10108 - 1205000) / 250000, 0, 255);
146 else 143 else
147 return (u8) 144 return (u8) clamp_val((val * 41714 - 12050000) / 2500000, 0,
148 SENSORS_LIMIT((val * 41714 - 12050000) / 2500000, 0, 255); 145 255);
149} 146}
150 147
151static inline long IN_FROM_REG(u8 val, int inNum) 148static inline long IN_FROM_REG(u8 val, int inNum)
@@ -175,8 +172,8 @@ static inline u8 FAN_TO_REG(long rpm, int div)
175{ 172{
176 if (rpm == 0) 173 if (rpm == 0)
177 return 0; 174 return 0;
178 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 175 rpm = clamp_val(rpm, 1, 1000000);
179 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 255); 176 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 255);
180} 177}
181 178
182#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (val) == 255 ? 0 : 1350000 / \ 179#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : (val) == 255 ? 0 : 1350000 / \
diff --git a/drivers/hwmon/vt1211.c b/drivers/hwmon/vt1211.c
index 751703059fae..dcc62f80f67b 100644
--- a/drivers/hwmon/vt1211.c
+++ b/drivers/hwmon/vt1211.c
@@ -158,7 +158,7 @@ struct vt1211_data {
158#define IN_FROM_REG(ix, reg) ((reg) < 3 ? 0 : (ix) == 5 ? \ 158#define IN_FROM_REG(ix, reg) ((reg) < 3 ? 0 : (ix) == 5 ? \
159 (((reg) - 3) * 15882 + 479) / 958 : \ 159 (((reg) - 3) * 15882 + 479) / 958 : \
160 (((reg) - 3) * 10000 + 479) / 958) 160 (((reg) - 3) * 10000 + 479) / 958)
161#define IN_TO_REG(ix, val) (SENSORS_LIMIT((ix) == 5 ? \ 161#define IN_TO_REG(ix, val) (clamp_val((ix) == 5 ? \
162 ((val) * 958 + 7941) / 15882 + 3 : \ 162 ((val) * 958 + 7941) / 15882 + 3 : \
163 ((val) * 958 + 5000) / 10000 + 3, 0, 255)) 163 ((val) * 958 + 5000) / 10000 + 3, 0, 255))
164 164
@@ -173,7 +173,7 @@ struct vt1211_data {
173 (ix) == 1 ? (reg) < 51 ? 0 : \ 173 (ix) == 1 ? (reg) < 51 ? 0 : \
174 ((reg) - 51) * 1000 : \ 174 ((reg) - 51) * 1000 : \
175 ((253 - (reg)) * 2200 + 105) / 210) 175 ((253 - (reg)) * 2200 + 105) / 210)
176#define TEMP_TO_REG(ix, val) SENSORS_LIMIT( \ 176#define TEMP_TO_REG(ix, val) clamp_val( \
177 ((ix) == 0 ? ((val) + 500) / 1000 : \ 177 ((ix) == 0 ? ((val) + 500) / 1000 : \
178 (ix) == 1 ? ((val) + 500) / 1000 + 51 : \ 178 (ix) == 1 ? ((val) + 500) / 1000 + 51 : \
179 253 - ((val) * 210 + 1100) / 2200), 0, 255) 179 253 - ((val) * 210 + 1100) / 2200), 0, 255)
@@ -183,7 +183,7 @@ struct vt1211_data {
183#define RPM_FROM_REG(reg, div) (((reg) == 0) || ((reg) == 255) ? 0 : \ 183#define RPM_FROM_REG(reg, div) (((reg) == 0) || ((reg) == 255) ? 0 : \
184 1310720 / (reg) / DIV_FROM_REG(div)) 184 1310720 / (reg) / DIV_FROM_REG(div))
185#define RPM_TO_REG(val, div) ((val) == 0 ? 255 : \ 185#define RPM_TO_REG(val, div) ((val) == 0 ? 255 : \
186 SENSORS_LIMIT((1310720 / (val) / \ 186 clamp_val((1310720 / (val) / \
187 DIV_FROM_REG(div)), 1, 254)) 187 DIV_FROM_REG(div)), 1, 254))
188 188
189/* --------------------------------------------------------------------- 189/* ---------------------------------------------------------------------
@@ -687,7 +687,7 @@ static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
687 data->fan_ctl)); 687 data->fan_ctl));
688 break; 688 break;
689 case SHOW_SET_PWM_FREQ: 689 case SHOW_SET_PWM_FREQ:
690 val = 135000 / SENSORS_LIMIT(val, 135000 >> 7, 135000); 690 val = 135000 / clamp_val(val, 135000 >> 7, 135000);
691 /* calculate tmp = log2(val) */ 691 /* calculate tmp = log2(val) */
692 tmp = 0; 692 tmp = 0;
693 for (val >>= 1; val > 0; val >>= 1) 693 for (val >>= 1; val > 0; val >>= 1)
@@ -845,7 +845,7 @@ static ssize_t set_pwm_auto_point_pwm(struct device *dev,
845 return err; 845 return err;
846 846
847 mutex_lock(&data->update_lock); 847 mutex_lock(&data->update_lock);
848 data->pwm_auto_pwm[ix][ap] = SENSORS_LIMIT(val, 0, 255); 848 data->pwm_auto_pwm[ix][ap] = clamp_val(val, 0, 255);
849 vt1211_write8(data, VT1211_REG_PWM_AUTO_PWM(ix, ap), 849 vt1211_write8(data, VT1211_REG_PWM_AUTO_PWM(ix, ap),
850 data->pwm_auto_pwm[ix][ap]); 850 data->pwm_auto_pwm[ix][ap]);
851 mutex_unlock(&data->update_lock); 851 mutex_unlock(&data->update_lock);
diff --git a/drivers/hwmon/vt8231.c b/drivers/hwmon/vt8231.c
index a56355cef184..988a2a796764 100644
--- a/drivers/hwmon/vt8231.c
+++ b/drivers/hwmon/vt8231.c
@@ -147,7 +147,7 @@ static inline u8 FAN_TO_REG(long rpm, int div)
147{ 147{
148 if (rpm == 0) 148 if (rpm == 0)
149 return 0; 149 return 0;
150 return SENSORS_LIMIT(1310720 / (rpm * div), 1, 255); 150 return clamp_val(1310720 / (rpm * div), 1, 255);
151} 151}
152 152
153#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : 1310720 / ((val) * (div))) 153#define FAN_FROM_REG(val, div) ((val) == 0 ? 0 : 1310720 / ((val) * (div)))
@@ -236,7 +236,7 @@ static ssize_t set_in_min(struct device *dev, struct device_attribute *attr,
236 return err; 236 return err;
237 237
238 mutex_lock(&data->update_lock); 238 mutex_lock(&data->update_lock);
239 data->in_min[nr] = SENSORS_LIMIT(((val * 958) / 10000) + 3, 0, 255); 239 data->in_min[nr] = clamp_val(((val * 958) / 10000) + 3, 0, 255);
240 vt8231_write_value(data, regvoltmin[nr], data->in_min[nr]); 240 vt8231_write_value(data, regvoltmin[nr], data->in_min[nr]);
241 mutex_unlock(&data->update_lock); 241 mutex_unlock(&data->update_lock);
242 return count; 242 return count;
@@ -256,7 +256,7 @@ static ssize_t set_in_max(struct device *dev, struct device_attribute *attr,
256 return err; 256 return err;
257 257
258 mutex_lock(&data->update_lock); 258 mutex_lock(&data->update_lock);
259 data->in_max[nr] = SENSORS_LIMIT(((val * 958) / 10000) + 3, 0, 255); 259 data->in_max[nr] = clamp_val(((val * 958) / 10000) + 3, 0, 255);
260 vt8231_write_value(data, regvoltmax[nr], data->in_max[nr]); 260 vt8231_write_value(data, regvoltmax[nr], data->in_max[nr]);
261 mutex_unlock(&data->update_lock); 261 mutex_unlock(&data->update_lock);
262 return count; 262 return count;
@@ -302,8 +302,8 @@ static ssize_t set_in5_min(struct device *dev, struct device_attribute *attr,
302 return err; 302 return err;
303 303
304 mutex_lock(&data->update_lock); 304 mutex_lock(&data->update_lock);
305 data->in_min[5] = SENSORS_LIMIT(((val * 958 * 34) / (10000 * 54)) + 3, 305 data->in_min[5] = clamp_val(((val * 958 * 34) / (10000 * 54)) + 3,
306 0, 255); 306 0, 255);
307 vt8231_write_value(data, regvoltmin[5], data->in_min[5]); 307 vt8231_write_value(data, regvoltmin[5], data->in_min[5]);
308 mutex_unlock(&data->update_lock); 308 mutex_unlock(&data->update_lock);
309 return count; 309 return count;
@@ -321,8 +321,8 @@ static ssize_t set_in5_max(struct device *dev, struct device_attribute *attr,
321 return err; 321 return err;
322 322
323 mutex_lock(&data->update_lock); 323 mutex_lock(&data->update_lock);
324 data->in_max[5] = SENSORS_LIMIT(((val * 958 * 34) / (10000 * 54)) + 3, 324 data->in_max[5] = clamp_val(((val * 958 * 34) / (10000 * 54)) + 3,
325 0, 255); 325 0, 255);
326 vt8231_write_value(data, regvoltmax[5], data->in_max[5]); 326 vt8231_write_value(data, regvoltmax[5], data->in_max[5]);
327 mutex_unlock(&data->update_lock); 327 mutex_unlock(&data->update_lock);
328 return count; 328 return count;
@@ -380,7 +380,7 @@ static ssize_t set_temp0_max(struct device *dev, struct device_attribute *attr,
380 return err; 380 return err;
381 381
382 mutex_lock(&data->update_lock); 382 mutex_lock(&data->update_lock);
383 data->temp_max[0] = SENSORS_LIMIT((val + 500) / 1000, 0, 255); 383 data->temp_max[0] = clamp_val((val + 500) / 1000, 0, 255);
384 vt8231_write_value(data, regtempmax[0], data->temp_max[0]); 384 vt8231_write_value(data, regtempmax[0], data->temp_max[0]);
385 mutex_unlock(&data->update_lock); 385 mutex_unlock(&data->update_lock);
386 return count; 386 return count;
@@ -397,7 +397,7 @@ static ssize_t set_temp0_min(struct device *dev, struct device_attribute *attr,
397 return err; 397 return err;
398 398
399 mutex_lock(&data->update_lock); 399 mutex_lock(&data->update_lock);
400 data->temp_min[0] = SENSORS_LIMIT((val + 500) / 1000, 0, 255); 400 data->temp_min[0] = clamp_val((val + 500) / 1000, 0, 255);
401 vt8231_write_value(data, regtempmin[0], data->temp_min[0]); 401 vt8231_write_value(data, regtempmin[0], data->temp_min[0]);
402 mutex_unlock(&data->update_lock); 402 mutex_unlock(&data->update_lock);
403 return count; 403 return count;
@@ -444,7 +444,7 @@ static ssize_t set_temp_max(struct device *dev, struct device_attribute *attr,
444 return err; 444 return err;
445 445
446 mutex_lock(&data->update_lock); 446 mutex_lock(&data->update_lock);
447 data->temp_max[nr] = SENSORS_LIMIT(TEMP_MAXMIN_TO_REG(val), 0, 255); 447 data->temp_max[nr] = clamp_val(TEMP_MAXMIN_TO_REG(val), 0, 255);
448 vt8231_write_value(data, regtempmax[nr], data->temp_max[nr]); 448 vt8231_write_value(data, regtempmax[nr], data->temp_max[nr]);
449 mutex_unlock(&data->update_lock); 449 mutex_unlock(&data->update_lock);
450 return count; 450 return count;
@@ -463,7 +463,7 @@ static ssize_t set_temp_min(struct device *dev, struct device_attribute *attr,
463 return err; 463 return err;
464 464
465 mutex_lock(&data->update_lock); 465 mutex_lock(&data->update_lock);
466 data->temp_min[nr] = SENSORS_LIMIT(TEMP_MAXMIN_TO_REG(val), 0, 255); 466 data->temp_min[nr] = clamp_val(TEMP_MAXMIN_TO_REG(val), 0, 255);
467 vt8231_write_value(data, regtempmin[nr], data->temp_min[nr]); 467 vt8231_write_value(data, regtempmin[nr], data->temp_min[nr]);
468 mutex_unlock(&data->update_lock); 468 mutex_unlock(&data->update_lock);
469 return count; 469 return count;
diff --git a/drivers/hwmon/w83627ehf.c b/drivers/hwmon/w83627ehf.c
index 0e8ffd6059a0..0a89211c25f6 100644
--- a/drivers/hwmon/w83627ehf.c
+++ b/drivers/hwmon/w83627ehf.c
@@ -354,8 +354,8 @@ static inline unsigned int step_time_from_reg(u8 reg, u8 mode)
354 354
355static inline u8 step_time_to_reg(unsigned int msec, u8 mode) 355static inline u8 step_time_to_reg(unsigned int msec, u8 mode)
356{ 356{
357 return SENSORS_LIMIT((mode ? (msec + 50) / 100 : 357 return clamp_val((mode ? (msec + 50) / 100 : (msec + 200) / 400),
358 (msec + 200) / 400), 1, 255); 358 1, 255);
359} 359}
360 360
361static unsigned int fan_from_reg8(u16 reg, unsigned int divreg) 361static unsigned int fan_from_reg8(u16 reg, unsigned int divreg)
@@ -414,8 +414,7 @@ static inline long in_from_reg(u8 reg, u8 nr, const u16 *scale_in)
414 414
415static inline u8 in_to_reg(u32 val, u8 nr, const u16 *scale_in) 415static inline u8 in_to_reg(u32 val, u8 nr, const u16 *scale_in)
416{ 416{
417 return SENSORS_LIMIT(DIV_ROUND_CLOSEST(val * 100, scale_in[nr]), 0, 417 return clamp_val(DIV_ROUND_CLOSEST(val * 100, scale_in[nr]), 0, 255);
418 255);
419} 418}
420 419
421/* 420/*
@@ -1267,7 +1266,7 @@ store_temp_offset(struct device *dev, struct device_attribute *attr,
1267 if (err < 0) 1266 if (err < 0)
1268 return err; 1267 return err;
1269 1268
1270 val = SENSORS_LIMIT(DIV_ROUND_CLOSEST(val, 1000), -128, 127); 1269 val = clamp_val(DIV_ROUND_CLOSEST(val, 1000), -128, 127);
1271 1270
1272 mutex_lock(&data->update_lock); 1271 mutex_lock(&data->update_lock);
1273 data->temp_offset[nr] = val; 1272 data->temp_offset[nr] = val;
@@ -1435,7 +1434,7 @@ store_pwm(struct device *dev, struct device_attribute *attr,
1435 if (err < 0) 1434 if (err < 0)
1436 return err; 1435 return err;
1437 1436
1438 val = SENSORS_LIMIT(val, 0, 255); 1437 val = clamp_val(val, 0, 255);
1439 1438
1440 mutex_lock(&data->update_lock); 1439 mutex_lock(&data->update_lock);
1441 data->pwm[nr] = val; 1440 data->pwm[nr] = val;
@@ -1514,7 +1513,7 @@ store_target_temp(struct device *dev, struct device_attribute *attr,
1514 if (err < 0) 1513 if (err < 0)
1515 return err; 1514 return err;
1516 1515
1517 val = SENSORS_LIMIT(DIV_ROUND_CLOSEST(val, 1000), 0, 127); 1516 val = clamp_val(DIV_ROUND_CLOSEST(val, 1000), 0, 127);
1518 1517
1519 mutex_lock(&data->update_lock); 1518 mutex_lock(&data->update_lock);
1520 data->target_temp[nr] = val; 1519 data->target_temp[nr] = val;
@@ -1540,7 +1539,7 @@ store_tolerance(struct device *dev, struct device_attribute *attr,
1540 return err; 1539 return err;
1541 1540
1542 /* Limit the temp to 0C - 15C */ 1541 /* Limit the temp to 0C - 15C */
1543 val = SENSORS_LIMIT(DIV_ROUND_CLOSEST(val, 1000), 0, 15); 1542 val = clamp_val(DIV_ROUND_CLOSEST(val, 1000), 0, 15);
1544 1543
1545 mutex_lock(&data->update_lock); 1544 mutex_lock(&data->update_lock);
1546 if (sio_data->kind == nct6775 || sio_data->kind == nct6776) { 1545 if (sio_data->kind == nct6775 || sio_data->kind == nct6776) {
@@ -1639,7 +1638,7 @@ store_##reg(struct device *dev, struct device_attribute *attr, \
1639 err = kstrtoul(buf, 10, &val); \ 1638 err = kstrtoul(buf, 10, &val); \
1640 if (err < 0) \ 1639 if (err < 0) \
1641 return err; \ 1640 return err; \
1642 val = SENSORS_LIMIT(val, 1, 255); \ 1641 val = clamp_val(val, 1, 255); \
1643 mutex_lock(&data->update_lock); \ 1642 mutex_lock(&data->update_lock); \
1644 data->reg[nr] = val; \ 1643 data->reg[nr] = val; \
1645 w83627ehf_write_value(data, data->REG_##REG[nr], val); \ 1644 w83627ehf_write_value(data, data->REG_##REG[nr], val); \
diff --git a/drivers/hwmon/w83627hf.c b/drivers/hwmon/w83627hf.c
index 81f486520cea..3b9ef2d23452 100644
--- a/drivers/hwmon/w83627hf.c
+++ b/drivers/hwmon/w83627hf.c
@@ -254,16 +254,15 @@ static const u8 BIT_SCFG2[] = { 0x10, 0x20, 0x40 };
254 * these macros are called: arguments may be evaluated more than once. 254 * these macros are called: arguments may be evaluated more than once.
255 * Fixing this is just not worth it. 255 * Fixing this is just not worth it.
256 */ 256 */
257#define IN_TO_REG(val) (SENSORS_LIMIT((((val) + 8)/16),0,255)) 257#define IN_TO_REG(val) (clamp_val((((val) + 8) / 16), 0, 255))
258#define IN_FROM_REG(val) ((val) * 16) 258#define IN_FROM_REG(val) ((val) * 16)
259 259
260static inline u8 FAN_TO_REG(long rpm, int div) 260static inline u8 FAN_TO_REG(long rpm, int div)
261{ 261{
262 if (rpm == 0) 262 if (rpm == 0)
263 return 255; 263 return 255;
264 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 264 rpm = clamp_val(rpm, 1, 1000000);
265 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 265 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
266 254);
267} 266}
268 267
269#define TEMP_MIN (-128000) 268#define TEMP_MIN (-128000)
@@ -275,9 +274,9 @@ static inline u8 FAN_TO_REG(long rpm, int div)
275 */ 274 */
276static u8 TEMP_TO_REG(long temp) 275static u8 TEMP_TO_REG(long temp)
277{ 276{
278 int ntemp = SENSORS_LIMIT(temp, TEMP_MIN, TEMP_MAX); 277 int ntemp = clamp_val(temp, TEMP_MIN, TEMP_MAX);
279 ntemp += (ntemp<0 ? -500 : 500); 278 ntemp += (ntemp < 0 ? -500 : 500);
280 return (u8)(ntemp / 1000); 279 return (u8)(ntemp / 1000);
281} 280}
282 281
283static int TEMP_FROM_REG(u8 reg) 282static int TEMP_FROM_REG(u8 reg)
@@ -287,7 +286,7 @@ static int TEMP_FROM_REG(u8 reg)
287 286
288#define FAN_FROM_REG(val,div) ((val)==0?-1:(val)==255?0:1350000/((val)*(div))) 287#define FAN_FROM_REG(val,div) ((val)==0?-1:(val)==255?0:1350000/((val)*(div)))
289 288
290#define PWM_TO_REG(val) (SENSORS_LIMIT((val),0,255)) 289#define PWM_TO_REG(val) (clamp_val((val), 0, 255))
291 290
292static inline unsigned long pwm_freq_from_reg_627hf(u8 reg) 291static inline unsigned long pwm_freq_from_reg_627hf(u8 reg)
293{ 292{
@@ -342,7 +341,7 @@ static inline u8 pwm_freq_to_reg(unsigned long val)
342static inline u8 DIV_TO_REG(long val) 341static inline u8 DIV_TO_REG(long val)
343{ 342{
344 int i; 343 int i;
345 val = SENSORS_LIMIT(val, 1, 128) >> 1; 344 val = clamp_val(val, 1, 128) >> 1;
346 for (i = 0; i < 7; i++) { 345 for (i = 0; i < 7; i++) {
347 if (val == 0) 346 if (val == 0)
348 break; 347 break;
@@ -614,8 +613,7 @@ static ssize_t store_regs_in_min0(struct device *dev, struct device_attribute *a
614 613
615 /* use VRM9 calculation */ 614 /* use VRM9 calculation */
616 data->in_min[0] = 615 data->in_min[0] =
617 SENSORS_LIMIT(((val * 100) - 70000 + 244) / 488, 0, 616 clamp_val(((val * 100) - 70000 + 244) / 488, 0, 255);
618 255);
619 else 617 else
620 /* use VRM8 (standard) calculation */ 618 /* use VRM8 (standard) calculation */
621 data->in_min[0] = IN_TO_REG(val); 619 data->in_min[0] = IN_TO_REG(val);
@@ -644,8 +642,7 @@ static ssize_t store_regs_in_max0(struct device *dev, struct device_attribute *a
644 642
645 /* use VRM9 calculation */ 643 /* use VRM9 calculation */
646 data->in_max[0] = 644 data->in_max[0] =
647 SENSORS_LIMIT(((val * 100) - 70000 + 244) / 488, 0, 645 clamp_val(((val * 100) - 70000 + 244) / 488, 0, 255);
648 255);
649 else 646 else
650 /* use VRM8 (standard) calculation */ 647 /* use VRM8 (standard) calculation */
651 data->in_max[0] = IN_TO_REG(val); 648 data->in_max[0] = IN_TO_REG(val);
diff --git a/drivers/hwmon/w83781d.c b/drivers/hwmon/w83781d.c
index 93bd28639595..aeec5b1d81c9 100644
--- a/drivers/hwmon/w83781d.c
+++ b/drivers/hwmon/w83781d.c
@@ -159,7 +159,7 @@ static const u8 BIT_SCFG2[] = { 0x10, 0x20, 0x40 };
159#define W83781D_DEFAULT_BETA 3435 159#define W83781D_DEFAULT_BETA 3435
160 160
161/* Conversions */ 161/* Conversions */
162#define IN_TO_REG(val) SENSORS_LIMIT(((val) + 8) / 16, 0, 255) 162#define IN_TO_REG(val) clamp_val(((val) + 8) / 16, 0, 255)
163#define IN_FROM_REG(val) ((val) * 16) 163#define IN_FROM_REG(val) ((val) * 16)
164 164
165static inline u8 165static inline u8
@@ -167,8 +167,8 @@ FAN_TO_REG(long rpm, int div)
167{ 167{
168 if (rpm == 0) 168 if (rpm == 0)
169 return 255; 169 return 255;
170 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 170 rpm = clamp_val(rpm, 1, 1000000);
171 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 171 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
172} 172}
173 173
174static inline long 174static inline long
@@ -181,7 +181,7 @@ FAN_FROM_REG(u8 val, int div)
181 return 1350000 / (val * div); 181 return 1350000 / (val * div);
182} 182}
183 183
184#define TEMP_TO_REG(val) SENSORS_LIMIT((val) / 1000, -127, 128) 184#define TEMP_TO_REG(val) clamp_val((val) / 1000, -127, 128)
185#define TEMP_FROM_REG(val) ((val) * 1000) 185#define TEMP_FROM_REG(val) ((val) * 1000)
186 186
187#define BEEP_MASK_FROM_REG(val, type) ((type) == as99127f ? \ 187#define BEEP_MASK_FROM_REG(val, type) ((type) == as99127f ? \
@@ -195,9 +195,8 @@ static inline u8
195DIV_TO_REG(long val, enum chips type) 195DIV_TO_REG(long val, enum chips type)
196{ 196{
197 int i; 197 int i;
198 val = SENSORS_LIMIT(val, 1, 198 val = clamp_val(val, 1,
199 ((type == w83781d 199 ((type == w83781d || type == as99127f) ? 8 : 128)) >> 1;
200 || type == as99127f) ? 8 : 128)) >> 1;
201 for (i = 0; i < 7; i++) { 200 for (i = 0; i < 7; i++) {
202 if (val == 0) 201 if (val == 0)
203 break; 202 break;
@@ -443,7 +442,7 @@ store_vrm_reg(struct device *dev, struct device_attribute *attr,
443 err = kstrtoul(buf, 10, &val); 442 err = kstrtoul(buf, 10, &val);
444 if (err) 443 if (err)
445 return err; 444 return err;
446 data->vrm = SENSORS_LIMIT(val, 0, 255); 445 data->vrm = clamp_val(val, 0, 255);
447 446
448 return count; 447 return count;
449} 448}
@@ -730,7 +729,7 @@ store_pwm(struct device *dev, struct device_attribute *da, const char *buf,
730 return err; 729 return err;
731 730
732 mutex_lock(&data->update_lock); 731 mutex_lock(&data->update_lock);
733 data->pwm[nr] = SENSORS_LIMIT(val, 0, 255); 732 data->pwm[nr] = clamp_val(val, 0, 255);
734 w83781d_write_value(data, W83781D_REG_PWM[nr], data->pwm[nr]); 733 w83781d_write_value(data, W83781D_REG_PWM[nr], data->pwm[nr]);
735 mutex_unlock(&data->update_lock); 734 mutex_unlock(&data->update_lock);
736 return count; 735 return count;
diff --git a/drivers/hwmon/w83791d.c b/drivers/hwmon/w83791d.c
index ed397c645198..38dddddf8875 100644
--- a/drivers/hwmon/w83791d.c
+++ b/drivers/hwmon/w83791d.c
@@ -220,15 +220,15 @@ static inline int w83791d_write(struct i2c_client *client, u8 reg, u8 value)
220 * in mV as would be measured on the chip input pin, need to just 220 * in mV as would be measured on the chip input pin, need to just
221 * multiply/divide by 16 to translate from/to register values. 221 * multiply/divide by 16 to translate from/to register values.
222 */ 222 */
223#define IN_TO_REG(val) (SENSORS_LIMIT((((val) + 8) / 16), 0, 255)) 223#define IN_TO_REG(val) (clamp_val((((val) + 8) / 16), 0, 255))
224#define IN_FROM_REG(val) ((val) * 16) 224#define IN_FROM_REG(val) ((val) * 16)
225 225
226static u8 fan_to_reg(long rpm, int div) 226static u8 fan_to_reg(long rpm, int div)
227{ 227{
228 if (rpm == 0) 228 if (rpm == 0)
229 return 255; 229 return 255;
230 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 230 rpm = clamp_val(rpm, 1, 1000000);
231 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 231 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
232} 232}
233 233
234#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \ 234#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \
@@ -273,7 +273,7 @@ static u8 div_to_reg(int nr, long val)
273 int i; 273 int i;
274 274
275 /* fan divisors max out at 128 */ 275 /* fan divisors max out at 128 */
276 val = SENSORS_LIMIT(val, 1, 128) >> 1; 276 val = clamp_val(val, 1, 128) >> 1;
277 for (i = 0; i < 7; i++) { 277 for (i = 0; i < 7; i++) {
278 if (val == 0) 278 if (val == 0)
279 break; 279 break;
@@ -747,7 +747,7 @@ static ssize_t store_pwm(struct device *dev, struct device_attribute *attr,
747 return -EINVAL; 747 return -EINVAL;
748 748
749 mutex_lock(&data->update_lock); 749 mutex_lock(&data->update_lock);
750 data->pwm[nr] = SENSORS_LIMIT(val, 0, 255); 750 data->pwm[nr] = clamp_val(val, 0, 255);
751 w83791d_write(client, W83791D_REG_PWM[nr], data->pwm[nr]); 751 w83791d_write(client, W83791D_REG_PWM[nr], data->pwm[nr]);
752 mutex_unlock(&data->update_lock); 752 mutex_unlock(&data->update_lock);
753 return count; 753 return count;
diff --git a/drivers/hwmon/w83792d.c b/drivers/hwmon/w83792d.c
index 301942d08453..5cb83ddf2cc6 100644
--- a/drivers/hwmon/w83792d.c
+++ b/drivers/hwmon/w83792d.c
@@ -235,8 +235,8 @@ FAN_TO_REG(long rpm, int div)
235{ 235{
236 if (rpm == 0) 236 if (rpm == 0)
237 return 255; 237 return 255;
238 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 238 rpm = clamp_val(rpm, 1, 1000000);
239 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 239 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
240} 240}
241 241
242#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \ 242#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \
@@ -244,16 +244,15 @@ FAN_TO_REG(long rpm, int div)
244 1350000 / ((val) * (div)))) 244 1350000 / ((val) * (div))))
245 245
246/* for temp1 */ 246/* for temp1 */
247#define TEMP1_TO_REG(val) (SENSORS_LIMIT(((val) < 0 ? (val)+0x100*1000 \ 247#define TEMP1_TO_REG(val) (clamp_val(((val) < 0 ? (val) + 0x100 * 1000 \
248 : (val)) / 1000, 0, 0xff)) 248 : (val)) / 1000, 0, 0xff))
249#define TEMP1_FROM_REG(val) (((val) & 0x80 ? (val)-0x100 : (val)) * 1000) 249#define TEMP1_FROM_REG(val) (((val) & 0x80 ? (val)-0x100 : (val)) * 1000)
250/* for temp2 and temp3, because they need additional resolution */ 250/* for temp2 and temp3, because they need additional resolution */
251#define TEMP_ADD_FROM_REG(val1, val2) \ 251#define TEMP_ADD_FROM_REG(val1, val2) \
252 ((((val1) & 0x80 ? (val1)-0x100 \ 252 ((((val1) & 0x80 ? (val1)-0x100 \
253 : (val1)) * 1000) + ((val2 & 0x80) ? 500 : 0)) 253 : (val1)) * 1000) + ((val2 & 0x80) ? 500 : 0))
254#define TEMP_ADD_TO_REG_HIGH(val) \ 254#define TEMP_ADD_TO_REG_HIGH(val) \
255 (SENSORS_LIMIT(((val) < 0 ? (val)+0x100*1000 \ 255 (clamp_val(((val) < 0 ? (val) + 0x100 * 1000 : (val)) / 1000, 0, 0xff))
256 : (val)) / 1000, 0, 0xff))
257#define TEMP_ADD_TO_REG_LOW(val) ((val%1000) ? 0x80 : 0x00) 256#define TEMP_ADD_TO_REG_LOW(val) ((val%1000) ? 0x80 : 0x00)
258 257
259#define DIV_FROM_REG(val) (1 << (val)) 258#define DIV_FROM_REG(val) (1 << (val))
@@ -262,7 +261,7 @@ static inline u8
262DIV_TO_REG(long val) 261DIV_TO_REG(long val)
263{ 262{
264 int i; 263 int i;
265 val = SENSORS_LIMIT(val, 1, 128) >> 1; 264 val = clamp_val(val, 1, 128) >> 1;
266 for (i = 0; i < 7; i++) { 265 for (i = 0; i < 7; i++) {
267 if (val == 0) 266 if (val == 0)
268 break; 267 break;
@@ -397,7 +396,7 @@ static ssize_t store_in_##reg(struct device *dev, \
397 if (err) \ 396 if (err) \
398 return err; \ 397 return err; \
399 mutex_lock(&data->update_lock); \ 398 mutex_lock(&data->update_lock); \
400 data->in_##reg[nr] = SENSORS_LIMIT(IN_TO_REG(nr, val) / 4, 0, 255); \ 399 data->in_##reg[nr] = clamp_val(IN_TO_REG(nr, val) / 4, 0, 255); \
401 w83792d_write_value(client, W83792D_REG_IN_##REG[nr], \ 400 w83792d_write_value(client, W83792D_REG_IN_##REG[nr], \
402 data->in_##reg[nr]); \ 401 data->in_##reg[nr]); \
403 mutex_unlock(&data->update_lock); \ 402 mutex_unlock(&data->update_lock); \
@@ -645,7 +644,7 @@ store_pwm(struct device *dev, struct device_attribute *attr,
645 err = kstrtoul(buf, 10, &val); 644 err = kstrtoul(buf, 10, &val);
646 if (err) 645 if (err)
647 return err; 646 return err;
648 val = SENSORS_LIMIT(val, 0, 255) >> 4; 647 val = clamp_val(val, 0, 255) >> 4;
649 648
650 mutex_lock(&data->update_lock); 649 mutex_lock(&data->update_lock);
651 val |= w83792d_read_value(client, W83792D_REG_PWM[nr]) & 0xf0; 650 val |= w83792d_read_value(client, W83792D_REG_PWM[nr]) & 0xf0;
@@ -799,7 +798,7 @@ store_thermal_cruise(struct device *dev, struct device_attribute *attr,
799 mutex_lock(&data->update_lock); 798 mutex_lock(&data->update_lock);
800 target_mask = w83792d_read_value(client, 799 target_mask = w83792d_read_value(client,
801 W83792D_REG_THERMAL[nr]) & 0x80; 800 W83792D_REG_THERMAL[nr]) & 0x80;
802 data->thermal_cruise[nr] = SENSORS_LIMIT(target_tmp, 0, 255); 801 data->thermal_cruise[nr] = clamp_val(target_tmp, 0, 255);
803 w83792d_write_value(client, W83792D_REG_THERMAL[nr], 802 w83792d_write_value(client, W83792D_REG_THERMAL[nr],
804 (data->thermal_cruise[nr]) | target_mask); 803 (data->thermal_cruise[nr]) | target_mask);
805 mutex_unlock(&data->update_lock); 804 mutex_unlock(&data->update_lock);
@@ -837,7 +836,7 @@ store_tolerance(struct device *dev, struct device_attribute *attr,
837 mutex_lock(&data->update_lock); 836 mutex_lock(&data->update_lock);
838 tol_mask = w83792d_read_value(client, 837 tol_mask = w83792d_read_value(client,
839 W83792D_REG_TOLERANCE[nr]) & ((nr == 1) ? 0x0f : 0xf0); 838 W83792D_REG_TOLERANCE[nr]) & ((nr == 1) ? 0x0f : 0xf0);
840 tol_tmp = SENSORS_LIMIT(val, 0, 15); 839 tol_tmp = clamp_val(val, 0, 15);
841 tol_tmp &= 0x0f; 840 tol_tmp &= 0x0f;
842 data->tolerance[nr] = tol_tmp; 841 data->tolerance[nr] = tol_tmp;
843 if (nr == 1) 842 if (nr == 1)
@@ -881,7 +880,7 @@ store_sf2_point(struct device *dev, struct device_attribute *attr,
881 return err; 880 return err;
882 881
883 mutex_lock(&data->update_lock); 882 mutex_lock(&data->update_lock);
884 data->sf2_points[index][nr] = SENSORS_LIMIT(val, 0, 127); 883 data->sf2_points[index][nr] = clamp_val(val, 0, 127);
885 mask_tmp = w83792d_read_value(client, 884 mask_tmp = w83792d_read_value(client,
886 W83792D_REG_POINTS[index][nr]) & 0x80; 885 W83792D_REG_POINTS[index][nr]) & 0x80;
887 w83792d_write_value(client, W83792D_REG_POINTS[index][nr], 886 w83792d_write_value(client, W83792D_REG_POINTS[index][nr],
@@ -923,7 +922,7 @@ store_sf2_level(struct device *dev, struct device_attribute *attr,
923 return err; 922 return err;
924 923
925 mutex_lock(&data->update_lock); 924 mutex_lock(&data->update_lock);
926 data->sf2_levels[index][nr] = SENSORS_LIMIT((val * 15) / 100, 0, 15); 925 data->sf2_levels[index][nr] = clamp_val((val * 15) / 100, 0, 15);
927 mask_tmp = w83792d_read_value(client, W83792D_REG_LEVELS[index][nr]) 926 mask_tmp = w83792d_read_value(client, W83792D_REG_LEVELS[index][nr])
928 & ((nr == 3) ? 0xf0 : 0x0f); 927 & ((nr == 3) ? 0xf0 : 0x0f);
929 if (nr == 3) 928 if (nr == 3)
diff --git a/drivers/hwmon/w83793.c b/drivers/hwmon/w83793.c
index 99799fd1d917..660427520c53 100644
--- a/drivers/hwmon/w83793.c
+++ b/drivers/hwmon/w83793.c
@@ -191,7 +191,7 @@ static inline u16 FAN_TO_REG(long rpm)
191{ 191{
192 if (rpm <= 0) 192 if (rpm <= 0)
193 return 0x0fff; 193 return 0x0fff;
194 return SENSORS_LIMIT((1350000 + (rpm >> 1)) / rpm, 1, 0xffe); 194 return clamp_val((1350000 + (rpm >> 1)) / rpm, 1, 0xffe);
195} 195}
196 196
197static inline unsigned long TIME_FROM_REG(u8 reg) 197static inline unsigned long TIME_FROM_REG(u8 reg)
@@ -201,7 +201,7 @@ static inline unsigned long TIME_FROM_REG(u8 reg)
201 201
202static inline u8 TIME_TO_REG(unsigned long val) 202static inline u8 TIME_TO_REG(unsigned long val)
203{ 203{
204 return SENSORS_LIMIT((val + 50) / 100, 0, 0xff); 204 return clamp_val((val + 50) / 100, 0, 0xff);
205} 205}
206 206
207static inline long TEMP_FROM_REG(s8 reg) 207static inline long TEMP_FROM_REG(s8 reg)
@@ -211,7 +211,7 @@ static inline long TEMP_FROM_REG(s8 reg)
211 211
212static inline s8 TEMP_TO_REG(long val, s8 min, s8 max) 212static inline s8 TEMP_TO_REG(long val, s8 min, s8 max)
213{ 213{
214 return SENSORS_LIMIT((val + (val < 0 ? -500 : 500)) / 1000, min, max); 214 return clamp_val((val + (val < 0 ? -500 : 500)) / 1000, min, max);
215} 215}
216 216
217struct w83793_data { 217struct w83793_data {
@@ -558,7 +558,7 @@ store_pwm(struct device *dev, struct device_attribute *attr,
558 w83793_write_value(client, W83793_REG_PWM_STOP_TIME(index), 558 w83793_write_value(client, W83793_REG_PWM_STOP_TIME(index),
559 val); 559 val);
560 } else { 560 } else {
561 val = SENSORS_LIMIT(val, 0, 0xff) >> 2; 561 val = clamp_val(val, 0, 0xff) >> 2;
562 data->pwm[index][nr] = 562 data->pwm[index][nr] =
563 w83793_read_value(client, W83793_REG_PWM(index, nr)) & 0xc0; 563 w83793_read_value(client, W83793_REG_PWM(index, nr)) & 0xc0;
564 data->pwm[index][nr] |= val; 564 data->pwm[index][nr] |= val;
@@ -739,7 +739,7 @@ store_sf_setup(struct device *dev, struct device_attribute *attr,
739 if (nr == SETUP_PWM_DEFAULT) { 739 if (nr == SETUP_PWM_DEFAULT) {
740 data->pwm_default = 740 data->pwm_default =
741 w83793_read_value(client, W83793_REG_PWM_DEFAULT) & 0xc0; 741 w83793_read_value(client, W83793_REG_PWM_DEFAULT) & 0xc0;
742 data->pwm_default |= SENSORS_LIMIT(val, 0, 0xff) >> 2; 742 data->pwm_default |= clamp_val(val, 0, 0xff) >> 2;
743 w83793_write_value(client, W83793_REG_PWM_DEFAULT, 743 w83793_write_value(client, W83793_REG_PWM_DEFAULT,
744 data->pwm_default); 744 data->pwm_default);
745 } else if (nr == SETUP_PWM_UPTIME) { 745 } else if (nr == SETUP_PWM_UPTIME) {
@@ -838,7 +838,7 @@ store_sf_ctrl(struct device *dev, struct device_attribute *attr,
838 838
839 mutex_lock(&data->update_lock); 839 mutex_lock(&data->update_lock);
840 if (nr == TEMP_FAN_MAP) { 840 if (nr == TEMP_FAN_MAP) {
841 val = SENSORS_LIMIT(val, 0, 255); 841 val = clamp_val(val, 0, 255);
842 w83793_write_value(client, W83793_REG_TEMP_FAN_MAP(index), val); 842 w83793_write_value(client, W83793_REG_TEMP_FAN_MAP(index), val);
843 data->temp_fan_map[index] = val; 843 data->temp_fan_map[index] = val;
844 } else if (nr == TEMP_PWM_ENABLE) { 844 } else if (nr == TEMP_PWM_ENABLE) {
@@ -907,7 +907,7 @@ store_sf2_pwm(struct device *dev, struct device_attribute *attr,
907 err = kstrtoul(buf, 10, &val); 907 err = kstrtoul(buf, 10, &val);
908 if (err) 908 if (err)
909 return err; 909 return err;
910 val = SENSORS_LIMIT(val, 0, 0xff) >> 2; 910 val = clamp_val(val, 0, 0xff) >> 2;
911 911
912 mutex_lock(&data->update_lock); 912 mutex_lock(&data->update_lock);
913 data->sf2_pwm[index][nr] = 913 data->sf2_pwm[index][nr] =
@@ -1003,9 +1003,9 @@ store_in(struct device *dev, struct device_attribute *attr,
1003 /* fix the limit values of 5VDD and 5VSB to ALARM mechanism */ 1003 /* fix the limit values of 5VDD and 5VSB to ALARM mechanism */
1004 if (nr == 1 || nr == 2) 1004 if (nr == 1 || nr == 2)
1005 val -= scale_in_add[index] / scale_in[index]; 1005 val -= scale_in_add[index] / scale_in[index];
1006 val = SENSORS_LIMIT(val, 0, 255); 1006 val = clamp_val(val, 0, 255);
1007 } else { 1007 } else {
1008 val = SENSORS_LIMIT(val, 0, 0x3FF); 1008 val = clamp_val(val, 0, 0x3FF);
1009 data->in_low_bits[nr] = 1009 data->in_low_bits[nr] =
1010 w83793_read_value(client, W83793_REG_IN_LOW_BITS[nr]); 1010 w83793_read_value(client, W83793_REG_IN_LOW_BITS[nr]);
1011 data->in_low_bits[nr] &= ~(0x03 << (2 * index)); 1011 data->in_low_bits[nr] &= ~(0x03 << (2 * index));
diff --git a/drivers/hwmon/w83795.c b/drivers/hwmon/w83795.c
index 55a4f4894531..e226096148eb 100644
--- a/drivers/hwmon/w83795.c
+++ b/drivers/hwmon/w83795.c
@@ -262,7 +262,7 @@ static inline u16 fan_to_reg(long rpm)
262{ 262{
263 if (rpm <= 0) 263 if (rpm <= 0)
264 return 0x0fff; 264 return 0x0fff;
265 return SENSORS_LIMIT((1350000 + (rpm >> 1)) / rpm, 1, 0xffe); 265 return clamp_val((1350000 + (rpm >> 1)) / rpm, 1, 0xffe);
266} 266}
267 267
268static inline unsigned long time_from_reg(u8 reg) 268static inline unsigned long time_from_reg(u8 reg)
@@ -272,7 +272,7 @@ static inline unsigned long time_from_reg(u8 reg)
272 272
273static inline u8 time_to_reg(unsigned long val) 273static inline u8 time_to_reg(unsigned long val)
274{ 274{
275 return SENSORS_LIMIT((val + 50) / 100, 0, 0xff); 275 return clamp_val((val + 50) / 100, 0, 0xff);
276} 276}
277 277
278static inline long temp_from_reg(s8 reg) 278static inline long temp_from_reg(s8 reg)
@@ -282,7 +282,7 @@ static inline long temp_from_reg(s8 reg)
282 282
283static inline s8 temp_to_reg(long val, s8 min, s8 max) 283static inline s8 temp_to_reg(long val, s8 min, s8 max)
284{ 284{
285 return SENSORS_LIMIT(val / 1000, min, max); 285 return clamp_val(val / 1000, min, max);
286} 286}
287 287
288static const u16 pwm_freq_cksel0[16] = { 288static const u16 pwm_freq_cksel0[16] = {
@@ -319,7 +319,7 @@ static u8 pwm_freq_to_reg(unsigned long val, u16 clkin)
319 319
320 /* Best fit for cksel = 1 */ 320 /* Best fit for cksel = 1 */
321 base_clock = clkin * 1000 / ((clkin == 48000) ? 384 : 256); 321 base_clock = clkin * 1000 / ((clkin == 48000) ? 384 : 256);
322 reg1 = SENSORS_LIMIT(DIV_ROUND_CLOSEST(base_clock, val), 1, 128); 322 reg1 = clamp_val(DIV_ROUND_CLOSEST(base_clock, val), 1, 128);
323 best1 = base_clock / reg1; 323 best1 = base_clock / reg1;
324 reg1 = 0x80 | (reg1 - 1); 324 reg1 = 0x80 | (reg1 - 1);
325 325
@@ -889,7 +889,7 @@ store_pwm(struct device *dev, struct device_attribute *attr,
889 val = pwm_freq_to_reg(val, data->clkin); 889 val = pwm_freq_to_reg(val, data->clkin);
890 break; 890 break;
891 default: 891 default:
892 val = SENSORS_LIMIT(val, 0, 0xff); 892 val = clamp_val(val, 0, 0xff);
893 break; 893 break;
894 } 894 }
895 w83795_write(client, W83795_REG_PWM(index, nr), val); 895 w83795_write(client, W83795_REG_PWM(index, nr), val);
@@ -1126,7 +1126,7 @@ store_temp_pwm_enable(struct device *dev, struct device_attribute *attr,
1126 break; 1126 break;
1127 case TEMP_PWM_FAN_MAP: 1127 case TEMP_PWM_FAN_MAP:
1128 mutex_lock(&data->update_lock); 1128 mutex_lock(&data->update_lock);
1129 tmp = SENSORS_LIMIT(tmp, 0, 0xff); 1129 tmp = clamp_val(tmp, 0, 0xff);
1130 w83795_write(client, W83795_REG_TFMR(index), tmp); 1130 w83795_write(client, W83795_REG_TFMR(index), tmp);
1131 data->pwm_tfmr[index] = tmp; 1131 data->pwm_tfmr[index] = tmp;
1132 mutex_unlock(&data->update_lock); 1132 mutex_unlock(&data->update_lock);
@@ -1177,13 +1177,13 @@ store_fanin(struct device *dev, struct device_attribute *attr,
1177 mutex_lock(&data->update_lock); 1177 mutex_lock(&data->update_lock);
1178 switch (nr) { 1178 switch (nr) {
1179 case FANIN_TARGET: 1179 case FANIN_TARGET:
1180 val = fan_to_reg(SENSORS_LIMIT(val, 0, 0xfff)); 1180 val = fan_to_reg(clamp_val(val, 0, 0xfff));
1181 w83795_write(client, W83795_REG_FTSH(index), val >> 4); 1181 w83795_write(client, W83795_REG_FTSH(index), val >> 4);
1182 w83795_write(client, W83795_REG_FTSL(index), (val << 4) & 0xf0); 1182 w83795_write(client, W83795_REG_FTSL(index), (val << 4) & 0xf0);
1183 data->target_speed[index] = val; 1183 data->target_speed[index] = val;
1184 break; 1184 break;
1185 case FANIN_TOL: 1185 case FANIN_TOL:
1186 val = SENSORS_LIMIT(val, 0, 0x3f); 1186 val = clamp_val(val, 0, 0x3f);
1187 w83795_write(client, W83795_REG_TFTS, val); 1187 w83795_write(client, W83795_REG_TFTS, val);
1188 data->tol_speed = val; 1188 data->tol_speed = val;
1189 break; 1189 break;
@@ -1227,22 +1227,22 @@ store_temp_pwm(struct device *dev, struct device_attribute *attr,
1227 mutex_lock(&data->update_lock); 1227 mutex_lock(&data->update_lock);
1228 switch (nr) { 1228 switch (nr) {
1229 case TEMP_PWM_TTTI: 1229 case TEMP_PWM_TTTI:
1230 val = SENSORS_LIMIT(val, 0, 0x7f); 1230 val = clamp_val(val, 0, 0x7f);
1231 w83795_write(client, W83795_REG_TTTI(index), val); 1231 w83795_write(client, W83795_REG_TTTI(index), val);
1232 break; 1232 break;
1233 case TEMP_PWM_CTFS: 1233 case TEMP_PWM_CTFS:
1234 val = SENSORS_LIMIT(val, 0, 0x7f); 1234 val = clamp_val(val, 0, 0x7f);
1235 w83795_write(client, W83795_REG_CTFS(index), val); 1235 w83795_write(client, W83795_REG_CTFS(index), val);
1236 break; 1236 break;
1237 case TEMP_PWM_HCT: 1237 case TEMP_PWM_HCT:
1238 val = SENSORS_LIMIT(val, 0, 0x0f); 1238 val = clamp_val(val, 0, 0x0f);
1239 tmp = w83795_read(client, W83795_REG_HT(index)); 1239 tmp = w83795_read(client, W83795_REG_HT(index));
1240 tmp &= 0x0f; 1240 tmp &= 0x0f;
1241 tmp |= (val << 4) & 0xf0; 1241 tmp |= (val << 4) & 0xf0;
1242 w83795_write(client, W83795_REG_HT(index), tmp); 1242 w83795_write(client, W83795_REG_HT(index), tmp);
1243 break; 1243 break;
1244 case TEMP_PWM_HOT: 1244 case TEMP_PWM_HOT:
1245 val = SENSORS_LIMIT(val, 0, 0x0f); 1245 val = clamp_val(val, 0, 0x0f);
1246 tmp = w83795_read(client, W83795_REG_HT(index)); 1246 tmp = w83795_read(client, W83795_REG_HT(index));
1247 tmp &= 0xf0; 1247 tmp &= 0xf0;
1248 tmp |= val & 0x0f; 1248 tmp |= val & 0x0f;
@@ -1541,7 +1541,7 @@ store_in(struct device *dev, struct device_attribute *attr,
1541 if ((index >= 17) && 1541 if ((index >= 17) &&
1542 !((data->has_gain >> (index - 17)) & 1)) 1542 !((data->has_gain >> (index - 17)) & 1))
1543 val /= 8; 1543 val /= 8;
1544 val = SENSORS_LIMIT(val, 0, 0x3FF); 1544 val = clamp_val(val, 0, 0x3FF);
1545 mutex_lock(&data->update_lock); 1545 mutex_lock(&data->update_lock);
1546 1546
1547 lsb_idx = IN_LSB_SHIFT_IDX[index][IN_LSB_IDX]; 1547 lsb_idx = IN_LSB_SHIFT_IDX[index][IN_LSB_IDX];
@@ -1596,7 +1596,7 @@ store_sf_setup(struct device *dev, struct device_attribute *attr,
1596 1596
1597 switch (nr) { 1597 switch (nr) {
1598 case SETUP_PWM_DEFAULT: 1598 case SETUP_PWM_DEFAULT:
1599 val = SENSORS_LIMIT(val, 0, 0xff); 1599 val = clamp_val(val, 0, 0xff);
1600 break; 1600 break;
1601 case SETUP_PWM_UPTIME: 1601 case SETUP_PWM_UPTIME:
1602 case SETUP_PWM_DOWNTIME: 1602 case SETUP_PWM_DOWNTIME:
diff --git a/drivers/hwmon/w83l786ng.c b/drivers/hwmon/w83l786ng.c
index 79710bcac2f7..edb06cda5a68 100644
--- a/drivers/hwmon/w83l786ng.c
+++ b/drivers/hwmon/w83l786ng.c
@@ -86,8 +86,8 @@ FAN_TO_REG(long rpm, int div)
86{ 86{
87 if (rpm == 0) 87 if (rpm == 0)
88 return 255; 88 return 255;
89 rpm = SENSORS_LIMIT(rpm, 1, 1000000); 89 rpm = clamp_val(rpm, 1, 1000000);
90 return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254); 90 return clamp_val((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
91} 91}
92 92
93#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \ 93#define FAN_FROM_REG(val, div) ((val) == 0 ? -1 : \
@@ -95,9 +95,8 @@ FAN_TO_REG(long rpm, int div)
95 1350000 / ((val) * (div)))) 95 1350000 / ((val) * (div))))
96 96
97/* for temp */ 97/* for temp */
98#define TEMP_TO_REG(val) (SENSORS_LIMIT(((val) < 0 ? \ 98#define TEMP_TO_REG(val) (clamp_val(((val) < 0 ? (val) + 0x100 * 1000 \
99 (val) + 0x100 * 1000 \ 99 : (val)) / 1000, 0, 0xff))
100 : (val)) / 1000, 0, 0xff))
101#define TEMP_FROM_REG(val) (((val) & 0x80 ? \ 100#define TEMP_FROM_REG(val) (((val) & 0x80 ? \
102 (val) - 0x100 : (val)) * 1000) 101 (val) - 0x100 : (val)) * 1000)
103 102
@@ -106,7 +105,7 @@ FAN_TO_REG(long rpm, int div)
106 * in mV as would be measured on the chip input pin, need to just 105 * in mV as would be measured on the chip input pin, need to just
107 * multiply/divide by 8 to translate from/to register values. 106 * multiply/divide by 8 to translate from/to register values.
108 */ 107 */
109#define IN_TO_REG(val) (SENSORS_LIMIT((((val) + 4) / 8), 0, 255)) 108#define IN_TO_REG(val) (clamp_val((((val) + 4) / 8), 0, 255))
110#define IN_FROM_REG(val) ((val) * 8) 109#define IN_FROM_REG(val) ((val) * 8)
111 110
112#define DIV_FROM_REG(val) (1 << (val)) 111#define DIV_FROM_REG(val) (1 << (val))
@@ -115,7 +114,7 @@ static inline u8
115DIV_TO_REG(long val) 114DIV_TO_REG(long val)
116{ 115{
117 int i; 116 int i;
118 val = SENSORS_LIMIT(val, 1, 128) >> 1; 117 val = clamp_val(val, 1, 128) >> 1;
119 for (i = 0; i < 7; i++) { 118 for (i = 0; i < 7; i++) {
120 if (val == 0) 119 if (val == 0)
121 break; 120 break;
@@ -481,7 +480,7 @@ store_pwm(struct device *dev, struct device_attribute *attr,
481 err = kstrtoul(buf, 10, &val); 480 err = kstrtoul(buf, 10, &val);
482 if (err) 481 if (err)
483 return err; 482 return err;
484 val = SENSORS_LIMIT(val, 0, 255); 483 val = clamp_val(val, 0, 255);
485 484
486 mutex_lock(&data->update_lock); 485 mutex_lock(&data->update_lock);
487 data->pwm[nr] = val; 486 data->pwm[nr] = val;
@@ -564,7 +563,7 @@ store_tolerance(struct device *dev, struct device_attribute *attr,
564 mutex_lock(&data->update_lock); 563 mutex_lock(&data->update_lock);
565 tol_mask = w83l786ng_read_value(client, 564 tol_mask = w83l786ng_read_value(client,
566 W83L786NG_REG_TOLERANCE) & ((nr == 1) ? 0x0f : 0xf0); 565 W83L786NG_REG_TOLERANCE) & ((nr == 1) ? 0x0f : 0xf0);
567 tol_tmp = SENSORS_LIMIT(val, 0, 15); 566 tol_tmp = clamp_val(val, 0, 15);
568 tol_tmp &= 0x0f; 567 tol_tmp &= 0x0f;
569 data->tolerance[nr] = tol_tmp; 568 data->tolerance[nr] = tol_tmp;
570 if (nr == 1) 569 if (nr == 1)