mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-04-02 21:22:44 +00:00
[Polly] Update isl to isl-0.23-61-g24e8cd12.
This fixes llvm.org/PR48554 Some test cases had to be updated because the hash function for union_maps have been changed which affects the output order.
This commit is contained in:
parent
2f80995090
commit
842314b5f0
5
polly/lib/External/isl/AUTHORS
vendored
5
polly/lib/External/isl/AUTHORS
vendored
@ -23,8 +23,8 @@ isl was written by
|
||||
Domaine de Voluceau - Rocquencourt, B.P. 105
|
||||
78153 Le Chesnay
|
||||
France
|
||||
2015-2019 Polly Labs
|
||||
2018-2019 Cerebras Systems
|
||||
2015-2020 Polly Labs
|
||||
2018-2020 Cerebras Systems
|
||||
175 S San Antonio Rd
|
||||
Los Altos, CA
|
||||
USA
|
||||
@ -54,6 +54,7 @@ Uday Bondhugula
|
||||
Andreas Simbuerger
|
||||
Malhar Thakkar
|
||||
Sergei Trofimovich
|
||||
Miheer Vaidya
|
||||
Sven van Haastregt
|
||||
Oleksandr Zinenko
|
||||
|
||||
|
9
polly/lib/External/isl/ChangeLog
vendored
9
polly/lib/External/isl/ChangeLog
vendored
@ -1,3 +1,11 @@
|
||||
version: 0.23
|
||||
date: Sun 01 Nov 2020 02:41:20 PM CET
|
||||
changes:
|
||||
- minor improvements to coalescing
|
||||
- use build compiler to build extract_interface
|
||||
- add some convenience functions
|
||||
- ignore parameters in isl_union_* hash tables
|
||||
---
|
||||
version: 0.22.1
|
||||
date: Sun Jan 12 10:48:18 CET 2020
|
||||
changes:
|
||||
@ -6,6 +14,7 @@ changes:
|
||||
version: 0.22
|
||||
date: Fri Nov 1 18:39:30 CET 2019
|
||||
changes:
|
||||
- require C++11 to generate bindings
|
||||
- improved bindings
|
||||
- scheduler fix involving fixed dimensions
|
||||
- accept ranges in tuples during parsing
|
||||
|
2
polly/lib/External/isl/GIT_HEAD_ID
vendored
2
polly/lib/External/isl/GIT_HEAD_ID
vendored
@ -1 +1 @@
|
||||
isl-0.22.1-416-g61d6dc75
|
||||
isl-0.23-61-g24e8cd12
|
||||
|
5
polly/lib/External/isl/Makefile.am
vendored
5
polly/lib/External/isl/Makefile.am
vendored
@ -141,6 +141,7 @@ libisl_la_SOURCES = \
|
||||
isl_ilp_private.h \
|
||||
isl_input.c \
|
||||
isl_int.h \
|
||||
isl_list_private.h \
|
||||
isl_local_private.h \
|
||||
isl_local.h \
|
||||
isl_local.c \
|
||||
@ -465,7 +466,9 @@ EXTRA_DIST = \
|
||||
isl_check_named_params_templ.c \
|
||||
check_reparse_templ.c \
|
||||
check_reparse_test_templ.c \
|
||||
check_single_reference_templ.c \
|
||||
check_type_range_templ.c \
|
||||
isl_copy_tuple_id_templ.c \
|
||||
isl_domain_factor_templ.c \
|
||||
extract_key.c \
|
||||
isl_ilp_opt_multi_val_templ.c \
|
||||
@ -558,6 +561,7 @@ EXTRA_DIST = \
|
||||
isl_type_check_equal_space_templ.c \
|
||||
isl_type_has_equal_space_bin_templ.c \
|
||||
isl_type_has_equal_space_templ.c \
|
||||
isl_type_has_space_templ.c \
|
||||
isl_unbind_params_templ.c \
|
||||
uset_to_umap.c \
|
||||
uset_from_umap.c \
|
||||
@ -567,6 +571,7 @@ EXTRA_DIST = \
|
||||
isl_union_multi.c \
|
||||
isl_union_eval.c \
|
||||
isl_union_locals_templ.c \
|
||||
isl_union_map_lex_templ.c \
|
||||
isl_union_neg.c \
|
||||
isl_union_pw_templ.c \
|
||||
libisl-gdb.py \
|
||||
|
611
polly/lib/External/isl/Makefile.in
vendored
611
polly/lib/External/isl/Makefile.in
vendored
@ -1,7 +1,7 @@
|
||||
# Makefile.in generated by automake 1.15.1 from Makefile.am.
|
||||
# Makefile.in generated by automake 1.16.1 from Makefile.am.
|
||||
# @configure_input@
|
||||
|
||||
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This Makefile.in is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -151,16 +151,13 @@ CONFIG_HEADER = isl_config.h
|
||||
CONFIG_CLEAN_FILES = isl_srcdir.c bound_test.sh codegen_test.sh \
|
||||
pip_test.sh flow_test.sh schedule_test.sh
|
||||
CONFIG_CLEAN_VPATH_FILES =
|
||||
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_1 = \
|
||||
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp$(EXEEXT)
|
||||
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_2 = isl_test_cpp-checked$(EXEEXT) \
|
||||
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp-checked-conversion$(EXEEXT)
|
||||
@IMATH_FOR_MP_TRUE@am__EXEEXT_3 = isl_test_imath$(EXEEXT)
|
||||
PROGRAMS = $(noinst_PROGRAMS)
|
||||
LIBRARIES = $(noinst_LIBRARIES)
|
||||
ARFLAGS = cru
|
||||
AM_V_AR = $(am__v_AR_@AM_V@)
|
||||
am__v_AR_ = $(am__v_AR_@AM_DEFAULT_V@)
|
||||
am__v_AR_0 = @echo " AR " $@;
|
||||
am__v_AR_1 =
|
||||
libdep_a_AR = $(AR) $(ARFLAGS)
|
||||
libdep_a_LIBADD =
|
||||
am_libdep_a_OBJECTS = dep.$(OBJEXT)
|
||||
libdep_a_OBJECTS = $(am_libdep_a_OBJECTS)
|
||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
||||
am__vpath_adj = case $$p in \
|
||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
||||
@ -191,6 +188,15 @@ am__uninstall_files_from_dir = { \
|
||||
am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(pkgconfigdir)" \
|
||||
"$(DESTDIR)$(pkgincludedir)" "$(DESTDIR)$(pkgincludedir)"
|
||||
LTLIBRARIES = $(lib_LTLIBRARIES)
|
||||
ARFLAGS = cru
|
||||
AM_V_AR = $(am__v_AR_@AM_V@)
|
||||
am__v_AR_ = $(am__v_AR_@AM_DEFAULT_V@)
|
||||
am__v_AR_0 = @echo " AR " $@;
|
||||
am__v_AR_1 =
|
||||
libdep_a_AR = $(AR) $(ARFLAGS)
|
||||
libdep_a_LIBADD =
|
||||
am_libdep_a_OBJECTS = dep.$(OBJEXT)
|
||||
libdep_a_OBJECTS = $(am_libdep_a_OBJECTS)
|
||||
libisl_la_DEPENDENCIES =
|
||||
am__libisl_la_SOURCES_DIST = mp_get_memory_functions.c isl_int_gmp.h \
|
||||
isl_gmp.c isl_val_gmp.c isl_imath.c isl_imath.h \
|
||||
@ -211,17 +217,18 @@ am__libisl_la_SOURCES_DIST = mp_get_memory_functions.c isl_int_gmp.h \
|
||||
isl_factorization.c isl_factorization.h isl_farkas.c isl_ffs.c \
|
||||
isl_flow.c isl_fold.c isl_hash.c isl_id_to_ast_expr.c \
|
||||
isl_id_to_id.c isl_id_to_pw_aff.c isl_ilp.c isl_ilp_private.h \
|
||||
isl_input.c isl_int.h isl_local_private.h isl_local.h \
|
||||
isl_local.c isl_local_space_private.h isl_local_space.c \
|
||||
isl_lp.c isl_lp_private.h isl_map.c isl_map_list.c \
|
||||
isl_map_simplify.c isl_map_subtract.c isl_map_private.h \
|
||||
isl_map_to_basic_set.c isl_mat.c isl_mat_private.h isl_morph.c \
|
||||
isl_morph.h isl_id.c isl_id_private.h isl_obj.c isl_options.c \
|
||||
isl_options_private.h isl_output.c isl_output_private.h \
|
||||
isl_point_private.h isl_point.c isl_polynomial_private.h \
|
||||
isl_polynomial.c isl_printer_private.h isl_printer.c print.c \
|
||||
isl_range.c isl_range.h isl_reordering.c isl_reordering.h \
|
||||
isl_sample.h isl_sample.c isl_scan.c isl_scan.h isl_schedule.c \
|
||||
isl_input.c isl_int.h isl_list_private.h isl_local_private.h \
|
||||
isl_local.h isl_local.c isl_local_space_private.h \
|
||||
isl_local_space.c isl_lp.c isl_lp_private.h isl_map.c \
|
||||
isl_map_list.c isl_map_simplify.c isl_map_subtract.c \
|
||||
isl_map_private.h isl_map_to_basic_set.c isl_mat.c \
|
||||
isl_mat_private.h isl_morph.c isl_morph.h isl_id.c \
|
||||
isl_id_private.h isl_obj.c isl_options.c isl_options_private.h \
|
||||
isl_output.c isl_output_private.h isl_point_private.h \
|
||||
isl_point.c isl_polynomial_private.h isl_polynomial.c \
|
||||
isl_printer_private.h isl_printer.c print.c isl_range.c \
|
||||
isl_range.h isl_reordering.c isl_reordering.h isl_sample.h \
|
||||
isl_sample.c isl_scan.c isl_scan.h isl_schedule.c \
|
||||
isl_schedule_band.c isl_schedule_band.h isl_schedule_node.c \
|
||||
isl_schedule_node_private.h isl_schedule_read.c \
|
||||
isl_schedule_tree.c isl_schedule_tree.h isl_schedule_private.h \
|
||||
@ -281,12 +288,6 @@ am__v_lt_1 =
|
||||
libisl_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
|
||||
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
|
||||
$(libisl_la_LDFLAGS) $(LDFLAGS) -o $@
|
||||
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_1 = \
|
||||
@HAVE_CPP_ISL_H_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp$(EXEEXT)
|
||||
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@am__EXEEXT_2 = isl_test_cpp-checked$(EXEEXT) \
|
||||
@HAVE_CLANG_TRUE@@HAVE_CXX11_TRUE@ isl_test_cpp-checked-conversion$(EXEEXT)
|
||||
@IMATH_FOR_MP_TRUE@am__EXEEXT_3 = isl_test_imath$(EXEEXT)
|
||||
PROGRAMS = $(noinst_PROGRAMS)
|
||||
am_isl_bound_OBJECTS = bound.$(OBJEXT)
|
||||
isl_bound_OBJECTS = $(am_isl_bound_OBJECTS)
|
||||
isl_bound_DEPENDENCIES = libisl.la
|
||||
@ -410,7 +411,70 @@ am__v_at_0 = @
|
||||
am__v_at_1 =
|
||||
DEFAULT_INCLUDES =
|
||||
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
||||
am__depfiles_maybe = depfiles
|
||||
am__maybe_remake_depfiles = depfiles
|
||||
am__depfiles_remade = ./$(DEPDIR)/basis_reduction_tab.Plo \
|
||||
./$(DEPDIR)/bound.Po ./$(DEPDIR)/cat.Po ./$(DEPDIR)/closure.Po \
|
||||
./$(DEPDIR)/codegen.Po ./$(DEPDIR)/dep.Po ./$(DEPDIR)/flow.Po \
|
||||
./$(DEPDIR)/flow_cmp.Po ./$(DEPDIR)/isl_aff.Plo \
|
||||
./$(DEPDIR)/isl_aff_map.Plo ./$(DEPDIR)/isl_affine_hull.Plo \
|
||||
./$(DEPDIR)/isl_arg.Plo ./$(DEPDIR)/isl_ast.Plo \
|
||||
./$(DEPDIR)/isl_ast_build.Plo \
|
||||
./$(DEPDIR)/isl_ast_build_expr.Plo \
|
||||
./$(DEPDIR)/isl_ast_codegen.Plo ./$(DEPDIR)/isl_ast_graft.Plo \
|
||||
./$(DEPDIR)/isl_bernstein.Plo ./$(DEPDIR)/isl_blk.Plo \
|
||||
./$(DEPDIR)/isl_bound.Plo ./$(DEPDIR)/isl_box.Plo \
|
||||
./$(DEPDIR)/isl_coalesce.Plo ./$(DEPDIR)/isl_constraint.Plo \
|
||||
./$(DEPDIR)/isl_convex_hull.Plo ./$(DEPDIR)/isl_ctx.Plo \
|
||||
./$(DEPDIR)/isl_deprecated.Plo ./$(DEPDIR)/isl_dim_map.Plo \
|
||||
./$(DEPDIR)/isl_equalities.Plo \
|
||||
./$(DEPDIR)/isl_factorization.Plo ./$(DEPDIR)/isl_farkas.Plo \
|
||||
./$(DEPDIR)/isl_ffs.Plo ./$(DEPDIR)/isl_flow.Plo \
|
||||
./$(DEPDIR)/isl_fold.Plo ./$(DEPDIR)/isl_gmp.Plo \
|
||||
./$(DEPDIR)/isl_hash.Plo ./$(DEPDIR)/isl_id.Plo \
|
||||
./$(DEPDIR)/isl_id_to_ast_expr.Plo \
|
||||
./$(DEPDIR)/isl_id_to_id.Plo ./$(DEPDIR)/isl_id_to_pw_aff.Plo \
|
||||
./$(DEPDIR)/isl_ilp.Plo ./$(DEPDIR)/isl_imath.Plo \
|
||||
./$(DEPDIR)/isl_input.Plo ./$(DEPDIR)/isl_int_sioimath.Plo \
|
||||
./$(DEPDIR)/isl_local.Plo ./$(DEPDIR)/isl_local_space.Plo \
|
||||
./$(DEPDIR)/isl_lp.Plo ./$(DEPDIR)/isl_map.Plo \
|
||||
./$(DEPDIR)/isl_map_list.Plo ./$(DEPDIR)/isl_map_simplify.Plo \
|
||||
./$(DEPDIR)/isl_map_subtract.Plo \
|
||||
./$(DEPDIR)/isl_map_to_basic_set.Plo ./$(DEPDIR)/isl_mat.Plo \
|
||||
./$(DEPDIR)/isl_morph.Plo ./$(DEPDIR)/isl_obj.Plo \
|
||||
./$(DEPDIR)/isl_options.Plo ./$(DEPDIR)/isl_output.Plo \
|
||||
./$(DEPDIR)/isl_point.Plo ./$(DEPDIR)/isl_polynomial.Plo \
|
||||
./$(DEPDIR)/isl_printer.Plo ./$(DEPDIR)/isl_range.Plo \
|
||||
./$(DEPDIR)/isl_reordering.Plo ./$(DEPDIR)/isl_sample.Plo \
|
||||
./$(DEPDIR)/isl_scan.Plo ./$(DEPDIR)/isl_schedule.Plo \
|
||||
./$(DEPDIR)/isl_schedule_band.Plo \
|
||||
./$(DEPDIR)/isl_schedule_constraints.Plo \
|
||||
./$(DEPDIR)/isl_schedule_node.Plo \
|
||||
./$(DEPDIR)/isl_schedule_read.Plo \
|
||||
./$(DEPDIR)/isl_schedule_tree.Plo \
|
||||
./$(DEPDIR)/isl_scheduler.Plo ./$(DEPDIR)/isl_seq.Plo \
|
||||
./$(DEPDIR)/isl_set_list.Plo \
|
||||
./$(DEPDIR)/isl_set_to_ast_graft_list.Plo \
|
||||
./$(DEPDIR)/isl_sort.Plo ./$(DEPDIR)/isl_space.Plo \
|
||||
./$(DEPDIR)/isl_stream.Plo ./$(DEPDIR)/isl_stride.Plo \
|
||||
./$(DEPDIR)/isl_tab.Plo ./$(DEPDIR)/isl_tab_pip.Plo \
|
||||
./$(DEPDIR)/isl_tarjan.Plo ./$(DEPDIR)/isl_test.Po \
|
||||
./$(DEPDIR)/isl_test_cpp-checked-conversion.Po \
|
||||
./$(DEPDIR)/isl_test_cpp-checked.Po \
|
||||
./$(DEPDIR)/isl_test_cpp.Po ./$(DEPDIR)/isl_test_imath.Po \
|
||||
./$(DEPDIR)/isl_test_int.Po \
|
||||
./$(DEPDIR)/isl_transitive_closure.Plo \
|
||||
./$(DEPDIR)/isl_union_map.Plo ./$(DEPDIR)/isl_val.Plo \
|
||||
./$(DEPDIR)/isl_val_gmp.Plo ./$(DEPDIR)/isl_val_imath.Plo \
|
||||
./$(DEPDIR)/isl_val_sioimath.Plo ./$(DEPDIR)/isl_vec.Plo \
|
||||
./$(DEPDIR)/isl_version.Plo ./$(DEPDIR)/isl_vertices.Plo \
|
||||
./$(DEPDIR)/mp_get_memory_functions.Plo ./$(DEPDIR)/pip.Po \
|
||||
./$(DEPDIR)/polyhedron_detect_equalities.Po \
|
||||
./$(DEPDIR)/polyhedron_minimize.Po \
|
||||
./$(DEPDIR)/polyhedron_sample.Po ./$(DEPDIR)/polytope_scan.Po \
|
||||
./$(DEPDIR)/print.Plo ./$(DEPDIR)/schedule.Po \
|
||||
./$(DEPDIR)/schedule_cmp.Po \
|
||||
imath_wrap/$(DEPDIR)/gmp_compat.Plo \
|
||||
imath_wrap/$(DEPDIR)/imath.Plo imath_wrap/$(DEPDIR)/imrat.Plo
|
||||
am__mv = mv -f
|
||||
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
||||
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||
@ -522,7 +586,8 @@ am__recursive_targets = \
|
||||
$(RECURSIVE_CLEAN_TARGETS) \
|
||||
$(am__extra_recursive_targets)
|
||||
AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
|
||||
cscope check recheck distdir dist dist-all distcheck
|
||||
cscope check recheck distdir distdir-am dist dist-all \
|
||||
distcheck
|
||||
am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \
|
||||
$(LISP)isl_config.h.in
|
||||
# Read a list of newline-separated strings from the standard input,
|
||||
@ -1006,6 +1071,7 @@ libisl_la_SOURCES = \
|
||||
isl_ilp_private.h \
|
||||
isl_input.c \
|
||||
isl_int.h \
|
||||
isl_list_private.h \
|
||||
isl_local_private.h \
|
||||
isl_local.h \
|
||||
isl_local.c \
|
||||
@ -1278,7 +1344,9 @@ EXTRA_DIST = \
|
||||
isl_check_named_params_templ.c \
|
||||
check_reparse_templ.c \
|
||||
check_reparse_test_templ.c \
|
||||
check_single_reference_templ.c \
|
||||
check_type_range_templ.c \
|
||||
isl_copy_tuple_id_templ.c \
|
||||
isl_domain_factor_templ.c \
|
||||
extract_key.c \
|
||||
isl_ilp_opt_multi_val_templ.c \
|
||||
@ -1371,6 +1439,7 @@ EXTRA_DIST = \
|
||||
isl_type_check_equal_space_templ.c \
|
||||
isl_type_has_equal_space_bin_templ.c \
|
||||
isl_type_has_equal_space_templ.c \
|
||||
isl_type_has_space_templ.c \
|
||||
isl_unbind_params_templ.c \
|
||||
uset_to_umap.c \
|
||||
uset_from_umap.c \
|
||||
@ -1380,6 +1449,7 @@ EXTRA_DIST = \
|
||||
isl_union_multi.c \
|
||||
isl_union_eval.c \
|
||||
isl_union_locals_templ.c \
|
||||
isl_union_map_lex_templ.c \
|
||||
isl_union_neg.c \
|
||||
isl_union_pw_templ.c \
|
||||
libisl-gdb.py \
|
||||
@ -1432,8 +1502,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||
echo ' $(SHELL) ./config.status'; \
|
||||
$(SHELL) ./config.status;; \
|
||||
*) \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
|
||||
esac;
|
||||
|
||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||
@ -1472,14 +1542,18 @@ flow_test.sh: $(top_builddir)/config.status $(srcdir)/flow_test.sh.in
|
||||
schedule_test.sh: $(top_builddir)/config.status $(srcdir)/schedule_test.sh.in
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $@
|
||||
|
||||
clean-noinstPROGRAMS:
|
||||
@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
|
||||
echo " rm -f" $$list; \
|
||||
rm -f $$list || exit $$?; \
|
||||
test -n "$(EXEEXT)" || exit 0; \
|
||||
list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
|
||||
echo " rm -f" $$list; \
|
||||
rm -f $$list
|
||||
|
||||
clean-noinstLIBRARIES:
|
||||
-test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES)
|
||||
|
||||
libdep.a: $(libdep_a_OBJECTS) $(libdep_a_DEPENDENCIES) $(EXTRA_libdep_a_DEPENDENCIES)
|
||||
$(AM_V_at)-rm -f libdep.a
|
||||
$(AM_V_AR)$(libdep_a_AR) libdep.a $(libdep_a_OBJECTS) $(libdep_a_LIBADD)
|
||||
$(AM_V_at)$(RANLIB) libdep.a
|
||||
|
||||
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
||||
@$(NORMAL_INSTALL)
|
||||
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
|
||||
@ -1514,6 +1588,11 @@ clean-libLTLIBRARIES:
|
||||
echo rm -f $${locs}; \
|
||||
rm -f $${locs}; \
|
||||
}
|
||||
|
||||
libdep.a: $(libdep_a_OBJECTS) $(libdep_a_DEPENDENCIES) $(EXTRA_libdep_a_DEPENDENCIES)
|
||||
$(AM_V_at)-rm -f libdep.a
|
||||
$(AM_V_AR)$(libdep_a_AR) libdep.a $(libdep_a_OBJECTS) $(libdep_a_LIBADD)
|
||||
$(AM_V_at)$(RANLIB) libdep.a
|
||||
imath_wrap/$(am__dirstamp):
|
||||
@$(MKDIR_P) imath_wrap
|
||||
@: > imath_wrap/$(am__dirstamp)
|
||||
@ -1530,15 +1609,6 @@ imath_wrap/imrat.lo: imath_wrap/$(am__dirstamp) \
|
||||
libisl.la: $(libisl_la_OBJECTS) $(libisl_la_DEPENDENCIES) $(EXTRA_libisl_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libisl_la_LINK) -rpath $(libdir) $(libisl_la_OBJECTS) $(libisl_la_LIBADD) $(LIBS)
|
||||
|
||||
clean-noinstPROGRAMS:
|
||||
@list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \
|
||||
echo " rm -f" $$list; \
|
||||
rm -f $$list || exit $$?; \
|
||||
test -n "$(EXEEXT)" || exit 0; \
|
||||
list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
|
||||
echo " rm -f" $$list; \
|
||||
rm -f $$list
|
||||
|
||||
isl_bound$(EXEEXT): $(isl_bound_OBJECTS) $(isl_bound_DEPENDENCIES) $(EXTRA_isl_bound_DEPENDENCIES)
|
||||
@rm -f isl_bound$(EXEEXT)
|
||||
$(AM_V_CCLD)$(isl_bound_LINK) $(isl_bound_OBJECTS) $(isl_bound_LDADD) $(LIBS)
|
||||
@ -1623,113 +1693,119 @@ mostlyclean-compile:
|
||||
distclean-compile:
|
||||
-rm -f *.tab.c
|
||||
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/basis_reduction_tab.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bound.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cat.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/closure.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/codegen.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dep.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow_cmp.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff_map.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_affine_hull.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_arg.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build_expr.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_codegen.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_graft.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bernstein.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_blk.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bound.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_box.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_coalesce.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_constraint.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_convex_hull.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ctx.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_deprecated.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_dim_map.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_equalities.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_factorization.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_farkas.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ffs.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_flow.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_fold.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_gmp.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_hash.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_ast_expr.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_id.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_pw_aff.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ilp.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_imath.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_input.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_int_sioimath.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local_space.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_lp.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_list.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_simplify.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_subtract.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_to_basic_set.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_mat.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_morph.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_obj.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_options.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_output.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_point.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_polynomial.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_printer.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_range.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_reordering.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sample.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scan.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_band.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_constraints.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_node.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_read.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_tree.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scheduler.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_seq.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_list.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_to_ast_graft_list.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sort.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_space.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stream.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stride.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab_pip.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tarjan.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked-conversion.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_imath.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_int.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_transitive_closure.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_union_map.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_gmp.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_imath.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_sioimath.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vec.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_version.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vertices.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mp_get_memory_functions.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pip.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_detect_equalities.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_minimize.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_sample.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polytope_scan.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/print.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule_cmp.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/gmp_compat.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imath.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imrat.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/basis_reduction_tab.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bound.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cat.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/closure.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/codegen.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dep.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flow_cmp.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_aff_map.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_affine_hull.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_arg.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_build_expr.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_codegen.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ast_graft.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bernstein.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_blk.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_bound.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_box.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_coalesce.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_constraint.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_convex_hull.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ctx.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_deprecated.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_dim_map.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_equalities.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_factorization.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_farkas.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ffs.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_flow.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_fold.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_gmp.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_hash.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_ast_expr.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_id.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_id_to_pw_aff.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_ilp.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_imath.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_input.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_int_sioimath.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_local_space.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_lp.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_list.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_simplify.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_subtract.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_map_to_basic_set.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_mat.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_morph.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_obj.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_options.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_output.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_point.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_polynomial.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_printer.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_range.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_reordering.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sample.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scan.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_band.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_constraints.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_node.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_read.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_schedule_tree.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_scheduler.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_seq.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_list.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_set_to_ast_graft_list.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_sort.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_space.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stream.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_stride.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tab_pip.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_tarjan.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked-conversion.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp-checked.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_cpp.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_imath.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_test_int.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_transitive_closure.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_union_map.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_gmp.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_imath.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_val_sioimath.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vec.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_version.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/isl_vertices.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mp_get_memory_functions.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pip.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_detect_equalities.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_minimize.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polyhedron_sample.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/polytope_scan.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/print.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/schedule_cmp.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/gmp_compat.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imath.Plo@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@imath_wrap/$(DEPDIR)/imrat.Plo@am__quote@ # am--include-marker
|
||||
|
||||
$(am__depfiles_remade):
|
||||
@$(MKDIR_P) $(@D)
|
||||
@echo '# dummy' >$@-t && $(am__mv) $@-t $@
|
||||
|
||||
am--depfiles: $(am__depfiles_remade)
|
||||
|
||||
.c.o:
|
||||
@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\
|
||||
@ -2078,7 +2154,7 @@ $(TEST_SUITE_LOG): $(TEST_LOGS)
|
||||
fi; \
|
||||
$$success || exit 1
|
||||
|
||||
check-TESTS:
|
||||
check-TESTS:
|
||||
@list='$(RECHECK_LOGS)'; test -z "$$list" || rm -f $$list
|
||||
@list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list
|
||||
@test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
|
||||
@ -2191,7 +2267,10 @@ isl_test_imath.log: isl_test_imath$(EXEEXT)
|
||||
@am__EXEEXT_TRUE@ $(am__common_driver_flags) $(AM_PY_LOG_DRIVER_FLAGS) $(PY_LOG_DRIVER_FLAGS) -- $(PY_LOG_COMPILE) \
|
||||
@am__EXEEXT_TRUE@ "$$tst" $(AM_TESTS_FD_REDIRECT)
|
||||
|
||||
distdir: $(DISTFILES)
|
||||
distdir: $(BUILT_SOURCES)
|
||||
$(MAKE) $(AM_MAKEFLAGS) distdir-am
|
||||
|
||||
distdir-am: $(DISTFILES)
|
||||
$(am__remove_distdir)
|
||||
test -d "$(distdir)" || mkdir "$(distdir)"
|
||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
@ -2386,7 +2465,7 @@ check-am: all-am
|
||||
$(MAKE) $(AM_MAKEFLAGS) check-TESTS
|
||||
check: $(BUILT_SOURCES)
|
||||
$(MAKE) $(AM_MAKEFLAGS) check-recursive
|
||||
all-am: Makefile $(LIBRARIES) $(LTLIBRARIES) $(PROGRAMS) $(DATA) \
|
||||
all-am: Makefile $(PROGRAMS) $(LIBRARIES) $(LTLIBRARIES) $(DATA) \
|
||||
$(HEADERS) isl_config.h
|
||||
installdirs: installdirs-recursive
|
||||
installdirs-am:
|
||||
@ -2439,7 +2518,113 @@ clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
|
||||
|
||||
distclean: distclean-recursive
|
||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||
-rm -rf ./$(DEPDIR) imath_wrap/$(DEPDIR)
|
||||
-rm -f ./$(DEPDIR)/basis_reduction_tab.Plo
|
||||
-rm -f ./$(DEPDIR)/bound.Po
|
||||
-rm -f ./$(DEPDIR)/cat.Po
|
||||
-rm -f ./$(DEPDIR)/closure.Po
|
||||
-rm -f ./$(DEPDIR)/codegen.Po
|
||||
-rm -f ./$(DEPDIR)/dep.Po
|
||||
-rm -f ./$(DEPDIR)/flow.Po
|
||||
-rm -f ./$(DEPDIR)/flow_cmp.Po
|
||||
-rm -f ./$(DEPDIR)/isl_aff.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_aff_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_affine_hull.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_arg.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_build.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_build_expr.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_codegen.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_graft.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_bernstein.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_blk.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_bound.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_box.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_coalesce.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_constraint.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_convex_hull.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ctx.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_deprecated.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_dim_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_equalities.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_factorization.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_farkas.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ffs.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_flow.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_fold.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_gmp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_hash.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_ast_expr.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_id.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_pw_aff.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ilp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_imath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_input.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_int_sioimath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_local.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_local_space.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_lp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_simplify.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_subtract.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_to_basic_set.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_mat.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_morph.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_obj.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_options.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_output.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_point.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_polynomial.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_printer.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_range.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_reordering.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_sample.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_scan.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_band.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_constraints.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_node.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_read.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_tree.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_scheduler.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_seq.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_set_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_set_to_ast_graft_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_sort.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_space.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_stream.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_stride.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tab.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tab_pip.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tarjan.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_test.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp-checked-conversion.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp-checked.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_imath.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_int.Po
|
||||
-rm -f ./$(DEPDIR)/isl_transitive_closure.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_union_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_gmp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_imath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_sioimath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_vec.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_version.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_vertices.Plo
|
||||
-rm -f ./$(DEPDIR)/mp_get_memory_functions.Plo
|
||||
-rm -f ./$(DEPDIR)/pip.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_detect_equalities.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_minimize.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_sample.Po
|
||||
-rm -f ./$(DEPDIR)/polytope_scan.Po
|
||||
-rm -f ./$(DEPDIR)/print.Plo
|
||||
-rm -f ./$(DEPDIR)/schedule.Po
|
||||
-rm -f ./$(DEPDIR)/schedule_cmp.Po
|
||||
-rm -f imath_wrap/$(DEPDIR)/gmp_compat.Plo
|
||||
-rm -f imath_wrap/$(DEPDIR)/imath.Plo
|
||||
-rm -f imath_wrap/$(DEPDIR)/imrat.Plo
|
||||
-rm -f Makefile
|
||||
distclean-am: clean-am distclean-compile distclean-generic \
|
||||
distclean-hdr distclean-libtool distclean-tags
|
||||
@ -2488,7 +2673,113 @@ installcheck-am:
|
||||
maintainer-clean: maintainer-clean-recursive
|
||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||
-rm -rf $(top_srcdir)/autom4te.cache
|
||||
-rm -rf ./$(DEPDIR) imath_wrap/$(DEPDIR)
|
||||
-rm -f ./$(DEPDIR)/basis_reduction_tab.Plo
|
||||
-rm -f ./$(DEPDIR)/bound.Po
|
||||
-rm -f ./$(DEPDIR)/cat.Po
|
||||
-rm -f ./$(DEPDIR)/closure.Po
|
||||
-rm -f ./$(DEPDIR)/codegen.Po
|
||||
-rm -f ./$(DEPDIR)/dep.Po
|
||||
-rm -f ./$(DEPDIR)/flow.Po
|
||||
-rm -f ./$(DEPDIR)/flow_cmp.Po
|
||||
-rm -f ./$(DEPDIR)/isl_aff.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_aff_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_affine_hull.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_arg.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_build.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_build_expr.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_codegen.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ast_graft.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_bernstein.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_blk.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_bound.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_box.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_coalesce.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_constraint.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_convex_hull.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ctx.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_deprecated.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_dim_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_equalities.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_factorization.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_farkas.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ffs.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_flow.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_fold.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_gmp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_hash.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_ast_expr.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_id.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_id_to_pw_aff.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_ilp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_imath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_input.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_int_sioimath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_local.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_local_space.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_lp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_simplify.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_subtract.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_map_to_basic_set.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_mat.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_morph.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_obj.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_options.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_output.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_point.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_polynomial.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_printer.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_range.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_reordering.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_sample.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_scan.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_band.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_constraints.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_node.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_read.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_schedule_tree.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_scheduler.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_seq.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_set_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_set_to_ast_graft_list.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_sort.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_space.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_stream.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_stride.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tab.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tab_pip.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_tarjan.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_test.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp-checked-conversion.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp-checked.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_cpp.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_imath.Po
|
||||
-rm -f ./$(DEPDIR)/isl_test_int.Po
|
||||
-rm -f ./$(DEPDIR)/isl_transitive_closure.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_union_map.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_gmp.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_imath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_val_sioimath.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_vec.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_version.Plo
|
||||
-rm -f ./$(DEPDIR)/isl_vertices.Plo
|
||||
-rm -f ./$(DEPDIR)/mp_get_memory_functions.Plo
|
||||
-rm -f ./$(DEPDIR)/pip.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_detect_equalities.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_minimize.Po
|
||||
-rm -f ./$(DEPDIR)/polyhedron_sample.Po
|
||||
-rm -f ./$(DEPDIR)/polytope_scan.Po
|
||||
-rm -f ./$(DEPDIR)/print.Plo
|
||||
-rm -f ./$(DEPDIR)/schedule.Po
|
||||
-rm -f ./$(DEPDIR)/schedule_cmp.Po
|
||||
-rm -f imath_wrap/$(DEPDIR)/gmp_compat.Plo
|
||||
-rm -f imath_wrap/$(DEPDIR)/imath.Plo
|
||||
-rm -f imath_wrap/$(DEPDIR)/imrat.Plo
|
||||
-rm -f Makefile
|
||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||
|
||||
@ -2513,8 +2804,8 @@ uninstall-am: uninstall-libLTLIBRARIES uninstall-local \
|
||||
install-strip
|
||||
|
||||
.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \
|
||||
am--refresh check check-TESTS check-am clean clean-cscope \
|
||||
clean-generic clean-libLTLIBRARIES clean-libtool \
|
||||
am--depfiles am--refresh check check-TESTS check-am clean \
|
||||
clean-cscope clean-generic clean-libLTLIBRARIES clean-libtool \
|
||||
clean-noinstLIBRARIES clean-noinstPROGRAMS cscope \
|
||||
cscopelist-am ctags ctags-am dist dist-all dist-bzip2 \
|
||||
dist-gzip dist-hook dist-lzip dist-shar dist-tarZ dist-xz \
|
||||
|
199
polly/lib/External/isl/aclocal.m4
vendored
199
polly/lib/External/isl/aclocal.m4
vendored
@ -1,6 +1,6 @@
|
||||
# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
|
||||
# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -20,7 +20,7 @@ You have another version of autoconf. It may work, but is not guaranteed to.
|
||||
If you have problems, you may need to regenerate the build system entirely.
|
||||
To do so, use the procedure documented by the package, typically 'autoreconf'.])])
|
||||
|
||||
# Copyright (C) 2002-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2002-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
|
||||
# generated from the m4 files accompanying Automake X.Y.
|
||||
# (This private macro should not be called outside this file.)
|
||||
AC_DEFUN([AM_AUTOMAKE_VERSION],
|
||||
[am__api_version='1.15'
|
||||
[am__api_version='1.16'
|
||||
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
|
||||
dnl require some minimum version. Point them to the right macro.
|
||||
m4_if([$1], [1.15.1], [],
|
||||
m4_if([$1], [1.16.1], [],
|
||||
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
|
||||
])
|
||||
|
||||
@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
|
||||
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
|
||||
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
|
||||
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
|
||||
[AM_AUTOMAKE_VERSION([1.15.1])dnl
|
||||
[AM_AUTOMAKE_VERSION([1.16.1])dnl
|
||||
m4_ifndef([AC_AUTOCONF_VERSION],
|
||||
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
||||
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
|
||||
|
||||
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -110,7 +110,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
|
||||
|
||||
# AM_CONDITIONAL -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -141,7 +141,7 @@ AC_CONFIG_COMMANDS_PRE(
|
||||
Usually this means the macro was only invoked conditionally.]])
|
||||
fi])])
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -332,13 +332,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
|
||||
|
||||
# Generate code to set up dependency tracking. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
# with or without modifications, as long as this notice is preserved.
|
||||
|
||||
|
||||
# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||
# ------------------------------
|
||||
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
@ -346,49 +345,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
# Older Autoconf quotes --file arguments for eval, but not when files
|
||||
# are listed without --file. Let's play safe and only enable the eval
|
||||
# if we detect the quoting.
|
||||
case $CONFIG_FILES in
|
||||
*\'*) eval set x "$CONFIG_FILES" ;;
|
||||
*) set x $CONFIG_FILES ;;
|
||||
esac
|
||||
# TODO: see whether this extra hack can be removed once we start
|
||||
# requiring Autoconf 2.70 or later.
|
||||
AS_CASE([$CONFIG_FILES],
|
||||
[*\'*], [eval set x "$CONFIG_FILES"],
|
||||
[*], [set x $CONFIG_FILES])
|
||||
shift
|
||||
for mf
|
||||
# Used to flag and report bootstrapping failures.
|
||||
am_rc=0
|
||||
for am_mf
|
||||
do
|
||||
# Strip MF so we end up with the name of the file.
|
||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile or not.
|
||||
# We used to match only the files named 'Makefile.in', but
|
||||
# some people rename them; so instead we look at the file content.
|
||||
# Grep'ing the first line is not enough: some people post-process
|
||||
# each Makefile.in and add a new line on top of each file to say so.
|
||||
# Grep'ing the whole file is not good either: AIX grep has a line
|
||||
am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile which includes
|
||||
# dependency-tracking related rules and includes.
|
||||
# Grep'ing the whole file directly is not great: AIX grep has a line
|
||||
# limit of 2048, but all sed's we know have understand at least 4000.
|
||||
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
||||
dirpart=`AS_DIRNAME("$mf")`
|
||||
else
|
||||
continue
|
||||
fi
|
||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
||||
# from the Makefile without running 'make'.
|
||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
||||
test -z "$DEPDIR" && continue
|
||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
||||
test -z "$am__include" && continue
|
||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
||||
# Find all dependency output files, they are included files with
|
||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
||||
# expansion.
|
||||
for file in `sed -n "
|
||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
|
||||
# Make sure the directory exists.
|
||||
test -f "$dirpart/$file" && continue
|
||||
fdir=`AS_DIRNAME(["$file"])`
|
||||
AS_MKDIR_P([$dirpart/$fdir])
|
||||
# echo "creating $dirpart/$file"
|
||||
echo '# dummy' > "$dirpart/$file"
|
||||
done
|
||||
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|
||||
|| continue
|
||||
am_dirpart=`AS_DIRNAME(["$am_mf"])`
|
||||
am_filepart=`AS_BASENAME(["$am_mf"])`
|
||||
AM_RUN_LOG([cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles]) || am_rc=$?
|
||||
done
|
||||
if test $am_rc -ne 0; then
|
||||
AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
|
||||
for automatic dependency tracking. Try re-running configure with the
|
||||
'--disable-dependency-tracking' option to at least be able to build
|
||||
the package (albeit without support for automatic dependency tracking).])
|
||||
fi
|
||||
AS_UNSET([am_dirpart])
|
||||
AS_UNSET([am_filepart])
|
||||
AS_UNSET([am_mf])
|
||||
AS_UNSET([am_rc])
|
||||
rm -f conftest-deps.mk
|
||||
}
|
||||
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||
|
||||
@ -397,18 +388,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
# -----------------------------
|
||||
# This macro should only be invoked once -- use via AC_REQUIRE.
|
||||
#
|
||||
# This code is only required when automatic dependency tracking
|
||||
# is enabled. FIXME. This creates each '.P' file that we will
|
||||
# need in order to bootstrap the dependency handling code.
|
||||
# This code is only required when automatic dependency tracking is enabled.
|
||||
# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
|
||||
# order to bootstrap the dependency handling code.
|
||||
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
[AC_CONFIG_COMMANDS([depfiles],
|
||||
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
|
||||
])
|
||||
[AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
|
||||
|
||||
# Do all the work for Automake. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -495,8 +485,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
|
||||
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
|
||||
# For better backward compatibility. To be removed once Automake 1.9.x
|
||||
# dies out for good. For more background, see:
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
|
||||
# We need awk for the "check" target (and possibly the TAP driver). The
|
||||
# system "awk" is bad on some platforms.
|
||||
@ -563,7 +553,7 @@ END
|
||||
Aborting the configuration process, to ensure you take notice of the issue.
|
||||
|
||||
You can download and install GNU coreutils to get an 'rm' implementation
|
||||
that behaves properly: <http://www.gnu.org/software/coreutils/>.
|
||||
that behaves properly: <https://www.gnu.org/software/coreutils/>.
|
||||
|
||||
If you want to complete the configuration process using your problematic
|
||||
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
|
||||
@ -605,7 +595,7 @@ for _am_header in $config_headers :; do
|
||||
done
|
||||
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -626,7 +616,7 @@ if test x"${install_sh+set}" != xset; then
|
||||
fi
|
||||
AC_SUBST([install_sh])])
|
||||
|
||||
# Copyright (C) 2003-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2003-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -647,7 +637,7 @@ AC_SUBST([am__leading_dot])])
|
||||
|
||||
# Check to see how 'make' treats includes. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -655,49 +645,42 @@ AC_SUBST([am__leading_dot])])
|
||||
|
||||
# AM_MAKE_INCLUDE()
|
||||
# -----------------
|
||||
# Check to see how make treats includes.
|
||||
# Check whether make has an 'include' directive that can support all
|
||||
# the idioms we need for our automatic dependency tracking code.
|
||||
AC_DEFUN([AM_MAKE_INCLUDE],
|
||||
[am_make=${MAKE-make}
|
||||
cat > confinc << 'END'
|
||||
[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
|
||||
cat > confinc.mk << 'END'
|
||||
am__doit:
|
||||
@echo this is the am__doit target
|
||||
@echo this is the am__doit target >confinc.out
|
||||
.PHONY: am__doit
|
||||
END
|
||||
# If we don't find an include directive, just comment out the code.
|
||||
AC_MSG_CHECKING([for style of include used by $am_make])
|
||||
am__include="#"
|
||||
am__quote=
|
||||
_am_result=none
|
||||
# First try GNU make style include.
|
||||
echo "include confinc" > confmf
|
||||
# Ignore all kinds of additional output from 'make'.
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=include
|
||||
am__quote=
|
||||
_am_result=GNU
|
||||
;;
|
||||
esac
|
||||
# Now try BSD make style include.
|
||||
if test "$am__include" = "#"; then
|
||||
echo '.include "confinc"' > confmf
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=.include
|
||||
am__quote="\""
|
||||
_am_result=BSD
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
AC_SUBST([am__include])
|
||||
AC_SUBST([am__quote])
|
||||
AC_MSG_RESULT([$_am_result])
|
||||
rm -f confinc confmf
|
||||
])
|
||||
# BSD make does it like this.
|
||||
echo '.include "confinc.mk" # ignored' > confmf.BSD
|
||||
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
|
||||
echo 'include confinc.mk # ignored' > confmf.GNU
|
||||
_am_result=no
|
||||
for s in GNU BSD; do
|
||||
AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
|
||||
AS_CASE([$?:`cat confinc.out 2>/dev/null`],
|
||||
['0:this is the am__doit target'],
|
||||
[AS_CASE([$s],
|
||||
[BSD], [am__include='.include' am__quote='"'],
|
||||
[am__include='include' am__quote=''])])
|
||||
if test "$am__include" != "#"; then
|
||||
_am_result="yes ($s style)"
|
||||
break
|
||||
fi
|
||||
done
|
||||
rm -f confinc.* confmf.*
|
||||
AC_MSG_RESULT([${_am_result}])
|
||||
AC_SUBST([am__include])])
|
||||
AC_SUBST([am__quote])])
|
||||
|
||||
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -736,7 +719,7 @@ fi
|
||||
|
||||
# Helper functions for option handling. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -765,7 +748,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
|
||||
AC_DEFUN([_AM_IF_OPTION],
|
||||
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -812,7 +795,7 @@ AC_LANG_POP([C])])
|
||||
# For backward compatibility.
|
||||
AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -845,10 +828,12 @@ AC_DEFUN([AM_PATH_PYTHON],
|
||||
[
|
||||
dnl Find a Python interpreter. Python versions prior to 2.0 are not
|
||||
dnl supported. (2.0 was released on October 16, 2000).
|
||||
dnl FIXME: Remove the need to hard-code Python versions here.
|
||||
m4_define_default([_AM_PYTHON_INTERPRETER_LIST],
|
||||
[python python2 python3 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 dnl
|
||||
python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0])
|
||||
[python python2 python3 dnl
|
||||
python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 dnl
|
||||
python3.2 python3.1 python3.0 dnl
|
||||
python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 dnl
|
||||
python2.0])
|
||||
|
||||
AC_ARG_VAR([PYTHON], [the Python interpreter])
|
||||
|
||||
@ -1048,7 +1033,7 @@ for i in list(range(0, 4)): minverhex = (minverhex << 8) + minver[[i]]
|
||||
sys.exit(sys.hexversion < minverhex)"
|
||||
AS_IF([AM_RUN_LOG([$1 -c "$prog"])], [$3], [$4])])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1067,7 +1052,7 @@ AC_DEFUN([AM_RUN_LOG],
|
||||
|
||||
# Check to make sure that the build environment is sane. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1148,7 +1133,7 @@ AC_CONFIG_COMMANDS_PRE(
|
||||
rm -f conftest.file
|
||||
])
|
||||
|
||||
# Copyright (C) 2009-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2009-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1208,7 +1193,7 @@ AC_SUBST([AM_BACKSLASH])dnl
|
||||
_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
|
||||
])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1236,7 +1221,7 @@ fi
|
||||
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
|
||||
AC_SUBST([INSTALL_STRIP_PROGRAM])])
|
||||
|
||||
# Copyright (C) 2006-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2006-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1255,7 +1240,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
|
||||
|
||||
# Check how to create a tarball. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2004-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2004-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
|
19
polly/lib/External/isl/check_single_reference_templ.c
vendored
Normal file
19
polly/lib/External/isl/check_single_reference_templ.c
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
|
||||
#define FN(TYPE,NAME) xFN(TYPE,NAME)
|
||||
|
||||
/* Check that "obj" has a single reference.
|
||||
* That is, check that "obj" can be changed inplace.
|
||||
*/
|
||||
isl_stat FN(TYPE,check_single_reference)(__isl_keep TYPE *obj)
|
||||
{
|
||||
isl_bool single;
|
||||
|
||||
single = FN(TYPE,has_single_reference)(obj);
|
||||
if (single < 0)
|
||||
return isl_stat_error;
|
||||
if (!single)
|
||||
isl_die(FN(TYPE,get_ctx)(obj), isl_error_invalid,
|
||||
"object should have a single reference",
|
||||
return isl_stat_error);
|
||||
return isl_stat_ok;
|
||||
}
|
13
polly/lib/External/isl/compile
vendored
13
polly/lib/External/isl/compile
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# Wrapper for compilers which do not understand '-c -o'.
|
||||
|
||||
scriptversion=2012-10-14.11; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1999-2014 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
# Written by Tom Tromey <tromey@cygnus.com>.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
@ -17,7 +17,7 @@ scriptversion=2012-10-14.11; # UTC
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -255,7 +255,8 @@ EOF
|
||||
echo "compile $scriptversion"
|
||||
exit $?
|
||||
;;
|
||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
|
||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
|
||||
icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
|
||||
func_cl_wrapper "$@" # Doesn't return...
|
||||
;;
|
||||
esac
|
||||
@ -339,9 +340,9 @@ exit $ret
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
246
polly/lib/External/isl/configure
vendored
246
polly/lib/External/isl/configure
vendored
@ -1,6 +1,6 @@
|
||||
#! /bin/sh
|
||||
# Guess values for system-dependent variables and create Makefiles.
|
||||
# Generated by GNU Autoconf 2.69 for isl 0.22.1.
|
||||
# Generated by GNU Autoconf 2.69 for isl 0.23.
|
||||
#
|
||||
# Report bugs to <isl-development@googlegroups.com>.
|
||||
#
|
||||
@ -590,8 +590,8 @@ MAKEFLAGS=
|
||||
# Identity of this package.
|
||||
PACKAGE_NAME='isl'
|
||||
PACKAGE_TARNAME='isl'
|
||||
PACKAGE_VERSION='0.22.1'
|
||||
PACKAGE_STRING='isl 0.22.1'
|
||||
PACKAGE_VERSION='0.23'
|
||||
PACKAGE_STRING='isl 0.23'
|
||||
PACKAGE_BUGREPORT='isl-development@googlegroups.com'
|
||||
PACKAGE_URL=''
|
||||
|
||||
@ -734,7 +734,6 @@ am__nodep
|
||||
AMDEPBACKSLASH
|
||||
AMDEP_FALSE
|
||||
AMDEP_TRUE
|
||||
am__quote
|
||||
am__include
|
||||
DEPDIR
|
||||
OBJEXT
|
||||
@ -810,7 +809,8 @@ PACKAGE_VERSION
|
||||
PACKAGE_TARNAME
|
||||
PACKAGE_NAME
|
||||
PATH_SEPARATOR
|
||||
SHELL'
|
||||
SHELL
|
||||
am__quote'
|
||||
ac_subst_files=''
|
||||
ac_user_opts='
|
||||
enable_option_checking
|
||||
@ -1400,7 +1400,7 @@ if test "$ac_init_help" = "long"; then
|
||||
# Omit some internal or obsolete options to make the list less imposing.
|
||||
# This message is too long to be a string in the A/UX 3.1 sh.
|
||||
cat <<_ACEOF
|
||||
\`configure' configures isl 0.22.1 to adapt to many kinds of systems.
|
||||
\`configure' configures isl 0.23 to adapt to many kinds of systems.
|
||||
|
||||
Usage: $0 [OPTION]... [VAR=VALUE]...
|
||||
|
||||
@ -1471,7 +1471,7 @@ fi
|
||||
|
||||
if test -n "$ac_init_help"; then
|
||||
case $ac_init_help in
|
||||
short | recursive ) echo "Configuration of isl 0.22.1:";;
|
||||
short | recursive ) echo "Configuration of isl 0.23:";;
|
||||
esac
|
||||
cat <<\_ACEOF
|
||||
|
||||
@ -1602,7 +1602,7 @@ fi
|
||||
test -n "$ac_init_help" && exit $ac_status
|
||||
if $ac_init_version; then
|
||||
cat <<\_ACEOF
|
||||
isl configure 0.22.1
|
||||
isl configure 0.23
|
||||
generated by GNU Autoconf 2.69
|
||||
|
||||
Copyright (C) 2012 Free Software Foundation, Inc.
|
||||
@ -2375,7 +2375,7 @@ cat >config.log <<_ACEOF
|
||||
This file contains any messages produced by compilers while
|
||||
running configure, to aid debugging if configure makes a mistake.
|
||||
|
||||
It was created by isl $as_me 0.22.1, which was
|
||||
It was created by isl $as_me 0.23, which was
|
||||
generated by GNU Autoconf 2.69. Invocation command line was
|
||||
|
||||
$ $0 $@
|
||||
@ -2753,7 +2753,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
|
||||
|
||||
|
||||
|
||||
am__api_version='1.15'
|
||||
am__api_version='1.16'
|
||||
|
||||
# Find a good install program. We prefer a C program (faster),
|
||||
# so one script is as good as another. But avoid the broken or
|
||||
@ -3239,7 +3239,7 @@ fi
|
||||
|
||||
# Define the identity of the package.
|
||||
PACKAGE='isl'
|
||||
VERSION='0.22.1'
|
||||
VERSION='0.23'
|
||||
|
||||
|
||||
cat >>confdefs.h <<_ACEOF
|
||||
@ -3269,8 +3269,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
|
||||
|
||||
# For better backward compatibility. To be removed once Automake 1.9.x
|
||||
# dies out for good. For more background, see:
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
mkdir_p='$(MKDIR_P)'
|
||||
|
||||
# We need awk for the "check" target (and possibly the TAP driver). The
|
||||
@ -3321,7 +3321,7 @@ END
|
||||
Aborting the configuration process, to ensure you take notice of the issue.
|
||||
|
||||
You can download and install GNU coreutils to get an 'rm' implementation
|
||||
that behaves properly: <http://www.gnu.org/software/coreutils/>.
|
||||
that behaves properly: <https://www.gnu.org/software/coreutils/>.
|
||||
|
||||
If you want to complete the configuration process using your problematic
|
||||
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
|
||||
@ -3372,7 +3372,7 @@ fi
|
||||
AM_BACKSLASH='\'
|
||||
|
||||
|
||||
versioninfo=22:1:0
|
||||
versioninfo=23:0:0
|
||||
|
||||
if test "x$prefix" != "xNONE"; then
|
||||
prefix_wd=`cd $prefix && pwd`
|
||||
@ -4237,45 +4237,45 @@ DEPDIR="${am__leading_dot}deps"
|
||||
|
||||
ac_config_commands="$ac_config_commands depfiles"
|
||||
|
||||
|
||||
am_make=${MAKE-make}
|
||||
cat > confinc << 'END'
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
|
||||
$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
|
||||
cat > confinc.mk << 'END'
|
||||
am__doit:
|
||||
@echo this is the am__doit target
|
||||
@echo this is the am__doit target >confinc.out
|
||||
.PHONY: am__doit
|
||||
END
|
||||
# If we don't find an include directive, just comment out the code.
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
|
||||
$as_echo_n "checking for style of include used by $am_make... " >&6; }
|
||||
am__include="#"
|
||||
am__quote=
|
||||
_am_result=none
|
||||
# First try GNU make style include.
|
||||
echo "include confinc" > confmf
|
||||
# Ignore all kinds of additional output from 'make'.
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=include
|
||||
am__quote=
|
||||
_am_result=GNU
|
||||
;;
|
||||
esac
|
||||
# Now try BSD make style include.
|
||||
if test "$am__include" = "#"; then
|
||||
echo '.include "confinc"' > confmf
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=.include
|
||||
am__quote="\""
|
||||
_am_result=BSD
|
||||
# BSD make does it like this.
|
||||
echo '.include "confinc.mk" # ignored' > confmf.BSD
|
||||
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
|
||||
echo 'include confinc.mk # ignored' > confmf.GNU
|
||||
_am_result=no
|
||||
for s in GNU BSD; do
|
||||
{ echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
|
||||
(${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
|
||||
ac_status=$?
|
||||
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||
(exit $ac_status); }
|
||||
case $?:`cat confinc.out 2>/dev/null` in #(
|
||||
'0:this is the am__doit target') :
|
||||
case $s in #(
|
||||
BSD) :
|
||||
am__include='.include' am__quote='"' ;; #(
|
||||
*) :
|
||||
am__include='include' am__quote='' ;;
|
||||
esac ;; #(
|
||||
*) :
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
|
||||
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
|
||||
$as_echo "$_am_result" >&6; }
|
||||
rm -f confinc confmf
|
||||
esac
|
||||
if test "$am__include" != "#"; then
|
||||
_am_result="yes ($s style)"
|
||||
break
|
||||
fi
|
||||
done
|
||||
rm -f confinc.* confmf.*
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
|
||||
$as_echo "${_am_result}" >&6; }
|
||||
|
||||
# Check whether --enable-dependency-tracking was given.
|
||||
if test "${enable_dependency_tracking+set}" = set; then :
|
||||
@ -9767,7 +9767,7 @@ esac
|
||||
fi
|
||||
|
||||
: ${AR=ar}
|
||||
: ${AR_FLAGS=cru}
|
||||
: ${AR_FLAGS=cr}
|
||||
|
||||
|
||||
|
||||
@ -10268,11 +10268,8 @@ _LT_EOF
|
||||
test $ac_status = 0; }; then
|
||||
# Now try to grab the symbols.
|
||||
nlist=conftest.nm
|
||||
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5
|
||||
(eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5
|
||||
ac_status=$?
|
||||
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
|
||||
test $ac_status = 0; } && test -s "$nlist"; then
|
||||
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&5
|
||||
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&5 && test -s "$nlist"; then
|
||||
# Try sorting and uniquifying the output.
|
||||
if sort "$nlist" | uniq > "$nlist"T; then
|
||||
mv -f "$nlist"T "$nlist"
|
||||
@ -11491,8 +11488,8 @@ int forced_loaded() { return 2;}
|
||||
_LT_EOF
|
||||
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5
|
||||
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5
|
||||
echo "$AR cru libconftest.a conftest.o" >&5
|
||||
$AR cru libconftest.a conftest.o 2>&5
|
||||
echo "$AR cr libconftest.a conftest.o" >&5
|
||||
$AR cr libconftest.a conftest.o 2>&5
|
||||
echo "$RANLIB libconftest.a" >&5
|
||||
$RANLIB libconftest.a 2>&5
|
||||
cat > conftest.c << _LT_EOF
|
||||
@ -12494,6 +12491,12 @@ lt_prog_compiler_static=
|
||||
lt_prog_compiler_pic='-KPIC'
|
||||
lt_prog_compiler_static='-static'
|
||||
;;
|
||||
# flang / f18. f95 an alias for gfortran or flang on Debian
|
||||
flang* | f18* | f95*)
|
||||
lt_prog_compiler_wl='-Wl,'
|
||||
lt_prog_compiler_pic='-fPIC'
|
||||
lt_prog_compiler_static='-static'
|
||||
;;
|
||||
# icc used to be incompatible with GCC.
|
||||
# ICC 10 doesn't accept -KPIC any more.
|
||||
icc* | ifort*)
|
||||
@ -16436,7 +16439,7 @@ with_gnu_ld=$lt_cv_prog_gnu_ld
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
GXX=no
|
||||
@ -16928,7 +16931,7 @@ fi
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -16993,7 +16996,7 @@ fi
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -17332,7 +17335,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
# FIXME: insert proper C++ library support
|
||||
@ -17416,7 +17419,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
else
|
||||
# g++ 2.7 appears to require '-G' NOT '-shared' on this
|
||||
# platform.
|
||||
@ -17427,7 +17430,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
fi
|
||||
|
||||
hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir'
|
||||
@ -19482,7 +19485,7 @@ if ${am_cv_pathless_PYTHON+:} false; then :
|
||||
$as_echo_n "(cached) " >&6
|
||||
else
|
||||
|
||||
for am_cv_pathless_PYTHON in python python2 python3 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0 none; do
|
||||
for am_cv_pathless_PYTHON in python python2 python3 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2.7 python2.6 python2.5 python2.4 python2.3 python2.2 python2.1 python2.0 none; do
|
||||
test "$am_cv_pathless_PYTHON" = none && break
|
||||
prog="import sys
|
||||
# split strings by '.' and convert to numeric. Append some zeros
|
||||
@ -21762,7 +21765,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
|
||||
# report actual input values of CONFIG_FILES etc. instead of their
|
||||
# values after options handling.
|
||||
ac_log="
|
||||
This file was extended by isl $as_me 0.22.1, which was
|
||||
This file was extended by isl $as_me 0.23, which was
|
||||
generated by GNU Autoconf 2.69. Invocation command line was
|
||||
|
||||
CONFIG_FILES = $CONFIG_FILES
|
||||
@ -21828,7 +21831,7 @@ _ACEOF
|
||||
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
|
||||
ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"
|
||||
ac_cs_version="\\
|
||||
isl config.status 0.22.1
|
||||
isl config.status 0.23
|
||||
configured by $0, generated by GNU Autoconf 2.69,
|
||||
with options \\"\$ac_cs_config\\"
|
||||
|
||||
@ -21947,7 +21950,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
|
||||
#
|
||||
# INIT-COMMANDS
|
||||
#
|
||||
AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
|
||||
AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
|
||||
|
||||
|
||||
# The HP-UX ksh and POSIX shell print the target directory to stdout
|
||||
@ -22990,29 +22993,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}
|
||||
# Older Autoconf quotes --file arguments for eval, but not when files
|
||||
# are listed without --file. Let's play safe and only enable the eval
|
||||
# if we detect the quoting.
|
||||
case $CONFIG_FILES in
|
||||
*\'*) eval set x "$CONFIG_FILES" ;;
|
||||
*) set x $CONFIG_FILES ;;
|
||||
esac
|
||||
# TODO: see whether this extra hack can be removed once we start
|
||||
# requiring Autoconf 2.70 or later.
|
||||
case $CONFIG_FILES in #(
|
||||
*\'*) :
|
||||
eval set x "$CONFIG_FILES" ;; #(
|
||||
*) :
|
||||
set x $CONFIG_FILES ;; #(
|
||||
*) :
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
for mf
|
||||
# Used to flag and report bootstrapping failures.
|
||||
am_rc=0
|
||||
for am_mf
|
||||
do
|
||||
# Strip MF so we end up with the name of the file.
|
||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile or not.
|
||||
# We used to match only the files named 'Makefile.in', but
|
||||
# some people rename them; so instead we look at the file content.
|
||||
# Grep'ing the first line is not enough: some people post-process
|
||||
# each Makefile.in and add a new line on top of each file to say so.
|
||||
# Grep'ing the whole file is not good either: AIX grep has a line
|
||||
am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile which includes
|
||||
# dependency-tracking related rules and includes.
|
||||
# Grep'ing the whole file directly is not great: AIX grep has a line
|
||||
# limit of 2048, but all sed's we know have understand at least 4000.
|
||||
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
||||
dirpart=`$as_dirname -- "$mf" ||
|
||||
$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$mf" : 'X\(//\)[^/]' \| \
|
||||
X"$mf" : 'X\(//\)$' \| \
|
||||
X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$mf" |
|
||||
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|
||||
|| continue
|
||||
am_dirpart=`$as_dirname -- "$am_mf" ||
|
||||
$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$am_mf" : 'X\(//\)[^/]' \| \
|
||||
X"$am_mf" : 'X\(//\)$' \| \
|
||||
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$am_mf" |
|
||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
||||
s//\1/
|
||||
q
|
||||
@ -23030,53 +23039,48 @@ $as_echo X"$mf" |
|
||||
q
|
||||
}
|
||||
s/.*/./; q'`
|
||||
else
|
||||
continue
|
||||
fi
|
||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
||||
# from the Makefile without running 'make'.
|
||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
||||
test -z "$DEPDIR" && continue
|
||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
||||
test -z "$am__include" && continue
|
||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
||||
# Find all dependency output files, they are included files with
|
||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
||||
# expansion.
|
||||
for file in `sed -n "
|
||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
|
||||
# Make sure the directory exists.
|
||||
test -f "$dirpart/$file" && continue
|
||||
fdir=`$as_dirname -- "$file" ||
|
||||
$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$file" : 'X\(//\)[^/]' \| \
|
||||
X"$file" : 'X\(//\)$' \| \
|
||||
X"$file" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$file" |
|
||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
||||
am_filepart=`$as_basename -- "$am_mf" ||
|
||||
$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
|
||||
X"$am_mf" : 'X\(//\)$' \| \
|
||||
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X/"$am_mf" |
|
||||
sed '/^.*\/\([^/][^/]*\)\/*$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\/\)[^/].*/{
|
||||
/^X\/\(\/\/\)$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\/\)$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\).*/{
|
||||
/^X\/\(\/\).*/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
s/.*/./; q'`
|
||||
as_dir=$dirpart/$fdir; as_fn_mkdir_p
|
||||
# echo "creating $dirpart/$file"
|
||||
echo '# dummy' > "$dirpart/$file"
|
||||
done
|
||||
{ echo "$as_me:$LINENO: cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles" >&5
|
||||
(cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles) >&5 2>&5
|
||||
ac_status=$?
|
||||
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||
(exit $ac_status); } || am_rc=$?
|
||||
done
|
||||
if test $am_rc -ne 0; then
|
||||
{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
|
||||
$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
|
||||
as_fn_error $? "Something went wrong bootstrapping makefile fragments
|
||||
for automatic dependency tracking. Try re-running configure with the
|
||||
'--disable-dependency-tracking' option to at least be able to build
|
||||
the package (albeit without support for automatic dependency tracking).
|
||||
See \`config.log' for more details" "$LINENO" 5; }
|
||||
fi
|
||||
{ am_dirpart=; unset am_dirpart;}
|
||||
{ am_filepart=; unset am_filepart;}
|
||||
{ am_mf=; unset am_mf;}
|
||||
{ am_rc=; unset am_rc;}
|
||||
rm -f conftest-deps.mk
|
||||
}
|
||||
;;
|
||||
"libtool":C)
|
||||
|
4
polly/lib/External/isl/configure.ac
vendored
4
polly/lib/External/isl/configure.ac
vendored
@ -1,10 +1,10 @@
|
||||
AC_INIT([isl], [0.22.1], [isl-development@googlegroups.com])
|
||||
AC_INIT([isl], [0.23], [isl-development@googlegroups.com])
|
||||
AC_CONFIG_AUX_DIR([.])
|
||||
AC_CONFIG_MACRO_DIR([m4])
|
||||
AM_INIT_AUTOMAKE([foreign])
|
||||
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
|
||||
AC_SUBST(versioninfo)
|
||||
versioninfo=22:1:0
|
||||
versioninfo=23:0:0
|
||||
|
||||
if test "x$prefix" != "xNONE"; then
|
||||
prefix_wd=`cd $prefix && pwd`
|
||||
|
8
polly/lib/External/isl/depcomp
vendored
8
polly/lib/External/isl/depcomp
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# depcomp - compile a program generating dependencies as side-effects
|
||||
|
||||
scriptversion=2016-01-11.22; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -783,7 +783,7 @@ exit 0
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
|
13
polly/lib/External/isl/doc/Makefile.in
vendored
13
polly/lib/External/isl/doc/Makefile.in
vendored
@ -1,7 +1,7 @@
|
||||
# Makefile.in generated by automake 1.15.1 from Makefile.am.
|
||||
# Makefile.in generated by automake 1.16.1 from Makefile.am.
|
||||
# @configure_input@
|
||||
|
||||
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This Makefile.in is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -330,8 +330,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||
*config.status*) \
|
||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
|
||||
*) \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \
|
||||
esac;
|
||||
|
||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||
@ -355,7 +355,10 @@ ctags CTAGS:
|
||||
cscope cscopelist:
|
||||
|
||||
|
||||
distdir: $(DISTFILES)
|
||||
distdir: $(BUILT_SOURCES)
|
||||
$(MAKE) $(AM_MAKEFLAGS) distdir-am
|
||||
|
||||
distdir-am: $(DISTFILES)
|
||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
list='$(DISTFILES)'; \
|
||||
|
62
polly/lib/External/isl/doc/user.pod
vendored
62
polly/lib/External/isl/doc/user.pod
vendored
@ -2725,6 +2725,8 @@ a specified dimension on a given domain can be created using
|
||||
__isl_give isl_aff *isl_aff_var_on_domain(
|
||||
__isl_take isl_local_space *ls,
|
||||
enum isl_dim_type type, unsigned pos);
|
||||
__isl_give isl_aff *isl_aff_nan_on_domain_space(
|
||||
__isl_take isl_space *space);
|
||||
__isl_give isl_aff *isl_aff_nan_on_domain(
|
||||
__isl_take isl_local_space *ls);
|
||||
|
||||
@ -3417,10 +3419,15 @@ then create a piecewise expression over a universe domain.
|
||||
__isl_give isl_pw_aff *isl_pw_aff_var_on_domain(
|
||||
__isl_take isl_local_space *ls,
|
||||
enum isl_dim_type type, unsigned pos);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
|
||||
__isl_take isl_space *space);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain(
|
||||
__isl_take isl_local_space *ls);
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_zero(
|
||||
__isl_take isl_space *space);
|
||||
__isl_give isl_pw_multi_aff *
|
||||
isl_pw_multi_aff_identity_on_domain_space(
|
||||
__isl_take isl_space *space)
|
||||
__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_domain_map(
|
||||
@ -4019,6 +4026,10 @@ Objects can be read from input using the following functions.
|
||||
isl_union_pw_qpolynomial_read_from_str(
|
||||
isl_ctx *ctx, const char *str);
|
||||
|
||||
__isl_give isl_pw_qpolynomial_fold *
|
||||
isl_pw_qpolynomial_fold_read_from_str(
|
||||
isl_ctx *ctx, const char *str);
|
||||
|
||||
For sets and relations,
|
||||
the input format is autodetected and may be either the C<PolyLib> format
|
||||
or the C<isl> format.
|
||||
@ -5595,12 +5606,6 @@ dimension has the fixed given value.
|
||||
__isl_take isl_map *map,
|
||||
enum isl_dim_type type, unsigned pos,
|
||||
__isl_take isl_val *value);
|
||||
__isl_give isl_map *isl_map_lower_bound_multi_val(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *lower);
|
||||
__isl_give isl_map *isl_map_upper_bound_multi_val(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *upper);
|
||||
__isl_give isl_map *isl_map_lower_bound_multi_pw_aff(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_multi_pw_aff *lower);
|
||||
@ -5614,6 +5619,9 @@ symbolic constant expression.
|
||||
For functions taking a multi expression,
|
||||
this applies to all set dimensions.
|
||||
Those that bound a map, bound the range of that map.
|
||||
If the multi expression is zero-dimensional but has an explicit domain,
|
||||
then the (parameter) domain of the set or map is intersected
|
||||
with this explicit domain.
|
||||
|
||||
__isl_give isl_set *isl_set_equate(__isl_take isl_set *set,
|
||||
enum isl_dim_type type1, int pos1,
|
||||
@ -5775,6 +5783,16 @@ between image elements and corresponding domain elements in the input.
|
||||
The functions above construct a (basic, regular or union) relation
|
||||
that maps (a wrapped version of) the input relation to its delta set.
|
||||
|
||||
=item * Translation
|
||||
|
||||
#include <isl/map.h>
|
||||
__isl_give isl_map *isl_set_translation(
|
||||
__isl_take isl_set *deltas);
|
||||
|
||||
This function performs essentially the opposite operation
|
||||
of C<isl_map_deltas>. In particular, it returns pairs
|
||||
of elements in the same space that have a difference in C<deltas>.
|
||||
|
||||
=item * Coalescing
|
||||
|
||||
Simplify the representation of a set, relation or functions by trying
|
||||
@ -6959,6 +6977,10 @@ the same (number of) parameters.
|
||||
__isl_take isl_map *map1,
|
||||
__isl_take isl_map *map2);
|
||||
__isl_give isl_map *
|
||||
isl_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_map *factor);
|
||||
__isl_give isl_map *
|
||||
isl_map_intersect_domain_factor_range(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_map *factor);
|
||||
@ -7009,6 +7031,10 @@ the same (number of) parameters.
|
||||
__isl_take isl_union_map *umap1,
|
||||
__isl_take isl_union_map *umap2);
|
||||
__isl_give isl_union_map *
|
||||
isl_union_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_union_map *factor);
|
||||
__isl_give isl_union_map *
|
||||
isl_union_map_intersect_domain_factor_range(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_union_map *factor);
|
||||
@ -7539,9 +7565,19 @@ piecewise quasipolynomial reduction.
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_union_pw_multi_aff *upma);
|
||||
|
||||
#include <isl/aff.h>
|
||||
__isl_give isl_pw_multi_aff *
|
||||
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
|
||||
__isl_take isl_pw_multi_aff *pma1,
|
||||
__isl_take isl_pw_multi_aff *pma2);
|
||||
__isl_give isl_union_pw_multi_aff *
|
||||
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
|
||||
__isl_take isl_union_pw_multi_aff *upma1,
|
||||
__isl_take isl_union_pw_multi_aff *upma2);
|
||||
|
||||
These functions compute the preimage of the given set or map domain/range under
|
||||
the given function. In other words, the expression is plugged
|
||||
into the set description or into the domain/range of the map.
|
||||
into the set description or into the domain/range of the map or function.
|
||||
|
||||
=item * Pullback
|
||||
|
||||
@ -7765,12 +7801,20 @@ where the function values satisfy the given relation.
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *
|
||||
isl_union_map_lex_le_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *
|
||||
isl_union_map_lex_gt_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *
|
||||
isl_union_map_lex_ge_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
|
||||
These functions select the subset of elements in the union map
|
||||
that have an equal or lexicographically smaller function value.
|
||||
that have an equal or lexicographically smaller or greater function value.
|
||||
|
||||
=item * Cartesian Product
|
||||
|
||||
@ -8886,7 +8930,7 @@ Lists are defined over several element types, including
|
||||
C<isl_val>, C<isl_id>, C<isl_aff>, C<isl_pw_aff>, C<isl_pw_multi_aff>,
|
||||
C<isl_union_pw_aff>,
|
||||
C<isl_union_pw_multi_aff>,
|
||||
C<isl_pw_qpolynomial>, C<isl_pw_qpolynomial_fold>,
|
||||
C<isl_qpolynomial>, C<isl_pw_qpolynomial>, C<isl_pw_qpolynomial_fold>,
|
||||
C<isl_constraint>,
|
||||
C<isl_basic_set>, C<isl_set>, C<isl_basic_map>, C<isl_map>, C<isl_union_set>,
|
||||
C<isl_union_map>, C<isl_ast_expr> and C<isl_ast_node>.
|
||||
|
252
polly/lib/External/isl/imath/gmp_compat.c
vendored
252
polly/lib/External/isl/imath/gmp_compat.c
vendored
@ -24,18 +24,20 @@
|
||||
SOFTWARE.
|
||||
*/
|
||||
#include "gmp_compat.h"
|
||||
#include <stdlib.h>
|
||||
#include <assert.h>
|
||||
#include <ctype.h>
|
||||
#include <string.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#if defined(_MSC_VER)
|
||||
#include <BaseTsd.h>
|
||||
typedef SSIZE_T ssize_t;
|
||||
#else
|
||||
#include <sys/types.h>
|
||||
#endif
|
||||
|
||||
#ifdef NDEBUG
|
||||
#ifdef NDEBUG
|
||||
#define CHECK(res) (res)
|
||||
#else
|
||||
#define CHECK(res) assert(((res) == MP_OK) && "expected MP_OK")
|
||||
@ -53,34 +55,24 @@ static const uint16_t endian_test = 0x1FF;
|
||||
*
|
||||
*************************************************************************/
|
||||
/* gmp: mpq_clear */
|
||||
void GMPQAPI(clear)(mp_rat x) {
|
||||
mp_rat_clear(x);
|
||||
}
|
||||
void GMPQAPI(clear)(mp_rat x) { mp_rat_clear(x); }
|
||||
|
||||
/* gmp: mpq_cmp */
|
||||
int GMPQAPI(cmp)(mp_rat op1, mp_rat op2) {
|
||||
return mp_rat_compare(op1, op2);
|
||||
}
|
||||
int GMPQAPI(cmp)(mp_rat op1, mp_rat op2) { return mp_rat_compare(op1, op2); }
|
||||
|
||||
/* gmp: mpq_init */
|
||||
void GMPQAPI(init)(mp_rat x) {
|
||||
CHECK(mp_rat_init(x));
|
||||
}
|
||||
void GMPQAPI(init)(mp_rat x) { CHECK(mp_rat_init(x)); }
|
||||
|
||||
/* gmp: mpq_mul */
|
||||
void GMPQAPI(mul)(mp_rat product, mp_rat multiplier, mp_rat multiplicand) {
|
||||
CHECK(mp_rat_mul(multiplier, multiplicand, product));
|
||||
}
|
||||
|
||||
/* gmp: mpq_set*/
|
||||
void GMPQAPI(set)(mp_rat rop, mp_rat op) {
|
||||
CHECK(mp_rat_copy(op, rop));
|
||||
}
|
||||
/* gmp: mpq_set */
|
||||
void GMPQAPI(set)(mp_rat rop, mp_rat op) { CHECK(mp_rat_copy(op, rop)); }
|
||||
|
||||
/* gmp: mpz_abs */
|
||||
void GMPZAPI(abs)(mp_int rop, mp_int op) {
|
||||
CHECK(mp_int_abs(op, rop));
|
||||
}
|
||||
void GMPZAPI(abs)(mp_int rop, mp_int op) { CHECK(mp_int_abs(op, rop)); }
|
||||
|
||||
/* gmp: mpz_add */
|
||||
void GMPZAPI(add)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
@ -88,9 +80,7 @@ void GMPZAPI(add)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_clear */
|
||||
void GMPZAPI(clear)(mp_int x) {
|
||||
mp_int_clear(x);
|
||||
}
|
||||
void GMPZAPI(clear)(mp_int x) { mp_int_clear(x); }
|
||||
|
||||
/* gmp: mpz_cmp_si */
|
||||
int GMPZAPI(cmp_si)(mp_int op1, long op2) {
|
||||
@ -103,14 +93,10 @@ int GMPZAPI(cmpabs)(mp_int op1, mp_int op2) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_cmp */
|
||||
int GMPZAPI(cmp)(mp_int op1, mp_int op2) {
|
||||
return mp_int_compare(op1, op2);
|
||||
}
|
||||
int GMPZAPI(cmp)(mp_int op1, mp_int op2) { return mp_int_compare(op1, op2); }
|
||||
|
||||
/* gmp: mpz_init */
|
||||
void GMPZAPI(init)(mp_int x) {
|
||||
CHECK(mp_int_init(x));
|
||||
}
|
||||
void GMPZAPI(init)(mp_int x) { CHECK(mp_int_init(x)); }
|
||||
|
||||
/* gmp: mpz_mul */
|
||||
void GMPZAPI(mul)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
@ -118,19 +104,13 @@ void GMPZAPI(mul)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_neg */
|
||||
void GMPZAPI(neg)(mp_int rop, mp_int op) {
|
||||
CHECK(mp_int_neg(op, rop));
|
||||
}
|
||||
void GMPZAPI(neg)(mp_int rop, mp_int op) { CHECK(mp_int_neg(op, rop)); }
|
||||
|
||||
/* gmp: mpz_set_si */
|
||||
void GMPZAPI(set_si)(mp_int rop, long op) {
|
||||
CHECK(mp_int_set_value(rop, op));
|
||||
}
|
||||
void GMPZAPI(set_si)(mp_int rop, long op) { CHECK(mp_int_set_value(rop, op)); }
|
||||
|
||||
/* gmp: mpz_set */
|
||||
void GMPZAPI(set)(mp_int rop, mp_int op) {
|
||||
CHECK(mp_int_copy(op, rop));
|
||||
}
|
||||
void GMPZAPI(set)(mp_int rop, mp_int op) { CHECK(mp_int_copy(op, rop)); }
|
||||
|
||||
/* gmp: mpz_sub */
|
||||
void GMPZAPI(sub)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
@ -138,19 +118,13 @@ void GMPZAPI(sub)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_swap */
|
||||
void GMPZAPI(swap)(mp_int rop1, mp_int rop2) {
|
||||
mp_int_swap(rop1, rop2);
|
||||
}
|
||||
void GMPZAPI(swap)(mp_int rop1, mp_int rop2) { mp_int_swap(rop1, rop2); }
|
||||
|
||||
/* gmp: mpq_sgn */
|
||||
int GMPQAPI(sgn)(mp_rat op) {
|
||||
return mp_rat_compare_zero(op);
|
||||
}
|
||||
int GMPQAPI(sgn)(mp_rat op) { return mp_rat_compare_zero(op); }
|
||||
|
||||
/* gmp: mpz_sgn */
|
||||
int GMPZAPI(sgn)(mp_int op) {
|
||||
return mp_int_compare_zero(op);
|
||||
}
|
||||
int GMPZAPI(sgn)(mp_int op) { return mp_int_compare_zero(op); }
|
||||
|
||||
/* gmp: mpq_set_ui */
|
||||
void GMPQAPI(set_ui)(mp_rat rop, unsigned long op1, unsigned long op2) {
|
||||
@ -163,25 +137,18 @@ void GMPZAPI(set_ui)(mp_int rop, unsigned long op) {
|
||||
}
|
||||
|
||||
/* gmp: mpq_den_ref */
|
||||
mp_int GMPQAPI(denref)(mp_rat op) {
|
||||
return mp_rat_denom_ref(op);
|
||||
}
|
||||
mp_int GMPQAPI(denref)(mp_rat op) { return mp_rat_denom_ref(op); }
|
||||
|
||||
/* gmp: mpq_num_ref */
|
||||
mp_int GMPQAPI(numref)(mp_rat op) {
|
||||
return mp_rat_numer_ref(op);
|
||||
}
|
||||
mp_int GMPQAPI(numref)(mp_rat op) { return mp_rat_numer_ref(op); }
|
||||
|
||||
/* gmp: mpq_canonicalize */
|
||||
void GMPQAPI(canonicalize)(mp_rat op) {
|
||||
CHECK(mp_rat_reduce(op));
|
||||
}
|
||||
void GMPQAPI(canonicalize)(mp_rat op) { CHECK(mp_rat_reduce(op)); }
|
||||
|
||||
/*************************************************************************
|
||||
*
|
||||
/*
|
||||
* Functions that can be implemented as a combination of imath functions
|
||||
*
|
||||
*************************************************************************/
|
||||
*/
|
||||
|
||||
/* gmp: mpz_addmul */
|
||||
/* gmp: rop = rop + (op1 * op2) */
|
||||
void GMPZAPI(addmul)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
@ -212,8 +179,7 @@ int GMPZAPI(divisible_p)(mp_int n, mp_int d) {
|
||||
/* check for d = 0 */
|
||||
int n_is_zero = mp_int_compare_zero(n) == 0;
|
||||
int d_is_zero = mp_int_compare_zero(d) == 0;
|
||||
if (d_is_zero)
|
||||
return n_is_zero;
|
||||
if (d_is_zero) return n_is_zero;
|
||||
|
||||
/* return true if remainder is 0 */
|
||||
CHECK(mp_int_init(r));
|
||||
@ -320,13 +286,12 @@ void GMPZAPI(gcd)(mp_int rop, mp_int op1, mp_int op2) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_get_str */
|
||||
char* GMPZAPI(get_str)(char *str, int radix, mp_int op) {
|
||||
char *GMPZAPI(get_str)(char *str, int radix, mp_int op) {
|
||||
int i, r, len;
|
||||
|
||||
/* Support negative radix like gmp */
|
||||
r = radix;
|
||||
if (r < 0)
|
||||
r = -r;
|
||||
if (r < 0) r = -r;
|
||||
|
||||
/* Compute the length of the string needed to hold the int */
|
||||
len = mp_int_string_len(op, r);
|
||||
@ -338,16 +303,18 @@ char* GMPZAPI(get_str)(char *str, int radix, mp_int op) {
|
||||
CHECK(mp_int_to_string(op, r, str, len));
|
||||
|
||||
/* Change case to match gmp */
|
||||
for (i = 0; i < len - 1; i++)
|
||||
if (radix < 0)
|
||||
for (i = 0; i < len - 1; i++) {
|
||||
if (radix < 0) {
|
||||
str[i] = toupper(str[i]);
|
||||
else
|
||||
} else {
|
||||
str[i] = tolower(str[i]);
|
||||
}
|
||||
}
|
||||
return str;
|
||||
}
|
||||
|
||||
/* gmp: mpq_get_str */
|
||||
char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
|
||||
char *GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
|
||||
int i, r, len;
|
||||
|
||||
/* Only print numerator if it is a whole number */
|
||||
@ -356,8 +323,7 @@ char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
|
||||
|
||||
/* Support negative radix like gmp */
|
||||
r = radix;
|
||||
if (r < 0)
|
||||
r = -r;
|
||||
if (r < 0) r = -r;
|
||||
|
||||
/* Compute the length of the string needed to hold the int */
|
||||
len = mp_rat_string_len(op, r);
|
||||
@ -369,11 +335,13 @@ char* GMPQAPI(get_str)(char *str, int radix, mp_rat op) {
|
||||
CHECK(mp_rat_to_string(op, r, str, len));
|
||||
|
||||
/* Change case to match gmp */
|
||||
for (i = 0; i < len; i++)
|
||||
if (radix < 0)
|
||||
for (i = 0; i < len; i++) {
|
||||
if (radix < 0) {
|
||||
str[i] = toupper(str[i]);
|
||||
else
|
||||
} else {
|
||||
str[i] = tolower(str[i]);
|
||||
}
|
||||
}
|
||||
|
||||
return str;
|
||||
}
|
||||
@ -393,26 +361,27 @@ int GMPQAPI(set_str)(mp_rat rop, char *s, int base) {
|
||||
int res = 0;
|
||||
|
||||
/* Copy string to temporary storage so we can modify it below */
|
||||
str = malloc(strlen(s)+1);
|
||||
str = malloc(strlen(s) + 1);
|
||||
strcpy(str, s);
|
||||
|
||||
/* Properly format the string as an int by terminating at the / */
|
||||
slash = strchr(str, '/');
|
||||
if (slash)
|
||||
*slash = '\0';
|
||||
if (slash) *slash = '\0';
|
||||
|
||||
/* Parse numerator */
|
||||
resN = mp_int_read_string(mp_rat_numer_ref(rop), base, str);
|
||||
|
||||
/* Parse denomenator if given or set to 1 if not */
|
||||
if (slash)
|
||||
resD = mp_int_read_string(mp_rat_denom_ref(rop), base, slash+1);
|
||||
else
|
||||
/* Parse denominator if given or set to 1 if not */
|
||||
if (slash) {
|
||||
resD = mp_int_read_string(mp_rat_denom_ref(rop), base, slash + 1);
|
||||
} else {
|
||||
resD = mp_int_set_uvalue(mp_rat_denom_ref(rop), 1);
|
||||
}
|
||||
|
||||
/* Return failure if either parse failed */
|
||||
if (resN != MP_OK || resD != MP_OK)
|
||||
if (resN != MP_OK || resD != MP_OK) {
|
||||
res = -1;
|
||||
}
|
||||
|
||||
free(str);
|
||||
return res;
|
||||
@ -423,18 +392,24 @@ static unsigned long get_long_bits(mp_int op) {
|
||||
* the least significant digits that will fit into the long. Read the digits
|
||||
* into the long starting at the most significant digit that fits into a
|
||||
* long. The long is shifted over by MP_DIGIT_BIT before each digit is added.
|
||||
* The shift is decomposed into two steps to follow the patten used in the
|
||||
* rest of the imath library. The two step shift is used to accomedate
|
||||
* architectures that don't deal well with 32-bit shifts. */
|
||||
mp_size num_digits_in_long = sizeof(unsigned long) / sizeof(mp_digit);
|
||||
*
|
||||
* The shift is decomposed into two steps (following the pattern used in the
|
||||
* rest of the imath library) to accommodate architectures that don't deal
|
||||
* well with 32-bit shifts.
|
||||
*/
|
||||
mp_size digits_to_copy =
|
||||
(sizeof(unsigned long) + sizeof(mp_digit) - 1) / sizeof(mp_digit);
|
||||
if (digits_to_copy > MP_USED(op)) {
|
||||
digits_to_copy = MP_USED(op);
|
||||
}
|
||||
|
||||
mp_digit *digits = MP_DIGITS(op);
|
||||
unsigned long out = 0;
|
||||
int i;
|
||||
|
||||
for (i = num_digits_in_long - 1; i >= 0; i--) {
|
||||
out <<= (MP_DIGIT_BIT/2);
|
||||
out <<= (MP_DIGIT_BIT/2);
|
||||
out |= digits[i];
|
||||
for (int i = digits_to_copy - 1; i >= 0; i--) {
|
||||
out <<= (MP_DIGIT_BIT / 2);
|
||||
out <<= (MP_DIGIT_BIT / 2);
|
||||
out |= digits[i];
|
||||
}
|
||||
|
||||
return out;
|
||||
@ -446,14 +421,12 @@ unsigned long GMPZAPI(get_ui)(mp_int op) {
|
||||
|
||||
/* Try a standard conversion that fits into an unsigned long */
|
||||
mp_result res = mp_int_to_uint(op, &out);
|
||||
if (res == MP_OK)
|
||||
return out;
|
||||
if (res == MP_OK) return out;
|
||||
|
||||
/* Abort the try if we don't have a range error in the conversion.
|
||||
* The range error indicates that the value cannot fit into a long. */
|
||||
CHECK(res == MP_RANGE ? MP_OK : MP_RANGE);
|
||||
if (res != MP_RANGE)
|
||||
return 0;
|
||||
if (res != MP_RANGE) return 0;
|
||||
|
||||
return get_long_bits(op);
|
||||
}
|
||||
@ -466,14 +439,12 @@ long GMPZAPI(get_si)(mp_int op) {
|
||||
|
||||
/* Try a standard conversion that fits into a long */
|
||||
mp_result res = mp_int_to_int(op, &out);
|
||||
if (res == MP_OK)
|
||||
return out;
|
||||
if (res == MP_OK) return out;
|
||||
|
||||
/* Abort the try if we don't have a range error in the conversion.
|
||||
* The range error indicates that the value cannot fit into a long. */
|
||||
CHECK(res == MP_RANGE ? MP_OK : MP_RANGE);
|
||||
if (res != MP_RANGE)
|
||||
return 0;
|
||||
if (res != MP_RANGE) return 0;
|
||||
|
||||
/* get least significant bits into an unsigned long */
|
||||
uout = get_long_bits(op);
|
||||
@ -483,10 +454,11 @@ long GMPZAPI(get_si)(mp_int op) {
|
||||
uout &= (~(1UL << long_msb));
|
||||
|
||||
/* convert to negative if needed based on sign of op */
|
||||
if (MP_SIGN(op) == MP_NEG)
|
||||
if (MP_SIGN(op) == MP_NEG) {
|
||||
uout = 0 - uout;
|
||||
}
|
||||
|
||||
out = (long) uout;
|
||||
out = (long)uout;
|
||||
return out;
|
||||
}
|
||||
|
||||
@ -513,11 +485,9 @@ void GMPZAPI(mul_2exp)(mp_int rop, mp_int op1, unsigned long op2) {
|
||||
CHECK(mp_int_mul_pow2(op1, op2, rop));
|
||||
}
|
||||
|
||||
/*************************************************************************
|
||||
*
|
||||
/*
|
||||
* Functions needing expanded functionality
|
||||
*
|
||||
*************************************************************************/
|
||||
*/
|
||||
/* [Note]Overview of division implementation
|
||||
|
||||
All division operations (N / D) compute q and r such that
|
||||
@ -578,9 +548,8 @@ void GMPZAPI(cdiv_q)(mp_int q, mp_int n, mp_int d) {
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
CHECK(mp_int_add_value(q, 1, q));
|
||||
}
|
||||
}
|
||||
else if (qsign == 0) { /* q == 0 */
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
} else if (qsign == 0) { /* q == 0 */
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
if ((nsign > 0 && dsign > 0) || (nsign < 0 && dsign < 0)) {
|
||||
CHECK(mp_int_set_value(q, 1));
|
||||
}
|
||||
@ -610,9 +579,8 @@ void GMPZAPI(fdiv_q)(mp_int q, mp_int n, mp_int d) {
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
CHECK(mp_int_sub_value(q, 1, q));
|
||||
}
|
||||
}
|
||||
else if (qsign == 0) { /* q == 0 */
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
} else if (qsign == 0) { /* q == 0 */
|
||||
if (rsign != 0) { /* r != 0 */
|
||||
if ((nsign < 0 && dsign > 0) || (nsign > 0 && dsign < 0)) {
|
||||
CHECK(mp_int_set_value(q, -1));
|
||||
}
|
||||
@ -684,31 +652,32 @@ unsigned long GMPZAPI(fdiv_q_ui)(mp_int q, mp_int n, unsigned long d) {
|
||||
}
|
||||
|
||||
/* gmp: mpz_export */
|
||||
void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int endian, size_t nails, mp_int op) {
|
||||
int i, j;
|
||||
int num_used_bytes;
|
||||
void *GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size,
|
||||
int endian, size_t nails, mp_int op) {
|
||||
size_t i, j;
|
||||
size_t num_used_bytes;
|
||||
size_t num_words, num_missing_bytes;
|
||||
ssize_t word_offset;
|
||||
unsigned char* dst;
|
||||
mp_digit* src;
|
||||
unsigned char *dst;
|
||||
mp_digit *src;
|
||||
int src_bits;
|
||||
|
||||
/* We do not have a complete implementation. Assert to ensure our
|
||||
* restrictions are in place. */
|
||||
assert(nails == 0 && "Do not support non-full words");
|
||||
* restrictions are in place.
|
||||
*/
|
||||
assert(nails == 0 && "Do not support non-full words");
|
||||
assert(endian == 1 || endian == 0 || endian == -1);
|
||||
assert(order == 1 || order == -1);
|
||||
|
||||
/* Test for zero */
|
||||
if (mp_int_compare_zero(op) == 0) {
|
||||
if (countp)
|
||||
*countp = 0;
|
||||
if (countp) *countp = 0;
|
||||
return rop;
|
||||
}
|
||||
|
||||
/* Calculate how many words we need */
|
||||
num_used_bytes = mp_int_unsigned_len(op);
|
||||
num_words = (num_used_bytes + (size-1)) / size; /* ceil division */
|
||||
num_used_bytes = mp_int_unsigned_len(op);
|
||||
num_words = (num_used_bytes + (size - 1)) / size; /* ceil division */
|
||||
assert(num_used_bytes > 0);
|
||||
|
||||
/* Check to see if we will have missing bytes in the last word.
|
||||
@ -720,7 +689,7 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
|
||||
pad the word with extra zeros. Otherwise, the missing bytes can be filled
|
||||
directly from the zeros in the last digit in the number.
|
||||
*/
|
||||
num_missing_bytes = (size * num_words) - num_used_bytes;
|
||||
num_missing_bytes = (size * num_words) - num_used_bytes;
|
||||
assert(num_missing_bytes < size);
|
||||
|
||||
/* Allocate space for the result if needed */
|
||||
@ -733,7 +702,8 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
|
||||
}
|
||||
|
||||
/* Initialize dst and src pointers */
|
||||
dst = (unsigned char *) rop + (order >= 0 ? (num_words-1) * size : 0) + (endian >= 0 ? size-1 : 0);
|
||||
dst = (unsigned char *)rop + (order >= 0 ? (num_words - 1) * size : 0) +
|
||||
(endian >= 0 ? size - 1 : 0);
|
||||
src = MP_DIGITS(op);
|
||||
src_bits = MP_DIGIT_BIT;
|
||||
|
||||
@ -756,13 +726,13 @@ void* GMPZAPI(export)(void *rop, size_t *countp, int order, size_t size, int end
|
||||
dst += word_offset;
|
||||
}
|
||||
|
||||
if (countp)
|
||||
*countp = num_words;
|
||||
if (countp) *countp = num_words;
|
||||
return rop;
|
||||
}
|
||||
|
||||
/* gmp: mpz_import */
|
||||
void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endian, size_t nails, const void* op) {
|
||||
void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size,
|
||||
int endian, size_t nails, const void *op) {
|
||||
mpz_t tmpz;
|
||||
mp_int tmp = &tmpz;
|
||||
size_t total_size;
|
||||
@ -771,13 +741,12 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
|
||||
const unsigned char *src;
|
||||
mp_digit *dst;
|
||||
int dst_bits;
|
||||
int i, j;
|
||||
if (count == 0 || op == NULL)
|
||||
return;
|
||||
size_t i, j;
|
||||
if (count == 0 || op == NULL) return;
|
||||
|
||||
/* We do not have a complete implementation. Assert to ensure our
|
||||
* restrictions are in place. */
|
||||
assert(nails == 0 && "Do not support non-full words");
|
||||
assert(nails == 0 && "Do not support non-full words");
|
||||
assert(endian == 1 || endian == 0 || endian == -1);
|
||||
assert(order == 1 || order == -1);
|
||||
|
||||
@ -791,11 +760,11 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
|
||||
|
||||
/* Init temporary */
|
||||
mp_int_init_size(tmp, num_digits);
|
||||
for (i = 0; i < num_digits; i++)
|
||||
tmp->digits[i] = 0;
|
||||
for (i = 0; i < num_digits; i++) tmp->digits[i] = 0;
|
||||
|
||||
/* Copy bytes */
|
||||
src = (const unsigned char *) op + (order >= 0 ? (count-1) * size : 0) + (endian >= 0 ? size-1 : 0);
|
||||
src = (const unsigned char *)op + (order >= 0 ? (count - 1) * size : 0) +
|
||||
(endian >= 0 ? size - 1 : 0);
|
||||
dst = MP_DIGITS(tmp);
|
||||
dst_bits = 0;
|
||||
|
||||
@ -814,15 +783,14 @@ void GMPZAPI(import)(mp_int rop, size_t count, int order, size_t size, int endia
|
||||
src += word_offset;
|
||||
}
|
||||
|
||||
MP_USED(tmp) = num_digits;
|
||||
tmp->used = num_digits;
|
||||
|
||||
/* Remove leading zeros from number */
|
||||
{
|
||||
mp_size uz_ = MP_USED(tmp);
|
||||
mp_digit *dz_ = MP_DIGITS(tmp) + uz_ -1;
|
||||
while (uz_ > 1 && (*dz_-- == 0))
|
||||
--uz_;
|
||||
MP_USED(tmp) = uz_;
|
||||
mp_size uz_ = tmp->used;
|
||||
mp_digit *dz_ = MP_DIGITS(tmp) + uz_ - 1;
|
||||
while (uz_ > 1 && (*dz_-- == 0)) --uz_;
|
||||
tmp->used = uz_;
|
||||
}
|
||||
|
||||
/* Copy to destination */
|
||||
@ -836,8 +804,7 @@ size_t GMPZAPI(sizeinbase)(mp_int op, int base) {
|
||||
size_t size;
|
||||
|
||||
/* If op == 0, return 1 */
|
||||
if (mp_int_compare_zero(op) == 0)
|
||||
return 1;
|
||||
if (mp_int_compare_zero(op) == 0) return 1;
|
||||
|
||||
/* Compute string length in base */
|
||||
res = mp_int_string_len(op, base);
|
||||
@ -850,8 +817,7 @@ size_t GMPZAPI(sizeinbase)(mp_int op, int base) {
|
||||
size -= 1;
|
||||
|
||||
/* subtract one for the negative sign */
|
||||
if (mp_int_compare_zero(op) < 0)
|
||||
size -= 1;
|
||||
if (mp_int_compare_zero(op) < 0) size -= 1;
|
||||
|
||||
return size;
|
||||
}
|
||||
|
2482
polly/lib/External/isl/imath/imath.c
vendored
2482
polly/lib/External/isl/imath/imath.c
vendored
File diff suppressed because it is too large
Load Diff
437
polly/lib/External/isl/imath/imath.h
vendored
437
polly/lib/External/isl/imath/imath.h
vendored
@ -1,7 +1,7 @@
|
||||
/*
|
||||
Name: imath.h
|
||||
Purpose: Arbitrary precision integer arithmetic routines.
|
||||
Author: M. J. Fromberger <http://spinning-yarns.org/michael/>
|
||||
Author: M. J. Fromberger
|
||||
|
||||
Copyright (C) 2002-2007 Michael J. Fromberger, All Rights Reserved.
|
||||
|
||||
@ -27,44 +27,46 @@
|
||||
#ifndef IMATH_H_
|
||||
#define IMATH_H_
|
||||
|
||||
#include <stdint.h>
|
||||
#include <limits.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef unsigned char mp_sign;
|
||||
typedef unsigned int mp_size;
|
||||
typedef int mp_result;
|
||||
typedef long mp_small; /* must be a signed type */
|
||||
typedef unsigned long mp_usmall; /* must be an unsigned type */
|
||||
typedef unsigned char mp_sign;
|
||||
typedef unsigned int mp_size;
|
||||
typedef int mp_result;
|
||||
typedef long mp_small; /* must be a signed type */
|
||||
typedef unsigned long mp_usmall; /* must be an unsigned type */
|
||||
|
||||
/* Force building with uint64_t so that the library builds consistently
|
||||
* whether we build from the makefile or by embedding imath in another project.
|
||||
*/
|
||||
#undef USE_64BIT_WORDS
|
||||
#define USE_64BIT_WORDS
|
||||
#ifdef USE_64BIT_WORDS
|
||||
typedef uint32_t mp_digit;
|
||||
typedef uint64_t mp_word;
|
||||
|
||||
/* Build with words as uint64_t by default. */
|
||||
#ifdef USE_32BIT_WORDS
|
||||
typedef uint16_t mp_digit;
|
||||
typedef uint32_t mp_word;
|
||||
# define MP_DIGIT_MAX (UINT16_MAX * 1UL)
|
||||
# define MP_WORD_MAX (UINT32_MAX * 1UL)
|
||||
#else
|
||||
typedef uint16_t mp_digit;
|
||||
typedef uint32_t mp_word;
|
||||
typedef uint32_t mp_digit;
|
||||
typedef uint64_t mp_word;
|
||||
# define MP_DIGIT_MAX (UINT32_MAX * UINT64_C(1))
|
||||
# define MP_WORD_MAX (UINT64_MAX)
|
||||
#endif
|
||||
|
||||
typedef struct mpz {
|
||||
mp_digit single;
|
||||
mp_digit *digits;
|
||||
mp_size alloc;
|
||||
mp_size used;
|
||||
mp_sign sign;
|
||||
typedef struct {
|
||||
mp_digit single;
|
||||
mp_digit* digits;
|
||||
mp_size alloc;
|
||||
mp_size used;
|
||||
mp_sign sign;
|
||||
} mpz_t, *mp_int;
|
||||
|
||||
#define MP_DIGITS(Z) ((Z)->digits)
|
||||
#define MP_ALLOC(Z) ((Z)->alloc)
|
||||
#define MP_USED(Z) ((Z)->used)
|
||||
#define MP_SIGN(Z) ((Z)->sign)
|
||||
static inline mp_digit* MP_DIGITS(mp_int Z) { return Z->digits; }
|
||||
static inline mp_size MP_ALLOC(mp_int Z) { return Z->alloc; }
|
||||
static inline mp_size MP_USED(mp_int Z) { return Z->used; }
|
||||
static inline mp_sign MP_SIGN(mp_int Z) { return Z->sign; }
|
||||
|
||||
extern const mp_result MP_OK;
|
||||
extern const mp_result MP_FALSE;
|
||||
@ -76,156 +78,343 @@ extern const mp_result MP_TRUNC;
|
||||
extern const mp_result MP_BADARG;
|
||||
extern const mp_result MP_MINERR;
|
||||
|
||||
#define MP_DIGIT_BIT (sizeof(mp_digit) * CHAR_BIT)
|
||||
#define MP_WORD_BIT (sizeof(mp_word) * CHAR_BIT)
|
||||
#define MP_SMALL_MIN LONG_MIN
|
||||
#define MP_SMALL_MAX LONG_MAX
|
||||
#define MP_USMALL_MIN ULONG_MIN
|
||||
#define MP_USMALL_MAX ULONG_MAX
|
||||
#define MP_DIGIT_BIT (sizeof(mp_digit) * CHAR_BIT)
|
||||
#define MP_WORD_BIT (sizeof(mp_word) * CHAR_BIT)
|
||||
#define MP_SMALL_MIN LONG_MIN
|
||||
#define MP_SMALL_MAX LONG_MAX
|
||||
#define MP_USMALL_MAX ULONG_MAX
|
||||
|
||||
#ifdef USE_64BIT_WORDS
|
||||
# define MP_DIGIT_MAX (UINT32_MAX * UINT64_C(1))
|
||||
# define MP_WORD_MAX (UINT64_MAX)
|
||||
#else
|
||||
# define MP_DIGIT_MAX (UINT16_MAX * 1UL)
|
||||
# define MP_WORD_MAX (UINT32_MAX * 1UL)
|
||||
#endif
|
||||
#define MP_MIN_RADIX 2
|
||||
#define MP_MAX_RADIX 36
|
||||
|
||||
#define MP_MIN_RADIX 2
|
||||
#define MP_MAX_RADIX 36
|
||||
/** Sets the default number of digits allocated to an `mp_int` constructed by
|
||||
`mp_int_init_size()` with `prec == 0`. Allocations are rounded up to
|
||||
multiples of this value. `MP_DEFAULT_PREC` is the default value. Requires
|
||||
`ndigits > 0`. */
|
||||
void mp_int_default_precision(mp_size ndigits);
|
||||
|
||||
/* Values with fewer than this many significant digits use the standard
|
||||
multiplication algorithm; otherwise, a recursive algorithm is used.
|
||||
Choose a value to suit your platform.
|
||||
*/
|
||||
#define MP_MULT_THRESH 22
|
||||
/** Sets the number of digits below which multiplication will use the standard
|
||||
quadratic "schoolbook" multiplication algorithm rather than Karatsuba-Ofman.
|
||||
Requires `ndigits >= sizeof(mp_word)`. */
|
||||
void mp_int_multiply_threshold(mp_size ndigits);
|
||||
|
||||
#define MP_DEFAULT_PREC 8 /* default memory allocation, in digits */
|
||||
/** A sign indicating a (strictly) negative value. */
|
||||
extern const mp_sign MP_NEG;
|
||||
|
||||
extern const mp_sign MP_NEG;
|
||||
extern const mp_sign MP_ZPOS;
|
||||
/** A sign indicating a zero or positive value. */
|
||||
extern const mp_sign MP_ZPOS;
|
||||
|
||||
#define mp_int_is_odd(Z) ((Z)->digits[0] & 1)
|
||||
#define mp_int_is_even(Z) !((Z)->digits[0] & 1)
|
||||
/** Reports whether `z` is odd, having remainder 1 when divided by 2. */
|
||||
static inline bool mp_int_is_odd(mp_int z) { return (z->digits[0] & 1) != 0; }
|
||||
|
||||
/** Reports whether `z` is even, having remainder 0 when divided by 2. */
|
||||
static inline bool mp_int_is_even(mp_int z) { return (z->digits[0] & 1) == 0; }
|
||||
|
||||
/** Initializes `z` with 1-digit precision and sets it to zero. This function
|
||||
cannot fail unless `z == NULL`. */
|
||||
mp_result mp_int_init(mp_int z);
|
||||
mp_int mp_int_alloc(void);
|
||||
|
||||
/** Allocates a fresh zero-valued `mpz_t` on the heap, returning NULL in case
|
||||
of error. The only possible error is out-of-memory. */
|
||||
mp_int mp_int_alloc(void);
|
||||
|
||||
/** Initializes `z` with at least `prec` digits of storage, and sets it to
|
||||
zero. If `prec` is zero, the default precision is used. In either case the
|
||||
size is rounded up to the nearest multiple of the word size. */
|
||||
mp_result mp_int_init_size(mp_int z, mp_size prec);
|
||||
|
||||
/** Initializes `z` to be a copy of an already-initialized value in `old`. The
|
||||
new copy does not share storage with the original. */
|
||||
mp_result mp_int_init_copy(mp_int z, mp_int old);
|
||||
|
||||
/** Initializes `z` to the specified signed `value` at default precision. */
|
||||
mp_result mp_int_init_value(mp_int z, mp_small value);
|
||||
|
||||
/** Initializes `z` to the specified unsigned `value` at default precision. */
|
||||
mp_result mp_int_init_uvalue(mp_int z, mp_usmall uvalue);
|
||||
|
||||
/** Sets `z` to the value of the specified signed `value`. */
|
||||
mp_result mp_int_set_value(mp_int z, mp_small value);
|
||||
|
||||
/** Sets `z` to the value of the specified unsigned `value`. */
|
||||
mp_result mp_int_set_uvalue(mp_int z, mp_usmall uvalue);
|
||||
void mp_int_clear(mp_int z);
|
||||
void mp_int_free(mp_int z);
|
||||
|
||||
mp_result mp_int_copy(mp_int a, mp_int c); /* c = a */
|
||||
void mp_int_swap(mp_int a, mp_int c); /* swap a, c */
|
||||
void mp_int_zero(mp_int z); /* z = 0 */
|
||||
mp_result mp_int_abs(mp_int a, mp_int c); /* c = |a| */
|
||||
mp_result mp_int_neg(mp_int a, mp_int c); /* c = -a */
|
||||
mp_result mp_int_add(mp_int a, mp_int b, mp_int c); /* c = a + b */
|
||||
/** Releases the storage used by `z`. */
|
||||
void mp_int_clear(mp_int z);
|
||||
|
||||
/** Releases the storage used by `z` and also `z` itself.
|
||||
This should only be used for `z` allocated by `mp_int_alloc()`. */
|
||||
void mp_int_free(mp_int z);
|
||||
|
||||
/** Replaces the value of `c` with a copy of the value of `a`. No new memory is
|
||||
allocated unless `a` has more significant digits than `c` has allocated. */
|
||||
mp_result mp_int_copy(mp_int a, mp_int c);
|
||||
|
||||
/** Swaps the values and storage between `a` and `c`. */
|
||||
void mp_int_swap(mp_int a, mp_int c);
|
||||
|
||||
/** Sets `z` to zero. The allocated storage of `z` is not changed. */
|
||||
void mp_int_zero(mp_int z);
|
||||
|
||||
/** Sets `c` to the absolute value of `a`. */
|
||||
mp_result mp_int_abs(mp_int a, mp_int c);
|
||||
|
||||
/** Sets `c` to the additive inverse (negation) of `a`. */
|
||||
mp_result mp_int_neg(mp_int a, mp_int c);
|
||||
|
||||
/** Sets `c` to the sum of `a` and `b`. */
|
||||
mp_result mp_int_add(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
/** Sets `c` to the sum of `a` and `value`. */
|
||||
mp_result mp_int_add_value(mp_int a, mp_small value, mp_int c);
|
||||
mp_result mp_int_sub(mp_int a, mp_int b, mp_int c); /* c = a - b */
|
||||
|
||||
/** Sets `c` to the difference of `a` less `b`. */
|
||||
mp_result mp_int_sub(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
/** Sets `c` to the difference of `a` less `value`. */
|
||||
mp_result mp_int_sub_value(mp_int a, mp_small value, mp_int c);
|
||||
mp_result mp_int_mul(mp_int a, mp_int b, mp_int c); /* c = a * b */
|
||||
|
||||
/** Sets `c` to the product of `a` and `b`. */
|
||||
mp_result mp_int_mul(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
/** Sets `c` to the product of `a` and `value`. */
|
||||
mp_result mp_int_mul_value(mp_int a, mp_small value, mp_int c);
|
||||
|
||||
/** Sets `c` to the product of `a` and `2^p2`. Requires `p2 >= 0`. */
|
||||
mp_result mp_int_mul_pow2(mp_int a, mp_small p2, mp_int c);
|
||||
mp_result mp_int_sqr(mp_int a, mp_int c); /* c = a * a */
|
||||
mp_result mp_int_div(mp_int a, mp_int b, /* q = a / b */
|
||||
mp_int q, mp_int r); /* r = a % b */
|
||||
mp_result mp_int_div_value(mp_int a, mp_small value, /* q = a / value */
|
||||
mp_int q, mp_small *r); /* r = a % value */
|
||||
mp_result mp_int_div_pow2(mp_int a, mp_small p2, /* q = a / 2^p2 */
|
||||
mp_int q, mp_int r); /* r = q % 2^p2 */
|
||||
mp_result mp_int_mod(mp_int a, mp_int m, mp_int c); /* c = a % m */
|
||||
#define mp_int_mod_value(A, V, R) mp_int_div_value((A), (V), 0, (R))
|
||||
mp_result mp_int_expt(mp_int a, mp_small b, mp_int c); /* c = a^b */
|
||||
mp_result mp_int_expt_value(mp_small a, mp_small b, mp_int c); /* c = a^b */
|
||||
mp_result mp_int_expt_full(mp_int a, mp_int b, mp_int c); /* c = a^b */
|
||||
|
||||
int mp_int_compare(mp_int a, mp_int b); /* a <=> b */
|
||||
int mp_int_compare_unsigned(mp_int a, mp_int b); /* |a| <=> |b| */
|
||||
int mp_int_compare_zero(mp_int z); /* a <=> 0 */
|
||||
int mp_int_compare_value(mp_int z, mp_small v); /* a <=> v */
|
||||
int mp_int_compare_uvalue(mp_int z, mp_usmall uv); /* a <=> uv */
|
||||
/** Sets `c` to the square of `a`. */
|
||||
mp_result mp_int_sqr(mp_int a, mp_int c);
|
||||
|
||||
/* Returns true if v|a, false otherwise (including errors) */
|
||||
int mp_int_divisible_value(mp_int a, mp_small v);
|
||||
/** Sets `q` and `r` to the quotent and remainder of `a / b`. Division by
|
||||
powers of 2 is detected and handled efficiently. The remainder is pinned
|
||||
to `0 <= r < b`.
|
||||
|
||||
/* Returns k >= 0 such that z = 2^k, if one exists; otherwise < 0 */
|
||||
int mp_int_is_pow2(mp_int z);
|
||||
Either of `q` or `r` may be NULL, but not both, and `q` and `r` may not
|
||||
point to the same value. */
|
||||
mp_result mp_int_div(mp_int a, mp_int b, mp_int q, mp_int r);
|
||||
|
||||
mp_result mp_int_exptmod(mp_int a, mp_int b, mp_int m,
|
||||
mp_int c); /* c = a^b (mod m) */
|
||||
mp_result mp_int_exptmod_evalue(mp_int a, mp_small value,
|
||||
mp_int m, mp_int c); /* c = a^v (mod m) */
|
||||
mp_result mp_int_exptmod_bvalue(mp_small value, mp_int b,
|
||||
mp_int m, mp_int c); /* c = v^b (mod m) */
|
||||
mp_result mp_int_exptmod_known(mp_int a, mp_int b,
|
||||
mp_int m, mp_int mu,
|
||||
mp_int c); /* c = a^b (mod m) */
|
||||
/** Sets `q` and `*r` to the quotent and remainder of `a / value`. Division by
|
||||
powers of 2 is detected and handled efficiently. The remainder is pinned to
|
||||
`0 <= *r < b`. Either of `q` or `r` may be NULL. */
|
||||
mp_result mp_int_div_value(mp_int a, mp_small value, mp_int q, mp_small *r);
|
||||
|
||||
/** Sets `q` and `r` to the quotient and remainder of `a / 2^p2`. This is a
|
||||
special case for division by powers of two that is more efficient than
|
||||
using ordinary division. Note that `mp_int_div()` will automatically handle
|
||||
this case, this function is for cases where you have only the exponent. */
|
||||
mp_result mp_int_div_pow2(mp_int a, mp_small p2, mp_int q, mp_int r);
|
||||
|
||||
/** Sets `c` to the remainder of `a / m`.
|
||||
The remainder is pinned to `0 <= c < m`. */
|
||||
mp_result mp_int_mod(mp_int a, mp_int m, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power.
|
||||
It returns `MP_RANGE` if `b < 0`. */
|
||||
mp_result mp_int_expt(mp_int a, mp_small b, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power.
|
||||
It returns `MP_RANGE` if `b < 0`. */
|
||||
mp_result mp_int_expt_value(mp_small a, mp_small b, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power.
|
||||
It returns `MP_RANGE`) if `b < 0`. */
|
||||
mp_result mp_int_expt_full(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
/** Sets `*r` to the remainder of `a / value`.
|
||||
The remainder is pinned to `0 <= r < value`. */
|
||||
static inline
|
||||
mp_result mp_int_mod_value(mp_int a, mp_small value, mp_small* r) {
|
||||
return mp_int_div_value(a, value, 0, r);
|
||||
}
|
||||
|
||||
/** Returns the comparator of `a` and `b`. */
|
||||
int mp_int_compare(mp_int a, mp_int b);
|
||||
|
||||
/** Returns the comparator of the magnitudes of `a` and `b`, disregarding their
|
||||
signs. Neither `a` nor `b` is modified by the comparison. */
|
||||
int mp_int_compare_unsigned(mp_int a, mp_int b);
|
||||
|
||||
/** Returns the comparator of `z` and zero. */
|
||||
int mp_int_compare_zero(mp_int z);
|
||||
|
||||
/** Returns the comparator of `z` and the signed value `v`. */
|
||||
int mp_int_compare_value(mp_int z, mp_small v);
|
||||
|
||||
/** Returns the comparator of `z` and the unsigned value `uv`. */
|
||||
int mp_int_compare_uvalue(mp_int z, mp_usmall uv);
|
||||
|
||||
/** Reports whether `a` is divisible by `v`. */
|
||||
bool mp_int_divisible_value(mp_int a, mp_small v);
|
||||
|
||||
/** Returns `k >= 0` such that `z` is `2^k`, if such a `k` exists. If no such
|
||||
`k` exists, the function returns -1. */
|
||||
int mp_int_is_pow2(mp_int z);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power, reduced modulo `m`.
|
||||
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
|
||||
mp_result mp_int_exptmod(mp_int a, mp_int b, mp_int m, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `value` power, modulo `m`.
|
||||
It returns `MP_RANGE` if `value < 0` or `MP_UNDEF` if `m == 0`. */
|
||||
mp_result mp_int_exptmod_evalue(mp_int a, mp_small value, mp_int m, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `value` raised to the `b` power, modulo `m`.
|
||||
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
|
||||
mp_result mp_int_exptmod_bvalue(mp_small value, mp_int b, mp_int m, mp_int c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power, reduced modulo `m`,
|
||||
given a precomputed reduction constant `mu` defined for Barrett's modular
|
||||
reduction algorithm.
|
||||
|
||||
It returns `MP_RANGE` if `b < 0` or `MP_UNDEF` if `m == 0`. */
|
||||
mp_result mp_int_exptmod_known(mp_int a, mp_int b, mp_int m, mp_int mu, mp_int c);
|
||||
|
||||
/** Sets `c` to the reduction constant for Barrett reduction by modulus `m`.
|
||||
Requires that `c` and `m` point to distinct locations. */
|
||||
mp_result mp_int_redux_const(mp_int m, mp_int c);
|
||||
|
||||
mp_result mp_int_invmod(mp_int a, mp_int m, mp_int c); /* c = 1/a (mod m) */
|
||||
/** Sets `c` to the multiplicative inverse of `a` modulo `m`, if it exists.
|
||||
The least non-negative representative of the congruence class is computed.
|
||||
|
||||
mp_result mp_int_gcd(mp_int a, mp_int b, mp_int c); /* c = gcd(a, b) */
|
||||
It returns `MP_UNDEF` if the inverse does not exist, or `MP_RANGE` if `a ==
|
||||
0` or `m <= 0`. */
|
||||
mp_result mp_int_invmod(mp_int a, mp_int m, mp_int c);
|
||||
|
||||
mp_result mp_int_egcd(mp_int a, mp_int b, mp_int c, /* c = gcd(a, b) */
|
||||
mp_int x, mp_int y); /* c = ax + by */
|
||||
/** Sets `c` to the greatest common divisor of `a` and `b`.
|
||||
|
||||
mp_result mp_int_lcm(mp_int a, mp_int b, mp_int c); /* c = lcm(a, b) */
|
||||
It returns `MP_UNDEF` if the GCD is undefined, such as for example if `a`
|
||||
and `b` are both zero. */
|
||||
mp_result mp_int_gcd(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
mp_result mp_int_root(mp_int a, mp_small b, mp_int c); /* c = floor(a^{1/b}) */
|
||||
#define mp_int_sqrt(a, c) mp_int_root(a, 2, c) /* c = floor(sqrt(a)) */
|
||||
/** Sets `c` to the greatest common divisor of `a` and `b`, and sets `x` and
|
||||
`y` to values satisfying Bezout's identity `gcd(a, b) = ax + by`.
|
||||
|
||||
/* Convert to a small int, if representable; else MP_RANGE */
|
||||
It returns `MP_UNDEF` if the GCD is undefined, such as for example if `a`
|
||||
and `b` are both zero. */
|
||||
mp_result mp_int_egcd(mp_int a, mp_int b, mp_int c, mp_int x, mp_int y);
|
||||
|
||||
/** Sets `c` to the least common multiple of `a` and `b`.
|
||||
|
||||
It returns `MP_UNDEF` if the LCM is undefined, such as for example if `a`
|
||||
and `b` are both zero. */
|
||||
mp_result mp_int_lcm(mp_int a, mp_int b, mp_int c);
|
||||
|
||||
/** Sets `c` to the greatest integer not less than the `b`th root of `a`,
|
||||
using Newton's root-finding algorithm.
|
||||
It returns `MP_UNDEF` if `a < 0` and `b` is even. */
|
||||
mp_result mp_int_root(mp_int a, mp_small b, mp_int c);
|
||||
|
||||
/** Sets `c` to the greatest integer not less than the square root of `a`.
|
||||
This is a special case of `mp_int_root()`. */
|
||||
static inline
|
||||
mp_result mp_int_sqrt(mp_int a, mp_int c) { return mp_int_root(a, 2, c); }
|
||||
|
||||
/** Returns `MP_OK` if `z` is representable as `mp_small`, else `MP_RANGE`.
|
||||
If `out` is not NULL, `*out` is set to the value of `z` when `MP_OK`. */
|
||||
mp_result mp_int_to_int(mp_int z, mp_small *out);
|
||||
|
||||
/** Returns `MP_OK` if `z` is representable as `mp_usmall`, or `MP_RANGE`.
|
||||
If `out` is not NULL, `*out` is set to the value of `z` when `MP_OK`. */
|
||||
mp_result mp_int_to_uint(mp_int z, mp_usmall *out);
|
||||
|
||||
/* Convert to nul-terminated string with the specified radix, writing at
|
||||
most limit characters including the nul terminator */
|
||||
mp_result mp_int_to_string(mp_int z, mp_size radix,
|
||||
char *str, int limit);
|
||||
/** Converts `z` to a zero-terminated string of characters in the specified
|
||||
`radix`, writing at most `limit` characters to `str` including the
|
||||
terminating NUL value. A leading `-` is used to indicate a negative value.
|
||||
|
||||
/* Return the number of characters required to represent
|
||||
z in the given radix. May over-estimate. */
|
||||
Returns `MP_TRUNC` if `limit` was to small to write all of `z`.
|
||||
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_int_to_string(mp_int z, mp_size radix, char *str, int limit);
|
||||
|
||||
/** Reports the minimum number of characters required to represent `z` as a
|
||||
zero-terminated string in the given `radix`.
|
||||
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_int_string_len(mp_int z, mp_size radix);
|
||||
|
||||
/* Read zero-terminated string into z */
|
||||
mp_result mp_int_read_string(mp_int z, mp_size radix, const char *str);
|
||||
mp_result mp_int_read_cstring(mp_int z, mp_size radix, const char *str,
|
||||
char **end);
|
||||
/** Reads a string of ASCII digits in the specified `radix` from the zero
|
||||
terminated `str` provided into `z`. For values of `radix > 10`, the letters
|
||||
`A`..`Z` or `a`..`z` are accepted. Letters are interpreted without respect
|
||||
to case.
|
||||
|
||||
/* Return the number of significant bits in z */
|
||||
Leading whitespace is ignored, and a leading `+` or `-` is interpreted as a
|
||||
sign flag. Processing stops when a NUL or any other character out of range
|
||||
for a digit in the given radix is encountered.
|
||||
|
||||
If the whole string was consumed, `MP_OK` is returned; otherwise
|
||||
`MP_TRUNC`. is returned.
|
||||
|
||||
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_int_read_string(mp_int z, mp_size radix, const char *str);
|
||||
|
||||
/** Reads a string of ASCII digits in the specified `radix` from the zero
|
||||
terminated `str` provided into `z`. For values of `radix > 10`, the letters
|
||||
`A`..`Z` or `a`..`z` are accepted. Letters are interpreted without respect
|
||||
to case.
|
||||
|
||||
Leading whitespace is ignored, and a leading `+` or `-` is interpreted as a
|
||||
sign flag. Processing stops when a NUL or any other character out of range
|
||||
for a digit in the given radix is encountered.
|
||||
|
||||
If the whole string was consumed, `MP_OK` is returned; otherwise
|
||||
`MP_TRUNC`. is returned. If `end` is not NULL, `*end` is set to point to
|
||||
the first unconsumed byte of the input string (the NUL byte if the whole
|
||||
string was consumed). This emulates the behavior of the standard C
|
||||
`strtol()` function.
|
||||
|
||||
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_int_read_cstring(mp_int z, mp_size radix, const char *str, char **end);
|
||||
|
||||
/** Returns the number of significant bits in `z`. */
|
||||
mp_result mp_int_count_bits(mp_int z);
|
||||
|
||||
/* Convert z to two's complement binary, writing at most limit bytes */
|
||||
/** Converts `z` to 2's complement binary, writing at most `limit` bytes into
|
||||
the given `buf`. Returns `MP_TRUNC` if the buffer limit was too small to
|
||||
contain the whole value. If this occurs, the contents of buf will be
|
||||
effectively garbage, as the function uses the buffer as scratch space.
|
||||
|
||||
The binary representation of `z` is in base-256 with digits ordered from
|
||||
most significant to least significant (network byte ordering). The
|
||||
high-order bit of the first byte is set for negative values, clear for
|
||||
non-negative values.
|
||||
|
||||
As a result, non-negative values will be padded with a leading zero byte if
|
||||
the high-order byte of the base-256 magnitude is set. This extra byte is
|
||||
accounted for by the `mp_int_binary_len()` function. */
|
||||
mp_result mp_int_to_binary(mp_int z, unsigned char *buf, int limit);
|
||||
|
||||
/* Read a two's complement binary value into z from the given buffer */
|
||||
/** Reads a 2's complement binary value from `buf` into `z`, where `len` is the
|
||||
length of the buffer. The contents of `buf` may be overwritten during
|
||||
processing, although they will be restored when the function returns. */
|
||||
mp_result mp_int_read_binary(mp_int z, unsigned char *buf, int len);
|
||||
|
||||
/* Return the number of bytes required to represent z in binary. */
|
||||
/** Returns the number of bytes to represent `z` in 2's complement binary. */
|
||||
mp_result mp_int_binary_len(mp_int z);
|
||||
|
||||
/* Convert z to unsigned binary, writing at most limit bytes */
|
||||
/** Converts the magnitude of `z` to unsigned binary, writing at most `limit`
|
||||
bytes into the given `buf`. The sign of `z` is ignored, but `z` is not
|
||||
modified. Returns `MP_TRUNC` if the buffer limit was too small to contain
|
||||
the whole value. If this occurs, the contents of `buf` will be effectively
|
||||
garbage, as the function uses the buffer as scratch space during
|
||||
conversion.
|
||||
|
||||
The binary representation of `z` is in base-256 with digits ordered from
|
||||
most significant to least significant (network byte ordering). */
|
||||
mp_result mp_int_to_unsigned(mp_int z, unsigned char *buf, int limit);
|
||||
|
||||
/* Read an unsigned binary value into z from the given buffer */
|
||||
/** Reads an unsigned binary value from `buf` into `z`, where `len` is the
|
||||
length of the buffer. The contents of `buf` are not modified during
|
||||
processing. */
|
||||
mp_result mp_int_read_unsigned(mp_int z, unsigned char *buf, int len);
|
||||
|
||||
/* Return the number of bytes required to represent z as unsigned output */
|
||||
/** Returns the number of bytes required to represent `z` as an unsigned binary
|
||||
value in base 256. */
|
||||
mp_result mp_int_unsigned_len(mp_int z);
|
||||
|
||||
/* Return a statically allocated string describing error code res */
|
||||
/** Returns a pointer to a brief, human-readable, zero-terminated string
|
||||
describing `res`. The returned string is statically allocated and must not
|
||||
be freed by the caller. */
|
||||
const char *mp_error_string(mp_result res);
|
||||
|
||||
#if DEBUG
|
||||
void s_print(char *tag, mp_int z);
|
||||
void s_print_buf(char *tag, mp_digit *buf, mp_size num);
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
764
polly/lib/External/isl/imath/imrat.c
vendored
764
polly/lib/External/isl/imath/imrat.c
vendored
File diff suppressed because it is too large
Load Diff
230
polly/lib/External/isl/imath/imrat.h
vendored
230
polly/lib/External/isl/imath/imrat.h
vendored
@ -1,7 +1,7 @@
|
||||
/*
|
||||
Name: imrat.h
|
||||
Purpose: Arbitrary precision rational arithmetic routines.
|
||||
Author: M. J. Fromberger <http://spinning-yarns.org/michael/>
|
||||
Author: M. J. Fromberger
|
||||
|
||||
Copyright (C) 2002-2007 Michael J. Fromberger, All Rights Reserved.
|
||||
|
||||
@ -27,19 +27,24 @@
|
||||
#ifndef IMRAT_H_
|
||||
#define IMRAT_H_
|
||||
|
||||
#include <stdbool.h>
|
||||
|
||||
#include "imath.h"
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef struct mpq {
|
||||
typedef struct {
|
||||
mpz_t num; /* Numerator */
|
||||
mpz_t den; /* Denominator, <> 0 */
|
||||
} mpq_t, *mp_rat;
|
||||
|
||||
#define MP_NUMER_P(Q) (&((Q)->num)) /* Pointer to numerator */
|
||||
#define MP_DENOM_P(Q) (&((Q)->den)) /* Pointer to denominator */
|
||||
/* Return a pointer to the numerator. */
|
||||
static inline mp_int MP_NUMER_P(mp_rat Q) { return &(Q->num); }
|
||||
|
||||
/* Return a pointer to the denominator. */
|
||||
static inline mp_int MP_DENOM_P(mp_rat Q) { return &(Q->den); }
|
||||
|
||||
/* Rounding constants */
|
||||
typedef enum {
|
||||
@ -49,72 +54,213 @@ typedef enum {
|
||||
MP_ROUND_HALF_DOWN
|
||||
} mp_round_mode;
|
||||
|
||||
/** Initializes `r` with 1-digit precision and sets it to zero. This function
|
||||
cannot fail unless `r` is NULL. */
|
||||
mp_result mp_rat_init(mp_rat r);
|
||||
mp_rat mp_rat_alloc(void);
|
||||
|
||||
/** Allocates a fresh zero-valued `mpq_t` on the heap, returning NULL in case
|
||||
of error. The only possible error is out-of-memory. */
|
||||
mp_rat mp_rat_alloc(void);
|
||||
|
||||
/** Reduces `r` in-place to lowest terms and canonical form.
|
||||
|
||||
Zero is represented as 0/1, one as 1/1, and signs are adjusted so that the
|
||||
sign of the value is carried by the numerator. */
|
||||
mp_result mp_rat_reduce(mp_rat r);
|
||||
|
||||
/** Initializes `r` with at least `n_prec` digits of storage for the numerator
|
||||
and `d_prec` digits of storage for the denominator, and value zero.
|
||||
|
||||
If either precision is zero, the default precision is used, rounded up to
|
||||
the nearest word size. */
|
||||
mp_result mp_rat_init_size(mp_rat r, mp_size n_prec, mp_size d_prec);
|
||||
|
||||
/** Initializes `r` to be a copy of an already-initialized value in `old`. The
|
||||
new copy does not share storage with the original. */
|
||||
mp_result mp_rat_init_copy(mp_rat r, mp_rat old);
|
||||
|
||||
/** Sets the value of `r` to the ratio of signed `numer` to signed `denom`. It
|
||||
returns `MP_UNDEF` if `denom` is zero. */
|
||||
mp_result mp_rat_set_value(mp_rat r, mp_small numer, mp_small denom);
|
||||
|
||||
/** Sets the value of `r` to the ratio of unsigned `numer` to unsigned
|
||||
`denom`. It returns `MP_UNDEF` if `denom` is zero. */
|
||||
mp_result mp_rat_set_uvalue(mp_rat r, mp_usmall numer, mp_usmall denom);
|
||||
void mp_rat_clear(mp_rat r);
|
||||
void mp_rat_free(mp_rat r);
|
||||
mp_result mp_rat_numer(mp_rat r, mp_int z); /* z = num(r) */
|
||||
mp_int mp_rat_numer_ref(mp_rat r); /* &num(r) */
|
||||
mp_result mp_rat_denom(mp_rat r, mp_int z); /* z = den(r) */
|
||||
mp_int mp_rat_denom_ref(mp_rat r); /* &den(r) */
|
||||
mp_sign mp_rat_sign(mp_rat r);
|
||||
|
||||
mp_result mp_rat_copy(mp_rat a, mp_rat c); /* c = a */
|
||||
void mp_rat_zero(mp_rat r); /* r = 0 */
|
||||
mp_result mp_rat_abs(mp_rat a, mp_rat c); /* c = |a| */
|
||||
mp_result mp_rat_neg(mp_rat a, mp_rat c); /* c = -a */
|
||||
mp_result mp_rat_recip(mp_rat a, mp_rat c); /* c = 1 / a */
|
||||
mp_result mp_rat_add(mp_rat a, mp_rat b, mp_rat c); /* c = a + b */
|
||||
mp_result mp_rat_sub(mp_rat a, mp_rat b, mp_rat c); /* c = a - b */
|
||||
mp_result mp_rat_mul(mp_rat a, mp_rat b, mp_rat c); /* c = a * b */
|
||||
mp_result mp_rat_div(mp_rat a, mp_rat b, mp_rat c); /* c = a / b */
|
||||
/** Releases the storage used by `r`. */
|
||||
void mp_rat_clear(mp_rat r);
|
||||
|
||||
mp_result mp_rat_add_int(mp_rat a, mp_int b, mp_rat c); /* c = a + b */
|
||||
mp_result mp_rat_sub_int(mp_rat a, mp_int b, mp_rat c); /* c = a - b */
|
||||
mp_result mp_rat_mul_int(mp_rat a, mp_int b, mp_rat c); /* c = a * b */
|
||||
mp_result mp_rat_div_int(mp_rat a, mp_int b, mp_rat c); /* c = a / b */
|
||||
mp_result mp_rat_expt(mp_rat a, mp_small b, mp_rat c); /* c = a ^ b */
|
||||
/** Releases the storage used by `r` and also `r` itself.
|
||||
This should only be used for `r` allocated by `mp_rat_alloc()`. */
|
||||
void mp_rat_free(mp_rat r);
|
||||
|
||||
int mp_rat_compare(mp_rat a, mp_rat b); /* a <=> b */
|
||||
int mp_rat_compare_unsigned(mp_rat a, mp_rat b); /* |a| <=> |b| */
|
||||
int mp_rat_compare_zero(mp_rat r); /* r <=> 0 */
|
||||
int mp_rat_compare_value(mp_rat r, mp_small n, mp_small d); /* r <=> n/d */
|
||||
int mp_rat_is_integer(mp_rat r);
|
||||
/** Sets `z` to a copy of the numerator of `r`. */
|
||||
mp_result mp_rat_numer(mp_rat r, mp_int z);
|
||||
|
||||
/* Convert to integers, if representable (returns MP_RANGE if not). */
|
||||
/** Returns a pointer to the numerator of `r`. */
|
||||
mp_int mp_rat_numer_ref(mp_rat r);
|
||||
|
||||
/** Sets `z` to a copy of the denominator of `r`. */
|
||||
mp_result mp_rat_denom(mp_rat r, mp_int z);
|
||||
|
||||
/** Returns a pointer to the denominator of `r`. */
|
||||
mp_int mp_rat_denom_ref(mp_rat r);
|
||||
|
||||
/** Reports the sign of `r`. */
|
||||
mp_sign mp_rat_sign(mp_rat r);
|
||||
|
||||
/** Sets `c` to a copy of the value of `a`. No new memory is allocated unless a
|
||||
term of `a` has more significant digits than the corresponding term of `c`
|
||||
has allocated. */
|
||||
mp_result mp_rat_copy(mp_rat a, mp_rat c);
|
||||
|
||||
/** Sets `r` to zero. The allocated storage of `r` is not changed. */
|
||||
void mp_rat_zero(mp_rat r);
|
||||
|
||||
/** Sets `c` to the absolute value of `a`. */
|
||||
mp_result mp_rat_abs(mp_rat a, mp_rat c);
|
||||
|
||||
/** Sets `c` to the absolute value of `a`. */
|
||||
mp_result mp_rat_neg(mp_rat a, mp_rat c);
|
||||
|
||||
/** Sets `c` to the reciprocal of `a` if the reciprocal is defined.
|
||||
It returns `MP_UNDEF` if `a` is zero. */
|
||||
mp_result mp_rat_recip(mp_rat a, mp_rat c);
|
||||
|
||||
/** Sets `c` to the sum of `a` and `b`. */
|
||||
mp_result mp_rat_add(mp_rat a, mp_rat b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the difference of `a` less `b`. */
|
||||
mp_result mp_rat_sub(mp_rat a, mp_rat b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the product of `a` and `b`. */
|
||||
mp_result mp_rat_mul(mp_rat a, mp_rat b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the ratio `a / b` if that ratio is defined.
|
||||
It returns `MP_UNDEF` if `b` is zero. */
|
||||
mp_result mp_rat_div(mp_rat a, mp_rat b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the sum of `a` and integer `b`. */
|
||||
mp_result mp_rat_add_int(mp_rat a, mp_int b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the difference of `a` less integer `b`. */
|
||||
mp_result mp_rat_sub_int(mp_rat a, mp_int b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the product of `a` and integer `b`. */
|
||||
mp_result mp_rat_mul_int(mp_rat a, mp_int b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the ratio `a / b` if that ratio is defined.
|
||||
It returns `MP_UNDEF` if `b` is zero. */
|
||||
mp_result mp_rat_div_int(mp_rat a, mp_int b, mp_rat c);
|
||||
|
||||
/** Sets `c` to the value of `a` raised to the `b` power.
|
||||
It returns `MP_RANGE` if `b < 0`. */
|
||||
mp_result mp_rat_expt(mp_rat a, mp_small b, mp_rat c);
|
||||
|
||||
/** Returns the comparator of `a` and `b`. */
|
||||
int mp_rat_compare(mp_rat a, mp_rat b);
|
||||
|
||||
/** Returns the comparator of the magnitudes of `a` and `b`, disregarding their
|
||||
signs. Neither `a` nor `b` is modified by the comparison. */
|
||||
int mp_rat_compare_unsigned(mp_rat a, mp_rat b);
|
||||
|
||||
/** Returns the comparator of `r` and zero. */
|
||||
int mp_rat_compare_zero(mp_rat r);
|
||||
|
||||
/** Returns the comparator of `r` and the signed ratio `n / d`.
|
||||
It returns `MP_UNDEF` if `d` is zero. */
|
||||
int mp_rat_compare_value(mp_rat r, mp_small n, mp_small d);
|
||||
|
||||
/** Reports whether `r` is an integer, having canonical denominator 1. */
|
||||
bool mp_rat_is_integer(mp_rat r);
|
||||
|
||||
/** Reports whether the numerator and denominator of `r` can be represented as
|
||||
small signed integers, and if so stores the corresponding values to `num`
|
||||
and `den`. It returns `MP_RANGE` if either cannot be so represented. */
|
||||
mp_result mp_rat_to_ints(mp_rat r, mp_small *num, mp_small *den);
|
||||
|
||||
/* Convert to nul-terminated string with the specified radix, writing
|
||||
at most limit characters including the nul terminator. */
|
||||
/** Converts `r` to a zero-terminated string of the format `"n/d"` with `n` and
|
||||
`d` in the specified radix and writing no more than `limit` bytes to the
|
||||
given output buffer `str`. The output of the numerator includes a sign flag
|
||||
if `r` is negative. Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_rat_to_string(mp_rat r, mp_size radix, char *str, int limit);
|
||||
|
||||
/* Convert to decimal format in the specified radix and precision,
|
||||
writing at most limit characters including a nul terminator. */
|
||||
/** Converts the value of `r` to a string in decimal-point notation with the
|
||||
specified radix, writing no more than `limit` bytes of data to the given
|
||||
output buffer. It generates `prec` digits of precision, and requires
|
||||
`MP_MIN_RADIX <= radix <= MP_MAX_RADIX`.
|
||||
|
||||
Ratios usually must be rounded when they are being converted for output as
|
||||
a decimal value. There are four rounding modes currently supported:
|
||||
|
||||
MP_ROUND_DOWN
|
||||
Truncates the value toward zero.
|
||||
Example: 12.009 to 2dp becomes 12.00
|
||||
|
||||
MP_ROUND_UP
|
||||
Rounds the value away from zero:
|
||||
Example: 12.001 to 2dp becomes 12.01, but
|
||||
12.000 to 2dp remains 12.00
|
||||
|
||||
MP_ROUND_HALF_DOWN
|
||||
Rounds the value to nearest digit, half goes toward zero.
|
||||
Example: 12.005 to 2dp becomes 12.00, but
|
||||
12.006 to 2dp becomes 12.01
|
||||
|
||||
MP_ROUND_HALF_UP
|
||||
Rounds the value to nearest digit, half rounds upward.
|
||||
Example: 12.005 to 2dp becomes 12.01, but
|
||||
12.004 to 2dp becomes 12.00
|
||||
*/
|
||||
mp_result mp_rat_to_decimal(mp_rat r, mp_size radix, mp_size prec,
|
||||
mp_round_mode round, char *str, int limit);
|
||||
|
||||
/* Return the number of characters required to represent r in the given
|
||||
radix. May over-estimate. */
|
||||
/** Reports the minimum number of characters required to represent `r` as a
|
||||
zero-terminated string in the given `radix`.
|
||||
Requires `MP_MIN_RADIX <= radix <= MP_MAX_RADIX`. */
|
||||
mp_result mp_rat_string_len(mp_rat r, mp_size radix);
|
||||
|
||||
/* Return the number of characters required to represent r in decimal
|
||||
format with the given radix and precision. May over-estimate. */
|
||||
/** Reports the length in bytes of the buffer needed to convert `r` using the
|
||||
`mp_rat_to_decimal()` function with the specified `radix` and `prec`. The
|
||||
buffer size estimate may slightly exceed the actual required capacity. */
|
||||
mp_result mp_rat_decimal_len(mp_rat r, mp_size radix, mp_size prec);
|
||||
|
||||
/* Read zero-terminated string into r */
|
||||
/** Sets `r` to the value represented by a zero-terminated string `str` in the
|
||||
format `"n/d"` including a sign flag. It returns `MP_UNDEF` if the encoded
|
||||
denominator has value zero. */
|
||||
mp_result mp_rat_read_string(mp_rat r, mp_size radix, const char *str);
|
||||
|
||||
/** Sets `r` to the value represented by a zero-terminated string `str` in the
|
||||
format `"n/d"` including a sign flag. It returns `MP_UNDEF` if the encoded
|
||||
denominator has value zero. If `end` is not NULL then `*end` is set to
|
||||
point to the first unconsumed character in the string, after parsing.
|
||||
*/
|
||||
mp_result mp_rat_read_cstring(mp_rat r, mp_size radix, const char *str,
|
||||
char **end);
|
||||
|
||||
/** Sets `r` to the value represented by a zero-terminated string `str` having
|
||||
one of the following formats, each with an optional leading sign flag:
|
||||
|
||||
n : integer format, e.g. "123"
|
||||
n/d : ratio format, e.g., "-12/5"
|
||||
z.ffff : decimal format, e.g., "1.627"
|
||||
|
||||
It returns `MP_UNDEF` if the effective denominator is zero. If `end` is not
|
||||
NULL then `*end` is set to point to the first unconsumed character in the
|
||||
string, after parsing.
|
||||
*/
|
||||
mp_result mp_rat_read_ustring(mp_rat r, mp_size radix, const char *str,
|
||||
char **end);
|
||||
|
||||
/* Read zero-terminated string in decimal format into r */
|
||||
/** Sets `r` to the value represented by a zero-terminated string `str` in the
|
||||
format `"z.ffff"` including a sign flag. It returns `MP_UNDEF` if the
|
||||
effective denominator. */
|
||||
mp_result mp_rat_read_decimal(mp_rat r, mp_size radix, const char *str);
|
||||
|
||||
/** Sets `r` to the value represented by a zero-terminated string `str` in the
|
||||
format `"z.ffff"` including a sign flag. It returns `MP_UNDEF` if the
|
||||
effective denominator. If `end` is not NULL then `*end` is set to point to
|
||||
the first unconsumed character in the string, after parsing. */
|
||||
mp_result mp_rat_read_cdecimal(mp_rat r, mp_size radix, const char *str,
|
||||
char **end);
|
||||
|
||||
|
17
polly/lib/External/isl/include/isl/aff.h
vendored
17
polly/lib/External/isl/include/isl/aff.h
vendored
@ -26,6 +26,7 @@ __isl_give isl_aff *isl_aff_val_on_domain(__isl_take isl_local_space *ls,
|
||||
__isl_take isl_val *val);
|
||||
__isl_give isl_aff *isl_aff_var_on_domain(__isl_take isl_local_space *ls,
|
||||
enum isl_dim_type type, unsigned pos);
|
||||
__isl_give isl_aff *isl_aff_nan_on_domain_space(__isl_take isl_space *space);
|
||||
__isl_give isl_aff *isl_aff_nan_on_domain(__isl_take isl_local_space *ls);
|
||||
__isl_give isl_aff *isl_aff_param_on_domain_space_id(
|
||||
__isl_take isl_space *space, __isl_take isl_id *id);
|
||||
@ -50,6 +51,7 @@ __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);
|
||||
__isl_export
|
||||
__isl_give isl_val *isl_aff_get_constant_val(__isl_keep isl_aff *aff);
|
||||
__isl_give isl_val *isl_aff_get_coefficient_val(__isl_keep isl_aff *aff,
|
||||
enum isl_dim_type type, int pos);
|
||||
@ -73,6 +75,7 @@ __isl_give isl_aff *isl_aff_add_coefficient_si(__isl_take isl_aff *aff,
|
||||
__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);
|
||||
|
||||
__isl_export
|
||||
isl_bool isl_aff_is_cst(__isl_keep isl_aff *aff);
|
||||
|
||||
__isl_give isl_aff *isl_aff_set_tuple_id(__isl_take isl_aff *aff,
|
||||
@ -215,6 +218,8 @@ __isl_give isl_pw_aff *isl_pw_aff_zero_on_domain(
|
||||
__isl_take isl_local_space *ls);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_var_on_domain(__isl_take isl_local_space *ls,
|
||||
enum isl_dim_type type, unsigned pos);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
|
||||
__isl_take isl_space *space);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain(__isl_take isl_local_space *ls);
|
||||
__isl_give isl_pw_aff *isl_pw_aff_val_on_domain(__isl_take isl_set *domain,
|
||||
__isl_take isl_val *v);
|
||||
@ -561,6 +566,9 @@ ISL_DECLARE_MULTI_UNBIND_PARAMS(pw_aff)
|
||||
|
||||
__isl_export
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_zero(__isl_take isl_space *space);
|
||||
__isl_overload
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity_on_domain_space(
|
||||
__isl_take isl_space *space);
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
|
||||
__isl_take isl_space *space);
|
||||
__isl_export
|
||||
@ -752,6 +760,10 @@ __isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_multi_aff(
|
||||
__isl_overload
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_pw_multi_aff(
|
||||
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
|
||||
__isl_overload
|
||||
__isl_give isl_pw_multi_aff *
|
||||
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
|
||||
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
|
||||
|
||||
__isl_export
|
||||
isl_size isl_pw_multi_aff_n_piece(__isl_keep isl_pw_multi_aff *pma);
|
||||
@ -871,6 +883,11 @@ __isl_give isl_union_pw_multi_aff *
|
||||
isl_union_pw_multi_aff_apply_union_pw_multi_aff(
|
||||
__isl_take isl_union_pw_multi_aff *upma1,
|
||||
__isl_take isl_union_pw_multi_aff *upma2);
|
||||
__isl_overload
|
||||
__isl_give isl_union_pw_multi_aff *
|
||||
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
|
||||
__isl_take isl_union_pw_multi_aff *upma1,
|
||||
__isl_take isl_union_pw_multi_aff *upma2);
|
||||
|
||||
__isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_align_params(
|
||||
__isl_take isl_union_pw_multi_aff *upma, __isl_take isl_space *model);
|
||||
|
212
polly/lib/External/isl/include/isl/cpp-checked.h
vendored
212
polly/lib/External/isl/include/isl/cpp-checked.h
vendored
@ -328,8 +328,11 @@ public:
|
||||
inline isl::checked::val eval(isl::checked::point pnt) const;
|
||||
inline isl::checked::aff floor() const;
|
||||
inline isl::checked::set ge_set(isl::checked::aff aff2) const;
|
||||
inline isl::checked::val constant_val() const;
|
||||
inline isl::checked::val get_constant_val() const;
|
||||
inline isl::checked::aff gist(isl::checked::set context) const;
|
||||
inline isl::checked::set gt_set(isl::checked::aff aff2) const;
|
||||
inline boolean is_cst() const;
|
||||
inline isl::checked::set le_set(isl::checked::aff aff2) const;
|
||||
inline isl::checked::set lt_set(isl::checked::aff aff2) const;
|
||||
inline isl::checked::aff mod(isl::checked::val mod) const;
|
||||
@ -1491,8 +1494,12 @@ public:
|
||||
inline isl::checked::map gist_domain(isl::checked::set context) const;
|
||||
inline isl::checked::map intersect(isl::checked::map map2) const;
|
||||
inline isl::checked::map intersect_domain(isl::checked::set set) const;
|
||||
inline isl::checked::map intersect_domain_factor_domain(isl::checked::map factor) const;
|
||||
inline isl::checked::map intersect_domain_factor_range(isl::checked::map factor) const;
|
||||
inline isl::checked::map intersect_params(isl::checked::set params) const;
|
||||
inline isl::checked::map intersect_range(isl::checked::set set) const;
|
||||
inline isl::checked::map intersect_range_factor_domain(isl::checked::map factor) const;
|
||||
inline isl::checked::map intersect_range_factor_range(isl::checked::map factor) const;
|
||||
inline boolean is_bijective() const;
|
||||
inline boolean is_disjoint(const isl::checked::map &map2) const;
|
||||
inline boolean is_empty() const;
|
||||
@ -1510,7 +1517,6 @@ public:
|
||||
inline isl::checked::map lexmin() const;
|
||||
inline isl::checked::pw_multi_aff lexmin_pw_multi_aff() const;
|
||||
inline isl::checked::map lower_bound(isl::checked::multi_pw_aff lower) const;
|
||||
inline isl::checked::map lower_bound(isl::checked::multi_val lower) const;
|
||||
inline isl::checked::multi_pw_aff max_multi_pw_aff() const;
|
||||
inline isl::checked::multi_pw_aff min_multi_pw_aff() const;
|
||||
inline isl::checked::basic_map polyhedral_hull() const;
|
||||
@ -1519,6 +1525,7 @@ public:
|
||||
inline isl::checked::map preimage_domain(isl::checked::pw_multi_aff pma) const;
|
||||
inline isl::checked::map preimage_range(isl::checked::multi_aff ma) const;
|
||||
inline isl::checked::map preimage_range(isl::checked::pw_multi_aff pma) const;
|
||||
inline isl::checked::map product(isl::checked::map map2) const;
|
||||
inline isl::checked::map project_out_all_params() const;
|
||||
inline isl::checked::set range() const;
|
||||
inline isl::checked::map range_factor_domain() const;
|
||||
@ -1533,8 +1540,8 @@ public:
|
||||
static inline isl::checked::map universe(isl::checked::space space);
|
||||
inline isl::checked::basic_map unshifted_simple_hull() const;
|
||||
inline isl::checked::map upper_bound(isl::checked::multi_pw_aff upper) const;
|
||||
inline isl::checked::map upper_bound(isl::checked::multi_val upper) const;
|
||||
inline isl::checked::set wrap() const;
|
||||
inline isl::checked::map zip() const;
|
||||
};
|
||||
|
||||
// declarations for isl::multi_aff
|
||||
@ -1588,6 +1595,7 @@ public:
|
||||
static inline isl::checked::multi_aff identity_on_domain(isl::checked::space space);
|
||||
inline isl::checked::multi_aff insert_domain(isl::checked::space domain) const;
|
||||
inline boolean involves_locals() const;
|
||||
inline boolean involves_nan() const;
|
||||
inline isl::checked::multi_aff neg() const;
|
||||
inline boolean plain_is_equal(const isl::checked::multi_aff &multi2) const;
|
||||
inline isl::checked::multi_aff product(isl::checked::multi_aff multi2) const;
|
||||
@ -1701,6 +1709,7 @@ public:
|
||||
inline isl::checked::multi_pw_aff insert_domain(isl::checked::space domain) const;
|
||||
inline isl::checked::multi_pw_aff intersect_domain(isl::checked::set domain) const;
|
||||
inline isl::checked::multi_pw_aff intersect_params(isl::checked::set set) const;
|
||||
inline boolean involves_nan() const;
|
||||
inline boolean involves_param(const isl::checked::id &id) const;
|
||||
inline boolean involves_param(const std::string &id) const;
|
||||
inline boolean involves_param(const isl::checked::id_list &list) const;
|
||||
@ -1772,6 +1781,7 @@ public:
|
||||
inline isl::checked::multi_union_pw_aff gist(isl::checked::union_set context) const;
|
||||
inline isl::checked::multi_union_pw_aff intersect_domain(isl::checked::union_set uset) const;
|
||||
inline isl::checked::multi_union_pw_aff intersect_params(isl::checked::set params) const;
|
||||
inline boolean involves_nan() const;
|
||||
inline isl::checked::multi_union_pw_aff neg() const;
|
||||
inline boolean plain_is_equal(const isl::checked::multi_union_pw_aff &multi2) const;
|
||||
inline isl::checked::multi_union_pw_aff pullback(isl::checked::union_pw_multi_aff upma) const;
|
||||
@ -1826,6 +1836,7 @@ public:
|
||||
inline isl::checked::val_list get_list() const;
|
||||
inline isl::checked::space space() const;
|
||||
inline isl::checked::space get_space() const;
|
||||
inline boolean involves_nan() const;
|
||||
inline isl::checked::multi_val max(isl::checked::multi_val multi2) const;
|
||||
inline isl::checked::multi_val min(isl::checked::multi_val multi2) const;
|
||||
inline isl::checked::multi_val neg() const;
|
||||
@ -2029,6 +2040,7 @@ public:
|
||||
inline isl::checked::space space() const;
|
||||
inline isl::checked::space get_space() const;
|
||||
inline isl::checked::pw_multi_aff gist(isl::checked::set set) const;
|
||||
static inline isl::checked::pw_multi_aff identity_on_domain(isl::checked::space space);
|
||||
inline isl::checked::pw_multi_aff insert_domain(isl::checked::space domain) const;
|
||||
inline isl::checked::pw_multi_aff intersect_domain(isl::checked::set set) const;
|
||||
inline isl::checked::pw_multi_aff intersect_params(isl::checked::set set) const;
|
||||
@ -2037,6 +2049,7 @@ public:
|
||||
inline isl::checked::multi_val max_multi_val() const;
|
||||
inline isl::checked::multi_val min_multi_val() const;
|
||||
inline class size n_piece() const;
|
||||
inline isl::checked::pw_multi_aff preimage_domain_wrapped_domain(isl::checked::pw_multi_aff pma2) const;
|
||||
inline isl::checked::pw_multi_aff product(isl::checked::pw_multi_aff pma2) const;
|
||||
inline isl::checked::pw_multi_aff pullback(isl::checked::multi_aff ma) const;
|
||||
inline isl::checked::pw_multi_aff pullback(isl::checked::pw_multi_aff pma2) const;
|
||||
@ -2119,6 +2132,8 @@ public:
|
||||
inline isl::checked::ctx ctx() const;
|
||||
|
||||
static inline isl::checked::schedule from_domain(isl::checked::union_set domain);
|
||||
inline isl::checked::union_set domain() const;
|
||||
inline isl::checked::union_set get_domain() const;
|
||||
inline isl::checked::union_map map() const;
|
||||
inline isl::checked::union_map get_map() const;
|
||||
inline isl::checked::schedule_node root() const;
|
||||
@ -2590,6 +2605,7 @@ public:
|
||||
inline isl::checked::basic_set sample() const;
|
||||
inline isl::checked::point sample_point() const;
|
||||
inline isl::checked::set subtract(isl::checked::set set2) const;
|
||||
inline isl::checked::map translation() const;
|
||||
inline isl::checked::set unbind_params(isl::checked::multi_id tuple) const;
|
||||
inline isl::checked::map unbind_params_insert_domain(isl::checked::multi_id domain) const;
|
||||
inline isl::checked::set unite(isl::checked::set set2) const;
|
||||
@ -2628,6 +2644,7 @@ public:
|
||||
inline isl::checked::space add_named_tuple(isl::checked::id tuple_id, unsigned int dim) const;
|
||||
inline isl::checked::space add_named_tuple(const std::string &tuple_id, unsigned int dim) const;
|
||||
inline isl::checked::space add_unnamed_tuple(unsigned int dim) const;
|
||||
inline isl::checked::space curry() const;
|
||||
inline isl::checked::space domain() const;
|
||||
inline isl::checked::space flatten_domain() const;
|
||||
inline isl::checked::space flatten_range() const;
|
||||
@ -2635,7 +2652,11 @@ public:
|
||||
inline boolean is_wrapping() const;
|
||||
inline isl::checked::space map_from_set() const;
|
||||
inline isl::checked::space params() const;
|
||||
inline isl::checked::space product(isl::checked::space right) const;
|
||||
inline isl::checked::space range() const;
|
||||
inline isl::checked::space range_reverse() const;
|
||||
inline isl::checked::space reverse() const;
|
||||
inline isl::checked::space uncurry() const;
|
||||
static inline isl::checked::space unit(isl::checked::ctx ctx);
|
||||
inline isl::checked::space unwrap() const;
|
||||
inline isl::checked::space wrap() const;
|
||||
@ -2780,9 +2801,13 @@ public:
|
||||
inline isl::checked::union_map intersect(isl::checked::union_map umap2) const;
|
||||
inline isl::checked::union_map intersect_domain(isl::checked::space space) const;
|
||||
inline isl::checked::union_map intersect_domain(isl::checked::union_set uset) const;
|
||||
inline isl::checked::union_map intersect_domain_factor_domain(isl::checked::union_map factor) const;
|
||||
inline isl::checked::union_map intersect_domain_factor_range(isl::checked::union_map factor) const;
|
||||
inline isl::checked::union_map intersect_params(isl::checked::set set) const;
|
||||
inline isl::checked::union_map intersect_range(isl::checked::space space) const;
|
||||
inline isl::checked::union_map intersect_range(isl::checked::union_set uset) const;
|
||||
inline isl::checked::union_map intersect_range_factor_domain(isl::checked::union_map factor) const;
|
||||
inline isl::checked::union_map intersect_range_factor_range(isl::checked::union_map factor) const;
|
||||
inline boolean is_bijective() const;
|
||||
inline boolean is_disjoint(const isl::checked::union_map &umap2) const;
|
||||
inline boolean is_empty() const;
|
||||
@ -2955,6 +2980,7 @@ public:
|
||||
inline boolean involves_locals() const;
|
||||
inline boolean isa_pw_multi_aff() const;
|
||||
inline boolean plain_is_empty() const;
|
||||
inline isl::checked::union_pw_multi_aff preimage_domain_wrapped_domain(isl::checked::union_pw_multi_aff upma2) const;
|
||||
inline isl::checked::union_pw_multi_aff pullback(isl::checked::union_pw_multi_aff upma2) const;
|
||||
inline isl::checked::union_pw_multi_aff range_factor_domain() const;
|
||||
inline isl::checked::union_pw_multi_aff range_factor_range() const;
|
||||
@ -3323,6 +3349,17 @@ isl::checked::set aff::ge_set(isl::checked::aff aff2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::val aff::constant_val() const
|
||||
{
|
||||
auto res = isl_aff_get_constant_val(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::val aff::get_constant_val() const
|
||||
{
|
||||
return constant_val();
|
||||
}
|
||||
|
||||
isl::checked::aff aff::gist(isl::checked::set context) const
|
||||
{
|
||||
auto res = isl_aff_gist(copy(), context.release());
|
||||
@ -3335,6 +3372,12 @@ isl::checked::set aff::gt_set(isl::checked::aff aff2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean aff::is_cst() const
|
||||
{
|
||||
auto res = isl_aff_is_cst(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::set aff::le_set(isl::checked::aff aff2) const
|
||||
{
|
||||
auto res = isl_aff_le_set(copy(), aff2.release());
|
||||
@ -6343,6 +6386,18 @@ isl::checked::map map::intersect_domain(isl::checked::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::intersect_domain_factor_domain(isl::checked::map factor) const
|
||||
{
|
||||
auto res = isl_map_intersect_domain_factor_domain(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::intersect_domain_factor_range(isl::checked::map factor) const
|
||||
{
|
||||
auto res = isl_map_intersect_domain_factor_range(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::intersect_params(isl::checked::set params) const
|
||||
{
|
||||
auto res = isl_map_intersect_params(copy(), params.release());
|
||||
@ -6355,6 +6410,18 @@ isl::checked::map map::intersect_range(isl::checked::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::intersect_range_factor_domain(isl::checked::map factor) const
|
||||
{
|
||||
auto res = isl_map_intersect_range_factor_domain(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::intersect_range_factor_range(isl::checked::map factor) const
|
||||
{
|
||||
auto res = isl_map_intersect_range_factor_range(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean map::is_bijective() const
|
||||
{
|
||||
auto res = isl_map_is_bijective(get());
|
||||
@ -6457,12 +6524,6 @@ isl::checked::map map::lower_bound(isl::checked::multi_pw_aff lower) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::lower_bound(isl::checked::multi_val lower) const
|
||||
{
|
||||
auto res = isl_map_lower_bound_multi_val(copy(), lower.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::multi_pw_aff map::max_multi_pw_aff() const
|
||||
{
|
||||
auto res = isl_map_max_multi_pw_aff(copy());
|
||||
@ -6511,6 +6572,12 @@ isl::checked::map map::preimage_range(isl::checked::pw_multi_aff pma) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::product(isl::checked::map map2) const
|
||||
{
|
||||
auto res = isl_map_product(copy(), map2.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::project_out_all_params() const
|
||||
{
|
||||
auto res = isl_map_project_out_all_params(copy());
|
||||
@ -6595,18 +6662,18 @@ isl::checked::map map::upper_bound(isl::checked::multi_pw_aff upper) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::upper_bound(isl::checked::multi_val upper) const
|
||||
{
|
||||
auto res = isl_map_upper_bound_multi_val(copy(), upper.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::set map::wrap() const
|
||||
{
|
||||
auto res = isl_map_wrap(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map map::zip() const
|
||||
{
|
||||
auto res = isl_map_zip(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
inline std::ostream &operator<<(std::ostream &os, const map &obj)
|
||||
{
|
||||
char *str = isl_map_to_str(obj.get());
|
||||
@ -6823,6 +6890,12 @@ boolean multi_aff::involves_locals() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean multi_aff::involves_nan() const
|
||||
{
|
||||
auto res = isl_multi_aff_involves_nan(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::multi_aff multi_aff::neg() const
|
||||
{
|
||||
auto res = isl_multi_aff_neg(copy());
|
||||
@ -7297,6 +7370,12 @@ isl::checked::multi_pw_aff multi_pw_aff::intersect_params(isl::checked::set set)
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean multi_pw_aff::involves_nan() const
|
||||
{
|
||||
auto res = isl_multi_pw_aff_involves_nan(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean multi_pw_aff::involves_param(const isl::checked::id &id) const
|
||||
{
|
||||
auto res = isl_multi_pw_aff_involves_param_id(get(), id.get());
|
||||
@ -7620,6 +7699,12 @@ isl::checked::multi_union_pw_aff multi_union_pw_aff::intersect_params(isl::check
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean multi_union_pw_aff::involves_nan() const
|
||||
{
|
||||
auto res = isl_multi_union_pw_aff_involves_nan(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::multi_union_pw_aff multi_union_pw_aff::neg() const
|
||||
{
|
||||
auto res = isl_multi_union_pw_aff_neg(copy());
|
||||
@ -7841,6 +7926,12 @@ isl::checked::space multi_val::get_space() const
|
||||
return space();
|
||||
}
|
||||
|
||||
boolean multi_val::involves_nan() const
|
||||
{
|
||||
auto res = isl_multi_val_involves_nan(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::multi_val multi_val::max(isl::checked::multi_val multi2) const
|
||||
{
|
||||
auto res = isl_multi_val_max(copy(), multi2.release());
|
||||
@ -8675,6 +8766,12 @@ isl::checked::pw_multi_aff pw_multi_aff::gist(isl::checked::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::pw_multi_aff pw_multi_aff::identity_on_domain(isl::checked::space space)
|
||||
{
|
||||
auto res = isl_pw_multi_aff_identity_on_domain_space(space.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::pw_multi_aff pw_multi_aff::insert_domain(isl::checked::space domain) const
|
||||
{
|
||||
auto res = isl_pw_multi_aff_insert_domain(copy(), domain.release());
|
||||
@ -8723,6 +8820,12 @@ class size pw_multi_aff::n_piece() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::pw_multi_aff pw_multi_aff::preimage_domain_wrapped_domain(isl::checked::pw_multi_aff pma2) const
|
||||
{
|
||||
auto res = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(copy(), pma2.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::pw_multi_aff pw_multi_aff::product(isl::checked::pw_multi_aff pma2) const
|
||||
{
|
||||
auto res = isl_pw_multi_aff_product(copy(), pma2.release());
|
||||
@ -9026,6 +9129,17 @@ isl::checked::schedule schedule::from_domain(isl::checked::union_set domain)
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_set schedule::domain() const
|
||||
{
|
||||
auto res = isl_schedule_get_domain(get());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_set schedule::get_domain() const
|
||||
{
|
||||
return domain();
|
||||
}
|
||||
|
||||
isl::checked::union_map schedule::map() const
|
||||
{
|
||||
auto res = isl_schedule_get_map(get());
|
||||
@ -9783,28 +9897,24 @@ schedule_node_band schedule_node_band::tile(isl::checked::multi_val sizes) const
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) const
|
||||
{
|
||||
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_default);
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
|
||||
{
|
||||
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_atomic);
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
|
||||
{
|
||||
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_unroll);
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_separate(int pos) const
|
||||
{
|
||||
auto res = isl_schedule_node_band_member_set_ast_loop_type(copy(), pos, isl_ast_loop_separate);
|
||||
@ -10654,6 +10764,12 @@ isl::checked::set set::subtract(isl::checked::set set2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::map set::translation() const
|
||||
{
|
||||
auto res = isl_set_translation(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::set set::unbind_params(isl::checked::multi_id tuple) const
|
||||
{
|
||||
auto res = isl_set_unbind_params(copy(), tuple.release());
|
||||
@ -10784,6 +10900,12 @@ isl::checked::space space::add_unnamed_tuple(unsigned int dim) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::curry() const
|
||||
{
|
||||
auto res = isl_space_curry(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::domain() const
|
||||
{
|
||||
auto res = isl_space_domain(copy());
|
||||
@ -10826,12 +10948,36 @@ isl::checked::space space::params() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::product(isl::checked::space right) const
|
||||
{
|
||||
auto res = isl_space_product(copy(), right.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::range() const
|
||||
{
|
||||
auto res = isl_space_range(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::range_reverse() const
|
||||
{
|
||||
auto res = isl_space_range_reverse(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::reverse() const
|
||||
{
|
||||
auto res = isl_space_reverse(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::uncurry() const
|
||||
{
|
||||
auto res = isl_space_uncurry(copy());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::space space::unit(isl::checked::ctx ctx)
|
||||
{
|
||||
auto res = isl_space_unit(ctx.release());
|
||||
@ -11413,6 +11559,18 @@ isl::checked::union_map union_map::intersect_domain(isl::checked::union_set uset
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_map union_map::intersect_domain_factor_domain(isl::checked::union_map factor) const
|
||||
{
|
||||
auto res = isl_union_map_intersect_domain_factor_domain(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_map union_map::intersect_domain_factor_range(isl::checked::union_map factor) const
|
||||
{
|
||||
auto res = isl_union_map_intersect_domain_factor_range(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_map union_map::intersect_params(isl::checked::set set) const
|
||||
{
|
||||
auto res = isl_union_map_intersect_params(copy(), set.release());
|
||||
@ -11431,6 +11589,18 @@ isl::checked::union_map union_map::intersect_range(isl::checked::union_set uset)
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_map union_map::intersect_range_factor_domain(isl::checked::union_map factor) const
|
||||
{
|
||||
auto res = isl_union_map_intersect_range_factor_domain(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_map union_map::intersect_range_factor_range(isl::checked::union_map factor) const
|
||||
{
|
||||
auto res = isl_union_map_intersect_range_factor_range(copy(), factor.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
boolean union_map::is_bijective() const
|
||||
{
|
||||
auto res = isl_union_map_is_bijective(get());
|
||||
@ -12176,6 +12346,12 @@ boolean union_pw_multi_aff::plain_is_empty() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_pw_multi_aff union_pw_multi_aff::preimage_domain_wrapped_domain(isl::checked::union_pw_multi_aff upma2) const
|
||||
{
|
||||
auto res = isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(copy(), upma2.release());
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::checked::union_pw_multi_aff union_pw_multi_aff::pullback(isl::checked::union_pw_multi_aff upma2) const
|
||||
{
|
||||
auto res = isl_union_pw_multi_aff_pullback_union_pw_multi_aff(copy(), upma2.release());
|
||||
|
380
polly/lib/External/isl/include/isl/cpp.h
vendored
380
polly/lib/External/isl/include/isl/cpp.h
vendored
@ -392,8 +392,11 @@ public:
|
||||
inline isl::val eval(isl::point pnt) const;
|
||||
inline isl::aff floor() const;
|
||||
inline isl::set ge_set(isl::aff aff2) const;
|
||||
inline isl::val constant_val() const;
|
||||
inline isl::val get_constant_val() const;
|
||||
inline isl::aff gist(isl::set context) const;
|
||||
inline isl::set gt_set(isl::aff aff2) const;
|
||||
inline bool is_cst() const;
|
||||
inline isl::set le_set(isl::aff aff2) const;
|
||||
inline isl::set lt_set(isl::aff aff2) const;
|
||||
inline isl::aff mod(isl::val mod) const;
|
||||
@ -1556,8 +1559,12 @@ public:
|
||||
inline isl::map gist_domain(isl::set context) const;
|
||||
inline isl::map intersect(isl::map map2) const;
|
||||
inline isl::map intersect_domain(isl::set set) const;
|
||||
inline isl::map intersect_domain_factor_domain(isl::map factor) const;
|
||||
inline isl::map intersect_domain_factor_range(isl::map factor) const;
|
||||
inline isl::map intersect_params(isl::set params) const;
|
||||
inline isl::map intersect_range(isl::set set) const;
|
||||
inline isl::map intersect_range_factor_domain(isl::map factor) const;
|
||||
inline isl::map intersect_range_factor_range(isl::map factor) const;
|
||||
inline bool is_bijective() const;
|
||||
inline bool is_disjoint(const isl::map &map2) const;
|
||||
inline bool is_empty() const;
|
||||
@ -1575,7 +1582,6 @@ public:
|
||||
inline isl::map lexmin() const;
|
||||
inline isl::pw_multi_aff lexmin_pw_multi_aff() const;
|
||||
inline isl::map lower_bound(isl::multi_pw_aff lower) const;
|
||||
inline isl::map lower_bound(isl::multi_val lower) const;
|
||||
inline isl::multi_pw_aff max_multi_pw_aff() const;
|
||||
inline isl::multi_pw_aff min_multi_pw_aff() const;
|
||||
inline isl::basic_map polyhedral_hull() const;
|
||||
@ -1584,6 +1590,7 @@ public:
|
||||
inline isl::map preimage_domain(isl::pw_multi_aff pma) const;
|
||||
inline isl::map preimage_range(isl::multi_aff ma) const;
|
||||
inline isl::map preimage_range(isl::pw_multi_aff pma) const;
|
||||
inline isl::map product(isl::map map2) const;
|
||||
inline isl::map project_out_all_params() const;
|
||||
inline isl::set range() const;
|
||||
inline isl::map range_factor_domain() const;
|
||||
@ -1598,8 +1605,8 @@ public:
|
||||
static inline isl::map universe(isl::space space);
|
||||
inline isl::basic_map unshifted_simple_hull() const;
|
||||
inline isl::map upper_bound(isl::multi_pw_aff upper) const;
|
||||
inline isl::map upper_bound(isl::multi_val upper) const;
|
||||
inline isl::set wrap() const;
|
||||
inline isl::map zip() const;
|
||||
};
|
||||
|
||||
// declarations for isl::multi_aff
|
||||
@ -1653,6 +1660,7 @@ public:
|
||||
static inline isl::multi_aff identity_on_domain(isl::space space);
|
||||
inline isl::multi_aff insert_domain(isl::space domain) const;
|
||||
inline bool involves_locals() const;
|
||||
inline bool involves_nan() const;
|
||||
inline isl::multi_aff neg() const;
|
||||
inline bool plain_is_equal(const isl::multi_aff &multi2) const;
|
||||
inline isl::multi_aff product(isl::multi_aff multi2) const;
|
||||
@ -1766,6 +1774,7 @@ public:
|
||||
inline isl::multi_pw_aff insert_domain(isl::space domain) const;
|
||||
inline isl::multi_pw_aff intersect_domain(isl::set domain) const;
|
||||
inline isl::multi_pw_aff intersect_params(isl::set set) const;
|
||||
inline bool involves_nan() const;
|
||||
inline bool involves_param(const isl::id &id) const;
|
||||
inline bool involves_param(const std::string &id) const;
|
||||
inline bool involves_param(const isl::id_list &list) const;
|
||||
@ -1837,6 +1846,7 @@ public:
|
||||
inline isl::multi_union_pw_aff gist(isl::union_set context) const;
|
||||
inline isl::multi_union_pw_aff intersect_domain(isl::union_set uset) const;
|
||||
inline isl::multi_union_pw_aff intersect_params(isl::set params) const;
|
||||
inline bool involves_nan() const;
|
||||
inline isl::multi_union_pw_aff neg() const;
|
||||
inline bool plain_is_equal(const isl::multi_union_pw_aff &multi2) const;
|
||||
inline isl::multi_union_pw_aff pullback(isl::union_pw_multi_aff upma) const;
|
||||
@ -1891,6 +1901,7 @@ public:
|
||||
inline isl::val_list get_list() const;
|
||||
inline isl::space space() const;
|
||||
inline isl::space get_space() const;
|
||||
inline bool involves_nan() const;
|
||||
inline isl::multi_val max(isl::multi_val multi2) const;
|
||||
inline isl::multi_val min(isl::multi_val multi2) const;
|
||||
inline isl::multi_val neg() const;
|
||||
@ -2094,6 +2105,7 @@ public:
|
||||
inline isl::space space() const;
|
||||
inline isl::space get_space() const;
|
||||
inline isl::pw_multi_aff gist(isl::set set) const;
|
||||
static inline isl::pw_multi_aff identity_on_domain(isl::space space);
|
||||
inline isl::pw_multi_aff insert_domain(isl::space domain) const;
|
||||
inline isl::pw_multi_aff intersect_domain(isl::set set) const;
|
||||
inline isl::pw_multi_aff intersect_params(isl::set set) const;
|
||||
@ -2102,6 +2114,7 @@ public:
|
||||
inline isl::multi_val max_multi_val() const;
|
||||
inline isl::multi_val min_multi_val() const;
|
||||
inline unsigned n_piece() const;
|
||||
inline isl::pw_multi_aff preimage_domain_wrapped_domain(isl::pw_multi_aff pma2) const;
|
||||
inline isl::pw_multi_aff product(isl::pw_multi_aff pma2) const;
|
||||
inline isl::pw_multi_aff pullback(isl::multi_aff ma) const;
|
||||
inline isl::pw_multi_aff pullback(isl::pw_multi_aff pma2) const;
|
||||
@ -2184,6 +2197,8 @@ public:
|
||||
inline isl::ctx ctx() const;
|
||||
|
||||
static inline isl::schedule from_domain(isl::union_set domain);
|
||||
inline isl::union_set domain() const;
|
||||
inline isl::union_set get_domain() const;
|
||||
inline isl::union_map map() const;
|
||||
inline isl::union_map get_map() const;
|
||||
inline isl::schedule_node root() const;
|
||||
@ -2655,6 +2670,7 @@ public:
|
||||
inline isl::basic_set sample() const;
|
||||
inline isl::point sample_point() const;
|
||||
inline isl::set subtract(isl::set set2) const;
|
||||
inline isl::map translation() const;
|
||||
inline isl::set unbind_params(isl::multi_id tuple) const;
|
||||
inline isl::map unbind_params_insert_domain(isl::multi_id domain) const;
|
||||
inline isl::set unite(isl::set set2) const;
|
||||
@ -2693,6 +2709,7 @@ public:
|
||||
inline isl::space add_named_tuple(isl::id tuple_id, unsigned int dim) const;
|
||||
inline isl::space add_named_tuple(const std::string &tuple_id, unsigned int dim) const;
|
||||
inline isl::space add_unnamed_tuple(unsigned int dim) const;
|
||||
inline isl::space curry() const;
|
||||
inline isl::space domain() const;
|
||||
inline isl::space flatten_domain() const;
|
||||
inline isl::space flatten_range() const;
|
||||
@ -2700,7 +2717,11 @@ public:
|
||||
inline bool is_wrapping() const;
|
||||
inline isl::space map_from_set() const;
|
||||
inline isl::space params() const;
|
||||
inline isl::space product(isl::space right) const;
|
||||
inline isl::space range() const;
|
||||
inline isl::space range_reverse() const;
|
||||
inline isl::space reverse() const;
|
||||
inline isl::space uncurry() const;
|
||||
static inline isl::space unit(isl::ctx ctx);
|
||||
inline isl::space unwrap() const;
|
||||
inline isl::space wrap() const;
|
||||
@ -2845,9 +2866,13 @@ public:
|
||||
inline isl::union_map intersect(isl::union_map umap2) const;
|
||||
inline isl::union_map intersect_domain(isl::space space) const;
|
||||
inline isl::union_map intersect_domain(isl::union_set uset) const;
|
||||
inline isl::union_map intersect_domain_factor_domain(isl::union_map factor) const;
|
||||
inline isl::union_map intersect_domain_factor_range(isl::union_map factor) const;
|
||||
inline isl::union_map intersect_params(isl::set set) const;
|
||||
inline isl::union_map intersect_range(isl::space space) const;
|
||||
inline isl::union_map intersect_range(isl::union_set uset) const;
|
||||
inline isl::union_map intersect_range_factor_domain(isl::union_map factor) const;
|
||||
inline isl::union_map intersect_range_factor_range(isl::union_map factor) const;
|
||||
inline bool is_bijective() const;
|
||||
inline bool is_disjoint(const isl::union_map &umap2) const;
|
||||
inline bool is_empty() const;
|
||||
@ -3020,6 +3045,7 @@ public:
|
||||
inline bool involves_locals() const;
|
||||
inline bool isa_pw_multi_aff() const;
|
||||
inline bool plain_is_empty() const;
|
||||
inline isl::union_pw_multi_aff preimage_domain_wrapped_domain(isl::union_pw_multi_aff upma2) const;
|
||||
inline isl::union_pw_multi_aff pullback(isl::union_pw_multi_aff upma2) const;
|
||||
inline isl::union_pw_multi_aff range_factor_domain() const;
|
||||
inline isl::union_pw_multi_aff range_factor_range() const;
|
||||
@ -3464,6 +3490,23 @@ isl::set aff::ge_set(isl::aff aff2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::val aff::constant_val() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_aff_get_constant_val(get());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::val aff::get_constant_val() const
|
||||
{
|
||||
return constant_val();
|
||||
}
|
||||
|
||||
isl::aff aff::gist(isl::set context) const
|
||||
{
|
||||
if (!ptr || context.is_null())
|
||||
@ -3488,6 +3531,18 @@ isl::set aff::gt_set(isl::aff aff2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
bool aff::is_cst() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_aff_is_cst(get());
|
||||
if (res < 0)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::set aff::le_set(isl::aff aff2) const
|
||||
{
|
||||
if (!ptr || aff2.is_null())
|
||||
@ -7714,6 +7769,30 @@ isl::map map::intersect_domain(isl::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::intersect_domain_factor_domain(isl::map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_intersect_domain_factor_domain(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::intersect_domain_factor_range(isl::map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_intersect_domain_factor_range(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::intersect_params(isl::set params) const
|
||||
{
|
||||
if (!ptr || params.is_null())
|
||||
@ -7738,6 +7817,30 @@ isl::map map::intersect_range(isl::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::intersect_range_factor_domain(isl::map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_intersect_range_factor_domain(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::intersect_range_factor_range(isl::map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_intersect_range_factor_range(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
bool map::is_bijective() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -7942,18 +8045,6 @@ isl::map map::lower_bound(isl::multi_pw_aff lower) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::lower_bound(isl::multi_val lower) const
|
||||
{
|
||||
if (!ptr || lower.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_lower_bound_multi_val(copy(), lower.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::multi_pw_aff map::max_multi_pw_aff() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -8050,6 +8141,18 @@ isl::map map::preimage_range(isl::pw_multi_aff pma) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::product(isl::map map2) const
|
||||
{
|
||||
if (!ptr || map2.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_product(copy(), map2.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::project_out_all_params() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -8218,18 +8321,6 @@ isl::map map::upper_bound(isl::multi_pw_aff upper) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::upper_bound(isl::multi_val upper) const
|
||||
{
|
||||
if (!ptr || upper.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_upper_bound_multi_val(copy(), upper.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::set map::wrap() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -8242,6 +8333,18 @@ isl::set map::wrap() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map map::zip() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_map_zip(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
inline std::ostream &operator<<(std::ostream &os, const map &obj)
|
||||
{
|
||||
if (!obj.get())
|
||||
@ -8600,6 +8703,18 @@ bool multi_aff::involves_locals() const
|
||||
return res;
|
||||
}
|
||||
|
||||
bool multi_aff::involves_nan() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_multi_aff_involves_nan(get());
|
||||
if (res < 0)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::multi_aff multi_aff::neg() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -9404,6 +9519,18 @@ isl::multi_pw_aff multi_pw_aff::intersect_params(isl::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
bool multi_pw_aff::involves_nan() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_multi_pw_aff_involves_nan(get());
|
||||
if (res < 0)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return res;
|
||||
}
|
||||
|
||||
bool multi_pw_aff::involves_param(const isl::id &id) const
|
||||
{
|
||||
if (!ptr || id.is_null())
|
||||
@ -9975,6 +10102,18 @@ isl::multi_union_pw_aff multi_union_pw_aff::intersect_params(isl::set params) co
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
bool multi_union_pw_aff::involves_nan() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_multi_union_pw_aff_involves_nan(get());
|
||||
if (res < 0)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::multi_union_pw_aff multi_union_pw_aff::neg() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -10342,6 +10481,18 @@ isl::space multi_val::get_space() const
|
||||
return space();
|
||||
}
|
||||
|
||||
bool multi_val::involves_nan() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_multi_val_involves_nan(get());
|
||||
if (res < 0)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::multi_val multi_val::max(isl::multi_val multi2) const
|
||||
{
|
||||
if (!ptr || multi2.is_null())
|
||||
@ -11766,6 +11917,18 @@ isl::pw_multi_aff pw_multi_aff::gist(isl::set set) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::pw_multi_aff pw_multi_aff::identity_on_domain(isl::space space)
|
||||
{
|
||||
if (space.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = space.ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_pw_multi_aff_identity_on_domain_space(space.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::pw_multi_aff pw_multi_aff::insert_domain(isl::space domain) const
|
||||
{
|
||||
if (!ptr || domain.is_null())
|
||||
@ -11862,6 +12025,18 @@ unsigned pw_multi_aff::n_piece() const
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::pw_multi_aff pw_multi_aff::preimage_domain_wrapped_domain(isl::pw_multi_aff pma2) const
|
||||
{
|
||||
if (!ptr || pma2.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(copy(), pma2.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::pw_multi_aff pw_multi_aff::product(isl::pw_multi_aff pma2) const
|
||||
{
|
||||
if (!ptr || pma2.is_null())
|
||||
@ -12355,6 +12530,23 @@ isl::schedule schedule::from_domain(isl::union_set domain)
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_set schedule::domain() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_schedule_get_domain(get());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_set schedule::get_domain() const
|
||||
{
|
||||
return domain();
|
||||
}
|
||||
|
||||
isl::union_map schedule::map() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -13610,7 +13802,6 @@ schedule_node_band schedule_node_band::tile(isl::multi_val sizes) const
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -13623,7 +13814,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_default(int pos) cons
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -13636,7 +13826,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_atomic(int pos) const
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -13649,7 +13838,6 @@ schedule_node_band schedule_node_band::member_set_ast_loop_unroll(int pos) const
|
||||
return manage(res).as<schedule_node_band>();
|
||||
}
|
||||
|
||||
|
||||
schedule_node_band schedule_node_band::member_set_ast_loop_separate(int pos) const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -14929,6 +15117,18 @@ isl::set set::subtract(isl::set set2) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::map set::translation() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_set_translation(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::set set::unbind_params(isl::multi_id tuple) const
|
||||
{
|
||||
if (!ptr || tuple.is_null())
|
||||
@ -15137,6 +15337,18 @@ isl::space space::add_unnamed_tuple(unsigned int dim) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::curry() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_space_curry(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::domain() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -15221,6 +15433,18 @@ isl::space space::params() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::product(isl::space right) const
|
||||
{
|
||||
if (!ptr || right.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_space_product(copy(), right.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::range() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -15233,6 +15457,42 @@ isl::space space::range() const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::range_reverse() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_space_range_reverse(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::reverse() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_space_reverse(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::uncurry() const
|
||||
{
|
||||
if (!ptr)
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_space_uncurry(copy());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::space space::unit(isl::ctx ctx)
|
||||
{
|
||||
auto saved_ctx = ctx;
|
||||
@ -16204,6 +16464,30 @@ isl::union_map union_map::intersect_domain(isl::union_set uset) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_map union_map::intersect_domain_factor_domain(isl::union_map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_union_map_intersect_domain_factor_domain(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_map union_map::intersect_domain_factor_range(isl::union_map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_union_map_intersect_domain_factor_range(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_map union_map::intersect_params(isl::set set) const
|
||||
{
|
||||
if (!ptr || set.is_null())
|
||||
@ -16240,6 +16524,30 @@ isl::union_map union_map::intersect_range(isl::union_set uset) const
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_map union_map::intersect_range_factor_domain(isl::union_map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_union_map_intersect_range_factor_domain(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_map union_map::intersect_range_factor_range(isl::union_map factor) const
|
||||
{
|
||||
if (!ptr || factor.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_union_map_intersect_range_factor_range(copy(), factor.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
bool union_map::is_bijective() const
|
||||
{
|
||||
if (!ptr)
|
||||
@ -17557,6 +17865,18 @@ bool union_pw_multi_aff::plain_is_empty() const
|
||||
return res;
|
||||
}
|
||||
|
||||
isl::union_pw_multi_aff union_pw_multi_aff::preimage_domain_wrapped_domain(isl::union_pw_multi_aff upma2) const
|
||||
{
|
||||
if (!ptr || upma2.is_null())
|
||||
exception::throw_invalid("NULL input", __FILE__, __LINE__);
|
||||
auto saved_ctx = ctx();
|
||||
options_scoped_set_on_error saved_on_error(saved_ctx, exception::on_error);
|
||||
auto res = isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(copy(), upma2.release());
|
||||
if (!res)
|
||||
exception::throw_last_error(saved_ctx);
|
||||
return manage(res);
|
||||
}
|
||||
|
||||
isl::union_pw_multi_aff union_pw_multi_aff::pullback(isl::union_pw_multi_aff upma2) const
|
||||
{
|
||||
if (!ptr || upma2.is_null())
|
||||
|
16
polly/lib/External/isl/include/isl/map.h
vendored
16
polly/lib/External/isl/include/isl/map.h
vendored
@ -203,12 +203,6 @@ __isl_give isl_basic_map *isl_basic_map_upper_bound_si(
|
||||
__isl_take isl_basic_map *bmap,
|
||||
enum isl_dim_type type, unsigned pos, int value);
|
||||
__isl_overload
|
||||
__isl_give isl_map *isl_map_lower_bound_multi_val(__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *lower);
|
||||
__isl_overload
|
||||
__isl_give isl_map *isl_map_upper_bound_multi_val(__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *upper);
|
||||
__isl_overload
|
||||
__isl_give isl_map *isl_map_lower_bound_multi_pw_aff(__isl_take isl_map *map,
|
||||
__isl_take isl_multi_pw_aff *lower);
|
||||
__isl_overload
|
||||
@ -327,10 +321,16 @@ __isl_export
|
||||
__isl_give isl_map *isl_map_intersect_range(
|
||||
__isl_take isl_map *map,
|
||||
__isl_take isl_set *set);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_intersect_domain_factor_range(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_intersect_range_factor_domain(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_intersect_range_factor_range(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor);
|
||||
__isl_export
|
||||
@ -358,6 +358,7 @@ __isl_give isl_map *isl_map_preimage_domain_multi_pw_aff(
|
||||
__isl_take isl_map *map, __isl_take isl_multi_pw_aff *mpa);
|
||||
__isl_give isl_basic_map *isl_basic_map_product(
|
||||
__isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_product(__isl_take isl_map *map1,
|
||||
__isl_take isl_map *map2);
|
||||
__isl_give isl_basic_map *isl_basic_map_domain_product(
|
||||
@ -497,6 +498,8 @@ __isl_give isl_basic_map *isl_basic_map_order_gt(__isl_take isl_basic_map *bmap,
|
||||
__isl_give isl_map *isl_map_order_gt(__isl_take isl_map *map,
|
||||
enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2);
|
||||
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_set_translation(__isl_take isl_set *deltas);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_set_identity(__isl_take isl_set *set);
|
||||
|
||||
@ -593,6 +596,7 @@ isl_bool isl_map_has_equal_space(__isl_keep isl_map *map1,
|
||||
isl_bool isl_basic_map_can_zip(__isl_keep isl_basic_map *bmap);
|
||||
isl_bool isl_map_can_zip(__isl_keep isl_map *map);
|
||||
__isl_give isl_basic_map *isl_basic_map_zip(__isl_take isl_basic_map *bmap);
|
||||
__isl_export
|
||||
__isl_give isl_map *isl_map_zip(__isl_take isl_map *map);
|
||||
|
||||
isl_bool isl_basic_map_can_curry(__isl_keep isl_basic_map *bmap);
|
||||
|
1
polly/lib/External/isl/include/isl/multi.h
vendored
1
polly/lib/External/isl/include/isl/multi.h
vendored
@ -144,6 +144,7 @@ __isl_give isl_multi_##BASE *isl_multi_##BASE##_zero( \
|
||||
__isl_take isl_space *space);
|
||||
|
||||
#define ISL_DECLARE_MULTI_NAN(BASE) \
|
||||
__isl_export \
|
||||
isl_bool isl_multi_##BASE##_involves_nan( \
|
||||
__isl_keep isl_multi_##BASE *multi);
|
||||
|
||||
|
@ -315,7 +315,8 @@ __isl_null isl_qpolynomial_fold *isl_qpolynomial_fold_free(
|
||||
|
||||
isl_bool isl_qpolynomial_fold_is_empty(__isl_keep isl_qpolynomial_fold *fold);
|
||||
isl_bool isl_qpolynomial_fold_is_nan(__isl_keep isl_qpolynomial_fold *fold);
|
||||
int isl_qpolynomial_fold_plain_is_equal(__isl_keep isl_qpolynomial_fold *fold1,
|
||||
isl_bool isl_qpolynomial_fold_plain_is_equal(
|
||||
__isl_keep isl_qpolynomial_fold *fold1,
|
||||
__isl_keep isl_qpolynomial_fold *fold2);
|
||||
|
||||
__isl_give isl_space *isl_qpolynomial_fold_get_domain_space(
|
||||
@ -487,6 +488,8 @@ isl_bool isl_pw_qpolynomial_fold_isa_qpolynomial_fold(
|
||||
__isl_give isl_qpolynomial_fold *isl_pw_qpolynomial_fold_as_qpolynomial_fold(
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf);
|
||||
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_read_from_str(
|
||||
isl_ctx *ctx, const char *str);
|
||||
__isl_give isl_printer *isl_printer_print_pw_qpolynomial_fold(
|
||||
__isl_take isl_printer *p, __isl_keep isl_pw_qpolynomial_fold *pwf);
|
||||
void isl_pw_qpolynomial_fold_print(__isl_keep isl_pw_qpolynomial_fold *pwf,
|
||||
@ -814,6 +817,7 @@ __isl_give isl_union_pw_qpolynomial_fold *isl_union_map_apply_union_pw_qpolynomi
|
||||
__isl_give isl_union_pw_qpolynomial *isl_union_pw_qpolynomial_to_polynomial(
|
||||
__isl_take isl_union_pw_qpolynomial *upwqp, int sign);
|
||||
|
||||
ISL_DECLARE_LIST_FN(qpolynomial)
|
||||
ISL_DECLARE_LIST_FN(pw_qpolynomial)
|
||||
ISL_DECLARE_LIST_FN(pw_qpolynomial_fold)
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
struct isl_qpolynomial;
|
||||
typedef struct isl_qpolynomial isl_qpolynomial;
|
||||
|
||||
ISL_DECLARE_LIST_TYPE(qpolynomial)
|
||||
|
||||
struct isl_term;
|
||||
typedef struct isl_term isl_term;
|
||||
|
||||
|
@ -144,6 +144,7 @@ isl_bool isl_schedule_plain_is_equal(__isl_keep isl_schedule *schedule1,
|
||||
__isl_export
|
||||
__isl_give isl_schedule_node *isl_schedule_get_root(
|
||||
__isl_keep isl_schedule *schedule);
|
||||
__isl_export
|
||||
__isl_give isl_union_set *isl_schedule_get_domain(
|
||||
__isl_keep isl_schedule *schedule);
|
||||
|
||||
|
5
polly/lib/External/isl/include/isl/space.h
vendored
5
polly/lib/External/isl/include/isl/space.h
vendored
@ -85,6 +85,7 @@ __isl_give isl_space *isl_space_insert_dims(__isl_take isl_space *space,
|
||||
enum isl_dim_type type, unsigned pos, unsigned n);
|
||||
__isl_give isl_space *isl_space_join(__isl_take isl_space *left,
|
||||
__isl_take isl_space *right);
|
||||
__isl_export
|
||||
__isl_give isl_space *isl_space_product(__isl_take isl_space *left,
|
||||
__isl_take isl_space *right);
|
||||
__isl_give isl_space *isl_space_domain_product(__isl_take isl_space *left,
|
||||
@ -105,7 +106,9 @@ __isl_export
|
||||
__isl_give isl_space *isl_space_map_from_set(__isl_take isl_space *space);
|
||||
__isl_give isl_space *isl_space_map_from_domain_and_range(
|
||||
__isl_take isl_space *domain, __isl_take isl_space *range);
|
||||
__isl_export
|
||||
__isl_give isl_space *isl_space_reverse(__isl_take isl_space *space);
|
||||
__isl_export
|
||||
__isl_give isl_space *isl_space_range_reverse(__isl_take isl_space *space);
|
||||
__isl_give isl_space *isl_space_drop_dims(__isl_take isl_space *space,
|
||||
enum isl_dim_type type, unsigned first, unsigned num);
|
||||
@ -151,12 +154,14 @@ isl_bool isl_space_can_zip(__isl_keep isl_space *space);
|
||||
__isl_give isl_space *isl_space_zip(__isl_take isl_space *space);
|
||||
|
||||
isl_bool isl_space_can_curry(__isl_keep isl_space *space);
|
||||
__isl_export
|
||||
__isl_give isl_space *isl_space_curry(__isl_take isl_space *space);
|
||||
|
||||
isl_bool isl_space_can_range_curry(__isl_keep isl_space *space);
|
||||
__isl_give isl_space *isl_space_range_curry(__isl_take isl_space *space);
|
||||
|
||||
isl_bool isl_space_can_uncurry(__isl_keep isl_space *space);
|
||||
__isl_export
|
||||
__isl_give isl_space *isl_space_uncurry(__isl_take isl_space *space);
|
||||
|
||||
isl_bool isl_space_is_domain(__isl_keep isl_space *space1,
|
||||
|
12
polly/lib/External/isl/include/isl/union_map.h
vendored
12
polly/lib/External/isl/include/isl/union_map.h
vendored
@ -164,10 +164,16 @@ __isl_give isl_union_map *isl_union_map_intersect_range_space(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_space *space);
|
||||
__isl_give isl_union_map *isl_union_map_intersect_range(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
|
||||
__isl_export
|
||||
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_range(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_union_map *isl_union_map_intersect_range_factor_domain(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
|
||||
__isl_export
|
||||
__isl_give isl_union_map *isl_union_map_intersect_range_factor_range(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor);
|
||||
|
||||
@ -310,9 +316,15 @@ __isl_overload
|
||||
__isl_give isl_union_map *isl_union_map_eq_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *isl_union_map_lex_le_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *isl_union_map_lex_lt_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *isl_union_map_lex_ge_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
__isl_give isl_union_map *isl_union_map_lex_gt_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa);
|
||||
|
36
polly/lib/External/isl/install-sh
vendored
36
polly/lib/External/isl/install-sh
vendored
@ -1,7 +1,7 @@
|
||||
#!/bin/sh
|
||||
# install - install a program, script, or datafile
|
||||
|
||||
scriptversion=2014-09-12.12; # UTC
|
||||
scriptversion=2018-03-11.20; # UTC
|
||||
|
||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
||||
@ -271,15 +271,18 @@ do
|
||||
fi
|
||||
dst=$dst_arg
|
||||
|
||||
# If destination is a directory, append the input filename; won't work
|
||||
# if double slashes aren't ignored.
|
||||
# If destination is a directory, append the input filename.
|
||||
if test -d "$dst"; then
|
||||
if test "$is_target_a_directory" = never; then
|
||||
echo "$0: $dst_arg: Is a directory" >&2
|
||||
exit 1
|
||||
fi
|
||||
dstdir=$dst
|
||||
dst=$dstdir/`basename "$src"`
|
||||
dstbase=`basename "$src"`
|
||||
case $dst in
|
||||
*/) dst=$dst$dstbase;;
|
||||
*) dst=$dst/$dstbase;;
|
||||
esac
|
||||
dstdir_status=0
|
||||
else
|
||||
dstdir=`dirname "$dst"`
|
||||
@ -288,6 +291,11 @@ do
|
||||
fi
|
||||
fi
|
||||
|
||||
case $dstdir in
|
||||
*/) dstdirslash=$dstdir;;
|
||||
*) dstdirslash=$dstdir/;;
|
||||
esac
|
||||
|
||||
obsolete_mkdir_used=false
|
||||
|
||||
if test $dstdir_status != 0; then
|
||||
@ -324,14 +332,16 @@ do
|
||||
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
||||
;;
|
||||
*)
|
||||
# $RANDOM is not portable (e.g. dash); use it when possible to
|
||||
# lower collision chance
|
||||
# Note that $RANDOM variable is not portable (e.g. dash); Use it
|
||||
# here however when possible just to lower collision chance.
|
||||
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
||||
|
||||
trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
|
||||
|
||||
# As "mkdir -p" follows symlinks and we work in /tmp possibly; so
|
||||
# create the $tmpdir first (and fail if unsuccessful) to make sure
|
||||
# that nobody tries to guess the $tmpdir name.
|
||||
# Because "mkdir -p" follows existing symlinks and we likely work
|
||||
# directly in world-writeable /tmp, make sure that the '$tmpdir'
|
||||
# directory is successfully created first before we actually test
|
||||
# 'mkdir -p' feature.
|
||||
if (umask $mkdir_umask &&
|
||||
$mkdirprog $mkdir_mode "$tmpdir" &&
|
||||
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
|
||||
@ -434,8 +444,8 @@ do
|
||||
else
|
||||
|
||||
# Make a couple of temp file names in the proper directory.
|
||||
dsttmp=$dstdir/_inst.$$_
|
||||
rmtmp=$dstdir/_rm.$$_
|
||||
dsttmp=${dstdirslash}_inst.$$_
|
||||
rmtmp=${dstdirslash}_rm.$$_
|
||||
|
||||
# Trap to clean up those temp files at exit.
|
||||
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
||||
@ -500,9 +510,9 @@ do
|
||||
done
|
||||
|
||||
# Local variables:
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
80
polly/lib/External/isl/interface/Makefile.in
vendored
80
polly/lib/External/isl/interface/Makefile.in
vendored
@ -1,7 +1,7 @@
|
||||
# Makefile.in generated by automake 1.15.1 from Makefile.am.
|
||||
# Makefile.in generated by automake 1.16.1 from Makefile.am.
|
||||
# @configure_input@
|
||||
|
||||
# Copyright (C) 1994-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This Makefile.in is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -141,7 +141,12 @@ am__v_at_0 = @
|
||||
am__v_at_1 =
|
||||
DEFAULT_INCLUDES =
|
||||
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
||||
am__depfiles_maybe = depfiles
|
||||
am__maybe_remake_depfiles = depfiles
|
||||
am__depfiles_remade = ./$(DEPDIR)/extract_interface-cpp.Po \
|
||||
./$(DEPDIR)/extract_interface-cpp_conversion.Po \
|
||||
./$(DEPDIR)/extract_interface-extract_interface.Po \
|
||||
./$(DEPDIR)/extract_interface-generator.Po \
|
||||
./$(DEPDIR)/extract_interface-python.Po
|
||||
am__mv = mv -f
|
||||
CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
|
||||
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
@ -416,8 +421,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||
echo ' $(SHELL) ./config.status'; \
|
||||
$(SHELL) ./config.status;; \
|
||||
*) \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
|
||||
esac;
|
||||
|
||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||
@ -463,11 +468,17 @@ mostlyclean-compile:
|
||||
distclean-compile:
|
||||
-rm -f *.tab.c
|
||||
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp_conversion.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-extract_interface.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-generator.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-python.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-cpp_conversion.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-extract_interface.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-generator.Po@am__quote@ # am--include-marker
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/extract_interface-python.Po@am__quote@ # am--include-marker
|
||||
|
||||
$(am__depfiles_remade):
|
||||
@$(MKDIR_P) $(@D)
|
||||
@echo '# dummy' >$@-t && $(am__mv) $@-t $@
|
||||
|
||||
am--depfiles: $(am__depfiles_remade)
|
||||
|
||||
.cc.o:
|
||||
@am__fastdepCXX_TRUE@ $(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
||||
@ -628,7 +639,10 @@ distclean-tags:
|
||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
||||
-rm -f cscope.out cscope.in.out cscope.po.out cscope.files
|
||||
|
||||
distdir: $(DISTFILES)
|
||||
distdir: $(BUILT_SOURCES)
|
||||
$(MAKE) $(AM_MAKEFLAGS) distdir-am
|
||||
|
||||
distdir-am: $(DISTFILES)
|
||||
$(am__remove_distdir)
|
||||
test -d "$(distdir)" || mkdir "$(distdir)"
|
||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
@ -832,7 +846,11 @@ clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \
|
||||
|
||||
distclean: distclean-am
|
||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||
-rm -rf ./$(DEPDIR)
|
||||
-rm -f ./$(DEPDIR)/extract_interface-cpp.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-cpp_conversion.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-extract_interface.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-generator.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-python.Po
|
||||
-rm -f Makefile
|
||||
distclean-am: clean-am distclean-compile distclean-generic \
|
||||
distclean-hdr distclean-libtool distclean-tags
|
||||
@ -880,7 +898,11 @@ installcheck-am:
|
||||
maintainer-clean: maintainer-clean-am
|
||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||
-rm -rf $(top_srcdir)/autom4te.cache
|
||||
-rm -rf ./$(DEPDIR)
|
||||
-rm -f ./$(DEPDIR)/extract_interface-cpp.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-cpp_conversion.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-extract_interface.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-generator.Po
|
||||
-rm -f ./$(DEPDIR)/extract_interface-python.Po
|
||||
-rm -f Makefile
|
||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||
|
||||
@ -901,22 +923,22 @@ uninstall-am:
|
||||
|
||||
.MAKE: all install-am install-strip
|
||||
|
||||
.PHONY: CTAGS GTAGS TAGS all all-am am--refresh check check-am clean \
|
||||
clean-cscope clean-generic clean-libtool clean-noinstPROGRAMS \
|
||||
cscope cscopelist-am ctags ctags-am dist dist-all dist-bzip2 \
|
||||
dist-gzip dist-lzip dist-shar dist-tarZ dist-xz dist-zip \
|
||||
distcheck distclean distclean-compile distclean-generic \
|
||||
distclean-hdr distclean-libtool distclean-tags distcleancheck \
|
||||
distdir distuninstallcheck dvi dvi-am html html-am info \
|
||||
info-am install install-am install-data install-data-am \
|
||||
install-dvi install-dvi-am install-exec install-exec-am \
|
||||
install-html install-html-am install-info install-info-am \
|
||||
install-man install-pdf install-pdf-am install-ps \
|
||||
install-ps-am install-strip installcheck installcheck-am \
|
||||
installdirs maintainer-clean maintainer-clean-generic \
|
||||
mostlyclean mostlyclean-compile mostlyclean-generic \
|
||||
mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \
|
||||
uninstall-am
|
||||
.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles am--refresh check \
|
||||
check-am clean clean-cscope clean-generic clean-libtool \
|
||||
clean-noinstPROGRAMS cscope cscopelist-am ctags ctags-am dist \
|
||||
dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \
|
||||
dist-xz dist-zip distcheck distclean distclean-compile \
|
||||
distclean-generic distclean-hdr distclean-libtool \
|
||||
distclean-tags distcleancheck distdir distuninstallcheck dvi \
|
||||
dvi-am html html-am info info-am install install-am \
|
||||
install-data install-data-am install-dvi install-dvi-am \
|
||||
install-exec install-exec-am install-html install-html-am \
|
||||
install-info install-info-am install-man install-pdf \
|
||||
install-pdf-am install-ps install-ps-am install-strip \
|
||||
installcheck installcheck-am installdirs maintainer-clean \
|
||||
maintainer-clean-generic mostlyclean mostlyclean-compile \
|
||||
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
|
||||
tags tags-am uninstall uninstall-am
|
||||
|
||||
.PRECIOUS: Makefile
|
||||
|
||||
|
189
polly/lib/External/isl/interface/aclocal.m4
vendored
189
polly/lib/External/isl/interface/aclocal.m4
vendored
@ -1,6 +1,6 @@
|
||||
# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
|
||||
# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -20,7 +20,7 @@ You have another version of autoconf. It may work, but is not guaranteed to.
|
||||
If you have problems, you may need to regenerate the build system entirely.
|
||||
To do so, use the procedure documented by the package, typically 'autoreconf'.])])
|
||||
|
||||
# Copyright (C) 2002-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2002-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
|
||||
# generated from the m4 files accompanying Automake X.Y.
|
||||
# (This private macro should not be called outside this file.)
|
||||
AC_DEFUN([AM_AUTOMAKE_VERSION],
|
||||
[am__api_version='1.15'
|
||||
[am__api_version='1.16'
|
||||
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
|
||||
dnl require some minimum version. Point them to the right macro.
|
||||
m4_if([$1], [1.15.1], [],
|
||||
m4_if([$1], [1.16.1], [],
|
||||
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
|
||||
])
|
||||
|
||||
@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
|
||||
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
|
||||
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
|
||||
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
|
||||
[AM_AUTOMAKE_VERSION([1.15.1])dnl
|
||||
[AM_AUTOMAKE_VERSION([1.16.1])dnl
|
||||
m4_ifndef([AC_AUTOCONF_VERSION],
|
||||
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
||||
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
|
||||
|
||||
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -110,7 +110,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
|
||||
|
||||
# AM_CONDITIONAL -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -141,7 +141,7 @@ AC_CONFIG_COMMANDS_PRE(
|
||||
Usually this means the macro was only invoked conditionally.]])
|
||||
fi])])
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -332,13 +332,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
|
||||
|
||||
# Generate code to set up dependency tracking. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
# with or without modifications, as long as this notice is preserved.
|
||||
|
||||
|
||||
# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||
# ------------------------------
|
||||
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
@ -346,49 +345,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
# Older Autoconf quotes --file arguments for eval, but not when files
|
||||
# are listed without --file. Let's play safe and only enable the eval
|
||||
# if we detect the quoting.
|
||||
case $CONFIG_FILES in
|
||||
*\'*) eval set x "$CONFIG_FILES" ;;
|
||||
*) set x $CONFIG_FILES ;;
|
||||
esac
|
||||
# TODO: see whether this extra hack can be removed once we start
|
||||
# requiring Autoconf 2.70 or later.
|
||||
AS_CASE([$CONFIG_FILES],
|
||||
[*\'*], [eval set x "$CONFIG_FILES"],
|
||||
[*], [set x $CONFIG_FILES])
|
||||
shift
|
||||
for mf
|
||||
# Used to flag and report bootstrapping failures.
|
||||
am_rc=0
|
||||
for am_mf
|
||||
do
|
||||
# Strip MF so we end up with the name of the file.
|
||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile or not.
|
||||
# We used to match only the files named 'Makefile.in', but
|
||||
# some people rename them; so instead we look at the file content.
|
||||
# Grep'ing the first line is not enough: some people post-process
|
||||
# each Makefile.in and add a new line on top of each file to say so.
|
||||
# Grep'ing the whole file is not good either: AIX grep has a line
|
||||
am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile which includes
|
||||
# dependency-tracking related rules and includes.
|
||||
# Grep'ing the whole file directly is not great: AIX grep has a line
|
||||
# limit of 2048, but all sed's we know have understand at least 4000.
|
||||
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
||||
dirpart=`AS_DIRNAME("$mf")`
|
||||
else
|
||||
continue
|
||||
fi
|
||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
||||
# from the Makefile without running 'make'.
|
||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
||||
test -z "$DEPDIR" && continue
|
||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
||||
test -z "$am__include" && continue
|
||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
||||
# Find all dependency output files, they are included files with
|
||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
||||
# expansion.
|
||||
for file in `sed -n "
|
||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
|
||||
# Make sure the directory exists.
|
||||
test -f "$dirpart/$file" && continue
|
||||
fdir=`AS_DIRNAME(["$file"])`
|
||||
AS_MKDIR_P([$dirpart/$fdir])
|
||||
# echo "creating $dirpart/$file"
|
||||
echo '# dummy' > "$dirpart/$file"
|
||||
done
|
||||
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|
||||
|| continue
|
||||
am_dirpart=`AS_DIRNAME(["$am_mf"])`
|
||||
am_filepart=`AS_BASENAME(["$am_mf"])`
|
||||
AM_RUN_LOG([cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles]) || am_rc=$?
|
||||
done
|
||||
if test $am_rc -ne 0; then
|
||||
AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
|
||||
for automatic dependency tracking. Try re-running configure with the
|
||||
'--disable-dependency-tracking' option to at least be able to build
|
||||
the package (albeit without support for automatic dependency tracking).])
|
||||
fi
|
||||
AS_UNSET([am_dirpart])
|
||||
AS_UNSET([am_filepart])
|
||||
AS_UNSET([am_mf])
|
||||
AS_UNSET([am_rc])
|
||||
rm -f conftest-deps.mk
|
||||
}
|
||||
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||
|
||||
@ -397,18 +388,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
# -----------------------------
|
||||
# This macro should only be invoked once -- use via AC_REQUIRE.
|
||||
#
|
||||
# This code is only required when automatic dependency tracking
|
||||
# is enabled. FIXME. This creates each '.P' file that we will
|
||||
# need in order to bootstrap the dependency handling code.
|
||||
# This code is only required when automatic dependency tracking is enabled.
|
||||
# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
|
||||
# order to bootstrap the dependency handling code.
|
||||
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
[AC_CONFIG_COMMANDS([depfiles],
|
||||
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
|
||||
])
|
||||
[AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
|
||||
|
||||
# Do all the work for Automake. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -495,8 +485,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
|
||||
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
|
||||
# For better backward compatibility. To be removed once Automake 1.9.x
|
||||
# dies out for good. For more background, see:
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
|
||||
# We need awk for the "check" target (and possibly the TAP driver). The
|
||||
# system "awk" is bad on some platforms.
|
||||
@ -563,7 +553,7 @@ END
|
||||
Aborting the configuration process, to ensure you take notice of the issue.
|
||||
|
||||
You can download and install GNU coreutils to get an 'rm' implementation
|
||||
that behaves properly: <http://www.gnu.org/software/coreutils/>.
|
||||
that behaves properly: <https://www.gnu.org/software/coreutils/>.
|
||||
|
||||
If you want to complete the configuration process using your problematic
|
||||
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
|
||||
@ -605,7 +595,7 @@ for _am_header in $config_headers :; do
|
||||
done
|
||||
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -626,7 +616,7 @@ if test x"${install_sh+set}" != xset; then
|
||||
fi
|
||||
AC_SUBST([install_sh])])
|
||||
|
||||
# Copyright (C) 2003-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2003-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -647,7 +637,7 @@ AC_SUBST([am__leading_dot])])
|
||||
|
||||
# Check to see how 'make' treats includes. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -655,49 +645,42 @@ AC_SUBST([am__leading_dot])])
|
||||
|
||||
# AM_MAKE_INCLUDE()
|
||||
# -----------------
|
||||
# Check to see how make treats includes.
|
||||
# Check whether make has an 'include' directive that can support all
|
||||
# the idioms we need for our automatic dependency tracking code.
|
||||
AC_DEFUN([AM_MAKE_INCLUDE],
|
||||
[am_make=${MAKE-make}
|
||||
cat > confinc << 'END'
|
||||
[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
|
||||
cat > confinc.mk << 'END'
|
||||
am__doit:
|
||||
@echo this is the am__doit target
|
||||
@echo this is the am__doit target >confinc.out
|
||||
.PHONY: am__doit
|
||||
END
|
||||
# If we don't find an include directive, just comment out the code.
|
||||
AC_MSG_CHECKING([for style of include used by $am_make])
|
||||
am__include="#"
|
||||
am__quote=
|
||||
_am_result=none
|
||||
# First try GNU make style include.
|
||||
echo "include confinc" > confmf
|
||||
# Ignore all kinds of additional output from 'make'.
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=include
|
||||
am__quote=
|
||||
_am_result=GNU
|
||||
;;
|
||||
esac
|
||||
# Now try BSD make style include.
|
||||
if test "$am__include" = "#"; then
|
||||
echo '.include "confinc"' > confmf
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=.include
|
||||
am__quote="\""
|
||||
_am_result=BSD
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
AC_SUBST([am__include])
|
||||
AC_SUBST([am__quote])
|
||||
AC_MSG_RESULT([$_am_result])
|
||||
rm -f confinc confmf
|
||||
])
|
||||
# BSD make does it like this.
|
||||
echo '.include "confinc.mk" # ignored' > confmf.BSD
|
||||
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
|
||||
echo 'include confinc.mk # ignored' > confmf.GNU
|
||||
_am_result=no
|
||||
for s in GNU BSD; do
|
||||
AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
|
||||
AS_CASE([$?:`cat confinc.out 2>/dev/null`],
|
||||
['0:this is the am__doit target'],
|
||||
[AS_CASE([$s],
|
||||
[BSD], [am__include='.include' am__quote='"'],
|
||||
[am__include='include' am__quote=''])])
|
||||
if test "$am__include" != "#"; then
|
||||
_am_result="yes ($s style)"
|
||||
break
|
||||
fi
|
||||
done
|
||||
rm -f confinc.* confmf.*
|
||||
AC_MSG_RESULT([${_am_result}])
|
||||
AC_SUBST([am__include])])
|
||||
AC_SUBST([am__quote])])
|
||||
|
||||
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1997-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1997-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -736,7 +719,7 @@ fi
|
||||
|
||||
# Helper functions for option handling. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -765,7 +748,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
|
||||
AC_DEFUN([_AM_IF_OPTION],
|
||||
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -812,7 +795,7 @@ AC_LANG_POP([C])])
|
||||
# For backward compatibility.
|
||||
AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -831,7 +814,7 @@ AC_DEFUN([AM_RUN_LOG],
|
||||
|
||||
# Check to make sure that the build environment is sane. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 1996-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -912,7 +895,7 @@ AC_CONFIG_COMMANDS_PRE(
|
||||
rm -f conftest.file
|
||||
])
|
||||
|
||||
# Copyright (C) 2009-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2009-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -972,7 +955,7 @@ AC_SUBST([AM_BACKSLASH])dnl
|
||||
_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
|
||||
])
|
||||
|
||||
# Copyright (C) 2001-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2001-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1000,7 +983,7 @@ fi
|
||||
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
|
||||
AC_SUBST([INSTALL_STRIP_PROGRAM])])
|
||||
|
||||
# Copyright (C) 2006-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2006-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
@ -1019,7 +1002,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
|
||||
|
||||
# Check how to create a tarball. -*- Autoconf -*-
|
||||
|
||||
# Copyright (C) 2004-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2004-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This file is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
|
13
polly/lib/External/isl/interface/compile
vendored
13
polly/lib/External/isl/interface/compile
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# Wrapper for compilers which do not understand '-c -o'.
|
||||
|
||||
scriptversion=2012-10-14.11; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1999-2014 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
# Written by Tom Tromey <tromey@cygnus.com>.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
@ -17,7 +17,7 @@ scriptversion=2012-10-14.11; # UTC
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -255,7 +255,8 @@ EOF
|
||||
echo "compile $scriptversion"
|
||||
exit $?
|
||||
;;
|
||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
|
||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
|
||||
icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
|
||||
func_cl_wrapper "$@" # Doesn't return...
|
||||
;;
|
||||
esac
|
||||
@ -339,9 +340,9 @@ exit $ret
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
222
polly/lib/External/isl/interface/configure
vendored
222
polly/lib/External/isl/interface/configure
vendored
@ -700,7 +700,6 @@ am__nodep
|
||||
AMDEPBACKSLASH
|
||||
AMDEP_FALSE
|
||||
AMDEP_TRUE
|
||||
am__quote
|
||||
am__include
|
||||
DEPDIR
|
||||
OBJEXT
|
||||
@ -775,7 +774,8 @@ PACKAGE_VERSION
|
||||
PACKAGE_TARNAME
|
||||
PACKAGE_NAME
|
||||
PATH_SEPARATOR
|
||||
SHELL'
|
||||
SHELL
|
||||
am__quote'
|
||||
ac_subst_files=''
|
||||
ac_user_opts='
|
||||
enable_option_checking
|
||||
@ -2437,7 +2437,7 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
|
||||
|
||||
|
||||
|
||||
am__api_version='1.15'
|
||||
am__api_version='1.16'
|
||||
|
||||
# Find a good install program. We prefer a C program (faster),
|
||||
# so one script is as good as another. But avoid the broken or
|
||||
@ -2953,8 +2953,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
|
||||
|
||||
# For better backward compatibility. To be removed once Automake 1.9.x
|
||||
# dies out for good. For more background, see:
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
|
||||
# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
|
||||
mkdir_p='$(MKDIR_P)'
|
||||
|
||||
# We need awk for the "check" target (and possibly the TAP driver). The
|
||||
@ -3005,7 +3005,7 @@ END
|
||||
Aborting the configuration process, to ensure you take notice of the issue.
|
||||
|
||||
You can download and install GNU coreutils to get an 'rm' implementation
|
||||
that behaves properly: <http://www.gnu.org/software/coreutils/>.
|
||||
that behaves properly: <https://www.gnu.org/software/coreutils/>.
|
||||
|
||||
If you want to complete the configuration process using your problematic
|
||||
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
|
||||
@ -3566,45 +3566,45 @@ DEPDIR="${am__leading_dot}deps"
|
||||
|
||||
ac_config_commands="$ac_config_commands depfiles"
|
||||
|
||||
|
||||
am_make=${MAKE-make}
|
||||
cat > confinc << 'END'
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
|
||||
$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
|
||||
cat > confinc.mk << 'END'
|
||||
am__doit:
|
||||
@echo this is the am__doit target
|
||||
@echo this is the am__doit target >confinc.out
|
||||
.PHONY: am__doit
|
||||
END
|
||||
# If we don't find an include directive, just comment out the code.
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
|
||||
$as_echo_n "checking for style of include used by $am_make... " >&6; }
|
||||
am__include="#"
|
||||
am__quote=
|
||||
_am_result=none
|
||||
# First try GNU make style include.
|
||||
echo "include confinc" > confmf
|
||||
# Ignore all kinds of additional output from 'make'.
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=include
|
||||
am__quote=
|
||||
_am_result=GNU
|
||||
;;
|
||||
esac
|
||||
# Now try BSD make style include.
|
||||
if test "$am__include" = "#"; then
|
||||
echo '.include "confinc"' > confmf
|
||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||
*the\ am__doit\ target*)
|
||||
am__include=.include
|
||||
am__quote="\""
|
||||
_am_result=BSD
|
||||
# BSD make does it like this.
|
||||
echo '.include "confinc.mk" # ignored' > confmf.BSD
|
||||
# Other make implementations (GNU, Solaris 10, AIX) do it like this.
|
||||
echo 'include confinc.mk # ignored' > confmf.GNU
|
||||
_am_result=no
|
||||
for s in GNU BSD; do
|
||||
{ echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
|
||||
(${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
|
||||
ac_status=$?
|
||||
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||
(exit $ac_status); }
|
||||
case $?:`cat confinc.out 2>/dev/null` in #(
|
||||
'0:this is the am__doit target') :
|
||||
case $s in #(
|
||||
BSD) :
|
||||
am__include='.include' am__quote='"' ;; #(
|
||||
*) :
|
||||
am__include='include' am__quote='' ;;
|
||||
esac ;; #(
|
||||
*) :
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
|
||||
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
|
||||
$as_echo "$_am_result" >&6; }
|
||||
rm -f confinc confmf
|
||||
esac
|
||||
if test "$am__include" != "#"; then
|
||||
_am_result="yes ($s style)"
|
||||
break
|
||||
fi
|
||||
done
|
||||
rm -f confinc.* confmf.*
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
|
||||
$as_echo "${_am_result}" >&6; }
|
||||
|
||||
# Check whether --enable-dependency-tracking was given.
|
||||
if test "${enable_dependency_tracking+set}" = set; then :
|
||||
@ -8137,7 +8137,7 @@ esac
|
||||
fi
|
||||
|
||||
: ${AR=ar}
|
||||
: ${AR_FLAGS=cru}
|
||||
: ${AR_FLAGS=cr}
|
||||
|
||||
|
||||
|
||||
@ -8638,11 +8638,8 @@ _LT_EOF
|
||||
test $ac_status = 0; }; then
|
||||
# Now try to grab the symbols.
|
||||
nlist=conftest.nm
|
||||
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5
|
||||
(eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5
|
||||
ac_status=$?
|
||||
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
|
||||
test $ac_status = 0; } && test -s "$nlist"; then
|
||||
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&5
|
||||
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&5 && test -s "$nlist"; then
|
||||
# Try sorting and uniquifying the output.
|
||||
if sort "$nlist" | uniq > "$nlist"T; then
|
||||
mv -f "$nlist"T "$nlist"
|
||||
@ -9861,8 +9858,8 @@ int forced_loaded() { return 2;}
|
||||
_LT_EOF
|
||||
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5
|
||||
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5
|
||||
echo "$AR cru libconftest.a conftest.o" >&5
|
||||
$AR cru libconftest.a conftest.o 2>&5
|
||||
echo "$AR cr libconftest.a conftest.o" >&5
|
||||
$AR cr libconftest.a conftest.o 2>&5
|
||||
echo "$RANLIB libconftest.a" >&5
|
||||
$RANLIB libconftest.a 2>&5
|
||||
cat > conftest.c << _LT_EOF
|
||||
@ -10835,6 +10832,12 @@ lt_prog_compiler_static=
|
||||
lt_prog_compiler_pic='-KPIC'
|
||||
lt_prog_compiler_static='-static'
|
||||
;;
|
||||
# flang / f18. f95 an alias for gfortran or flang on Debian
|
||||
flang* | f18* | f95*)
|
||||
lt_prog_compiler_wl='-Wl,'
|
||||
lt_prog_compiler_pic='-fPIC'
|
||||
lt_prog_compiler_static='-static'
|
||||
;;
|
||||
# icc used to be incompatible with GCC.
|
||||
# ICC 10 doesn't accept -KPIC any more.
|
||||
icc* | ifort*)
|
||||
@ -14777,7 +14780,7 @@ with_gnu_ld=$lt_cv_prog_gnu_ld
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
GXX=no
|
||||
@ -15269,7 +15272,7 @@ fi
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -15334,7 +15337,7 @@ fi
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -15673,7 +15676,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
# FIXME: insert proper C++ library support
|
||||
@ -15757,7 +15760,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
else
|
||||
# g++ 2.7 appears to require '-G' NOT '-shared' on this
|
||||
# platform.
|
||||
@ -15768,7 +15771,7 @@ fi
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
fi
|
||||
|
||||
hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir'
|
||||
@ -19319,7 +19322,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
|
||||
#
|
||||
# INIT-COMMANDS
|
||||
#
|
||||
AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
|
||||
AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
|
||||
|
||||
|
||||
# The HP-UX ksh and POSIX shell print the target directory to stdout
|
||||
@ -20313,29 +20316,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}
|
||||
# Older Autoconf quotes --file arguments for eval, but not when files
|
||||
# are listed without --file. Let's play safe and only enable the eval
|
||||
# if we detect the quoting.
|
||||
case $CONFIG_FILES in
|
||||
*\'*) eval set x "$CONFIG_FILES" ;;
|
||||
*) set x $CONFIG_FILES ;;
|
||||
esac
|
||||
# TODO: see whether this extra hack can be removed once we start
|
||||
# requiring Autoconf 2.70 or later.
|
||||
case $CONFIG_FILES in #(
|
||||
*\'*) :
|
||||
eval set x "$CONFIG_FILES" ;; #(
|
||||
*) :
|
||||
set x $CONFIG_FILES ;; #(
|
||||
*) :
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
for mf
|
||||
# Used to flag and report bootstrapping failures.
|
||||
am_rc=0
|
||||
for am_mf
|
||||
do
|
||||
# Strip MF so we end up with the name of the file.
|
||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile or not.
|
||||
# We used to match only the files named 'Makefile.in', but
|
||||
# some people rename them; so instead we look at the file content.
|
||||
# Grep'ing the first line is not enough: some people post-process
|
||||
# each Makefile.in and add a new line on top of each file to say so.
|
||||
# Grep'ing the whole file is not good either: AIX grep has a line
|
||||
am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
|
||||
# Check whether this is an Automake generated Makefile which includes
|
||||
# dependency-tracking related rules and includes.
|
||||
# Grep'ing the whole file directly is not great: AIX grep has a line
|
||||
# limit of 2048, but all sed's we know have understand at least 4000.
|
||||
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
||||
dirpart=`$as_dirname -- "$mf" ||
|
||||
$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$mf" : 'X\(//\)[^/]' \| \
|
||||
X"$mf" : 'X\(//\)$' \| \
|
||||
X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$mf" |
|
||||
sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
|
||||
|| continue
|
||||
am_dirpart=`$as_dirname -- "$am_mf" ||
|
||||
$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$am_mf" : 'X\(//\)[^/]' \| \
|
||||
X"$am_mf" : 'X\(//\)$' \| \
|
||||
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$am_mf" |
|
||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
||||
s//\1/
|
||||
q
|
||||
@ -20353,53 +20362,48 @@ $as_echo X"$mf" |
|
||||
q
|
||||
}
|
||||
s/.*/./; q'`
|
||||
else
|
||||
continue
|
||||
fi
|
||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
||||
# from the Makefile without running 'make'.
|
||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
||||
test -z "$DEPDIR" && continue
|
||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
||||
test -z "$am__include" && continue
|
||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
||||
# Find all dependency output files, they are included files with
|
||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
||||
# expansion.
|
||||
for file in `sed -n "
|
||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
|
||||
# Make sure the directory exists.
|
||||
test -f "$dirpart/$file" && continue
|
||||
fdir=`$as_dirname -- "$file" ||
|
||||
$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||
X"$file" : 'X\(//\)[^/]' \| \
|
||||
X"$file" : 'X\(//\)$' \| \
|
||||
X"$file" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X"$file" |
|
||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
||||
am_filepart=`$as_basename -- "$am_mf" ||
|
||||
$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
|
||||
X"$am_mf" : 'X\(//\)$' \| \
|
||||
X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
|
||||
$as_echo X/"$am_mf" |
|
||||
sed '/^.*\/\([^/][^/]*\)\/*$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\/\)[^/].*/{
|
||||
/^X\/\(\/\/\)$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\/\)$/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
/^X\(\/\).*/{
|
||||
/^X\/\(\/\).*/{
|
||||
s//\1/
|
||||
q
|
||||
}
|
||||
s/.*/./; q'`
|
||||
as_dir=$dirpart/$fdir; as_fn_mkdir_p
|
||||
# echo "creating $dirpart/$file"
|
||||
echo '# dummy' > "$dirpart/$file"
|
||||
done
|
||||
{ echo "$as_me:$LINENO: cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles" >&5
|
||||
(cd "$am_dirpart" \
|
||||
&& sed -e '/# am--include-marker/d' "$am_filepart" \
|
||||
| $MAKE -f - am--depfiles) >&5 2>&5
|
||||
ac_status=$?
|
||||
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||
(exit $ac_status); } || am_rc=$?
|
||||
done
|
||||
if test $am_rc -ne 0; then
|
||||
{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
|
||||
$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
|
||||
as_fn_error $? "Something went wrong bootstrapping makefile fragments
|
||||
for automatic dependency tracking. Try re-running configure with the
|
||||
'--disable-dependency-tracking' option to at least be able to build
|
||||
the package (albeit without support for automatic dependency tracking).
|
||||
See \`config.log' for more details" "$LINENO" 5; }
|
||||
fi
|
||||
{ am_dirpart=; unset am_dirpart;}
|
||||
{ am_filepart=; unset am_filepart;}
|
||||
{ am_mf=; unset am_mf;}
|
||||
{ am_rc=; unset am_rc;}
|
||||
rm -f conftest-deps.mk
|
||||
}
|
||||
;;
|
||||
"libtool":C)
|
||||
|
12
polly/lib/External/isl/interface/cpp.cc
vendored
12
polly/lib/External/isl/interface/cpp.cc
vendored
@ -397,7 +397,7 @@ void cpp_generator::print_method<cpp_generator::decl>(ostream &os,
|
||||
* inline explicit val(ctx ctx, const std::string &str);
|
||||
*/
|
||||
void cpp_generator::print_constructors_decl(ostream &os,
|
||||
const isl_class &clazz)
|
||||
const isl_class &clazz)
|
||||
{
|
||||
function_set::const_iterator in;
|
||||
const function_set &constructors = clazz.constructors;
|
||||
@ -643,7 +643,7 @@ void cpp_generator::print_persistent_callback_data(ostream &os,
|
||||
* public methods for setting the persistent callbacks.
|
||||
*/
|
||||
void cpp_generator::print_persistent_callbacks_decl(ostream &os,
|
||||
const isl_class &clazz)
|
||||
const isl_class &clazz)
|
||||
{
|
||||
std::string cppstring = type2cpp(clazz);
|
||||
const char *cppname = cppstring.c_str();
|
||||
@ -1223,7 +1223,7 @@ void cpp_generator::print_method<cpp_generator::impl>(ostream &os,
|
||||
/* Print implementations of constructors for class "clazz" to "os".
|
||||
*/
|
||||
void cpp_generator::print_constructors_impl(ostream &os,
|
||||
const isl_class &clazz)
|
||||
const isl_class &clazz)
|
||||
{
|
||||
function_set::const_iterator in;
|
||||
const function_set constructors = clazz.constructors;
|
||||
@ -1405,7 +1405,7 @@ void cpp_generator::print_ctx_impl(ostream &os, const isl_class &clazz)
|
||||
* of "clazz".
|
||||
*/
|
||||
void cpp_generator::print_persistent_callbacks_impl(ostream &os,
|
||||
const isl_class &clazz)
|
||||
const isl_class &clazz)
|
||||
{
|
||||
std::string cppstring = type2cpp(clazz);
|
||||
const char *cppname = cppstring.c_str();
|
||||
@ -1502,7 +1502,6 @@ void cpp_generator::print_set_enums_impl(ostream &os, const isl_class &clazz,
|
||||
const vector<set_enum> &set_enums = clazz.set_enums.at(fd);
|
||||
|
||||
for (it = set_enums.begin(); it != set_enums.end(); ++it) {
|
||||
osprintf(os, "\n");
|
||||
print_set_enum_impl(os, clazz, fd, it->name, it->method_name);
|
||||
}
|
||||
}
|
||||
@ -1984,7 +1983,8 @@ ParmVarDecl *cpp_generator::get_param(FunctionDecl *fd, int pos,
|
||||
* For static functions and constructors all parameters of the original isl
|
||||
* function are exposed.
|
||||
*
|
||||
* Parameters that are defined as __isl_keep or are of type string, are passed
|
||||
* Parameters that are defined as __isl_keep, are of type string or
|
||||
* are callbacks, are passed
|
||||
* as const reference, which allows the compiler to optimize the parameter
|
||||
* transfer.
|
||||
*
|
||||
|
8
polly/lib/External/isl/interface/depcomp
vendored
8
polly/lib/External/isl/interface/depcomp
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# depcomp - compile a program generating dependencies as side-effects
|
||||
|
||||
scriptversion=2016-01-11.22; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1999-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -783,7 +783,7 @@ exit 0
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
|
@ -367,6 +367,8 @@ static bool less_name(const FunctionDecl *a, const FunctionDecl *b)
|
||||
* functions as belonging to the subclasses.
|
||||
* Sort the names of the functions based on their lengths
|
||||
* to ensure that nested subclasses are handled later.
|
||||
*
|
||||
* Also extract information about automatic conversion functions.
|
||||
*/
|
||||
generator::generator(SourceManager &SM, set<RecordDecl *> &exported_types,
|
||||
set<FunctionDecl *> exported_functions, set<FunctionDecl *> functions) :
|
||||
|
36
polly/lib/External/isl/interface/install-sh
vendored
36
polly/lib/External/isl/interface/install-sh
vendored
@ -1,7 +1,7 @@
|
||||
#!/bin/sh
|
||||
# install - install a program, script, or datafile
|
||||
|
||||
scriptversion=2014-09-12.12; # UTC
|
||||
scriptversion=2018-03-11.20; # UTC
|
||||
|
||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
||||
@ -271,15 +271,18 @@ do
|
||||
fi
|
||||
dst=$dst_arg
|
||||
|
||||
# If destination is a directory, append the input filename; won't work
|
||||
# if double slashes aren't ignored.
|
||||
# If destination is a directory, append the input filename.
|
||||
if test -d "$dst"; then
|
||||
if test "$is_target_a_directory" = never; then
|
||||
echo "$0: $dst_arg: Is a directory" >&2
|
||||
exit 1
|
||||
fi
|
||||
dstdir=$dst
|
||||
dst=$dstdir/`basename "$src"`
|
||||
dstbase=`basename "$src"`
|
||||
case $dst in
|
||||
*/) dst=$dst$dstbase;;
|
||||
*) dst=$dst/$dstbase;;
|
||||
esac
|
||||
dstdir_status=0
|
||||
else
|
||||
dstdir=`dirname "$dst"`
|
||||
@ -288,6 +291,11 @@ do
|
||||
fi
|
||||
fi
|
||||
|
||||
case $dstdir in
|
||||
*/) dstdirslash=$dstdir;;
|
||||
*) dstdirslash=$dstdir/;;
|
||||
esac
|
||||
|
||||
obsolete_mkdir_used=false
|
||||
|
||||
if test $dstdir_status != 0; then
|
||||
@ -324,14 +332,16 @@ do
|
||||
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
||||
;;
|
||||
*)
|
||||
# $RANDOM is not portable (e.g. dash); use it when possible to
|
||||
# lower collision chance
|
||||
# Note that $RANDOM variable is not portable (e.g. dash); Use it
|
||||
# here however when possible just to lower collision chance.
|
||||
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
||||
|
||||
trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
|
||||
|
||||
# As "mkdir -p" follows symlinks and we work in /tmp possibly; so
|
||||
# create the $tmpdir first (and fail if unsuccessful) to make sure
|
||||
# that nobody tries to guess the $tmpdir name.
|
||||
# Because "mkdir -p" follows existing symlinks and we likely work
|
||||
# directly in world-writeable /tmp, make sure that the '$tmpdir'
|
||||
# directory is successfully created first before we actually test
|
||||
# 'mkdir -p' feature.
|
||||
if (umask $mkdir_umask &&
|
||||
$mkdirprog $mkdir_mode "$tmpdir" &&
|
||||
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
|
||||
@ -434,8 +444,8 @@ do
|
||||
else
|
||||
|
||||
# Make a couple of temp file names in the proper directory.
|
||||
dsttmp=$dstdir/_inst.$$_
|
||||
rmtmp=$dstdir/_rm.$$_
|
||||
dsttmp=${dstdirslash}_inst.$$_
|
||||
rmtmp=${dstdirslash}_rm.$$_
|
||||
|
||||
# Trap to clean up those temp files at exit.
|
||||
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
||||
@ -500,9 +510,9 @@ do
|
||||
done
|
||||
|
||||
# Local variables:
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
374
polly/lib/External/isl/interface/isl.py
vendored
374
polly/lib/External/isl/interface/isl.py
vendored
@ -1,4 +1,4 @@
|
||||
isl_dlname='libisl.so.22'
|
||||
isl_dlname='libisl.so.23'
|
||||
import os
|
||||
from ctypes import *
|
||||
from ctypes.util import find_library
|
||||
@ -286,6 +286,13 @@ class union_pw_multi_aff(object):
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def preimage_domain_wrapped_domain(*args):
|
||||
if len(args) == 2 and args[1].__class__ is union_pw_multi_aff:
|
||||
ctx = args[0].ctx
|
||||
res = isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(isl.isl_union_pw_multi_aff_copy(args[0].ptr), isl.isl_union_pw_multi_aff_copy(args[1].ptr))
|
||||
obj = union_pw_multi_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def pullback(*args):
|
||||
if len(args) == 2 and args[1].__class__ is union_pw_multi_aff:
|
||||
ctx = args[0].ctx
|
||||
@ -412,6 +419,8 @@ isl.isl_union_pw_multi_aff_intersect_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_pw_multi_aff_involves_locals.argtypes = [c_void_p]
|
||||
isl.isl_union_pw_multi_aff_isa_pw_multi_aff.argtypes = [c_void_p]
|
||||
isl.isl_union_pw_multi_aff_plain_is_empty.argtypes = [c_void_p]
|
||||
isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff.restype = c_void_p
|
||||
isl.isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_pw_multi_aff_pullback_union_pw_multi_aff.restype = c_void_p
|
||||
isl.isl_union_pw_multi_aff_pullback_union_pw_multi_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_pw_multi_aff_range_factor_domain.restype = c_void_p
|
||||
@ -623,6 +632,17 @@ class multi_union_pw_aff(object):
|
||||
res = isl.isl_multi_union_pw_aff_intersect_params(isl.isl_multi_union_pw_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = multi_union_pw_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def involves_nan(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_union_pw_aff:
|
||||
arg0 = multi_union_pw_aff(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_multi_union_pw_aff_involves_nan(arg0.ptr)
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def neg(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_union_pw_aff:
|
||||
@ -805,6 +825,7 @@ isl.isl_multi_union_pw_aff_intersect_domain.restype = c_void_p
|
||||
isl.isl_multi_union_pw_aff_intersect_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_union_pw_aff_intersect_params.restype = c_void_p
|
||||
isl.isl_multi_union_pw_aff_intersect_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_union_pw_aff_involves_nan.argtypes = [c_void_p]
|
||||
isl.isl_multi_union_pw_aff_neg.restype = c_void_p
|
||||
isl.isl_multi_union_pw_aff_neg.argtypes = [c_void_p]
|
||||
isl.isl_multi_union_pw_aff_plain_is_equal.argtypes = [c_void_p, c_void_p]
|
||||
@ -1375,6 +1396,17 @@ class multi_pw_aff(multi_union_pw_aff):
|
||||
res = isl.isl_multi_pw_aff_intersect_params(isl.isl_multi_pw_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = multi_pw_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def involves_nan(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_pw_aff:
|
||||
arg0 = multi_pw_aff(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_multi_pw_aff_involves_nan(arg0.ptr)
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def involves_param(*args):
|
||||
if len(args) == 2 and (args[1].__class__ is id or type(args[1]) == str):
|
||||
args = list(args)
|
||||
@ -1685,6 +1717,7 @@ isl.isl_multi_pw_aff_intersect_domain.restype = c_void_p
|
||||
isl.isl_multi_pw_aff_intersect_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_pw_aff_intersect_params.restype = c_void_p
|
||||
isl.isl_multi_pw_aff_intersect_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_pw_aff_involves_nan.argtypes = [c_void_p]
|
||||
isl.isl_multi_pw_aff_involves_param_id.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_pw_aff_involves_param_id_list.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_pw_aff_max.restype = c_void_p
|
||||
@ -1943,6 +1976,14 @@ class pw_multi_aff(union_pw_multi_aff, multi_pw_aff):
|
||||
res = isl.isl_pw_multi_aff_gist(isl.isl_pw_multi_aff_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = pw_multi_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
@staticmethod
|
||||
def identity_on_domain(*args):
|
||||
if len(args) == 1 and args[0].__class__ is space:
|
||||
ctx = args[0].ctx
|
||||
res = isl.isl_pw_multi_aff_identity_on_domain_space(isl.isl_space_copy(args[0].ptr))
|
||||
obj = pw_multi_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def insert_domain(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is pw_multi_aff:
|
||||
@ -2041,6 +2082,13 @@ class pw_multi_aff(union_pw_multi_aff, multi_pw_aff):
|
||||
if res < 0:
|
||||
raise
|
||||
return int(res)
|
||||
def preimage_domain_wrapped_domain(*args):
|
||||
if len(args) == 2 and args[1].__class__ is pw_multi_aff:
|
||||
ctx = args[0].ctx
|
||||
res = isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(isl.isl_pw_multi_aff_copy(args[0].ptr), isl.isl_pw_multi_aff_copy(args[1].ptr))
|
||||
obj = pw_multi_aff(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def product(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is pw_multi_aff:
|
||||
@ -2228,6 +2276,8 @@ isl.isl_pw_multi_aff_get_space.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_get_space.argtypes = [c_void_p]
|
||||
isl.isl_pw_multi_aff_gist.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_gist.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_pw_multi_aff_identity_on_domain_space.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_identity_on_domain_space.argtypes = [c_void_p]
|
||||
isl.isl_pw_multi_aff_insert_domain.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_insert_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_pw_multi_aff_intersect_domain.restype = c_void_p
|
||||
@ -2241,6 +2291,8 @@ isl.isl_pw_multi_aff_max_multi_val.argtypes = [c_void_p]
|
||||
isl.isl_pw_multi_aff_min_multi_val.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_min_multi_val.argtypes = [c_void_p]
|
||||
isl.isl_pw_multi_aff_n_piece.argtypes = [c_void_p]
|
||||
isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_pw_multi_aff_product.restype = c_void_p
|
||||
isl.isl_pw_multi_aff_product.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_pw_multi_aff_pullback_multi_aff.restype = c_void_p
|
||||
@ -3187,6 +3239,17 @@ class multi_aff(pw_multi_aff, multi_pw_aff):
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def involves_nan(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_aff:
|
||||
arg0 = multi_aff(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_multi_aff_involves_nan(arg0.ptr)
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def neg(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_aff:
|
||||
@ -3406,6 +3469,7 @@ isl.isl_multi_aff_identity_on_domain_space.argtypes = [c_void_p]
|
||||
isl.isl_multi_aff_insert_domain.restype = c_void_p
|
||||
isl.isl_multi_aff_insert_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_aff_involves_locals.argtypes = [c_void_p]
|
||||
isl.isl_multi_aff_involves_nan.argtypes = [c_void_p]
|
||||
isl.isl_multi_aff_neg.restype = c_void_p
|
||||
isl.isl_multi_aff_neg.argtypes = [c_void_p]
|
||||
isl.isl_multi_aff_plain_is_equal.argtypes = [c_void_p, c_void_p]
|
||||
@ -3592,6 +3656,18 @@ class aff(pw_aff, multi_aff):
|
||||
res = isl.isl_aff_ge_set(isl.isl_aff_copy(arg0.ptr), isl.isl_aff_copy(arg1.ptr))
|
||||
obj = set(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def constant_val(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is aff:
|
||||
arg0 = aff(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_aff_get_constant_val(arg0.ptr)
|
||||
obj = val(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def get_constant_val(arg0):
|
||||
return arg0.constant_val()
|
||||
def gist(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is aff:
|
||||
@ -3622,6 +3698,17 @@ class aff(pw_aff, multi_aff):
|
||||
res = isl.isl_aff_gt_set(isl.isl_aff_copy(arg0.ptr), isl.isl_aff_copy(arg1.ptr))
|
||||
obj = set(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def is_cst(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is aff:
|
||||
arg0 = aff(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_aff_is_cst(arg0.ptr)
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def le_set(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is aff:
|
||||
@ -3797,10 +3884,13 @@ isl.isl_aff_floor.restype = c_void_p
|
||||
isl.isl_aff_floor.argtypes = [c_void_p]
|
||||
isl.isl_aff_ge_set.restype = c_void_p
|
||||
isl.isl_aff_ge_set.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_aff_get_constant_val.restype = c_void_p
|
||||
isl.isl_aff_get_constant_val.argtypes = [c_void_p]
|
||||
isl.isl_aff_gist.restype = c_void_p
|
||||
isl.isl_aff_gist.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_aff_gt_set.restype = c_void_p
|
||||
isl.isl_aff_gt_set.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_aff_is_cst.argtypes = [c_void_p]
|
||||
isl.isl_aff_le_set.restype = c_void_p
|
||||
isl.isl_aff_le_set.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_aff_lt_set.restype = c_void_p
|
||||
@ -6641,6 +6731,36 @@ class union_map(object):
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def intersect_domain_factor_domain(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
arg0 = union_map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is union_map:
|
||||
arg1 = union_map(arg1)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_union_map_intersect_domain_factor_domain(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_domain_factor_range(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
arg0 = union_map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is union_map:
|
||||
arg1 = union_map(arg1)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_union_map_intersect_domain_factor_range(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_params(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
@ -6668,6 +6788,36 @@ class union_map(object):
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def intersect_range_factor_domain(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
arg0 = union_map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is union_map:
|
||||
arg1 = union_map(arg1)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_union_map_intersect_range_factor_domain(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_range_factor_range(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
arg0 = union_map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is union_map:
|
||||
arg1 = union_map(arg1)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_union_map_intersect_range_factor_range(isl.isl_union_map_copy(arg0.ptr), isl.isl_union_map_copy(arg1.ptr))
|
||||
obj = union_map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def is_bijective(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is union_map:
|
||||
@ -7133,12 +7283,20 @@ isl.isl_union_map_intersect_domain_space.restype = c_void_p
|
||||
isl.isl_union_map_intersect_domain_space.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_domain_union_set.restype = c_void_p
|
||||
isl.isl_union_map_intersect_domain_union_set.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_domain_factor_domain.restype = c_void_p
|
||||
isl.isl_union_map_intersect_domain_factor_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_domain_factor_range.restype = c_void_p
|
||||
isl.isl_union_map_intersect_domain_factor_range.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_params.restype = c_void_p
|
||||
isl.isl_union_map_intersect_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_range_space.restype = c_void_p
|
||||
isl.isl_union_map_intersect_range_space.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_range_union_set.restype = c_void_p
|
||||
isl.isl_union_map_intersect_range_union_set.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_range_factor_domain.restype = c_void_p
|
||||
isl.isl_union_map_intersect_range_factor_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_intersect_range_factor_range.restype = c_void_p
|
||||
isl.isl_union_map_intersect_range_factor_range.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_is_bijective.argtypes = [c_void_p]
|
||||
isl.isl_union_map_is_disjoint.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_union_map_is_empty.argtypes = [c_void_p]
|
||||
@ -7584,6 +7742,36 @@ class map(union_map):
|
||||
res = isl.isl_map_intersect_domain(isl.isl_map_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_domain_factor_domain(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is map:
|
||||
arg1 = map(arg1)
|
||||
except:
|
||||
return union_map(arg0).intersect_domain_factor_domain(arg1)
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_intersect_domain_factor_domain(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_domain_factor_range(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is map:
|
||||
arg1 = map(arg1)
|
||||
except:
|
||||
return union_map(arg0).intersect_domain_factor_range(arg1)
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_intersect_domain_factor_range(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_params(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
@ -7614,6 +7802,36 @@ class map(union_map):
|
||||
res = isl.isl_map_intersect_range(isl.isl_map_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_range_factor_domain(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is map:
|
||||
arg1 = map(arg1)
|
||||
except:
|
||||
return union_map(arg0).intersect_range_factor_domain(arg1)
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_intersect_range_factor_domain(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def intersect_range_factor_range(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is map:
|
||||
arg1 = map(arg1)
|
||||
except:
|
||||
return union_map(arg0).intersect_range_factor_range(arg1)
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_intersect_range_factor_range(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def is_bijective(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
@ -7796,11 +8014,6 @@ class map(union_map):
|
||||
res = isl.isl_map_lower_bound_multi_pw_aff(isl.isl_map_copy(args[0].ptr), isl.isl_multi_pw_aff_copy(args[1].ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
if len(args) == 2 and args[1].__class__ is multi_val:
|
||||
ctx = args[0].ctx
|
||||
res = isl.isl_map_lower_bound_multi_val(isl.isl_map_copy(args[0].ptr), isl.isl_multi_val_copy(args[1].ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def max_multi_pw_aff(arg0):
|
||||
try:
|
||||
@ -7861,6 +8074,21 @@ class map(union_map):
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def product(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is map:
|
||||
arg1 = map(arg1)
|
||||
except:
|
||||
return union_map(arg0).product(arg1)
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_product(isl.isl_map_copy(arg0.ptr), isl.isl_map_copy(arg1.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def project_out_all_params(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
@ -8013,11 +8241,6 @@ class map(union_map):
|
||||
res = isl.isl_map_upper_bound_multi_pw_aff(isl.isl_map_copy(args[0].ptr), isl.isl_multi_pw_aff_copy(args[1].ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
if len(args) == 2 and args[1].__class__ is multi_val:
|
||||
ctx = args[0].ctx
|
||||
res = isl.isl_map_upper_bound_multi_val(isl.isl_map_copy(args[0].ptr), isl.isl_multi_val_copy(args[1].ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def wrap(arg0):
|
||||
try:
|
||||
@ -8029,6 +8252,16 @@ class map(union_map):
|
||||
res = isl.isl_map_wrap(isl.isl_map_copy(arg0.ptr))
|
||||
obj = set(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def zip(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is map:
|
||||
arg0 = map(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_map_zip(isl.isl_map_copy(arg0.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
|
||||
isl.isl_map_from_basic_map.restype = c_void_p
|
||||
isl.isl_map_from_basic_map.argtypes = [c_void_p]
|
||||
@ -8089,10 +8322,18 @@ isl.isl_map_intersect.restype = c_void_p
|
||||
isl.isl_map_intersect.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_domain.restype = c_void_p
|
||||
isl.isl_map_intersect_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_domain_factor_domain.restype = c_void_p
|
||||
isl.isl_map_intersect_domain_factor_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_domain_factor_range.restype = c_void_p
|
||||
isl.isl_map_intersect_domain_factor_range.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_params.restype = c_void_p
|
||||
isl.isl_map_intersect_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_range.restype = c_void_p
|
||||
isl.isl_map_intersect_range.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_range_factor_domain.restype = c_void_p
|
||||
isl.isl_map_intersect_range_factor_domain.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_intersect_range_factor_range.restype = c_void_p
|
||||
isl.isl_map_intersect_range_factor_range.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_is_bijective.argtypes = [c_void_p]
|
||||
isl.isl_map_is_disjoint.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_is_empty.argtypes = [c_void_p]
|
||||
@ -8119,8 +8360,6 @@ isl.isl_map_lexmin_pw_multi_aff.restype = c_void_p
|
||||
isl.isl_map_lexmin_pw_multi_aff.argtypes = [c_void_p]
|
||||
isl.isl_map_lower_bound_multi_pw_aff.restype = c_void_p
|
||||
isl.isl_map_lower_bound_multi_pw_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_lower_bound_multi_val.restype = c_void_p
|
||||
isl.isl_map_lower_bound_multi_val.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_max_multi_pw_aff.restype = c_void_p
|
||||
isl.isl_map_max_multi_pw_aff.argtypes = [c_void_p]
|
||||
isl.isl_map_min_multi_pw_aff.restype = c_void_p
|
||||
@ -8137,6 +8376,8 @@ isl.isl_map_preimage_range_multi_aff.restype = c_void_p
|
||||
isl.isl_map_preimage_range_multi_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_preimage_range_pw_multi_aff.restype = c_void_p
|
||||
isl.isl_map_preimage_range_pw_multi_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_product.restype = c_void_p
|
||||
isl.isl_map_product.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_project_out_all_params.restype = c_void_p
|
||||
isl.isl_map_project_out_all_params.argtypes = [c_void_p]
|
||||
isl.isl_map_range.restype = c_void_p
|
||||
@ -8165,10 +8406,10 @@ isl.isl_map_unshifted_simple_hull.restype = c_void_p
|
||||
isl.isl_map_unshifted_simple_hull.argtypes = [c_void_p]
|
||||
isl.isl_map_upper_bound_multi_pw_aff.restype = c_void_p
|
||||
isl.isl_map_upper_bound_multi_pw_aff.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_upper_bound_multi_val.restype = c_void_p
|
||||
isl.isl_map_upper_bound_multi_val.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_map_wrap.restype = c_void_p
|
||||
isl.isl_map_wrap.argtypes = [c_void_p]
|
||||
isl.isl_map_zip.restype = c_void_p
|
||||
isl.isl_map_zip.argtypes = [c_void_p]
|
||||
isl.isl_map_copy.restype = c_void_p
|
||||
isl.isl_map_copy.argtypes = [c_void_p]
|
||||
isl.isl_map_free.restype = c_void_p
|
||||
@ -9692,6 +9933,16 @@ class set(union_set):
|
||||
res = isl.isl_set_subtract(isl.isl_set_copy(arg0.ptr), isl.isl_set_copy(arg1.ptr))
|
||||
obj = set(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def translation(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is set:
|
||||
arg0 = set(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_set_translation(isl.isl_set_copy(arg0.ptr))
|
||||
obj = map(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def unbind_params(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is set:
|
||||
@ -9881,6 +10132,8 @@ isl.isl_set_sample_point.restype = c_void_p
|
||||
isl.isl_set_sample_point.argtypes = [c_void_p]
|
||||
isl.isl_set_subtract.restype = c_void_p
|
||||
isl.isl_set_subtract.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_set_translation.restype = c_void_p
|
||||
isl.isl_set_translation.argtypes = [c_void_p]
|
||||
isl.isl_set_unbind_params.restype = c_void_p
|
||||
isl.isl_set_unbind_params.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_set_unbind_params_insert_domain.restype = c_void_p
|
||||
@ -10794,6 +11047,17 @@ class multi_val(object):
|
||||
return obj
|
||||
def get_space(arg0):
|
||||
return arg0.space()
|
||||
def involves_nan(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is multi_val:
|
||||
arg0 = multi_val(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_multi_val_involves_nan(arg0.ptr)
|
||||
if res < 0:
|
||||
raise
|
||||
return bool(res)
|
||||
def max(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is multi_val:
|
||||
@ -10985,6 +11249,7 @@ isl.isl_multi_val_get_list.restype = c_void_p
|
||||
isl.isl_multi_val_get_list.argtypes = [c_void_p]
|
||||
isl.isl_multi_val_get_space.restype = c_void_p
|
||||
isl.isl_multi_val_get_space.argtypes = [c_void_p]
|
||||
isl.isl_multi_val_involves_nan.argtypes = [c_void_p]
|
||||
isl.isl_multi_val_max.restype = c_void_p
|
||||
isl.isl_multi_val_max.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_multi_val_min.restype = c_void_p
|
||||
@ -11451,6 +11716,18 @@ class schedule(object):
|
||||
res = isl.isl_schedule_from_domain(isl.isl_union_set_copy(arg0.ptr))
|
||||
obj = schedule(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def domain(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is schedule:
|
||||
arg0 = schedule(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_schedule_get_domain(arg0.ptr)
|
||||
obj = union_set(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def get_domain(arg0):
|
||||
return arg0.domain()
|
||||
def map(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is schedule:
|
||||
@ -11487,6 +11764,8 @@ isl.isl_schedule_read_from_str.restype = c_void_p
|
||||
isl.isl_schedule_read_from_str.argtypes = [Context, c_char_p]
|
||||
isl.isl_schedule_from_domain.restype = c_void_p
|
||||
isl.isl_schedule_from_domain.argtypes = [c_void_p]
|
||||
isl.isl_schedule_get_domain.restype = c_void_p
|
||||
isl.isl_schedule_get_domain.argtypes = [c_void_p]
|
||||
isl.isl_schedule_get_map.restype = c_void_p
|
||||
isl.isl_schedule_get_map.argtypes = [c_void_p]
|
||||
isl.isl_schedule_get_root.restype = c_void_p
|
||||
@ -13269,6 +13548,16 @@ class space(object):
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
raise Error
|
||||
def curry(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
arg0 = space(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_space_curry(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def domain(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
@ -13346,6 +13635,21 @@ class space(object):
|
||||
res = isl.isl_space_params(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def product(arg0, arg1):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
arg0 = space(arg0)
|
||||
except:
|
||||
raise
|
||||
try:
|
||||
if not arg1.__class__ is space:
|
||||
arg1 = space(arg1)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_space_product(isl.isl_space_copy(arg0.ptr), isl.isl_space_copy(arg1.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def range(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
@ -13356,6 +13660,36 @@ class space(object):
|
||||
res = isl.isl_space_range(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def range_reverse(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
arg0 = space(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_space_range_reverse(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def reverse(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
arg0 = space(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_space_reverse(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
def uncurry(arg0):
|
||||
try:
|
||||
if not arg0.__class__ is space:
|
||||
arg0 = space(arg0)
|
||||
except:
|
||||
raise
|
||||
ctx = arg0.ctx
|
||||
res = isl.isl_space_uncurry(isl.isl_space_copy(arg0.ptr))
|
||||
obj = space(ctx=ctx, ptr=res)
|
||||
return obj
|
||||
@staticmethod
|
||||
def unit():
|
||||
ctx = Context.getDefaultInstance()
|
||||
@ -13387,6 +13721,8 @@ isl.isl_space_add_named_tuple_id_ui.restype = c_void_p
|
||||
isl.isl_space_add_named_tuple_id_ui.argtypes = [c_void_p, c_void_p, c_int]
|
||||
isl.isl_space_add_unnamed_tuple_ui.restype = c_void_p
|
||||
isl.isl_space_add_unnamed_tuple_ui.argtypes = [c_void_p, c_int]
|
||||
isl.isl_space_curry.restype = c_void_p
|
||||
isl.isl_space_curry.argtypes = [c_void_p]
|
||||
isl.isl_space_domain.restype = c_void_p
|
||||
isl.isl_space_domain.argtypes = [c_void_p]
|
||||
isl.isl_space_flatten_domain.restype = c_void_p
|
||||
@ -13399,8 +13735,16 @@ isl.isl_space_map_from_set.restype = c_void_p
|
||||
isl.isl_space_map_from_set.argtypes = [c_void_p]
|
||||
isl.isl_space_params.restype = c_void_p
|
||||
isl.isl_space_params.argtypes = [c_void_p]
|
||||
isl.isl_space_product.restype = c_void_p
|
||||
isl.isl_space_product.argtypes = [c_void_p, c_void_p]
|
||||
isl.isl_space_range.restype = c_void_p
|
||||
isl.isl_space_range.argtypes = [c_void_p]
|
||||
isl.isl_space_range_reverse.restype = c_void_p
|
||||
isl.isl_space_range_reverse.argtypes = [c_void_p]
|
||||
isl.isl_space_reverse.restype = c_void_p
|
||||
isl.isl_space_reverse.argtypes = [c_void_p]
|
||||
isl.isl_space_uncurry.restype = c_void_p
|
||||
isl.isl_space_uncurry.argtypes = [c_void_p]
|
||||
isl.isl_space_unit.restype = c_void_p
|
||||
isl.isl_space_unit.argtypes = [Context]
|
||||
isl.isl_space_unwrap.restype = c_void_p
|
||||
|
217
polly/lib/External/isl/interface/ltmain.sh
vendored
217
polly/lib/External/isl/interface/ltmain.sh
vendored
@ -31,7 +31,7 @@
|
||||
|
||||
PROGRAM=libtool
|
||||
PACKAGE=libtool
|
||||
VERSION="2.4.6 Debian-2.4.6-2"
|
||||
VERSION="2.4.6 Debian-2.4.6-14"
|
||||
package_revision=2.4.6
|
||||
|
||||
|
||||
@ -387,7 +387,7 @@ EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
|
||||
# putting '$debug_cmd' at the start of all your functions, you can get
|
||||
# bash to show function call trace with:
|
||||
#
|
||||
# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
|
||||
# debug_cmd='echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
|
||||
debug_cmd=${debug_cmd-":"}
|
||||
exit_cmd=:
|
||||
|
||||
@ -1370,7 +1370,7 @@ func_lt_ver ()
|
||||
#! /bin/sh
|
||||
|
||||
# Set a version string for this script.
|
||||
scriptversion=2014-01-07.03; # UTC
|
||||
scriptversion=2015-10-07.11; # UTC
|
||||
|
||||
# A portable, pluggable option parser for Bourne shell.
|
||||
# Written by Gary V. Vaughan, 2010
|
||||
@ -1530,6 +1530,8 @@ func_run_hooks ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_run_hooks=false
|
||||
|
||||
case " $hookable_fns " in
|
||||
*" $1 "*) ;;
|
||||
*) func_fatal_error "'$1' does not support hook funcions.n" ;;
|
||||
@ -1538,16 +1540,16 @@ func_run_hooks ()
|
||||
eval _G_hook_fns=\$$1_hooks; shift
|
||||
|
||||
for _G_hook in $_G_hook_fns; do
|
||||
eval $_G_hook '"$@"'
|
||||
|
||||
# store returned options list back into positional
|
||||
# parameters for next 'cmd' execution.
|
||||
eval _G_hook_result=\$${_G_hook}_result
|
||||
eval set dummy "$_G_hook_result"; shift
|
||||
if eval $_G_hook '"$@"'; then
|
||||
# store returned options list back into positional
|
||||
# parameters for next 'cmd' execution.
|
||||
eval _G_hook_result=\$${_G_hook}_result
|
||||
eval set dummy "$_G_hook_result"; shift
|
||||
_G_rc_run_hooks=:
|
||||
fi
|
||||
done
|
||||
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_run_hooks_result=$func_quote_for_eval_result
|
||||
$_G_rc_run_hooks && func_run_hooks_result=$_G_hook_result
|
||||
}
|
||||
|
||||
|
||||
@ -1557,10 +1559,16 @@ func_run_hooks ()
|
||||
## --------------- ##
|
||||
|
||||
# In order to add your own option parsing hooks, you must accept the
|
||||
# full positional parameter list in your hook function, remove any
|
||||
# options that you action, and then pass back the remaining unprocessed
|
||||
# full positional parameter list in your hook function, you may remove/edit
|
||||
# any options that you action, and then pass back the remaining unprocessed
|
||||
# options in '<hooked_function_name>_result', escaped suitably for
|
||||
# 'eval'. Like this:
|
||||
# 'eval'. In this case you also must return $EXIT_SUCCESS to let the
|
||||
# hook's caller know that it should pay attention to
|
||||
# '<hooked_function_name>_result'. Returning $EXIT_FAILURE signalizes that
|
||||
# arguments are left untouched by the hook and therefore caller will ignore the
|
||||
# result variable.
|
||||
#
|
||||
# Like this:
|
||||
#
|
||||
# my_options_prep ()
|
||||
# {
|
||||
@ -1570,9 +1578,11 @@ func_run_hooks ()
|
||||
# usage_message=$usage_message'
|
||||
# -s, --silent don'\''t print informational messages
|
||||
# '
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_options_prep_result=$func_quote_for_eval_result
|
||||
# # No change in '$@' (ignored completely by this hook). There is
|
||||
# # no need to do the equivalent (but slower) action:
|
||||
# # func_quote_for_eval ${1+"$@"}
|
||||
# # my_options_prep_result=$func_quote_for_eval_result
|
||||
# false
|
||||
# }
|
||||
# func_add_hook func_options_prep my_options_prep
|
||||
#
|
||||
@ -1581,25 +1591,37 @@ func_run_hooks ()
|
||||
# {
|
||||
# $debug_cmd
|
||||
#
|
||||
# args_changed=false
|
||||
#
|
||||
# # Note that for efficiency, we parse as many options as we can
|
||||
# # recognise in a loop before passing the remainder back to the
|
||||
# # caller on the first unrecognised argument we encounter.
|
||||
# while test $# -gt 0; do
|
||||
# opt=$1; shift
|
||||
# case $opt in
|
||||
# --silent|-s) opt_silent=: ;;
|
||||
# --silent|-s) opt_silent=:
|
||||
# args_changed=:
|
||||
# ;;
|
||||
# # Separate non-argument short options:
|
||||
# -s*) func_split_short_opt "$_G_opt"
|
||||
# set dummy "$func_split_short_opt_name" \
|
||||
# "-$func_split_short_opt_arg" ${1+"$@"}
|
||||
# shift
|
||||
# args_changed=:
|
||||
# ;;
|
||||
# *) set dummy "$_G_opt" "$*"; shift; break ;;
|
||||
# *) # Make sure the first unrecognised option "$_G_opt"
|
||||
# # is added back to "$@", we could need that later
|
||||
# # if $args_changed is true.
|
||||
# set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
# esac
|
||||
# done
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_silent_option_result=$func_quote_for_eval_result
|
||||
# if $args_changed; then
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_silent_option_result=$func_quote_for_eval_result
|
||||
# fi
|
||||
#
|
||||
# $args_changed
|
||||
# }
|
||||
# func_add_hook func_parse_options my_silent_option
|
||||
#
|
||||
@ -1611,16 +1633,32 @@ func_run_hooks ()
|
||||
# $opt_silent && $opt_verbose && func_fatal_help "\
|
||||
# '--silent' and '--verbose' options are mutually exclusive."
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_option_validation_result=$func_quote_for_eval_result
|
||||
# false
|
||||
# }
|
||||
# func_add_hook func_validate_options my_option_validation
|
||||
#
|
||||
# You'll alse need to manually amend $usage_message to reflect the extra
|
||||
# You'll also need to manually amend $usage_message to reflect the extra
|
||||
# options you parse. It's preferable to append if you can, so that
|
||||
# multiple option parsing hooks can be added safely.
|
||||
|
||||
|
||||
# func_options_finish [ARG]...
|
||||
# ----------------------------
|
||||
# Finishing the option parse loop (call 'func_options' hooks ATM).
|
||||
func_options_finish ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_func_options_finish_exit=false
|
||||
if func_run_hooks func_options ${1+"$@"}; then
|
||||
func_options_finish_result=$func_run_hooks_result
|
||||
_G_func_options_finish_exit=:
|
||||
fi
|
||||
|
||||
$_G_func_options_finish_exit
|
||||
}
|
||||
|
||||
|
||||
# func_options [ARG]...
|
||||
# ---------------------
|
||||
# All the functions called inside func_options are hookable. See the
|
||||
@ -1630,17 +1668,28 @@ func_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
func_options_prep ${1+"$@"}
|
||||
eval func_parse_options \
|
||||
${func_options_prep_result+"$func_options_prep_result"}
|
||||
eval func_validate_options \
|
||||
${func_parse_options_result+"$func_parse_options_result"}
|
||||
_G_rc_options=false
|
||||
|
||||
eval func_run_hooks func_options \
|
||||
${func_validate_options_result+"$func_validate_options_result"}
|
||||
for my_func in options_prep parse_options validate_options options_finish
|
||||
do
|
||||
if eval func_$my_func '${1+"$@"}'; then
|
||||
eval _G_res_var='$'"func_${my_func}_result"
|
||||
eval set dummy "$_G_res_var" ; shift
|
||||
_G_rc_options=:
|
||||
fi
|
||||
done
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_options_result=$func_run_hooks_result
|
||||
# Save modified positional parameters for caller. As a top-level
|
||||
# options-parser function we always need to set the 'func_options_result'
|
||||
# variable (regardless the $_G_rc_options value).
|
||||
if $_G_rc_options; then
|
||||
func_options_result=$_G_res_var
|
||||
else
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_options
|
||||
}
|
||||
|
||||
|
||||
@ -1649,9 +1698,9 @@ func_options ()
|
||||
# All initialisations required before starting the option parse loop.
|
||||
# Note that when calling hook functions, we pass through the list of
|
||||
# positional parameters. If a hook function modifies that list, and
|
||||
# needs to propogate that back to rest of this script, then the complete
|
||||
# needs to propagate that back to rest of this script, then the complete
|
||||
# modified list must be put in 'func_run_hooks_result' before
|
||||
# returning.
|
||||
# returning $EXIT_SUCCESS (otherwise $EXIT_FAILURE is returned).
|
||||
func_hookable func_options_prep
|
||||
func_options_prep ()
|
||||
{
|
||||
@ -1661,10 +1710,14 @@ func_options_prep ()
|
||||
opt_verbose=false
|
||||
opt_warning_types=
|
||||
|
||||
func_run_hooks func_options_prep ${1+"$@"}
|
||||
_G_rc_options_prep=false
|
||||
if func_run_hooks func_options_prep ${1+"$@"}; then
|
||||
_G_rc_options_prep=:
|
||||
# save modified positional parameters for caller
|
||||
func_options_prep_result=$func_run_hooks_result
|
||||
fi
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_options_prep_result=$func_run_hooks_result
|
||||
$_G_rc_options_prep
|
||||
}
|
||||
|
||||
|
||||
@ -1678,18 +1731,20 @@ func_parse_options ()
|
||||
|
||||
func_parse_options_result=
|
||||
|
||||
_G_rc_parse_options=false
|
||||
# this just eases exit handling
|
||||
while test $# -gt 0; do
|
||||
# Defer to hook functions for initial option parsing, so they
|
||||
# get priority in the event of reusing an option name.
|
||||
func_run_hooks func_parse_options ${1+"$@"}
|
||||
|
||||
# Adjust func_parse_options positional parameters to match
|
||||
eval set dummy "$func_run_hooks_result"; shift
|
||||
if func_run_hooks func_parse_options ${1+"$@"}; then
|
||||
eval set dummy "$func_run_hooks_result"; shift
|
||||
_G_rc_parse_options=:
|
||||
fi
|
||||
|
||||
# Break out of the loop if we already parsed every option.
|
||||
test $# -gt 0 || break
|
||||
|
||||
_G_match_parse_options=:
|
||||
_G_opt=$1
|
||||
shift
|
||||
case $_G_opt in
|
||||
@ -1704,7 +1759,10 @@ func_parse_options ()
|
||||
;;
|
||||
|
||||
--warnings|--warning|-W)
|
||||
test $# = 0 && func_missing_arg $_G_opt && break
|
||||
if test $# = 0 && func_missing_arg $_G_opt; then
|
||||
_G_rc_parse_options=:
|
||||
break
|
||||
fi
|
||||
case " $warning_categories $1" in
|
||||
*" $1 "*)
|
||||
# trailing space prevents matching last $1 above
|
||||
@ -1757,15 +1815,25 @@ func_parse_options ()
|
||||
shift
|
||||
;;
|
||||
|
||||
--) break ;;
|
||||
--) _G_rc_parse_options=: ; break ;;
|
||||
-*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift
|
||||
_G_match_parse_options=false
|
||||
break
|
||||
;;
|
||||
esac
|
||||
|
||||
$_G_match_parse_options && _G_rc_parse_options=:
|
||||
done
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_parse_options_result=$func_quote_for_eval_result
|
||||
|
||||
if $_G_rc_parse_options; then
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_parse_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_parse_options
|
||||
}
|
||||
|
||||
|
||||
@ -1778,16 +1846,21 @@ func_validate_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_validate_options=false
|
||||
|
||||
# Display all warnings if -W was not given.
|
||||
test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
|
||||
|
||||
func_run_hooks func_validate_options ${1+"$@"}
|
||||
if func_run_hooks func_validate_options ${1+"$@"}; then
|
||||
# save modified positional parameters for caller
|
||||
func_validate_options_result=$func_run_hooks_result
|
||||
_G_rc_validate_options=:
|
||||
fi
|
||||
|
||||
# Bail if the options were screwed!
|
||||
$exit_cmd $EXIT_FAILURE
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_validate_options_result=$func_run_hooks_result
|
||||
$_G_rc_validate_options
|
||||
}
|
||||
|
||||
|
||||
@ -2068,7 +2141,7 @@ include the following information:
|
||||
compiler: $LTCC
|
||||
compiler flags: $LTCFLAGS
|
||||
linker: $LD (gnu? $with_gnu_ld)
|
||||
version: $progname $scriptversion Debian-2.4.6-2
|
||||
version: $progname $scriptversion Debian-2.4.6-14
|
||||
automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
|
||||
autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
|
||||
|
||||
@ -2270,6 +2343,8 @@ libtool_options_prep ()
|
||||
nonopt=
|
||||
preserve_args=
|
||||
|
||||
_G_rc_lt_options_prep=:
|
||||
|
||||
# Shorthand for --mode=foo, only valid as the first argument
|
||||
case $1 in
|
||||
clean|clea|cle|cl)
|
||||
@ -2293,11 +2368,18 @@ libtool_options_prep ()
|
||||
uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
|
||||
shift; set dummy --mode uninstall ${1+"$@"}; shift
|
||||
;;
|
||||
*)
|
||||
_G_rc_lt_options_prep=false
|
||||
;;
|
||||
esac
|
||||
|
||||
# Pass back the list of options.
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_options_prep_result=$func_quote_for_eval_result
|
||||
if $_G_rc_lt_options_prep; then
|
||||
# Pass back the list of options.
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_options_prep_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_lt_options_prep
|
||||
}
|
||||
func_add_hook func_options_prep libtool_options_prep
|
||||
|
||||
@ -2309,9 +2391,12 @@ libtool_parse_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_lt_parse_options=false
|
||||
|
||||
# Perform our own loop to consume as many options as possible in
|
||||
# each iteration.
|
||||
while test $# -gt 0; do
|
||||
_G_match_lt_parse_options=:
|
||||
_G_opt=$1
|
||||
shift
|
||||
case $_G_opt in
|
||||
@ -2386,15 +2471,22 @@ libtool_parse_options ()
|
||||
func_append preserve_args " $_G_opt"
|
||||
;;
|
||||
|
||||
# An option not handled by this hook function:
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
# An option not handled by this hook function:
|
||||
*) set dummy "$_G_opt" ${1+"$@"} ; shift
|
||||
_G_match_lt_parse_options=false
|
||||
break
|
||||
;;
|
||||
esac
|
||||
$_G_match_lt_parse_options && _G_rc_lt_parse_options=:
|
||||
done
|
||||
|
||||
if $_G_rc_lt_parse_options; then
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_parse_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_parse_options_result=$func_quote_for_eval_result
|
||||
$_G_rc_lt_parse_options
|
||||
}
|
||||
func_add_hook func_parse_options libtool_parse_options
|
||||
|
||||
@ -7275,10 +7367,13 @@ func_mode_link ()
|
||||
# -specs=* GCC specs files
|
||||
# -stdlib=* select c++ std lib with clang
|
||||
# -fsanitize=* Clang/GCC memory and address sanitizer
|
||||
# -fuse-ld=* Linker select flags for GCC
|
||||
# -static-* direct GCC to link specific libraries statically
|
||||
# -fcilkplus Cilk Plus language extension features for C/C++
|
||||
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
|
||||
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
|
||||
-O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
|
||||
-specs=*|-fsanitize=*)
|
||||
-specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus)
|
||||
func_quote_for_eval "$arg"
|
||||
arg=$func_quote_for_eval_result
|
||||
func_append compile_command " $arg"
|
||||
|
16
polly/lib/External/isl/interface/missing
vendored
16
polly/lib/External/isl/interface/missing
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# Common wrapper for a few potentially missing GNU programs.
|
||||
|
||||
scriptversion=2013-10-28.13; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1996-2014 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
@ -17,7 +17,7 @@ scriptversion=2013-10-28.13; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -101,9 +101,9 @@ else
|
||||
exit $st
|
||||
fi
|
||||
|
||||
perl_URL=http://www.perl.org/
|
||||
flex_URL=http://flex.sourceforge.net/
|
||||
gnu_software_URL=http://www.gnu.org/software
|
||||
perl_URL=https://www.perl.org/
|
||||
flex_URL=https://github.com/westes/flex
|
||||
gnu_software_URL=https://www.gnu.org/software
|
||||
|
||||
program_details ()
|
||||
{
|
||||
@ -207,9 +207,9 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \
|
||||
exit $st
|
||||
|
||||
# Local variables:
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
257
polly/lib/External/isl/isl_aff.c
vendored
257
polly/lib/External/isl/isl_aff.c
vendored
@ -4,7 +4,7 @@
|
||||
* Copyright 2012-2014 Ecole Normale Superieure
|
||||
* Copyright 2014 INRIA Rocquencourt
|
||||
* Copyright 2016 Sven Verdoolaege
|
||||
* Copyright 2018 Cerebras Systems
|
||||
* Copyright 2018,2020 Cerebras Systems
|
||||
*
|
||||
* Use of this software is governed by the MIT license
|
||||
*
|
||||
@ -196,6 +196,23 @@ __isl_give isl_aff *isl_aff_nan_on_domain(__isl_take isl_local_space *ls)
|
||||
return isl_aff_set_nan(aff);
|
||||
}
|
||||
|
||||
/* Return an affine expression defined on the specified domain space
|
||||
* that represents NaN.
|
||||
*/
|
||||
__isl_give isl_aff *isl_aff_nan_on_domain_space(__isl_take isl_space *space)
|
||||
{
|
||||
return isl_aff_nan_on_domain(isl_local_space_from_space(space));
|
||||
}
|
||||
|
||||
/* Return a piecewise affine expression defined on the specified domain space
|
||||
* that represents NaN.
|
||||
*/
|
||||
__isl_give isl_pw_aff *isl_pw_aff_nan_on_domain_space(
|
||||
__isl_take isl_space *space)
|
||||
{
|
||||
return isl_pw_aff_from_aff(isl_aff_nan_on_domain_space(space));
|
||||
}
|
||||
|
||||
/* Return a piecewise affine expression defined on the specified domain
|
||||
* that represents NaN.
|
||||
*/
|
||||
@ -901,25 +918,12 @@ __isl_give isl_aff *isl_aff_add_constant(__isl_take isl_aff *aff, isl_int v)
|
||||
return aff;
|
||||
}
|
||||
|
||||
/* Add "v" to the constant term of "aff".
|
||||
*
|
||||
* A NaN is unaffected by this operation.
|
||||
/* Add "v" to the constant term of "aff",
|
||||
* in case "aff" is a rational expression.
|
||||
*/
|
||||
__isl_give isl_aff *isl_aff_add_constant_val(__isl_take isl_aff *aff,
|
||||
static __isl_give isl_aff *isl_aff_add_rat_constant_val(__isl_take isl_aff *aff,
|
||||
__isl_take isl_val *v)
|
||||
{
|
||||
if (!aff || !v)
|
||||
goto error;
|
||||
|
||||
if (isl_aff_is_nan(aff) || isl_val_is_zero(v)) {
|
||||
isl_val_free(v);
|
||||
return aff;
|
||||
}
|
||||
|
||||
if (!isl_val_is_rat(v))
|
||||
isl_die(isl_aff_get_ctx(aff), isl_error_invalid,
|
||||
"expecting rational value", goto error);
|
||||
|
||||
aff = isl_aff_cow(aff);
|
||||
if (!aff)
|
||||
goto error;
|
||||
@ -953,6 +957,58 @@ error:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Return the first argument and free the second.
|
||||
*/
|
||||
static __isl_give isl_aff *pick_free(__isl_take isl_aff *aff,
|
||||
__isl_take isl_val *v)
|
||||
{
|
||||
isl_val_free(v);
|
||||
return aff;
|
||||
}
|
||||
|
||||
/* Replace the first argument by NaN and free the second argument.
|
||||
*/
|
||||
static __isl_give isl_aff *set_nan_free_val(__isl_take isl_aff *aff,
|
||||
__isl_take isl_val *v)
|
||||
{
|
||||
isl_val_free(v);
|
||||
return isl_aff_set_nan(aff);
|
||||
}
|
||||
|
||||
/* Add "v" to the constant term of "aff".
|
||||
*
|
||||
* A NaN is unaffected by this operation.
|
||||
* Conversely, adding a NaN turns "aff" into a NaN.
|
||||
*/
|
||||
__isl_give isl_aff *isl_aff_add_constant_val(__isl_take isl_aff *aff,
|
||||
__isl_take isl_val *v)
|
||||
{
|
||||
isl_bool is_nan, is_zero, is_rat;
|
||||
|
||||
is_nan = isl_aff_is_nan(aff);
|
||||
is_zero = isl_val_is_zero(v);
|
||||
if (is_nan < 0 || is_zero < 0)
|
||||
goto error;
|
||||
if (is_nan || is_zero)
|
||||
return pick_free(aff, v);
|
||||
|
||||
is_nan = isl_val_is_nan(v);
|
||||
is_rat = isl_val_is_rat(v);
|
||||
if (is_nan < 0 || is_rat < 0)
|
||||
goto error;
|
||||
if (is_nan)
|
||||
return set_nan_free_val(aff, v);
|
||||
if (!is_rat)
|
||||
isl_die(isl_aff_get_ctx(aff), isl_error_invalid,
|
||||
"expecting rational value or NaN", goto error);
|
||||
|
||||
return isl_aff_add_rat_constant_val(aff, v);
|
||||
error:
|
||||
isl_aff_free(aff);
|
||||
isl_val_free(v);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
__isl_give isl_aff *isl_aff_add_constant_si(__isl_take isl_aff *aff, int v)
|
||||
{
|
||||
isl_int t;
|
||||
@ -4151,6 +4207,18 @@ __isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
|
||||
return isl_pw_multi_aff_from_multi_aff(isl_multi_aff_identity(space));
|
||||
}
|
||||
|
||||
/* Create a piecewise multi expression that maps elements in the given space
|
||||
* to themselves.
|
||||
*/
|
||||
__isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity_on_domain_space(
|
||||
__isl_take isl_space *space)
|
||||
{
|
||||
isl_multi_aff *ma;
|
||||
|
||||
ma = isl_multi_aff_identity_on_domain_space(space);
|
||||
return isl_pw_multi_aff_from_multi_aff(ma);
|
||||
}
|
||||
|
||||
/* Exploit the equalities in "eq" to simplify the affine expressions.
|
||||
*/
|
||||
static __isl_give isl_multi_aff *isl_multi_aff_substitute_equalities(
|
||||
@ -6432,6 +6500,23 @@ error:
|
||||
#include <isl_multi_zero_templ.c>
|
||||
#include <isl_multi_unbind_params_templ.c>
|
||||
|
||||
/* If "mpa" has an explicit domain, then intersect the domain of "map"
|
||||
* with this explicit domain.
|
||||
*/
|
||||
__isl_give isl_map *isl_map_intersect_multi_pw_aff_explicit_domain(
|
||||
__isl_take isl_map *map, __isl_keep isl_multi_pw_aff *mpa)
|
||||
{
|
||||
isl_set *dom;
|
||||
|
||||
if (!isl_multi_pw_aff_has_explicit_domain(mpa))
|
||||
return map;
|
||||
|
||||
dom = isl_multi_pw_aff_domain(isl_multi_pw_aff_copy(mpa));
|
||||
map = isl_map_intersect_domain(map, dom);
|
||||
|
||||
return map;
|
||||
}
|
||||
|
||||
/* Are all elements of "mpa" piecewise constants?
|
||||
*/
|
||||
isl_bool isl_multi_pw_aff_is_cst(__isl_keep isl_multi_pw_aff *mpa)
|
||||
@ -7372,17 +7457,24 @@ __isl_give isl_map *isl_map_eq_at_multi_pw_aff(__isl_take isl_map *map,
|
||||
}
|
||||
|
||||
/* Return a map containing pairs of elements in the domains of "mpa1" and "mpa2"
|
||||
* where the function values of "mpa1" lexicographically satisfies "base"
|
||||
* compared to that of "mpa2". "space" is the space of the result.
|
||||
* where the function values of "mpa1" lexicographically satisfies
|
||||
* "strict_base"/"base" compared to that of "mpa2".
|
||||
* "space" is the space of the result.
|
||||
* The parameters of "mpa1" and "mpa2" are assumed to have been aligned.
|
||||
*
|
||||
* "mpa1" lexicographically satisfies "base" compared to "mpa2"
|
||||
* if its i-th element satisfies "base" when compared to
|
||||
* the i-th element of "mpa2" while all previous elements are
|
||||
* "mpa1" lexicographically satisfies "strict_base"/"base" compared to "mpa2"
|
||||
* if, for some i, the i-th element of "mpa1" satisfies "strict_base"/"base"
|
||||
* when compared to the i-th element of "mpa2" while all previous elements are
|
||||
* pairwise equal.
|
||||
* In particular, if i corresponds to the final elements
|
||||
* then they need to satisfy "base", while "strict_base" needs to be satisfied
|
||||
* for other values of i.
|
||||
* If "base" is a strict order, then "base" and "strict_base" are the same.
|
||||
*/
|
||||
static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
|
||||
__isl_keep isl_multi_pw_aff *mpa1, __isl_keep isl_multi_pw_aff *mpa2,
|
||||
__isl_give isl_map *(*strict_base)(__isl_take isl_pw_aff *pa1,
|
||||
__isl_take isl_pw_aff *pa2),
|
||||
__isl_give isl_map *(*base)(__isl_take isl_pw_aff *pa1,
|
||||
__isl_take isl_pw_aff *pa2),
|
||||
__isl_take isl_space *space)
|
||||
@ -7398,16 +7490,19 @@ static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
|
||||
rest = isl_map_universe(space);
|
||||
|
||||
for (i = 0; i < n; ++i) {
|
||||
int last;
|
||||
isl_pw_aff *pa1, *pa2;
|
||||
isl_map *map;
|
||||
|
||||
last = i == n - 1;
|
||||
|
||||
pa1 = isl_multi_pw_aff_get_pw_aff(mpa1, i);
|
||||
pa2 = isl_multi_pw_aff_get_pw_aff(mpa2, i);
|
||||
map = base(pa1, pa2);
|
||||
map = last ? base(pa1, pa2) : strict_base(pa1, pa2);
|
||||
map = isl_map_intersect(map, isl_map_copy(rest));
|
||||
res = isl_map_union(res, map);
|
||||
|
||||
if (i == n - 1)
|
||||
if (last)
|
||||
continue;
|
||||
|
||||
pa1 = isl_multi_pw_aff_get_pw_aff(mpa1, i);
|
||||
@ -7421,19 +7516,27 @@ static __isl_give isl_map *isl_multi_pw_aff_lex_map_on_space(
|
||||
}
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER le
|
||||
#define ORDER le
|
||||
#undef STRICT_ORDER
|
||||
#define STRICT_ORDER lt
|
||||
#include "isl_aff_lex_templ.c"
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER lt
|
||||
#define ORDER lt
|
||||
#undef STRICT_ORDER
|
||||
#define STRICT_ORDER lt
|
||||
#include "isl_aff_lex_templ.c"
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER ge
|
||||
#define ORDER ge
|
||||
#undef STRICT_ORDER
|
||||
#define STRICT_ORDER gt
|
||||
#include "isl_aff_lex_templ.c"
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER gt
|
||||
#define ORDER gt
|
||||
#undef STRICT_ORDER
|
||||
#define STRICT_ORDER gt
|
||||
#include "isl_aff_lex_templ.c"
|
||||
|
||||
/* Compare two isl_affs.
|
||||
@ -7689,6 +7792,104 @@ isl_union_pw_multi_aff_apply_union_pw_multi_aff(
|
||||
return isl_union_pw_multi_aff_pullback_union_pw_multi_aff(upma2, upma1);
|
||||
}
|
||||
|
||||
#undef TYPE
|
||||
#define TYPE isl_pw_multi_aff
|
||||
static
|
||||
#include "isl_copy_tuple_id_templ.c"
|
||||
|
||||
/* Given a function "pma1" of the form A[B -> C] -> D and
|
||||
* a function "pma2" of the form E -> B,
|
||||
* replace the domain of the wrapped relation inside the domain of "pma1"
|
||||
* by the preimage with respect to "pma2".
|
||||
* In other words, plug in "pma2" in this nested domain.
|
||||
* The result is of the form A[E -> C] -> D.
|
||||
*
|
||||
* In particular, extend E -> B to A[E -> C] -> A[B -> C] and
|
||||
* plug that into "pma1".
|
||||
*/
|
||||
__isl_give isl_pw_multi_aff *
|
||||
isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
|
||||
__isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2)
|
||||
{
|
||||
isl_space *pma1_space, *pma2_space;
|
||||
isl_space *space;
|
||||
isl_pw_multi_aff *id;
|
||||
|
||||
pma1_space = isl_pw_multi_aff_peek_space(pma1);
|
||||
pma2_space = isl_pw_multi_aff_peek_space(pma2);
|
||||
|
||||
if (isl_space_check_domain_is_wrapping(pma1_space) < 0)
|
||||
goto error;
|
||||
if (isl_space_check_wrapped_tuple_is_equal(pma1_space,
|
||||
isl_dim_in, isl_dim_in, pma2_space, isl_dim_out) < 0)
|
||||
goto error;
|
||||
|
||||
space = isl_space_domain(isl_space_copy(pma1_space));
|
||||
space = isl_space_range(isl_space_unwrap(space));
|
||||
id = isl_pw_multi_aff_identity_on_domain_space(space);
|
||||
pma2 = isl_pw_multi_aff_product(pma2, id);
|
||||
|
||||
pma2 = isl_pw_multi_aff_copy_tuple_id(pma2, isl_dim_in,
|
||||
pma1_space, isl_dim_in);
|
||||
pma2 = isl_pw_multi_aff_copy_tuple_id(pma2, isl_dim_out,
|
||||
pma1_space, isl_dim_in);
|
||||
|
||||
return isl_pw_multi_aff_pullback_pw_multi_aff(pma1, pma2);
|
||||
error:
|
||||
isl_pw_multi_aff_free(pma1);
|
||||
isl_pw_multi_aff_free(pma2);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* If data->pma and "pma2" are such that
|
||||
* data->pma is of the form A[B -> C] -> D and
|
||||
* "pma2" is of the form E -> B,
|
||||
* then replace the domain of the wrapped relation
|
||||
* inside the domain of data->pma by the preimage with respect to "pma2" and
|
||||
* add the result to data->res.
|
||||
*/
|
||||
static isl_stat preimage_domain_wrapped_domain_entry(
|
||||
__isl_take isl_pw_multi_aff *pma2, void *user)
|
||||
{
|
||||
struct isl_union_pw_multi_aff_bin_data *data = user;
|
||||
isl_space *pma1_space, *pma2_space;
|
||||
isl_bool match;
|
||||
|
||||
pma1_space = isl_pw_multi_aff_peek_space(data->pma);
|
||||
pma2_space = isl_pw_multi_aff_peek_space(pma2);
|
||||
|
||||
match = isl_space_domain_is_wrapping(pma1_space);
|
||||
if (match >= 0 && match)
|
||||
match = isl_space_wrapped_tuple_is_equal(pma1_space, isl_dim_in,
|
||||
isl_dim_in, pma2_space, isl_dim_out);
|
||||
if (match < 0 || !match) {
|
||||
isl_pw_multi_aff_free(pma2);
|
||||
return match < 0 ? isl_stat_error : isl_stat_ok;
|
||||
}
|
||||
|
||||
pma2 = isl_pw_multi_aff_preimage_domain_wrapped_domain_pw_multi_aff(
|
||||
isl_pw_multi_aff_copy(data->pma), pma2);
|
||||
|
||||
data->res = isl_union_pw_multi_aff_add_pw_multi_aff(data->res, pma2);
|
||||
|
||||
return isl_stat_non_null(data->res);
|
||||
}
|
||||
|
||||
/* For each pair of functions A[B -> C] -> D in "upma1" and
|
||||
* E -> B in "upma2",
|
||||
* replace the domain of the wrapped relation inside the domain of the first
|
||||
* by the preimage with respect to the second and collect the results.
|
||||
* In other words, plug in the second function in this nested domain.
|
||||
* The results are of the form A[E -> C] -> D.
|
||||
*/
|
||||
__isl_give isl_union_pw_multi_aff *
|
||||
isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff(
|
||||
__isl_take isl_union_pw_multi_aff *upma1,
|
||||
__isl_take isl_union_pw_multi_aff *upma2)
|
||||
{
|
||||
return bin_op(upma1, upma2, &preimage_domain_wrapped_domain_entry);
|
||||
}
|
||||
|
||||
/* Check that the domain space of "upa" matches "space".
|
||||
*
|
||||
* This function is called from isl_multi_union_pw_aff_set_union_pw_aff and
|
||||
|
8
polly/lib/External/isl/isl_aff_lex_templ.c
vendored
8
polly/lib/External/isl/isl_aff_lex_templ.c
vendored
@ -17,15 +17,19 @@
|
||||
* The parameters of "mpa1" and "mpa2" are assumed to have been aligned.
|
||||
*
|
||||
* "mpa1" is in the given lexicographic order compared to "mpa2"
|
||||
* if its i-th element is in that order compared to
|
||||
* if, for some i, the i-th element of "mpa1" is in that order compared to
|
||||
* the i-th element of "mpa2" while all previous elements are
|
||||
* pairwise equal.
|
||||
* pairwise equal, where the order needs to be strict (not-equal)
|
||||
* if i corresponds to anything but the last element.
|
||||
* The strict version of "ORDER" is defined by "STRICT_ORDER",
|
||||
* which is the same if "ORDER" itself is strict.
|
||||
*/
|
||||
static __isl_give isl_map *FN(FN(isl_multi_pw_aff_lex,ORDER),map_on_space)(
|
||||
__isl_keep isl_multi_pw_aff *mpa1, __isl_keep isl_multi_pw_aff *mpa2,
|
||||
__isl_take isl_space *space)
|
||||
{
|
||||
return isl_multi_pw_aff_lex_map_on_space(mpa1, mpa2,
|
||||
&FN(FN(isl_pw_aff,STRICT_ORDER),map),
|
||||
&FN(FN(isl_pw_aff,ORDER),map), space);
|
||||
}
|
||||
|
||||
|
3
polly/lib/External/isl/isl_aff_private.h
vendored
3
polly/lib/External/isl/isl_aff_private.h
vendored
@ -200,6 +200,9 @@ __isl_give isl_basic_set *isl_aff_pos_basic_set(__isl_take isl_aff *aff);
|
||||
|
||||
#undef EXPLICIT_DOMAIN
|
||||
|
||||
__isl_give isl_map *isl_map_intersect_multi_pw_aff_explicit_domain(
|
||||
__isl_take isl_map *map, __isl_keep isl_multi_pw_aff *mpa);
|
||||
|
||||
#undef EL
|
||||
#define EL isl_union_pw_aff
|
||||
|
||||
|
1
polly/lib/External/isl/isl_arg.c
vendored
1
polly/lib/External/isl/isl_arg.c
vendored
@ -17,6 +17,7 @@
|
||||
|
||||
static struct isl_arg help_arg[] = {
|
||||
ISL_ARG_PHANTOM_BOOL('h', "help", NULL, "print this help, then exit")
|
||||
{ isl_arg_end }
|
||||
};
|
||||
|
||||
static void set_default_choice(struct isl_arg *arg, void *opt)
|
||||
|
29
polly/lib/External/isl/isl_ast_codegen.c
vendored
29
polly/lib/External/isl/isl_ast_codegen.c
vendored
@ -5187,6 +5187,32 @@ static __isl_give isl_ast_graft_list *build_ast_from_leaf(
|
||||
return list;
|
||||
}
|
||||
|
||||
/* Check that the band partial schedule "partial" does not filter out
|
||||
* any statement instances, as specified by the range of "executed".
|
||||
*/
|
||||
static isl_stat check_band_schedule_total_on_instances(
|
||||
__isl_keep isl_multi_union_pw_aff *partial,
|
||||
__isl_keep isl_union_map *executed)
|
||||
{
|
||||
isl_bool subset;
|
||||
isl_union_set *domain, *instances;
|
||||
|
||||
instances = isl_union_map_range(isl_union_map_copy(executed));
|
||||
partial = isl_multi_union_pw_aff_copy(partial);
|
||||
domain = isl_multi_union_pw_aff_domain(partial);
|
||||
subset = isl_union_set_is_subset(instances, domain);
|
||||
isl_union_set_free(domain);
|
||||
isl_union_set_free(instances);
|
||||
|
||||
if (subset < 0)
|
||||
return isl_stat_error;
|
||||
if (!subset)
|
||||
isl_die(isl_union_map_get_ctx(executed), isl_error_invalid,
|
||||
"band node is not allowed to drop statement instances",
|
||||
return isl_stat_error);
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Generate an AST that visits the elements in the domain of "executed"
|
||||
* in the relative order specified by the band node "node" and its descendants.
|
||||
*
|
||||
@ -5224,6 +5250,9 @@ static __isl_give isl_ast_graft_list *build_ast_from_band(
|
||||
isl_ast_build_get_space(build, 1));
|
||||
space = isl_multi_union_pw_aff_get_space(extra);
|
||||
|
||||
if (check_band_schedule_total_on_instances(extra, executed) < 0)
|
||||
executed = isl_union_map_free(executed);
|
||||
|
||||
extra_umap = isl_union_map_from_multi_union_pw_aff(extra);
|
||||
extra_umap = isl_union_map_reverse(extra_umap);
|
||||
|
||||
|
50
polly/lib/External/isl/isl_bernstein.c
vendored
50
polly/lib/External/isl/isl_bernstein.c
vendored
@ -99,11 +99,18 @@ error:
|
||||
* which is the case if we select exactly one vertex (i.e., one of the
|
||||
* exponents in "k" is exactly "d") and if that vertex
|
||||
* is integral for all values of the parameters.
|
||||
*
|
||||
* If the degree "d" is zero, then there are no exponents.
|
||||
* Since the polynomial is a constant expression in this case,
|
||||
* the bound is necessarily tight.
|
||||
*/
|
||||
static isl_bool is_tight(int *k, int n, int d, isl_cell *cell)
|
||||
{
|
||||
int i;
|
||||
|
||||
if (d == 0)
|
||||
return isl_bool_true;
|
||||
|
||||
for (i = 0; i < n; ++i) {
|
||||
int v;
|
||||
if (!k[i])
|
||||
@ -352,43 +359,34 @@ error:
|
||||
* We compute the chamber decomposition of the parametric polytope "bset"
|
||||
* and then perform bernstein expansion on the parametric vertices
|
||||
* that are active on each chamber.
|
||||
*
|
||||
* If the polynomial does not depend on the set variables
|
||||
* (and in particular if the number of set variables is zero)
|
||||
* then the bound is equal to the polynomial and
|
||||
* no actual bernstein expansion needs to be performed.
|
||||
*/
|
||||
static __isl_give isl_pw_qpolynomial_fold *bernstein_coefficients_base(
|
||||
__isl_take isl_basic_set *bset,
|
||||
__isl_take isl_qpolynomial *poly, struct bernstein_data *data,
|
||||
isl_bool *tight)
|
||||
{
|
||||
int degree;
|
||||
isl_size nvar;
|
||||
isl_space *space;
|
||||
isl_pw_qpolynomial_fold *pwf;
|
||||
isl_vertices *vertices;
|
||||
isl_bool covers;
|
||||
|
||||
nvar = isl_basic_set_dim(bset, isl_dim_set);
|
||||
if (nvar < 0)
|
||||
bset = isl_basic_set_free(bset);
|
||||
if (nvar == 0) {
|
||||
isl_set *dom;
|
||||
isl_qpolynomial_fold *fold;
|
||||
if (nvar == 0)
|
||||
return isl_qpolynomial_cst_bound(bset, poly, data->type, tight);
|
||||
|
||||
fold = isl_qpolynomial_fold_alloc(data->type, poly);
|
||||
dom = isl_set_from_basic_set(bset);
|
||||
if (tight)
|
||||
*tight = isl_bool_true;
|
||||
pwf = isl_pw_qpolynomial_fold_alloc(data->type, dom, fold);
|
||||
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
|
||||
}
|
||||
|
||||
if (isl_qpolynomial_is_zero(poly)) {
|
||||
isl_set *dom;
|
||||
isl_qpolynomial_fold *fold;
|
||||
fold = isl_qpolynomial_fold_alloc(data->type, poly);
|
||||
dom = isl_set_from_basic_set(bset);
|
||||
pwf = isl_pw_qpolynomial_fold_alloc(data->type, dom, fold);
|
||||
if (tight)
|
||||
*tight = isl_bool_true;
|
||||
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
|
||||
}
|
||||
degree = isl_qpolynomial_degree(poly);
|
||||
if (degree < -1)
|
||||
bset = isl_basic_set_free(bset);
|
||||
if (degree <= 0)
|
||||
return isl_qpolynomial_cst_bound(bset, poly, data->type, tight);
|
||||
|
||||
space = isl_basic_set_get_space(bset);
|
||||
space = isl_space_params(space);
|
||||
@ -482,7 +480,7 @@ static __isl_give isl_pw_qpolynomial_fold *bernstein_coefficients_factors(
|
||||
goto error;
|
||||
if (f->n_group == 0) {
|
||||
isl_factorizer_free(f);
|
||||
return bernstein_coefficients_base(bset, poly, data, tight);
|
||||
return bernstein_coefficients_base(bset, poly, data, tight);
|
||||
}
|
||||
|
||||
set = isl_set_from_basic_set(bset);
|
||||
@ -575,11 +573,9 @@ isl_stat isl_qpolynomial_bound_on_domain_bernstein(
|
||||
pwf = bernstein_coefficients_base(bset, poly, &data, tp);
|
||||
|
||||
if (tight)
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(bound->pwf_tight, pwf);
|
||||
return isl_bound_add_tight(bound, pwf);
|
||||
else
|
||||
bound->pwf = isl_pw_qpolynomial_fold_fold(bound->pwf, pwf);
|
||||
|
||||
return isl_stat_ok;
|
||||
return isl_bound_add(bound, pwf);
|
||||
error:
|
||||
isl_basic_set_free(bset);
|
||||
isl_qpolynomial_free(poly);
|
||||
|
101
polly/lib/External/isl/isl_bound.c
vendored
101
polly/lib/External/isl/isl_bound.c
vendored
@ -16,23 +16,91 @@
|
||||
#include <isl_polynomial_private.h>
|
||||
#include <isl_options_private.h>
|
||||
|
||||
/* Given a polynomial "poly" that is constant in terms
|
||||
* of the domain variables, construct a polynomial reduction
|
||||
* of type "type" that is equal to "poly" on "bset",
|
||||
* with the domain projected onto the parameters.
|
||||
*/
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_qpolynomial_cst_bound(
|
||||
__isl_take isl_basic_set *bset, __isl_take isl_qpolynomial *poly,
|
||||
enum isl_fold type, isl_bool *tight)
|
||||
{
|
||||
isl_set *dom;
|
||||
isl_qpolynomial_fold *fold;
|
||||
isl_pw_qpolynomial_fold *pwf;
|
||||
|
||||
fold = isl_qpolynomial_fold_alloc(type, poly);
|
||||
dom = isl_set_from_basic_set(bset);
|
||||
if (tight)
|
||||
*tight = isl_bool_true;
|
||||
pwf = isl_pw_qpolynomial_fold_alloc(type, dom, fold);
|
||||
return isl_pw_qpolynomial_fold_project_domain_on_params(pwf);
|
||||
}
|
||||
|
||||
/* Add the bound "pwf", which is not known to be tight,
|
||||
* to the output of "bound".
|
||||
*/
|
||||
isl_stat isl_bound_add(struct isl_bound *bound,
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf)
|
||||
{
|
||||
bound->pwf = isl_pw_qpolynomial_fold_fold(bound->pwf, pwf);
|
||||
return isl_stat_non_null(bound->pwf);
|
||||
}
|
||||
|
||||
/* Add the bound "pwf", which is known to be tight,
|
||||
* to the output of "bound".
|
||||
*/
|
||||
isl_stat isl_bound_add_tight(struct isl_bound *bound,
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf)
|
||||
{
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(bound->pwf_tight, pwf);
|
||||
return isl_stat_non_null(bound->pwf);
|
||||
}
|
||||
|
||||
/* Given a polynomial "poly" that is constant in terms
|
||||
* of the domain variables and the domain "bset",
|
||||
* construct the corresponding polynomial reduction and
|
||||
* add it to the tight bounds of "bound".
|
||||
*/
|
||||
static isl_stat add_constant_poly(__isl_take isl_basic_set *bset,
|
||||
__isl_take isl_qpolynomial *poly, struct isl_bound *bound)
|
||||
{
|
||||
isl_pw_qpolynomial_fold *pwf;
|
||||
|
||||
pwf = isl_qpolynomial_cst_bound(bset, poly, bound->type, NULL);
|
||||
return isl_bound_add_tight(bound, pwf);
|
||||
}
|
||||
|
||||
/* Compute a bound on the polynomial defined over the parametric polytope
|
||||
* using either range propagation or bernstein expansion and
|
||||
* store the result in bound->pwf and bound->pwf_tight.
|
||||
* Since bernstein expansion requires bounded domains, we apply
|
||||
* range propagation on unbounded domains. Otherwise, we respect the choice
|
||||
* of the user.
|
||||
*
|
||||
* If the polynomial does not depend on the set variables
|
||||
* then the bound is equal to the polynomial and
|
||||
* it can be added to "bound" directly.
|
||||
*/
|
||||
static isl_stat compressed_guarded_poly_bound(__isl_take isl_basic_set *bset,
|
||||
__isl_take isl_qpolynomial *poly, void *user)
|
||||
{
|
||||
struct isl_bound *bound = (struct isl_bound *)user;
|
||||
isl_ctx *ctx;
|
||||
int bounded;
|
||||
int degree;
|
||||
|
||||
if (!bset || !poly)
|
||||
goto error;
|
||||
|
||||
if (bset->ctx->opt->bound == ISL_BOUND_RANGE)
|
||||
degree = isl_qpolynomial_degree(poly);
|
||||
if (degree < -1)
|
||||
goto error;
|
||||
if (degree <= 0)
|
||||
return add_constant_poly(bset, poly, bound);
|
||||
|
||||
ctx = isl_basic_set_get_ctx(bset);
|
||||
if (ctx->opt->bound == ISL_BOUND_RANGE)
|
||||
return isl_qpolynomial_bound_on_domain_range(bset, poly, bound);
|
||||
|
||||
bounded = isl_basic_set_is_bounded(bset);
|
||||
@ -94,9 +162,8 @@ static isl_stat unwrapped_guarded_poly_bound(__isl_take isl_basic_set *bset,
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_morph_domain(
|
||||
bound->pwf_tight, morph);
|
||||
|
||||
bound->pwf = isl_pw_qpolynomial_fold_fold(top_pwf, bound->pwf);
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(top_pwf_tight,
|
||||
bound->pwf_tight);
|
||||
isl_bound_add(bound, top_pwf);
|
||||
isl_bound_add_tight(bound, top_pwf_tight);
|
||||
|
||||
return r;
|
||||
error:
|
||||
@ -105,6 +172,24 @@ error:
|
||||
return isl_stat_error;
|
||||
}
|
||||
|
||||
/* Update bound->pwf and bound->pwf_tight with a bound
|
||||
* of type bound->type on the polynomial "poly" over the domain "bset".
|
||||
*
|
||||
* If the original problem had a wrapped relation in the domain,
|
||||
* meaning that the bound should be computed over the range
|
||||
* of this relation, then temporarily treat the domain dimensions
|
||||
* of this wrapped relation as parameters, compute a bound
|
||||
* in terms of these and the original parameters,
|
||||
* turn the parameters back into set dimensions and
|
||||
* add the results to bound->pwf and bound->pwf_tight.
|
||||
*
|
||||
* Note that even though "bset" is known to live in the same space
|
||||
* as the domain of "poly", the names of the set dimensions
|
||||
* may be different (or missing). Make sure the naming is exactly
|
||||
* the same before turning these dimensions into parameters
|
||||
* to ensure that the spaces are still the same after
|
||||
* this operation.
|
||||
*/
|
||||
static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
|
||||
__isl_take isl_qpolynomial *poly, void *user)
|
||||
{
|
||||
@ -124,6 +209,9 @@ static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
|
||||
if (nparam < 0 || n_in < 0)
|
||||
goto error;
|
||||
|
||||
space = isl_qpolynomial_get_domain_space(poly);
|
||||
bset = isl_basic_set_reset_space(bset, space);
|
||||
|
||||
bset = isl_basic_set_move_dims(bset, isl_dim_param, nparam,
|
||||
isl_dim_set, 0, n_in);
|
||||
poly = isl_qpolynomial_move_dims(poly, isl_dim_param, nparam,
|
||||
@ -148,9 +236,8 @@ static isl_stat guarded_poly_bound(__isl_take isl_basic_set *bset,
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_reset_space(bound->pwf_tight,
|
||||
isl_space_copy(bound->dim));
|
||||
|
||||
bound->pwf = isl_pw_qpolynomial_fold_fold(top_pwf, bound->pwf);
|
||||
bound->pwf_tight = isl_pw_qpolynomial_fold_fold(top_pwf_tight,
|
||||
bound->pwf_tight);
|
||||
isl_bound_add(bound, top_pwf);
|
||||
isl_bound_add_tight(bound, top_pwf_tight);
|
||||
|
||||
return r;
|
||||
error:
|
||||
|
9
polly/lib/External/isl/isl_bound.h
vendored
9
polly/lib/External/isl/isl_bound.h
vendored
@ -17,4 +17,13 @@ struct isl_bound {
|
||||
isl_pw_qpolynomial_fold *pwf_tight;
|
||||
};
|
||||
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_qpolynomial_cst_bound(
|
||||
__isl_take isl_basic_set *bset, __isl_take isl_qpolynomial *poly,
|
||||
enum isl_fold type, isl_bool *tight);
|
||||
|
||||
isl_stat isl_bound_add(struct isl_bound *bound,
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf);
|
||||
isl_stat isl_bound_add_tight(struct isl_bound *bound,
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf);
|
||||
|
||||
#endif
|
||||
|
1
polly/lib/External/isl/isl_convex_hull.c
vendored
1
polly/lib/External/isl/isl_convex_hull.c
vendored
@ -2618,6 +2618,7 @@ __isl_give isl_basic_map *isl_basic_map_plain_unshifted_simple_hull(
|
||||
|
||||
bmap1 = isl_basic_map_drop_constraints_involving_unknown_divs(bmap1);
|
||||
bmap2 = isl_basic_map_drop_constraints_involving_unknown_divs(bmap2);
|
||||
bmap1 = isl_basic_map_order_divs(bmap1);
|
||||
bmap2 = isl_basic_map_align_divs(bmap2, bmap1);
|
||||
bmap1 = isl_basic_map_align_divs(bmap1, bmap2);
|
||||
bmap1 = isl_basic_map_sort_constraints(bmap1);
|
||||
|
33
polly/lib/External/isl/isl_copy_tuple_id_templ.c
vendored
Normal file
33
polly/lib/External/isl/isl_copy_tuple_id_templ.c
vendored
Normal file
@ -0,0 +1,33 @@
|
||||
/*
|
||||
* Copyright 2019 Cerebras Systems
|
||||
*
|
||||
* Use of this software is governed by the MIT license
|
||||
*
|
||||
* Written by Sven Verdoolaege,
|
||||
* Cerebras Systems, 175 S San Antonio Rd, Los Altos, CA, USA
|
||||
*/
|
||||
|
||||
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
|
||||
#define FN(TYPE,NAME) xFN(TYPE,NAME)
|
||||
|
||||
/* Copy the identifier of tuple "src_type" in "src"
|
||||
* to that of "dst_type" in "dst", if there is any such identifier.
|
||||
*/
|
||||
__isl_give TYPE *FN(TYPE,copy_tuple_id)(__isl_take TYPE *dst,
|
||||
enum isl_dim_type dst_type, __isl_keep isl_space *src,
|
||||
enum isl_dim_type src_type)
|
||||
{
|
||||
isl_bool has_id;
|
||||
isl_id *id;
|
||||
|
||||
has_id = isl_space_has_tuple_id(src, src_type);
|
||||
if (has_id < 0)
|
||||
return FN(TYPE,free)(dst);
|
||||
if (!has_id)
|
||||
return dst;
|
||||
|
||||
id = isl_space_get_tuple_id(src, src_type);
|
||||
dst = FN(TYPE,set_tuple_id)(dst, dst_type, id);
|
||||
|
||||
return dst;
|
||||
}
|
1195
polly/lib/External/isl/isl_fold.c
vendored
1195
polly/lib/External/isl/isl_fold.c
vendored
File diff suppressed because it is too large
Load Diff
55
polly/lib/External/isl/isl_input.c
vendored
55
polly/lib/External/isl/isl_input.c
vendored
@ -593,10 +593,7 @@ static __isl_give isl_pw_aff *add_cst(__isl_take isl_pw_aff *pwaff, isl_int v)
|
||||
*/
|
||||
static __isl_give isl_pw_aff *nan_on_domain(__isl_keep isl_space *space)
|
||||
{
|
||||
isl_local_space *ls;
|
||||
|
||||
ls = isl_local_space_from_space(isl_space_copy(space));
|
||||
return isl_pw_aff_nan_on_domain(ls);
|
||||
return isl_pw_aff_nan_on_domain_space(isl_space_copy(space));
|
||||
}
|
||||
|
||||
static __isl_give isl_pw_aff *accept_affine(__isl_keep isl_stream *s,
|
||||
@ -2602,24 +2599,28 @@ static struct isl_obj obj_read_poly(__isl_keep isl_stream *s,
|
||||
static struct isl_obj obj_read_poly_or_fold(__isl_keep isl_stream *s,
|
||||
__isl_take isl_set *set, struct vars *v, int n)
|
||||
{
|
||||
int min, max;
|
||||
struct isl_obj obj = { isl_obj_pw_qpolynomial_fold, NULL };
|
||||
isl_pw_qpolynomial *pwqp;
|
||||
isl_pw_qpolynomial_fold *pwf = NULL;
|
||||
enum isl_fold fold;
|
||||
|
||||
if (!isl_stream_eat_if_available(s, ISL_TOKEN_MAX))
|
||||
max = isl_stream_eat_if_available(s, ISL_TOKEN_MAX);
|
||||
min = !max && isl_stream_eat_if_available(s, ISL_TOKEN_MIN);
|
||||
if (!min && !max)
|
||||
return obj_read_poly(s, set, v, n);
|
||||
fold = max ? isl_fold_max : isl_fold_min;
|
||||
|
||||
if (isl_stream_eat(s, '('))
|
||||
goto error;
|
||||
|
||||
pwqp = read_term(s, set, v);
|
||||
pwf = isl_pw_qpolynomial_fold_from_pw_qpolynomial(isl_fold_max, pwqp);
|
||||
pwf = isl_pw_qpolynomial_fold_from_pw_qpolynomial(fold, pwqp);
|
||||
|
||||
while (isl_stream_eat_if_available(s, ',')) {
|
||||
isl_pw_qpolynomial_fold *pwf_i;
|
||||
pwqp = read_term(s, set, v);
|
||||
pwf_i = isl_pw_qpolynomial_fold_from_pw_qpolynomial(isl_fold_max,
|
||||
pwqp);
|
||||
pwf_i = isl_pw_qpolynomial_fold_from_pw_qpolynomial(fold, pwqp);
|
||||
pwf = isl_pw_qpolynomial_fold_fold(pwf, pwf_i);
|
||||
}
|
||||
|
||||
@ -3385,7 +3386,43 @@ __isl_give isl_pw_qpolynomial *isl_pw_qpolynomial_read_from_file(isl_ctx *ctx,
|
||||
return pwqp;
|
||||
}
|
||||
|
||||
/* Is the next token an identifer not in "v"?
|
||||
/* Read an isl_pw_qpolynomial_fold from "s".
|
||||
* First read a generic object and
|
||||
* then check that it is an isl_pw_qpolynomial_fold.
|
||||
*/
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_stream_read_pw_qpolynomial_fold(
|
||||
__isl_keep isl_stream *s)
|
||||
{
|
||||
struct isl_obj obj;
|
||||
|
||||
obj = obj_read(s);
|
||||
if (obj.v && obj.type != isl_obj_pw_qpolynomial_fold)
|
||||
isl_die(s->ctx, isl_error_invalid, "invalid input", goto error);
|
||||
|
||||
return obj.v;
|
||||
error:
|
||||
obj.type->free(obj.v);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read an isl_pw_qpolynomial_fold from "str".
|
||||
*/
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_read_from_str(
|
||||
isl_ctx *ctx, const char *str)
|
||||
{
|
||||
isl_pw_qpolynomial_fold *pwqp;
|
||||
isl_stream *s;
|
||||
|
||||
s = isl_stream_new_str(ctx, str);
|
||||
if (!s)
|
||||
return NULL;
|
||||
pwqp = isl_stream_read_pw_qpolynomial_fold(s);
|
||||
isl_stream_free(s);
|
||||
|
||||
return pwqp;
|
||||
}
|
||||
|
||||
/* Is the next token an identifier not in "v"?
|
||||
*/
|
||||
static int next_is_fresh_ident(__isl_keep isl_stream *s, struct vars *v)
|
||||
{
|
||||
|
10
polly/lib/External/isl/isl_list_private.h
vendored
Normal file
10
polly/lib/External/isl/isl_list_private.h
vendored
Normal file
@ -0,0 +1,10 @@
|
||||
#ifndef ISL_LIST_PRIVATE_H
|
||||
#define ISL_LIST_PRIVATE_H
|
||||
|
||||
#include <isl/list.h>
|
||||
|
||||
#define ISL_DECLARE_LIST_FN_PRIVATE(EL) \
|
||||
__isl_keep isl_##EL *isl_##EL##_list_peek( \
|
||||
__isl_keep isl_##EL##_list *list, int index);
|
||||
|
||||
#endif
|
2
polly/lib/External/isl/isl_list_templ.c
vendored
2
polly/lib/External/isl/isl_list_templ.c
vendored
@ -265,7 +265,7 @@ isl_size FN(FN(LIST(EL),n),EL_BASE)(__isl_keep LIST(EL) *list)
|
||||
|
||||
/* Return the element at position "index" in "list".
|
||||
*/
|
||||
static __isl_keep EL *FN(LIST(EL),peek)(__isl_keep LIST(EL) *list, int index)
|
||||
__isl_keep EL *FN(LIST(EL),peek)(__isl_keep LIST(EL) *list, int index)
|
||||
{
|
||||
if (FN(LIST(EL),check_index)(list, index) < 0)
|
||||
return NULL;
|
||||
|
11
polly/lib/External/isl/isl_local_space.c
vendored
11
polly/lib/External/isl/isl_local_space.c
vendored
@ -37,7 +37,7 @@ uint32_t isl_local_space_get_hash(__isl_keep isl_local_space *ls)
|
||||
return 0;
|
||||
|
||||
hash = isl_hash_init();
|
||||
space_hash = isl_space_get_hash(ls->dim);
|
||||
space_hash = isl_space_get_full_hash(isl_local_space_peek_space(ls));
|
||||
isl_hash_hash(hash, space_hash);
|
||||
div_hash = isl_mat_get_hash(ls->div);
|
||||
isl_hash_hash(hash, div_hash);
|
||||
@ -163,14 +163,7 @@ isl_bool isl_local_space_is_set(__isl_keep isl_local_space *ls)
|
||||
#define TYPE isl_local_space
|
||||
|
||||
#include "isl_type_has_equal_space_bin_templ.c"
|
||||
|
||||
/* Is the space of "ls" equal to "space"?
|
||||
*/
|
||||
isl_bool isl_local_space_has_space(__isl_keep isl_local_space *ls,
|
||||
__isl_keep isl_space *space)
|
||||
{
|
||||
return isl_space_is_equal(isl_local_space_peek_space(ls), space);
|
||||
}
|
||||
#include "isl_type_has_space_templ.c"
|
||||
|
||||
/* Check that the space of "ls" is equal to "space".
|
||||
*/
|
||||
|
123
polly/lib/External/isl/isl_map.c
vendored
123
polly/lib/External/isl/isl_map.c
vendored
@ -6864,6 +6864,18 @@ __isl_give isl_set *isl_set_upper_bound_val(__isl_take isl_set *set,
|
||||
return set_from_map(isl_map_upper_bound_val(map, type, pos, value));
|
||||
}
|
||||
|
||||
/* If "mv" has an explicit domain, then intersect the domain of "map"
|
||||
* with this explicit domain.
|
||||
*
|
||||
* An isl_multi_val object never has an explicit domain,
|
||||
* so simply return "map".
|
||||
*/
|
||||
static __isl_give isl_map *isl_map_intersect_multi_val_explicit_domain(
|
||||
__isl_take isl_map *map, __isl_keep isl_multi_val *mv)
|
||||
{
|
||||
return map;
|
||||
}
|
||||
|
||||
#undef BASE
|
||||
#define BASE val
|
||||
#include "isl_map_bound_templ.c"
|
||||
@ -6921,15 +6933,6 @@ __isl_give isl_set *isl_set_lower_bound_multi_val(__isl_take isl_set *set,
|
||||
return set_bound_multi_val(set, lower, &map_lower_bound_val);
|
||||
}
|
||||
|
||||
/* Force the values of the output dimensions of "map"
|
||||
* to be no smaller than the corresponding values in "lower".
|
||||
*/
|
||||
__isl_give isl_map *isl_map_lower_bound_multi_val(__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *lower)
|
||||
{
|
||||
return map_bound_multi_val(map, lower, &map_lower_bound_val);
|
||||
}
|
||||
|
||||
/* Wrapper around isl_map_upper_bound_val for use in map_bound_multi_val,
|
||||
* setting a bound on the given output dimension.
|
||||
*/
|
||||
@ -6948,15 +6951,6 @@ __isl_give isl_set *isl_set_upper_bound_multi_val(__isl_take isl_set *set,
|
||||
return set_bound_multi_val(set, upper, &map_upper_bound_val);
|
||||
}
|
||||
|
||||
/* Force the values of the set dimensions of "set"
|
||||
* to be no greater than the corresponding values in "upper".
|
||||
*/
|
||||
__isl_give isl_map *isl_map_upper_bound_multi_val(__isl_take isl_map *map,
|
||||
__isl_take isl_multi_val *upper)
|
||||
{
|
||||
return map_bound_multi_val(map, upper, &map_upper_bound_val);
|
||||
}
|
||||
|
||||
/* Force the symbolic constant expression "bound"
|
||||
* to satisfy the relation "order" with respect to
|
||||
* the output variable at position "pos" of "map".
|
||||
@ -8287,6 +8281,11 @@ error:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
#undef TYPE
|
||||
#define TYPE isl_map
|
||||
static
|
||||
#include "isl_copy_tuple_id_templ.c"
|
||||
|
||||
/* Data structure that specifies how isl_map_intersect_factor
|
||||
* should operate.
|
||||
*
|
||||
@ -8322,8 +8321,7 @@ static __isl_give isl_map *isl_map_intersect_factor(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor,
|
||||
struct isl_intersect_factor_control *control)
|
||||
{
|
||||
isl_bool equal, has_id;
|
||||
isl_id *id;
|
||||
isl_bool equal;
|
||||
isl_space *space;
|
||||
isl_map *other, *product;
|
||||
|
||||
@ -8336,19 +8334,12 @@ static __isl_give isl_map *isl_map_intersect_factor(
|
||||
}
|
||||
|
||||
space = isl_map_get_space(map);
|
||||
has_id = isl_space_has_tuple_id(space, control->preserve_type);
|
||||
if (has_id < 0)
|
||||
space = isl_space_free(space);
|
||||
else if (has_id)
|
||||
id = isl_space_get_tuple_id(space, control->preserve_type);
|
||||
|
||||
other = isl_map_universe(control->other_factor(space));
|
||||
product = control->product(factor, other);
|
||||
|
||||
if (has_id >= 0 && has_id)
|
||||
product = isl_map_set_tuple_id(product,
|
||||
control->preserve_type, id);
|
||||
|
||||
space = isl_map_peek_space(map);
|
||||
product = isl_map_copy_tuple_id(product, control->preserve_type,
|
||||
space, control->preserve_type);
|
||||
return map_intersect(map, product);
|
||||
error:
|
||||
isl_map_free(map);
|
||||
@ -8372,6 +8363,21 @@ static __isl_give isl_map *isl_map_reverse_range_product(
|
||||
return isl_map_range_product(map2, map1);
|
||||
}
|
||||
|
||||
/* Given a map "map" in a space [A -> B] -> C and a map "factor"
|
||||
* in the space A -> C, return the intersection.
|
||||
*/
|
||||
__isl_give isl_map *isl_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_map *map, __isl_take isl_map *factor)
|
||||
{
|
||||
struct isl_intersect_factor_control control = {
|
||||
.preserve_type = isl_dim_in,
|
||||
.other_factor = isl_space_domain_factor_range,
|
||||
.product = isl_map_domain_product,
|
||||
};
|
||||
|
||||
return isl_map_intersect_factor(map, factor, &control);
|
||||
}
|
||||
|
||||
/* Given a map "map" in a space [A -> B] -> C and a map "factor"
|
||||
* in the space B -> C, return the intersection.
|
||||
*/
|
||||
@ -8604,6 +8610,17 @@ isl_bool isl_map_tuple_is_equal(__isl_keep isl_map *map1,
|
||||
return isl_space_tuple_is_equal(space1, type1, space2, type2);
|
||||
}
|
||||
|
||||
/* Is the space of "obj" equal to "space", ignoring parameters?
|
||||
*/
|
||||
isl_bool isl_map_has_space_tuples(__isl_keep isl_map *map,
|
||||
__isl_keep isl_space *space)
|
||||
{
|
||||
isl_space *map_space;
|
||||
|
||||
map_space = isl_map_peek_space(map);
|
||||
return isl_space_has_equal_tuples(map_space, space);
|
||||
}
|
||||
|
||||
/* Check that "map" is a transformation, i.e.,
|
||||
* that it relates elements from the same space.
|
||||
*/
|
||||
@ -8707,6 +8724,20 @@ __isl_give isl_map *isl_map_deltas_map(__isl_take isl_map *map)
|
||||
&isl_basic_map_deltas_map);
|
||||
}
|
||||
|
||||
/* Return pairs of elements { x -> y } such that y - x is in "deltas".
|
||||
*/
|
||||
__isl_give isl_map *isl_set_translation(__isl_take isl_set *deltas)
|
||||
{
|
||||
isl_space *space;
|
||||
isl_map *map;
|
||||
|
||||
space = isl_space_map_from_set(isl_set_get_space(deltas));
|
||||
map = isl_map_deltas_map(isl_map_universe(space));
|
||||
map = isl_map_intersect_range(map, deltas);
|
||||
|
||||
return isl_set_unwrap(isl_map_domain(map));
|
||||
}
|
||||
|
||||
__isl_give isl_basic_map *isl_basic_map_identity(__isl_take isl_space *space)
|
||||
{
|
||||
isl_size n_in, n_out;
|
||||
@ -9022,6 +9053,7 @@ isl_stat isl_basic_set_check_equal_space(__isl_keep isl_basic_set *bset1,
|
||||
|
||||
#include "isl_type_has_equal_space_bin_templ.c"
|
||||
#include "isl_type_check_equal_space_templ.c"
|
||||
#include "isl_type_has_space_templ.c"
|
||||
|
||||
isl_bool isl_set_has_equal_space(__isl_keep isl_set *set1,
|
||||
__isl_keep isl_set *set2)
|
||||
@ -9480,6 +9512,16 @@ static int find_div(__isl_keep isl_basic_map *dst,
|
||||
/* Align the divs of "dst" to those of "src", adding divs from "src"
|
||||
* if needed. That is, make sure that the first src->n_div divs
|
||||
* of the result are equal to those of src.
|
||||
* The integer division of "src" are assumed to be ordered.
|
||||
*
|
||||
* The integer divisions are swapped into the right position
|
||||
* (possibly after adding them first). This may result
|
||||
* in the remaining integer divisions appearing in the wrong order,
|
||||
* i.e., with some integer division appearing before
|
||||
* some other integer division on which it depends.
|
||||
* The integer divisions therefore need to be ordered.
|
||||
* This will not affect the integer divisions aligned to those of "src",
|
||||
* since "src" is assumed to have ordered integer divisions.
|
||||
*
|
||||
* The result is not finalized as by design it will have redundant
|
||||
* divs if any divs from "src" were copied.
|
||||
@ -9511,10 +9553,6 @@ __isl_give isl_basic_map *isl_basic_map_align_divs(
|
||||
if (v_div < 0)
|
||||
return isl_basic_map_free(dst);
|
||||
|
||||
src = isl_basic_map_order_divs(isl_basic_map_copy(src));
|
||||
if (!src)
|
||||
return isl_basic_map_free(dst);
|
||||
|
||||
extended = 0;
|
||||
dst_n_div = isl_basic_map_dim(dst, isl_dim_div);
|
||||
if (dst_n_div < 0)
|
||||
@ -9528,32 +9566,27 @@ __isl_give isl_basic_map *isl_basic_map_align_divs(
|
||||
int extra = src->n_div - i;
|
||||
dst = isl_basic_map_cow(dst);
|
||||
if (!dst)
|
||||
goto error;
|
||||
return isl_basic_map_free(dst);
|
||||
dst = isl_basic_map_extend(dst,
|
||||
extra, 0, 2 * extra);
|
||||
extended = 1;
|
||||
}
|
||||
j = isl_basic_map_alloc_div(dst);
|
||||
if (j < 0)
|
||||
goto error;
|
||||
return isl_basic_map_free(dst);
|
||||
isl_seq_cpy(dst->div[j], src->div[i], 1+1+v_div+i);
|
||||
isl_seq_clr(dst->div[j]+1+1+v_div+i, dst->n_div - i);
|
||||
dst_n_div++;
|
||||
dst = isl_basic_map_add_div_constraints(dst, j);
|
||||
if (!dst)
|
||||
goto error;
|
||||
return isl_basic_map_free(dst);
|
||||
}
|
||||
if (j != i)
|
||||
dst = isl_basic_map_swap_div(dst, i, j);
|
||||
if (!dst)
|
||||
goto error;
|
||||
return isl_basic_map_free(dst);
|
||||
}
|
||||
isl_basic_map_free(src);
|
||||
return dst;
|
||||
error:
|
||||
isl_basic_map_free(src);
|
||||
isl_basic_map_free(dst);
|
||||
return NULL;
|
||||
return isl_basic_map_order_divs(dst);
|
||||
}
|
||||
|
||||
__isl_give isl_map *isl_map_align_divs_internal(__isl_take isl_map *map)
|
||||
@ -9565,6 +9598,7 @@ __isl_give isl_map *isl_map_align_divs_internal(__isl_take isl_map *map)
|
||||
if (map->n == 0)
|
||||
return map;
|
||||
map = isl_map_compute_divs(map);
|
||||
map = isl_map_order_divs(map);
|
||||
map = isl_map_cow(map);
|
||||
if (!map)
|
||||
return NULL;
|
||||
@ -9613,6 +9647,7 @@ __isl_give isl_map *isl_map_align_divs_to_basic_map_list(
|
||||
isl_basic_map *bmap;
|
||||
|
||||
bmap = isl_basic_map_list_get_basic_map(list, i);
|
||||
bmap = isl_basic_map_order_divs(bmap);
|
||||
map->p[0] = isl_basic_map_align_divs(map->p[0], bmap);
|
||||
isl_basic_map_free(bmap);
|
||||
}
|
||||
|
4
polly/lib/External/isl/isl_map_bound_templ.c
vendored
4
polly/lib/External/isl/isl_map_bound_templ.c
vendored
@ -25,6 +25,9 @@ static isl_stat FN(check_map_equal_tuples_multi,BASE)(__isl_keep isl_map *map,
|
||||
|
||||
/* Apply "map_bound" to "map" with the corresponding value in "bound"
|
||||
* for each output dimension.
|
||||
* If "bound" has an explicit domain (which implies that "bound"
|
||||
* is zero-dimensional), then intersect the domain of "map"
|
||||
* with this explicit domain instead.
|
||||
*/
|
||||
static __isl_give isl_map *FN(map_bound_multi,BASE)(__isl_take isl_map *map,
|
||||
__isl_take MULTI(BASE) *bound,
|
||||
@ -44,6 +47,7 @@ static __isl_give isl_map *FN(map_bound_multi,BASE)(__isl_take isl_map *map,
|
||||
el = FN(MULTI(BASE),get_at)(bound, i);
|
||||
map = map_bound(map, i, el);
|
||||
}
|
||||
map = FN(FN(isl_map_intersect_multi,BASE),explicit_domain)(map, bound);
|
||||
FN(MULTI(BASE),free)(bound);
|
||||
return map;
|
||||
error:
|
||||
|
4
polly/lib/External/isl/isl_map_private.h
vendored
4
polly/lib/External/isl/isl_map_private.h
vendored
@ -562,6 +562,10 @@ isl_bool isl_map_space_tuple_is_equal(__isl_keep isl_map *map,
|
||||
isl_bool isl_map_tuple_is_equal(__isl_keep isl_map *map1,
|
||||
enum isl_dim_type type1, __isl_keep isl_map *map2,
|
||||
enum isl_dim_type type2);
|
||||
isl_bool isl_map_has_space(__isl_keep isl_map *map,
|
||||
__isl_keep isl_space *space);
|
||||
isl_bool isl_map_has_space_tuples(__isl_keep isl_map *map,
|
||||
__isl_keep isl_space *space);
|
||||
|
||||
isl_bool isl_basic_map_is_transformation(__isl_keep isl_basic_map *bmap);
|
||||
isl_stat isl_map_check_transformation(__isl_keep isl_map *map);
|
||||
|
3
polly/lib/External/isl/isl_map_simplify.c
vendored
3
polly/lib/External/isl/isl_map_simplify.c
vendored
@ -2149,6 +2149,7 @@ static __isl_give isl_basic_map *isl_basic_map_remove_shifted_constraints(
|
||||
return bmap;
|
||||
}
|
||||
|
||||
bmap = isl_basic_map_order_divs(bmap);
|
||||
context = isl_basic_map_align_divs(context, bmap);
|
||||
bmap = isl_basic_map_align_divs(bmap, context);
|
||||
|
||||
@ -3284,6 +3285,7 @@ __isl_give isl_basic_map *isl_basic_map_gist(__isl_take isl_basic_map *bmap,
|
||||
|
||||
bmap = isl_basic_map_remove_redundancies(bmap);
|
||||
context = isl_basic_map_remove_redundancies(context);
|
||||
bmap = isl_basic_map_order_divs(bmap);
|
||||
context = isl_basic_map_align_divs(context, bmap);
|
||||
|
||||
n_div = isl_basic_map_dim(context, isl_dim_div);
|
||||
@ -3520,6 +3522,7 @@ __isl_give isl_basic_map *isl_basic_map_plain_gist(
|
||||
isl_die(isl_basic_map_get_ctx(bmap), isl_error_invalid,
|
||||
"context has unknown divs", goto error);
|
||||
|
||||
context = isl_basic_map_order_divs(context);
|
||||
bmap = isl_basic_map_align_divs(bmap, context);
|
||||
bmap = isl_basic_map_gauss(bmap, NULL);
|
||||
bmap = isl_basic_map_sort_constraints(bmap);
|
||||
|
18
polly/lib/External/isl/isl_mat.c
vendored
18
polly/lib/External/isl/isl_mat.c
vendored
@ -64,12 +64,14 @@ __isl_give isl_mat *isl_mat_alloc(isl_ctx *ctx,
|
||||
mat->block = isl_blk_alloc(ctx, n_row * n_col);
|
||||
if (isl_blk_is_error(mat->block))
|
||||
goto error;
|
||||
mat->row = isl_alloc_array(ctx, isl_int *, n_row);
|
||||
mat->row = isl_calloc_array(ctx, isl_int *, n_row);
|
||||
if (n_row && !mat->row)
|
||||
goto error;
|
||||
|
||||
for (i = 0; i < n_row; ++i)
|
||||
mat->row[i] = mat->block.data + i * n_col;
|
||||
if (n_col != 0) {
|
||||
for (i = 0; i < n_row; ++i)
|
||||
mat->row[i] = mat->block.data + i * n_col;
|
||||
}
|
||||
|
||||
mat->ctx = ctx;
|
||||
isl_ctx_ref(ctx);
|
||||
@ -646,9 +648,6 @@ __isl_give isl_mat *isl_mat_left_hermite(__isl_take isl_mat *M, int neg,
|
||||
*U = NULL;
|
||||
if (Q)
|
||||
*Q = NULL;
|
||||
if (!M)
|
||||
goto error;
|
||||
M = isl_mat_cow(M);
|
||||
if (!M)
|
||||
goto error;
|
||||
if (U) {
|
||||
@ -662,6 +661,13 @@ __isl_give isl_mat *isl_mat_left_hermite(__isl_take isl_mat *M, int neg,
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (M->n_col == 0)
|
||||
return M;
|
||||
|
||||
M = isl_mat_cow(M);
|
||||
if (!M)
|
||||
goto error;
|
||||
|
||||
col = 0;
|
||||
isl_int_init(c);
|
||||
for (row = 0; row < M->n_row; ++row) {
|
||||
|
239
polly/lib/External/isl/isl_morph.c
vendored
239
polly/lib/External/isl/isl_morph.c
vendored
@ -18,6 +18,8 @@
|
||||
#include <isl_space_private.h>
|
||||
#include <isl_equalities.h>
|
||||
#include <isl_id_private.h>
|
||||
#include <isl_aff_private.h>
|
||||
#include <isl_vec_private.h>
|
||||
|
||||
isl_ctx *isl_morph_get_ctx(__isl_keep isl_morph *morph)
|
||||
{
|
||||
@ -179,12 +181,46 @@ __isl_give isl_multi_aff *isl_morph_get_var_multi_aff(
|
||||
|
||||
/* Return the domain space of "morph".
|
||||
*/
|
||||
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph)
|
||||
static __isl_keep isl_space *isl_morph_peek_dom_space(
|
||||
__isl_keep isl_morph *morph)
|
||||
{
|
||||
if (!morph)
|
||||
return NULL;
|
||||
|
||||
return isl_basic_set_get_space(morph->dom);
|
||||
return isl_basic_set_peek_space(morph->dom);
|
||||
}
|
||||
|
||||
/* Return a copy of the domain space of "morph".
|
||||
*/
|
||||
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph)
|
||||
{
|
||||
return isl_space_copy(isl_morph_peek_dom_space(morph));
|
||||
}
|
||||
|
||||
/* Check that the match against "space" with result "match" was successful.
|
||||
*/
|
||||
static isl_stat check_space_match(__isl_keep isl_space *space, isl_bool match)
|
||||
{
|
||||
if (match < 0)
|
||||
return isl_stat_error;
|
||||
if (!match)
|
||||
isl_die(isl_space_get_ctx(space), isl_error_invalid,
|
||||
"spaces don't match", return isl_stat_error);
|
||||
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Check that "morph" can be applied to the "space".
|
||||
*/
|
||||
isl_stat isl_morph_check_applies(__isl_keep isl_morph *morph,
|
||||
__isl_keep isl_space *space)
|
||||
{
|
||||
isl_space *dom_space;
|
||||
isl_bool applies;
|
||||
|
||||
dom_space = isl_morph_peek_dom_space(morph);
|
||||
applies = isl_space_is_equal(dom_space, space);
|
||||
return check_space_match(space, applies);
|
||||
}
|
||||
|
||||
__isl_give isl_space *isl_morph_get_ran_space(__isl_keep isl_morph *morph)
|
||||
@ -573,191 +609,96 @@ __isl_give isl_morph *isl_basic_set_parameter_compression(
|
||||
return isl_morph_alloc(dom, ran, map, inv);
|
||||
}
|
||||
|
||||
/* Add stride constraints to "bset" based on the inverse mapping
|
||||
* that was plugged in. In particular, if morph maps x' to x,
|
||||
* the constraints of the original input
|
||||
*
|
||||
* A x' + b >= 0
|
||||
*
|
||||
* have been rewritten to
|
||||
*
|
||||
* A inv x + b >= 0
|
||||
*
|
||||
* However, this substitution may loose information on the integrality of x',
|
||||
* so we need to impose that
|
||||
*
|
||||
* inv x
|
||||
*
|
||||
* is integral. If inv = B/d, this means that we need to impose that
|
||||
*
|
||||
* B x = 0 mod d
|
||||
*
|
||||
* or
|
||||
*
|
||||
* exists alpha in Z^m: B x = d alpha
|
||||
*
|
||||
* This function is similar to add_strides in isl_affine_hull.c
|
||||
/* Construct an isl_multi_aff that corresponds
|
||||
* to the affine transformation matrix "mat" and
|
||||
* that lives in an anonymous space.
|
||||
*/
|
||||
static __isl_give isl_basic_set *add_strides(__isl_take isl_basic_set *bset,
|
||||
__isl_keep isl_morph *morph)
|
||||
static __isl_give isl_multi_aff *isl_multi_aff_from_aff_mat_anonymous(
|
||||
__isl_take isl_mat *mat)
|
||||
{
|
||||
int i, div, k;
|
||||
isl_int gcd;
|
||||
isl_size n_row, n_col;
|
||||
isl_ctx *ctx;
|
||||
isl_space *space;
|
||||
|
||||
if (isl_int_is_one(morph->inv->row[0][0]))
|
||||
return bset;
|
||||
ctx = isl_mat_get_ctx(mat);
|
||||
n_row = isl_mat_rows(mat);
|
||||
n_col = isl_mat_cols(mat);
|
||||
if (n_row < 0 || n_col < 0)
|
||||
space = NULL;
|
||||
else
|
||||
space = isl_space_alloc(ctx, 0, n_col - 1, n_row - 1);
|
||||
|
||||
isl_int_init(gcd);
|
||||
|
||||
for (i = 0; 1 + i < morph->inv->n_row; ++i) {
|
||||
isl_seq_gcd(morph->inv->row[1 + i], morph->inv->n_col, &gcd);
|
||||
if (isl_int_is_divisible_by(gcd, morph->inv->row[0][0]))
|
||||
continue;
|
||||
div = isl_basic_set_alloc_div(bset);
|
||||
if (div < 0)
|
||||
goto error;
|
||||
isl_int_set_si(bset->div[div][0], 0);
|
||||
k = isl_basic_set_alloc_equality(bset);
|
||||
if (k < 0)
|
||||
goto error;
|
||||
isl_seq_cpy(bset->eq[k], morph->inv->row[1 + i],
|
||||
morph->inv->n_col);
|
||||
isl_seq_clr(bset->eq[k] + morph->inv->n_col, bset->n_div);
|
||||
isl_int_set(bset->eq[k][morph->inv->n_col + div],
|
||||
morph->inv->row[0][0]);
|
||||
}
|
||||
|
||||
isl_int_clear(gcd);
|
||||
|
||||
return bset;
|
||||
error:
|
||||
isl_int_clear(gcd);
|
||||
isl_basic_set_free(bset);
|
||||
return NULL;
|
||||
return isl_multi_aff_from_aff_mat(space, mat);
|
||||
}
|
||||
|
||||
/* Apply the morphism to the basic set.
|
||||
* We basically just compute the preimage of "bset" under the inverse mapping
|
||||
* in morph, add in stride constraints and intersect with the range
|
||||
* of the morphism.
|
||||
* In particular, compute the preimage of "bset" under the inverse mapping
|
||||
* in morph and intersect with the range of the morphism.
|
||||
* Note that the mapping in morph applies to both parameters and set dimensions,
|
||||
* so the parameters need to be treated as set dimensions during the call
|
||||
* to isl_basic_set_preimage_multi_aff.
|
||||
*/
|
||||
__isl_give isl_basic_set *isl_morph_basic_set(__isl_take isl_morph *morph,
|
||||
__isl_take isl_basic_set *bset)
|
||||
{
|
||||
isl_basic_set *res = NULL;
|
||||
isl_mat *mat = NULL;
|
||||
int i, k;
|
||||
int max_stride;
|
||||
isl_size n_param;
|
||||
isl_space *space;
|
||||
isl_multi_aff *ma;
|
||||
|
||||
if (!morph || isl_basic_set_check_equal_space(bset, morph->dom) < 0)
|
||||
goto error;
|
||||
|
||||
max_stride = morph->inv->n_row - 1;
|
||||
if (isl_int_is_one(morph->inv->row[0][0]))
|
||||
max_stride = 0;
|
||||
res = isl_basic_set_alloc_space(isl_space_copy(morph->ran->dim),
|
||||
bset->n_div + max_stride, bset->n_eq + max_stride, bset->n_ineq);
|
||||
|
||||
for (i = 0; i < bset->n_div; ++i)
|
||||
if (isl_basic_set_alloc_div(res) < 0)
|
||||
goto error;
|
||||
|
||||
mat = isl_mat_sub_alloc6(bset->ctx, bset->eq, 0, bset->n_eq,
|
||||
0, morph->inv->n_row);
|
||||
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
|
||||
if (!mat)
|
||||
n_param = isl_basic_set_dim(morph->dom, isl_dim_param);
|
||||
if (n_param < 0)
|
||||
goto error;
|
||||
for (i = 0; i < bset->n_eq; ++i) {
|
||||
k = isl_basic_set_alloc_equality(res);
|
||||
if (k < 0)
|
||||
goto error;
|
||||
isl_seq_cpy(res->eq[k], mat->row[i], mat->n_col);
|
||||
isl_seq_scale(res->eq[k] + mat->n_col, bset->eq[i] + mat->n_col,
|
||||
morph->inv->row[0][0], bset->n_div);
|
||||
}
|
||||
isl_mat_free(mat);
|
||||
|
||||
mat = isl_mat_sub_alloc6(bset->ctx, bset->ineq, 0, bset->n_ineq,
|
||||
0, morph->inv->n_row);
|
||||
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
|
||||
if (!mat)
|
||||
goto error;
|
||||
for (i = 0; i < bset->n_ineq; ++i) {
|
||||
k = isl_basic_set_alloc_inequality(res);
|
||||
if (k < 0)
|
||||
goto error;
|
||||
isl_seq_cpy(res->ineq[k], mat->row[i], mat->n_col);
|
||||
isl_seq_scale(res->ineq[k] + mat->n_col,
|
||||
bset->ineq[i] + mat->n_col,
|
||||
morph->inv->row[0][0], bset->n_div);
|
||||
}
|
||||
isl_mat_free(mat);
|
||||
ma = isl_multi_aff_from_aff_mat_anonymous(isl_mat_copy(morph->inv));
|
||||
|
||||
mat = isl_mat_sub_alloc6(bset->ctx, bset->div, 0, bset->n_div,
|
||||
1, morph->inv->n_row);
|
||||
mat = isl_mat_product(mat, isl_mat_copy(morph->inv));
|
||||
if (!mat)
|
||||
goto error;
|
||||
for (i = 0; i < bset->n_div; ++i) {
|
||||
isl_int_mul(res->div[i][0],
|
||||
morph->inv->row[0][0], bset->div[i][0]);
|
||||
isl_seq_cpy(res->div[i] + 1, mat->row[i], mat->n_col);
|
||||
isl_seq_scale(res->div[i] + 1 + mat->n_col,
|
||||
bset->div[i] + 1 + mat->n_col,
|
||||
morph->inv->row[0][0], bset->n_div);
|
||||
}
|
||||
isl_mat_free(mat);
|
||||
|
||||
res = add_strides(res, morph);
|
||||
|
||||
if (isl_basic_set_is_rational(bset))
|
||||
res = isl_basic_set_set_rational(res);
|
||||
|
||||
res = isl_basic_set_simplify(res);
|
||||
res = isl_basic_set_finalize(res);
|
||||
|
||||
res = isl_basic_set_intersect(res, isl_basic_set_copy(morph->ran));
|
||||
bset = isl_basic_set_move_dims(bset, isl_dim_set, 0,
|
||||
isl_dim_param, 0, n_param);
|
||||
bset = isl_basic_set_preimage_multi_aff(bset, ma);
|
||||
space = isl_basic_set_get_space(morph->ran);
|
||||
bset = isl_basic_set_reset_space(bset, space);
|
||||
bset = isl_basic_set_intersect(bset, isl_basic_set_copy(morph->ran));
|
||||
|
||||
isl_morph_free(morph);
|
||||
isl_basic_set_free(bset);
|
||||
return res;
|
||||
return bset;
|
||||
error:
|
||||
isl_mat_free(mat);
|
||||
isl_morph_free(morph);
|
||||
isl_basic_set_free(bset);
|
||||
isl_basic_set_free(res);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Apply the morphism to the set.
|
||||
* In particular, compute the preimage of "set" under the inverse mapping
|
||||
* in morph and intersect with the range of the morphism.
|
||||
* Note that the mapping in morph applies to both parameters and set dimensions,
|
||||
* so the parameters need to be treated as set dimensions during the call
|
||||
* to isl_set_preimage_multi_aff.
|
||||
*/
|
||||
__isl_give isl_set *isl_morph_set(__isl_take isl_morph *morph,
|
||||
__isl_take isl_set *set)
|
||||
{
|
||||
int i;
|
||||
isl_size n_param;
|
||||
isl_space *space;
|
||||
isl_multi_aff *ma;
|
||||
isl_basic_set *ran;
|
||||
|
||||
if (!morph || isl_set_basic_set_check_equal_space(set, morph->dom) < 0)
|
||||
goto error;
|
||||
|
||||
set = isl_set_cow(set);
|
||||
if (!set)
|
||||
n_param = isl_basic_set_dim(morph->dom, isl_dim_param);
|
||||
if (n_param < 0)
|
||||
goto error;
|
||||
|
||||
isl_space_free(set->dim);
|
||||
set->dim = isl_space_copy(morph->ran->dim);
|
||||
if (!set->dim)
|
||||
goto error;
|
||||
ma = isl_multi_aff_from_aff_mat_anonymous(isl_mat_copy(morph->inv));
|
||||
|
||||
for (i = 0; i < set->n; ++i) {
|
||||
set->p[i] = isl_morph_basic_set(isl_morph_copy(morph), set->p[i]);
|
||||
if (!set->p[i])
|
||||
goto error;
|
||||
}
|
||||
set = isl_set_move_dims(set, isl_dim_set, 0, isl_dim_param, 0, n_param);
|
||||
set = isl_set_preimage_multi_aff(set, ma);
|
||||
space = isl_basic_set_get_space(morph->ran);
|
||||
set = isl_set_reset_space(set, space);
|
||||
ran = isl_basic_set_copy(morph->ran);
|
||||
set = isl_set_intersect(set, isl_set_from_basic_set(ran));
|
||||
|
||||
isl_morph_free(morph);
|
||||
|
||||
ISL_F_CLR(set, ISL_SET_NORMALIZED);
|
||||
|
||||
return set;
|
||||
error:
|
||||
isl_set_free(set);
|
||||
|
3
polly/lib/External/isl/isl_morph.h
vendored
3
polly/lib/External/isl/isl_morph.h
vendored
@ -45,6 +45,9 @@ __isl_give isl_morph *isl_morph_copy(__isl_keep isl_morph *morph);
|
||||
__isl_give isl_morph *isl_morph_identity(__isl_keep isl_basic_set *bset);
|
||||
__isl_null isl_morph *isl_morph_free(__isl_take isl_morph *morph);
|
||||
|
||||
isl_stat isl_morph_check_applies(__isl_keep isl_morph *morph,
|
||||
__isl_keep isl_space *space);
|
||||
|
||||
__isl_give isl_space *isl_morph_get_dom_space(__isl_keep isl_morph *morph);
|
||||
__isl_give isl_space *isl_morph_get_ran_space(__isl_keep isl_morph *morph);
|
||||
__isl_give isl_multi_aff *isl_morph_get_var_multi_aff(
|
||||
|
8
polly/lib/External/isl/isl_opt_mpa_templ.c
vendored
8
polly/lib/External/isl/isl_opt_mpa_templ.c
vendored
@ -19,8 +19,8 @@
|
||||
* for a single dimension.
|
||||
*
|
||||
* If the resulting multi piecewise affine expression has
|
||||
* an explicit domain, then assign it the parameter domain of the input.
|
||||
* In other cases, the parameter domain is stored in the individual elements.
|
||||
* an explicit domain, then assign it the (parameter) domain of the input.
|
||||
* In other cases, the (parameter) domain is stored in the individual elements.
|
||||
*/
|
||||
static __isl_give isl_multi_pw_aff *FN(BASE,opt_mpa)(__isl_take TYPE *obj,
|
||||
__isl_give isl_pw_aff *(*opt)(__isl_take TYPE *obj, int pos))
|
||||
@ -42,8 +42,8 @@ static __isl_give isl_multi_pw_aff *FN(BASE,opt_mpa)(__isl_take TYPE *obj,
|
||||
if (isl_multi_pw_aff_has_explicit_domain(mpa)) {
|
||||
isl_set *dom;
|
||||
|
||||
dom = FN(TYPE,params)(FN(TYPE,copy)(obj));
|
||||
mpa = isl_multi_pw_aff_intersect_params(mpa, dom);
|
||||
dom = FN(TYPE,domain)(FN(TYPE,copy)(obj));
|
||||
mpa = isl_multi_pw_aff_intersect_domain(mpa, dom);
|
||||
}
|
||||
FN(TYPE,free)(obj);
|
||||
|
||||
|
28
polly/lib/External/isl/isl_output.c
vendored
28
polly/lib/External/isl/isl_output.c
vendored
@ -1988,16 +1988,25 @@ static __isl_give isl_printer *qpolynomial_fold_print(
|
||||
__isl_keep isl_qpolynomial_fold *fold, __isl_take isl_printer *p)
|
||||
{
|
||||
int i;
|
||||
isl_qpolynomial_list *list;
|
||||
isl_size n;
|
||||
|
||||
list = isl_qpolynomial_fold_peek_list(fold);
|
||||
n = isl_qpolynomial_list_size(list);
|
||||
if (n < 0)
|
||||
return isl_printer_free(p);
|
||||
if (fold->type == isl_fold_min)
|
||||
p = isl_printer_print_str(p, "min");
|
||||
else if (fold->type == isl_fold_max)
|
||||
p = isl_printer_print_str(p, "max");
|
||||
p = isl_printer_print_str(p, "(");
|
||||
for (i = 0; i < fold->n; ++i) {
|
||||
for (i = 0; i < n; ++i) {
|
||||
isl_qpolynomial *qp;
|
||||
|
||||
if (i)
|
||||
p = isl_printer_print_str(p, ", ");
|
||||
p = print_qpolynomial(p, fold->qp[i]);
|
||||
qp = isl_qpolynomial_list_peek(list, i);
|
||||
p = print_qpolynomial(p, qp);
|
||||
}
|
||||
p = isl_printer_print_str(p, ")");
|
||||
return p;
|
||||
@ -2337,17 +2346,26 @@ static __isl_give isl_printer *print_qpolynomial_fold_c(
|
||||
__isl_keep isl_qpolynomial_fold *fold)
|
||||
{
|
||||
int i;
|
||||
isl_qpolynomial_list *list;
|
||||
isl_size n;
|
||||
|
||||
for (i = 0; i < fold->n - 1; ++i)
|
||||
list = isl_qpolynomial_fold_peek_list(fold);
|
||||
n = isl_qpolynomial_list_size(list);
|
||||
if (n < 0)
|
||||
return isl_printer_free(p);
|
||||
for (i = 0; i < n - 1; ++i)
|
||||
if (fold->type == isl_fold_min)
|
||||
p = isl_printer_print_str(p, "min(");
|
||||
else if (fold->type == isl_fold_max)
|
||||
p = isl_printer_print_str(p, "max(");
|
||||
|
||||
for (i = 0; i < fold->n; ++i) {
|
||||
for (i = 0; i < n; ++i) {
|
||||
isl_qpolynomial *qp;
|
||||
|
||||
if (i)
|
||||
p = isl_printer_print_str(p, ", ");
|
||||
p = print_qpolynomial_c(p, space, fold->qp[i]);
|
||||
qp = isl_qpolynomial_list_peek(list, i);
|
||||
p = print_qpolynomial_c(p, space, qp);
|
||||
if (i)
|
||||
p = isl_printer_print_str(p, ")");
|
||||
}
|
||||
|
14
polly/lib/External/isl/isl_polynomial.c
vendored
14
polly/lib/External/isl/isl_polynomial.c
vendored
@ -28,6 +28,11 @@
|
||||
#include <isl_val_private.h>
|
||||
#include <isl_config.h>
|
||||
|
||||
#undef EL_BASE
|
||||
#define EL_BASE qpolynomial
|
||||
|
||||
#include <isl_list_templ.c>
|
||||
|
||||
#undef EL_BASE
|
||||
#define EL_BASE pw_qpolynomial
|
||||
|
||||
@ -4384,16 +4389,17 @@ __isl_give isl_qpolynomial *isl_qpolynomial_morph_domain(
|
||||
int i;
|
||||
int n_sub;
|
||||
isl_ctx *ctx;
|
||||
isl_space *space;
|
||||
isl_poly **subs;
|
||||
isl_mat *mat, *diag;
|
||||
|
||||
qp = isl_qpolynomial_cow(qp);
|
||||
if (!qp || !morph)
|
||||
|
||||
space = isl_qpolynomial_peek_domain_space(qp);
|
||||
if (isl_morph_check_applies(morph, space) < 0)
|
||||
goto error;
|
||||
|
||||
ctx = qp->dim->ctx;
|
||||
isl_assert(ctx, isl_space_is_equal(qp->dim, morph->dom->dim), goto error);
|
||||
|
||||
ctx = isl_qpolynomial_get_ctx(qp);
|
||||
n_sub = morph->inv->n_row - 1;
|
||||
if (morph->inv->n_row != morph->inv->n_col)
|
||||
n_sub += qp->div->n_row;
|
||||
|
16
polly/lib/External/isl/isl_polynomial_private.h
vendored
16
polly/lib/External/isl/isl_polynomial_private.h
vendored
@ -5,6 +5,7 @@
|
||||
#include <isl_morph.h>
|
||||
#include <isl/polynomial.h>
|
||||
#include <isl_reordering.h>
|
||||
#include "isl_list_private.h"
|
||||
|
||||
struct isl_poly {
|
||||
int ref;
|
||||
@ -40,6 +41,11 @@ struct isl_qpolynomial {
|
||||
isl_poly *poly;
|
||||
};
|
||||
|
||||
#undef EL
|
||||
#define EL isl_qpolynomial
|
||||
|
||||
#include <isl_list_templ.h>
|
||||
|
||||
struct isl_term {
|
||||
int ref;
|
||||
|
||||
@ -86,10 +92,7 @@ struct isl_qpolynomial_fold {
|
||||
enum isl_fold type;
|
||||
isl_space *dim;
|
||||
|
||||
int n;
|
||||
|
||||
size_t size;
|
||||
struct isl_qpolynomial *qp[1];
|
||||
isl_qpolynomial_list *list;
|
||||
};
|
||||
|
||||
struct isl_pw_qpolynomial_fold_piece {
|
||||
@ -202,6 +205,9 @@ __isl_give isl_qpolynomial_fold *isl_qpolynomial_fold_cow(
|
||||
__isl_give isl_qpolynomial_fold *isl_qpolynomial_fold_dup(
|
||||
__isl_keep isl_qpolynomial_fold *fold);
|
||||
|
||||
__isl_keep isl_qpolynomial_list *isl_qpolynomial_fold_peek_list(
|
||||
__isl_keep isl_qpolynomial_fold *fold);
|
||||
|
||||
__isl_give isl_pw_qpolynomial_fold *isl_pw_qpolynomial_fold_cow(
|
||||
__isl_take isl_pw_qpolynomial_fold *pwf);
|
||||
|
||||
@ -289,3 +295,5 @@ __isl_give isl_union_pw_qpolynomial *isl_union_pw_qpolynomial_mul_isl_int(
|
||||
__isl_give isl_union_pw_qpolynomial_fold *
|
||||
isl_union_pw_qpolynomial_fold_mul_isl_int(
|
||||
__isl_take isl_union_pw_qpolynomial_fold *upwf, isl_int v);
|
||||
|
||||
ISL_DECLARE_LIST_FN_PRIVATE(qpolynomial)
|
||||
|
21
polly/lib/External/isl/isl_pw_templ.c
vendored
21
polly/lib/External/isl/isl_pw_templ.c
vendored
@ -1434,14 +1434,29 @@ static __isl_keep isl_set *FN(PW,peek_domain_at)(__isl_keep PW *pw, int pos)
|
||||
return pw->p[pos].set;
|
||||
}
|
||||
|
||||
/* Return a copy of the cell at position "pos" in "pw".
|
||||
*/
|
||||
__isl_give isl_set *FN(PW,get_domain_at)(__isl_keep PW *pw, int pos)
|
||||
{
|
||||
return isl_set_copy(FN(PW,peek_domain_at)(pw, pos));
|
||||
}
|
||||
|
||||
/* Return the base expression associated to
|
||||
* the cell at position "pos" in "pw".
|
||||
*/
|
||||
static __isl_keep EL *FN(PW,peek_base_at)(__isl_keep PW *pw, int pos)
|
||||
{
|
||||
if (FN(PW,check_pos)(pw, pos) < 0)
|
||||
return NULL;
|
||||
return pw->p[pos].FIELD;
|
||||
}
|
||||
|
||||
/* Return a copy of the base expression associated to
|
||||
* the cell at position "pos" in "pw".
|
||||
*/
|
||||
__isl_give EL *FN(PW,get_base_at)(__isl_keep PW *pw, int pos)
|
||||
{
|
||||
if (FN(PW,check_pos)(pw, pos) < 0)
|
||||
return NULL;
|
||||
return FN(EL,copy)(pw->p[pos].FIELD);
|
||||
return FN(EL,copy)(FN(PW,peek_base_at)(pw, pos));
|
||||
}
|
||||
|
||||
/* Return the base expression associated to
|
||||
|
258
polly/lib/External/isl/isl_pw_union_opt.c
vendored
258
polly/lib/External/isl/isl_pw_union_opt.c
vendored
@ -1,6 +1,7 @@
|
||||
/*
|
||||
* Copyright 2011 INRIA Saclay
|
||||
* Copyright 2012 Ecole Normale Superieure
|
||||
* Copyright 2020 Cerebras Systems
|
||||
*
|
||||
* Use of this software is governed by the MIT license
|
||||
*
|
||||
@ -8,6 +9,7 @@
|
||||
* Parc Club Orsay Universite, ZAC des vignes, 4 rue Jacques Monod,
|
||||
* 91893 Orsay, France
|
||||
* and Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
|
||||
* and Cerebras Systems, 175 S San Antonio Rd, Los Altos, CA, USA
|
||||
*/
|
||||
|
||||
#include <isl_pw_macro.h>
|
||||
@ -69,29 +71,173 @@ static __isl_give isl_set *FN(PW,worse_or_out)(__isl_take isl_set *set,
|
||||
return isl_set_union(set_worse, set_out);
|
||||
}
|
||||
|
||||
/* Given two piecewise expressions "pw1" and "pw2", replace their domains
|
||||
* by the sets in "list1" and "list2" and combine the results into
|
||||
/* Internal data structure used by isl_pw_*_union_opt_cmp
|
||||
* that keeps track of a piecewise expression with updated cells.
|
||||
* "pw" holds the original piecewise expression.
|
||||
* "list" holds the updated cells.
|
||||
*/
|
||||
S(PW,union_opt_cmp_data) {
|
||||
PW *pw;
|
||||
isl_set_list *cell;
|
||||
};
|
||||
|
||||
/* Free all memory allocated for "data".
|
||||
*/
|
||||
static void FN(PW,union_opt_cmp_data_clear)(S(PW,union_opt_cmp_data) *data)
|
||||
{
|
||||
isl_set_list_free(data->cell);
|
||||
FN(PW,free)(data->pw);
|
||||
}
|
||||
|
||||
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
|
||||
* a set "better" where the piece from data_j->pw is better
|
||||
* than the piece from data_i->pw,
|
||||
* (further) update the specified cells such that only the better elements
|
||||
* remain on the (non-empty) intersection.
|
||||
*
|
||||
* Let C be the set "better".
|
||||
* Let A be the cell data_i->cell[i] and B the cell data_j->cell[j].
|
||||
*
|
||||
* The elements in C need to be removed from A, except for those parts
|
||||
* that lie outside of B. That is,
|
||||
*
|
||||
* A <- (A \setminus C) \cup ((A \cap C) \setminus B')
|
||||
*
|
||||
* Conversely, the elements in B need to be restricted to C, except
|
||||
* for those parts that lie outside of A. That is
|
||||
*
|
||||
* B <- (B \cap C) \cup ((B \setminus C) \setminus A')
|
||||
*
|
||||
* Since all pairs of pieces are considered, the domains are updated
|
||||
* several times. A and B refer to these updated domains
|
||||
* (kept track of in data_i->cell[i] and data_j->cell[j]), while A' and B' refer
|
||||
* to the original domains of the pieces. It is safe to use these
|
||||
* original domains because the difference between, say, A' and A is
|
||||
* the domains of pw2-pieces that have been removed before and
|
||||
* those domains are disjoint from B. A' is used instead of A
|
||||
* because the continued updating of A may result in this domain
|
||||
* getting broken up into more disjuncts.
|
||||
*/
|
||||
static isl_stat FN(PW,union_opt_cmp_split)(S(PW,union_opt_cmp_data) *data_i,
|
||||
int i, S(PW,union_opt_cmp_data) *data_j, int j,
|
||||
__isl_take isl_set *better)
|
||||
{
|
||||
isl_set *set_i, *set_j;
|
||||
|
||||
set_i = isl_set_list_get_set(data_i->cell, i);
|
||||
set_j = FN(PW,get_domain_at)(data_j->pw, j);
|
||||
set_i = FN(PW,worse_or_out)(set_i, isl_set_copy(better), set_j);
|
||||
data_i->cell = isl_set_list_set_set(data_i->cell, i, set_i);
|
||||
set_i = FN(PW,get_domain_at)(data_i->pw, i);
|
||||
set_j = isl_set_list_get_set(data_j->cell, j);
|
||||
set_j = FN(PW,better_or_out)(set_j, better, set_i);
|
||||
data_j->cell = isl_set_list_set_set(data_j->cell, j, set_j);
|
||||
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
|
||||
* a function "cmp" that returns the set of elements where
|
||||
* "el1" is "better" than "el2",
|
||||
* (further) update the specified cells such that only the "better" elements
|
||||
* remain on the (non-empty) intersection.
|
||||
*/
|
||||
static isl_stat FN(PW,union_opt_cmp_pair)(S(PW,union_opt_cmp_data) *data_i,
|
||||
int i, S(PW,union_opt_cmp_data) *data_j, int j,
|
||||
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
|
||||
{
|
||||
isl_set *better;
|
||||
EL *el_i, *el_j;
|
||||
|
||||
el_i = FN(PW,peek_base_at)(data_i->pw, i);
|
||||
el_j = FN(PW,peek_base_at)(data_j->pw, j);
|
||||
better = FN(PW,better)(el_j, el_i, cmp);
|
||||
return FN(PW,union_opt_cmp_split)(data_i, i, data_j, j, better);
|
||||
}
|
||||
|
||||
/* Given (potentially) updated cells "i" of data_i->pw and "j" of data_j->pw and
|
||||
* a function "cmp" that returns the set of elements where
|
||||
* "el1" is "better" than "el2",
|
||||
* (further) update the specified cells such that only the "better" elements
|
||||
* remain on the (non-empty) intersection.
|
||||
*
|
||||
* The base computation is performed by isl_pw_*_union_opt_cmp_pair,
|
||||
* which splits the cells according to the set of elements
|
||||
* where the piece from data_j->pw is better than the piece from data_i->pw.
|
||||
*
|
||||
* In some cases, there may be a subset of the intersection
|
||||
* where both pieces have the same value and can therefore
|
||||
* both be considered to be "better" than the other.
|
||||
* This can result in unnecessary splitting on this subset.
|
||||
* Avoid some of these cases by checking whether
|
||||
* data_i->pw is always better than data_j->pw on the intersection.
|
||||
* In particular, do this for the special case where this intersection
|
||||
* is equal to the cell "j" and data_i->pw is better on its entire cell.
|
||||
*
|
||||
* Similarly, if data_i->pw is never better than data_j->pw,
|
||||
* then no splitting will occur and there is no need to check
|
||||
* where data_j->pw is better than data_i->pw.
|
||||
*/
|
||||
static isl_stat FN(PW,union_opt_cmp_two)(S(PW,union_opt_cmp_data) *data_i,
|
||||
int i, S(PW,union_opt_cmp_data) *data_j, int j,
|
||||
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
|
||||
{
|
||||
isl_bool is_subset, is_empty;
|
||||
isl_set *better, *set_i, *set_j;
|
||||
EL *el_i, *el_j;
|
||||
|
||||
set_i = FN(PW,peek_domain_at)(data_i->pw, i);
|
||||
set_j = FN(PW,peek_domain_at)(data_j->pw, j);
|
||||
is_subset = isl_set_is_subset(set_j, set_i);
|
||||
if (is_subset < 0)
|
||||
return isl_stat_error;
|
||||
if (!is_subset)
|
||||
return FN(PW,union_opt_cmp_pair)(data_i, i, data_j, j, cmp);
|
||||
|
||||
el_i = FN(PW,peek_base_at)(data_i->pw, i);
|
||||
el_j = FN(PW,peek_base_at)(data_j->pw, j);
|
||||
better = FN(PW,better)(el_i, el_j, cmp);
|
||||
is_empty = isl_set_is_empty(better);
|
||||
if (is_empty >= 0 && is_empty)
|
||||
return FN(PW,union_opt_cmp_split)(data_j, j, data_i, i, better);
|
||||
is_subset = isl_set_is_subset(set_i, better);
|
||||
if (is_subset >= 0 && is_subset)
|
||||
return FN(PW,union_opt_cmp_split)(data_j, j, data_i, i, better);
|
||||
isl_set_free(better);
|
||||
if (is_empty < 0 || is_subset < 0)
|
||||
return isl_stat_error;
|
||||
|
||||
return FN(PW,union_opt_cmp_pair)(data_i, i, data_j, j, cmp);
|
||||
}
|
||||
|
||||
/* Given two piecewise expressions data1->pw and data2->pw, replace
|
||||
* their domains
|
||||
* by the sets in data1->cell and data2->cell and combine the results into
|
||||
* a single piecewise expression.
|
||||
* The pieces of "pw1" and "pw2" are assumed to have been sorted
|
||||
* The pieces of data1->pw and data2->pw are assumed to have been sorted
|
||||
* according to the function value expressions.
|
||||
* The pieces of the result are also sorted in this way.
|
||||
*
|
||||
* Run through the pieces of "pw1" and "pw2" in order until they
|
||||
* have both been exhausted, picking the piece from "pw1" or "pw2"
|
||||
* Run through the pieces of data1->pw and data2->pw in order until they
|
||||
* have both been exhausted, picking the piece from data1->pw or data2->pw
|
||||
* depending on which should come first, together with the corresponding
|
||||
* domain from "list1" or "list2". In cases where the next pieces
|
||||
* in both "pw1" and "pw2" have the same function value expression,
|
||||
* domain from data1->cell or data2->cell. In cases where the next pieces
|
||||
* in both data1->pw and data2->pw have the same function value expression,
|
||||
* construct only a single piece in the result with as domain
|
||||
* the union of the domains in "list1" and "list2".
|
||||
* the union of the domains in data1->cell and data2->cell.
|
||||
*/
|
||||
static __isl_give PW *FN(PW,merge)(__isl_take PW *pw1, __isl_take PW *pw2,
|
||||
__isl_take isl_set_list *list1, __isl_take isl_set_list *list2)
|
||||
static __isl_give PW *FN(PW,merge)(S(PW,union_opt_cmp_data) *data1,
|
||||
S(PW,union_opt_cmp_data) *data2)
|
||||
{
|
||||
int i, j;
|
||||
PW *res;
|
||||
PW *pw1 = data1->pw;
|
||||
PW *pw2 = data2->pw;
|
||||
isl_set_list *list1 = data1->cell;
|
||||
isl_set_list *list2 = data2->cell;
|
||||
|
||||
if (!pw1 || !pw2)
|
||||
goto error;
|
||||
return NULL;
|
||||
|
||||
res = FN(PW,alloc_size)(isl_space_copy(pw1->dim), pw1->n + pw2->n);
|
||||
|
||||
@ -125,17 +271,7 @@ static __isl_give PW *FN(PW,merge)(__isl_take PW *pw1, __isl_take PW *pw2,
|
||||
res = FN(PW,add_piece)(res, set, el);
|
||||
}
|
||||
|
||||
isl_set_list_free(list1);
|
||||
isl_set_list_free(list2);
|
||||
FN(PW,free)(pw1);
|
||||
FN(PW,free)(pw2);
|
||||
return res;
|
||||
error:
|
||||
isl_set_list_free(list1);
|
||||
isl_set_list_free(list2);
|
||||
FN(PW,free)(pw1);
|
||||
FN(PW,free)(pw2);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Given a function "cmp" that returns the set of elements where
|
||||
@ -148,32 +284,9 @@ error:
|
||||
* Run through all pairs of pieces in "pw1" and "pw2".
|
||||
* If the domains of these pieces intersect, then the intersection
|
||||
* needs to be distributed over the two pieces based on "cmp".
|
||||
* Let C be the set where the piece from "pw2" is better (according to "cmp")
|
||||
* than the piece from "pw1". Let A be the domain of the piece from "pw1" and
|
||||
* B the domain of the piece from "pw2".
|
||||
*
|
||||
* The elements in C need to be removed from A, except for those parts
|
||||
* that lie outside of B. That is,
|
||||
*
|
||||
* A <- (A \setminus C) \cup ((A \cap C) \setminus B')
|
||||
*
|
||||
* Conversely, the elements in B need to be restricted to C, except
|
||||
* for those parts that lie outside of A. That is
|
||||
*
|
||||
* B <- (B \cap C) \cup ((B \setminus C) \setminus A')
|
||||
*
|
||||
* Since all pairs of pieces are considered, the domains are updated
|
||||
* several times. A and B refer to these updated domains
|
||||
* (kept track of in "list1" and "list2"), while A' and B' refer
|
||||
* to the original domains of the pieces. It is safe to use these
|
||||
* original domains because the difference between, say, A' and A is
|
||||
* the domains of pw2-pieces that have been removed before and
|
||||
* those domains are disjoint from B. A' is used instead of A
|
||||
* because the continued updating of A may result in this domain
|
||||
* getting broken up into more disjuncts.
|
||||
*
|
||||
* After the updated domains have been computed, the result is constructed
|
||||
* from "pw1", "pw2", "list1" and "list2". If there are any pieces
|
||||
* from "pw1", "pw2", data[0].cell and data[1].cell. If there are any pieces
|
||||
* in "pw1" and "pw2" with the same function value expression, then
|
||||
* they are combined into a single piece in the result.
|
||||
* In order to be able to do this efficiently, the pieces of "pw1" and
|
||||
@ -183,11 +296,11 @@ static __isl_give PW *FN(PW,union_opt_cmp)(
|
||||
__isl_take PW *pw1, __isl_take PW *pw2,
|
||||
__isl_give isl_set *(*cmp)(__isl_take EL *el1, __isl_take EL *el2))
|
||||
{
|
||||
S(PW,union_opt_cmp_data) data[2] = { { pw1, NULL }, { pw2, NULL } };
|
||||
int i, j;
|
||||
isl_size n1, n2;
|
||||
PW *res = NULL;
|
||||
isl_ctx *ctx;
|
||||
isl_set *set = NULL;
|
||||
isl_set_list *list1 = NULL, *list2 = NULL;
|
||||
|
||||
if (!pw1 || !pw2)
|
||||
goto error;
|
||||
@ -207,47 +320,40 @@ static __isl_give PW *FN(PW,union_opt_cmp)(
|
||||
return pw1;
|
||||
}
|
||||
|
||||
pw1 = FN(PW,sort)(pw1);
|
||||
pw2 = FN(PW,sort)(pw2);
|
||||
if (!pw1 || !pw2)
|
||||
for (i = 0; i < 2; ++i) {
|
||||
data[i].pw = FN(PW,sort)(data[i].pw);
|
||||
data[i].cell = FN(PW,extract_domains)(data[i].pw);
|
||||
}
|
||||
|
||||
n1 = FN(PW,n_piece)(data[0].pw);
|
||||
n2 = FN(PW,n_piece)(data[1].pw);
|
||||
if (n1 < 0 || n2 < 0)
|
||||
goto error;
|
||||
|
||||
list1 = FN(PW,extract_domains)(pw1);
|
||||
list2 = FN(PW,extract_domains)(pw2);
|
||||
|
||||
for (i = 0; i < pw1->n; ++i) {
|
||||
for (j = 0; j < pw2->n; ++j) {
|
||||
for (i = 0; i < n1; ++i) {
|
||||
for (j = 0; j < n2; ++j) {
|
||||
isl_bool disjoint;
|
||||
isl_set *better, *set_i, *set_j;
|
||||
isl_set *set_i, *set_j;
|
||||
|
||||
disjoint = isl_set_is_disjoint(pw1->p[i].set,
|
||||
pw2->p[j].set);
|
||||
set_i = FN(PW,peek_domain_at)(data[0].pw, i);
|
||||
set_j = FN(PW,peek_domain_at)(data[1].pw, j);
|
||||
disjoint = isl_set_is_disjoint(set_i, set_j);
|
||||
if (disjoint < 0)
|
||||
goto error;
|
||||
if (disjoint)
|
||||
continue;
|
||||
better = FN(PW,better)(pw2->p[j].FIELD,
|
||||
pw1->p[i].FIELD, cmp);
|
||||
set_i = isl_set_list_get_set(list1, i);
|
||||
set_j = isl_set_copy(pw2->p[j].set);
|
||||
set_i = FN(PW,worse_or_out)(set_i,
|
||||
isl_set_copy(better), set_j);
|
||||
list1 = isl_set_list_set_set(list1, i, set_i);
|
||||
set_i = isl_set_copy(pw1->p[i].set);
|
||||
set_j = isl_set_list_get_set(list2, j);
|
||||
set_j = FN(PW,better_or_out)(set_j, better, set_i);
|
||||
list2 = isl_set_list_set_set(list2, j, set_j);
|
||||
if (FN(PW,union_opt_cmp_two)(&data[0], i,
|
||||
&data[1], j, cmp) < 0)
|
||||
goto error;
|
||||
}
|
||||
}
|
||||
|
||||
res = FN(PW,merge)(pw1, pw2, list1, list2);
|
||||
res = FN(PW,merge)(&data[0], &data[1]);
|
||||
for (i = 0; i < 2; ++i)
|
||||
FN(PW,union_opt_cmp_data_clear)(&data[i]);
|
||||
|
||||
return res;
|
||||
error:
|
||||
isl_set_list_free(list1);
|
||||
isl_set_list_free(list2);
|
||||
FN(PW,free)(pw1);
|
||||
FN(PW,free)(pw2);
|
||||
isl_set_free(set);
|
||||
for (i = 0; i < 2; ++i)
|
||||
FN(PW,union_opt_cmp_data_clear)(&data[i]);
|
||||
return FN(PW,free)(res);
|
||||
}
|
||||
|
9
polly/lib/External/isl/isl_seq.c
vendored
9
polly/lib/External/isl/isl_seq.c
vendored
@ -125,9 +125,12 @@ void isl_seq_combine(isl_int *dst, isl_int m1, isl_int *src1,
|
||||
isl_int_clear(tmp);
|
||||
}
|
||||
|
||||
/*
|
||||
* Let d = dst[pos] and s = src[pos]
|
||||
* dst is replaced by |s| dst - sgn(s)d src
|
||||
/* Eliminate element "pos" from "dst" using "src".
|
||||
* In particular, let d = dst[pos] and s = src[pos], then
|
||||
* dst is replaced by (|s| dst - sgn(s)d src)/gcd(s,d),
|
||||
* such that dst[pos] is zero after the elimination.
|
||||
* If "m" is not NULL, then *m is multiplied by |s|/gcd(s,d).
|
||||
* That is, it is multiplied by the same factor as "dst".
|
||||
*/
|
||||
void isl_seq_elim(isl_int *dst, isl_int *src, unsigned pos, unsigned len,
|
||||
isl_int *m)
|
||||
|
110
polly/lib/External/isl/isl_space.c
vendored
110
polly/lib/External/isl/isl_space.c
vendored
@ -121,6 +121,22 @@ static isl_stat isl_space_check_is_map(__isl_keep isl_space *space)
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Check that "space" is the space of a map
|
||||
* where the domain is a wrapped map space.
|
||||
*/
|
||||
isl_stat isl_space_check_domain_is_wrapping(__isl_keep isl_space *space)
|
||||
{
|
||||
isl_bool wrapping;
|
||||
|
||||
wrapping = isl_space_domain_is_wrapping(space);
|
||||
if (wrapping < 0)
|
||||
return isl_stat_error;
|
||||
if (!wrapping)
|
||||
isl_die(isl_space_get_ctx(space), isl_error_invalid,
|
||||
"domain not a product", return isl_stat_error);
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Check that "space" is the space of a map
|
||||
* where the range is a wrapped map space.
|
||||
*/
|
||||
@ -929,6 +945,20 @@ isl_bool isl_space_has_equal_tuples(__isl_keep isl_space *space1,
|
||||
space2, isl_dim_out);
|
||||
}
|
||||
|
||||
/* Check that a match involving "space" was successful.
|
||||
* That is, check that "match" is equal to isl_bool_true.
|
||||
*/
|
||||
static isl_stat check_match(__isl_keep isl_space *space, isl_bool match)
|
||||
{
|
||||
if (match < 0)
|
||||
return isl_stat_error;
|
||||
if (!match)
|
||||
isl_die(isl_space_get_ctx(space), isl_error_invalid,
|
||||
"incompatible spaces", return isl_stat_error);
|
||||
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Check that the two spaces are the same,
|
||||
* apart from positions and names of parameters.
|
||||
*/
|
||||
@ -938,13 +968,7 @@ isl_stat isl_space_check_equal_tuples(__isl_keep isl_space *space1,
|
||||
isl_bool is_equal;
|
||||
|
||||
is_equal = isl_space_has_equal_tuples(space1, space2);
|
||||
if (is_equal < 0)
|
||||
return isl_stat_error;
|
||||
if (!is_equal)
|
||||
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
|
||||
"incompatible spaces", return isl_stat_error);
|
||||
|
||||
return isl_stat_ok;
|
||||
return check_match(space1, is_equal);
|
||||
}
|
||||
|
||||
/* Check if the tuple of type "type1" of "space1" is the same as
|
||||
@ -989,6 +1013,41 @@ isl_bool isl_space_tuple_is_equal(__isl_keep isl_space *space1,
|
||||
return isl_bool_true;
|
||||
}
|
||||
|
||||
/* Is the tuple "inner" within the wrapped relation inside tuple "outer"
|
||||
* of "space1" equal to tuple "type2" of "space2"?
|
||||
*/
|
||||
isl_bool isl_space_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
|
||||
enum isl_dim_type outer, enum isl_dim_type inner,
|
||||
__isl_keep isl_space *space2, enum isl_dim_type type2)
|
||||
{
|
||||
int pos;
|
||||
isl_space *nested;
|
||||
|
||||
if (!space1)
|
||||
return isl_bool_error;
|
||||
if (outer != isl_dim_in && outer != isl_dim_out)
|
||||
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
|
||||
"only input, output and set tuples "
|
||||
"can have nested relations", return isl_bool_error);
|
||||
pos = outer - isl_dim_in;
|
||||
nested = isl_space_peek_nested(space1, pos);
|
||||
return isl_space_tuple_is_equal(nested, inner, space2, type2);
|
||||
}
|
||||
|
||||
/* Check that the tuple "inner" within the wrapped relation inside tuple "outer"
|
||||
* of "space1" is equal to tuple "type2" of "space2".
|
||||
*/
|
||||
isl_stat isl_space_check_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
|
||||
enum isl_dim_type outer, enum isl_dim_type inner,
|
||||
__isl_keep isl_space *space2, enum isl_dim_type type2)
|
||||
{
|
||||
isl_bool is_equal;
|
||||
|
||||
is_equal = isl_space_wrapped_tuple_is_equal(space1, outer, inner,
|
||||
space2, type2);
|
||||
return check_match(space1, is_equal);
|
||||
}
|
||||
|
||||
static isl_bool match(__isl_keep isl_space *space1, enum isl_dim_type type1,
|
||||
__isl_keep isl_space *space2, enum isl_dim_type type2)
|
||||
{
|
||||
@ -1525,11 +1584,8 @@ __isl_give isl_space *isl_space_domain_factor_domain(
|
||||
isl_space *nested;
|
||||
isl_space *domain;
|
||||
|
||||
if (!space)
|
||||
return NULL;
|
||||
if (!isl_space_domain_is_wrapping(space))
|
||||
isl_die(isl_space_get_ctx(space), isl_error_invalid,
|
||||
"domain not a product", return isl_space_free(space));
|
||||
if (isl_space_check_domain_is_wrapping(space) < 0)
|
||||
return isl_space_free(space);
|
||||
|
||||
nested = space->nested[0];
|
||||
domain = isl_space_copy(space);
|
||||
@ -1564,11 +1620,8 @@ __isl_give isl_space *isl_space_domain_factor_range(
|
||||
isl_space *nested;
|
||||
isl_space *range;
|
||||
|
||||
if (!space)
|
||||
return NULL;
|
||||
if (!isl_space_domain_is_wrapping(space))
|
||||
isl_die(isl_space_get_ctx(space), isl_error_invalid,
|
||||
"domain not a product", return isl_space_free(space));
|
||||
if (isl_space_check_domain_is_wrapping(space) < 0)
|
||||
return isl_space_free(space);
|
||||
|
||||
nested = space->nested[0];
|
||||
range = isl_space_copy(space);
|
||||
@ -2424,13 +2477,7 @@ isl_stat isl_space_check_domain_tuples(__isl_keep isl_space *space1,
|
||||
isl_bool is_equal;
|
||||
|
||||
is_equal = isl_space_has_domain_tuples(space1, space2);
|
||||
if (is_equal < 0)
|
||||
return isl_stat_error;
|
||||
if (!is_equal)
|
||||
isl_die(isl_space_get_ctx(space1), isl_error_invalid,
|
||||
"incompatible spaces", return isl_stat_error);
|
||||
|
||||
return isl_stat_ok;
|
||||
return check_match(space1, is_equal);
|
||||
}
|
||||
|
||||
/* Check that the tuples of "space1" correspond to those
|
||||
@ -2581,6 +2628,8 @@ static uint32_t isl_hash_tuples_domain(uint32_t hash,
|
||||
|
||||
/* Return a hash value that digests the tuples of "space",
|
||||
* i.e., that ignores the parameters.
|
||||
* Changes in this function should be reflected
|
||||
* in isl_space_get_tuple_domain_hash.
|
||||
*/
|
||||
uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space)
|
||||
{
|
||||
@ -2595,7 +2644,9 @@ uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space)
|
||||
return hash;
|
||||
}
|
||||
|
||||
uint32_t isl_space_get_hash(__isl_keep isl_space *space)
|
||||
/* Return the hash value of "space".
|
||||
*/
|
||||
uint32_t isl_space_get_full_hash(__isl_keep isl_space *space)
|
||||
{
|
||||
uint32_t hash;
|
||||
|
||||
@ -2609,11 +2660,11 @@ uint32_t isl_space_get_hash(__isl_keep isl_space *space)
|
||||
return hash;
|
||||
}
|
||||
|
||||
/* Return the hash value of the domain of "space".
|
||||
* That is, isl_space_get_domain_hash(space) is equal to
|
||||
* isl_space_get_hash(isl_space_domain(space)).
|
||||
/* Return the hash value of the domain tuple of "space".
|
||||
* That is, isl_space_get_tuple_domain_hash(space) is equal to
|
||||
* isl_space_get_tuple_hash(isl_space_domain(space)).
|
||||
*/
|
||||
uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space)
|
||||
uint32_t isl_space_get_tuple_domain_hash(__isl_keep isl_space *space)
|
||||
{
|
||||
uint32_t hash;
|
||||
|
||||
@ -2621,7 +2672,6 @@ uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space)
|
||||
return 0;
|
||||
|
||||
hash = isl_hash_init();
|
||||
hash = isl_hash_params(hash, space);
|
||||
hash = isl_hash_tuples_domain(hash, space);
|
||||
|
||||
return hash;
|
||||
|
11
polly/lib/External/isl/isl_space_private.h
vendored
11
polly/lib/External/isl/isl_space_private.h
vendored
@ -28,8 +28,8 @@ __isl_give isl_space *isl_space_underlying(__isl_take isl_space *space,
|
||||
unsigned n_div);
|
||||
|
||||
uint32_t isl_space_get_tuple_hash(__isl_keep isl_space *space);
|
||||
uint32_t isl_space_get_hash(__isl_keep isl_space *space);
|
||||
uint32_t isl_space_get_domain_hash(__isl_keep isl_space *space);
|
||||
uint32_t isl_space_get_tuple_domain_hash(__isl_keep isl_space *space);
|
||||
uint32_t isl_space_get_full_hash(__isl_keep isl_space *space);
|
||||
|
||||
isl_bool isl_space_has_domain_tuples(__isl_keep isl_space *space1,
|
||||
__isl_keep isl_space *space2);
|
||||
@ -43,6 +43,12 @@ isl_bool isl_space_is_range_internal(__isl_keep isl_space *space1,
|
||||
__isl_keep isl_space *space2);
|
||||
isl_stat isl_space_check_domain_wrapped_domain_tuples(
|
||||
__isl_keep isl_space *space1, __isl_keep isl_space *space2);
|
||||
isl_bool isl_space_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
|
||||
enum isl_dim_type outer, enum isl_dim_type inner,
|
||||
__isl_keep isl_space *space2, enum isl_dim_type type2);
|
||||
isl_stat isl_space_check_wrapped_tuple_is_equal(__isl_keep isl_space *space1,
|
||||
enum isl_dim_type outer, enum isl_dim_type inner,
|
||||
__isl_keep isl_space *space2, enum isl_dim_type type2);
|
||||
|
||||
isl_size isl_space_wrapped_dim(__isl_keep isl_space *space,
|
||||
enum isl_dim_type outer, enum isl_dim_type inner);
|
||||
@ -66,6 +72,7 @@ __isl_give isl_space *isl_space_reset(__isl_take isl_space *space,
|
||||
enum isl_dim_type type);
|
||||
__isl_give isl_space *isl_space_flatten(__isl_take isl_space *space);
|
||||
|
||||
isl_stat isl_space_check_domain_is_wrapping(__isl_keep isl_space *space);
|
||||
isl_stat isl_space_check_range_is_wrapping(__isl_keep isl_space *space);
|
||||
|
||||
__isl_give isl_space *isl_space_replace_params(__isl_take isl_space *dst,
|
||||
|
14
polly/lib/External/isl/isl_tab.c
vendored
14
polly/lib/External/isl/isl_tab.c
vendored
@ -1787,17 +1787,6 @@ int isl_tab_insert_var(struct isl_tab *tab, int r)
|
||||
return r;
|
||||
}
|
||||
|
||||
/* Add a variable to the tableau and allocate a column for it.
|
||||
* Return the index into the variable array "var".
|
||||
*/
|
||||
int isl_tab_allocate_var(struct isl_tab *tab)
|
||||
{
|
||||
if (!tab)
|
||||
return -1;
|
||||
|
||||
return isl_tab_insert_var(tab, tab->n_var);
|
||||
}
|
||||
|
||||
/* Add a row to the tableau. The row is given as an affine combination
|
||||
* of the original variables and needs to be expressed in terms of the
|
||||
* column variables.
|
||||
@ -3884,7 +3873,8 @@ static isl_stat drop_bmap_div(struct isl_tab *tab, int pos)
|
||||
if (n_div < 0)
|
||||
return isl_stat_error;
|
||||
off = tab->n_var - n_div;
|
||||
if (isl_basic_map_drop_div(tab->bmap, pos - off) < 0)
|
||||
tab->bmap = isl_basic_map_drop_div(tab->bmap, pos - off);
|
||||
if (!tab->bmap)
|
||||
return isl_stat_error;
|
||||
if (tab->samples) {
|
||||
tab->samples = isl_mat_drop_cols(tab->samples, 1 + pos, 1);
|
||||
|
1
polly/lib/External/isl/isl_tab.h
vendored
1
polly/lib/External/isl/isl_tab.h
vendored
@ -299,7 +299,6 @@ struct isl_tab *isl_tab_product(struct isl_tab *tab1, struct isl_tab *tab2);
|
||||
int isl_tab_extend_cons(struct isl_tab *tab, unsigned n_new) WARN_UNUSED;
|
||||
int isl_tab_allocate_con(struct isl_tab *tab) WARN_UNUSED;
|
||||
int isl_tab_extend_vars(struct isl_tab *tab, unsigned n_new) WARN_UNUSED;
|
||||
int isl_tab_allocate_var(struct isl_tab *tab) WARN_UNUSED;
|
||||
int isl_tab_insert_var(struct isl_tab *tab, int pos) WARN_UNUSED;
|
||||
int isl_tab_pivot(struct isl_tab *tab, int row, int col) WARN_UNUSED;
|
||||
int isl_tab_add_row(struct isl_tab *tab, isl_int *line) WARN_UNUSED;
|
||||
|
1
polly/lib/External/isl/isl_tab_pip.c
vendored
1
polly/lib/External/isl/isl_tab_pip.c
vendored
@ -4379,6 +4379,7 @@ static __isl_give isl_basic_map *align_context_divs(
|
||||
}
|
||||
other = bmap_n_div - common;
|
||||
if (dom->n_div - common > 0) {
|
||||
bmap = isl_basic_map_cow(bmap);
|
||||
bmap = isl_basic_map_extend(bmap, dom->n_div - common, 0, 0);
|
||||
if (!bmap)
|
||||
return NULL;
|
||||
|
378
polly/lib/External/isl/isl_test.c
vendored
378
polly/lib/External/isl/isl_test.c
vendored
@ -1402,76 +1402,47 @@ static isl_stat test_plain_unshifted_simple_hull_special(isl_ctx *ctx)
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Pairs of maps and the corresponding expected results of
|
||||
* isl_map_plain_unshifted_simple_hull.
|
||||
*/
|
||||
struct {
|
||||
const char *map;
|
||||
const char *hull;
|
||||
} plain_unshifted_simple_hull_tests[] = {
|
||||
{ "{ [i] -> [j] : i >= 1 and j >= 1 or i >= 2 and j <= 10 }",
|
||||
"{ [i] -> [j] : i >= 1 }" },
|
||||
{ "{ [n] -> [i,j,k] : (i mod 3 = 2 and j mod 4 = 2) or "
|
||||
"(j mod 4 = 2 and k mod 6 = n) }",
|
||||
"{ [n] -> [i,j,k] : j mod 4 = 2 }" },
|
||||
};
|
||||
|
||||
/* Basic tests for isl_map_plain_unshifted_simple_hull.
|
||||
*/
|
||||
static int test_plain_unshifted_simple_hull(isl_ctx *ctx)
|
||||
{
|
||||
int i;
|
||||
isl_map *map;
|
||||
isl_basic_map *hull, *expected;
|
||||
isl_bool equal;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(plain_unshifted_simple_hull_tests); ++i) {
|
||||
const char *str;
|
||||
str = plain_unshifted_simple_hull_tests[i].map;
|
||||
map = isl_map_read_from_str(ctx, str);
|
||||
str = plain_unshifted_simple_hull_tests[i].hull;
|
||||
expected = isl_basic_map_read_from_str(ctx, str);
|
||||
hull = isl_map_plain_unshifted_simple_hull(map);
|
||||
equal = isl_basic_map_is_equal(hull, expected);
|
||||
isl_basic_map_free(hull);
|
||||
isl_basic_map_free(expected);
|
||||
if (equal < 0)
|
||||
return -1;
|
||||
if (!equal)
|
||||
isl_die(ctx, isl_error_unknown, "unexpected hull",
|
||||
return -1);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Pairs of sets and the corresponding expected results of
|
||||
* isl_set_unshifted_simple_hull.
|
||||
/* Inputs for simple hull tests, consisting of
|
||||
* the specific simple hull function, the input set and the expected result.
|
||||
*/
|
||||
struct {
|
||||
__isl_give isl_basic_set *(*fn)(__isl_take isl_set *set);
|
||||
const char *set;
|
||||
const char *hull;
|
||||
} unshifted_simple_hull_tests[] = {
|
||||
{ "{ [0,x,y] : x <= -1; [1,x,y] : x <= y <= -x; [2,x,y] : x <= 1 }",
|
||||
} simple_hull_tests[] = {
|
||||
{ &isl_set_plain_unshifted_simple_hull,
|
||||
"{ [i,j] : i >= 1 and j >= 1 or i >= 2 and j <= 10 }",
|
||||
"{ [i,j] : i >= 1 }" },
|
||||
{ &isl_set_plain_unshifted_simple_hull,
|
||||
"{ [n,i,j,k] : (i mod 3 = 2 and j mod 4 = 2) or "
|
||||
"(j mod 4 = 2 and k mod 6 = n) }",
|
||||
"{ [n,i,j,k] : j mod 4 = 2 }" },
|
||||
{ &isl_set_unshifted_simple_hull,
|
||||
"{ [0,x,y] : x <= -1; [1,x,y] : x <= y <= -x; [2,x,y] : x <= 1 }",
|
||||
"{ [t,x,y] : 0 <= t <= 2 and x <= 1 }" },
|
||||
{ &isl_set_simple_hull,
|
||||
"{ [a, b] : b <= 0 and "
|
||||
"2*floor((-2*floor((b)/2))/5) >= a - floor((b)/2); "
|
||||
"[a, b] : a mod 2 = 0 }",
|
||||
"{ [a, b] }" },
|
||||
};
|
||||
|
||||
/* Basic tests for isl_set_unshifted_simple_hull.
|
||||
/* Basic tests for various simple hull functions.
|
||||
*/
|
||||
static int test_unshifted_simple_hull(isl_ctx *ctx)
|
||||
static int test_various_simple_hull(isl_ctx *ctx)
|
||||
{
|
||||
int i;
|
||||
isl_set *set;
|
||||
isl_basic_set *hull, *expected;
|
||||
isl_bool equal;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(unshifted_simple_hull_tests); ++i) {
|
||||
for (i = 0; i < ARRAY_SIZE(simple_hull_tests); ++i) {
|
||||
const char *str;
|
||||
str = unshifted_simple_hull_tests[i].set;
|
||||
str = simple_hull_tests[i].set;
|
||||
set = isl_set_read_from_str(ctx, str);
|
||||
str = unshifted_simple_hull_tests[i].hull;
|
||||
str = simple_hull_tests[i].hull;
|
||||
expected = isl_basic_set_read_from_str(ctx, str);
|
||||
hull = isl_set_unshifted_simple_hull(set);
|
||||
hull = simple_hull_tests[i].fn(set);
|
||||
equal = isl_basic_set_is_equal(hull, expected);
|
||||
isl_basic_set_free(hull);
|
||||
isl_basic_set_free(expected);
|
||||
@ -1508,9 +1479,7 @@ static int test_simple_hull(struct isl_ctx *ctx)
|
||||
|
||||
if (test_plain_unshifted_simple_hull_special(ctx) < 0)
|
||||
return -1;
|
||||
if (test_plain_unshifted_simple_hull(ctx) < 0)
|
||||
return -1;
|
||||
if (test_unshifted_simple_hull(ctx) < 0)
|
||||
if (test_various_simple_hull(ctx) < 0)
|
||||
return -1;
|
||||
|
||||
return 0;
|
||||
@ -1683,33 +1652,6 @@ static int test_convex_hull(isl_ctx *ctx)
|
||||
return 0;
|
||||
}
|
||||
|
||||
void test_gist_case(struct isl_ctx *ctx, const char *name)
|
||||
{
|
||||
char *filename;
|
||||
FILE *input;
|
||||
struct isl_basic_set *bset1, *bset2;
|
||||
|
||||
filename = get_filename(ctx, name, "polylib");
|
||||
assert(filename);
|
||||
input = fopen(filename, "r");
|
||||
assert(input);
|
||||
|
||||
bset1 = isl_basic_set_read_from_file(ctx, input);
|
||||
bset2 = isl_basic_set_read_from_file(ctx, input);
|
||||
|
||||
bset1 = isl_basic_set_gist(bset1, bset2);
|
||||
|
||||
bset2 = isl_basic_set_read_from_file(ctx, input);
|
||||
|
||||
assert(isl_basic_set_is_equal(bset1, bset2) == 1);
|
||||
|
||||
isl_basic_set_free(bset1);
|
||||
isl_basic_set_free(bset2);
|
||||
free(filename);
|
||||
|
||||
fclose(input);
|
||||
}
|
||||
|
||||
/* Check that computing the gist of "map" with respect to "context"
|
||||
* does not make any copy of "map" get marked empty.
|
||||
* Earlier versions of isl would end up doing that.
|
||||
@ -1858,6 +1800,9 @@ struct {
|
||||
const char *context;
|
||||
const char *gist;
|
||||
} gist_tests[] = {
|
||||
{ "{ [1, -1, 3] }",
|
||||
"{ [1, b, 2 - b] : -1 <= b <= 2 }",
|
||||
"{ [a, -1, c] }" },
|
||||
{ "{ [a, b, c] : a <= 15 and a >= 1 }",
|
||||
"{ [a, b, c] : exists (e0 = floor((-1 + a)/16): a >= 1 and "
|
||||
"c <= 30 and 32e0 >= -62 + 2a + 2b - c and b >= 0) }",
|
||||
@ -1982,8 +1927,6 @@ static int test_gist(struct isl_ctx *ctx)
|
||||
if (test_gist_fail(ctx) < 0)
|
||||
return -1;
|
||||
|
||||
test_gist_case(ctx, "gist1");
|
||||
|
||||
str = "[p0, p2, p3, p5, p6, p10] -> { [] : "
|
||||
"exists (e0 = [(15 + p0 + 15p6 + 15p10)/16], e1 = [(p5)/8], "
|
||||
"e2 = [(p6)/128], e3 = [(8p2 - p5)/128], "
|
||||
@ -3177,6 +3120,53 @@ static int test_min_special2(isl_ctx *ctx)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Check that the result of isl_set_min_multi_pw_aff
|
||||
* on the union of the sets with string descriptions "s1" and "s2"
|
||||
* consists of a single expression (on a single cell).
|
||||
*/
|
||||
static isl_stat check_single_expr_min(isl_ctx *ctx, const char *s1,
|
||||
const char *s2)
|
||||
{
|
||||
isl_size n;
|
||||
isl_set *set1, *set2;
|
||||
isl_multi_pw_aff *mpa;
|
||||
isl_pw_multi_aff *pma;
|
||||
|
||||
set1 = isl_set_read_from_str(ctx, s1);
|
||||
set2 = isl_set_read_from_str(ctx, s2);
|
||||
set1 = isl_set_union(set1, set2);
|
||||
mpa = isl_set_min_multi_pw_aff(set1);
|
||||
pma = isl_pw_multi_aff_from_multi_pw_aff(mpa);
|
||||
n = isl_pw_multi_aff_n_piece(pma);
|
||||
isl_pw_multi_aff_free(pma);
|
||||
|
||||
if (n < 0)
|
||||
return isl_stat_error;
|
||||
if (n != 1)
|
||||
isl_die(ctx, isl_error_unknown, "expecting single expression",
|
||||
return isl_stat_error);
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* A specialized isl_set_min_multi_pw_aff test that checks
|
||||
* that the minimum of 2N and 3N for N >= 0 is represented
|
||||
* by a single expression, without splitting off the special case N = 0.
|
||||
* Do this for both orderings.
|
||||
*/
|
||||
static int test_min_mpa(isl_ctx *ctx)
|
||||
{
|
||||
const char *s1, *s2;
|
||||
|
||||
s1 = "[N=0:] -> { [1, 3N:] }";
|
||||
s2 = "[N=0:] -> { [10, 2N:] }";
|
||||
if (check_single_expr_min(ctx, s1, s2) < 0)
|
||||
return -1;
|
||||
if (check_single_expr_min(ctx, s2, s1) < 0)
|
||||
return -1;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
struct {
|
||||
const char *set;
|
||||
const char *obj;
|
||||
@ -3870,67 +3860,88 @@ static int test_union(isl_ctx *ctx)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Check that computing a bound of a non-zero polynomial over an unbounded
|
||||
* domain does not produce a rational value.
|
||||
* In particular, check that the upper bound is infinity.
|
||||
/* Inputs for basic isl_pw_qpolynomial_bound tests.
|
||||
* "type" is the type of bound that should be computed.
|
||||
* "poly" is a string representation of the input.
|
||||
* "bound" is a string representation of the expected result.
|
||||
* "tight" is set if the result is expected to be tight.
|
||||
*/
|
||||
static int test_bound_unbounded_domain(isl_ctx *ctx)
|
||||
static struct {
|
||||
int tight;
|
||||
enum isl_fold type;
|
||||
const char *poly;
|
||||
const char *bound;
|
||||
} bound_tests[] = {
|
||||
/* Check that computing a bound of a non-zero polynomial
|
||||
* over an unbounded domain does not produce a rational value.
|
||||
* In particular, check that the upper bound is infinity.
|
||||
*/
|
||||
{ 0, isl_fold_max, "{ [m, n] -> -m * n }", "{ max(infty) }" },
|
||||
{ 1, isl_fold_max, "{ [[a, b, c, d] -> [e]] -> 0 }",
|
||||
"{ [a, b, c, d] -> max(0) }" },
|
||||
{ 1, isl_fold_max, "{ [[x] -> [x]] -> 1 : exists a : x = 2 a }",
|
||||
"{ [x] -> max(1) : x mod 2 = 0 }" },
|
||||
{ 1, isl_fold_min, "{ [x=5:10] -> (x + 2)^2 }", "{ min(49) }" },
|
||||
{ 1, isl_fold_max, "{ [0:10] -> 1 }", "{ max(1) }" },
|
||||
{ 1, isl_fold_max, "{ [[m] -> [0:m]] -> m^2 }",
|
||||
"{ [m] -> max(m^2) : m >= 0 }" },
|
||||
};
|
||||
|
||||
/* Check that the bound computation can handle differences
|
||||
* in domain dimension names of the input polynomial and its domain.
|
||||
*/
|
||||
static isl_stat test_bound_space(isl_ctx *ctx)
|
||||
{
|
||||
const char *str;
|
||||
isl_pw_qpolynomial *pwqp;
|
||||
isl_pw_qpolynomial_fold *pwf, *pwf2;
|
||||
isl_bool equal;
|
||||
|
||||
str = "{ [m,n] -> -m * n }";
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
|
||||
str = "{ infty }";
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
pwf2 = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
|
||||
equal = isl_pw_qpolynomial_fold_plain_is_equal(pwf, pwf2);
|
||||
isl_pw_qpolynomial_fold_free(pwf);
|
||||
isl_pw_qpolynomial_fold_free(pwf2);
|
||||
|
||||
if (equal < 0)
|
||||
return -1;
|
||||
if (!equal)
|
||||
isl_die(ctx, isl_error_unknown,
|
||||
"expecting infinite polynomial bound", return -1);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int test_bound(isl_ctx *ctx)
|
||||
{
|
||||
const char *str;
|
||||
isl_size dim;
|
||||
isl_set *set;
|
||||
isl_pw_qpolynomial *pwqp;
|
||||
isl_pw_qpolynomial_fold *pwf;
|
||||
|
||||
if (test_bound_unbounded_domain(ctx) < 0)
|
||||
str = "{ [[c] -> [c]] }";
|
||||
set = isl_set_read_from_str(ctx, str);
|
||||
str = "{ [[a] -> [b]] -> 1 }";
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
pwqp = isl_pw_qpolynomial_intersect_domain(pwqp, set);
|
||||
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
|
||||
isl_pw_qpolynomial_fold_free(pwf);
|
||||
|
||||
return isl_stat_non_null(pwf);
|
||||
}
|
||||
|
||||
/* Perform basic isl_pw_qpolynomial_bound tests.
|
||||
*/
|
||||
static int test_bound(isl_ctx *ctx)
|
||||
{
|
||||
int i;
|
||||
|
||||
if (test_bound_space(ctx) < 0)
|
||||
return -1;
|
||||
|
||||
str = "{ [[a, b, c, d] -> [e]] -> 0 }";
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
|
||||
dim = isl_pw_qpolynomial_fold_dim(pwf, isl_dim_in);
|
||||
isl_pw_qpolynomial_fold_free(pwf);
|
||||
if (dim < 0)
|
||||
return -1;
|
||||
if (dim != 4)
|
||||
isl_die(ctx, isl_error_unknown, "unexpected input dimension",
|
||||
return -1);
|
||||
for (i = 0; i < ARRAY_SIZE(bound_tests); ++i) {
|
||||
const char *str;
|
||||
enum isl_fold type;
|
||||
isl_bool equal, tight;
|
||||
isl_pw_qpolynomial *pwqp;
|
||||
isl_pw_qpolynomial_fold *pwf1, *pwf2;
|
||||
|
||||
str = "{ [[x]->[x]] -> 1 : exists a : x = 2 a }";
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
pwf = isl_pw_qpolynomial_bound(pwqp, isl_fold_max, NULL);
|
||||
dim = isl_pw_qpolynomial_fold_dim(pwf, isl_dim_in);
|
||||
isl_pw_qpolynomial_fold_free(pwf);
|
||||
if (dim < 0)
|
||||
return -1;
|
||||
if (dim != 1)
|
||||
isl_die(ctx, isl_error_unknown, "unexpected input dimension",
|
||||
return -1);
|
||||
str = bound_tests[i].poly;
|
||||
pwqp = isl_pw_qpolynomial_read_from_str(ctx, str);
|
||||
type = bound_tests[i].type;
|
||||
pwf1 = isl_pw_qpolynomial_bound(pwqp, type, &tight);
|
||||
str = bound_tests[i].bound;
|
||||
pwf2 = isl_pw_qpolynomial_fold_read_from_str(ctx, str);
|
||||
equal = isl_pw_qpolynomial_fold_plain_is_equal(pwf1, pwf2);
|
||||
isl_pw_qpolynomial_fold_free(pwf2);
|
||||
isl_pw_qpolynomial_fold_free(pwf1);
|
||||
if (equal < 0)
|
||||
return -1;
|
||||
if (!equal)
|
||||
isl_die(ctx, isl_error_unknown,
|
||||
"incorrect bound result", return -1);
|
||||
if (bound_tests[i].tight && !tight)
|
||||
isl_die(ctx, isl_error_unknown,
|
||||
"bound unexpectedly not tight", return -1);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -5600,6 +5611,26 @@ struct {
|
||||
{ &isl_union_pw_multi_aff_union_add, "{ B[x] -> A[1] : x <= 0 }",
|
||||
"{ B[x] -> A[2] : x >= 0 }",
|
||||
"{ B[x] -> A[1] : x < 0; B[x] -> A[2] : x > 0; B[0] -> A[3] }" },
|
||||
{
|
||||
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
|
||||
"{ B[x] -> C[x + 2] }",
|
||||
"{ D[y] -> B[2y] }",
|
||||
"{ }" },
|
||||
{
|
||||
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
|
||||
"{ [A[x] -> B[x + 1]] -> C[x + 2] }",
|
||||
"{ D[y] -> B[2y] }",
|
||||
"{ }" },
|
||||
{
|
||||
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
|
||||
"{ [A[x] -> B[x + 1]] -> C[x + 2]; B[x] -> C[x + 2] }",
|
||||
"{ D[y] -> A[2y] }",
|
||||
"{ [D[y] -> B[2y + 1]] -> C[2y + 2] }" },
|
||||
{
|
||||
&isl_union_pw_multi_aff_preimage_domain_wrapped_domain_union_pw_multi_aff,
|
||||
"{ T[A[x] -> B[x + 1]] -> C[x + 2]; B[x] -> C[x + 2] }",
|
||||
"{ D[y] -> A[2y] }",
|
||||
"{ T[D[y] -> B[2y + 1]] -> C[2y + 2] }" },
|
||||
};
|
||||
|
||||
/* Perform some basic tests of binary operations on
|
||||
@ -7938,6 +7969,18 @@ static struct {
|
||||
"[n] -> { A[i] -> [] : 0 <= i <= n; B[] -> [] }",
|
||||
"[m] -> { A[i] -> [] : 0 <= i <= m; C[] -> [] }",
|
||||
"[m, n] -> { A[i] -> [] : 0 <= i <= n and i <= m }" },
|
||||
{ &isl_union_map_intersect_domain_factor_domain,
|
||||
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
|
||||
"[N] -> { B[i] -> C[N] }",
|
||||
"{ }" },
|
||||
{ &isl_union_map_intersect_domain_factor_domain,
|
||||
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
|
||||
"[N] -> { A[i] -> C[N] }",
|
||||
"[N] -> { [A[N - 2] -> B[N - 1]] -> C[N] }" },
|
||||
{ &isl_union_map_intersect_domain_factor_domain,
|
||||
"{ T[A[i] -> B[i + 1]] -> C[i + 2] }",
|
||||
"[N] -> { A[i] -> C[N] }",
|
||||
"[N] -> { T[A[N - 2] -> B[N - 1]] -> C[N] }" },
|
||||
{ &isl_union_map_intersect_domain_factor_range,
|
||||
"{ [A[i] -> B[i + 1]] -> C[i + 2] }",
|
||||
"[N] -> { B[i] -> C[N] }",
|
||||
@ -8160,11 +8203,21 @@ struct {
|
||||
"{ A[i,j] -> B[i',j'] }",
|
||||
"F[{ A[i,j] -> [i] : i > j; B[i,j] -> [i] }]",
|
||||
"{ A[i,j] -> B[i,j'] : i > j }" },
|
||||
{ &isl_union_map_lex_le_at_multi_union_pw_aff,
|
||||
"{ A[i,j] -> B[i',j'] }",
|
||||
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
|
||||
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
|
||||
"{ A[i,j] -> B[i',j'] : i,j <<= i',j' }" },
|
||||
{ &isl_union_map_lex_lt_at_multi_union_pw_aff,
|
||||
"{ A[i,j] -> B[i',j'] }",
|
||||
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
|
||||
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
|
||||
"{ A[i,j] -> B[i',j'] : i,j << i',j' }" },
|
||||
{ &isl_union_map_lex_ge_at_multi_union_pw_aff,
|
||||
"{ A[i,j] -> B[i',j'] }",
|
||||
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
|
||||
"{ A[i,j] -> [j]; B[i,j] -> [j] }]",
|
||||
"{ A[i,j] -> B[i',j'] : i,j >>= i',j' }" },
|
||||
{ &isl_union_map_lex_gt_at_multi_union_pw_aff,
|
||||
"{ A[i,j] -> B[i',j'] }",
|
||||
"F[{ A[i,j] -> [i]; B[i,j] -> [i] }, "
|
||||
@ -10006,6 +10059,48 @@ static isl_stat test_multi_pw_aff_3(isl_ctx *ctx)
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* String descriptions of boxes that
|
||||
* are used for reconstructing box maps from their lower and upper bounds.
|
||||
*/
|
||||
static const char *multi_pw_aff_box_tests[] = {
|
||||
"{ A[x, y] -> [] : x + y >= 0 }",
|
||||
"[N] -> { A[x, y] -> [x] : x + y <= N }",
|
||||
"[N] -> { A[x, y] -> [x : y] : x + y <= N }",
|
||||
};
|
||||
|
||||
/* Check that map representations of boxes can be reconstructed
|
||||
* from their lower and upper bounds.
|
||||
*/
|
||||
static isl_stat test_multi_pw_aff_box(isl_ctx *ctx)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(multi_pw_aff_box_tests); ++i) {
|
||||
const char *str;
|
||||
isl_bool equal;
|
||||
isl_map *map, *box;
|
||||
isl_multi_pw_aff *min, *max;
|
||||
|
||||
str = multi_pw_aff_box_tests[i];
|
||||
map = isl_map_read_from_str(ctx, str);
|
||||
min = isl_map_min_multi_pw_aff(isl_map_copy(map));
|
||||
max = isl_map_max_multi_pw_aff(isl_map_copy(map));
|
||||
box = isl_map_universe(isl_map_get_space(map));
|
||||
box = isl_map_lower_bound_multi_pw_aff(box, min);
|
||||
box = isl_map_upper_bound_multi_pw_aff(box, max);
|
||||
equal = isl_map_is_equal(map, box);
|
||||
isl_map_free(map);
|
||||
isl_map_free(box);
|
||||
if (equal < 0)
|
||||
return isl_stat_error;
|
||||
if (!equal)
|
||||
isl_die(ctx, isl_error_unknown,
|
||||
"unexpected result", return isl_stat_error);
|
||||
}
|
||||
|
||||
return isl_stat_ok;
|
||||
}
|
||||
|
||||
/* Perform some tests on multi piecewise affine expressions.
|
||||
*/
|
||||
static int test_multi_pw_aff(isl_ctx *ctx)
|
||||
@ -10016,6 +10111,8 @@ static int test_multi_pw_aff(isl_ctx *ctx)
|
||||
return -1;
|
||||
if (test_multi_pw_aff_3(ctx) < 0)
|
||||
return -1;
|
||||
if (test_multi_pw_aff_box(ctx) < 0)
|
||||
return -1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -10560,7 +10657,7 @@ static int test_tile(isl_ctx *ctx)
|
||||
}
|
||||
|
||||
/* Check that the domain hash of a space is equal to the hash
|
||||
* of the domain of the space.
|
||||
* of the domain of the space, both ignoring parameters.
|
||||
*/
|
||||
static int test_domain_hash(isl_ctx *ctx)
|
||||
{
|
||||
@ -10571,9 +10668,9 @@ static int test_domain_hash(isl_ctx *ctx)
|
||||
map = isl_map_read_from_str(ctx, "[n] -> { A[B[x] -> C[]] -> D[] }");
|
||||
space = isl_map_get_space(map);
|
||||
isl_map_free(map);
|
||||
hash1 = isl_space_get_domain_hash(space);
|
||||
hash1 = isl_space_get_tuple_domain_hash(space);
|
||||
space = isl_space_domain(space);
|
||||
hash2 = isl_space_get_hash(space);
|
||||
hash2 = isl_space_get_tuple_hash(space);
|
||||
isl_space_free(space);
|
||||
|
||||
if (!space)
|
||||
@ -10761,6 +10858,7 @@ struct {
|
||||
{ "intersect", &test_intersect },
|
||||
{ "lexmin", &test_lexmin },
|
||||
{ "min", &test_min },
|
||||
{ "set lower bounds", &test_min_mpa },
|
||||
{ "gist", &test_gist },
|
||||
{ "piecewise quasi-polynomials", &test_pwqp },
|
||||
{ "lift", &test_lift },
|
||||
|
1
polly/lib/External/isl/isl_test_imath.c
vendored
1
polly/lib/External/isl/isl_test_imath.c
vendored
@ -34,7 +34,6 @@ int test_imath_internals()
|
||||
assert(MP_SMALL_MAX == LONG_MAX);
|
||||
|
||||
assert(sizeof(mp_usmall) == sizeof(unsigned long));
|
||||
assert(MP_USMALL_MIN == ULONG_MIN);
|
||||
assert(MP_USMALL_MAX == ULONG_MAX);
|
||||
|
||||
retval = mp_int_init_value(&val, 0);
|
||||
|
18
polly/lib/External/isl/isl_type_has_space_templ.c
vendored
Normal file
18
polly/lib/External/isl/isl_type_has_space_templ.c
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
/*
|
||||
* Copyright 2013 Ecole Normale Superieure
|
||||
*
|
||||
* Use of this software is governed by the MIT license
|
||||
*
|
||||
* Written by Sven Verdoolaege,
|
||||
* Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
|
||||
*/
|
||||
|
||||
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
|
||||
#define FN(TYPE,NAME) xFN(TYPE,NAME)
|
||||
|
||||
/* Is the space of "obj" equal to "space"?
|
||||
*/
|
||||
isl_bool FN(TYPE,has_space)(__isl_keep TYPE *obj, __isl_keep isl_space *space)
|
||||
{
|
||||
return isl_space_is_equal(FN(TYPE,peek_space)(obj), space);
|
||||
}
|
64
polly/lib/External/isl/isl_union_eval.c
vendored
64
polly/lib/External/isl/isl_union_eval.c
vendored
@ -24,53 +24,57 @@ static __isl_give isl_val *FN(UNION,eval_void)(__isl_take UNION *u,
|
||||
return isl_val_nan(ctx);
|
||||
}
|
||||
|
||||
/* Do the tuples of "space" correspond to those of the domain of "part"?
|
||||
* That is, is the domain space of "part" equal to "space", ignoring parameters?
|
||||
/* Internal data structure for isl_union_*_eval.
|
||||
*
|
||||
* "pnt" is the point in which the function is evaluated.
|
||||
* "v" stores the result and is initialized to zero.
|
||||
*/
|
||||
static isl_bool FN(UNION,has_domain_space_tuples)(const void *entry,
|
||||
const void *val)
|
||||
{
|
||||
PART *part = (PART *)entry;
|
||||
isl_space *space = (isl_space *) val;
|
||||
S(UNION,eval_data) {
|
||||
isl_point *pnt;
|
||||
isl_val *v;
|
||||
};
|
||||
|
||||
return FN(PART,has_domain_space_tuples)(part, space);
|
||||
/* Update the evaluation in data->v based on the evaluation of "part".
|
||||
*
|
||||
* Only (at most) a single part on which this function is called
|
||||
* is assumed to evaluate to anything other than zero.
|
||||
* Since the value is initialized to zero, the evaluation of "part"
|
||||
* can simply be added.
|
||||
*/
|
||||
static isl_stat FN(UNION,eval_entry)(__isl_take PART *part, void *user)
|
||||
{
|
||||
S(UNION,eval_data) *data = user;
|
||||
isl_val *v;
|
||||
|
||||
v = FN(PART,eval)(part, isl_point_copy(data->pnt));
|
||||
data->v = isl_val_add(data->v, v);
|
||||
|
||||
return isl_stat_non_null(data->v);
|
||||
}
|
||||
|
||||
/* Evaluate "u" in the point "pnt".
|
||||
*/
|
||||
__isl_give isl_val *FN(UNION,eval)(__isl_take UNION *u,
|
||||
__isl_take isl_point *pnt)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry;
|
||||
S(UNION,eval_data) data = { pnt };
|
||||
isl_bool is_void;
|
||||
isl_space *space;
|
||||
isl_val *v;
|
||||
|
||||
if (!u || !pnt)
|
||||
goto error;
|
||||
is_void = isl_point_is_void(pnt);
|
||||
if (is_void < 0)
|
||||
goto error;
|
||||
if (is_void)
|
||||
return FN(UNION,eval_void)(u, pnt);
|
||||
|
||||
space = isl_space_copy(pnt->dim);
|
||||
if (!space)
|
||||
goto error;
|
||||
hash = isl_space_get_hash(space);
|
||||
entry = isl_hash_table_find(u->space->ctx, &u->table,
|
||||
hash, &FN(UNION,has_domain_space_tuples),
|
||||
space, 0);
|
||||
isl_space_free(space);
|
||||
if (!entry)
|
||||
goto error;
|
||||
if (entry == isl_hash_table_entry_none) {
|
||||
v = isl_val_zero(isl_point_get_ctx(pnt));
|
||||
isl_point_free(pnt);
|
||||
} else {
|
||||
v = FN(PART,eval)(FN(PART,copy)(entry->data), pnt);
|
||||
}
|
||||
data.v = isl_val_zero(isl_point_get_ctx(pnt));
|
||||
space = isl_point_peek_space(pnt);
|
||||
if (FN(UNION,foreach_on_domain)(u, space,
|
||||
&FN(UNION,eval_entry), &data) < 0)
|
||||
data.v = isl_val_free(data.v);
|
||||
FN(UNION,free)(u);
|
||||
return v;
|
||||
isl_point_free(pnt);
|
||||
return data.v;
|
||||
error:
|
||||
FN(UNION,free)(u);
|
||||
isl_point_free(pnt);
|
||||
|
172
polly/lib/External/isl/isl_union_map.c
vendored
172
polly/lib/External/isl/isl_union_map.c
vendored
@ -32,6 +32,13 @@
|
||||
#include <uset_from_umap.c>
|
||||
#include <set_list_from_map_list_inl.c>
|
||||
|
||||
#undef TYPE
|
||||
#define TYPE isl_union_map
|
||||
static
|
||||
#include "has_single_reference_templ.c"
|
||||
static
|
||||
#include "check_single_reference_templ.c"
|
||||
|
||||
/* Return the number of parameters of "umap", where "type"
|
||||
* is required to be set to isl_dim_param.
|
||||
*/
|
||||
@ -402,20 +409,58 @@ isl_bool isl_union_set_space_has_equal_params(__isl_keep isl_union_set *uset,
|
||||
return isl_union_map_space_has_equal_params(uset_to_umap(uset), space);
|
||||
}
|
||||
|
||||
static isl_bool has_space(const void *entry, const void *val)
|
||||
/* Is the space of the map at "entry" equal to "space", ignoring parameters?
|
||||
*/
|
||||
static isl_bool has_space_tuples(const void *entry, const void *val)
|
||||
{
|
||||
isl_map *map = (isl_map *)entry;
|
||||
isl_space *space = (isl_space *) val;
|
||||
|
||||
return isl_space_is_equal(map->dim, space);
|
||||
return isl_map_has_space_tuples(map, space);
|
||||
}
|
||||
|
||||
/* Find the entry in "umap" with space "space" (ignoring parameters),
|
||||
* returning isl_hash_table_entry_none if no such entry appears in "umap" and
|
||||
* NULL on error.
|
||||
* If "reserve" is set, then an entry is created if it does
|
||||
* not exist already. Since this modifies the hash table in-place,
|
||||
* this means "umap" must have a single reference when "reserve" is set.
|
||||
*/
|
||||
static struct isl_hash_table_entry *isl_union_map_find_entry(
|
||||
__isl_keep isl_union_map *umap, __isl_keep isl_space *space,
|
||||
int reserve)
|
||||
{
|
||||
uint32_t hash;
|
||||
|
||||
if (!umap || !space)
|
||||
return NULL;
|
||||
if (reserve && isl_union_map_check_single_reference(umap) < 0)
|
||||
return NULL;
|
||||
|
||||
hash = isl_space_get_tuple_hash(space);
|
||||
return isl_hash_table_find(isl_union_map_get_ctx(umap), &umap->table,
|
||||
hash, &has_space_tuples, space, reserve);
|
||||
}
|
||||
|
||||
/* Find the entry in "uset" with space "space" (ignoring parameters),
|
||||
* returning isl_hash_table_entry_none if no such entry appears in "uset" and
|
||||
* NULL on error.
|
||||
* If "reserve" is set, then an entry is created if it does
|
||||
* not exist already. In this case, a NULL return indicates an error.
|
||||
*/
|
||||
struct isl_hash_table_entry *isl_union_set_find_entry(
|
||||
__isl_keep isl_union_set *uset, __isl_keep isl_space *space,
|
||||
int reserve)
|
||||
{
|
||||
return isl_union_map_find_entry(uset_to_umap(uset), space, reserve);
|
||||
}
|
||||
|
||||
__isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap,
|
||||
__isl_take isl_map *map)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry;
|
||||
isl_bool aligned;
|
||||
isl_space *space;
|
||||
|
||||
if (!map || !umap)
|
||||
goto error;
|
||||
@ -435,12 +480,8 @@ __isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap,
|
||||
|
||||
umap = isl_union_map_cow(umap);
|
||||
|
||||
if (!map || !umap)
|
||||
goto error;
|
||||
|
||||
hash = isl_space_get_hash(map->dim);
|
||||
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
|
||||
&has_space, map->dim, 1);
|
||||
space = isl_map_peek_space(map);
|
||||
entry = isl_union_map_find_entry(umap, space, 1);
|
||||
if (!entry)
|
||||
goto error;
|
||||
|
||||
@ -701,17 +742,9 @@ __isl_give isl_set *isl_set_from_union_set(__isl_take isl_union_set *uset)
|
||||
__isl_give isl_map *isl_union_map_extract_map(__isl_keep isl_union_map *umap,
|
||||
__isl_take isl_space *space)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry;
|
||||
|
||||
space = isl_space_drop_all_params(space);
|
||||
space = isl_space_align_params(space, isl_union_map_get_space(umap));
|
||||
if (!umap || !space)
|
||||
goto error;
|
||||
|
||||
hash = isl_space_get_hash(space);
|
||||
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
|
||||
&has_space, space, 0);
|
||||
entry = isl_union_map_find_entry(umap, space, 0);
|
||||
if (!entry)
|
||||
goto error;
|
||||
if (entry == isl_hash_table_entry_none)
|
||||
@ -734,17 +767,11 @@ __isl_give isl_set *isl_union_set_extract_set(__isl_keep isl_union_set *uset,
|
||||
isl_bool isl_union_map_contains(__isl_keep isl_union_map *umap,
|
||||
__isl_keep isl_space *space)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry;
|
||||
|
||||
space = isl_space_drop_all_params(isl_space_copy(space));
|
||||
space = isl_space_align_params(space, isl_union_map_get_space(umap));
|
||||
if (!space)
|
||||
return isl_bool_error;
|
||||
|
||||
hash = isl_space_get_hash(space);
|
||||
entry = isl_hash_table_find(umap->dim->ctx, &umap->table, hash,
|
||||
&has_space, space, 0);
|
||||
entry = isl_union_map_find_entry(umap, space, 0);
|
||||
isl_space_free(space);
|
||||
if (!entry)
|
||||
return isl_bool_error;
|
||||
@ -903,7 +930,6 @@ static __isl_give isl_space *identity(__isl_take isl_space *space)
|
||||
static __isl_keep isl_maybe_isl_map bin_try_get_match(
|
||||
struct isl_union_map_gen_bin_data *data, __isl_keep isl_map *map)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry2;
|
||||
isl_space *space;
|
||||
isl_maybe_isl_map res = { isl_bool_error, NULL };
|
||||
@ -918,12 +944,7 @@ static __isl_keep isl_maybe_isl_map bin_try_get_match(
|
||||
space = isl_map_get_space(map);
|
||||
if (data->control->match_space != &identity)
|
||||
space = data->control->match_space(space);
|
||||
if (!space)
|
||||
return res;
|
||||
hash = isl_space_get_hash(space);
|
||||
entry2 = isl_hash_table_find(isl_union_map_get_ctx(data->umap2),
|
||||
&data->umap2->table, hash,
|
||||
&has_space, space, 0);
|
||||
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
|
||||
isl_space_free(space);
|
||||
if (entry2)
|
||||
res.valid = isl_bool_ok(entry2 != isl_hash_table_entry_none);
|
||||
@ -1119,14 +1140,13 @@ struct isl_union_map_match_bin_data {
|
||||
static isl_stat match_bin_entry(void **entry, void *user)
|
||||
{
|
||||
struct isl_union_map_match_bin_data *data = user;
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry2;
|
||||
isl_space *space;
|
||||
isl_map *map = *entry;
|
||||
int empty;
|
||||
|
||||
hash = isl_space_get_hash(map->dim);
|
||||
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
|
||||
hash, &has_space, map->dim, 0);
|
||||
space = isl_map_peek_space(map);
|
||||
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
|
||||
if (!entry2)
|
||||
return isl_stat_error;
|
||||
if (entry2 == isl_hash_table_entry_none)
|
||||
@ -1446,6 +1466,22 @@ __isl_give isl_union_map *isl_union_map_intersect_range(
|
||||
return isl_union_map_intersect_range_union_set(umap, uset);
|
||||
}
|
||||
|
||||
/* Intersect each map in "umap" in a space [A -> B] -> C
|
||||
* with the corresponding map in "factor" in the space A -> C and
|
||||
* collect the results.
|
||||
*/
|
||||
__isl_give isl_union_map *isl_union_map_intersect_domain_factor_domain(
|
||||
__isl_take isl_union_map *umap, __isl_take isl_union_map *factor)
|
||||
{
|
||||
struct isl_bin_op_control control = {
|
||||
.filter = &isl_map_domain_is_wrapping,
|
||||
.match_space = &isl_space_domain_factor_domain,
|
||||
.fn_map = &isl_map_intersect_domain_factor_domain,
|
||||
};
|
||||
|
||||
return gen_bin_op(umap, factor, &control);
|
||||
}
|
||||
|
||||
/* Intersect each map in "umap" in a space [A -> B] -> C
|
||||
* with the corresponding map in "factor" in the space B -> C and
|
||||
* collect the results.
|
||||
@ -2484,13 +2520,12 @@ struct isl_union_map_is_subset_data {
|
||||
static isl_stat is_subset_entry(void **entry, void *user)
|
||||
{
|
||||
struct isl_union_map_is_subset_data *data = user;
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry2;
|
||||
isl_space *space;
|
||||
isl_map *map = *entry;
|
||||
|
||||
hash = isl_space_get_hash(map->dim);
|
||||
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
|
||||
hash, &has_space, map->dim, 0);
|
||||
space = isl_map_peek_space(map);
|
||||
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
|
||||
if (!entry2)
|
||||
return isl_stat_error;
|
||||
if (entry2 == isl_hash_table_entry_none) {
|
||||
@ -2515,28 +2550,16 @@ isl_bool isl_union_map_is_subset(__isl_keep isl_union_map *umap1,
|
||||
{
|
||||
struct isl_union_map_is_subset_data data = { NULL, isl_bool_true };
|
||||
|
||||
umap1 = isl_union_map_copy(umap1);
|
||||
umap2 = isl_union_map_copy(umap2);
|
||||
umap1 = isl_union_map_align_params(umap1, isl_union_map_get_space(umap2));
|
||||
umap2 = isl_union_map_align_params(umap2, isl_union_map_get_space(umap1));
|
||||
|
||||
if (!umap1 || !umap2)
|
||||
goto error;
|
||||
return isl_bool_error;
|
||||
|
||||
data.umap2 = umap2;
|
||||
if (isl_hash_table_foreach(umap1->dim->ctx, &umap1->table,
|
||||
&is_subset_entry, &data) < 0 &&
|
||||
data.is_subset)
|
||||
goto error;
|
||||
|
||||
isl_union_map_free(umap1);
|
||||
isl_union_map_free(umap2);
|
||||
return isl_bool_error;
|
||||
|
||||
return data.is_subset;
|
||||
error:
|
||||
isl_union_map_free(umap1);
|
||||
isl_union_map_free(umap2);
|
||||
return isl_bool_error;
|
||||
}
|
||||
|
||||
isl_bool isl_union_set_is_subset(__isl_keep isl_union_set *uset1,
|
||||
@ -2601,13 +2624,12 @@ struct isl_union_map_is_disjoint_data {
|
||||
static isl_stat is_disjoint_entry(void **entry, void *user)
|
||||
{
|
||||
struct isl_union_map_is_disjoint_data *data = user;
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry2;
|
||||
isl_space *space;
|
||||
isl_map *map = *entry;
|
||||
|
||||
hash = isl_space_get_hash(map->dim);
|
||||
entry2 = isl_hash_table_find(data->umap2->dim->ctx, &data->umap2->table,
|
||||
hash, &has_space, map->dim, 0);
|
||||
space = isl_map_peek_space(map);
|
||||
entry2 = isl_union_map_find_entry(data->umap2, space, 0);
|
||||
if (!entry2)
|
||||
return isl_stat_error;
|
||||
if (entry2 == isl_hash_table_entry_none)
|
||||
@ -4234,27 +4256,21 @@ __isl_give isl_union_map *isl_union_map_eq_at_multi_union_pw_aff(
|
||||
&isl_multi_pw_aff_eq_map);
|
||||
}
|
||||
|
||||
/* Return the subset of "umap" where the domain has a lexicographically
|
||||
* smaller "mupa" value than the range.
|
||||
*/
|
||||
__isl_give isl_union_map *isl_union_map_lex_lt_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa)
|
||||
{
|
||||
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
|
||||
&isl_multi_pw_aff_lex_lt_map);
|
||||
}
|
||||
#undef ORDER
|
||||
#define ORDER le
|
||||
#include "isl_union_map_lex_templ.c"
|
||||
|
||||
/* Return the subset of "umap" where the domain has a lexicographically
|
||||
* greater "mupa" value than the range.
|
||||
*/
|
||||
__isl_give isl_union_map *isl_union_map_lex_gt_at_multi_union_pw_aff(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa)
|
||||
{
|
||||
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
|
||||
&isl_multi_pw_aff_lex_gt_map);
|
||||
}
|
||||
#undef ORDER
|
||||
#define ORDER lt
|
||||
#include "isl_union_map_lex_templ.c"
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER ge
|
||||
#include "isl_union_map_lex_templ.c"
|
||||
|
||||
#undef ORDER
|
||||
#define ORDER gt
|
||||
#include "isl_union_map_lex_templ.c"
|
||||
|
||||
/* Return the union of the elements in the list "list".
|
||||
*/
|
||||
|
23
polly/lib/External/isl/isl_union_map_lex_templ.c
vendored
Normal file
23
polly/lib/External/isl/isl_union_map_lex_templ.c
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
/*
|
||||
* Copyright 2014 INRIA Rocquencourt
|
||||
*
|
||||
* Use of this software is governed by the MIT license
|
||||
*
|
||||
* Written by Sven Verdoolaege,
|
||||
* Inria Paris - Rocquencourt, Domaine de Voluceau - Rocquencourt,
|
||||
* B.P. 105 - 78153 Le Chesnay, France
|
||||
*/
|
||||
|
||||
#define xFN(TYPE,NAME) TYPE ## _ ## NAME
|
||||
#define FN(TYPE,NAME) xFN(TYPE,NAME)
|
||||
|
||||
/* Return the subset of "umap" where the domain and the range
|
||||
* have "mupa" values that lexicographically compare as "ORDER".
|
||||
*/
|
||||
__isl_give isl_union_map *FN(FN(isl_union_map_lex,ORDER),at_multi_union_pw_aff)(
|
||||
__isl_take isl_union_map *umap,
|
||||
__isl_take isl_multi_union_pw_aff *mupa)
|
||||
{
|
||||
return isl_union_map_order_at_multi_union_pw_aff(umap, mupa,
|
||||
&FN(FN(isl_multi_pw_aff_lex,ORDER),map));
|
||||
}
|
@ -10,6 +10,10 @@ struct isl_union_map {
|
||||
struct isl_hash_table table;
|
||||
};
|
||||
|
||||
struct isl_hash_table_entry *isl_union_set_find_entry(
|
||||
__isl_keep isl_union_set *uset, __isl_keep isl_space *space,
|
||||
int reserve);
|
||||
|
||||
__isl_keep isl_space *isl_union_map_peek_space(__isl_keep isl_union_map *umap);
|
||||
__isl_keep isl_space *isl_union_set_peek_space(__isl_keep isl_union_set *uset);
|
||||
isl_bool isl_union_map_is_params(__isl_keep isl_union_map *umap);
|
||||
|
35
polly/lib/External/isl/isl_union_multi.c
vendored
35
polly/lib/External/isl/isl_union_multi.c
vendored
@ -18,7 +18,7 @@
|
||||
|
||||
/* A group of expressions defined over the same domain space "domain_space".
|
||||
* The entries of "part_table" are the individual expressions,
|
||||
* keyed on the entire space of the expression.
|
||||
* keyed on the entire space of the expression (ignoring parameters).
|
||||
*
|
||||
* Each UNION has its own groups, so there can only ever be a single
|
||||
* reference to each group.
|
||||
@ -30,7 +30,8 @@ S(UNION,group) {
|
||||
|
||||
/* A union of expressions defined over different disjoint domains.
|
||||
* "space" describes the parameters.
|
||||
* The entries of "table" are keyed on the domain space of the entry and
|
||||
* The entries of "table" are keyed on the domain space of the entry
|
||||
* (ignoring parameters) and
|
||||
* contain groups of expressions that are defined over the same domain space.
|
||||
*/
|
||||
struct UNION {
|
||||
@ -158,14 +159,16 @@ error:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Is the space of "entry" equal to "space"?
|
||||
/* Is the space of "entry" equal to "space", ignoring parameters?
|
||||
*/
|
||||
static isl_bool FN(UNION,has_space)(const void *entry, const void *val)
|
||||
static isl_bool FN(UNION,has_space_tuples)(const void *entry, const void *val)
|
||||
{
|
||||
PART *part = (PART *) entry;
|
||||
isl_space *space = (isl_space *) val;
|
||||
isl_space *part_space;
|
||||
|
||||
return isl_space_is_equal(part->dim, space);
|
||||
part_space = FN(PART,peek_space)(part);
|
||||
return isl_space_has_equal_tuples(part_space, space);
|
||||
}
|
||||
|
||||
/* Return a group equal to "group", but with a single reference.
|
||||
@ -221,15 +224,15 @@ isl_stat FN(FN(UNION,foreach),BASE)(__isl_keep UNION *u,
|
||||
}
|
||||
|
||||
/* Is the domain space of the group of expressions at "entry"
|
||||
* equal to that of "space"?
|
||||
* equal to that of "space", ignoring parameters?
|
||||
*/
|
||||
static isl_bool FN(UNION,group_has_same_domain_space)(const void *entry,
|
||||
static isl_bool FN(UNION,group_has_same_domain_space_tuples)(const void *entry,
|
||||
const void *val)
|
||||
{
|
||||
S(UNION,group) *group = (S(UNION,group) *) entry;
|
||||
isl_space *space = (isl_space *) val;
|
||||
|
||||
return isl_space_is_domain_internal(group->domain_space, space);
|
||||
return isl_space_has_domain_tuples(group->domain_space, space);
|
||||
}
|
||||
|
||||
/* Return the entry, if any, in "u" that lives in "space".
|
||||
@ -254,9 +257,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
|
||||
return NULL;
|
||||
|
||||
ctx = FN(UNION,get_ctx)(u);
|
||||
hash = isl_space_get_domain_hash(space);
|
||||
hash = isl_space_get_tuple_domain_hash(space);
|
||||
group_entry = isl_hash_table_find(ctx, &u->table, hash,
|
||||
&FN(UNION,group_has_same_domain_space), space, reserve);
|
||||
&FN(UNION,group_has_same_domain_space_tuples), space, reserve);
|
||||
if (!group_entry || group_entry == isl_hash_table_entry_none)
|
||||
return group_entry;
|
||||
if (reserve && !group_entry->data) {
|
||||
@ -270,9 +273,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
|
||||
}
|
||||
if (!group)
|
||||
return NULL;
|
||||
hash = isl_space_get_hash(space);
|
||||
hash = isl_space_get_tuple_hash(space);
|
||||
return isl_hash_table_find(ctx, &group->part_table, hash,
|
||||
&FN(UNION,has_space), space, reserve);
|
||||
&FN(UNION,has_space_tuples), space, reserve);
|
||||
}
|
||||
|
||||
/* Remove "part_entry" from the hash table of "u".
|
||||
@ -297,9 +300,9 @@ static __isl_give UNION *FN(UNION,remove_part_entry)(__isl_take UNION *u,
|
||||
part = part_entry->data;
|
||||
ctx = FN(UNION,get_ctx)(u);
|
||||
space = FN(PART,peek_space)(part);
|
||||
hash = isl_space_get_domain_hash(space);
|
||||
hash = isl_space_get_tuple_domain_hash(space);
|
||||
group_entry = isl_hash_table_find(ctx, &u->table, hash,
|
||||
&FN(UNION,group_has_same_domain_space), space, 0);
|
||||
&FN(UNION,group_has_same_domain_space_tuples), space, 0);
|
||||
if (!group_entry)
|
||||
return FN(UNION,free)(u);
|
||||
if (group_entry == isl_hash_table_entry_none)
|
||||
@ -383,9 +386,9 @@ static isl_stat FN(UNION,check_disjoint_domain_other)(__isl_keep UNION *u,
|
||||
return isl_stat_error;
|
||||
ctx = FN(UNION,get_ctx)(u);
|
||||
space = FN(PART,peek_space)(part);
|
||||
hash = isl_space_get_domain_hash(space);
|
||||
hash = isl_space_get_tuple_domain_hash(space);
|
||||
group_entry = isl_hash_table_find(ctx, &u->table, hash,
|
||||
&FN(UNION,group_has_same_domain_space), space, 0);
|
||||
&FN(UNION,group_has_same_domain_space_tuples), space, 0);
|
||||
if (!group_entry)
|
||||
return isl_stat_error;
|
||||
if (group_entry == isl_hash_table_entry_none)
|
||||
|
53
polly/lib/External/isl/isl_union_single.c
vendored
53
polly/lib/External/isl/isl_union_single.c
vendored
@ -15,7 +15,8 @@
|
||||
|
||||
/* A union of expressions defined over different domain spaces.
|
||||
* "space" describes the parameters.
|
||||
* The entries of "table" are keyed on the domain space of the entry.
|
||||
* The entries of "table" are keyed on the domain space of the entry
|
||||
* (ignoring parameters).
|
||||
*/
|
||||
struct UNION {
|
||||
int ref;
|
||||
@ -63,9 +64,10 @@ isl_stat FN(FN(UNION,foreach),BASE)(__isl_keep UNION *u,
|
||||
&FN(UNION,call_on_copy), &data);
|
||||
}
|
||||
|
||||
/* Is the domain space of "entry" equal to the domain of "space"?
|
||||
/* Is the domain space of "entry" equal to the domain of "space",
|
||||
* ignoring parameters?
|
||||
*/
|
||||
static isl_bool FN(UNION,has_same_domain_space)(const void *entry,
|
||||
static isl_bool FN(UNION,has_same_domain_space_tuples)(const void *entry,
|
||||
const void *val)
|
||||
{
|
||||
PART *part = (PART *)entry;
|
||||
@ -100,9 +102,9 @@ static struct isl_hash_table_entry *FN(UNION,find_part_entry)(
|
||||
return NULL;
|
||||
|
||||
ctx = FN(UNION,get_ctx)(u);
|
||||
hash = isl_space_get_domain_hash(space);
|
||||
hash = isl_space_get_tuple_domain_hash(space);
|
||||
entry = isl_hash_table_find(ctx, &u->table, hash,
|
||||
&FN(UNION,has_same_domain_space), space, reserve);
|
||||
&FN(UNION,has_same_domain_space_tuples), space, reserve);
|
||||
if (!entry || entry == isl_hash_table_entry_none)
|
||||
return entry;
|
||||
if (reserve && !entry->data)
|
||||
@ -178,6 +180,47 @@ static isl_stat FN(UNION,foreach_inplace)(__isl_keep UNION *u,
|
||||
return isl_hash_table_foreach(ctx, &u->table, fn, user);
|
||||
}
|
||||
|
||||
static isl_bool FN(PART,has_domain_space_tuples)(__isl_keep PART *part,
|
||||
__isl_keep isl_space *space);
|
||||
|
||||
/* Do the tuples of "space" correspond to those of the domain of "part"?
|
||||
* That is, is the domain space of "part" equal to "space", ignoring parameters?
|
||||
*/
|
||||
static isl_bool FN(UNION,has_domain_space_tuples)(const void *entry,
|
||||
const void *val)
|
||||
{
|
||||
PART *part = (PART *)entry;
|
||||
isl_space *space = (isl_space *) val;
|
||||
|
||||
return FN(PART,has_domain_space_tuples)(part, space);
|
||||
}
|
||||
|
||||
/* Call "fn" on each part of "u" that has domain space "space".
|
||||
*
|
||||
* Since each entry is defined over a different domain space,
|
||||
* simply look for an entry with the given domain space and
|
||||
* call "fn" on the corresponding part if there is one.
|
||||
*/
|
||||
isl_stat FN(UNION,foreach_on_domain)(__isl_keep UNION *u,
|
||||
__isl_keep isl_space *space,
|
||||
isl_stat (*fn)(__isl_take PART *part, void *user), void *user)
|
||||
{
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry;
|
||||
|
||||
if (!u || !space)
|
||||
return isl_stat_error;
|
||||
hash = isl_space_get_tuple_hash(space);
|
||||
entry = isl_hash_table_find(FN(UNION,get_ctx)(u), &u->table,
|
||||
hash, &FN(UNION,has_domain_space_tuples),
|
||||
space, 0);
|
||||
if (!entry)
|
||||
return isl_stat_error;
|
||||
if (entry == isl_hash_table_entry_none)
|
||||
return isl_stat_ok;
|
||||
return fn(FN(PART,copy)(entry->data), user);
|
||||
}
|
||||
|
||||
static isl_stat FN(UNION,free_u_entry)(void **entry, void *user)
|
||||
{
|
||||
PART *part = *entry;
|
||||
|
23
polly/lib/External/isl/isl_union_templ.c
vendored
23
polly/lib/External/isl/isl_union_templ.c
vendored
@ -143,8 +143,6 @@ __isl_give PART *FN(FN(UNION,extract),BASE)(__isl_keep UNION *u,
|
||||
{
|
||||
struct isl_hash_table_entry *entry;
|
||||
|
||||
space = isl_space_replace_params(space, FN(UNION,peek_space)(u));
|
||||
|
||||
entry = FN(UNION,find_part_entry)(u, space, 0);
|
||||
if (!entry)
|
||||
goto error;
|
||||
@ -736,24 +734,15 @@ S(UNION,match_domain_data) {
|
||||
S(UNION,match_domain_control) *control;
|
||||
};
|
||||
|
||||
static isl_bool FN(UNION,set_has_space)(const void *entry, const void *val)
|
||||
{
|
||||
isl_set *set = (isl_set *)entry;
|
||||
isl_space *space = (isl_space *)val;
|
||||
|
||||
return isl_space_is_equal(set->dim, space);
|
||||
}
|
||||
|
||||
/* Find the set in data->uset that lives in the same space as the domain
|
||||
* of "part", apply data->fn to *entry and this set (if any), and add
|
||||
* the result to data->res.
|
||||
* of "part" (ignoring parameters), apply data->fn to *entry and this set
|
||||
* (if any), and add the result to data->res.
|
||||
*/
|
||||
static isl_stat FN(UNION,match_domain_entry)(__isl_take PART *part, void *user)
|
||||
{
|
||||
S(UNION,match_domain_data) *data = user;
|
||||
uint32_t hash;
|
||||
struct isl_hash_table_entry *entry2;
|
||||
isl_space *space, *uset_space;
|
||||
isl_space *space;
|
||||
|
||||
if (data->control->filter) {
|
||||
isl_bool pass = data->control->filter(part);
|
||||
@ -763,14 +752,10 @@ static isl_stat FN(UNION,match_domain_entry)(__isl_take PART *part, void *user)
|
||||
}
|
||||
}
|
||||
|
||||
uset_space = isl_union_set_peek_space(data->uset);
|
||||
space = FN(PART,get_domain_space)(part);
|
||||
if (data->control->match_space)
|
||||
space = data->control->match_space(space);
|
||||
space = isl_space_replace_params(space, uset_space);
|
||||
hash = isl_space_get_hash(space);
|
||||
entry2 = isl_hash_table_find(data->uset->dim->ctx, &data->uset->table,
|
||||
hash, &FN(UNION,set_has_space), space, 0);
|
||||
entry2 = isl_union_set_find_entry(data->uset, space, 0);
|
||||
isl_space_free(space);
|
||||
if (!entry2 || entry2 == isl_hash_table_entry_none) {
|
||||
FN(PART,free)(part);
|
||||
|
217
polly/lib/External/isl/ltmain.sh
vendored
217
polly/lib/External/isl/ltmain.sh
vendored
@ -31,7 +31,7 @@
|
||||
|
||||
PROGRAM=libtool
|
||||
PACKAGE=libtool
|
||||
VERSION="2.4.6 Debian-2.4.6-2"
|
||||
VERSION="2.4.6 Debian-2.4.6-14"
|
||||
package_revision=2.4.6
|
||||
|
||||
|
||||
@ -387,7 +387,7 @@ EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
|
||||
# putting '$debug_cmd' at the start of all your functions, you can get
|
||||
# bash to show function call trace with:
|
||||
#
|
||||
# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
|
||||
# debug_cmd='echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
|
||||
debug_cmd=${debug_cmd-":"}
|
||||
exit_cmd=:
|
||||
|
||||
@ -1370,7 +1370,7 @@ func_lt_ver ()
|
||||
#! /bin/sh
|
||||
|
||||
# Set a version string for this script.
|
||||
scriptversion=2014-01-07.03; # UTC
|
||||
scriptversion=2015-10-07.11; # UTC
|
||||
|
||||
# A portable, pluggable option parser for Bourne shell.
|
||||
# Written by Gary V. Vaughan, 2010
|
||||
@ -1530,6 +1530,8 @@ func_run_hooks ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_run_hooks=false
|
||||
|
||||
case " $hookable_fns " in
|
||||
*" $1 "*) ;;
|
||||
*) func_fatal_error "'$1' does not support hook funcions.n" ;;
|
||||
@ -1538,16 +1540,16 @@ func_run_hooks ()
|
||||
eval _G_hook_fns=\$$1_hooks; shift
|
||||
|
||||
for _G_hook in $_G_hook_fns; do
|
||||
eval $_G_hook '"$@"'
|
||||
|
||||
# store returned options list back into positional
|
||||
# parameters for next 'cmd' execution.
|
||||
eval _G_hook_result=\$${_G_hook}_result
|
||||
eval set dummy "$_G_hook_result"; shift
|
||||
if eval $_G_hook '"$@"'; then
|
||||
# store returned options list back into positional
|
||||
# parameters for next 'cmd' execution.
|
||||
eval _G_hook_result=\$${_G_hook}_result
|
||||
eval set dummy "$_G_hook_result"; shift
|
||||
_G_rc_run_hooks=:
|
||||
fi
|
||||
done
|
||||
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_run_hooks_result=$func_quote_for_eval_result
|
||||
$_G_rc_run_hooks && func_run_hooks_result=$_G_hook_result
|
||||
}
|
||||
|
||||
|
||||
@ -1557,10 +1559,16 @@ func_run_hooks ()
|
||||
## --------------- ##
|
||||
|
||||
# In order to add your own option parsing hooks, you must accept the
|
||||
# full positional parameter list in your hook function, remove any
|
||||
# options that you action, and then pass back the remaining unprocessed
|
||||
# full positional parameter list in your hook function, you may remove/edit
|
||||
# any options that you action, and then pass back the remaining unprocessed
|
||||
# options in '<hooked_function_name>_result', escaped suitably for
|
||||
# 'eval'. Like this:
|
||||
# 'eval'. In this case you also must return $EXIT_SUCCESS to let the
|
||||
# hook's caller know that it should pay attention to
|
||||
# '<hooked_function_name>_result'. Returning $EXIT_FAILURE signalizes that
|
||||
# arguments are left untouched by the hook and therefore caller will ignore the
|
||||
# result variable.
|
||||
#
|
||||
# Like this:
|
||||
#
|
||||
# my_options_prep ()
|
||||
# {
|
||||
@ -1570,9 +1578,11 @@ func_run_hooks ()
|
||||
# usage_message=$usage_message'
|
||||
# -s, --silent don'\''t print informational messages
|
||||
# '
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_options_prep_result=$func_quote_for_eval_result
|
||||
# # No change in '$@' (ignored completely by this hook). There is
|
||||
# # no need to do the equivalent (but slower) action:
|
||||
# # func_quote_for_eval ${1+"$@"}
|
||||
# # my_options_prep_result=$func_quote_for_eval_result
|
||||
# false
|
||||
# }
|
||||
# func_add_hook func_options_prep my_options_prep
|
||||
#
|
||||
@ -1581,25 +1591,37 @@ func_run_hooks ()
|
||||
# {
|
||||
# $debug_cmd
|
||||
#
|
||||
# args_changed=false
|
||||
#
|
||||
# # Note that for efficiency, we parse as many options as we can
|
||||
# # recognise in a loop before passing the remainder back to the
|
||||
# # caller on the first unrecognised argument we encounter.
|
||||
# while test $# -gt 0; do
|
||||
# opt=$1; shift
|
||||
# case $opt in
|
||||
# --silent|-s) opt_silent=: ;;
|
||||
# --silent|-s) opt_silent=:
|
||||
# args_changed=:
|
||||
# ;;
|
||||
# # Separate non-argument short options:
|
||||
# -s*) func_split_short_opt "$_G_opt"
|
||||
# set dummy "$func_split_short_opt_name" \
|
||||
# "-$func_split_short_opt_arg" ${1+"$@"}
|
||||
# shift
|
||||
# args_changed=:
|
||||
# ;;
|
||||
# *) set dummy "$_G_opt" "$*"; shift; break ;;
|
||||
# *) # Make sure the first unrecognised option "$_G_opt"
|
||||
# # is added back to "$@", we could need that later
|
||||
# # if $args_changed is true.
|
||||
# set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
# esac
|
||||
# done
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_silent_option_result=$func_quote_for_eval_result
|
||||
# if $args_changed; then
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_silent_option_result=$func_quote_for_eval_result
|
||||
# fi
|
||||
#
|
||||
# $args_changed
|
||||
# }
|
||||
# func_add_hook func_parse_options my_silent_option
|
||||
#
|
||||
@ -1611,16 +1633,32 @@ func_run_hooks ()
|
||||
# $opt_silent && $opt_verbose && func_fatal_help "\
|
||||
# '--silent' and '--verbose' options are mutually exclusive."
|
||||
#
|
||||
# func_quote_for_eval ${1+"$@"}
|
||||
# my_option_validation_result=$func_quote_for_eval_result
|
||||
# false
|
||||
# }
|
||||
# func_add_hook func_validate_options my_option_validation
|
||||
#
|
||||
# You'll alse need to manually amend $usage_message to reflect the extra
|
||||
# You'll also need to manually amend $usage_message to reflect the extra
|
||||
# options you parse. It's preferable to append if you can, so that
|
||||
# multiple option parsing hooks can be added safely.
|
||||
|
||||
|
||||
# func_options_finish [ARG]...
|
||||
# ----------------------------
|
||||
# Finishing the option parse loop (call 'func_options' hooks ATM).
|
||||
func_options_finish ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_func_options_finish_exit=false
|
||||
if func_run_hooks func_options ${1+"$@"}; then
|
||||
func_options_finish_result=$func_run_hooks_result
|
||||
_G_func_options_finish_exit=:
|
||||
fi
|
||||
|
||||
$_G_func_options_finish_exit
|
||||
}
|
||||
|
||||
|
||||
# func_options [ARG]...
|
||||
# ---------------------
|
||||
# All the functions called inside func_options are hookable. See the
|
||||
@ -1630,17 +1668,28 @@ func_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
func_options_prep ${1+"$@"}
|
||||
eval func_parse_options \
|
||||
${func_options_prep_result+"$func_options_prep_result"}
|
||||
eval func_validate_options \
|
||||
${func_parse_options_result+"$func_parse_options_result"}
|
||||
_G_rc_options=false
|
||||
|
||||
eval func_run_hooks func_options \
|
||||
${func_validate_options_result+"$func_validate_options_result"}
|
||||
for my_func in options_prep parse_options validate_options options_finish
|
||||
do
|
||||
if eval func_$my_func '${1+"$@"}'; then
|
||||
eval _G_res_var='$'"func_${my_func}_result"
|
||||
eval set dummy "$_G_res_var" ; shift
|
||||
_G_rc_options=:
|
||||
fi
|
||||
done
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_options_result=$func_run_hooks_result
|
||||
# Save modified positional parameters for caller. As a top-level
|
||||
# options-parser function we always need to set the 'func_options_result'
|
||||
# variable (regardless the $_G_rc_options value).
|
||||
if $_G_rc_options; then
|
||||
func_options_result=$_G_res_var
|
||||
else
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_options
|
||||
}
|
||||
|
||||
|
||||
@ -1649,9 +1698,9 @@ func_options ()
|
||||
# All initialisations required before starting the option parse loop.
|
||||
# Note that when calling hook functions, we pass through the list of
|
||||
# positional parameters. If a hook function modifies that list, and
|
||||
# needs to propogate that back to rest of this script, then the complete
|
||||
# needs to propagate that back to rest of this script, then the complete
|
||||
# modified list must be put in 'func_run_hooks_result' before
|
||||
# returning.
|
||||
# returning $EXIT_SUCCESS (otherwise $EXIT_FAILURE is returned).
|
||||
func_hookable func_options_prep
|
||||
func_options_prep ()
|
||||
{
|
||||
@ -1661,10 +1710,14 @@ func_options_prep ()
|
||||
opt_verbose=false
|
||||
opt_warning_types=
|
||||
|
||||
func_run_hooks func_options_prep ${1+"$@"}
|
||||
_G_rc_options_prep=false
|
||||
if func_run_hooks func_options_prep ${1+"$@"}; then
|
||||
_G_rc_options_prep=:
|
||||
# save modified positional parameters for caller
|
||||
func_options_prep_result=$func_run_hooks_result
|
||||
fi
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_options_prep_result=$func_run_hooks_result
|
||||
$_G_rc_options_prep
|
||||
}
|
||||
|
||||
|
||||
@ -1678,18 +1731,20 @@ func_parse_options ()
|
||||
|
||||
func_parse_options_result=
|
||||
|
||||
_G_rc_parse_options=false
|
||||
# this just eases exit handling
|
||||
while test $# -gt 0; do
|
||||
# Defer to hook functions for initial option parsing, so they
|
||||
# get priority in the event of reusing an option name.
|
||||
func_run_hooks func_parse_options ${1+"$@"}
|
||||
|
||||
# Adjust func_parse_options positional parameters to match
|
||||
eval set dummy "$func_run_hooks_result"; shift
|
||||
if func_run_hooks func_parse_options ${1+"$@"}; then
|
||||
eval set dummy "$func_run_hooks_result"; shift
|
||||
_G_rc_parse_options=:
|
||||
fi
|
||||
|
||||
# Break out of the loop if we already parsed every option.
|
||||
test $# -gt 0 || break
|
||||
|
||||
_G_match_parse_options=:
|
||||
_G_opt=$1
|
||||
shift
|
||||
case $_G_opt in
|
||||
@ -1704,7 +1759,10 @@ func_parse_options ()
|
||||
;;
|
||||
|
||||
--warnings|--warning|-W)
|
||||
test $# = 0 && func_missing_arg $_G_opt && break
|
||||
if test $# = 0 && func_missing_arg $_G_opt; then
|
||||
_G_rc_parse_options=:
|
||||
break
|
||||
fi
|
||||
case " $warning_categories $1" in
|
||||
*" $1 "*)
|
||||
# trailing space prevents matching last $1 above
|
||||
@ -1757,15 +1815,25 @@ func_parse_options ()
|
||||
shift
|
||||
;;
|
||||
|
||||
--) break ;;
|
||||
--) _G_rc_parse_options=: ; break ;;
|
||||
-*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift
|
||||
_G_match_parse_options=false
|
||||
break
|
||||
;;
|
||||
esac
|
||||
|
||||
$_G_match_parse_options && _G_rc_parse_options=:
|
||||
done
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_parse_options_result=$func_quote_for_eval_result
|
||||
|
||||
if $_G_rc_parse_options; then
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
func_parse_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_parse_options
|
||||
}
|
||||
|
||||
|
||||
@ -1778,16 +1846,21 @@ func_validate_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_validate_options=false
|
||||
|
||||
# Display all warnings if -W was not given.
|
||||
test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
|
||||
|
||||
func_run_hooks func_validate_options ${1+"$@"}
|
||||
if func_run_hooks func_validate_options ${1+"$@"}; then
|
||||
# save modified positional parameters for caller
|
||||
func_validate_options_result=$func_run_hooks_result
|
||||
_G_rc_validate_options=:
|
||||
fi
|
||||
|
||||
# Bail if the options were screwed!
|
||||
$exit_cmd $EXIT_FAILURE
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_validate_options_result=$func_run_hooks_result
|
||||
$_G_rc_validate_options
|
||||
}
|
||||
|
||||
|
||||
@ -2068,7 +2141,7 @@ include the following information:
|
||||
compiler: $LTCC
|
||||
compiler flags: $LTCFLAGS
|
||||
linker: $LD (gnu? $with_gnu_ld)
|
||||
version: $progname $scriptversion Debian-2.4.6-2
|
||||
version: $progname $scriptversion Debian-2.4.6-14
|
||||
automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
|
||||
autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
|
||||
|
||||
@ -2270,6 +2343,8 @@ libtool_options_prep ()
|
||||
nonopt=
|
||||
preserve_args=
|
||||
|
||||
_G_rc_lt_options_prep=:
|
||||
|
||||
# Shorthand for --mode=foo, only valid as the first argument
|
||||
case $1 in
|
||||
clean|clea|cle|cl)
|
||||
@ -2293,11 +2368,18 @@ libtool_options_prep ()
|
||||
uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
|
||||
shift; set dummy --mode uninstall ${1+"$@"}; shift
|
||||
;;
|
||||
*)
|
||||
_G_rc_lt_options_prep=false
|
||||
;;
|
||||
esac
|
||||
|
||||
# Pass back the list of options.
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_options_prep_result=$func_quote_for_eval_result
|
||||
if $_G_rc_lt_options_prep; then
|
||||
# Pass back the list of options.
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_options_prep_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
$_G_rc_lt_options_prep
|
||||
}
|
||||
func_add_hook func_options_prep libtool_options_prep
|
||||
|
||||
@ -2309,9 +2391,12 @@ libtool_parse_options ()
|
||||
{
|
||||
$debug_cmd
|
||||
|
||||
_G_rc_lt_parse_options=false
|
||||
|
||||
# Perform our own loop to consume as many options as possible in
|
||||
# each iteration.
|
||||
while test $# -gt 0; do
|
||||
_G_match_lt_parse_options=:
|
||||
_G_opt=$1
|
||||
shift
|
||||
case $_G_opt in
|
||||
@ -2386,15 +2471,22 @@ libtool_parse_options ()
|
||||
func_append preserve_args " $_G_opt"
|
||||
;;
|
||||
|
||||
# An option not handled by this hook function:
|
||||
*) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
|
||||
# An option not handled by this hook function:
|
||||
*) set dummy "$_G_opt" ${1+"$@"} ; shift
|
||||
_G_match_lt_parse_options=false
|
||||
break
|
||||
;;
|
||||
esac
|
||||
$_G_match_lt_parse_options && _G_rc_lt_parse_options=:
|
||||
done
|
||||
|
||||
if $_G_rc_lt_parse_options; then
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_parse_options_result=$func_quote_for_eval_result
|
||||
fi
|
||||
|
||||
# save modified positional parameters for caller
|
||||
func_quote_for_eval ${1+"$@"}
|
||||
libtool_parse_options_result=$func_quote_for_eval_result
|
||||
$_G_rc_lt_parse_options
|
||||
}
|
||||
func_add_hook func_parse_options libtool_parse_options
|
||||
|
||||
@ -7275,10 +7367,13 @@ func_mode_link ()
|
||||
# -specs=* GCC specs files
|
||||
# -stdlib=* select c++ std lib with clang
|
||||
# -fsanitize=* Clang/GCC memory and address sanitizer
|
||||
# -fuse-ld=* Linker select flags for GCC
|
||||
# -static-* direct GCC to link specific libraries statically
|
||||
# -fcilkplus Cilk Plus language extension features for C/C++
|
||||
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
|
||||
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
|
||||
-O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
|
||||
-specs=*|-fsanitize=*)
|
||||
-specs=*|-fsanitize=*|-fuse-ld=*|-static-*|-fcilkplus)
|
||||
func_quote_for_eval "$arg"
|
||||
arg=$func_quote_for_eval_result
|
||||
func_append compile_command " $arg"
|
||||
|
27
polly/lib/External/isl/m4/libtool.m4
vendored
27
polly/lib/External/isl/m4/libtool.m4
vendored
@ -1041,8 +1041,8 @@ int forced_loaded() { return 2;}
|
||||
_LT_EOF
|
||||
echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD
|
||||
$LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD
|
||||
echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD
|
||||
$AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD
|
||||
echo "$AR cr libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD
|
||||
$AR cr libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD
|
||||
echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD
|
||||
$RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD
|
||||
cat > conftest.c << _LT_EOF
|
||||
@ -1492,7 +1492,7 @@ need_locks=$enable_libtool_lock
|
||||
m4_defun([_LT_PROG_AR],
|
||||
[AC_CHECK_TOOLS(AR, [ar], false)
|
||||
: ${AR=ar}
|
||||
: ${AR_FLAGS=cru}
|
||||
: ${AR_FLAGS=cr}
|
||||
_LT_DECL([], [AR], [1], [The archiver])
|
||||
_LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive])
|
||||
|
||||
@ -4063,7 +4063,8 @@ _LT_EOF
|
||||
if AC_TRY_EVAL(ac_compile); then
|
||||
# Now try to grab the symbols.
|
||||
nlist=conftest.nm
|
||||
if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then
|
||||
$ECHO "$as_me:$LINENO: $NM conftest.$ac_objext | $lt_cv_sys_global_symbol_pipe > $nlist" >&AS_MESSAGE_LOG_FD
|
||||
if eval "$NM" conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist 2>&AS_MESSAGE_LOG_FD && test -s "$nlist"; then
|
||||
# Try sorting and uniquifying the output.
|
||||
if sort "$nlist" | uniq > "$nlist"T; then
|
||||
mv -f "$nlist"T "$nlist"
|
||||
@ -4703,6 +4704,12 @@ m4_if([$1], [CXX], [
|
||||
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
|
||||
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
|
||||
;;
|
||||
# flang / f18. f95 an alias for gfortran or flang on Debian
|
||||
flang* | f18* | f95*)
|
||||
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
|
||||
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
|
||||
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
|
||||
;;
|
||||
# icc used to be incompatible with GCC.
|
||||
# ICC 10 doesn't accept -KPIC any more.
|
||||
icc* | ifort*)
|
||||
@ -6438,7 +6445,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
GXX=no
|
||||
@ -6813,7 +6820,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -6878,7 +6885,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# explicitly linking system object files so we need to strip them
|
||||
# from the output so that they don't get included in the library
|
||||
# dependencies.
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP " \-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
|
||||
;;
|
||||
*)
|
||||
if test yes = "$GXX"; then
|
||||
@ -7217,7 +7224,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
|
||||
else
|
||||
# FIXME: insert proper C++ library support
|
||||
@ -7301,7 +7308,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
else
|
||||
# g++ 2.7 appears to require '-G' NOT '-shared' on this
|
||||
# platform.
|
||||
@ -7312,7 +7319,7 @@ if test yes != "$_lt_caught_CXX_error"; then
|
||||
# Commands to make compiler produce verbose output that lists
|
||||
# what "hidden" libraries, object files and flags are used when
|
||||
# linking a shared library.
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
|
||||
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP " \-L"'
|
||||
fi
|
||||
|
||||
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir'
|
||||
|
16
polly/lib/External/isl/missing
vendored
16
polly/lib/External/isl/missing
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# Common wrapper for a few potentially missing GNU programs.
|
||||
|
||||
scriptversion=2013-10-28.13; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 1996-2014 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1996-2018 Free Software Foundation, Inc.
|
||||
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
@ -17,7 +17,7 @@ scriptversion=2013-10-28.13; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -101,9 +101,9 @@ else
|
||||
exit $st
|
||||
fi
|
||||
|
||||
perl_URL=http://www.perl.org/
|
||||
flex_URL=http://flex.sourceforge.net/
|
||||
gnu_software_URL=http://www.gnu.org/software
|
||||
perl_URL=https://www.perl.org/
|
||||
flex_URL=https://github.com/westes/flex
|
||||
gnu_software_URL=https://www.gnu.org/software
|
||||
|
||||
program_details ()
|
||||
{
|
||||
@ -207,9 +207,9 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \
|
||||
exit $st
|
||||
|
||||
# Local variables:
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
8
polly/lib/External/isl/py-compile
vendored
8
polly/lib/External/isl/py-compile
vendored
@ -1,9 +1,9 @@
|
||||
#!/bin/sh
|
||||
# py-compile - Compile a Python program
|
||||
|
||||
scriptversion=2016-01-11.22; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 2000-2017 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2000-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -162,7 +162,7 @@ sys.stdout.write('\n')" 2>/dev/null || :
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
|
10
polly/lib/External/isl/test-driver
vendored
10
polly/lib/External/isl/test-driver
vendored
@ -1,9 +1,9 @@
|
||||
#! /bin/sh
|
||||
# test-driver - basic testsuite driver script.
|
||||
|
||||
scriptversion=2013-07-13.22; # UTC
|
||||
scriptversion=2018-03-07.03; # UTC
|
||||
|
||||
# Copyright (C) 2011-2014 Free Software Foundation, Inc.
|
||||
# Copyright (C) 2011-2018 Free Software Foundation, Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@ -16,7 +16,7 @@ scriptversion=2013-07-13.22; # UTC
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@ -140,9 +140,9 @@ echo ":copy-in-global-log: $gcopy" >> $trs_file
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
# time-stamp-time-zone: "UTC"
|
||||
# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
|
@ -1,9 +1,9 @@
|
||||
if (m >= 1) {
|
||||
S1(0, 1, 1, 1);
|
||||
if (m >= 2) {
|
||||
S2(0, 1, 1, 1, 1, 1, 2, 1);
|
||||
S3(0, 1, 1, 2, 1, 1, 1, 2);
|
||||
S4(0, 1, 2, 2, 1, 1, 2, 2);
|
||||
S3(0, 1, 1, 2, 1, 1, 1, 2);
|
||||
S2(0, 1, 1, 1, 1, 1, 2, 1);
|
||||
}
|
||||
S8(0, 1);
|
||||
for (int c0 = 1; c0 < 2 * m - 1; c0 += 1) {
|
||||
@ -12,45 +12,45 @@ if (m >= 1) {
|
||||
S5(m - 2, 1, m - 1, 1, m - 1, 1, m, 1);
|
||||
S1(m - 1, 1, m, 1);
|
||||
S3(m - 1, 1, m, 2, m, 1, m, 2);
|
||||
} else if (m >= c0 + 2) {
|
||||
S5(c0 - 1, 1, c0, 1, c0, 1, c0 + 1, 1);
|
||||
S1(c0, 1, c0 + 1, 1);
|
||||
S2(c0, 1, c0 + 1, 1, c0 + 1, 1, c0 + 2, 1);
|
||||
S4(c0, 1, c0 + 2, 2, c0 + 1, 1, c0 + 2, 2);
|
||||
S3(c0, 1, c0 + 1, 2, c0 + 1, 1, c0 + 1, 2);
|
||||
} else {
|
||||
} else if (c0 >= m) {
|
||||
S5(c0 - 1, -m + c0 + 2, c0, -m + c0 + 2, m - 1, -m + c0 + 2, m, -m + c0 + 2);
|
||||
S6(c0 - 1, -m + c0 + 1, c0, -m + c0 + 2, m, -m + c0 + 1, m, -m + c0 + 2);
|
||||
S1(c0, -m + c0 + 2, m, -m + c0 + 2);
|
||||
S3(c0, -m + c0 + 2, c0 + 1, -m + c0 + 3, m, -m + c0 + 2, m, -m + c0 + 3);
|
||||
} else {
|
||||
S5(c0 - 1, 1, c0, 1, c0, 1, c0 + 1, 1);
|
||||
S1(c0, 1, c0 + 1, 1);
|
||||
S3(c0, 1, c0 + 1, 2, c0 + 1, 1, c0 + 1, 2);
|
||||
S4(c0, 1, c0 + 2, 2, c0 + 1, 1, c0 + 2, 2);
|
||||
S2(c0, 1, c0 + 1, 1, c0 + 1, 1, c0 + 2, 1);
|
||||
}
|
||||
for (int c1 = max(2, -m + c0 + 3); c1 <= min(m - 1, c0); c1 += 1) {
|
||||
S5(c0 - 1, c1, c0, c1, c0 - c1 + 1, c1, c0 - c1 + 2, c1);
|
||||
S7(c0 - 1, c1 - 1, c0 + 1, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 3, c1);
|
||||
S6(c0 - 1, c1 - 1, c0, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 2, c1);
|
||||
S7(c0 - 1, c1 - 1, c0 + 1, c1, c0 - c1 + 2, c1 - 1, c0 - c1 + 3, c1);
|
||||
S1(c0, c1, c0 - c1 + 2, c1);
|
||||
S2(c0, c1, c0 + 1, c1, c0 - c1 + 2, c1, c0 - c1 + 3, c1);
|
||||
S4(c0, c1, c0 + 2, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 3, c1 + 1);
|
||||
S3(c0, c1, c0 + 1, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 2, c1 + 1);
|
||||
S4(c0, c1, c0 + 2, c1 + 1, c0 - c1 + 2, c1, c0 - c1 + 3, c1 + 1);
|
||||
S2(c0, c1, c0 + 1, c1, c0 - c1 + 2, c1, c0 - c1 + 3, c1);
|
||||
}
|
||||
if (c0 + 1 == m) {
|
||||
S7(m - 2, m - 1, m, m, 1, m - 1, 2, m);
|
||||
S6(m - 2, m - 1, m - 1, m, 1, m - 1, 1, m);
|
||||
S7(m - 2, m - 1, m, m, 1, m - 1, 2, m);
|
||||
S1(m - 1, m, 1, m);
|
||||
S2(m - 1, m, m, m, 1, m, 2, m);
|
||||
} else if (m >= c0 + 2) {
|
||||
} else if (c0 >= m) {
|
||||
S5(c0 - 1, m, c0, m, -m + c0 + 1, m, -m + c0 + 2, m);
|
||||
S6(c0 - 1, m - 1, c0, m, -m + c0 + 2, m - 1, -m + c0 + 2, m);
|
||||
S7(c0 - 1, m - 1, c0 + 1, m, -m + c0 + 2, m - 1, -m + c0 + 3, m);
|
||||
S1(c0, m, -m + c0 + 2, m);
|
||||
S2(c0, m, c0 + 1, m, -m + c0 + 2, m, -m + c0 + 3, m);
|
||||
} else {
|
||||
S6(c0 - 1, c0, c0, c0 + 1, 1, c0, 1, c0 + 1);
|
||||
S7(c0 - 1, c0, c0 + 1, c0 + 1, 1, c0, 2, c0 + 1);
|
||||
S1(c0, c0 + 1, 1, c0 + 1);
|
||||
S2(c0, c0 + 1, c0 + 1, c0 + 1, 1, c0 + 1, 2, c0 + 1);
|
||||
S4(c0, c0 + 1, c0 + 2, c0 + 2, 1, c0 + 1, 2, c0 + 2);
|
||||
S3(c0, c0 + 1, c0 + 1, c0 + 2, 1, c0 + 1, 1, c0 + 2);
|
||||
} else {
|
||||
S5(c0 - 1, m, c0, m, -m + c0 + 1, m, -m + c0 + 2, m);
|
||||
S7(c0 - 1, m - 1, c0 + 1, m, -m + c0 + 2, m - 1, -m + c0 + 3, m);
|
||||
S6(c0 - 1, m - 1, c0, m, -m + c0 + 2, m - 1, -m + c0 + 2, m);
|
||||
S1(c0, m, -m + c0 + 2, m);
|
||||
S2(c0, m, c0 + 1, m, -m + c0 + 2, m, -m + c0 + 3, m);
|
||||
S4(c0, c0 + 1, c0 + 2, c0 + 2, 1, c0 + 1, 2, c0 + 2);
|
||||
S2(c0, c0 + 1, c0 + 1, c0 + 1, 1, c0 + 1, 2, c0 + 1);
|
||||
}
|
||||
} else {
|
||||
S5(2 * m - 3, m, 2 * m - 2, m, m - 1, m, m, m);
|
||||
|
@ -2,6 +2,8 @@ for (int c0 = 0; c0 <= min(min(T_2 - 1, T_67 - 1), T_66); c0 += 1) {
|
||||
S1(c0);
|
||||
S2(c0);
|
||||
}
|
||||
for (int c0 = T_2; c0 <= min(T_67 - 1, T_66); c0 += 1)
|
||||
S2(c0);
|
||||
for (int c0 = max(0, T_66 + 1); c0 < min(T_2, T_67); c0 += 1)
|
||||
S1(c0);
|
||||
for (int c0 = T_67; c0 <= min(T_2 - 1, T_66); c0 += 1) {
|
||||
@ -10,7 +12,5 @@ for (int c0 = T_67; c0 <= min(T_2 - 1, T_66); c0 += 1) {
|
||||
}
|
||||
for (int c0 = max(T_67, T_66 + 1); c0 < T_2; c0 += 1)
|
||||
S1(c0);
|
||||
for (int c0 = T_2; c0 <= min(T_67 - 1, T_66); c0 += 1)
|
||||
S2(c0);
|
||||
if (T_2 == 0 && T_67 == 0)
|
||||
S1(0);
|
||||
|
@ -3,8 +3,8 @@ for (int c0 = 1; c0 <= min(M, N); c0 += 1) {
|
||||
for (int c1 = 1; c1 <= M; c1 += 1)
|
||||
S2(c0, c1);
|
||||
}
|
||||
for (int c0 = N + 1; c0 <= M; c0 += 1)
|
||||
S1(c0);
|
||||
for (int c0 = M + 1; c0 <= N; c0 += 1)
|
||||
for (int c1 = 1; c1 <= M; c1 += 1)
|
||||
S2(c0, c1);
|
||||
for (int c0 = N + 1; c0 <= M; c0 += 1)
|
||||
S1(c0);
|
||||
|
@ -36,18 +36,16 @@ for (int c0 = 0; c0 <= 36; c0 += 1) {
|
||||
for (int c1 = 1; c1 <= 18; c1 += 1) {
|
||||
for (int c2 = -8 * c1; c2 <= min(6, -8 * c1 + 24); c2 += 1)
|
||||
S3(c0, c1, c2);
|
||||
if (c1 == 2) {
|
||||
S3(c0, 2, 7);
|
||||
} else if (c0 <= 34 && c1 == 1) {
|
||||
if (c0 <= 34 && c1 == 1) {
|
||||
S3(c0, 1, 7);
|
||||
} else if (c1 == 2) {
|
||||
S3(c0, 2, 7);
|
||||
} else if (c0 >= 35 && c1 == 1) {
|
||||
S3(c0, 1, 7);
|
||||
S7(c0, 1, 7);
|
||||
}
|
||||
for (int c2 = 8; c2 <= min(-8 * c1 + 24, c1 - (6 * c0 + 77) / 77 + 12); c2 += 1)
|
||||
S3(c0, c1, c2);
|
||||
for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1)
|
||||
S6(c0, c1, c2);
|
||||
if (c1 == 1) {
|
||||
for (int c2 = -((6 * c0 + 77) / 77) + 14; c2 <= 13; c2 += 1) {
|
||||
S3(c0, 1, c2);
|
||||
@ -56,6 +54,8 @@ for (int c0 = 0; c0 <= 36; c0 += 1) {
|
||||
for (int c2 = 14; c2 <= 16; c2 += 1)
|
||||
S3(c0, 1, c2);
|
||||
}
|
||||
for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1)
|
||||
S6(c0, c1, c2);
|
||||
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1)
|
||||
S1(c0, c1, c2);
|
||||
}
|
||||
@ -77,14 +77,6 @@ for (int c0 = 37; c0 <= 218; c0 += 1) {
|
||||
for (int c2 = -2 * c1 + 30; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
|
||||
S1(c0, c1, c2);
|
||||
}
|
||||
for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
|
||||
if (7 * c1 + 114 >= 2 * c0)
|
||||
S7(c0, c1, 6);
|
||||
for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
|
||||
S6(c0, c1, c2);
|
||||
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
|
||||
S1(c0, c1, c2);
|
||||
}
|
||||
if (c0 <= 148)
|
||||
for (int c1 = max(0, (c0 + 5) / 14 - 8); c1 < c0 / 14 - 5; c1 += 1) {
|
||||
if (c1 == 0)
|
||||
@ -95,6 +87,14 @@ for (int c0 = 37; c0 <= 218; c0 += 1) {
|
||||
if (c0 >= 70 && c0 % 14 >= 9)
|
||||
for (int c2 = max((c0 + 5) / 14 + 18, -((3 * c0 + 14) / 14) + c0 / 14 + 44); c2 <= -((3 * c0 + 17) / 14) + c0 / 14 + 51; c2 += 1)
|
||||
S1(c0, c0 / 14 - 5, c2);
|
||||
for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
|
||||
if (7 * c1 + 114 >= 2 * c0)
|
||||
S7(c0, c1, 6);
|
||||
for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
|
||||
S6(c0, c1, c2);
|
||||
for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
|
||||
S1(c0, c1, c2);
|
||||
}
|
||||
for (int c1 = max(0, (c0 + 5) / 14 - 5); c1 < c0 / 14 - 2; c1 += 1) {
|
||||
for (int c2 = max(c1, -2 * c1 + 6); c2 <= min(c1 + 5, -2 * c1 + 24); c2 += 1)
|
||||
S9(c0, c1, c2);
|
||||
|
@ -4,10 +4,10 @@ for (int c0 = N + 1; c0 <= 2 * N; c0 += 1)
|
||||
for (int c1 = 1; c1 <= N; c1 += 1)
|
||||
S2(c1, -N + c0);
|
||||
for (int c0 = 2 * N + 1; c0 <= M + N; c0 += 1) {
|
||||
for (int c1 = 1; c1 <= N; c1 += 1)
|
||||
S2(c1, -N + c0);
|
||||
for (int c1 = 1; c1 <= N; c1 += 1)
|
||||
S3(c1, -2 * N + c0);
|
||||
for (int c1 = 1; c1 <= N; c1 += 1)
|
||||
S2(c1, -N + c0);
|
||||
}
|
||||
for (int c0 = M + N + 1; c0 <= M + 2 * N; c0 += 1)
|
||||
for (int c1 = 1; c1 <= N; c1 += 1)
|
||||
|
@ -1,8 +1,8 @@
|
||||
for (int c0 = M + 1; c0 <= 2 * M; c0 += 1)
|
||||
S1(-M + c0);
|
||||
for (int c0 = 2 * M + 1; c0 <= M + N; c0 += 1) {
|
||||
S2(-2 * M + c0);
|
||||
S1(-M + c0);
|
||||
S2(-2 * M + c0);
|
||||
}
|
||||
for (int c0 = M + N + 1; c0 <= 2 * M + N; c0 += 1)
|
||||
S2(-2 * M + c0);
|
||||
|
@ -3,8 +3,8 @@ for (int c0 = 0; c0 <= M; c0 += 1) {
|
||||
S1(c0, c1);
|
||||
S2(c0, c1);
|
||||
}
|
||||
for (int c1 = c0 + 1; c1 <= N; c1 += 1)
|
||||
S2(c0, c1);
|
||||
for (int c1 = max(0, N + 1); c1 <= c0; c1 += 1)
|
||||
S1(c0, c1);
|
||||
for (int c1 = c0 + 1; c1 <= N; c1 += 1)
|
||||
S2(c0, c1);
|
||||
}
|
||||
|
@ -1,18 +1,18 @@
|
||||
if (M >= 0 && N >= 0)
|
||||
for (int c0 = -4; c0 <= 3 * M + N; c0 += 1) {
|
||||
if (c0 >= 3 * M) {
|
||||
S2(M, -3 * M + c0);
|
||||
} else if (3 * M >= c0 + 4 && (c0 + 1) % 3 == 0) {
|
||||
if (3 * M >= c0 + 4 && (c0 + 1) % 3 == 0) {
|
||||
S1((c0 + 4) / 3, 0);
|
||||
} else if (c0 >= 3 * M) {
|
||||
S2(M, -3 * M + c0);
|
||||
}
|
||||
for (int c1 = max(-3 * M + c0 + 3, (c0 + 6) % 3); c1 <= min(N - 1, c0); c1 += 3) {
|
||||
S2((c0 - c1) / 3, c1);
|
||||
S1(((c0 - c1) / 3) + 1, c1 + 1);
|
||||
}
|
||||
if (3 * M + N >= c0 + 3 && c0 >= N && (N - c0) % 3 == 0) {
|
||||
S2((-N + c0) / 3, N);
|
||||
} else if (N >= c0 + 4 && c0 >= -3) {
|
||||
if (N >= c0 + 4 && c0 >= -3) {
|
||||
S1(0, c0 + 4);
|
||||
} else if (3 * M + N >= c0 + 3 && c0 >= N && (N - c0) % 3 == 0) {
|
||||
S2((-N + c0) / 3, N);
|
||||
}
|
||||
for (int c1 = max(-3 * M + c0, (c0 + 6) % 3); c1 <= min(N, c0); c1 += 3)
|
||||
S3((c0 - c1) / 3, c1);
|
||||
|
@ -4,12 +4,12 @@ for (int c0 = 1; c0 <= 2; c0 += 1)
|
||||
for (int c0 = 3; c0 <= N; c0 += 1) {
|
||||
for (int c1 = 1; c1 <= min(M, c0 - 1); c1 += 1)
|
||||
S1(c0, c1);
|
||||
if (c0 >= M + 1) {
|
||||
S2(c0, c0);
|
||||
} else {
|
||||
if (M >= c0) {
|
||||
S1(c0, c0);
|
||||
S2(c0, c0);
|
||||
}
|
||||
for (int c1 = c0 + 1; c1 <= M; c1 += 1)
|
||||
S1(c0, c1);
|
||||
if (c0 >= M + 1)
|
||||
S2(c0, c0);
|
||||
}
|
||||
|
@ -14,8 +14,8 @@ for (int c0 = 2; c0 <= min(2 * n, n + 29); c0 += 1) {
|
||||
}
|
||||
}
|
||||
for (int c1 = -c0 + c0 / 2 + 3; c1 <= min(-1, n - c0); c1 += 1) {
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
S4(-c1, c0 + c1);
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
for (int c2 = 1; c2 <= -c1; c2 += 1)
|
||||
S5(-c1 + 1, c0 + c1 - 1, c2);
|
||||
}
|
||||
@ -24,23 +24,22 @@ for (int c0 = 2; c0 <= min(2 * n, n + 29); c0 += 1) {
|
||||
for (int c2 = 1; c2 < -n + c0; c2 += 1)
|
||||
S5(-n + c0, n, c2);
|
||||
}
|
||||
if (n >= 3 && c0 == n + 2) {
|
||||
S1(n + 1);
|
||||
S6(2, n);
|
||||
if (c0 >= n + 3 && 2 * n >= c0 + 1)
|
||||
S6(-n + c0, n);
|
||||
if (c0 >= n + 3) {
|
||||
S1(c0 - 1);
|
||||
} else {
|
||||
if (c0 >= n + 3 && 2 * n >= c0 + 1)
|
||||
S6(-n + c0, n);
|
||||
if (c0 >= n + 3) {
|
||||
if (n + 1 >= c0 && c0 <= 4) {
|
||||
S1(c0 - 1);
|
||||
} else {
|
||||
if (n + 1 >= c0 && c0 <= 4) {
|
||||
S1(c0 - 1);
|
||||
} else if (c0 >= 5 && n + 1 >= c0) {
|
||||
S1(c0 - 1);
|
||||
S6(2, c0 - 2);
|
||||
}
|
||||
if (n + 1 >= c0)
|
||||
S6(1, c0 - 1);
|
||||
} else if (c0 >= 5 && n + 1 >= c0) {
|
||||
S1(c0 - 1);
|
||||
S6(2, c0 - 2);
|
||||
}
|
||||
if (n + 1 >= c0) {
|
||||
S6(1, c0 - 1);
|
||||
} else if (n >= 3) {
|
||||
S1(n + 1);
|
||||
S6(2, n);
|
||||
}
|
||||
}
|
||||
if (n == 2 && c0 == 4)
|
||||
@ -67,8 +66,8 @@ for (int c0 = n + 30; c0 <= 2 * n; c0 += 1) {
|
||||
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
|
||||
}
|
||||
for (int c1 = -c0 + c0 / 2 + 3; c1 <= n - c0; c1 += 1) {
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
S4(-c1, c0 + c1);
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
for (int c2 = 1; c2 <= -c1; c2 += 1)
|
||||
S5(-c1 + 1, c0 + c1 - 1, c2);
|
||||
}
|
||||
|
@ -3,14 +3,19 @@ for (int c0 = -27 * n + 2; c0 <= 1; c0 += 1)
|
||||
for (int c0 = 2; c0 <= n + 29; c0 += 1) {
|
||||
if (c0 >= 3) {
|
||||
S4(c0 - c0 / 2 - 1, c0 / 2 + 1);
|
||||
if (c0 >= 5 && 2 * n >= c0 + 3) {
|
||||
if (c0 <= 4) {
|
||||
S1(c0 - 1);
|
||||
} else if (c0 + 2 >= 2 * n) {
|
||||
for (int c2 = 1; c2 < -n + c0; c2 += 1)
|
||||
S5(-n + c0, n, c2);
|
||||
} else {
|
||||
S4(c0 - c0 / 2 - 2, c0 / 2 + 2);
|
||||
for (int c2 = 1; c2 < c0 - c0 / 2 - 1; c2 += 1)
|
||||
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
|
||||
}
|
||||
for (int c1 = -c0 + c0 / 2 + 3; c1 <= min(-1, n - c0); c1 += 1) {
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
S4(-c1, c0 + c1);
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
for (int c2 = 1; c2 <= -c1; c2 += 1)
|
||||
S5(-c1 + 1, c0 + c1 - 1, c2);
|
||||
}
|
||||
@ -18,26 +23,19 @@ for (int c0 = 2; c0 <= n + 29; c0 += 1) {
|
||||
S6(-n + c0 + 1, n - 1);
|
||||
for (int c2 = 1; c2 < -n + c0; c2 += 1)
|
||||
S5(-n + c0, n, c2);
|
||||
if (c0 == n + 2) {
|
||||
S1(n + 1);
|
||||
S6(2, n);
|
||||
}
|
||||
} else if (c0 + 2 >= 2 * n) {
|
||||
for (int c2 = 1; c2 < -n + c0; c2 += 1)
|
||||
S5(-n + c0, n, c2);
|
||||
}
|
||||
if (c0 >= n + 3) {
|
||||
S6(-n + c0, n);
|
||||
S1(c0 - 1);
|
||||
} else if (c0 == n + 2) {
|
||||
S1(n + 1);
|
||||
S6(2, n);
|
||||
} else {
|
||||
if (c0 >= 5 && n + 1 >= c0) {
|
||||
if (c0 >= 5) {
|
||||
S1(c0 - 1);
|
||||
S6(2, c0 - 2);
|
||||
} else if (c0 <= 4) {
|
||||
S1(c0 - 1);
|
||||
}
|
||||
if (n + 1 >= c0)
|
||||
S6(1, c0 - 1);
|
||||
S6(1, c0 - 1);
|
||||
}
|
||||
} else {
|
||||
S1(1);
|
||||
@ -59,8 +57,8 @@ for (int c0 = n + 30; c0 <= 2 * n; c0 += 1) {
|
||||
S5(c0 - c0 / 2 - 1, c0 / 2 + 1, c2);
|
||||
}
|
||||
for (int c1 = -c0 + c0 / 2 + 3; c1 <= n - c0; c1 += 1) {
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
S4(-c1, c0 + c1);
|
||||
S6(-c1 + 2, c0 + c1 - 2);
|
||||
for (int c2 = 1; c2 <= -c1; c2 += 1)
|
||||
S5(-c1 + 1, c0 + c1 - 1, c2);
|
||||
}
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user