dnl Process this file with autoconf to produce a configure script.
-AC_INIT(cacao, 0.95+cvs, cacao@cacaojvm.org)
+AC_INIT(cacao, 0.96+svn, cacao@cacaojvm.org)
AC_CONFIG_SRCDIR(src/cacao/cacao.c)
AC_CANONICAL_HOST
AC_PREREQ(2.59)
dnl set optimization and debugging for all architectures and systems
if test x"$CFLAGS" = "x"; then
- CFLAGS="-O0 -g3"
+ OPT_CFLAGS="-O0 -g3"
+else
+ OPT_CFLAGS=$CFLAGS
fi
dnl system type
case "$host_cpu" in
alpha | alphaev56 | alphapca56 )
ARCH_DIR="alpha"
- CFLAGS="$CFLAGS -mieee -D__ALPHA__"
+ ARCH_CFLAGS="-mieee -D__ALPHA__"
;;
-arm | armv4tl | armv5b )
+arm | armv4tl | armv5b | armv5l )
ARCH_DIR="arm"
- CFLAGS="$CFLAGS -D__ARM__"
+ ARCH_CFLAGS="-D__ARM__"
;;
i386 | i486 | i586 | i686 )
ARCH_DIR="i386"
- CFLAGS="$CFLAGS -D__I386__"
+ ARCH_CFLAGS="-D__I386__"
;;
mips )
ARCH_DIR="mips"
- CFLAGS="$CFLAGS -D__MIPS__"
+ ARCH_CFLAGS="-D__MIPS__"
;;
powerpc )
ARCH_DIR="powerpc"
- CFLAGS="$CFLAGS -D__POWERPC__"
+ ARCH_CFLAGS="-D__POWERPC__"
;;
powerpc64 )
ARCH_DIR="powerpc64"
- CFLAGS="$CFLAGS -D__POWERPC64__"
+ ARCH_CFLAGS="-D__POWERPC64__"
+ ;;
+
+sparc64 )
+ ARCH_DIR="sparc64"
+ ARCH_CFLAGS="-mcpu=v9 -m64 -D__SPARC_64__"
;;
x86_64 )
ARCH_DIR="x86_64"
- CFLAGS="$CFLAGS -D__X86_64__"
+ ARCH_CFLAGS="-D__X86_64__"
;;
xdspcore )
ARCH_DIR="xdspcore"
ENABLE_STATICVM="yes"
- CFLAGS="$CFLAGS -D__XDSPCORE__"
+ ARCH_CFLAGS="-D__XDSPCORE__"
USE_SCHEDULER="1"
;;
case "$host_os" in
*darwin* )
OS_DIR="darwin"
- CFLAGS="$CFLAGS -D__DARWIN__ -ansi -pedantic -Wall -Wno-long-long"
+ INTRP_CFLAGS="$ARCH_CFLAGS -D__DARWIN__ -Wall -Wno-long-long"
+ ARCH_CFLAGS="$ARCH_CFLAGS -D__DARWIN__ -ansi -pedantic -Wall -Wno-long-long"
;;
*freebsd* )
OS_DIR="freebsd"
- CFLAGS="$CFLAGS -D__FREEBSD__ -ansi -pedantic -Wall -Wno-long-long -D_XOPEN_SOURCE_EXTENDED"
+ INTRP_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -Wall -Wno-long-long -D_XOPEN_SOURCE_EXTENDED"
+ ARCH_CFLAGS="$ARCH_CFLAGS -D__FREEBSD__ -ansi -pedantic -Wall -Wno-long-long -D_XOPEN_SOURCE_EXTENDED"
;;
*irix* )
OS_DIR="irix"
- CFLAGS="$CFLAGS -D__IRIX__"
+ INTRP_CFLAGS="$ARCH_CFLAGS -D__IRIX__"
+ ARCH_CFLAGS="$ARCH_CFLAGS -D__IRIX__"
;;
*linux* | *Linux* )
OS_DIR="linux"
- CFLAGS="$CFLAGS -D__LINUX__ -ansi -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
+ INTRP_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
+ ARCH_CFLAGS="$ARCH_CFLAGS -D__LINUX__ -ansi -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
+ ;;
+
+*netbsd* )
+ OS_DIR="netbsd"
+ INTRP_CFLAGS="$ARCH_CFLAGS -D__NETBSD__ -Wall -Wno-long-long -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
+ ARCH_CFLAGS="$ARCH_CFLAGS -D__NETBSD__ -ansi -pedantic -Wall -Wno-long-long -D_POSIX_C_SOURCE=199506L -D_XOPEN_SOURCE=500 -D_XOPEN_SOURCE_EXTENDED -D_BSD_SOURCE"
;;
* )
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 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, "$CFLAGS", [CFLAGS used])
+AC_DEFINE_UNQUOTED(VERSION_CFLAGS, "$OPT_CFLAGS $ARCH_CFLAGS", [CFLAGS used])
dnl define and substitute some architecture specific variables
AC_DEFINE_UNQUOTED([ARCH_DIR], "${ARCH_DIR}", [architecture directory])
AC_SUBST(ARCH_DIR)
AC_SUBST(OS_DIR)
+AC_SUBST(INTRP_CFLAGS)
AC_SUBST(USE_SCHEDULER)
AC_PROG_MAKE_SET
AM_PROG_MKDIR_P
-AC_ENABLE_SHARED
-AC_DISABLE_STATIC
-
-dnl libtool stuff
-AC_LIBTOOL_DLOPEN
-AC_PROG_LIBTOOL
-
dnl Checks for header files.
AC_HEADER_DIRENT
AC_HEADER_STDC
AC_PROG_GCC_TRADITIONAL
AC_TYPE_SIGNAL
AC_FUNC_MEMCMP
-AC_CHECK_FUNCS([calloc mprotect getpagesize free])
+AC_FUNC_MMAP
+AC_CHECK_FUNCS([calloc mmap getpagesize free])
AC_CHECK_FUNCS([getcwd gettimeofday])
AC_CHECK_FUNCS([scandir])
-AC_CHECK_FUNCS([mmap])
AC_CHECK_FUNCS([isnan])
dnl Checks for libraries.
AC_C_BIGENDIAN
-dnl check which ld flags are required to export symbols
-if test x"$with_gnu_ld" = "xyes"; then
- EXPORT_SYMBOLS_FLAGS="-Wl,--export-dynamic"
-else
- EXPORT_SYMBOLS_FLAGS=""
-fi
-AC_SUBST(EXPORT_SYMBOLS_FLAGS)
-
-
dnl define install prefix
if test "x$prefix" = "xNONE"; then
CACAO_PREFIX=$ac_default_prefix
AC_DEFINE_UNQUOTED([CACAO_PREFIX], "${CACAO_PREFIX}", [installation prefix])
AC_SUBST(CACAO_PREFIX)
+dnl define libdir prefix
+if test "x$libdir" = "xNONE"; then
+ CACAO_LIBDIR=$ac_default_libdir
+else
+ CACAO_LIBDIR=$libdir
+fi
+dnl expand CACAO_LIBDIR to something that is usable in C code
+AS_AC_EXPAND([CACAO_LIBDIR], ${CACAO_LIBDIR})
+AC_DEFINE_UNQUOTED([CACAO_LIBDIR], "${CACAO_LIBDIR}", [library installation prefix])
+AC_SUBST(CACAO_LIBDIR)
+
dnl Features
if test x"${NDEBUG}" = "xno"; then
AC_MSG_RESULT(yes)
+else
+ AC_MSG_RESULT(no)
+fi
+AM_CONDITIONAL([NDEBUG], test x"${NDEBUG}" = "xyes")
+
+
+dnl check for disassembler support
+AC_MSG_CHECKING(whether disassembler should be enabled)
+AC_ARG_ENABLE([disassembler],
+ [AS_HELP_STRING(--enable-disassembler,enable disassembler [[default=no]])],
+ [case "${enableval}" in
+ yes) ENABLE_DISASSEMBLER=yes;;
+ *) ENABLE_DISASSEMBLER=no;;
+ esac],
+ [ENABLE_DISASSEMBLER=no])
+AC_MSG_RESULT(${ENABLE_DISASSEMBLER})
+AM_CONDITIONAL([ENABLE_DISASSEMBLER], test x"${ENABLE_DISASSEMBLER}" = "xyes")
+
+if test x"${ENABLE_DISASSEMBLER}" = "xyes"; then
+ AC_DEFINE([ENABLE_DISASSEMBLER], 1, [enable disassembler])
dnl check for binutils headers and libraries on some architectures for the
dnl disassembler
case "${ARCH_DIR}" in
- arm | i386 | powerpc | x86_64 )
+ arm | i386 | powerpc | x86_64 | sparc64 | powerpc64)
AC_CHECK_HEADER([ansidecl.h],, [AC_MSG_ERROR(cannot find ansidecl.h)])
AC_CHECK_HEADER([symcat.h],, [AC_MSG_ERROR(cannot find symcat.h)])
AC_CHECK_HEADER([bfd.h],, [AC_MSG_ERROR(cannot find bfd.h)])
AC_CHECK_HEADER([dis-asm.h],, [AC_MSG_ERROR(cannot find dis-asm.h)])
case "${OS_DIR}" in
- cygwin | darwin )
- AC_CHECK_LIB(intl, dcgettext,, [AC_MSG_ERROR(cannot find libintl (from bintuils))])
+ cygwin | darwin | netbsd )
+ AC_CHECK_LIB(intl, dcgettext,, [AC_MSG_ERROR(cannot find libintl (from binutils))])
;;
esac
- AC_CHECK_LIB(iberty, xstrerror,, [AC_MSG_ERROR(cannot find libiberty (from bintuils))])
- AC_CHECK_LIB(bfd, bfd_get_arch,, [AC_MSG_ERROR(cannot find libbfd (from bintuils))])
- AC_CHECK_LIB(opcodes, init_disassemble_info,, [AC_MSG_ERROR(cannot find libopcodes (from bintuils))])
+ AC_CHECK_LIB(iberty, xstrerror,, [AC_MSG_ERROR(cannot find libiberty (from binutils))])
+ AC_CHECK_LIB(bfd, bfd_get_arch,, [AC_MSG_ERROR(cannot find libbfd (from binutils))])
+ AC_CHECK_LIB(opcodes, disassembler,, [AC_MSG_ERROR(cannot find libopcodes (from binutils))])
AC_DEFINE([WITH_BINUTILS_DISASSEMBLER], 1, [use binutils disassembler])
AM_CONDITIONAL([WITH_BINUTILS_DISASSEMBLER], [true])
;;
AM_CONDITIONAL([WITH_BINUTILS_DISASSEMBLER], [false])
;;
esac
-
else
- AC_MSG_RESULT(no)
AM_CONDITIONAL([WITH_BINUTILS_DISASSEMBLER], [false])
fi
-AM_CONDITIONAL([NDEBUG], test x"${NDEBUG}" = "xyes")
dnl check for statistics
AC_MSG_CHECKING(whether statistics generation should be enabled)
AC_ARG_ENABLE([statistics],
- [AS_HELP_STRING(--disable-statistics,disable statistics generation [[default=yes]])],
+ [AS_HELP_STRING(--enable-statistics,enable statistics generation [[default=no]])],
[case "${enableval}" in
- no) ENABLE_STATISTICS=no;;
- *) ENABLE_STATISTICS=yes;;
+ yes) ENABLE_STATISTICS=yes;;
+ *) ENABLE_STATISTICS=no;;
esac],
- [ENABLE_STATISTICS=yes])
+ [ENABLE_STATISTICS=no])
AC_MSG_RESULT(${ENABLE_STATISTICS})
AM_CONDITIONAL([ENABLE_STATISTICS], test x"${ENABLE_STATISTICS}" = "xyes")
fi
+dnl check for verifier
+AC_MSG_CHECKING(whether classfile verification should be enabled)
+AC_ARG_ENABLE([verifier],
+ [AS_HELP_STRING(--disable-verifier,disable classfile verification [[default=yes]])],
+ [case "${enableval}" in
+ no) ENABLE_VERIFIER=no;;
+ *) ENABLE_VERIFIER=yes;;
+ esac],
+ [ENABLE_VERIFIER=yes])
+AC_MSG_RESULT(${ENABLE_VERIFIER})
+AM_CONDITIONAL([ENABLE_VERIFIER], test x"${ENABLE_VERIFIER}" = "xyes")
+
+if test x"${ENABLE_VERIFIER}" = "xyes"; then
+ AC_DEFINE([ENABLE_VERIFIER], 1, [enable classfile verification])
+fi
+
+
+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
+
+
dnl check for JVMTI
AC_MSG_CHECKING(whether to compile JVMTI support)
AC_ARG_ENABLE([jvmti],
enable_threads=${enable_threads:-native}
case "$enable_threads" in
no | none | single)
- AC_MSG_RESULT(no)
- dnl no threads for boehm
- ac_configure_args="$ac_configure_args --disable-boehm-threads"
- AM_CONDITIONAL([USE_THREADS], [false])
- AM_CONDITIONAL([NATIVE_THREADS], [false])
- ;;
-
-green | native | posix | pthreads)
- AC_DEFINE([USE_THREADS], 1, [use threads])
-
- AM_CONDITIONAL([USE_THREADS], [true])
-
- if test x"$enable_threads" != "xgreen"; then
- AC_MSG_RESULT(yes, native)
- AC_CHECK_LIB(pthread, main)
- AC_DEFINE([NATIVE_THREADS], 1, [use pthreads])
+ AC_MSG_RESULT(no)
+ dnl no threads for boehm
+ ac_configure_args="$ac_configure_args --disable-boehm-threads"
+ AM_CONDITIONAL([ENABLE_THREADS], [false])
+ ;;
- CFLAGS="$CFLAGS -D_REENTRANT"
+native | posix | pthreads)
+ AC_DEFINE([ENABLE_THREADS], 1, [enable threads])
+
+ AM_CONDITIONAL([ENABLE_THREADS], [true])
+
+ AC_MSG_RESULT(yes, native)
+ AC_CHECK_LIB(pthread, main)
- dnl tell boehm to support threads as well
- ac_configure_args="$ac_configure_args --enable-boehm-threads=posix"
- AM_CONDITIONAL([NATIVE_THREADS], [true])
+ ARCH_CFLAGS="$ARCH_CFLAGS -D_REENTRANT"
- else
- AC_MSG_RESULT(yes, green)
+ dnl we changed ARCH_CFLAGS, set CFLAGS again
+ CFLAGS="$ARCH_CFLAGS $OPT_CFLAGS"
- dnl no threads for boehm
- ac_configure_args="$ac_configure_args --disable-boehm-threads"
- AM_CONDITIONAL([NATIVE_THREADS], [false])
- fi
+ dnl tell boehm to support threads as well
+ ac_configure_args="$ac_configure_args --enable-boehm-threads=posix"
;;
+
*)
AC_MSG_ERROR($enable_threads is an unknown thread package)
;;
[cat > conftest.c <<\EOF
__thread int a = 42;
EOF
- if AC_TRY_COMMAND([${CC-cc} $CFLAGS -c conftest.c >&AS_MESSAGE_LOG_FD]); then
+ if AC_TRY_COMMAND([${CC-cc} $ARCH_CFLAGS $OPT_CFLAGS -c conftest.c >&AS_MESSAGE_LOG_FD]); then
ac_cv_gcc___thread=yes
else
ac_cv_gcc___thread=no
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 loop optimization
+AC_MSG_CHECKING(whether loop optimization should be supported)
+AC_ARG_ENABLE([loop],
+ [AS_HELP_STRING(--enable-loop,enable loop optimization [[default=no]])],
+ [case "${enableval}" in
+ yes) ENABLE_LOOP=yes;;
+ *) ENABLE_LOOP=no;;
+ esac],
+ [ENABLE_LOOP=no])
+AC_MSG_RESULT(${ENABLE_LOOP})
+AM_CONDITIONAL([ENABLE_LOOP], test x"${ENABLE_LOOP}" = "xyes")
+
+if test x"${ENABLE_LOOP}" = "xyes"; then
+ AC_DEFINE([ENABLE_LOOP], 1, [use loop optimization])
+fi
+
+
+dnl check if linear scan register allocator(lsra) with SSA should be used
+AC_MSG_CHECKING(whether lsra with ssa should be supported)
+AC_ARG_ENABLE([ssa],
+ [AS_HELP_STRING(--disable-ssa,disable ssa [[default=no]])],
+ [case "${enableval}" in
+ no) ENABLE_SSA=no;;
+ *) ENABLE_SSA=yes;;
+ esac],
+ [ENABLE_SSA=no])
+AC_MSG_RESULT(${ENABLE_SSA})
+AM_CONDITIONAL([ENABLE_SSA], test x"${ENABLE_SSA}" = "xyes")
+
+if test x"${ENABLE_SSA}" = "xyes"; then
+ AC_DEFINE([ENABLE_SSA], 1, [enable lsra with ssa])
+ ENABLE_LSRA="no"
+fi
+
+
dnl check if linear scan register allocator(lsra) should be used
AC_MSG_CHECKING(whether lsra should be supported)
AC_ARG_ENABLE([lsra],
- [AS_HELP_STRING(--disable-lsra,disable linear scan register allocator [[default=yes]])],
+ [AS_HELP_STRING(--enable-lsra,enable linear scan register allocator [[default=no]])],
[case "${enableval}" in
- no) ENABLE_LSRA=no;;
- *) ENABLE_LSRA=yes;;
+ yes) ENABLE_LSRA=yes;;
+ *) ENABLE_LSRA=no;;
esac],
- [ENABLE_LSRA=yes])
+ [ENABLE_LSRA=no])
+
+if test x"${ENABLE_LSRA}" = "xyes"; then
+ if test x"${ENABLE_SSA}" = "xyes"; then
+ ENABLE_LSRA="no"
+ fi
+fi
AC_MSG_RESULT(${ENABLE_LSRA})
AM_CONDITIONAL([ENABLE_LSRA], test x"${ENABLE_LSRA}" = "xyes")
-
+
if test x"${ENABLE_LSRA}" = "xyes"; then
AC_DEFINE([ENABLE_LSRA], 1, [enable lsra])
fi
-dnl check for inlining
-dnl AC_ARG_ENABLE([inlining], [AS_HELP_STRING(--disable-inlining,disable method inlining [[default=yes]])])
-
-dnl AC_MSG_CHECKING(whether method inlining should be disabled)
-dnl if test x"$enable_inlining" = "xno"; then
-dnl AC_MSG_RESULT(yes)
-dnl AM_CONDITIONAL([USE_INLINING], [false])
-dnl else
-dnl AC_MSG_RESULT(no)
- AC_DEFINE([USE_INLINING], 1, [use method inlining])
- AM_CONDITIONAL([USE_INLINING], [true])
-dnl fi
+dnl check if profiling should be supported
+AC_MSG_CHECKING(whether profiling should be supported)
+AC_ARG_ENABLE([profiling],
+ [AS_HELP_STRING(--enable-profiling,enable profiling [[default=no]])],
+ [case "${enableval}" in
+ yes) ENABLE_PROFILING=yes;;
+ *) ENABLE_PROFILING=no;;
+ esac],
+ [ENABLE_PROFILING=no])
+AC_MSG_RESULT(${ENABLE_PROFILING})
+AM_CONDITIONAL([ENABLE_PROFILING], test x"${ENABLE_PROFILING}" = "xyes")
+
+if test x"${ENABLE_PROFILING}" = "xyes"; then
+ AC_DEFINE([ENABLE_PROFILING], 1, [enable profiling])
+fi
dnl check for instruction scheduler
AC_CHECK_HEADERS([zlib.h],, [AC_MSG_ERROR(cannot find zlib.h)])
AC_CHECK_LIB(z, inflate,, [AC_MSG_ERROR(cannot find libz)])
AC_DEFINE([ENABLE_ZLIB], 1, [use zlib])
- VM_ZIP_STRING=vm.zip
-else
- VM_ZIP_STRING=classes/
fi
-AC_DEFINE_UNQUOTED(VM_ZIP_STRING, "${VM_ZIP_STRING}", [define to the string base name of the VM zip file])
-AC_SUBST(VM_ZIP_STRING)
AM_CONDITIONAL([ENABLE_ZLIB], test x"${ENABLE_ZLIB}" = "xyes")
+dnl check if a libjvm.so should be built
+AC_MSG_CHECKING(whether to build a libjvm.so)
+AC_ARG_ENABLE([libjvm],
+ [AS_HELP_STRING(--disable-libjvm,build a libjvm.so [[default=yes]])],
+ [case "${enableval}" in
+ no) ENABLE_LIBJVM=no;;
+ *) ENABLE_LIBJVM=yes;;
+ esac],
+ [ENABLE_LIBJVM=yes])
+AC_MSG_RESULT(${ENABLE_LIBJVM})
+AM_CONDITIONAL([ENABLE_LIBJVM], test x"${ENABLE_LIBJVM}" = "xyes")
+AC_SUBST(ENABLE_LIBJVM)
+
+if test x"${ENABLE_LIBJVM}" = "xyes"; then
+ AC_DEFINE([ENABLE_LIBJVM], 1, [enable libjvm.so])
+
+ dnl set AC_ENABLE_SHARED and AC_DISABLE_STATIC properly
+ enable_shared=yes
+ enable_static=no
+else
+ enable_shared=no
+ enable_static=yes
+fi
+
+dnl libtool stuff
+AC_LIBTOOL_DLOPEN
+AC_PROG_LIBTOOL
+
+
dnl check if CACAO should be linked statically
AC_MSG_CHECKING(whether to link CACAO statically)
AC_ARG_ENABLE([staticvm],
[AS_HELP_STRING(--enable-staticvm,link CACAO statically [[default=no]])],
[case "${enableval}" in
- yes) ENABLE_STATICVM=yes;;
+ yes) ENABLE_STATICVM=yes
+ AC_DEFINE([ENABLE_STATICVM], 1, [link CACAO statically])
+ ;;
*) ENABLE_STATICVM=no;;
esac],
[ENABLE_STATICVM=no])
AC_MSG_RESULT(${ENABLE_STATICVM})
-
-if test x"${ENABLE_STATICVM}" = "xyes"; then
- AC_DEFINE([ENABLE_STATICVM], 1, [link CACAO statically])
-fi
AM_CONDITIONAL([ENABLE_STATICVM], test x"${ENABLE_STATICVM}" = "xyes")
AC_SUBST(ENABLE_STATICVM)
+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)
+
+
dnl is GNU classpath installed somewhere different
AC_MSG_CHECKING(where GNU Classpath is installed)
AC_ARG_WITH([classpath-prefix],
AC_DEFINE_UNQUOTED([CLASSPATH_PREFIX], "${CLASSPATH_PREFIX}", [GNU Classpath installation directory])
AC_SUBST(CLASSPATH_PREFIX)
+
+dnl where is GNU Classpath's glibj.zip
+AC_MSG_CHECKING(where GNU Classpath's glibj.zip is installed)
+AC_ARG_WITH([classpath-glibj-zip],
+ [AS_HELP_STRING(--with-classpath-glibj-zip,path to GNU Classpath's glibj.zip (includes the name of the file and may be flat) [[default=/usr/local/classpath/share/classpath/glibj.zip]])],
+ [CLASSPATH_GLIBJ_ZIP=${withval}],
+ [CLASSPATH_GLIBJ_ZIP=${CLASSPATH_PREFIX}/share/classpath/glibj.zip])
+AC_MSG_RESULT(${CLASSPATH_GLIBJ_ZIP})
+AC_DEFINE_UNQUOTED([CLASSPATH_GLIBJ_ZIP], "${CLASSPATH_GLIBJ_ZIP}", [GNU Classpath's glibj.zip])
+AC_SUBST(CLASSPATH_GLIBJ_ZIP)
+
+
+dnl where are the GNU Classpath libraries installed
AC_MSG_CHECKING(where GNU Classpath libraries are installed)
AC_ARG_WITH([classpath-libdir],
[AS_HELP_STRING(--with-classpath-libdir=<dir>,installation directory of GNU Classpath libraries [[default=/usr/local/classpath/lib]])],
AC_DEFINE_UNQUOTED([CLASSPATH_LIBDIR], "${CLASSPATH_LIBDIR}", [GNU Classpath libraries installation directory])
AC_SUBST(CLASSPATH_LIBDIR)
-AC_CHECK_HEADER([${CLASSPATH_PREFIX}/include/jni.h],
- [AC_DEFINE_UNQUOTED([CLASSPATH_JNI_H], "${CLASSPATH_PREFIX}/include/jni.h", [GNU Classpath jni.h header])],
+
+dnl where are the GNU Classpath headers installed
+AC_MSG_CHECKING(where GNU Classpath headers are installed)
+AC_ARG_WITH([classpath-includedir],
+ [AS_HELP_STRING(--with-classpath-includedir=<dir>,installation directory of GNU Classpath headers [[default=/usr/local/classpath/include]])],
+ [CLASSPATH_INCLUDEDIR=${withval}],
+ [CLASSPATH_INCLUDEDIR=${CLASSPATH_PREFIX}/include])
+AC_MSG_RESULT(${CLASSPATH_INCLUDEDIR})
+
+AC_CHECK_HEADER([${CLASSPATH_INCLUDEDIR}/jni.h],
+ [AC_DEFINE_UNQUOTED([CLASSPATH_JNI_H], "${CLASSPATH_INCLUDEDIR}/jni.h", [GNU Classpath jni.h header])],
[AC_MSG_ERROR(cannot find jni.h)])
AC_SUBST(WITH_STATIC_CLASSPATH)
-dnl Maybe the user has Classpath installed 'flat'.
-AC_ARG_WITH([flat-classpath], [AS_HELP_STRING(--with-flat-classpath, GNU Classpath is not zipped in the install directory)])
-if test x"$with_flat_classpath" = "x"; then
- GLIBJ_ZIP_STRING=glibj.zip
-else
- GLIBJ_ZIP_STRING=
-fi
-AC_SUBST(GLIBJ_ZIP_STRING)
-AC_DEFINE_UNQUOTED(GLIBJ_ZIP_STRING, "$GLIBJ_ZIP_STRING", [define to the string base name of the classpath zip file])
-
-
dnl check for some programs we need
AC_PROG_JAVAC
AC_PROG_JAR
-dnl now configure subpackages
-dnl the export is not my favorite (is there another way?)
-export CFLAGS
-AC_CONFIG_SUBDIRS(src/boehm-gc)
+dnl finally pass CFLAGS to Makefiles via AM_CFLAGS
+CFLAGS=$OPT_CFLAGS
+AM_CFLAGS=$ARCH_CFLAGS
+AC_SUBST(AM_CFLAGS)
AC_CONFIG_FILES([Makefile]
[src/native/vm/Makefile]
[src/scripts/Makefile]
[src/scripts/java]
+ [src/scripts/rmic]
[src/scripts/rmiregistry]
[src/threads/Makefile]
- [src/threads/green/Makefile]
[src/threads/native/Makefile]
+ [src/threads/none/Makefile]
[src/toolbox/Makefile]
[src/vm/Makefile]
[src/vm/jit/Makefile]
[src/vm/jit/alpha/freebsd/Makefile]
[src/vm/jit/alpha/linux/Makefile]
[src/vm/jit/i386/Makefile]
+ [src/vm/jit/i386/darwin/Makefile]
[src/vm/jit/i386/freebsd/Makefile]
[src/vm/jit/i386/linux/Makefile]
+ [src/vm/jit/ifconv/Makefile]
[src/vm/jit/intrp/Makefile]
[src/vm/jit/inline/Makefile]
[src/vm/jit/loop/Makefile]
[src/vm/jit/mips/Makefile]
[src/vm/jit/mips/irix/Makefile]
[src/vm/jit/mips/linux/Makefile]
+ [src/vm/jit/optimizing/Makefile]
[src/vm/jit/powerpc/Makefile]
[src/vm/jit/powerpc/darwin/Makefile]
[src/vm/jit/powerpc/linux/Makefile]
+ [src/vm/jit/powerpc/netbsd/Makefile]
+ [src/vm/jit/powerpc64/Makefile]
+ [src/vm/jit/powerpc64/linux/Makefile]
[src/vm/jit/profile/Makefile]
[src/vm/jit/schedule/Makefile]
+ [src/vm/jit/sparc64/Makefile]
+ [src/vm/jit/sparc64/linux/Makefile]
[src/vm/jit/tools/Makefile]
[src/vm/jit/verify/Makefile]
[src/vm/jit/x86_64/Makefile]
[tests/regression/codepatching/Makefile]
[tests/regression/native/Makefile])
+
+dnl now configure subpackages with OPT_CFLAGS and ARCH_CFLAGS
+export OPT_CFLAGS
+export ARCH_CFLAGS
+AC_CONFIG_SUBDIRS(src/boehm-gc)
+
+
AC_OUTPUT