diff options
author | Rob Clark <robdclark@gmail.com> | 2016-03-16 14:57:22 -0400 |
---|---|---|
committer | Rob Clark <robdclark@gmail.com> | 2016-05-08 10:16:03 -0400 |
commit | 340ff4104f4454f8f1c3bf793c46411115309545 (patch) | |
tree | aade7554b941603b793bbd4ff837f1d63f1beb22 | |
parent | 79f0e20215bb902352cf7eb31222f4120563775c (diff) |
drm/msm: split out timeout_to_jiffies helper
Signed-off-by: Rob Clark <robdclark@gmail.com>
-rw-r--r-- | drivers/gpu/drm/msm/msm_drv.h | 15 | ||||
-rw-r--r-- | drivers/gpu/drm/msm/msm_fence.c | 11 |
2 files changed, 16 insertions, 10 deletions
diff --git a/drivers/gpu/drm/msm/msm_drv.h b/drivers/gpu/drm/msm/msm_drv.h index 86b7b3796d8f..af007ac8c733 100644 --- a/drivers/gpu/drm/msm/msm_drv.h +++ b/drivers/gpu/drm/msm/msm_drv.h | |||
@@ -302,5 +302,20 @@ static inline int align_pitch(int width, int bpp) | |||
302 | /* for conditionally setting boolean flag(s): */ | 302 | /* for conditionally setting boolean flag(s): */ |
303 | #define COND(bool, val) ((bool) ? (val) : 0) | 303 | #define COND(bool, val) ((bool) ? (val) : 0) |
304 | 304 | ||
305 | static inline unsigned long timeout_to_jiffies(const ktime_t *timeout) | ||
306 | { | ||
307 | ktime_t now = ktime_get(); | ||
308 | unsigned long remaining_jiffies; | ||
309 | |||
310 | if (ktime_compare(*timeout, now) < 0) { | ||
311 | remaining_jiffies = 0; | ||
312 | } else { | ||
313 | ktime_t rem = ktime_sub(*timeout, now); | ||
314 | struct timespec ts = ktime_to_timespec(rem); | ||
315 | remaining_jiffies = timespec_to_jiffies(&ts); | ||
316 | } | ||
317 | |||
318 | return remaining_jiffies; | ||
319 | } | ||
305 | 320 | ||
306 | #endif /* __MSM_DRV_H__ */ | 321 | #endif /* __MSM_DRV_H__ */ |
diff --git a/drivers/gpu/drm/msm/msm_fence.c b/drivers/gpu/drm/msm/msm_fence.c index 55a5f9280088..002eecb3934e 100644 --- a/drivers/gpu/drm/msm/msm_fence.c +++ b/drivers/gpu/drm/msm/msm_fence.c | |||
@@ -44,16 +44,7 @@ int msm_wait_fence(struct drm_device *dev, uint32_t fence, | |||
44 | /* no-wait: */ | 44 | /* no-wait: */ |
45 | ret = fence_completed(dev, fence) ? 0 : -EBUSY; | 45 | ret = fence_completed(dev, fence) ? 0 : -EBUSY; |
46 | } else { | 46 | } else { |
47 | ktime_t now = ktime_get(); | 47 | unsigned long remaining_jiffies = timeout_to_jiffies(timeout); |
48 | unsigned long remaining_jiffies; | ||
49 | |||
50 | if (ktime_compare(*timeout, now) < 0) { | ||
51 | remaining_jiffies = 0; | ||
52 | } else { | ||
53 | ktime_t rem = ktime_sub(*timeout, now); | ||
54 | struct timespec ts = ktime_to_timespec(rem); | ||
55 | remaining_jiffies = timespec_to_jiffies(&ts); | ||
56 | } | ||
57 | 48 | ||
58 | if (interruptible) | 49 | if (interruptible) |
59 | ret = wait_event_interruptible_timeout(priv->fence_event, | 50 | ret = wait_event_interruptible_timeout(priv->fence_event, |