For ZFS, change the type of clock_t to int64_t.

The clock_t type in OpenSolaris is long (int64_t on amd64).
On FreeBSD clock_t is int32_t. The clock_t type is used in several places
in the ZFS code to store system uptime in milliseconds ("seconds * hz").

With hz=1000 we have a 32-bit integer overflow in 24 days, 20 hours,
31 minutes and 23.648 seconds. This has a user reported negative impact
on l2arc_feed_thread() and may cause unexpected results from other functions
using clock_t.

Reported by:	Artem Belevich <fbsdlist@src.cx> on freebsd-fs@
MFC after:	1 week
This commit is contained in:
mm 2011-02-01 14:28:50 +00:00
parent d690434e20
commit cab1b4d893

View File

@ -34,6 +34,10 @@
*/ */
#include <sys/stdint.h> #include <sys/stdint.h>
typedef int64_t clock_t;
#define _CLOCK_T_DECLARED
#include_next <sys/types.h> #include_next <sys/types.h>
#define MAXNAMELEN 256 #define MAXNAMELEN 256