diff options
author | Maarten Lankhorst <maarten.lankhorst@canonical.com> | 2012-11-06 08:39:43 -0500 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2012-11-20 01:17:35 -0500 |
commit | 654aa79259a19f0d5e3cf9cb20aff56dc3b041b7 (patch) | |
tree | 406029f079300aac57d3463cf952b68d122619e9 | |
parent | 6c1e963cc5771c93d4ed7aa8bdd4322a7c918e9b (diff) |
drm/ttm: alter cpu_writers to return -EBUSY in ttm_execbuf_util reservations
This is similar to other platforms that don't allow command submission
to buffers locked on the cpu.
Signed-off-by: Maarten Lankhorst <maarten.lankhorst@canonical.com>
Reviewed-by: Thomas Hellstrom <thellstrom@vmware.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r-- | drivers/gpu/drm/ttm/ttm_bo.c | 13 | ||||
-rw-r--r-- | drivers/gpu/drm/ttm/ttm_execbuf_util.c | 5 | ||||
-rw-r--r-- | include/drm/ttm/ttm_bo_api.h | 5 | ||||
-rw-r--r-- | include/drm/ttm/ttm_bo_driver.h | 14 |
4 files changed, 5 insertions, 32 deletions
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c index 5f61f133b419..7426fe59108e 100644 --- a/drivers/gpu/drm/ttm/ttm_bo.c +++ b/drivers/gpu/drm/ttm/ttm_bo.c | |||
@@ -1053,16 +1053,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, | |||
1053 | } | 1053 | } |
1054 | EXPORT_SYMBOL(ttm_bo_mem_space); | 1054 | EXPORT_SYMBOL(ttm_bo_mem_space); |
1055 | 1055 | ||
1056 | int ttm_bo_wait_cpu(struct ttm_buffer_object *bo, bool no_wait) | ||
1057 | { | ||
1058 | if ((atomic_read(&bo->cpu_writers) > 0) && no_wait) | ||
1059 | return -EBUSY; | ||
1060 | |||
1061 | return wait_event_interruptible(bo->event_queue, | ||
1062 | atomic_read(&bo->cpu_writers) == 0); | ||
1063 | } | ||
1064 | EXPORT_SYMBOL(ttm_bo_wait_cpu); | ||
1065 | |||
1066 | int ttm_bo_move_buffer(struct ttm_buffer_object *bo, | 1056 | int ttm_bo_move_buffer(struct ttm_buffer_object *bo, |
1067 | struct ttm_placement *placement, | 1057 | struct ttm_placement *placement, |
1068 | bool interruptible, bool no_wait_reserve, | 1058 | bool interruptible, bool no_wait_reserve, |
@@ -1788,8 +1778,7 @@ EXPORT_SYMBOL(ttm_bo_synccpu_write_grab); | |||
1788 | 1778 | ||
1789 | void ttm_bo_synccpu_write_release(struct ttm_buffer_object *bo) | 1779 | void ttm_bo_synccpu_write_release(struct ttm_buffer_object *bo) |
1790 | { | 1780 | { |
1791 | if (atomic_dec_and_test(&bo->cpu_writers)) | 1781 | atomic_dec(&bo->cpu_writers); |
1792 | wake_up_all(&bo->event_queue); | ||
1793 | } | 1782 | } |
1794 | EXPORT_SYMBOL(ttm_bo_synccpu_write_release); | 1783 | EXPORT_SYMBOL(ttm_bo_synccpu_write_release); |
1795 | 1784 | ||
diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c index b227a9961a07..1986d006c264 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 | ||
diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h index 5ff938df5fce..c6cae733ddef 100644 --- a/include/drm/ttm/ttm_bo_api.h +++ b/include/drm/ttm/ttm_bo_api.h | |||
@@ -424,8 +424,9 @@ extern void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, | |||
424 | * @no_wait: Return immediately if buffer is busy. | 424 | * @no_wait: Return immediately if buffer is busy. |
425 | * | 425 | * |
426 | * Synchronizes a buffer object for CPU RW access. This means | 426 | * Synchronizes a buffer object for CPU RW access. This means |
427 | * blocking command submission that affects the buffer and | 427 | * command submission that affects the buffer will return -EBUSY |
428 | * waiting for buffer idle. This lock is recursive. | 428 | * until ttm_bo_synccpu_write_release is called. |
429 | * | ||
429 | * Returns | 430 | * Returns |
430 | * -EBUSY if the buffer is busy and no_wait is true. | 431 | * -EBUSY if the buffer is busy and no_wait is true. |
431 | * -ERESTARTSYS if interrupted by a signal. | 432 | * -ERESTARTSYS if interrupted by a signal. |
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h index 4789beee3b77..dd96442cdc2a 100644 --- a/include/drm/ttm/ttm_bo_driver.h +++ b/include/drm/ttm/ttm_bo_driver.h | |||
@@ -726,20 +726,6 @@ extern void ttm_bo_mem_put(struct ttm_buffer_object *bo, | |||
726 | extern void ttm_bo_mem_put_locked(struct ttm_buffer_object *bo, | 726 | extern void ttm_bo_mem_put_locked(struct ttm_buffer_object *bo, |
727 | struct ttm_mem_reg *mem); | 727 | struct ttm_mem_reg *mem); |
728 | 728 | ||
729 | /** | ||
730 | * ttm_bo_wait_for_cpu | ||
731 | * | ||
732 | * @bo: Pointer to a struct ttm_buffer_object. | ||
733 | * @no_wait: Don't sleep while waiting. | ||
734 | * | ||
735 | * Wait until a buffer object is no longer sync'ed for CPU access. | ||
736 | * Returns: | ||
737 | * -EBUSY: Buffer object was sync'ed for CPU access. (only if no_wait == 1). | ||
738 | * -ERESTARTSYS: An interruptible sleep was interrupted by a signal. | ||
739 | */ | ||
740 | |||
741 | extern int ttm_bo_wait_cpu(struct ttm_buffer_object *bo, bool no_wait); | ||
742 | |||
743 | extern void ttm_bo_global_release(struct drm_global_reference *ref); | 729 | extern void ttm_bo_global_release(struct drm_global_reference *ref); |
744 | extern int ttm_bo_global_init(struct drm_global_reference *ref); | 730 | extern int ttm_bo_global_init(struct drm_global_reference *ref); |
745 | 731 | ||