X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=configure.ac;h=41853414f0d10090f961bea259247713ae1116c5;hb=4490ae80a2bce8b8e404fc8a63372bd3b71ebd9e;hp=00de78943ceb4eb4609cd92eb64f1f7710eb7556;hpb=5eac71228631d22c0966c4c7a0ea733f94128267;p=cacao.git diff --git a/configure.ac b/configure.ac index 00de78943..41853414f 100644 --- a/configure.ac +++ b/configure.ac @@ -23,8 +23,9 @@ dnl 02110-1301, USA. dnl Process this file with autoconf to produce a configure script. -AC_INIT(cacao, 1.1.0pre, cacao@cacaojvm.org) -AC_CONFIG_SRCDIR(src/cacao/cacao.c) +AC_INIT(cacao, 1.1.0pre1, cacao@cacaojvm.org) +AC_CONFIG_SRCDIR(src/cacao/cacao.cpp) +AC_CONFIG_AUX_DIR([.]) AC_CANONICAL_HOST AC_PREREQ(2.59) AM_INIT_AUTOMAKE([1.9.0 dist-bzip2 tar-ustar]) @@ -35,145 +36,144 @@ AM_CONFIG_HEADER([config.h]) AC_PREFIX_DEFAULT(/usr/local/cacao) -dnl set optimization and debugging for all architectures and systems -if test x"$CFLAGS" = "x"; then - OPT_CFLAGS="-O0 -g" -else - OPT_CFLAGS=$CFLAGS -fi - -dnl system type +dnl Host CPU type. case "$host_cpu" in alpha | alphaev56 | alphapca56 ) ARCH_DIR="alpha" - ARCH_CFLAGS="-mieee -D__ALPHA__" + ARCH_FLAGS="-mieee -D__ALPHA__" JAVA_ARCH="alpha" ;; -arm | armv4 | armv4tl | armv5b | armv5l ) +arm | armv4* | armv5* | armv6* ) ARCH_DIR="arm" - ARCH_CFLAGS="-D__ARM__" + ARCH_FLAGS="-D__ARM__" JAVA_ARCH="arm" ;; hppa2.0 ) ARCH_DIR="parisc" - ARCH_CFLAGS="-D__PARISC__" + ARCH_FLAGS="-D__PARISC__" JAVA_ARCH="hppa" ;; i386 | i486 | i586 | i686 ) ARCH_DIR="i386" - ARCH_CFLAGS="-D__I386__" + ARCH_FLAGS="-m32 -D__I386__" JAVA_ARCH="i386" ;; m68k ) ARCH_DIR="m68k" - ARCH_CFLAGS="-D__M68K__" + ARCH_FLAGS="-D__M68K__" JAVA_ARCH="m68k" ;; -mips | mipsel ) +mips ) ARCH_DIR="mips" - ARCH_CFLAGS="-D__MIPS__" - dnl Is this correct for mipsel? + ARCH_FLAGS="-D__MIPS__" JAVA_ARCH="mips" ;; +mipsel ) + ARCH_DIR="mips" + ARCH_FLAGS="-D__MIPS__" + JAVA_ARCH="mipsel" + ;; + powerpc ) ARCH_DIR="powerpc" - ARCH_CFLAGS="-D__POWERPC__" + ARCH_FLAGS="-m32 -D__POWERPC__" JAVA_ARCH="ppc" ;; powerpc64 ) ARCH_DIR="powerpc64" - ARCH_CFLAGS="-D__POWERPC64__" + ARCH_FLAGS="-m64 -D__POWERPC64__" JAVA_ARCH="ppc64" ;; s390 ) ARCH_DIR="s390" - ARCH_CFLAGS="-D__S390__" + ARCH_FLAGS="-D__S390__" JAVA_ARCH="s390" ;; sparc | sparc64 ) ARCH_DIR="sparc64" - ARCH_CFLAGS="-mcpu=v9 -m64 -D__SPARC_64__" + ARCH_FLAGS="-mcpu=v9 -m64 -D__SPARC_64__" dnl Is this correct for 64-bits? JAVA_ARCH="sparc" ;; x86_64 ) ARCH_DIR="x86_64" - ARCH_CFLAGS="-D__X86_64__" + ARCH_FLAGS="-m64 -D__X86_64__" JAVA_ARCH="amd64" ;; xdspcore ) ARCH_DIR="xdspcore" ENABLE_STATICVM="yes" - ARCH_CFLAGS="-D__XDSPCORE__" + ARCH_FLAGS="-D__XDSPCORE__" USE_SCHEDULER="1" ;; * ) - AC_MSG_ERROR($host_cpu systems are not supported at this time) + AC_MSG_ERROR([$host_cpu systems are currently not supported.]) ;; esac -dnl host type + +dnl Host operating system type. case "$host_os" in *cygwin* ) OS_DIR="cygwin" - INTRP_CFLAGS="$ARCH_CFLAGS -D__WINDOWS__ -D__CYGWIN__ -Wall -Wno-long-long" - ARCH_CFLAGS="$ARCH_CFLAGS -D__WINDOWS__ -D__CYGWIN__ -std=c99 -pedantic -Wall -Wno-long-long" + OS_FLAGS="-D__WINDOWS__ -D__CYGWIN__" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *darwin* ) OS_DIR="darwin" - INTRP_CFLAGS="$ARCH_CFLAGS -D__DARWIN__ -Wall -Wno-long-long" - ARCH_CFLAGS="$ARCH_CFLAGS -D__DARWIN__ -std=c99 -pedantic -Wall -Wno-long-long" + OS_FLAGS="-D__DARWIN__" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; dnl Must be BEFORE *freebsd*. *kfreebsd*-gnu) OS_DIR="freebsd" - INTRP_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" - ARCH_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -std=c99 -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + OS_FLAGS="-D__FREEBSD__ -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *freebsd* ) OS_DIR="freebsd" - INTRP_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -Wall -Wno-long-long -D_XOPEN_SOURCE_EXTENDED" - ARCH_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -std=c99 -pedantic -Wall -Wno-long-long -D_XOPEN_SOURCE_EXTENDED" + OS_FLAGS="-D__FREEBSD__ -D_XOPEN_SOURCE_EXTENDED" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *irix* ) OS_DIR="irix" - INTRP_CFLAGS="$ARCH_CFLAGS -D__IRIX__" - ARCH_CFLAGS="$ARCH_CFLAGS -D__IRIX__" + OS_FLAGS="-D__IRIX__" + INTRP_CFLAGS="$ARCH_FLAGS $OS_FLAGS" ;; dnl Must be BEFORE *linux*. *uclinux | *elf ) OS_DIR="uclinux" - INTRP_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" - ARCH_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -std=c99 -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + OS_FLAGS="-D__LINUX__ -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *linux* | *Linux* ) OS_DIR="linux" - INTRP_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" - ARCH_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -std=c99 -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + OS_FLAGS="-D__LINUX__ -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *netbsd* ) OS_DIR="netbsd" - INTRP_CFLAGS="$ARCH_CFLAGS -D__NETBSD__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" - ARCH_CFLAGS="$ARCH_CFLAGS -D__NETBSD__ -std=c99 -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + OS_FLAGS="-D__NETBSD__ -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; *solaris* ) @@ -181,18 +181,67 @@ dnl Must be BEFORE *linux*. dnl On solaris the architecture defines 'sparc', 'sun', 'unix' are dnl not set when cpp is called with -std=c99, therefore we add them dnl here. - INTRP_CFLAGS="$ARCH_CFLAGS -D__SOLARIS__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D__EXTENSIONS__ -D_BSD_SOURCE -Dsparc -Dsun -Dunix" - ARCH_CFLAGS="$ARCH_CFLAGS -D__SOLARIS__ -std=c99 -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D__EXTENSIONS__ -D_BSD_SOURCE -Dsparc -Dsun -Dunix" + OS_FLAGS="-D__SOLARIS__ -D_POSIX_C_SOURCE=200112L -D__EXTENSIONS__ -D_BSD_SOURCE" + CC_FLAGS="-D_XOPEN_SOURCE=600" + CXX_FLAGS="-D_XOPEN_SOURCE=500" + INTRP_CFLAGS="-Wall -Wno-long-long $ARCH_FLAGS $OS_FLAGS" ;; * ) + AC_MSG_ERROR([$host_os operating systems are currently not supported.]) ;; esac -dnl temporary set the CFLAGS for configure tests (e.g. inline keyword) -dnl we set it properly at the end of this file -CFLAGS="$ARCH_CFLAGS $OPT_CFLAGS" +dnl Set optimization and debugging for all architectures and systems. +dnl NOTE: Setting the CFLAGS/CXXFLAGS only works before calling AC_PROG_CC/AC_PROG_CXX. +if test x"$CFLAGS" = "x"; then + OPT_CFLAGS="-g -O2" +else + OPT_CFLAGS=$CFLAGS +fi +OPT_CFLAGS="$OPT_CFLAGS -fno-strict-aliasing" + +if test x"$CXXFLAGS" = "x"; then + OPT_CXXFLAGS="-g -O2" +else + OPT_CXXFLAGS=$CXXFLAGS +fi +OPT_CXXFLAGS="$OPT_CXXFLAGS -fno-strict-aliasing" + +dnl Check for compiler. +AC_PROG_CC +AC_PROG_CXX + +dnl Check compiler vendor. +AX_COMPILER_VENDOR + +dnl Set compiler flags depending on the compiler vendor. +case "$ax_cv_c_compiler_vendor" in +gnu ) + CC_FLAGS="-std=c99 -pedantic -Wall -Wno-long-long $CC_FLAGS" + CXX_FLAGS="-std=c++98 -pedantic -Wall -Wno-long-long $CXX_FLAGS" + ;; + +sgi ) + CC_FLAGS="-c99 $CC_FLAGS" + CXX_FLAGS="$CXX_FLAGS" + ;; + +sun ) + CC_FLAGS="-xc99 $CC_FLAGS" + CXX_FLAGS="$CXX_FLAGS" + ;; + +* ) + AC_MSG_ERROR([$ax_cv_c_compiler_vendor compilers are currently not supported.]) + ;; +esac + +dnl Temporary set the CFLAGS for configure tests (e.g. inline keyword) +dnl we set it properly at the end of this file. +CFLAGS="$OPT_CFLAGS $ARCH_FLAGS $OS_FLAGS $CC_FLAGS" +CXXFLAGS="$OPT_CXXFLAGS $ARCH_FLAGS $OS_FLAGS $CXX_FLAGS" dnl set interpreter flags AC_SUBST(INTRP_CFLAGS) @@ -205,9 +254,7 @@ AC_SUBST(JAVA_ARCH) AC_SUBST(OS_DIR) AC_SUBST(USE_SCHEDULER) - dnl Checks for programs. -AC_PROG_CC AM_PROG_AS AC_PROG_LD AC_PROG_LD_GNU @@ -215,6 +262,8 @@ AC_PROG_LN_S AC_PROG_MAKE_SET AM_PROG_MKDIR_P +AM_CONDITIONAL([WITH_GNU_LD], [test x"$with_gnu_ld" = "xyes"]) + dnl Checks for header files. AC_HEADER_DIRENT AC_HEADER_STDC @@ -226,9 +275,12 @@ AC_CHECK_HEADERS([stdint.h],, [AC_MSG_ERROR(cannot find stdint.h)]) dnl keep them alpha-sorted! AC_CHECK_HEADERS([assert.h]) AC_CHECK_HEADERS([errno.h]) +AC_CHECK_HEADERS([execinfo.h]) AC_CHECK_HEADERS([fcntl.h]) AC_CHECK_HEADERS([libgen.h]) AC_CHECK_HEADERS([netdb.h]) +AC_CHECK_HEADERS([signal.h]) +AC_CHECK_HEADERS([stdarg.h]) AC_CHECK_HEADERS([stdint.h]) AC_CHECK_HEADERS([stdio.h]) AC_CHECK_HEADERS([stdlib.h]) @@ -236,7 +288,9 @@ AC_CHECK_HEADERS([string.h]) AC_CHECK_HEADERS([time.h]) AC_CHECK_HEADERS([ucontext.h]) AC_CHECK_HEADERS([unistd.h]) +AC_CHECK_HEADERS([mach/mach.h]) AC_CHECK_HEADERS([sys/ioctl.h]) +AC_CHECK_HEADERS([sys/loadavg.h]) AC_CHECK_HEADERS([sys/mman.h]) AC_CHECK_HEADERS([sys/resource.h]) AC_CHECK_HEADERS([sys/select.h]) @@ -244,6 +298,7 @@ AC_CHECK_HEADERS([sys/socket.h]) AC_CHECK_HEADERS([sys/stat.h]) AC_CHECK_HEADERS([sys/time.h]) AC_CHECK_HEADERS([sys/types.h]) +AC_CHECK_HEADERS([sys/utsname.h]) dnl Checks for typedefs, structures, and compiler characteristics. AC_C_CONST @@ -256,6 +311,11 @@ AC_STRUCT_TM dnl Checks for libraries (NOTE: Should be done before function checks, dnl as some functions may be in libraries we check for). +case "${OS_DIR}" in + solaris ) + AC_CHECK_LIB([socket], [gethostname],, [AC_MSG_ERROR(cannot find libsocket)]) + ;; +esac dnl Checks for library functions. AC_PROG_GCC_TRADITIONAL @@ -269,6 +329,8 @@ AC_CHECK_FUNCS([accept]) AC_CHECK_FUNCS([access]) AC_CHECK_FUNCS([atoi]) AC_CHECK_FUNCS([atol]) +AC_CHECK_FUNCS([backtrace]) +AC_CHECK_FUNCS([backtrace_symbols]) AC_CHECK_FUNCS([calloc]) AC_CHECK_FUNCS([close]) AC_CHECK_FUNCS([confstr]) @@ -284,9 +346,12 @@ AC_CHECK_FUNCS([fstat]) AC_CHECK_FUNCS([fsync]) AC_CHECK_FUNCS([ftruncate]) AC_CHECK_FUNCS([getcwd]) +AC_CHECK_FUNCS([getenv]) AC_CHECK_FUNCS([gethostbyname]) AC_CHECK_FUNCS([gethostname]) +AC_CHECK_FUNCS([getloadavg]) AC_CHECK_FUNCS([getpagesize]) +AC_CHECK_FUNCS([getpid]) AC_CHECK_FUNCS([getrusage]) AC_CHECK_FUNCS([getsockname]) AC_CHECK_FUNCS([getsockopt]) @@ -304,6 +369,7 @@ AC_CHECK_FUNCS([memset]) AC_CHECK_FUNCS([mmap]) AC_CHECK_FUNCS([mprotect]) AC_CHECK_FUNCS([open]) +AC_CHECK_FUNCS([printf]) AC_CHECK_FUNCS([read]) AC_CHECK_FUNCS([readlink]) AC_CHECK_FUNCS([realloc]) @@ -315,9 +381,11 @@ AC_CHECK_FUNCS([setsockopt]) AC_CHECK_FUNCS([shutdown]) AC_CHECK_FUNCS([socket]) AC_CHECK_FUNCS([stat]) +AC_CHECK_FUNCS([str2sig]) AC_CHECK_FUNCS([strcat]) AC_CHECK_FUNCS([strchr]) AC_CHECK_FUNCS([strcpy]) +AC_CHECK_FUNCS([strcmp]) AC_CHECK_FUNCS([strdup]) AC_CHECK_FUNCS([strerror]) AC_CHECK_FUNCS([strlen]) @@ -378,111 +446,17 @@ AC_CHECK_ENABLE_VMLOG AC_CHECK_ENABLE_DISASSEMBLER AC_CHECK_ENABLE_STATISTICS AC_CHECK_ENABLE_VERIFIER - -dnl check for compiler timing -AC_MSG_CHECKING(whether real-time timing should be enabled) -AC_ARG_ENABLE([rt-timing], - [AS_HELP_STRING(--enable-rt-timing,enable real-time timing [[default=no]])], - [case "${enableval}" in - yes) ENABLE_RT_TIMING=yes;; - *) ENABLE_RT_TIMING=no;; - esac], - [ENABLE_RT_TIMING=no]) -AC_MSG_RESULT(${ENABLE_RT_TIMING}) -AM_CONDITIONAL([ENABLE_RT_TIMING], test x"${ENABLE_RT_TIMING}" = "xyes") - -if test x"${ENABLE_RT_TIMING}" = "xyes"; then - AC_DEFINE([ENABLE_RT_TIMING], 1, [enable real-time timing]) -fi - - -dnl check for cycle count statistics -AC_MSG_CHECKING(whether cycle count statistics should be enabled) -AC_ARG_ENABLE([cycles-stats], - [AS_HELP_STRING(--enable-cycles-stats,enable cycle count statistics [[default=no]])], - [case "${enableval}" in - yes) ENABLE_CYCLES_STATS=yes;; - *) ENABLE_CYCLES_STATS=no;; - esac], - [ENABLE_CYCLES_STATS=no]) -AC_MSG_RESULT(${ENABLE_CYCLES_STATS}) -AM_CONDITIONAL([ENABLE_CYCLES_STATS], test x"${ENABLE_CYCLES_STATS}" = "xyes") - -if test x"${ENABLE_CYCLES_STATS}" = "xyes"; then - AC_DEFINE([ENABLE_CYCLES_STATS], 1, [enable cycle count statistics]) -fi - +AC_CHECK_ENABLE_RT_TIMING +AC_CHECK_ENABLE_CYCLE_STATS AC_CHECK_ENABLE_JVMTI AC_CHECK_ENABLE_THREADS - - -dnl check if if-conversion should be supported -AC_MSG_CHECKING(whether if-conversion should be supported) -AC_ARG_ENABLE([ifconv], - [AS_HELP_STRING(--disable-ifconv,disable if-conversion [[default=enabled]])], - [case "${enableval}" in - no) ENABLE_IFCONV=no;; - *) ENABLE_IFCONV=yes;; - esac], - [ENABLE_IFCONV=yes]) -AC_MSG_RESULT(${ENABLE_IFCONV}) -AM_CONDITIONAL([ENABLE_IFCONV], test x"${ENABLE_IFCONV}" = "xyes") - -if test x"${ENABLE_IFCONV}" = "xyes"; then - AC_DEFINE([ENABLE_IFCONV], 1, [enable if-conversion]) -fi - - -dnl check for inlining -AC_MSG_CHECKING(whether method inlining should be supported) -AC_ARG_ENABLE([inlining], - [AS_HELP_STRING(--enable-inlining,enable method inlining [[default=no]])], - [case "${enableval}" in - yes) ENABLE_INLINING=yes;; - *) ENABLE_INLINING=no;; - esac], - [ENABLE_INLINING=no]) -AC_MSG_RESULT(${ENABLE_INLINING}) -AM_CONDITIONAL([ENABLE_INLINING], test x"${ENABLE_INLINING}" = "xyes") - -if test x"${ENABLE_INLINING}" = "xyes"; then - AC_DEFINE([ENABLE_INLINING], 1, [use method inlining]) -fi - - -dnl check for inlining debug options -AC_MSG_CHECKING(whether method inlining debug options should be enabled) -AC_ARG_ENABLE([inlining-debug], - [AS_HELP_STRING(--enable-inlining-debug,enable method inlining debug options [[default=no]])], - [case "${enableval}" in - yes) ENABLE_INLINING_DEBUG=yes;; - *) ENABLE_INLINING_DEBUG=no;; - esac], - [ENABLE_INLINING_DEBUG=no]) -AC_MSG_RESULT(${ENABLE_INLINING_DEBUG}) -AM_CONDITIONAL([ENABLE_INLINING_DEBUG], test x"${ENABLE_INLINING_DEBUG}" = "xyes") - -if test x"${ENABLE_INLINING_DEBUG}" = "xyes"; then - AC_DEFINE([ENABLE_INLINING_DEBUG], 1, [enable method inlining debug options]) -fi - - -dnl check for replacement -AC_MSG_CHECKING(whether on-stack replacement should be supported) -AC_ARG_ENABLE([replacement], - [AS_HELP_STRING(--enable-replacement,enable on-stack replacement [[default=no]])], - [case "${enableval}" in - yes) ENABLE_REPLACEMENT=yes;; - *) ENABLE_REPLACEMENT=no;; - esac], - [ENABLE_REPLACEMENT=no]) -AC_MSG_RESULT(${ENABLE_REPLACEMENT}) -AM_CONDITIONAL([ENABLE_REPLACEMENT], test x"${ENABLE_REPLACEMENT}" = "xyes") - -if test x"${ENABLE_REPLACEMENT}" = "xyes"; then - AC_DEFINE([ENABLE_REPLACEMENT], 1, [use on-stack replacement]) +if test x"${ENABLE_THREADS}" != "xno"; then + AC_CHECK_USE___THREAD fi - +AC_CHECK_ENABLE_IFCONV +AC_CHECK_ENABLE_INLINING +AC_CHECK_ENABLE_INLINING_DEBUG +AC_CHECK_ENABLE_REPLACEMENT dnl check for loop optimization AC_MSG_CHECKING(whether loop optimization should be supported) @@ -514,11 +488,13 @@ AC_MSG_RESULT(${ENABLE_SSA}) AM_CONDITIONAL([ENABLE_SSA], test x"${ENABLE_SSA}" = "xyes") AM_CONDITIONAL([ENABLE_ESCAPE], test x"${ENABLE_SSA}" = "xyes") AM_CONDITIONAL([ENABLE_ESCAPE_CHECK], test x"${ENABLE_SSA}" = "xyes") +AM_CONDITIONAL([ENABLE_TLH], test x"${ENABLE_SSA}" = "xyes") if test x"${ENABLE_SSA}" = "xyes"; then AC_DEFINE([ENABLE_SSA], 1, [enable lsra with ssa]) AC_DEFINE([ENABLE_ESCAPE], 1, [enable escape analysis with ssa]) AC_DEFINE([ENABLE_ESCAPE_CHECK], 1, [enable generating code to validate escape analysis results]) + AC_DEFINE([ENABLE_TLH], 1, [enable thread local heap]) ENABLE_LSRA="no" fi @@ -583,6 +559,7 @@ else AM_CONDITIONAL([USE_SCHEDULER], [false]) fi +AC_CHECK_ENABLE_OPAGENT AC_CHECK_ENABLE_ZLIB @@ -600,19 +577,9 @@ AC_CHECK_ENABLE_STATICVM AC_CHECK_ENABLE_ANNOTATIONS AC_CHECK_ENABLE_ASSERTION +dnl This one depends on AC_CHECK_ENABLE_ZLIB. +AC_CHECK_WITH_VM_ZIP -dnl where is CACAO's vm.zip -AC_MSG_CHECKING(where CACAO's vm.zip is installed) -AC_ARG_WITH([vm-zip], - [AS_HELP_STRING(--with-vm-zip=,path to CACAO's vm.zip (includes the name of the file and may be flat) [[default=/usr/local/cacao/share/cacao/vm.zip]])], - [CACAO_VM_ZIP=${withval}], - [CACAO_VM_ZIP=${CACAO_PREFIX}/share/cacao/vm.zip]) -AC_MSG_RESULT(${CACAO_VM_ZIP}) -AC_DEFINE_UNQUOTED([CACAO_VM_ZIP], "${CACAO_VM_ZIP}", [CACAO's vm.zip]) -AC_SUBST(CACAO_VM_ZIP) - - -AC_CHECK_WITH_CACAOH AC_CHECK_WITH_JAVA_RUNTIME_LIBRARY dnl Now we check for jre-layout so we can skip some checks that are @@ -621,6 +588,7 @@ AC_CHECK_ENABLE_JRE_LAYOUT AC_CHECK_WITH_JAVA_RUNTIME_LIBRARY_PREFIX AC_CHECK_WITH_JAVA_RUNTIME_LIBRARY_CLASSES +AC_CHECK_WITH_BUILD_JAVA_RUNTIME_LIBRARY_CLASSES if test x"${ENABLE_JRE_LAYOUT}" = "xno"; then AC_CHECK_WITH_JAVA_RUNTIME_LIBRARY_LIBDIR @@ -630,11 +598,19 @@ dnl The check for jni_md.h must be before jni.h. AC_CHECK_WITH_JNI_MD_H AC_CHECK_WITH_JNI_H -dnl HPI is only required for OpenJDK +dnl The jvmti.h header is only required if JVMTI is enabled. +if test x"${ENABLE_JVMTI}" = "xyes"; then + AC_CHECK_WITH_JVMTI_H +fi + +dnl JVM, HPI, and JMM is only required for OpenJDK. case "${WITH_JAVA_RUNTIME_LIBRARY}" in openjdk) + AC_CHECK_WITH_JVM_MD_H + AC_CHECK_WITH_JVM_H AC_CHECK_WITH_HPI_MD_H AC_CHECK_WITH_HPI_H + AC_CHECK_WITH_JMM_H ;; *) ;; @@ -681,18 +657,20 @@ AZ_PYTHON_VERSION_ENSURE( [2.4] ) AZ_PYTHON_CSPEC AZ_PYTHON_LSPEC +dnl Define version numbers. +AC_VERSION_DETAIL +AC_VERSION_CONFIG -dnl define some stuff required for --fullversion -AC_DEFINE_UNQUOTED(VERSION_CONFIGURE_ARGS, "$ac_configure_args", [configure arguments]) -AC_DEFINE_UNQUOTED(VERSION_CC, "$CC", [CC used]) -AC_DEFINE_UNQUOTED(VERSION_CFLAGS, "$OPT_CFLAGS $ARCH_CFLAGS $CPPFLAGS", [CFLAGS used]) - - -dnl finally pass CFLAGS to Makefiles via AM_CFLAGS +dnl Finally pass flags to Makefiles. CFLAGS="$OPT_CFLAGS" -AM_CFLAGS=$ARCH_CFLAGS +CXXFLAGS="$OPT_CXXFLAGS" + +AM_CFLAGS="$CC_FLAGS $ARCH_FLAGS $OS_FLAGS" +AM_CXXFLAGS="$CXX_FLAGS $ARCH_FLAGS $OS_FLAGS" AM_CPPFLAGS="$CPPFLAGS" + AC_SUBST(AM_CFLAGS) +AC_SUBST(AM_CXXFLAGS) AC_SUBST(AM_CPPFLAGS) @@ -708,13 +686,11 @@ AC_CONFIG_FILES([Makefile] [man/Makefile] [src/Makefile] [src/cacao/Makefile] - [src/cacaoh/Makefile] [src/classes/Makefile] [src/fdlibm/Makefile] [src/mm/Makefile] [src/mm/cacao-gc/Makefile] [src/native/Makefile] - [src/native/include/Makefile] [src/native/jvmti/Makefile] [src/native/vm/Makefile] [src/native/vm/cldc1.1/Makefile] @@ -739,6 +715,7 @@ AC_CONFIG_FILES([Makefile] [src/vm/jit/i386/darwin/Makefile] [src/vm/jit/i386/freebsd/Makefile] [src/vm/jit/i386/linux/Makefile] + [src/vm/jit/i386/solaris/Makefile] [src/vm/jit/intrp/Makefile] [src/vm/jit/inline/Makefile] [src/vm/jit/ir/Makefile] @@ -767,7 +744,7 @@ AC_CONFIG_FILES([Makefile] [src/vm/jit/x86_64/Makefile] [src/vm/jit/x86_64/freebsd/Makefile] [src/vm/jit/x86_64/linux/Makefile] - [src/vmcore/Makefile] + [src/vm/jit/x86_64/solaris/Makefile] [tests/Makefile] [tests/regression/Makefile] [tests/regression/assertion/Makefile] @@ -782,11 +759,8 @@ AC_CONFIG_FILES([Makefile] ) -dnl now configure subpackages with OPT_CFLAGS and ARCH_CFLAGS -export OPT_CFLAGS -export ARCH_CFLAGS dnl We only build the shared library objects but we use it as -dnl noinst_LTLIBRARIES +dnl noinst_LTLIBRARIES. ac_configure_args="$ac_configure_args --disable-static" AC_CONFIG_SUBDIRS(src/mm/boehm-gc)