cl_enqueuemapbuffer.c 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010,2011 University of Bordeaux
  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 mapbuffer_task(void *args) {
  18. command_map_buffer cmd = (command_map_buffer)args;
  19. cl_event ev = command_event_get(cmd);
  20. ev->prof_start = _socl_nanotime();
  21. gc_entity_release(ev);
  22. enum starpu_data_access_mode mode = (cmd->map_flags == CL_MAP_READ ? STARPU_R : STARPU_RW);
  23. starpu_data_acquire_cb(cmd->buffer->handle, mode, command_completed_task_callback, cmd);
  24. }
  25. static struct starpu_codelet codelet_mapbuffer = {
  26. .name = "SOCL_MAP_BUFFER"
  27. };
  28. cl_int command_map_buffer_submit(command_map_buffer cmd) {
  29. gc_entity_retain(cmd);
  30. cpu_task_submit(cmd, mapbuffer_task, cmd, 0, 0, &codelet_mapbuffer, 0, NULL);
  31. return CL_SUCCESS;
  32. }
  33. CL_API_ENTRY void * CL_API_CALL
  34. soclEnqueueMapBuffer(cl_command_queue cq,
  35. cl_mem buffer,
  36. cl_bool blocking,
  37. cl_map_flags map_flags,
  38. size_t offset,
  39. size_t cb,
  40. cl_uint num_events,
  41. const cl_event * events,
  42. cl_event * event,
  43. cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_0
  44. {
  45. command_map_buffer cmd = command_map_buffer_create(buffer, map_flags, offset, cb);
  46. cl_event ev = command_event_get(cmd);
  47. command_queue_enqueue(cq, cmd, num_events, events);
  48. if (errcode_ret != NULL)
  49. *errcode_ret = CL_SUCCESS;
  50. MAY_BLOCK_THEN_RETURN_EVENT(ev,blocking,event);
  51. return (void*)(starpu_variable_get_local_ptr(buffer->handle) + offset);
  52. }