lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Sun, 19 Oct 2014 08:13:29 -0700 From: Guenter Roeck <linux@...ck-us.net> To: Pali Rohár <pali.rohar@...il.com>, Arnd Bergmann <arnd@...db.de>, Greg Kroah-Hartman <gregkh@...uxfoundation.org> CC: linux-kernel@...r.kernel.org, Steven Honeyman <stevenhoneyman@...il.com> Subject: Re: [PATCH] i8k: Ignore temperature sensors which report invalid values On 10/19/2014 07:46 AM, Pali Rohár wrote: > On some machines some temperature sensors report too high values which are What is "too high", and what is "some machines" ? Would be great if you can be more specific. > invalid. When value is invalid function i8k_get_temp() returns previous > value and at next call it returns I8K_MAX_TEMP. > > With this patch also firt i8k_get_temp() call returns I8K_MAX_TEMP and fix ? Also, I am not entirely sure I understand what exactly you are fixing here. > i8k_init_hwmon() will ignore all sensor ids which report incorrect values. > > Signed-off-by: Pali Rohár <pali.rohar@...il.com> > --- > drivers/char/i8k.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/drivers/char/i8k.c b/drivers/char/i8k.c > index 7272b08..bc327fa 100644 > --- a/drivers/char/i8k.c > +++ b/drivers/char/i8k.c > @@ -298,7 +298,7 @@ static int i8k_get_temp(int sensor) > int temp; > > #ifdef I8K_TEMPERATURE_BUG > - static int prev[4]; > + static int prev[4] = { I8K_MAX_TEMP, I8K_MAX_TEMP, I8K_MAX_TEMP, I8K_MAX_TEMP }; I am not sure I understand what this change is expected to accomplish. Please explain. > #endif > regs.ebx = sensor & 0xff; > rc = i8k_smm(®s); > @@ -610,17 +610,17 @@ static int __init i8k_init_hwmon(void) > > /* CPU temperature attributes, if temperature reading is OK */ > err = i8k_get_temp(0); > - if (err >= 0) > + if (err >= 0 && err < I8K_MAX_TEMP) I8K_MAX_TEMP is, at least in theory, a valid temperature, so this should be "<=". It would be important to understand what the "too high" temperature is to possibly be able to distinguish it from the buggy temperature that the code is trying to fix. Thanks, Guenter > i8k_hwmon_flags |= I8K_HWMON_HAVE_TEMP1; > /* check for additional temperature sensors */ > err = i8k_get_temp(1); > - if (err >= 0) > + if (err >= 0 && err < I8K_MAX_TEMP) > i8k_hwmon_flags |= I8K_HWMON_HAVE_TEMP2; > err = i8k_get_temp(2); > - if (err >= 0) > + if (err >= 0 && err < I8K_MAX_TEMP) > i8k_hwmon_flags |= I8K_HWMON_HAVE_TEMP3; > err = i8k_get_temp(3); > - if (err >= 0) > + if (err >= 0 && err < I8K_MAX_TEMP) > i8k_hwmon_flags |= I8K_HWMON_HAVE_TEMP4; > > /* Left fan attributes, if left fan is present */ > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists