blob: 532b670cd65d08d1654767240f5b6e7dad6c9d7b [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])
sewardj08c7f012002-10-07 23:56:55 +0000175 ## Use the same suppression for as for 2.2.
176 ## This is a horrible hack that should be gotten
177 ## rid of. JRS, 20021007.
178 DEFAULT_SUPP="${DEFAULT_SUPP} glibc-2.2.supp"
179 ;;
180
sewardjde4a1d02002-03-22 01:27:54 +0000181 *)
182 AC_MSG_RESULT(unsupported version)
sewardj08c7f012002-10-07 23:56:55 +0000183 AC_MSG_ERROR([Valgrind requires the glibc version 2.1, 2.2 or 2.3])
sewardjde4a1d02002-03-22 01:27:54 +0000184 ;;
185esac
186
sewardj3e909ce2002-06-03 13:27:15 +0000187# APIs introduced in recent glibc versions
188
189AC_MSG_CHECKING([whether sched_param has a sched_priority member])
190AC_CACHE_VAL(vg_have_sched_priority,
191[
192AC_TRY_COMPILE([#include <pthread.h>],[
193struct sched_param p; p.sched_priority=1;],
194vg_have_sched_priority=yes,
195vg_have_sched_priority=no)
196])
197AC_MSG_RESULT($vg_have_sched_priority)
198if test "$vg_have_sched_priority" = yes; then
daywalker418c7482002-10-16 13:09:26 +0000199AC_DEFINE([HAVE_SCHED_PRIORITY], 1, [pthread / sched_priority exists])
sewardj3e909ce2002-06-03 13:27:15 +0000200fi
201
202AC_MSG_CHECKING([whether nfds_t is defined])
203AC_CACHE_VAL(vg_have_nfds_t,
204[
205AC_TRY_COMPILE([#include <sys/poll.h>],[
206nfds_t i=0;],
207vg_have_nfds_t=yes,
208vg_have_nfds_t=no)
209])
210AC_MSG_RESULT($vg_have_nfds_t)
211if test "$vg_have_nfds_t" = yes; then
daywalker418c7482002-10-16 13:09:26 +0000212AC_DEFINE([HAVE_NFDS_T], 1, [nfds_t exists])
sewardj3e909ce2002-06-03 13:27:15 +0000213fi
214
sewardjde4a1d02002-03-22 01:27:54 +0000215# try to detect the XFree version
sewardj8ce25cd2002-06-18 01:05:58 +0000216# JRS 2002-06-17: this is completely bogus because it
217# detects the server version, whereas we need to know the
218# client library version. So what follows is hacked to
219# use all the X supp files regardless of what is detected.
220# This is really stoooopid and should be fixed properly.
sewardjde4a1d02002-03-22 01:27:54 +0000221
gobrye721a522002-03-22 13:38:30 +0000222AC_PATH_X
223
224if test "${no_x}" != 'yes' ; then
225
226 AC_MSG_CHECKING([XFree version])
227
228 cat<<EOF > conftest.c
229#include <X11/Xlib.h>
230
231int main (int argc, char * argv [])
232{
233 Display * display = XOpenDisplay (NULL);
234
235 if (display) {
236 printf ("%s version=%d\n", ServerVendor (display), VendorRelease (display));
237 }
238
239 return 0;
240}
241EOF
242
243 ${CC} -o conftest conftest.c -I${x_includes} -L${x_libraries} -lX11 >&5 2>&1
244
245 if test "$?" != 0 ; then
246 AC_MSG_RESULT([cannot compile test program])
247 else
248 xfree=`./conftest`
249
250 case "${xfree}" in
251 *XFree86*)
252 ;;
253
254 *) AC_MSG_RESULT([not a XFree86 server])
255 ;;
256 esac
257
258 case "${xfree}" in
259
260 *version=4*)
261 AC_MSG_RESULT([XFree 4.x family])
daywalker418c7482002-10-16 13:09:26 +0000262 AC_DEFINE([XFREE_4], 1, [Define to 1 if you're using XFree 4.x])
gobry3b777892002-04-04 09:18:39 +0000263 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
sewardj8ce25cd2002-06-18 01:05:58 +0000264 # haaaaaaack!
265 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
gobrye721a522002-03-22 13:38:30 +0000266 ;;
267
268 *version=3*)
269 AC_MSG_RESULT([XFree 3.x family])
daywalker418c7482002-10-16 13:09:26 +0000270 AC_DEFINE([XFREE_3], 1, [Define to 1 if you're using XFree86 3.x])
sewardj19e6a4d2002-05-22 11:58:25 +0000271 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
sewardj8ce25cd2002-06-18 01:05:58 +0000272 # haaaaaaack!
273 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
gobrye721a522002-03-22 13:38:30 +0000274 ;;
275
276 *) AC_MSG_RESULT([unknown XFree86 server (${xfree})])
sewardj8ce25cd2002-06-18 01:05:58 +0000277 # haaaaaaack!
278 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-3.supp"
279 DEFAULT_SUPP="${DEFAULT_SUPP} xfree-4.supp"
gobrye721a522002-03-22 13:38:30 +0000280 ;;
281 esac
282 fi
283
284 rm -f conftest conftest.c
285fi
286
sewardj2e10a682003-04-07 19:36:41 +0000287
sewardj2e10a682003-04-07 19:36:41 +0000288AC_MSG_CHECKING([if this is an NPTL-based system])
daywalker6cb58cf2003-04-17 16:58:03 +0000289safe_LIBS="$LIBS"
290LIBS="$LIBS -lpthread"
daywalker94ece2f2003-04-17 17:38:45 +0000291AC_TRY_RUN([
sewardj2e10a682003-04-07 19:36:41 +0000292#include <pthread.h>
293#include <stdio.h>
294int main (int argc, char * argv [])
295{
296 int ret;
297 pthread_mutexattr_t mutexattr;
298 ret = pthread_mutexattr_init (&mutexattr);
299 if (ret == 0) {
300 ret = pthread_mutexattr_setpshared(&mutexattr, PTHREAD_PROCESS_SHARED);
301 if (ret == 0) /* nptl */
sewardj2e10a682003-04-07 19:36:41 +0000302 return 0;
daywalker6cb58cf2003-04-17 16:58:03 +0000303 else /* not nptl */
304 return 1;
sewardj2e10a682003-04-07 19:36:41 +0000305 }
306 return 1;
307}
daywalker6cb58cf2003-04-17 16:58:03 +0000308],
309[
310 NPTL_THREADING="yes"
311 AC_MSG_RESULT([yes])
312],
313[
314 NPTL_THREADING="no"
315 AC_MSG_RESULT([no])
316],
317[
sewardj2e10a682003-04-07 19:36:41 +0000318 AC_MSG_RESULT([couldn't run test program])
319 NPTL_THREADING="no"
daywalker6cb58cf2003-04-17 16:58:03 +0000320])
321LIBS=$safe_LIBS
sewardj2e10a682003-04-07 19:36:41 +0000322
323AC_SUBST(NPTL_THREADING)
324
325
sewardj5b754b42002-06-03 22:53:35 +0000326# does this compiler support -mpreferred-stack-boundary=2 ?
327AC_MSG_CHECKING([if gcc accepts -mpreferred-stack-boundary])
328
329CFLAGS="-mpreferred-stack-boundary=2"
330
331AC_TRY_COMPILE(, [
332
333int main () { return 0 ; }
334
335],
336[
337PREFERRED_STACK_BOUNDARY="-mpreferred-stack-boundary=2"
338AC_MSG_RESULT([$PREFERRED_STACK_BOUNDARY])
339], [
340PREFERRED_STACK_BOUNDARY=""
341AC_MSG_RESULT([no])
342])
343
344AC_SUBST(PREFERRED_STACK_BOUNDARY)
345
346
347
sewardjde4a1d02002-03-22 01:27:54 +0000348# Checks for header files.
349AC_HEADER_STDC
sewardja83005f2002-06-13 16:07:51 +0000350AC_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 +0000351
352# Checks for typedefs, structures, and compiler characteristics.
sewardjde4a1d02002-03-22 01:27:54 +0000353AC_TYPE_UID_T
354AC_TYPE_OFF_T
355AC_TYPE_SIZE_T
356AC_HEADER_TIME
357
358# Checks for library functions.
359AC_FUNC_MEMCMP
360AC_FUNC_MMAP
361AC_TYPE_SIGNAL
362
363AC_CHECK_FUNCS([floor memchr memset mkdir strchr strdup strpbrk strrchr strstr])
364
gobrye721a522002-03-22 13:38:30 +0000365AC_OUTPUT(
sewardjde4a1d02002-03-22 01:27:54 +0000366 Makefile
njn25cac76cb2002-09-23 11:21:57 +0000367 valgrind.spec
njn254d542432002-09-23 16:09:39 +0000368 docs/Makefile
369 tests/Makefile
njnc2e7f482002-09-27 08:44:17 +0000370 tests/vg_regtest
njn251ffab942002-09-23 16:42:19 +0000371 tests/unused/Makefile
njn254d542432002-09-23 16:09:39 +0000372 include/Makefile
njn7a6e7462002-11-09 17:53:30 +0000373 auxprogs/Makefile
njn25ab726032002-09-23 16:24:41 +0000374 coregrind/Makefile
375 coregrind/demangle/Makefile
376 coregrind/docs/Makefile
377 coregrind/valgrind
njn25cac76cb2002-09-23 11:21:57 +0000378 addrcheck/Makefile
njnf2df9b52002-10-04 11:35:47 +0000379 addrcheck/tests/Makefile
njn7da8fa72002-10-03 10:38:40 +0000380 addrcheck/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000381 memcheck/Makefile
382 memcheck/tests/Makefile
383 memcheck/docs/Makefile
384 cachegrind/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000385 cachegrind/tests/Makefile
386 cachegrind/docs/Makefile
njnf2df9b52002-10-04 11:35:47 +0000387 cachegrind/cg_annotate
njn25cac76cb2002-09-23 11:21:57 +0000388 corecheck/Makefile
389 corecheck/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000390 corecheck/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000391 helgrind/Makefile
njnf2df9b52002-10-04 11:35:47 +0000392 helgrind/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000393 helgrind/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000394 lackey/Makefile
njnf2df9b52002-10-04 11:35:47 +0000395 lackey/tests/Makefile
njn83157fc2002-10-03 10:07:34 +0000396 lackey/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000397 none/Makefile
398 none/tests/Makefile
njn9bc8c002002-10-02 13:49:13 +0000399 none/docs/Makefile
njn25cac76cb2002-09-23 11:21:57 +0000400)
gobry3b777892002-04-04 09:18:39 +0000401
402cat<<EOF
403
404Using the following suppressions by default:
405
406 ${DEFAULT_SUPP}
407EOF
408
409cat<<EOF > default.supp
410# This is a generated file, composed of the following suppression rules:
411#
412# ${DEFAULT_SUPP}
413#
414
415EOF
416
417for file in ${DEFAULT_SUPP} ; do
418 cat ${srcdir}/$file >> default.supp
419done