blob: 2c525502c297775926942fc1f0d9076306e6575d [file] [log] [blame]
sewardjde4a1d02002-03-22 01:27:54 +00001# Process this file with autoconf to produce a configure script.
njn3e884182003-04-15 13:03:23 +00002AC_INIT(coregrind/vg_main.c) # give me a source file, any source file...
sewardjde4a1d02002-03-22 01:27:54 +00003AM_CONFIG_HEADER(config.h)
sewardje5521a52003-04-23 21:17:24 +00004AM_INIT_AUTOMAKE(valgrind, cvs-head-2003-04-23)
sewardjde4a1d02002-03-22 01:27:54 +00005
gobryb0ed4672002-03-27 20:58:58 +00006AM_MAINTAINER_MODE
7
sewardjde4a1d02002-03-22 01:27:54 +00008# Checks for programs.
gobrye721a522002-03-22 13:38:30 +00009CFLAGS=""
10
sewardjde4a1d02002-03-22 01:27:54 +000011AC_PROG_LN_S
12AC_PROG_CC
13AC_PROG_CPP
njn25e49d8e72002-09-23 09:36:25 +000014AC_PROG_CXX
sewardjde4a1d02002-03-22 01:27:54 +000015AC_PROG_RANLIB
16
gobrye721a522002-03-22 13:38:30 +000017# Check for the compiler support
18if test "${GCC}" != "yes" ; then
19 AC_MSG_ERROR([Valgrind relies on GCC to be compiled])
20fi
21
sewardj2f685952002-12-22 19:32:23 +000022# figure out where perl lives
23AC_PATH_PROG(PERL, perl)
24
njn9315df32003-04-16 20:50:50 +000025# figure out where gdb lives
26AC_PATH_PROG(GDB, gdb)
njn17b85352003-04-18 12:54:24 +000027# autoheader tries to execute the 3rd string or something; I get warnings when
28# it's defined. So just leave it undefined. --njn 2002-Apr-18
29AC_DEFINE_UNQUOTED(GDB_PATH, "$GDB", "")
njn9315df32003-04-16 20:50:50 +000030
daywalker48ccca52002-04-15 00:31:58 +000031# some older automake's don't have it so try something on our own
32ifdef([AM_PROG_AS],[AM_PROG_AS],
33[
gobry1be19852002-03-26 20:44:55 +000034AS="${CC}"
35AC_SUBST(AS)
gobry3b777892002-04-04 09:18:39 +000036
gobry1be19852002-03-26 20:44:55 +000037ASFLAGS=""
38AC_SUBST(ASFLAGS)
daywalker48ccca52002-04-15 00:31:58 +000039])
gobry3b777892002-04-04 09:18:39 +000040
41# This variable will collect the individual suppression files
42# depending on the results of autoconf
43
44DEFAULT_SUPP=""
45
46
gobrye721a522002-03-22 13:38:30 +000047# We don't want gcc 2.7
48AC_MSG_CHECKING([for a supported version of gcc])
49
daywalker870ac4c2002-05-21 00:09:48 +000050gcc_version=`${CC} --version | head -n 1`
gobrye721a522002-03-22 13:38:30 +000051
52case "${gcc_version}" in
53 gcc-2.7.*)
54 AC_MSG_RESULT([no (${gcc_version})])
55 AC_MSG_ERROR([please use a recent (>= gcc-2.95) version of gcc])
56 ;;
57
58 *)
59 AC_MSG_RESULT([ok (${gcc_version})])
60 ;;
61esac
62
gobrye721a522002-03-22 13:38:30 +000063
sewardjde4a1d02002-03-22 01:27:54 +000064# Checks for the platform
65AC_CANONICAL_HOST
66
67AC_MSG_CHECKING([for a supported CPU])
68
gobrye721a522002-03-22 13:38:30 +000069case "${host_cpu}" in
sewardjde4a1d02002-03-22 01:27:54 +000070 i?86)
71 AC_MSG_RESULT([ok (${host_cpu})])
72 ;;
73
74 *)
75 AC_MSG_RESULT([no (${host_cpu})])
76 AC_MSG_ERROR([Valgrind is ix86 specific. Sorry])
77 ;;
78esac
79
80AC_MSG_CHECKING([for a supported OS])
81
gobrye721a522002-03-22 13:38:30 +000082case "${host_os}" in
sewardjde4a1d02002-03-22 01:27:54 +000083 *linux*)
84 AC_MSG_RESULT([ok (${host_os})])
85 ;;
86
87 *)
88 AC_MSG_RESULT([no (${host_os})])
89 AC_MSG_ERROR([Valgrind is Linux specific. Sorry])
90 ;;
91esac
92
93
94# Ok, this is linux. Check the kernel version
95AC_MSG_CHECKING([for the kernel version])
96
97kernel=`uname -r`
98
gobrye721a522002-03-22 13:38:30 +000099case "${kernel}" in
sewardj2c216242002-12-14 23:49:42 +0000100 2.5.*)
101 AC_MSG_RESULT([2.5 family (${kernel})])
102 AC_DEFINE([KERNEL_2_5], 1, [Define to 1 if you're using Linux 2.5.x])
103 ;;
104
sewardjde4a1d02002-03-22 01:27:54 +0000105 2.4.*)
106 AC_MSG_RESULT([2.4 family (${kernel})])
daywalker418c7482002-10-16 13:09:26 +0000107 AC_DEFINE([KERNEL_2_4], 1, [Define to 1 if you're using Linux 2.4.x])
sewardjde4a1d02002-03-22 01:27:54 +0000108 ;;
109
110 2.2.*)
111 AC_MSG_RESULT([2.2 family (${kernel})])
daywalker418c7482002-10-16 13:09:26 +0000112 AC_DEFINE([KERNEL_2_2], 1, [Define to 1 if you're using Linux 2.2.x])
sewardjde4a1d02002-03-22 01:27:54 +0000113 ;;
114
115 *)
116 AC_MSG_RESULT([unsupported (${kernel})])
117 AC_MSG_ERROR([Valgrind works on kernels 2.2 and 2.4])
118 ;;
119esac
120
121AC_SUBST(DEFAULT_SUPP)
122
123
124# Ok, this is linux. Check the kernel version
125AC_MSG_CHECKING([the glibc version])
126
127glibc=""
128
129AC_EGREP_CPP([GLIBC_21], [
130#include <features.h>
131#ifdef __GNU_LIBRARY__
132 #if (__GLIBC__ == 2 && __GLIBC_MINOR__ == 1)
133 GLIBC_21
134 #endif
135#endif
136],
137glibc="2.1")
138
139AC_EGREP_CPP([GLIBC_22], [
140#include <features.h>
141#ifdef __GNU_LIBRARY__
142 #if (__GLIBC__ == 2 && __GLIBC_MINOR__ == 2)
143 GLIBC_22
144 #endif
145#endif
146],
147glibc="2.2")
148
sewardj08c7f012002-10-07 23:56:55 +0000149AC_EGREP_CPP([GLIBC_23], [
150#include <features.h>
151#ifdef __GNU_LIBRARY__
152 #if (__GLIBC__ == 2 && __GLIBC_MINOR__ == 3)
153 GLIBC_23
154 #endif
155#endif
156],
157glibc="2.3")
158
gobrye721a522002-03-22 13:38:30 +0000159case "${glibc}" in
sewardjde4a1d02002-03-22 01:27:54 +0000160 2.1)
161 AC_MSG_RESULT(2.1 family)
daywalker418c7482002-10-16 13:09:26 +0000162 AC_DEFINE([GLIBC_2_1], 1, [Define to 1 if you're using glibc 2.1.x])
gobry3b777892002-04-04 09:18:39 +0000163 DEFAULT_SUPP="${DEFAULT_SUPP} glibc-2.1.supp"
sewardjde4a1d02002-03-22 01:27:54 +0000164 ;;
165
166 2.2)
167 AC_MSG_RESULT(2.2 family)
daywalker418c7482002-10-16 13:09:26 +0000168 AC_DEFINE([GLIBC_2_2], 1, [Define to 1 if you're using glibc 2.2.x])
gobry3b777892002-04-04 09:18:39 +0000169 DEFAULT_SUPP="${DEFAULT_SUPP} glibc-2.2.supp"
sewardjde4a1d02002-03-22 01:27:54 +0000170 ;;
171
sewardj08c7f012002-10-07 23:56:55 +0000172 2.3)
173 AC_MSG_RESULT(2.3 family)
daywalker418c7482002-10-16 13:09:26 +0000174 AC_DEFINE([GLIBC_2_3], 1, [Define to 1 if you're using glibc 2.3.x])
daywalker63f6f782003-05-27 00:19:52 +0000175 DEFAULT_SUPP="${DEFAULT_SUPP} glibc-2.3.supp"
sewardj08c7f012002-10-07 23:56:55 +0000176 ;;
177
sewardjde4a1d02002-03-22 01:27:54 +0000178 *)
179 AC_MSG_RESULT(unsupported version)
sewardj08c7f012002-10-07 23:56:55 +0000180 AC_MSG_ERROR([Valgrind requires the glibc version 2.1, 2.2 or 2.3])
sewardjde4a1d02002-03-22 01:27:54 +0000181 ;;
182esac
183
sewardj3e909ce2002-06-03 13:27:15 +0000184# APIs introduced in recent glibc versions
185
186AC_MSG_CHECKING([whether sched_param has a sched_priority member])
187AC_CACHE_VAL(vg_have_sched_priority,
188[
189AC_TRY_COMPILE([#include <pthread.h>],[
190struct sched_param p; p.sched_priority=1;],
191vg_have_sched_priority=yes,
192vg_have_sched_priority=no)
193])
194AC_MSG_RESULT($vg_have_sched_priority)
195if test "$vg_have_sched_priority" = yes; then
daywalker418c7482002-10-16 13:09:26 +0000196AC_DEFINE([HAVE_SCHED_PRIORITY], 1, [pthread / sched_priority exists])
sewardj3e909ce2002-06-03 13:27:15 +0000197fi
198
199AC_MSG_CHECKING([whether nfds_t is defined])
200AC_CACHE_VAL(vg_have_nfds_t,
201[
202AC_TRY_COMPILE([#include <sys/poll.h>],[
203nfds_t i=0;],
204vg_have_nfds_t=yes,
205vg_have_nfds_t=no)
206])
207AC_MSG_RESULT($vg_have_nfds_t)
208if test "$vg_have_nfds_t" = yes; then
daywalker418c7482002-10-16 13:09:26 +0000209AC_DEFINE([HAVE_NFDS_T], 1, [nfds_t exists])
sewardj3e909ce2002-06-03 13:27:15 +0000210fi
211
sewardjde4a1d02002-03-22 01:27:54 +0000212# try to detect the XFree version
sewardj8ce25cd2002-06-18 01:05:58 +0000213# JRS 2002-06-17: this is completely bogus because it
214# detects the server version, whereas we need to know the
215# client library version. So what follows is hacked to
216# use all the X supp files regardless of what is detected.
217# This is really stoooopid and should be fixed properly.
sewardjde4a1d02002-03-22 01:27:54 +0000218
gobrye721a522002-03-22 13:38:30 +0000219AC_PATH_X
220
221if test "${no_x}" != 'yes' ; then
222
223 AC_MSG_CHECKING([XFree version])
224
225 cat<<EOF > conftest.c
226#include <X11/Xlib.h>
227
228int main (int argc, char * argv [])
229{
230 Display * display = XOpenDisplay (NULL);
231
232 if (display) {
233 printf ("%s version=%d\n", ServerVendor (display), VendorRelease (display));
234 }
235
236 return 0;
237}
238EOF
239
240 ${CC} -o conftest conftest.c -I${x_includes} -L${x_libraries} -lX11 >&5 2>&1
241
242 if test "$?" != 0 ; then
243 AC_MSG_RESULT([cannot compile test program])
244 else
245 xfree=`./conftest`
246
247 case "${xfree}" in
248 *XFree86*)
249 ;;
250
251 *) AC_MSG_RESULT([not a XFree86 server])
252 ;;
253 esac
254
255 case "${xfree}" in
256
257 *version=4*)
258 AC_MSG_RESULT([XFree 4.x family])
daywalker418c7482002-10-16 13:09:26 +0000259 AC_DEFINE([XFREE_4], 1, [Define to 1 if you're using XFree 4.x])
gobry3b777892002-04-04 09:18:39 +0000260 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
sewardj8ce25cd2002-06-18 01:05:58 +0000261 # haaaaaaack!
262 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
gobrye721a522002-03-22 13:38:30 +0000263 ;;
264
265 *version=3*)
266 AC_MSG_RESULT([XFree 3.x family])
daywalker418c7482002-10-16 13:09:26 +0000267 AC_DEFINE([XFREE_3], 1, [Define to 1 if you're using XFree86 3.x])
sewardj19e6a4d2002-05-22 11:58:25 +0000268 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
sewardj8ce25cd2002-06-18 01:05:58 +0000269 # haaaaaaack!
270 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
gobrye721a522002-03-22 13:38:30 +0000271 ;;
272
273 *) AC_MSG_RESULT([unknown XFree86 server (${xfree})])
sewardj8ce25cd2002-06-18 01:05:58 +0000274 # haaaaaaack!
275 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
276 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
gobrye721a522002-03-22 13:38:30 +0000277 ;;
278 esac
279 fi
280
281 rm -f conftest conftest.c
282fi
283
sewardj2e10a682003-04-07 19:36:41 +0000284
sewardj2e10a682003-04-07 19:36:41 +0000285AC_MSG_CHECKING([if this is an NPTL-based system])
daywalker6cb58cf2003-04-17 16:58:03 +0000286safe_LIBS="$LIBS"
287LIBS="$LIBS -lpthread"
daywalker94ece2f2003-04-17 17:38:45 +0000288AC_TRY_RUN([
sewardj2e10a682003-04-07 19:36:41 +0000289#include <pthread.h>
290#include <stdio.h>
291int main (int argc, char * argv [])
292{
293 int ret;
294 pthread_mutexattr_t mutexattr;
295 ret = pthread_mutexattr_init (&mutexattr);
296 if (ret == 0) {
297 ret = pthread_mutexattr_setpshared(&mutexattr, PTHREAD_PROCESS_SHARED);
298 if (ret == 0) /* nptl */
sewardj2e10a682003-04-07 19:36:41 +0000299 return 0;
daywalker6cb58cf2003-04-17 16:58:03 +0000300 else /* not nptl */
301 return 1;
sewardj2e10a682003-04-07 19:36:41 +0000302 }
303 return 1;
304}
daywalker6cb58cf2003-04-17 16:58:03 +0000305],
306[
307 NPTL_THREADING="yes"
308 AC_MSG_RESULT([yes])
309],
310[
311 NPTL_THREADING="no"
312 AC_MSG_RESULT([no])
313],
314[
sewardj2e10a682003-04-07 19:36:41 +0000315 AC_MSG_RESULT([couldn't run test program])
316 NPTL_THREADING="no"
daywalker6cb58cf2003-04-17 16:58:03 +0000317])
318LIBS=$safe_LIBS
sewardj2e10a682003-04-07 19:36:41 +0000319
320AC_SUBST(NPTL_THREADING)
321
322
sewardj5b754b42002-06-03 22:53:35 +0000323# does this compiler support -mpreferred-stack-boundary=2 ?
324AC_MSG_CHECKING([if gcc accepts -mpreferred-stack-boundary])
325
326CFLAGS="-mpreferred-stack-boundary=2"
327
328AC_TRY_COMPILE(, [
329
330int main () { return 0 ; }
331
332],
333[
334PREFERRED_STACK_BOUNDARY="-mpreferred-stack-boundary=2"
335AC_MSG_RESULT([$PREFERRED_STACK_BOUNDARY])
336], [
337PREFERRED_STACK_BOUNDARY=""
338AC_MSG_RESULT([no])
339])
340
341AC_SUBST(PREFERRED_STACK_BOUNDARY)
342
343
344
sewardjde4a1d02002-03-22 01:27:54 +0000345# Checks for header files.
346AC_HEADER_STDC
sewardja83005f2002-06-13 16:07:51 +0000347AC_CHECK_HEADERS([fcntl.h malloc.h stdlib.h string.h sys/socket.h sys/statfs.h sys/time.h termios.h unistd.h utime.h])
sewardjde4a1d02002-03-22 01:27:54 +0000348
349# Checks for typedefs, structures, and compiler characteristics.
sewardjde4a1d02002-03-22 01:27:54 +0000350AC_TYPE_UID_T
351AC_TYPE_OFF_T
352AC_TYPE_SIZE_T
353AC_HEADER_TIME
354
355# Checks for library functions.
356AC_FUNC_MEMCMP
357AC_FUNC_MMAP
358AC_TYPE_SIGNAL
359
360AC_CHECK_FUNCS([floor memchr memset mkdir strchr strdup strpbrk strrchr strstr])
361
gobrye721a522002-03-22 13:38:30 +0000362AC_OUTPUT(
sewardjde4a1d02002-03-22 01:27:54 +0000363 Makefile
njn25cac76cb2002-09-23 11:21:57 +0000364 valgrind.spec
njn254d542432002-09-23 16:09:39 +0000365 docs/Makefile
366 tests/Makefile
njnc2e7f482002-09-27 08:44:17 +0000367 tests/vg_regtest
njn251ffab942002-09-23 16:42:19 +0000368 tests/unused/Makefile
njn254d542432002-09-23 16:09:39 +0000369 include/Makefile
njn7a6e7462002-11-09 17:53:30 +0000370 auxprogs/Makefile
njn25ab726032002-09-23 16:24:41 +0000371 coregrind/Makefile
372 coregrind/demangle/Makefile
373 coregrind/docs/Makefile
374 coregrind/valgrind
njn25cac76cb2002-09-23 11:21:57 +0000375 addrcheck/Makefile
njnf2df9b52002-10-04 11:35:47 +0000376 addrcheck/tests/Makefile
njn7da8fa72002-10-03 10:38:40 +0000377 addrcheck/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000378 memcheck/Makefile
379 memcheck/tests/Makefile
380 memcheck/docs/Makefile
381 cachegrind/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000382 cachegrind/tests/Makefile
383 cachegrind/docs/Makefile
njnf2df9b52002-10-04 11:35:47 +0000384 cachegrind/cg_annotate
njn25cac76cb2002-09-23 11:21:57 +0000385 corecheck/Makefile
386 corecheck/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000387 corecheck/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000388 helgrind/Makefile
njnf2df9b52002-10-04 11:35:47 +0000389 helgrind/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000390 helgrind/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000391 lackey/Makefile
njnf2df9b52002-10-04 11:35:47 +0000392 lackey/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000393 lackey/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000394 none/Makefile
395 none/tests/Makefile
njn9bc8c002002-10-02 13:49:13 +0000396 none/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000397)
gobry3b777892002-04-04 09:18:39 +0000398
399cat<<EOF
400
401Using the following suppressions by default:
402
403 ${DEFAULT_SUPP}
404EOF
405
406cat<<EOF > default.supp
407# This is a generated file, composed of the following suppression rules:
408#
409# ${DEFAULT_SUPP}
410#
411
412EOF
413
414for file in ${DEFAULT_SUPP} ; do
415 cat ${srcdir}/$file >> default.supp
416done