[Beignet] [PATCH 04/11] Runtime: Apply base object to cl_device_id

Yang, Rong R rong.r.yang at intel.com
Thu Sep 1 08:06:49 UTC 2016


Because the device is static variable, so it is special.
Is it safe for use-case:
clCreateDevice()
clReleaseDevice()
clCreateDevice()

clReleaseDevice do nothing, so CL_OBJECT_INIT_BASE will be called several times without CL_OBJECT_DESTROY_BASE() is called.

> -----Original Message-----
> From: Beignet [mailto:beignet-bounces at lists.freedesktop.org] On Behalf Of
> junyan.he at inbox.com
> Sent: Tuesday, July 19, 2016 19:26
> To: beignet at lists.freedesktop.org
> Subject: [Beignet] [PATCH 04/11] Runtime: Apply base object to cl_device_id
> 
> From: Junyan He <junyan.he at intel.com>
> 
> Signed-off-by: Junyan He <junyan.he at intel.com>
> ---
>  src/cl_device_id.c |   16 +++++++++++++++-
>  src/cl_device_id.h |    8 +++++---
>  src/cl_gt_device.h |    1 -
>  3 files changed, 20 insertions(+), 5 deletions(-)
> 
> diff --git a/src/cl_device_id.c b/src/cl_device_id.c index 66666ea..3294f9d
> 100644
> --- a/src/cl_device_id.c
> +++ b/src/cl_device_id.c
> @@ -600,6 +600,7 @@ bxt_break:
>    if (ret == NULL)
>      return NULL;
> 
> +  CL_OBJECT_INIT_BASE(ret, CL_OBJECT_DEVICE_MAGIC);
>    if (!CompilerSupported()) {
>      ret->compiler_available = CL_FALSE;
>      //ret->linker_available = CL_FALSE;
> @@ -887,10 +888,23 @@ cl_get_device_info(cl_device_id     device,
>      DECL_FIELD(PARTITION_PROPERTIES, partition_property)
>      DECL_FIELD(PARTITION_AFFINITY_DOMAIN, affinity_domain)
>      DECL_FIELD(PARTITION_TYPE, partition_type)
> -    DECL_FIELD(REFERENCE_COUNT, device_reference_count)
>      DECL_FIELD(IMAGE_PITCH_ALIGNMENT, image_pitch_alignment)
>      DECL_FIELD(IMAGE_BASE_ADDRESS_ALIGNMENT,
> image_base_address_alignment)
> 
> +    case CL_DEVICE_REFERENCE_COUNT:
> +    {
> +      cl_uint dev_ref = CL_OBJECT_GET_REF(device);
> +      if (param_value_size_ret) {
> +        *param_value_size_ret = sizeof(cl_uint);
> +        if (!param_value)
> +          return CL_SUCCESS;
> +      }
> +      if (param_value_size < sizeof(cl_uint))
> +        return CL_INVALID_VALUE;
> +      memcpy(param_value, &dev_ref, sizeof(cl_uint));
> +      return CL_SUCCESS;
> +    }
> +
>      case CL_DRIVER_VERSION:
>        if (param_value_size_ret) {
>          *param_value_size_ret = device->driver_version_sz; diff --git
> a/src/cl_device_id.h b/src/cl_device_id.h index 7db125b..abb6403 100644
> --- a/src/cl_device_id.h
> +++ b/src/cl_device_id.h
> @@ -22,10 +22,10 @@
> 
>  #define EXTENSTION_LENGTH 512
> 
> -#include "cl_khr_icd.h"
> +#include "cl_base_object.h"
>  /* Store complete information about the device */  struct _cl_device_id {
> -  DEFINE_ICD(dispatch)
> +  _cl_base_object base;
>    cl_device_type device_type;
>    cl_uint  device_id;
>    cl_uint  vendor_id;
> @@ -117,7 +117,6 @@ struct _cl_device_id {
>    cl_device_partition_property partition_property[3];
>    cl_device_affinity_domain    affinity_domain;
>    cl_device_partition_property partition_type[3];
> -  cl_uint      device_reference_count;
>    uint32_t atomic_test_result;
>    uint32_t image_pitch_alignment;
>    uint32_t image_base_address_alignment; @@ -126,6 +125,9 @@ struct
> _cl_device_id {
>    void* cmrt_device;  //realtype: CmDevice*  };
> 
> +#define CL_OBJECT_DEVICE_MAGIC 0x2acaddcca8853c52LL #define
> +CL_OBJECT_IS_DEVICE(obj) (((cl_base_object)obj)->magic ==
> +CL_OBJECT_DEVICE_MAGIC)
> +
>  /* Get a device from the given platform */
>  extern cl_int cl_get_device_ids(cl_platform_id    platform,
>                                  cl_device_type    device_type,
> diff --git a/src/cl_gt_device.h b/src/cl_gt_device.h index 70a0a54..d27c1ad
> 100644
> --- a/src/cl_gt_device.h
> +++ b/src/cl_gt_device.h
> @@ -127,7 +127,6 @@ DECL_INFO_STRING(spir_versions,
> "1.2")  .partition_property = {0},  .affinity_domain = 0,  .partition_type = {0}, -
> .device_reference_count = 1,  .image_pitch_alignment =
> 1,  .image_base_address_alignment = 4096,  .cmrt_device = NULL
> --
> 1.7.9.5
> 
> __________________________________________________________
> __
> TRY FREE IM TOOLPACK at http://www.imtoolpack.com/default.aspx?rc=if5
> Capture screenshots, upload images, edit and send them to your friends
> through IMs, post on Twitter®, Facebook®, MySpace™, LinkedIn® – FAST!
> 
> 
> _______________________________________________
> Beignet mailing list
> Beignet at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/beignet


More information about the Beignet mailing list