cl_createcommandqueue.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010-2020 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
  4. *
  5. * StarPU is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU Lesser General Public License as published by
  7. * the Free Software Foundation; either version 2.1 of the License, or (at
  8. * your option) any later version.
  9. *
  10. * StarPU is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  13. *
  14. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  15. */
  16. #include "socl.h"
  17. static void release_callback_command_queue(void * e)
  18. {
  19. cl_command_queue cq = (cl_command_queue)e;
  20. //Disable StarPU profiling if necessary
  21. if (cq->properties & CL_QUEUE_PROFILING_ENABLE)
  22. {
  23. profiling_queue_count -= 1;
  24. if (profiling_queue_count == 0)
  25. starpu_profiling_status_set(STARPU_PROFILING_DISABLE);
  26. }
  27. /* Release references */
  28. gc_entity_unstore(&cq->context);
  29. /* Destruct object */
  30. STARPU_PTHREAD_MUTEX_DESTROY(&cq->mutex);
  31. }
  32. CL_API_SUFFIX__VERSION_1_0
  33. CL_API_ENTRY cl_command_queue CL_API_CALL
  34. soclCreateCommandQueue(cl_context context,
  35. cl_device_id device,
  36. cl_command_queue_properties properties,
  37. cl_int * errcode_ret)
  38. {
  39. cl_command_queue cq;
  40. cq = (cl_command_queue)gc_entity_alloc(sizeof(struct _cl_command_queue),
  41. release_callback_command_queue, "command_queue");
  42. if (cq == NULL)
  43. {
  44. if (errcode_ret != NULL)
  45. *errcode_ret = CL_OUT_OF_HOST_MEMORY;
  46. return NULL;
  47. }
  48. cq->properties = properties;
  49. gc_entity_store(&cq->context, context);
  50. char * fd = getenv("SOCL_FORCE_DYNAMIC");
  51. int force_dynamic = fd == NULL ? 0 : atoi(fd);
  52. cq->device = force_dynamic ? NULL : device;
  53. #ifdef DEBUG
  54. static int id = 0;
  55. cq->id = id++;
  56. #endif
  57. //Enable StarPU profiling if necessary
  58. if (properties & CL_QUEUE_PROFILING_ENABLE)
  59. {
  60. if (profiling_queue_count == 0)
  61. starpu_profiling_status_set(STARPU_PROFILING_ENABLE);
  62. profiling_queue_count += 1;
  63. }
  64. cq->commands = NULL;
  65. cq->barrier = NULL;
  66. STARPU_PTHREAD_MUTEX_INIT(&cq->mutex, NULL);
  67. if (errcode_ret != NULL)
  68. *errcode_ret = CL_SUCCESS;
  69. return cq;
  70. }