X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=include%2Fisl%2Faff.h;h=77114e33c14749d1906c138809cdb262c418f41f;hb=c53ceda9cc1f9556507c9956647975a1d661a380;hp=1acb28e786c2164454b9995ac7ba3d7cc091238d;hpb=27b230c534bdef3411e89011354b8606514f8614;p=platform%2Fupstream%2Fisl.git diff --git a/include/isl/aff.h b/include/isl/aff.h index 1acb28e..77114e3 100644 --- a/include/isl/aff.h +++ b/include/isl/aff.h @@ -8,6 +8,7 @@ #include #include #include +#include #include #if defined(__cplusplus) @@ -36,18 +37,28 @@ __isl_give isl_local_space *isl_aff_get_local_space(__isl_keep isl_aff *aff); const char *isl_aff_get_dim_name(__isl_keep isl_aff *aff, enum isl_dim_type type, unsigned pos); int isl_aff_get_constant(__isl_keep isl_aff *aff, isl_int *v); +__isl_give isl_val *isl_aff_get_constant_val(__isl_keep isl_aff *aff); int isl_aff_get_coefficient(__isl_keep isl_aff *aff, enum isl_dim_type type, int pos, isl_int *v); +__isl_give isl_val *isl_aff_get_coefficient_val(__isl_keep isl_aff *aff, + enum isl_dim_type type, int pos); int isl_aff_get_denominator(__isl_keep isl_aff *aff, isl_int *v); +__isl_give isl_val *isl_aff_get_denominator_val(__isl_keep isl_aff *aff); __isl_give isl_aff *isl_aff_set_constant(__isl_take isl_aff *aff, isl_int v); __isl_give isl_aff *isl_aff_set_constant_si(__isl_take isl_aff *aff, int v); +__isl_give isl_aff *isl_aff_set_constant_val(__isl_take isl_aff *aff, + __isl_take isl_val *v); __isl_give isl_aff *isl_aff_set_coefficient(__isl_take isl_aff *aff, enum isl_dim_type type, int pos, isl_int v); __isl_give isl_aff *isl_aff_set_coefficient_si(__isl_take isl_aff *aff, enum isl_dim_type type, int pos, int v); +__isl_give isl_aff *isl_aff_set_coefficient_val(__isl_take isl_aff *aff, + enum isl_dim_type type, int pos, __isl_take isl_val *v); __isl_give isl_aff *isl_aff_set_denominator(__isl_take isl_aff *aff, isl_int v); __isl_give isl_aff *isl_aff_add_constant(__isl_take isl_aff *aff, isl_int v); __isl_give isl_aff *isl_aff_add_constant_si(__isl_take isl_aff *aff, int v); +__isl_give isl_aff *isl_aff_add_constant_val(__isl_take isl_aff *aff, + __isl_take isl_val *v); __isl_give isl_aff *isl_aff_add_constant_num(__isl_take isl_aff *aff, isl_int v); __isl_give isl_aff *isl_aff_add_constant_num_si(__isl_take isl_aff *aff, int v); @@ -55,6 +66,8 @@ __isl_give isl_aff *isl_aff_add_coefficient(__isl_take isl_aff *aff, enum isl_dim_type type, int pos, isl_int v); __isl_give isl_aff *isl_aff_add_coefficient_si(__isl_take isl_aff *aff, enum isl_dim_type type, int pos, int v); +__isl_give isl_aff *isl_aff_add_coefficient_val(__isl_take isl_aff *aff, + enum isl_dim_type type, int pos, __isl_take isl_val *v); int isl_aff_is_cst(__isl_keep isl_aff *aff); @@ -83,8 +96,12 @@ __isl_give isl_aff *isl_aff_sub(__isl_take isl_aff *aff1, __isl_take isl_aff *aff2); __isl_give isl_aff *isl_aff_scale(__isl_take isl_aff *aff, isl_int f); +__isl_give isl_aff *isl_aff_scale_val(__isl_take isl_aff *aff, + __isl_take isl_val *v); __isl_give isl_aff *isl_aff_scale_down(__isl_take isl_aff *aff, isl_int f); __isl_give isl_aff *isl_aff_scale_down_ui(__isl_take isl_aff *aff, unsigned f); +__isl_give isl_aff *isl_aff_scale_down_val(__isl_take isl_aff *aff, + __isl_take isl_val *v); __isl_give isl_aff *isl_aff_insert_dims(__isl_take isl_aff *aff, enum isl_dim_type type, unsigned first, unsigned n); @@ -271,41 +288,11 @@ __isl_give isl_set *isl_pw_aff_list_ge_set(__isl_take isl_pw_aff_list *list1, __isl_give isl_set *isl_pw_aff_list_gt_set(__isl_take isl_pw_aff_list *list1, __isl_take isl_pw_aff_list *list2); +ISL_DECLARE_MULTI(aff) + __isl_give isl_multi_aff *isl_multi_aff_from_aff(__isl_take isl_aff *aff); -__isl_give isl_multi_aff *isl_multi_aff_zero(__isl_take isl_space *space); __isl_give isl_multi_aff *isl_multi_aff_identity(__isl_take isl_space *space); -isl_ctx *isl_multi_aff_get_ctx(__isl_keep isl_multi_aff *maff); -__isl_give isl_space *isl_multi_aff_get_space(__isl_keep isl_multi_aff *maff); -__isl_give isl_space *isl_multi_aff_get_domain_space( - __isl_keep isl_multi_aff *maff); -__isl_give isl_multi_aff *isl_multi_aff_set_tuple_name( - __isl_take isl_multi_aff *maff, - enum isl_dim_type type, const char *s); -__isl_give isl_multi_aff *isl_multi_aff_set_tuple_id( - __isl_take isl_multi_aff *maff, - enum isl_dim_type type, __isl_take isl_id *id); -__isl_give isl_multi_aff *isl_multi_aff_copy(__isl_keep isl_multi_aff *maff); -void *isl_multi_aff_free(__isl_take isl_multi_aff *maff); - -unsigned isl_multi_aff_dim(__isl_keep isl_multi_aff *maff, - enum isl_dim_type type); -__isl_give isl_aff *isl_multi_aff_get_aff(__isl_keep isl_multi_aff *multi, - int pos); - -__isl_give isl_multi_aff *isl_multi_aff_insert_dims( - __isl_take isl_multi_aff *ma, - enum isl_dim_type type, unsigned first, unsigned n); -__isl_give isl_multi_aff *isl_multi_aff_add_dims(__isl_take isl_multi_aff *ma, - enum isl_dim_type type, unsigned n); -__isl_give isl_multi_aff *isl_multi_aff_drop_dims( - __isl_take isl_multi_aff *maff, - enum isl_dim_type type, unsigned first, unsigned n); - -__isl_give isl_multi_aff *isl_multi_aff_set_dim_name( - __isl_take isl_multi_aff *maff, - enum isl_dim_type type, unsigned pos, const char *s); - int isl_multi_aff_plain_is_equal(__isl_keep isl_multi_aff *maff1, __isl_keep isl_multi_aff *maff2); @@ -319,16 +306,6 @@ __isl_give isl_multi_aff *isl_multi_aff_scale(__isl_take isl_multi_aff *maff, __isl_give isl_multi_aff *isl_multi_aff_scale_vec(__isl_take isl_multi_aff *ma, __isl_take isl_vec *v); -__isl_give isl_multi_aff *isl_multi_aff_range_splice( - __isl_take isl_multi_aff *ma1, unsigned pos, - __isl_take isl_multi_aff *ma2); -__isl_give isl_multi_aff *isl_multi_aff_splice( - __isl_take isl_multi_aff *ma1, unsigned in_pos, unsigned out_pos, - __isl_take isl_multi_aff *ma2); -__isl_give isl_multi_aff *isl_multi_aff_range_product( - __isl_take isl_multi_aff *ma1, __isl_take isl_multi_aff *ma2); -__isl_give isl_multi_aff *isl_multi_aff_flat_range_product( - __isl_take isl_multi_aff *ma1, __isl_take isl_multi_aff *ma2); __isl_give isl_multi_aff *isl_multi_aff_product( __isl_take isl_multi_aff *ma1, __isl_take isl_multi_aff *ma2); @@ -358,6 +335,8 @@ __isl_give isl_multi_aff *isl_multi_aff_read_from_str(isl_ctx *ctx, const char *str); void isl_multi_aff_dump(__isl_keep isl_multi_aff *maff); +ISL_DECLARE_MULTI(pw_aff) + __isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity( __isl_take isl_space *space); __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_multi_aff( @@ -540,50 +519,11 @@ void isl_union_pw_multi_aff_dump(__isl_keep isl_union_pw_multi_aff *upma); __isl_give char *isl_union_pw_multi_aff_to_str( __isl_keep isl_union_pw_multi_aff *upma); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_zero(__isl_take isl_space *space); __isl_give isl_multi_pw_aff *isl_multi_pw_aff_identity( __isl_take isl_space *space); __isl_give isl_multi_pw_aff *isl_multi_pw_aff_from_pw_aff( __isl_take isl_pw_aff *pa); -isl_ctx *isl_multi_pw_aff_get_ctx(__isl_keep isl_multi_pw_aff *mpa); -__isl_give isl_space *isl_multi_pw_aff_get_space( - __isl_keep isl_multi_pw_aff *mpa); -__isl_give isl_space *isl_multi_pw_aff_get_domain_space( - __isl_keep isl_multi_pw_aff *mpa); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_set_tuple_name( - __isl_take isl_multi_pw_aff *mpa, - enum isl_dim_type type, const char *s); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_copy( - __isl_keep isl_multi_pw_aff *mpa); -void *isl_multi_pw_aff_free(__isl_take isl_multi_pw_aff *mpa); - -unsigned isl_multi_pw_aff_dim(__isl_keep isl_multi_pw_aff *mpa, - enum isl_dim_type type); -__isl_give isl_pw_aff *isl_multi_pw_aff_get_pw_aff( - __isl_keep isl_multi_pw_aff *mpa, int pos); - -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_insert_dims( - __isl_take isl_multi_pw_aff *mpa, - enum isl_dim_type type, unsigned first, unsigned n); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_add_dims( - __isl_take isl_multi_pw_aff *mpa, enum isl_dim_type type, unsigned n); - -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_set_dim_name( - __isl_take isl_multi_pw_aff *mpa, - enum isl_dim_type type, unsigned pos, const char *s); - -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_range_splice( - __isl_take isl_multi_pw_aff *mpa1, unsigned pos, - __isl_take isl_multi_pw_aff *mpa2); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_splice( - __isl_take isl_multi_pw_aff *mpa1, unsigned in_pos, unsigned out_pos, - __isl_take isl_multi_pw_aff *mpa2); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_flat_range_product( - __isl_take isl_multi_pw_aff *mpa1, __isl_take isl_multi_pw_aff *mpa2); -__isl_give isl_multi_pw_aff *isl_multi_pw_aff_range_product( - __isl_take isl_multi_pw_aff *mpa1, __isl_take isl_multi_pw_aff *mpa2); - __isl_give isl_printer *isl_printer_print_multi_pw_aff( __isl_take isl_printer *p, __isl_keep isl_multi_pw_aff *mpa); void isl_multi_pw_aff_dump(__isl_keep isl_multi_pw_aff *mpa);