Staging: rts5208: Replace timeval with timespec64
[firefly-linux-kernel-4.4.55.git] / drivers / staging / rts5208 / rtsx.h
index 262441bcfc41ab5f0b2a5c9bacbd11081ad88fd7..aa1e034f7f4552fa1153c9f0f299eacad45bbd43 100644 (file)
@@ -37,7 +37,7 @@
 #include <linux/cdrom.h>
 #include <linux/workqueue.h>
 #include <linux/timer.h>
-#include <linux/time.h>
+#include <linux/time64.h>
 
 #include <scsi/scsi.h>
 #include <scsi/scsi_cmnd.h>
@@ -148,21 +148,24 @@ static inline struct rtsx_dev *host_to_rtsx(struct Scsi_Host *host)
 
 static inline void get_current_time(u8 *timeval_buf, int buf_len)
 {
-       struct timeval tv;
+       struct timespec64 ts64;
+       u32 tv_usec;
 
        if (!timeval_buf || (buf_len < 8))
                return;
 
-       do_gettimeofday(&tv);
+       getnstimeofday64(&ts64);
 
-       timeval_buf[0] = (u8)(tv.tv_sec >> 24);
-       timeval_buf[1] = (u8)(tv.tv_sec >> 16);
-       timeval_buf[2] = (u8)(tv.tv_sec >> 8);
-       timeval_buf[3] = (u8)(tv.tv_sec);
-       timeval_buf[4] = (u8)(tv.tv_usec >> 24);
-       timeval_buf[5] = (u8)(tv.tv_usec >> 16);
-       timeval_buf[6] = (u8)(tv.tv_usec >> 8);
-       timeval_buf[7] = (u8)(tv.tv_usec);
+       tv_usec = ts64.tv_nsec/NSEC_PER_USEC;
+
+       timeval_buf[0] = (u8)(ts64.tv_sec >> 24);
+       timeval_buf[1] = (u8)(ts64.tv_sec >> 16);
+       timeval_buf[2] = (u8)(ts64.tv_sec >> 8);
+       timeval_buf[3] = (u8)(ts64.tv_sec);
+       timeval_buf[4] = (u8)(tv_usec >> 24);
+       timeval_buf[5] = (u8)(tv_usec >> 16);
+       timeval_buf[6] = (u8)(tv_usec >> 8);
+       timeval_buf[7] = (u8)(tv_usec);
 }
 
 /* The scsi_lock() and scsi_unlock() macros protect the sm_state and the