aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRob Clark <robdclark@gmail.com>2016-03-16 14:57:22 -0400
committerRob Clark <robdclark@gmail.com>2016-05-08 10:16:03 -0400
commit340ff4104f4454f8f1c3bf793c46411115309545 (patch)
treeaade7554b941603b793bbd4ff837f1d63f1beb22
parent79f0e20215bb902352cf7eb31222f4120563775c (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.h15
-rw-r--r--drivers/gpu/drm/msm/msm_fence.c11
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
305static 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,