mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
drm/i915: If interrupted while setting object domains, still emit the flush.
Otherwise, we would leave the objects in an inconsistent state, such as write_domain == 0 but on the flushing list. Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
ce44b0ea3d
commit
b670d81582
@ -1880,8 +1880,20 @@ i915_gem_execbuffer(struct drm_device *dev, void *data,
|
|||||||
ret = i915_gem_object_set_domain(obj,
|
ret = i915_gem_object_set_domain(obj,
|
||||||
obj->pending_read_domains,
|
obj->pending_read_domains,
|
||||||
obj->pending_write_domain);
|
obj->pending_write_domain);
|
||||||
if (ret)
|
if (ret) {
|
||||||
|
/* As we've partially updated domains on our buffers,
|
||||||
|
* we have to emit the flush we've accumulated
|
||||||
|
* before exiting, or we'll have broken the
|
||||||
|
* active/flushing/inactive invariants.
|
||||||
|
*
|
||||||
|
* We'll potentially have some things marked as
|
||||||
|
* being in write domains that they actually aren't,
|
||||||
|
* but that should be merely a minor performance loss.
|
||||||
|
*/
|
||||||
|
flush_domains = i915_gem_dev_set_domain(dev);
|
||||||
|
(void)i915_add_request(dev, flush_domains);
|
||||||
goto err;
|
goto err;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
i915_verify_inactive(dev, __FILE__, __LINE__);
|
i915_verify_inactive(dev, __FILE__, __LINE__);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user