aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2018-01-17 09:48:51 -0500
committerMartin K. Petersen <martin.petersen@oracle.com>2018-01-22 20:03:57 -0500
commitb45093dd76bed88ac72330c08338ea329c94d20c (patch)
treec8579fe778573906b183376265e9399603f6e2b1
parent22807aa812a65a7b859187e0fc6cfa0802a858c4 (diff)
scsi: megaraid: use ktime_get_real for firmware time
do_gettimeofday() overflows in 2038 on 32-bit architectures and is deprecated, so convert this driver to call ktime_get_real() directly. This also simplifies the calculation. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Sumit Saxena <sumit.saxena@broadcom.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r--drivers/scsi/megaraid/megaraid_sas_fusion.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/scsi/megaraid/megaraid_sas_fusion.c b/drivers/scsi/megaraid/megaraid_sas_fusion.c
index 0a85f3c48ef6..97fae28c8374 100644
--- a/drivers/scsi/megaraid/megaraid_sas_fusion.c
+++ b/drivers/scsi/megaraid/megaraid_sas_fusion.c
@@ -983,7 +983,7 @@ megasas_ioc_init_fusion(struct megasas_instance *instance)
983 MFI_CAPABILITIES *drv_ops; 983 MFI_CAPABILITIES *drv_ops;
984 u32 scratch_pad_2; 984 u32 scratch_pad_2;
985 unsigned long flags; 985 unsigned long flags;
986 struct timeval tv; 986 ktime_t time;
987 bool cur_fw_64bit_dma_capable; 987 bool cur_fw_64bit_dma_capable;
988 988
989 fusion = instance->ctrl_context; 989 fusion = instance->ctrl_context;
@@ -1042,10 +1042,9 @@ megasas_ioc_init_fusion(struct megasas_instance *instance)
1042 IOCInitMessage->HostMSIxVectors = instance->msix_vectors; 1042 IOCInitMessage->HostMSIxVectors = instance->msix_vectors;
1043 IOCInitMessage->HostPageSize = MR_DEFAULT_NVME_PAGE_SHIFT; 1043 IOCInitMessage->HostPageSize = MR_DEFAULT_NVME_PAGE_SHIFT;
1044 1044
1045 do_gettimeofday(&tv); 1045 time = ktime_get_real();
1046 /* Convert to milliseconds as per FW requirement */ 1046 /* Convert to milliseconds as per FW requirement */
1047 IOCInitMessage->TimeStamp = cpu_to_le64((tv.tv_sec * 1000) + 1047 IOCInitMessage->TimeStamp = cpu_to_le64(ktime_to_ms(time));
1048 (tv.tv_usec / 1000));
1049 1048
1050 init_frame = (struct megasas_init_frame *)cmd->frame; 1049 init_frame = (struct megasas_init_frame *)cmd->frame;
1051 memset(init_frame, 0, IOC_INIT_FRAME_SIZE); 1050 memset(init_frame, 0, IOC_INIT_FRAME_SIZE);