handle_refcnt 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. handle.refcnt usage
  2. ===================
  3. It is the counter for a software rwlock, accounting the number of readers
  4. (mode == STARPU_R) or writers (mode == STARPU_W)
  5. It is thus used
  6. - during task duration for each data
  7. - right after completion of a data request
  8. - during application data acquisition
  9. * Creates a reference:
  10. * Released by _starpu_notify_data_dependencies():
  11. - _starpu_attempt_to_submit_data_request() immediately when returning 0, but otherwise (1) when the pending request is given control
  12. * Released by _starpu_notify_data_dependencies():
  13. - _starpu_notify_data_dependencies() when may_unlock_data_req_list_head returned a request which can proceed
  14. * Indirectly creates a reference:
  15. * Released by starpu_data_release():
  16. - _starpu_attempt_to_submit_data_request_from_apps() when returning 0
  17. - starpu_data_acquire_cb()
  18. - starpu_data_acquire()
  19. * Released by _starpu_notify_data_dependencies():
  20. - attempt_to_submit_data_request_from_job() when returning 0
  21. * Released by _starpu_push_task_output():
  22. - _submit_job_enforce_data_deps() for each data.
  23. * Releases a reference:
  24. - _starpu_notify_data_dependencies()
  25. * Indirectly releases a reference:
  26. - _starpu_release_data_on_node()
  27. - _starpu_push_task_output() for each data
  28. - starpu_data_release()
  29. * Temporarily creates a reference, released immediately:
  30. - _starpu_write_through_data() for needed write-throughs, released by wt_callback
  31. - _starpu_benchmark_ping_pong()
  32. - _starpu_data_unregister()
  33. - _starpu_prefetch_data_on_node_with_mode()
  34. - starpu_data_invalidate()
  35. TODO: unclear conversion use