[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <5443D519.1090408@roeck-us.net>
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