diff options
author | Brian Behlendorf <[email protected]> | 2018-06-19 21:51:18 -0700 |
---|---|---|
committer | GitHub <[email protected]> | 2018-06-19 21:51:18 -0700 |
commit | 6413c95fbd88dc06ae57e50398b8530a17d0c7d3 (patch) | |
tree | eaa8a5618a917abcf0a4e30e328be4db4bd3e710 /include/spl/sys | |
parent | aeb39df72615b896db2b69921d7d887f1bb0a396 (diff) |
Linux 4.18 compat: inode timespec -> timespec64
Commit torvalds/linux@95582b0 changes the inode i_atime, i_mtime,
and i_ctime members form timespec's to timespec64's to make them
2038 safe. As part of this change the current_time() function was
also updated to return the timespec64 type.
Resolve this issue by introducing a new inode_timespec_t type which
is defined to match the timespec type used by the inode. It should
be used when working with inode timestamps to ensure matching types.
The timestruc_t type under Illumos was used in a similar fashion but
was specified to always be a timespec_t. Rather than incorrectly
define this type all timespec_t types have been replaced by the new
inode_timespec_t type.
Finally, the kernel and user space 'sys/time.h' headers were aligned
with each other. They define as appropriate for the context several
constants as macros and include static inline implementation of
gethrestime(), gethrestime_sec(), and gethrtime().
Reviewed-by: Chunwei Chen <[email protected]>
Signed-off-by: Brian Behlendorf <[email protected]>
Closes #7643
Diffstat (limited to 'include/spl/sys')
-rw-r--r-- | include/spl/sys/condvar.h | 1 | ||||
-rw-r--r-- | include/spl/sys/time.h | 23 | ||||
-rw-r--r-- | include/spl/sys/types.h | 4 | ||||
-rw-r--r-- | include/spl/sys/vnode.h | 6 |
4 files changed, 22 insertions, 12 deletions
diff --git a/include/spl/sys/condvar.h b/include/spl/sys/condvar.h index 1d47cdd96..28caea571 100644 --- a/include/spl/sys/condvar.h +++ b/include/spl/sys/condvar.h @@ -30,6 +30,7 @@ #include <sys/mutex.h> #include <sys/callo.h> #include <sys/wait.h> +#include <sys/time.h> /* * The kcondvar_t struct is protected by mutex taken externally before diff --git a/include/spl/sys/time.h b/include/spl/sys/time.h index d6aaca913..14d3ec2c9 100644 --- a/include/spl/sys/time.h +++ b/include/spl/sys/time.h @@ -54,13 +54,26 @@ static const int hz = HZ; +typedef longlong_t hrtime_t; +typedef struct timespec timespec_t; + #define TIMESPEC_OVERFLOW(ts) \ ((ts)->tv_sec < TIME_MIN || (ts)->tv_sec > TIME_MAX) +#if defined(HAVE_INODE_TIMESPEC64_TIMES) +typedef struct timespec64 inode_timespec_t; +#else +typedef struct timespec inode_timespec_t; +#endif + static inline void -gethrestime(timestruc_t *now) +gethrestime(inode_timespec_t *ts) { - *now = current_kernel_time(); +#if defined(HAVE_INODE_TIMESPEC64_TIMES) + *ts = current_kernel_time64(); +#else + *ts = current_kernel_time(); +#endif } static inline time_t @@ -74,9 +87,9 @@ gethrestime_sec(void) static inline hrtime_t gethrtime(void) { - struct timespec now; - getrawmonotonic(&now); - return (((hrtime_t)now.tv_sec * NSEC_PER_SEC) + now.tv_nsec); + struct timespec ts; + getrawmonotonic(&ts); + return (((hrtime_t)ts.tv_sec * NSEC_PER_SEC) + ts.tv_nsec); } #endif /* _SPL_TIME_H */ diff --git a/include/spl/sys/types.h b/include/spl/sys/types.h index 3bb3ed3e2..483e36751 100644 --- a/include/spl/sys/types.h +++ b/include/spl/sys/types.h @@ -53,10 +53,6 @@ typedef unsigned long long rlim64_t; typedef struct task_struct kthread_t; typedef struct task_struct proc_t; -typedef struct timespec timestruc_t; -typedef struct timespec timespec_t; -typedef longlong_t hrtime_t; - typedef int id_t; typedef short pri_t; typedef short index_t; diff --git a/include/spl/sys/vnode.h b/include/spl/sys/vnode.h index d3b903f13..2c038a6d2 100644 --- a/include/spl/sys/vnode.h +++ b/include/spl/sys/vnode.h @@ -128,9 +128,9 @@ typedef struct vattr { long va_nodeid; /* node # */ uint32_t va_nlink; /* # links */ uint64_t va_size; /* file size */ - struct timespec va_atime; /* last acc */ - struct timespec va_mtime; /* last mod */ - struct timespec va_ctime; /* last chg */ + inode_timespec_t va_atime; /* last acc */ + inode_timespec_t va_mtime; /* last mod */ + inode_timespec_t va_ctime; /* last chg */ dev_t va_rdev; /* dev */ uint64_t va_nblocks; /* space used */ uint32_t va_blksize; /* block size */ |