add ast_node_mark
[isl.git] / isl_schedule_tree.h
blobac1254f4d881c0bc0d63d2d6ae7e4cb3ddfa2614
1 #ifndef ISL_SCHEDLUE_TREE_H
2 #define ISL_SCHEDLUE_TREE_H
4 #include <isl_schedule_band.h>
5 #include <isl/schedule.h>
6 #include <isl/set.h>
7 #include <isl/union_set.h>
9 struct isl_schedule_tree;
10 typedef struct isl_schedule_tree isl_schedule_tree;
12 ISL_DECLARE_LIST(schedule_tree)
14 /* A schedule (sub)tree.
16 * The leaves of a tree are not explicitly represented inside
17 * the isl_schedule_tree. If a tree consists of only a leaf,
18 * then it is equal to the static object isl_schedule_tree_empty.
20 * ctx may be NULL if type is isl_schedule_node_leaf.
21 * In this case, ref has a negative value.
23 * The "band" field is valid when type is isl_schedule_node_band.
24 * The "context" field is valid when type is isl_schedule_node_context
25 * and represents constraints on the flat product of the outer band nodes,
26 * possibly introducing additional parameters.
27 * The "domain" field is valid when type is isl_schedule_node_domain
28 * and introduces the statement instances scheduled by the tree.
30 * The "contraction" and "expansion" fields are valid when type
31 * is isl_schedule_node_expansion.
32 * "expansion" expands the reaching domain elements to one or more
33 * domain elements for the subtree.
34 * "contraction" maps these elements back to the corresponding
35 * reaching domain element. It does not involve any domain constraints.
37 * The "filter" field is valid when type is isl_schedule_node_filter
38 * and represents the statement instances selected by the node.
40 * The "children" field is valid for all types except
41 * isl_schedule_node_leaf. This field is NULL if there are
42 * no children (except for the implicit leaves).
44 * anchored is set if the node or any of its descendants depends
45 * on its position in the schedule tree.
47 struct isl_schedule_tree {
48 int ref;
49 isl_ctx *ctx;
50 int anchored;
51 enum isl_schedule_node_type type;
52 union {
53 isl_schedule_band *band;
54 isl_set *context;
55 isl_union_set *domain;
56 struct {
57 isl_union_pw_multi_aff *contraction;
58 isl_union_map *expansion;
60 isl_union_set *filter;
62 isl_schedule_tree_list *children;
65 isl_ctx *isl_schedule_tree_get_ctx(__isl_keep isl_schedule_tree *tree);
66 enum isl_schedule_node_type isl_schedule_tree_get_type(
67 __isl_keep isl_schedule_tree *tree);
69 __isl_give isl_schedule_tree *isl_schedule_tree_leaf(isl_ctx *ctx);
70 int isl_schedule_tree_is_leaf(__isl_keep isl_schedule_tree *tree);
72 int isl_schedule_tree_plain_is_equal(__isl_keep isl_schedule_tree *tree1,
73 __isl_keep isl_schedule_tree *tree2);
75 __isl_give isl_schedule_tree *isl_schedule_tree_copy(
76 __isl_keep isl_schedule_tree *tree);
77 __isl_null isl_schedule_tree *isl_schedule_tree_free(
78 __isl_take isl_schedule_tree *tree);
80 __isl_give isl_schedule_tree *isl_schedule_tree_from_band(
81 __isl_take isl_schedule_band *band);
82 __isl_give isl_schedule_tree *isl_schedule_tree_from_context(
83 __isl_take isl_set *context);
84 __isl_give isl_schedule_tree *isl_schedule_tree_from_domain(
85 __isl_take isl_union_set *domain);
86 __isl_give isl_schedule_tree *isl_schedule_tree_from_expansion(
87 __isl_take isl_union_pw_multi_aff *contraction,
88 __isl_take isl_union_map *expansion);
89 __isl_give isl_schedule_tree *isl_schedule_tree_from_filter(
90 __isl_take isl_union_set *filter);
91 __isl_give isl_schedule_tree *isl_schedule_tree_from_children(
92 enum isl_schedule_node_type type,
93 __isl_take isl_schedule_tree_list *list);
94 __isl_give isl_schedule_tree *isl_schedule_tree_from_pair(
95 enum isl_schedule_node_type type, __isl_take isl_schedule_tree *tree1,
96 __isl_take isl_schedule_tree *tree2);
98 int isl_schedule_tree_is_subtree_anchored(__isl_keep isl_schedule_tree *tree);
100 __isl_give isl_space *isl_schedule_tree_band_get_space(
101 __isl_keep isl_schedule_tree *tree);
102 __isl_give isl_schedule_tree *isl_schedule_tree_band_intersect_domain(
103 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *domain);
104 __isl_give isl_multi_union_pw_aff *isl_schedule_tree_band_get_partial_schedule(
105 __isl_keep isl_schedule_tree *tree);
106 __isl_give isl_schedule_tree *isl_schedule_tree_band_set_partial_schedule(
107 __isl_take isl_schedule_tree *tree,
108 __isl_take isl_multi_union_pw_aff *schedule);
109 enum isl_ast_loop_type isl_schedule_tree_band_member_get_ast_loop_type(
110 __isl_keep isl_schedule_tree *tree, int pos);
111 __isl_give isl_schedule_tree *isl_schedule_tree_band_member_set_ast_loop_type(
112 __isl_take isl_schedule_tree *tree, int pos,
113 enum isl_ast_loop_type type);
114 enum isl_ast_loop_type isl_schedule_tree_band_member_get_isolate_ast_loop_type(
115 __isl_keep isl_schedule_tree *tree, int pos);
116 __isl_give isl_schedule_tree *
117 isl_schedule_tree_band_member_set_isolate_ast_loop_type(
118 __isl_take isl_schedule_tree *tree, int pos,
119 enum isl_ast_loop_type type);
120 __isl_give isl_union_set *isl_schedule_tree_band_get_ast_build_options(
121 __isl_keep isl_schedule_tree *tree);
122 __isl_give isl_schedule_tree *isl_schedule_tree_band_set_ast_build_options(
123 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *options);
124 __isl_give isl_set *isl_schedule_tree_context_get_context(
125 __isl_keep isl_schedule_tree *tree);
126 __isl_give isl_union_set *isl_schedule_tree_domain_get_domain(
127 __isl_keep isl_schedule_tree *tree);
128 __isl_give isl_schedule_tree *isl_schedule_tree_domain_set_domain(
129 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *domain);
130 __isl_give isl_union_pw_multi_aff *isl_schedule_tree_expansion_get_contraction(
131 __isl_keep isl_schedule_tree *tree);
132 __isl_give isl_union_map *isl_schedule_tree_expansion_get_expansion(
133 __isl_keep isl_schedule_tree *tree);
134 __isl_give isl_schedule_tree *
135 isl_schedule_tree_expansion_set_contraction_and_expansion(
136 __isl_take isl_schedule_tree *tree,
137 __isl_take isl_union_pw_multi_aff *contraction,
138 __isl_take isl_union_map *expansion);
139 __isl_give isl_union_set *isl_schedule_tree_filter_get_filter(
140 __isl_keep isl_schedule_tree *tree);
141 __isl_give isl_schedule_tree *isl_schedule_tree_filter_set_filter(
142 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *filter);
144 __isl_give isl_schedule_tree *isl_schedule_tree_first_schedule_descendant(
145 __isl_take isl_schedule_tree *tree, __isl_keep isl_schedule_tree *leaf);
146 __isl_give isl_union_map *isl_schedule_tree_get_subtree_schedule_union_map(
147 __isl_keep isl_schedule_tree *tree);
149 unsigned isl_schedule_tree_band_n_member(__isl_keep isl_schedule_tree *tree);
151 int isl_schedule_tree_band_member_get_coincident(
152 __isl_keep isl_schedule_tree *tree, int pos);
153 __isl_give isl_schedule_tree *isl_schedule_tree_band_member_set_coincident(
154 __isl_take isl_schedule_tree *tree, int pos, int coincident);
155 int isl_schedule_tree_band_get_permutable(__isl_keep isl_schedule_tree *tree);
156 __isl_give isl_schedule_tree *isl_schedule_tree_band_set_permutable(
157 __isl_take isl_schedule_tree *tree, int permutable);
159 int isl_schedule_tree_has_children(__isl_keep isl_schedule_tree *tree);
160 int isl_schedule_tree_n_children(__isl_keep isl_schedule_tree *tree);
161 __isl_give isl_schedule_tree *isl_schedule_tree_get_child(
162 __isl_keep isl_schedule_tree *tree, int pos);
164 __isl_give isl_schedule_tree *isl_schedule_tree_insert_band(
165 __isl_take isl_schedule_tree *tree, __isl_take isl_schedule_band *band);
166 __isl_give isl_schedule_tree *isl_schedule_tree_insert_context(
167 __isl_take isl_schedule_tree *tree, __isl_take isl_set *context);
168 __isl_give isl_schedule_tree *isl_schedule_tree_insert_domain(
169 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *domain);
170 __isl_give isl_schedule_tree *isl_schedule_tree_insert_expansion(
171 __isl_take isl_schedule_tree *tree,
172 __isl_take isl_union_pw_multi_aff *contraction,
173 __isl_take isl_union_map *expansion);
174 __isl_give isl_schedule_tree *isl_schedule_tree_insert_filter(
175 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *filter);
176 __isl_give isl_schedule_tree *isl_schedule_tree_children_insert_filter(
177 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *filter);
179 __isl_give isl_schedule_tree *isl_schedule_tree_append_to_leaves(
180 __isl_take isl_schedule_tree *tree1,
181 __isl_take isl_schedule_tree *tree2);
183 __isl_give isl_schedule_tree *isl_schedule_tree_band_scale(
184 __isl_take isl_schedule_tree *tree, __isl_take isl_multi_val *mv);
185 __isl_give isl_schedule_tree *isl_schedule_tree_band_scale_down(
186 __isl_take isl_schedule_tree *tree, __isl_take isl_multi_val *mv);
187 __isl_give isl_schedule_tree *isl_schedule_tree_band_tile(
188 __isl_take isl_schedule_tree *tree, __isl_take isl_multi_val *sizes);
189 __isl_give isl_schedule_tree *isl_schedule_tree_band_split(
190 __isl_take isl_schedule_tree *tree, int pos);
191 __isl_give isl_schedule_tree *isl_schedule_tree_band_gist(
192 __isl_take isl_schedule_tree *tree, __isl_take isl_union_set *context);
194 __isl_give isl_schedule_tree *isl_schedule_tree_child(
195 __isl_take isl_schedule_tree *tree, int pos);
196 __isl_give isl_schedule_tree *isl_schedule_tree_reset_children(
197 __isl_take isl_schedule_tree *tree);
198 __isl_give isl_schedule_tree *isl_schedule_tree_drop_child(
199 __isl_take isl_schedule_tree *tree, int pos);
200 __isl_give isl_schedule_tree *isl_schedule_tree_replace_child(
201 __isl_take isl_schedule_tree *tree, int pos,
202 __isl_take isl_schedule_tree *new_child);
204 __isl_give isl_schedule_tree *isl_schedule_tree_reset_user(
205 __isl_take isl_schedule_tree *tree);
206 __isl_give isl_schedule_tree *isl_schedule_tree_align_params(
207 __isl_take isl_schedule_tree *tree, __isl_take isl_space *space);
208 __isl_give isl_schedule_tree *isl_schedule_tree_pullback_union_pw_multi_aff(
209 __isl_take isl_schedule_tree *tree,
210 __isl_take isl_union_pw_multi_aff *upma);
212 __isl_give isl_printer *isl_printer_print_schedule_tree(
213 __isl_take isl_printer *p, __isl_keep isl_schedule_tree *tree);
214 __isl_give isl_printer *isl_printer_print_schedule_tree_mark(
215 __isl_take isl_printer *p, __isl_keep isl_schedule_tree *tree,
216 int n_ancestor, int *child_pos);
218 #endif