ttm: Return -ERESTART when a signal interrupts bo eviction.
A bug caused the ttm code to just terminate the wait when a signal was received while waiting for the GPU to release a buffer object that was to be evicted. Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
9a298b2acd
commit
78ecf091aa
1 changed files with 6 additions and 3 deletions
|
@ -527,9 +527,12 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo, unsigned mem_type,
|
||||||
ret = ttm_bo_wait(bo, false, interruptible, no_wait);
|
ret = ttm_bo_wait(bo, false, interruptible, no_wait);
|
||||||
spin_unlock(&bo->lock);
|
spin_unlock(&bo->lock);
|
||||||
|
|
||||||
if (ret && ret != -ERESTART) {
|
if (unlikely(ret != 0)) {
|
||||||
printk(KERN_ERR TTM_PFX "Failed to expire sync object before "
|
if (ret != -ERESTART) {
|
||||||
|
printk(KERN_ERR TTM_PFX
|
||||||
|
"Failed to expire sync object before "
|
||||||
"buffer eviction.\n");
|
"buffer eviction.\n");
|
||||||
|
}
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue