[PATCH 0/9] drm/syncobj: Add full-featured wait support (v2)

Jason Ekstrand jason at jlekstrand.net
Sun Aug 13 15:26:10 UTC 2017


On August 13, 2017 6:19:53 AM Christian König <christian.koenig at amd.com> wrote:

> Patches #1-#4 are Acked-by: Christian König <christian.koenig at amd.com>.
>
> Patch #5: NAK, that will break radeon.
>
> On radeon we need the non-default wait or otherwise we can run into a
> situation where we never signal a fence.
>
> The general question is why do you need this?

Because i915 sets a non-default wait function so calling wait_any just 
bails with fences from i915 immediately bails with -EINVAL.  This makes it 
work even with non-default waits.

> Patch #6: Yes, please. Patch is Reviewed-by: Christian König
> <christian.koenig at amd.com>.
>
> Patch #7: Already gave my rb on the patch Chris send out earlier.
>
> Patch #8: NAK to the whole approach.
>
> IIRC we discussed a very similar thing during the initial fence bringup
> and also during the fence_array development.
>
> The problem is that you can easily build ring dependencies and so
> deadlocks with it.
>
> I would really prefer an approach which is completely contained inside
> the syncobj code base.

Are you use to the approach of internally making a proxy so long as all the 
proxy code is inside syncobj?  Is also be happy to go back to the original 
approach with v3 of the last patch.

> Regards,
> Christian.
>
> Am 12.08.2017 um 00:39 schrieb Jason Ekstrand:
>> This series does the same thing as my earlier series in that it adds a sync
>> object wait interface complete with WAIT_FOR_SUBMIT flag.  While the uapi
>> remains unchanged, the guts look a bit different.  Instead of adding a
>> callback mechanism to drm_syncobj that fired whenever replace_fence was
>> called, it's now using proxy fences.  The drm_syncobj_fence_get still
>> returns NULL whenever the sync object is in an unsubmitted state but there
>> is a new drm_syncobj_fence_proxy_get which returns either the real fence or
>> a proxy fence that will be triggered the next time replace_fence is called
>> with a non-NULL replacement.  This does make both drm_syncobj_fence_get and
>> drm_syncobj_replace_fence a tiny bit more expensive, but it lets us do it
>> all without locking.
>>
>> This series can be found as a branch here:
>>
>> https://cgit.freedesktop.org/~jekstrand/linux/log/?h=drm-syncobj-wait-submit-v4
>>
>> IGT tests for DRM_IOCTL_SYNCOBJ_WAIT and DRM_IOCTL_SYNCOBJ_RESET can be
>> found on patchwork here:
>>
>> https://patchwork.freedesktop.org/series/28666/
>>
>> Patches to the Intel Vulkan driver to implement VK_KHR_external_fence on
>> top of this kernel interface can be found here:
>>
>> https://cgit.freedesktop.org/~jekstrand/mesa/log/?h=wip/anv-external-fence
>>
>> Cc: Dave Airlie <airlied at redhat.com>
>> Cc: Chris Wilson <chris at chris-wilson.co.uk>
>> Cc: Christian König <christian.koenig at amd.com>
>>
>> Chris Wilson (2):
>>    dma-buf/dma-fence: Signal all callbacks from dma_fence_release()
>>    dma-buf/dma-fence: Add a mechanism for proxy fences
>>
>> Dave Airlie (1):
>>    drm/syncobj: add sync obj wait interface. (v8)
>>
>> Jason Ekstrand (6):
>>    drm/syncobj: Rename fence_get to find_fence
>>    drm/syncobj: Add a race-free drm_syncobj_fence_get helper
>>    i915: Add support for drm syncobjs
>>    dma-buf/dma-fence: Allow wait_any_timeout without default_wait (v2)
>>    drm/syncobj: Add a reset ioctl
>>    drm/syncobj: Allow wait for submit and signal behavior (v4)
>>
>>   drivers/dma-buf/Makefile                   |   4 +-
>>   drivers/dma-buf/dma-fence-proxy.c          | 186 +++++++++++++++++++
>>   drivers/dma-buf/dma-fence.c                |  34 ++--
>>   drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c     |   2 +-
>>   drivers/gpu/drm/drm_internal.h             |   4 +
>>   drivers/gpu/drm/drm_ioctl.c                |   4 +
>>   drivers/gpu/drm/drm_syncobj.c              | 275 +++++++++++++++++++++++++++--
>>   drivers/gpu/drm/i915/i915_drv.c            |   3 +-
>>   drivers/gpu/drm/i915/i915_gem_execbuffer.c | 146 ++++++++++++++-
>>   include/drm/drm_syncobj.h                  |  15 +-
>>   include/linux/dma-fence-proxy.h            |  25 +++
>>   include/uapi/drm/drm.h                     |  19 ++
>>   include/uapi/drm/i915_drm.h                |  30 +++-
>>   13 files changed, 710 insertions(+), 37 deletions(-)
>>   create mode 100644 drivers/dma-buf/dma-fence-proxy.c
>>   create mode 100644 include/linux/dma-fence-proxy.h
>>
>




More information about the dri-devel mailing list