From: Maarten Lankhorst <maarten.lankhorst@canonical.com> To: gregkh@linuxfoundation.org Cc: linux-arch@vger.kernel.org, thellstrom@vmware.com, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org, ccross@google.com, linux-media@vger.kernel.org Subject: [REPOST PATCH 5/8] reservation: add support for fences to enable cross-device synchronisation Date: Wed, 18 Jun 2014 12:37:17 +0200 [thread overview] Message-ID: <20140618103717.15728.58471.stgit@patser> (raw) In-Reply-To: <20140618102957.15728.43525.stgit@patser> Signed-off-by: Maarten Lankhorst <maarten.lankhorst@canonical.com> Reviewed-by: Rob Clark <robdclark@gmail.com> --- include/linux/reservation.h | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/include/linux/reservation.h b/include/linux/reservation.h index 813dae960ebd..f3f57460a205 100644 --- a/include/linux/reservation.h +++ b/include/linux/reservation.h @@ -6,7 +6,7 @@ * Copyright (C) 2012 Texas Instruments * * Authors: - * Rob Clark <rob.clark@linaro.org> + * Rob Clark <robdclark@gmail.com> * Maarten Lankhorst <maarten.lankhorst@canonical.com> * Thomas Hellstrom <thellstrom-at-vmware-dot-com> * @@ -40,22 +40,40 @@ #define _LINUX_RESERVATION_H #include <linux/ww_mutex.h> +#include <linux/fence.h> +#include <linux/slab.h> extern struct ww_class reservation_ww_class; struct reservation_object { struct ww_mutex lock; + + struct fence *fence_excl; + struct fence **fence_shared; + u32 fence_shared_count, fence_shared_max; }; static inline void reservation_object_init(struct reservation_object *obj) { ww_mutex_init(&obj->lock, &reservation_ww_class); + + obj->fence_shared_count = obj->fence_shared_max = 0; + obj->fence_shared = NULL; + obj->fence_excl = NULL; } static inline void reservation_object_fini(struct reservation_object *obj) { + int i; + + if (obj->fence_excl) + fence_put(obj->fence_excl); + for (i = 0; i < obj->fence_shared_count; ++i) + fence_put(obj->fence_shared[i]); + kfree(obj->fence_shared); + ww_mutex_destroy(&obj->lock); }
WARNING: multiple messages have this Message-ID (diff)
From: Maarten Lankhorst <maarten.lankhorst@canonical.com> To: gregkh@linuxfoundation.org Cc: linux-arch@vger.kernel.org, thellstrom@vmware.com, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org, robdclark@gmail.com, thierry.reding@gmail.com, ccross@google.com, daniel@ffwll.ch, sumit.semwal@linaro.org, linux-media@vger.kernel.org Subject: [REPOST PATCH 5/8] reservation: add support for fences to enable cross-device synchronisation Date: Wed, 18 Jun 2014 12:37:17 +0200 [thread overview] Message-ID: <20140618103717.15728.58471.stgit@patser> (raw) Message-ID: <20140618103717.s2EuXjq6CdX-Uz8TiPHdCa0mZUWsOVkzjnWzzjl4WDM@z> (raw) In-Reply-To: <20140618102957.15728.43525.stgit@patser> Signed-off-by: Maarten Lankhorst <maarten.lankhorst@canonical.com> Reviewed-by: Rob Clark <robdclark@gmail.com> --- include/linux/reservation.h | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/include/linux/reservation.h b/include/linux/reservation.h index 813dae960ebd..f3f57460a205 100644 --- a/include/linux/reservation.h +++ b/include/linux/reservation.h @@ -6,7 +6,7 @@ * Copyright (C) 2012 Texas Instruments * * Authors: - * Rob Clark <rob.clark@linaro.org> + * Rob Clark <robdclark@gmail.com> * Maarten Lankhorst <maarten.lankhorst@canonical.com> * Thomas Hellstrom <thellstrom-at-vmware-dot-com> * @@ -40,22 +40,40 @@ #define _LINUX_RESERVATION_H #include <linux/ww_mutex.h> +#include <linux/fence.h> +#include <linux/slab.h> extern struct ww_class reservation_ww_class; struct reservation_object { struct ww_mutex lock; + + struct fence *fence_excl; + struct fence **fence_shared; + u32 fence_shared_count, fence_shared_max; }; static inline void reservation_object_init(struct reservation_object *obj) { ww_mutex_init(&obj->lock, &reservation_ww_class); + + obj->fence_shared_count = obj->fence_shared_max = 0; + obj->fence_shared = NULL; + obj->fence_excl = NULL; } static inline void reservation_object_fini(struct reservation_object *obj) { + int i; + + if (obj->fence_excl) + fence_put(obj->fence_excl); + for (i = 0; i < obj->fence_shared_count; ++i) + fence_put(obj->fence_shared[i]); + kfree(obj->fence_shared); + ww_mutex_destroy(&obj->lock); }
next prev parent reply other threads:[~2014-06-18 10:37 UTC|newest] Thread overview: 78+ messages / expand[flat|nested] mbox.gz Atom feed top 2014-06-18 10:36 [REPOST PATCH 0/8] fence synchronization patches Maarten Lankhorst 2014-06-18 10:36 ` Maarten Lankhorst 2014-06-18 10:36 ` [REPOST PATCH 1/8] fence: dma-buf cross-device synchronization (v17) Maarten Lankhorst 2014-06-18 10:36 ` Maarten Lankhorst 2014-06-19 1:13 ` Greg KH 2014-06-19 1:13 ` Greg KH 2014-06-19 1:23 ` Rob Clark 2014-06-19 1:23 ` Rob Clark 2014-06-19 1:44 ` Greg KH 2014-06-19 1:44 ` Greg KH 2014-06-19 14:00 ` Rob Clark 2014-06-19 17:00 ` Greg KH 2014-06-19 17:00 ` Greg KH 2014-06-19 17:45 ` Rob Clark 2014-06-19 17:45 ` Rob Clark 2014-06-19 18:19 ` Greg KH 2014-06-19 18:37 ` James Bottomley 2014-06-19 18:37 ` James Bottomley 2014-06-19 18:52 ` Rob Clark 2014-06-19 18:52 ` Rob Clark 2014-06-19 19:20 ` Daniel Vetter 2014-06-19 19:20 ` Daniel Vetter 2014-06-19 21:50 ` Dave Airlie 2014-06-19 21:50 ` Dave Airlie 2014-06-19 23:21 ` Rob Clark 2014-06-19 23:21 ` Rob Clark 2014-06-19 19:15 ` Daniel Vetter 2014-06-19 19:15 ` Daniel Vetter 2014-06-19 20:01 ` Greg KH 2014-06-19 20:01 ` Greg KH 2014-06-19 22:39 ` H. Peter Anvin 2014-06-19 22:39 ` H. Peter Anvin 2014-06-19 23:08 ` James Bottomley 2014-06-19 23:08 ` James Bottomley 2014-06-19 23:42 ` Greg KH 2014-06-20 8:30 ` Daniel Vetter 2014-06-20 8:24 ` Daniel Vetter 2014-06-20 8:24 ` Daniel Vetter 2014-06-19 1:15 ` Greg KH 2014-06-19 1:16 ` Greg KH 2014-06-19 1:25 ` Rob Clark 2014-06-19 1:25 ` Rob Clark 2014-06-19 4:27 ` Sumit Semwal 2014-06-19 4:54 ` Greg KH 2014-06-19 4:54 ` Greg KH 2014-06-19 5:26 ` Sumit Semwal 2014-06-19 5:26 ` Sumit Semwal 2014-06-18 10:37 ` [REPOST PATCH 2/8] seqno-fence: Hardware dma-buf implementation of fencing (v5) Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst 2014-06-18 10:37 ` [REPOST PATCH 3/8] dma-buf: use reservation objects Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst 2014-06-18 10:37 ` [REPOST PATCH 4/8] android: convert sync to fence api, v5 Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst 2014-06-19 1:15 ` Greg KH 2014-06-19 6:37 ` Daniel Vetter 2014-06-19 6:37 ` Daniel Vetter 2014-06-19 11:48 ` Thierry Reding 2014-06-19 11:48 ` Thierry Reding 2014-06-19 12:28 ` Daniel Vetter 2014-06-19 15:35 ` Colin Cross 2014-06-19 16:34 ` Daniel Vetter 2014-06-19 16:34 ` Daniel Vetter 2014-06-20 20:52 ` Thierry Reding 2014-06-20 20:52 ` Thierry Reding 2014-06-23 8:45 ` Maarten Lankhorst 2014-07-07 13:28 ` Daniel Vetter 2014-07-07 13:28 ` Daniel Vetter 2014-06-19 15:22 ` Colin Cross 2014-06-19 15:22 ` Colin Cross 2014-06-19 16:12 ` Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst [this message] 2014-06-18 10:37 ` [REPOST PATCH 5/8] reservation: add support for fences to enable cross-device synchronisation Maarten Lankhorst 2014-06-18 10:37 ` [REPOST PATCH 6/8] dma-buf: add poll support, v3 Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst 2014-06-18 10:37 ` [REPOST PATCH 7/8] reservation: update api and add some helpers Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst 2014-06-18 10:37 ` [REPOST PATCH 8/8] reservation: add suppport for read-only access using rcu Maarten Lankhorst 2014-06-18 10:37 ` Maarten Lankhorst
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20140618103717.15728.58471.stgit@patser \ --to=maarten.lankhorst@canonical.com \ --cc=ccross@google.com \ --cc=dri-devel@lists.freedesktop.org \ --cc=gregkh@linuxfoundation.org \ --cc=linaro-mm-sig@lists.linaro.org \ --cc=linux-arch@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-media@vger.kernel.org \ --cc=thellstrom@vmware.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).