Re: [PATCH 1/2] Read temperature as a signed value.
From: Guenter Roeck
Date: Thu Nov 13 2025 - 15:19:58 EST
On Thu, Nov 13, 2025 at 11:00:23AM +0100, Marius Zachmann wrote:
> Convert temperature to s16 to correctly read negative temperatures.
>
> Signed-off-by: Marius Zachmann <mail@xxxxxxxxxxxxxxxxx>
> ---
> drivers/hwmon/corsair-cpro.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/hwmon/corsair-cpro.c b/drivers/hwmon/corsair-cpro.c
> index b7b911f8359c..6e1c415f3e26 100644
> --- a/drivers/hwmon/corsair-cpro.c
> +++ b/drivers/hwmon/corsair-cpro.c
> @@ -40,7 +40,7 @@
> #define CTL_GET_TMP 0x11 /*
> * send: byte 1 is channel, rest zero
> * rcv: returns temp for channel in centi-degree celsius
> - * in bytes 1 and 2
> + * in bytes 1 and 2 as a two's complement value
> * returns 0x11 in byte 0 if no sensor is connected
> */
> #define CTL_GET_VOLT 0x12 /*
> @@ -258,7 +258,7 @@ static int ccp_read(struct device *dev, enum hwmon_sensor_types type,
> ret = get_data(ccp, CTL_GET_TMP, channel, true);
> if (ret < 0)
> return ret;
> - *val = ret * 10;
> + *val = (s16) ret * 10;
checkpatch:
CHECK: No space necessary after a cast
No need to resend, I'll patch that up.
Applied.
Guenter