sched_ctx_list.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2013 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. #ifndef __SCHED_CONTEXT_LIST_H__
  17. #define __SCHED_CONTEXT_LIST_H__
  18. /* Represents a non circular list of priorities and contains a list of sched context */
  19. struct _starpu_sched_ctx_elt;
  20. struct _starpu_sched_ctx_list
  21. {
  22. struct _starpu_sched_ctx_list *prev;
  23. struct _starpu_sched_ctx_list *next;
  24. struct _starpu_sched_ctx_elt *head;
  25. unsigned priority;
  26. };
  27. /* Represents a circular list of sched context. */
  28. struct _starpu_sched_ctx_elt
  29. {
  30. struct _starpu_sched_ctx_elt *prev;
  31. struct _starpu_sched_ctx_elt *next;
  32. struct _starpu_sched_ctx_list *parent;
  33. unsigned sched_ctx;
  34. long task_number;
  35. unsigned last_poped;
  36. };
  37. struct _starpu_sched_ctx_list_iterator
  38. {
  39. struct _starpu_sched_ctx_list *list_head;
  40. struct _starpu_sched_ctx_elt *cursor;
  41. };
  42. /* Element (sched_ctx) level operations */
  43. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_elt_find(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  44. void _starpu_sched_ctx_elt_ensure_consistency(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  45. void _starpu_sched_ctx_elt_init(struct _starpu_sched_ctx_elt *elt, unsigned sched_ctx);
  46. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_elt_add_after(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  47. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_elt_add_before(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  48. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_elt_add(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  49. void _starpu_sched_ctx_elt_remove(struct _starpu_sched_ctx_list *list, struct _starpu_sched_ctx_elt **elt);
  50. int _starpu_sched_ctx_elt_exists(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  51. int _starpu_sched_ctx_elt_get_priority(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  52. /* List (priority) level operations */
  53. struct _starpu_sched_ctx_list* _starpu_sched_ctx_list_find(struct _starpu_sched_ctx_list *list, unsigned prio);
  54. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_list_add_prio(struct _starpu_sched_ctx_list **list, unsigned prio, unsigned sched_ctx);
  55. int _starpu_sched_ctx_list_add(struct _starpu_sched_ctx_list **list, unsigned sched_ctx);
  56. void _starpu_sched_ctx_list_remove_elt(struct _starpu_sched_ctx_list **list, struct _starpu_sched_ctx_elt *rm);
  57. int _starpu_sched_ctx_list_remove(struct _starpu_sched_ctx_list **list, unsigned sched_ctx);
  58. int _starpu_sched_ctx_list_move(struct _starpu_sched_ctx_list **list, unsigned sched_ctx, unsigned prio_to);
  59. int _starpu_sched_ctx_list_exists(struct _starpu_sched_ctx_list *list, unsigned prio);
  60. void _starpu_sched_ctx_list_remove_all(struct _starpu_sched_ctx_list *list);
  61. void _starpu_sched_ctx_list_delete(struct _starpu_sched_ctx_list **list);
  62. /* Task number management */
  63. int _starpu_sched_ctx_list_push_event(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  64. int _starpu_sched_ctx_list_pop_event(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  65. int _starpu_sched_ctx_list_pop_all_event(struct _starpu_sched_ctx_list *list, unsigned sched_ctx);
  66. /* Iterator operations */
  67. int _starpu_sched_ctx_list_iterator_init(struct _starpu_sched_ctx_list *list, struct _starpu_sched_ctx_list_iterator *it);
  68. int _starpu_sched_ctx_list_iterator_has_next(struct _starpu_sched_ctx_list_iterator *it);
  69. struct _starpu_sched_ctx_elt* _starpu_sched_ctx_list_iterator_get_next(struct _starpu_sched_ctx_list_iterator *it);
  70. #endif // __SCHED_CONTEXT_H__