aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorAlex Deucher <alexdeucher@gmail.com>2009-09-08 14:45:05 -0400
committerDave Airlie <airlied@linux.ie>2009-09-08 18:17:57 -0400
commitcecc6b63a5de547a345c491bb4c18c01a15984a4 (patch)
tree6092e559358347c5db904dec4070a9c2812704d1 /drivers
parent60d15f551abdbc5fef70d85f55aac1e85950bf59 (diff)
drm/radeon/r600: use fence->timeout directly
Fixes fence timeouts on r6xx/r7xx. Noticed by taiu on IRC. Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/radeon/radeon_fence.c11
1 files changed, 1 insertions, 10 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_fence.c b/drivers/gpu/drm/radeon/radeon_fence.c
index 01a89633e265..3beb26d74719 100644
--- a/drivers/gpu/drm/radeon/radeon_fence.c
+++ b/drivers/gpu/drm/radeon/radeon_fence.c
@@ -171,17 +171,8 @@ bool radeon_fence_signaled(struct radeon_fence *fence)
171int r600_fence_wait(struct radeon_fence *fence, bool intr, bool lazy) 171int r600_fence_wait(struct radeon_fence *fence, bool intr, bool lazy)
172{ 172{
173 struct radeon_device *rdev; 173 struct radeon_device *rdev;
174 unsigned long cur_jiffies;
175 unsigned long timeout;
176 int ret = 0; 174 int ret = 0;
177 175
178 cur_jiffies = jiffies;
179 timeout = HZ / 100;
180
181 if (time_after(fence->timeout, cur_jiffies)) {
182 timeout = fence->timeout - cur_jiffies;
183 }
184
185 rdev = fence->rdev; 176 rdev = fence->rdev;
186 177
187 __set_current_state(intr ? TASK_INTERRUPTIBLE : TASK_UNINTERRUPTIBLE); 178 __set_current_state(intr ? TASK_INTERRUPTIBLE : TASK_UNINTERRUPTIBLE);
@@ -190,7 +181,7 @@ int r600_fence_wait(struct radeon_fence *fence, bool intr, bool lazy)
190 if (radeon_fence_signaled(fence)) 181 if (radeon_fence_signaled(fence))
191 break; 182 break;
192 183
193 if (time_after_eq(jiffies, timeout)) { 184 if (time_after_eq(jiffies, fence->timeout)) {
194 ret = -EBUSY; 185 ret = -EBUSY;
195 break; 186 break;
196 } 187 }