[Mesa-dev] [Mesa-stable] [PATCH] clover: Add support to mem objects for multiple destructor callbacks v2

Francisco Jerez currojerez at riseup.net
Mon Sep 22 09:19:30 PDT 2014


Thanks, looks good to me,

Reviewed-by: Francisco Jerez <currojerez at riseup.net>

Tom Stellard <thomas.stellard at amd.com> writes:

> The spec says that mem objects should maintain a stack of callbacks
> not just one.
>
> v2:
>   - Remove stray printf.
>
> CC: "10.3" <mesa-stable at lists.freedesktop.org>
> ---
>  src/gallium/state_trackers/clover/core/memory.cpp | 10 ++++++----
>  src/gallium/state_trackers/clover/core/memory.hpp |  3 ++-
>  2 files changed, 8 insertions(+), 5 deletions(-)
>
> diff --git a/src/gallium/state_trackers/clover/core/memory.cpp b/src/gallium/state_trackers/clover/core/memory.cpp
> index ba6869d..905ebc0 100644
> --- a/src/gallium/state_trackers/clover/core/memory.cpp
> +++ b/src/gallium/state_trackers/clover/core/memory.cpp
> @@ -29,14 +29,16 @@ using namespace clover;
>  memory_obj::memory_obj(clover::context &ctx, cl_mem_flags flags,
>                         size_t size, void *host_ptr) :
>     context(ctx), _flags(flags),
> -   _size(size), _host_ptr(host_ptr),
> -   _destroy_notify([]{}) {
> +   _size(size), _host_ptr(host_ptr) {
>     if (flags & (CL_MEM_COPY_HOST_PTR | CL_MEM_USE_HOST_PTR))
>        data.append((char *)host_ptr, size);
>  }
>  
>  memory_obj::~memory_obj() {
> -   _destroy_notify();
> +   while (_destroy_notify.size()) {
> +      _destroy_notify.top()();
> +      _destroy_notify.pop();
> +   }
>  }
>  
>  bool
> @@ -46,7 +48,7 @@ memory_obj::operator==(const memory_obj &obj) const {
>  
>  void
>  memory_obj::destroy_notify(std::function<void ()> f) {
> -   _destroy_notify = f;
> +   _destroy_notify.push(f);
>  }
>  
>  cl_mem_flags
> diff --git a/src/gallium/state_trackers/clover/core/memory.hpp b/src/gallium/state_trackers/clover/core/memory.hpp
> index f649ca0..bd6da6b 100644
> --- a/src/gallium/state_trackers/clover/core/memory.hpp
> +++ b/src/gallium/state_trackers/clover/core/memory.hpp
> @@ -26,6 +26,7 @@
>  #include <functional>
>  #include <map>
>  #include <memory>
> +#include <stack>
>  
>  #include "core/object.hpp"
>  #include "core/queue.hpp"
> @@ -61,7 +62,7 @@ namespace clover {
>        cl_mem_flags _flags;
>        size_t _size;
>        void *_host_ptr;
> -      std::function<void ()> _destroy_notify;
> +      std::stack<std::function<void ()>> _destroy_notify;
>  
>     protected:
>        std::string data;
> -- 
> 1.8.5.5
>
> _______________________________________________
> mesa-stable mailing list
> mesa-stable at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-stable
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 212 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20140922/4e557585/attachment.sig>


More information about the mesa-dev mailing list