summaryrefslogtreecommitdiff
path: root/include/uapi
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2019-07-03 21:06:01 +0300
committerChris Wilson <chris@chris-wilson.co.uk>2019-07-04 17:34:35 +0300
commit0c159ffef628fa94d0f4f9128e7f2b6f2b5e86ef (patch)
treeb03539a32585baf353d26f051bef55c9de15899d /include/uapi
parent21de5a9e34fb0f3efa31df5712cedc0ae97f7b4d (diff)
downloadlinux-0c159ffef628fa94d0f4f9128e7f2b6f2b5e86ef.tar.xz
drm/i915/gem: Defer obj->base.resv fini until RCU callback
Since reservation_object_fini() does an immediate free, rather than kfree_rcu as normal, we have to delay the release until after the RCU grace period has elapsed (i.e. from the rcu cleanup callback) so that we can rely on the RCU protected access to the fences while the object is a zombie. i915_gem_busy_ioctl relies on having an RCU barrier to protect the reservation in order to avoid having to take a reference and strong memory barriers. v2: Order is important; only release after putting the pages! Fixes: c03467ba40f7 ("drm/i915/gem: Free pages before rcu-freeing the object") Testcase: igt/gem_busy/close-race Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Matthew Auld <matthew.auld@intel.com> Reviewed-by: Mika Kuoppala <mika.kuoppala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190703180601.10950-1-chris@chris-wilson.co.uk
Diffstat (limited to 'include/uapi')
0 files changed, 0 insertions, 0 deletions