提交 bf6ea084 编写于 作者: G Guenter Roeck

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: NJean Delvare <khali@linux-fr.org>
Signed-off-by: NGuenter Roeck <linux@roeck-us.net>
上级 c09088d9
...@@ -177,18 +177,19 @@ static ssize_t show_temp(struct device *dev, ...@@ -177,18 +177,19 @@ static ssize_t show_temp(struct device *dev,
/* Check whether the time interval has elapsed */ /* Check whether the time interval has elapsed */
if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) { if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) {
rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx);
tdata->valid = 0; /*
/* Check whether the data is valid */ * Ignore the valid bit. In all observed cases the register
if (eax & 0x80000000) { * value is either low or zero if the valid bit is 0.
tdata->temp = tdata->tjmax - * Return it instead of reporting an error which doesn't
((eax >> 16) & 0x7f) * 1000; * really help at all.
tdata->valid = 1; */
} tdata->temp = tdata->tjmax - ((eax >> 16) & 0x7f) * 1000;
tdata->valid = 1;
tdata->last_updated = jiffies; tdata->last_updated = jiffies;
} }
mutex_unlock(&tdata->update_lock); mutex_unlock(&tdata->update_lock);
return tdata->valid ? sprintf(buf, "%d\n", tdata->temp) : -EAGAIN; return sprintf(buf, "%d\n", tdata->temp);
} }
struct tjmax_pci { struct tjmax_pci {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册