drm/nouveau/gem: return only valid domain when there's only one
authorIlia Mirkin <imirkin@alum.mit.edu>
Tue, 20 Oct 2015 05:15:39 +0000 (01:15 -0400)
committerZefan Li <lizefan@huawei.com>
Wed, 27 Apr 2016 10:55:29 +0000 (18:55 +0800)
commitb1d64b01ee7d043373a068c6b58b058876e56c7d
treed58b28ee7a19f23131ab5e2a05155d9ec64434e8
parentf9a3e62aa95e2f8c62e3d2c8188cbfe9fbfa1290
drm/nouveau/gem: return only valid domain when there's only one

commit 2a6c521bb41ce862e43db46f52e7681d33e8d771 upstream.

On nv50+, we restrict the valid domains to just the one where the buffer
was originally created. However after the buffer is evicted to system
memory, we might move it back to a different domain that was not
originally valid. When sharing the buffer and retrieving its GEM_INFO
data, we still want the domain that will be valid for this buffer in a
pushbuf, not the one where it currently happens to be.

This resolves fdo#92504 and several others. These are due to suspend
evicting all buffers, making it more likely that they temporarily end up
in the wrong place.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=92504
Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Signed-off-by: Zefan Li <lizefan@huawei.com>
drivers/gpu/drm/nouveau/nouveau_gem.c