2011-10-04 14:07:46 +00:00
|
|
|
# DESCRIPTION: Process this file with autoconf to produce a configure script.
|
|
|
|
#
|
2017-01-15 17:09:59 +00:00
|
|
|
# Copyright 2003-2017 by Wilson Snyder. Verilator is free software; you can
|
2011-10-04 14:07:46 +00:00
|
|
|
# redistribute it and/or modify it under the terms of either the GNU Lesser
|
|
|
|
# General Public License Version 3 or the Perl Artistic License Version 2.0.
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2012-09-04 00:32:32 +00:00
|
|
|
#AC_INIT([Verilator],[#.### YYYY-MM-DD])
|
|
|
|
#AC_INIT([Verilator],[#.### devel])
|
2017-04-02 12:43:53 +00:00
|
|
|
AC_INIT([Verilator],[3.902 2017-04-02])
|
2015-08-13 01:40:55 +00:00
|
|
|
# When releasing, also update header of Changes file
|
|
|
|
|
2006-12-18 19:20:45 +00:00
|
|
|
AC_CONFIG_HEADER(src/config_build.h)
|
2015-05-14 01:21:29 +00:00
|
|
|
AC_CONFIG_FILES(Makefile src/Makefile src/Makefile_obj include/verilated.mk include/verilated_config.h verilator.pc)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-05 13:50:14 +00:00
|
|
|
AC_MSG_RESULT([configuring for $PACKAGE_STRING])
|
|
|
|
|
2011-10-07 10:48:40 +00:00
|
|
|
# Special Substitutions - CFG_WITH_DEFENV
|
2016-11-19 01:31:41 +00:00
|
|
|
AC_MSG_CHECKING(whether to use hardcoded paths)
|
2011-10-04 14:07:46 +00:00
|
|
|
AC_ARG_ENABLE([defenv],
|
|
|
|
[AS_HELP_STRING([--disable-defenv],
|
|
|
|
[disable using some hardcoded data paths extracted from some default environment variables (the default is to use hardcoded paths)])],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_WITH_DEFENV=yes ;;
|
|
|
|
no) CFG_WITH_DEFENV=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value ${enableval} for --disable-defenv]) ;;
|
|
|
|
esac],
|
|
|
|
CFG_WITH_DEFENV=yes)
|
2008-03-18 20:26:37 +00:00
|
|
|
AC_SUBST(CFG_WITH_DEFENV)
|
2011-10-07 10:48:40 +00:00
|
|
|
AC_MSG_RESULT($CFG_WITH_DEFENV)
|
|
|
|
|
|
|
|
# Special Substitutions - CFG_WITH_CCWARN
|
|
|
|
AC_MSG_CHECKING(whether to show and stop on compilation warnings)
|
|
|
|
AC_ARG_ENABLE([ccwarn],
|
|
|
|
[AS_HELP_STRING([--enable-ccwarn],
|
|
|
|
[enable showing and stopping on compilation warnings])],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_WITH_CCWARN=yes ;;
|
|
|
|
no) CFG_WITH_CCWARN=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value ${enableval} for --enable-ccwarn]) ;;
|
|
|
|
esac],
|
|
|
|
[case "x${VERILATOR_AUTHOR_SITE}" in
|
|
|
|
x) CFG_WITH_CCWARN=no ;;
|
|
|
|
*) CFG_WITH_CCWARN=yes ;;
|
|
|
|
esac]
|
|
|
|
)
|
|
|
|
AC_SUBST(CFG_WITH_CCWARN)
|
|
|
|
AC_MSG_RESULT($CFG_WITH_CCWARN)
|
|
|
|
|
|
|
|
# Special Substitutions - CFG_WITH_LONGTESTS
|
|
|
|
AC_MSG_CHECKING(whether to run long tests)
|
|
|
|
AC_ARG_ENABLE([longtests],
|
|
|
|
[AS_HELP_STRING([--enable-longtests],
|
|
|
|
[enable running long developer tests])],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_WITH_LONGTESTS=yes ;;
|
|
|
|
no) CFG_WITH_LONGTESTS=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value ${enableval} for --enable-longtests]) ;;
|
|
|
|
esac],
|
|
|
|
[case "x${VERILATOR_AUTHOR_SITE}" in
|
|
|
|
x) CFG_WITH_LONGTESTS=no ;;
|
|
|
|
*) CFG_WITH_LONGTESTS=yes ;;
|
|
|
|
esac]
|
|
|
|
)
|
|
|
|
AC_SUBST(CFG_WITH_LONGTESTS)
|
|
|
|
AC_MSG_RESULT($CFG_WITH_LONGTESTS)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Compiler flags
|
2008-06-24 18:50:34 +00:00
|
|
|
CFLAGS=-I${includedir}
|
|
|
|
CPPFLAGS=-I${includedir}
|
|
|
|
CXXFLAGS=-I${includedir}
|
|
|
|
LDFLAGS=-L${libdir}
|
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for programs.
|
2006-08-26 11:35:28 +00:00
|
|
|
AC_PROG_CC
|
|
|
|
AC_PROG_CXX
|
|
|
|
AC_PROG_INSTALL
|
2008-06-12 01:00:42 +00:00
|
|
|
|
|
|
|
AC_LANG_PUSH(C++)
|
|
|
|
AC_MSG_CHECKING([that C++ compiler can compile simple program])
|
2011-10-04 12:48:37 +00:00
|
|
|
AC_RUN_IFELSE(
|
|
|
|
[AC_LANG_SOURCE([int main() { return 0; }])],
|
2008-06-12 01:00:42 +00:00
|
|
|
AC_MSG_RESULT(yes),
|
2011-10-04 12:48:37 +00:00
|
|
|
AC_MSG_RESULT(no);AC_MSG_ERROR([a working C++ compiler is required]),
|
|
|
|
AC_MSG_RESULT(yes))
|
2008-06-12 01:00:42 +00:00
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
AC_PATH_PROG(PERL,perl)
|
2007-04-24 17:03:52 +00:00
|
|
|
if test "x$PERL" = "x" ; then
|
|
|
|
AC_MSG_ERROR([Cannot find "perl" in your PATH, please install it])
|
|
|
|
fi
|
2006-09-25 15:58:17 +00:00
|
|
|
AC_PATH_PROG(LEX,flex)
|
2007-04-24 17:03:52 +00:00
|
|
|
if test "x$LEX" = "x" ; then
|
|
|
|
AC_MSG_ERROR([Cannot find "flex" in your PATH, please install it])
|
|
|
|
fi
|
|
|
|
AC_PATH_PROG(YACC,bison)
|
|
|
|
if test "x$YACC" = "x" ; then
|
|
|
|
AC_MSG_ERROR([Cannot find "bison" in your PATH, please install it])
|
|
|
|
fi
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for libraries.
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for typedefs, structures
|
2006-08-26 11:35:28 +00:00
|
|
|
AC_CHECK_TYPE(size_t,unsigned int)
|
|
|
|
AC_TYPE_SIZE_T
|
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for compiler characteristics.
|
2006-08-26 11:35:28 +00:00
|
|
|
AC_C_INLINE
|
|
|
|
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_DEFUN([_MY_CXX_CHECK_OPT],
|
|
|
|
[# _MY_CXX_CHECK_OPT(flag) -- Check if compiler supports specific options
|
|
|
|
ACO_SAVE_CXXFLAGS="$CXXFLAGS"
|
|
|
|
# -Werror needed otherwise unknown -Wno-div-by-zero won't report problems
|
2015-02-11 03:38:05 +00:00
|
|
|
CXXFLAGS="$CXXFLAGS $2 -Werror"
|
|
|
|
AC_MSG_CHECKING([whether $CXX accepts $2])
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_COMPILE_IFELSE(
|
|
|
|
[AC_LANG_PROGRAM([],[])],
|
2015-02-12 02:24:01 +00:00
|
|
|
[_my_result=yes
|
|
|
|
if test -s conftest.err; then
|
|
|
|
if grep -e "$2" conftest.err >/dev/null; then
|
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi],
|
2011-10-12 23:04:57 +00:00
|
|
|
[_my_result=no])
|
2016-11-19 00:27:29 +00:00
|
|
|
# GCC is annoying, trying to be helpful, it postpones unknown -Wno-
|
|
|
|
# options if there's no error We want to see them regardless, so try
|
|
|
|
# forcing an error and see if we get a gcc warning
|
|
|
|
AC_COMPILE_IFELSE(
|
|
|
|
[AC_LANG_PROGRAM([[an_error "intentional-error-for-test.h"
|
|
|
|
]],[])],
|
|
|
|
[], # Ignore ok exit
|
|
|
|
[if test -s conftest.err; then
|
|
|
|
if grep -e "$2" conftest.err >/dev/null; then
|
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi])
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_MSG_RESULT($_my_result)
|
|
|
|
if test "$_my_result" = "yes" ; then
|
2015-02-11 03:38:05 +00:00
|
|
|
$1="$$1 $2"
|
2011-10-12 23:04:57 +00:00
|
|
|
fi
|
|
|
|
CXXFLAGS="$ACO_SAVE_CXXFLAGS"
|
|
|
|
])# _MY_CXX_CHECK_OPT
|
|
|
|
|
2015-02-11 03:38:05 +00:00
|
|
|
# Flags for compiling Verilator internals including parser
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Wno-unused-parameter)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Wno-char-subscripts)
|
2016-02-09 03:16:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Wno-undefined-bool-conversion)
|
2015-02-11 03:38:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Qunused-arguments)
|
2016-05-14 21:56:04 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-fno-delete-null-pointer-checks)
|
2015-02-11 03:38:05 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_SRC)
|
|
|
|
|
|
|
|
# Flags for compiling Verilator parser
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-unused)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-parentheses-equality)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-null-conversion)
|
|
|
|
AC_SUBST(CFG_CXXFLAGS_PARSER)
|
|
|
|
|
|
|
|
# Flags for Verilated makefile
|
2011-10-12 23:04:57 +00:00
|
|
|
# For example, -Wno-div-by-zero isn't in 4.1.2
|
2015-02-11 03:38:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-char-subscripts)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-parentheses-equality)
|
2011-10-12 23:04:57 +00:00
|
|
|
# Random code often does / 0. Unfortunately VL_DIV_I(0,0) will warn
|
|
|
|
# without this flag, even though there's a conditional to prevent the divide.
|
2011-10-21 01:13:42 +00:00
|
|
|
# We still don't add no-div-by-zero as it throws message to stdout, though doesn't die.
|
|
|
|
#_MY_CXX_CHECK_OPT(-Wno-div-by-zero)
|
2015-02-11 03:38:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-sign-compare)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-uninitialized)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-unused-but-set-variable)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-unused-parameter)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Wno-unused-variable)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-fbracket-depth=4096)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-Qunused-arguments)
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_NO_UNUSED)
|
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for library functions.
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for system services
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Other install directories
|
2006-08-26 11:35:28 +00:00
|
|
|
pkgdatadir=${datadir}/verilator
|
|
|
|
AC_SUBST(pkgdatadir)
|
2015-05-14 01:21:29 +00:00
|
|
|
pkgconfigdir=${datadir}/pkgconfig
|
|
|
|
AC_SUBST(pkgconfigdir)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-10-04 12:48:37 +00:00
|
|
|
AC_OUTPUT
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
AC_MSG_RESULT([])
|
2011-10-04 14:07:46 +00:00
|
|
|
AC_MSG_RESULT([Now type 'make' (or sometimes 'gmake') to build Verilator.])
|
2006-08-26 11:35:28 +00:00
|
|
|
AC_MSG_RESULT([])
|