diff options
author | cheloha <cheloha@cvs.openbsd.org> | 2020-07-07 04:05:26 +0000 |
---|---|---|
committer | cheloha <cheloha@cvs.openbsd.org> | 2020-07-07 04:05:26 +0000 |
commit | f791f099684704cbfc4c303d96c592cf6a1be130 (patch) | |
tree | 7cd8bf2c1918e1c53372a7235bfd906cabd6ff7a /sys/dev/pci | |
parent | 726f1f53346c71076876de6e7ff054850758c1d2 (diff) |
drm: use hi-res time to implement ktime_get(), ktime_get_real()
There seems to have been some confusion about the granularity of
certain time interfaces in the Linux kernel when our DRM compatibility
layer was written.
To be clear: the Linux ktime_get() and ktime_get_real() interfaces are
*high resolution* clocks. We should to implement them with high
resolution interfaces from our own kernel.
Thus, use microuptime(9) to implement ktime_get() and microtime(9) to
implement ktime_get_real().
While here, ktime_get_raw_ns() should use ktime_get_raw(), not
ktime_get().
Discussed with kettenis@ and jsg@.
ok jsg@
Diffstat (limited to 'sys/dev/pci')
-rw-r--r-- | sys/dev/pci/drm/include/linux/ktime.h | 6 | ||||
-rw-r--r-- | sys/dev/pci/drm/include/linux/timekeeping.h | 2 |
2 files changed, 4 insertions, 4 deletions
diff --git a/sys/dev/pci/drm/include/linux/ktime.h b/sys/dev/pci/drm/include/linux/ktime.h index 8edf0205069..4e744bd9e66 100644 --- a/sys/dev/pci/drm/include/linux/ktime.h +++ b/sys/dev/pci/drm/include/linux/ktime.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ktime.h,v 1.3 2020/06/29 08:42:00 jsg Exp $ */ +/* $OpenBSD: ktime.h,v 1.4 2020/07/07 04:05:25 cheloha Exp $ */ /* * Copyright (c) 2013, 2014, 2015 Mark Kettenis * @@ -29,7 +29,7 @@ ktime_get(void) { struct timeval tv; - getmicrouptime(&tv); + microuptime(&tv); return tv; } @@ -63,7 +63,7 @@ ktime_to_ns(struct timeval tv) static inline int64_t ktime_get_raw_ns(void) { - return ktime_to_ns(ktime_get()); + return ktime_to_ns(ktime_get_raw()); } static inline struct timespec64 diff --git a/sys/dev/pci/drm/include/linux/timekeeping.h b/sys/dev/pci/drm/include/linux/timekeeping.h index ea19385fad6..a2a6828e966 100644 --- a/sys/dev/pci/drm/include/linux/timekeeping.h +++ b/sys/dev/pci/drm/include/linux/timekeeping.h @@ -16,7 +16,7 @@ static inline struct timeval ktime_get_real(void) { struct timeval tv; - getmicrotime(&tv); + microtime(&tv); return tv; } |