[PATCH] hwmon/dme1737: fix divide-by-0

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Juerg, Jean:

* Jean Delvare <khali at linux-fr.org> [2008-01-28 10:21:16 +0100]:
> Hi Juerg,
> 
> On Sun, 27 Jan 2008 16:39:46 -0800, Juerg Haefliger wrote:
> > This patch fixes a possible divide-by-0 and a minor bug in the
> > FAN_FROM_REG macro (in TPC mode).
> > 
> > Signed-off-by: Juerg Haefliger <juergh at gmail.com>
> >
> > Index: linux/drivers/hwmon/dme1737.c
> > ===================================================================
> > --- linux.orig/drivers/hwmon/dme1737.c	2008-01-24 09:04:24.000000000 -0800
> > +++ linux/drivers/hwmon/dme1737.c	2008-01-27 16:33:47.000000000 -0800
> > @@ -279,14 +279,21 @@
> >  /* Fan input RPM */
> >  static inline int FAN_FROM_REG(int reg, int tpc)
> >  {
> > -	return (reg == 0 || reg == 0xffff) ? 0 :
> > -		(tpc == 0) ? 90000 * 60 / reg : tpc * reg;
> > +	if (tpc) {
> > +		return tpc * reg;
> > +	} else {
> > +		return (reg == 0 || reg == 0xffff) ? 0 : 90000 * 60 / reg;
> > +	}
> >  }
> >  
> >  static inline int FAN_TO_REG(int val, int tpc)
> >  {
> > -	return SENSORS_LIMIT((tpc == 0) ? 90000 * 60 / val : val / tpc,
> > -			     0, 0xffff);
> > +	if (tpc) {
> > +		return SENSORS_LIMIT(val / tpc, 0, 0xffff);
> > +	} else {
> > +		return (val <= 0) ? 0xffff :
> > +			SENSORS_LIMIT(90000 * 60 / val, 0, 0xfffe);
> > +	}
> >  }
> >  
> >  /* Fan TPC (tach pulse count)
> 
> Looks good to me this time.
> 
> Acked-by: Jean Delvare <khali at linux-fr.org>

Applied to hwmon-2.6.git/testing, thanks.

-- 
Mark M. Hoffman
mhoffman at lightlink.com





[Index of Archives]     [Linux Kernel]     [Linux Hardware Monitoring]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux