aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon
diff options
context:
space:
mode:
authorGuenter Roeck <linux@roeck-us.net>2013-11-20 13:25:17 -0500
committerGuenter Roeck <linux@roeck-us.net>2014-01-15 00:36:52 -0500
commitbf6ea084ebb54cf8e1d6e60aac3c727cf45bf6c7 (patch)
tree2a2feafbbaae6a0c5000bd217eb6e9327753af70 /drivers/hwmon
parentc09088d934c1e1672be8b3cfe3ba4f40ab2bf13e (diff)
hwmon: (coretemp) Do not return -EAGAIN for low temperatures
Some Intel CPUs do not set the 'valid' bit in IA32_THERM_STATUS if the temperature is too low to be measured. This condition will not change until the CPU is hot enough for its temperature to be measured. Returning an error in such conditions is not very useful. Drop checking the valid bit and just return the reported temperature instead. Reviewed-by: Jean Delvare <khali@linux-fr.org> Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Diffstat (limited to 'drivers/hwmon')
-rw-r--r--drivers/hwmon/coretemp.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/drivers/hwmon/coretemp.c b/drivers/hwmon/coretemp.c
index b2e59b395ce4..bbb0b0d463f7 100644
--- a/drivers/hwmon/coretemp.c
+++ b/drivers/hwmon/coretemp.c
@@ -177,18 +177,19 @@ static ssize_t show_temp(struct device *dev,
177 /* Check whether the time interval has elapsed */ 177 /* Check whether the time interval has elapsed */
178 if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) { 178 if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) {
179 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); 179 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx);
180 tdata->valid = 0; 180 /*
181 /* Check whether the data is valid */ 181 * Ignore the valid bit. In all observed cases the register
182 if (eax & 0x80000000) { 182 * value is either low or zero if the valid bit is 0.
183 tdata->temp = tdata->tjmax - 183 * Return it instead of reporting an error which doesn't
184 ((eax >> 16) & 0x7f) * 1000; 184 * really help at all.
185 tdata->valid = 1; 185 */
186 } 186 tdata->temp = tdata->tjmax - ((eax >> 16) & 0x7f) * 1000;
187 tdata->valid = 1;
187 tdata->last_updated = jiffies; 188 tdata->last_updated = jiffies;
188 } 189 }
189 190
190 mutex_unlock(&tdata->update_lock); 191 mutex_unlock(&tdata->update_lock);
191 return tdata->valid ? sprintf(buf, "%d\n", tdata->temp) : -EAGAIN; 192 return sprintf(buf, "%d\n", tdata->temp);
192} 193}
193 194
194struct tjmax_pci { 195struct tjmax_pci {