summaryrefslogtreecommitdiff
path: root/drivers/scsi/scsi_module.c
diff options
context:
space:
mode:
authorAlison Schofield <amsfield22@gmail.com>2015-11-09 22:34:20 +0300
committerMartin K. Petersen <martin.petersen@oracle.com>2015-11-12 04:51:04 +0300
commit9c9bd593f30fc8a4d6e70d72b49b5651fa492e65 (patch)
tree3d92a7bd095e43985f94a271105f3e24c68ee8a5 /drivers/scsi/scsi_module.c
parent36f8ef7f7684997f1c1efcc775b1d7cdf452ce44 (diff)
downloadlinux-9c9bd593f30fc8a4d6e70d72b49b5651fa492e65.tar.xz
scsi: pmcraid: replace struct timeval with ktime_get_real_seconds()
Replace the use of struct timeval and do_gettimeofday() with 64 bit ktime_get_real_seconds. Prevents 32-bit type overflow in year 2038 on 32-bit systems. Driver was using the seconds portion of struct timeval (.tv_secs) to pass a millseconds timestamp to the firmware. This change maintains that same behavior using ktime_get_real_seconds. The structure used to pass the timestamp to firmware is 48 bits and works fine as long as the top 16 bits are zero and they will be zero for a long time..ie. thousands of years. Alternative Change: Add sub second granularity to timestamp As noted above, the driver only used the seconds portion of timeval, ignores the microseconds portion, and by multiplying by 1000 effectively does a <<10 and always writes zero into timestamp[0]. The alternative change would pass all the bits to the firmware: struct timespec64 ts; ktime_get_real_ts64(&ts); timestamp = ts.tv_sec * MSEC_PER_SEC + ts.tv_nsec / NSEC_PER_MSEC; Signed-off-by: Alison Schofield <amsfield22@gmail.com> Reviewed-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/scsi/scsi_module.c')
0 files changed, 0 insertions, 0 deletions