forked from ydmao/Metis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfigure.ac
117 lines (98 loc) · 4.34 KB
/
configure.ac
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
dnl Process this file with autoconf to produce a configure script
AC_INIT([metis], [0.1])
AC_PREREQ(2.60)
AC_CONFIG_HEADERS([config.h])
AC_CONFIG_FILES([GNUmakefile])
AC_SUBST(ac_configure_args)
dnl Memory allocator
AC_CHECK_LIB([flow], [malloc], [have_flow=true], [have_flow=])
AC_CHECK_LIB([jemalloc], [malloc], [have_jemalloc=true], [have_jemalloc=])
AC_ARG_WITH([malloc],
[AS_HELP_STRING([--with-malloc=TYPE], [Memory allocator (malloc|flow|jemalloc)])],
[ac_cv_malloc=$withval], [ac_cv_malloc=yes])
if test \( "$ac_cv_malloc" = flow -a -z "$have_flow" \) -o \
\( "$ac_cv_malloc" = jemalloc -a -z "$have_jemalloc" \) ; then
AC_MSG_ERROR([$ac_cv_malloc not found])
fi
if test "$ac_cv_malloc" = yes ; then
MEM_ALLOCATOR=
else
MEM_ALLOCATOR=-l$ac_cv_malloc
fi
AC_SUBST([MEM_ALLOCATOR])
dnl map data structure. Configurable if not forced to use append according to metis mode
AC_ARG_ENABLE([map-ds],
[AS_HELP_STRING([--enable-map-ds=ARG],
[default data structure for map phase: btree, array, append.
default: btree])],
[ac_cv_map_ds=$enableval], [ac_cv_map_ds=btree])
dnl Configure metis mode. With single_XXX, Metis uses one bucket per mapper during map phase,
dnl sorts the output of the map phase using PSRS, then reduce the output. Grouping may
dnl happen before or after the PSRS.
ac_cv_all_modes="metis single_btree single_append-group_first single_append-merge_first"
AC_ARG_ENABLE([mode],
[AS_HELP_STRING([--enable-mode=ARG],
[mode: $ac_cv_all_modes, default: metis])],
[ac_cv_mode=$enableval], [ac_cv_mode=metis])
ac_cv_map_merge_reduce=false
if test "$ac_cv_mode" = single_btree ; then
dnl grouped-map -> Merge -> Reduce
ac_cv_map_merge_reduce=true
ac_cv_map_ds=btree
elif test "$ac_cv_mode" = single_append-group_first ; then
AC_DEFINE_UNQUOTED([SINGLE_APPEND_GROUP_FIRST], [1],
[Define to (Append-map -> Group) -> (psrs-merge, and-reduce)])
ac_cv_map_merge_reduce=true
ac_cv_map_ds=append
elif test "$ac_cv_mode" = single_append-merge_first ; then
dnl Define to (Append-map) -> (psrs-merge, and Group-and-Reduce)]
ac_cv_map_merge_reduce=true
ac_cv_map_ds=append
fi
ac_cv_force_psrs=$ac_cv_map_merge_reduce
if test "$ac_cv_map_merge_reduce" = true; then
AC_DEFINE_UNQUOTED([MAP_MERGE_REDUCE], [1], [map -> merge -> reduce])
fi
ac_cv_map_ds=index_$ac_cv_map_ds
AC_DEFINE_UNQUOTED([DEFAULT_MAP_DS], [$ac_cv_map_ds], [Define data structure for map phase])
dnl Sort algorithm. Configurable only if not forced to use psrs
ac_cv_sort=psrs
AC_ARG_ENABLE([sort],
[AS_HELP_STRING([--enable-sort=ARG],
[mode: psrs or mergesort, default: psrs])],
[ac_cv_sort=$enableval], [ac_cv_sort=psrs])
if test "$ac_cv_sort" = psrs ; then
AC_DEFINE_UNQUOTED([USE_PSRS], [1], [Define if you want to use psrs for sorting])
elif test "$ac_cv_force_psrs" = true ; then
AC_MSG_ERROR([Metis must use psrs to sort in current mode])
else
AC_DEFINE_UNQUOTED([USE_PSRS], [0], [Define if you want to use psrs for sorting])
fi
dnl Debug mode
AC_ARG_ENABLE([debug],
[AS_HELP_STRING([--enable-debug],
[mode: -O0 in debug mode; -O3 otherwise, default: false])],
[ac_cv_debug=true], [ac_cv_debug=false])
if test "$ac_cv_debug" = true ; then
OPT_LEVEL=-O0
else
OPT_LEVEL=-O3
fi
dnl Profiling
AC_ARG_ENABLE([profile],
[AS_HELP_STRING([--enable-profile],
[profile: enable performmance counters (see lib/mr-prof.c), default: false])],
[ac_cv_profile=true], [ac_cv_profile=false])
if test "$ac_cv_profile" = true ; then
AC_DEFINE_UNQUOTED([PROFILE_ENABLED], [1],
[Define if you want metis to print out profiling results from performance counters])
fi
dnl constexpr
AC_CACHE_CHECK([whether the C++ compiler understands constexpr], [ac_cv_cxx_constexpr], [
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[constexpr int f(int x) { return x + 1; }]], [[]])],
[ac_cv_cxx_constexpr=yes], [ac_cv_cxx_constexpr=no])])
if test "$ac_cv_cxx_constexpr" = yes; then
AC_DEFINE([HAVE_CXX_CONSTEXPR], [1], [Define if the C++ compiler understands constexpr.])
fi
AC_SUBST([OPT_LEVEL])
AC_OUTPUT