[Mesa-dev] [PATCH 09/10] gallium, clover: add OpenCL interoperability support for CL events
Francisco Jerez
currojerez at riseup.net
Mon Apr 27 11:05:30 PDT 2015
Marek Olšák <maraeo at gmail.com> writes:
> From: Marek Olšák <marek.olsak at amd.com>
>
> v2: - move interop.cpp to clover/api
> - change intptr_t to void* in the interface
> - add a virtual function fence() to simplify some code
>
> v3: - use bool in the interface
> v4: - enclose the last two interop functions in try..catch
Looks good, thanks,
Reviewed-by: Francisco Jerez <currojerez at riseup.net>
> ---
> src/gallium/include/state_tracker/opencl_interop.h | 40 ++++++++++++++
> src/gallium/state_trackers/clover/Makefile.sources | 1 +
> src/gallium/state_trackers/clover/api/interop.cpp | 64 ++++++++++++++++++++++
> src/gallium/state_trackers/clover/core/event.hpp | 8 +++
> src/gallium/targets/opencl/opencl.sym | 1 +
> 5 files changed, 114 insertions(+)
> create mode 100644 src/gallium/include/state_tracker/opencl_interop.h
> create mode 100644 src/gallium/state_trackers/clover/api/interop.cpp
>
> diff --git a/src/gallium/include/state_tracker/opencl_interop.h b/src/gallium/include/state_tracker/opencl_interop.h
> new file mode 100644
> index 0000000..4983644
> --- /dev/null
> +++ b/src/gallium/include/state_tracker/opencl_interop.h
> @@ -0,0 +1,40 @@
> +/**************************************************************************
> + *
> + * Copyright 2015 Advanced Micro Devices, Inc.
> + * All Rights Reserved.
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the
> + * "Software"), to deal in the Software without restriction, including
> + * without limitation the rights to use, copy, modify, merge, publish,
> + * distribute, sub license, and/or sell copies of the Software, and to
> + * permit persons to whom the Software is furnished to do so, subject to
> + * the following conditions:
> + *
> + * The above copyright notice and this permission notice (including the
> + * next paragraph) shall be included in all copies or substantial portions
> + * of the Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
> + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
> + * IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR
> + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
> + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
> + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
> + *
> + **************************************************************************/
> +
> +#ifndef OPENCL_INTEROP_H
> +#define OPENCL_INTEROP_H
> +
> +/* dlsym these without the "_t" suffix. You should get the correct symbols
> + * if the OpenCL driver is loaded.
> + */
> +
> +typedef bool (*opencl_dri_event_add_ref_t)(void *cl_event);
> +typedef bool (*opencl_dri_event_release_t)(void *cl_event);
> +typedef bool (*opencl_dri_event_wait_t)(void *cl_event, uint64_t timeout);
> +typedef struct pipe_fence_handle *(*opencl_dri_event_get_fence_t)(void *cl_event);
> +
> +#endif /* OPENCL_INTEROP_H */
> diff --git a/src/gallium/state_trackers/clover/Makefile.sources b/src/gallium/state_trackers/clover/Makefile.sources
> index 5b3344c..9e30c69 100644
> --- a/src/gallium/state_trackers/clover/Makefile.sources
> +++ b/src/gallium/state_trackers/clover/Makefile.sources
> @@ -4,6 +4,7 @@ CPP_SOURCES := \
> api/dispatch.cpp \
> api/dispatch.hpp \
> api/event.cpp \
> + api/interop.cpp \
> api/kernel.cpp \
> api/memory.cpp \
> api/platform.cpp \
> diff --git a/src/gallium/state_trackers/clover/api/interop.cpp b/src/gallium/state_trackers/clover/api/interop.cpp
> new file mode 100644
> index 0000000..ea0c7c7
> --- /dev/null
> +++ b/src/gallium/state_trackers/clover/api/interop.cpp
> @@ -0,0 +1,64 @@
> +//
> +// Copyright 2015 Advanced Micro Devices, Inc.
> +// All Rights Reserved.
> +//
> +// Permission is hereby granted, free of charge, to any person obtaining a
> +// copy of this software and associated documentation files (the "Software"),
> +// to deal in the Software without restriction, including without limitation
> +// the rights to use, copy, modify, merge, publish, distribute, sublicense,
> +// and/or sell copies of the Software, and to permit persons to whom the
> +// Software is furnished to do so, subject to the following conditions:
> +//
> +// The above copyright notice and this permission notice shall be included in
> +// all copies or substantial portions of the Software.
> +//
> +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
> +// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
> +// OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> +// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
> +// OTHER DEALINGS IN THE SOFTWARE.
> +//
> +
> +#include "core/event.hpp"
> +#include "api/util.hpp"
> +
> +using namespace clover;
> +
> +extern "C" {
> +
> +PUBLIC bool
> +opencl_dri_event_add_ref(cl_event event)
> +{
> + return clRetainEvent(event) == CL_SUCCESS;
> +}
> +
> +PUBLIC bool
> +opencl_dri_event_release(cl_event event)
> +{
> + return clReleaseEvent(event) == CL_SUCCESS;
> +}
> +
> +PUBLIC bool
> +opencl_dri_event_wait(cl_event event, uint64_t timeout) try {
> + if (!timeout) {
> + return obj(event).status() == CL_COMPLETE;
> + }
> +
> + obj(event).wait();
> + return true;
> +
> +} catch (error &) {
> + return false;
> +}
> +
> +PUBLIC struct pipe_fence_handle *
> +opencl_dri_event_get_fence(cl_event event) try {
> + return obj(event).fence();
> +
> +} catch (error &) {
> + return NULL;
> +}
> +
> +}
> diff --git a/src/gallium/state_trackers/clover/core/event.hpp b/src/gallium/state_trackers/clover/core/event.hpp
> index 0e1359a..d407c80 100644
> --- a/src/gallium/state_trackers/clover/core/event.hpp
> +++ b/src/gallium/state_trackers/clover/core/event.hpp
> @@ -70,6 +70,10 @@ namespace clover {
> virtual cl_command_type command() const = 0;
> virtual void wait() const = 0;
>
> + virtual struct pipe_fence_handle *fence() const {
> + return NULL;
> + }
> +
> const intrusive_ref<clover::context> context;
>
> protected:
> @@ -116,6 +120,10 @@ namespace clover {
>
> friend class command_queue;
>
> + virtual struct pipe_fence_handle *fence() const {
> + return _fence;
> + }
> +
> private:
> virtual void fence(pipe_fence_handle *fence);
> action profile(command_queue &q, const action &action) const;
> diff --git a/src/gallium/targets/opencl/opencl.sym b/src/gallium/targets/opencl/opencl.sym
> index ee8aacf..9fcc576 100644
> --- a/src/gallium/targets/opencl/opencl.sym
> +++ b/src/gallium/targets/opencl/opencl.sym
> @@ -1,6 +1,7 @@
> {
> global:
> cl*;
> + opencl_dri_*;
> local:
> *;
> };
> --
> 2.1.0
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 212 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20150427/ec9b0d33/attachment.sig>
More information about the mesa-dev
mailing list