drm/i915: Fix rsvd2 mask when out-fence is returned
GENMASK_ULL wants the high bit of the mask first. The current value
cancels the in-fence when an out-fence is returned.
Fixes: fec0445caa
("drm/i915: Support explicit fencing for execbuf")
Testcase: igt/gem_exec_fence/keep-in-fence*
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20180214191827.8465-1-daniele.ceraolospurio@intel.com
Cc: <stable@vger.kernel.org> # v4.12+
This commit is contained in:
parent
31383410f5
commit
b6a88e4a80
@ -2410,7 +2410,7 @@ err_request:
|
|||||||
if (out_fence) {
|
if (out_fence) {
|
||||||
if (err == 0) {
|
if (err == 0) {
|
||||||
fd_install(out_fence_fd, out_fence->file);
|
fd_install(out_fence_fd, out_fence->file);
|
||||||
args->rsvd2 &= GENMASK_ULL(0, 31); /* keep in-fence */
|
args->rsvd2 &= GENMASK_ULL(31, 0); /* keep in-fence */
|
||||||
args->rsvd2 |= (u64)out_fence_fd << 32;
|
args->rsvd2 |= (u64)out_fence_fd << 32;
|
||||||
out_fence_fd = -1;
|
out_fence_fd = -1;
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user