diff options
| author | Ingo Molnar <mingo@kernel.org> | 2013-01-24 06:47:48 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2013-01-24 06:47:48 -0500 |
| commit | befddb21c845f8fb49e637997891ef97c6a869dc (patch) | |
| tree | 0e7629123184f2dd50291ad6d477b894175f0f26 /drivers/gpu/drm/ttm/ttm_execbuf_util.c | |
| parent | e716efde75267eab919cdb2bef5b2cb77f305326 (diff) | |
| parent | 7d1f9aeff1ee4a20b1aeb377dd0f579fe9647619 (diff) | |
Merge tag 'v3.8-rc4' into irq/core
Merge Linux 3.8-rc4 before pulling in new commits - we were on an old v3.7 base.
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'drivers/gpu/drm/ttm/ttm_execbuf_util.c')
| -rw-r--r-- | drivers/gpu/drm/ttm/ttm_execbuf_util.c | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c index 1937069432c5..cd9e4523dc56 100644 --- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c +++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c | |||
| @@ -185,10 +185,7 @@ retry_this_bo: | |||
| 185 | ttm_eu_backoff_reservation_locked(list); | 185 | ttm_eu_backoff_reservation_locked(list); |
| 186 | spin_unlock(&glob->lru_lock); | 186 | spin_unlock(&glob->lru_lock); |
| 187 | ttm_eu_list_ref_sub(list); | 187 | ttm_eu_list_ref_sub(list); |
| 188 | ret = ttm_bo_wait_cpu(bo, false); | 188 | return -EBUSY; |
| 189 | if (ret) | ||
| 190 | return ret; | ||
| 191 | goto retry; | ||
| 192 | } | 189 | } |
| 193 | } | 190 | } |
| 194 | 191 | ||
| @@ -216,19 +213,18 @@ void ttm_eu_fence_buffer_objects(struct list_head *list, void *sync_obj) | |||
| 216 | driver = bdev->driver; | 213 | driver = bdev->driver; |
| 217 | glob = bo->glob; | 214 | glob = bo->glob; |
| 218 | 215 | ||
| 219 | spin_lock(&bdev->fence_lock); | ||
| 220 | spin_lock(&glob->lru_lock); | 216 | spin_lock(&glob->lru_lock); |
| 217 | spin_lock(&bdev->fence_lock); | ||
| 221 | 218 | ||
| 222 | list_for_each_entry(entry, list, head) { | 219 | list_for_each_entry(entry, list, head) { |
| 223 | bo = entry->bo; | 220 | bo = entry->bo; |
| 224 | entry->old_sync_obj = bo->sync_obj; | 221 | entry->old_sync_obj = bo->sync_obj; |
| 225 | bo->sync_obj = driver->sync_obj_ref(sync_obj); | 222 | bo->sync_obj = driver->sync_obj_ref(sync_obj); |
| 226 | bo->sync_obj_arg = entry->new_sync_obj_arg; | ||
| 227 | ttm_bo_unreserve_locked(bo); | 223 | ttm_bo_unreserve_locked(bo); |
| 228 | entry->reserved = false; | 224 | entry->reserved = false; |
| 229 | } | 225 | } |
| 230 | spin_unlock(&glob->lru_lock); | ||
| 231 | spin_unlock(&bdev->fence_lock); | 226 | spin_unlock(&bdev->fence_lock); |
| 227 | spin_unlock(&glob->lru_lock); | ||
| 232 | 228 | ||
| 233 | list_for_each_entry(entry, list, head) { | 229 | list_for_each_entry(entry, list, head) { |
| 234 | if (entry->old_sync_obj) | 230 | if (entry->old_sync_obj) |
