freebsd-skq/sys/dev/buslogic
Steven Hartland 85c9dd9d89 Prevent overflow issues in timeout processing
Previously, any timeout value for which (timeout * hz) will overflow the
signed integer, will give weird results, since callout(9) routines will
convert negative values of ticks to '1'. For unsigned integer overflow we
will get sufficiently smaller timeout values than expected.

Switch from callout_reset, which requires conversion to int based ticks
to callout_reset_sbt to avoid this.

Also correct isci to correctly resolve ccb timeout.

This was based on the original work done by Eygene Ryabinkin
<rea@freebsd.org> back in 5 Aug 2011 which used a macro to help avoid
the overlow.

Differential Revision:	https://reviews.freebsd.org/D1157
Reviewed by:	mav, davide
MFC after:	1 month
Sponsored by:	Multiplay
2014-11-21 21:01:24 +00:00
..
bt_eisa.c Add locking to the bt(4) driver and mark it MPSAFE. 2012-10-15 16:13:55 +00:00
bt_isa.c Add locking to the bt(4) driver and mark it MPSAFE. 2012-10-15 16:13:55 +00:00
bt_mca.c Add locking to the bt(4) driver and mark it MPSAFE. 2012-10-15 16:13:55 +00:00
bt_pci.c Update PCI drivers to no longer look at the MEMIO-enabled bit in the PCI 2013-08-12 23:30:01 +00:00
bt.c Prevent overflow issues in timeout processing 2014-11-21 21:01:24 +00:00
btreg.h Add locking to the bt(4) driver and mark it MPSAFE. 2012-10-15 16:13:55 +00:00