2011-10-04 14:07:46 +00:00
|
|
|
# DESCRIPTION: Process this file with autoconf to produce a configure script.
|
|
|
|
#
|
2020-03-21 15:24:24 +00:00
|
|
|
# Copyright 2003-2020 by Wilson Snyder. Verilator is free software; you
|
|
|
|
# can redistribute it and/or modify it under the terms of either the GNU Lesser
|
2011-10-04 14:07:46 +00:00
|
|
|
# General Public License Version 3 or the Perl Artistic License Version 2.0.
|
2020-03-21 15:24:24 +00:00
|
|
|
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-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])
|
2020-05-03 15:18:53 +00:00
|
|
|
AC_INIT([Verilator],[4.035 devel],
|
2019-11-08 03:33:59 +00:00
|
|
|
[https://verilator.org],
|
|
|
|
[verilator],[https://verilator.org])
|
2015-08-13 01:40:55 +00:00
|
|
|
# When releasing, also update header of Changes file
|
2017-09-11 23:18:58 +00:00
|
|
|
# and commit using "devel release" or "Version bump" message
|
2015-08-13 01:40:55 +00:00
|
|
|
|
2006-12-18 19:20:45 +00:00
|
|
|
AC_CONFIG_HEADER(src/config_build.h)
|
2019-10-17 23:44:10 +00:00
|
|
|
AC_CONFIG_FILES(Makefile docs/Makefile src/Makefile src/Makefile_obj include/verilated.mk include/verilated_config.h verilator.pc verilator-config.cmake verilator-config-version.cmake)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2020-05-05 12:46:24 +00:00
|
|
|
# Version
|
2011-10-05 13:50:14 +00:00
|
|
|
AC_MSG_RESULT([configuring for $PACKAGE_STRING])
|
2020-05-05 12:46:24 +00:00
|
|
|
PACKAGE_VERSION_NUMBER=`AS_ECHO("$PACKAGE_VERSION") | sed 's/ .*//g'`
|
|
|
|
AC_SUBST(PACKAGE_VERSION_NUMBER)
|
2011-10-05 13:50:14 +00:00
|
|
|
|
2018-07-04 01:34:50 +00:00
|
|
|
# Ignore automake flags passed by Ubuntu builds
|
|
|
|
AC_ARG_ENABLE([dependency-tracking],
|
|
|
|
[AS_HELP_STRING([--disable-dependency-tracking], [ignored])])
|
|
|
|
AC_ARG_ENABLE([maintainer-mode],
|
|
|
|
[AS_HELP_STRING([--enable-maintainer-mode], [ignored])])
|
|
|
|
AC_ARG_ENABLE([silent-rules],
|
|
|
|
[AS_HELP_STRING([--disable-silent-rules], [ignored])])
|
|
|
|
|
2020-02-01 00:13:55 +00:00
|
|
|
# Flag to enable linking specific libraries statically
|
|
|
|
AC_MSG_CHECKING(whether to perform partial static linking of Verilator binary)
|
|
|
|
AC_ARG_ENABLE([partial-static],
|
|
|
|
[AS_HELP_STRING([--disable-partial-static],
|
|
|
|
[By default, for Verilation peformance, Verilator
|
|
|
|
is linked against some of its dependencies
|
|
|
|
statically. Use this to link the Verilator binary
|
|
|
|
fully dynamically.])],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_ENABLE_PARTIAL_STATIC=yes ;;
|
|
|
|
no) CFG_ENABLE_PARTIAL_STATIC=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value '${enableval}' for --disable-partial-static]) ;;
|
|
|
|
esac],
|
|
|
|
CFG_ENABLE_PARTIAL_STATIC=yes)
|
|
|
|
AC_MSG_RESULT($CFG_ENABLE_PARTIAL_STATIC)
|
|
|
|
|
2020-01-23 22:32:19 +00:00
|
|
|
# Flag to enable linking Verilator with tcmalloc if available
|
2020-02-01 00:13:55 +00:00
|
|
|
AC_MSG_CHECKING(whether to use tcmalloc)
|
2020-01-23 22:32:19 +00:00
|
|
|
AC_ARG_ENABLE([tcmalloc],
|
|
|
|
[AS_HELP_STRING([--enable-tcmalloc],
|
2020-02-01 00:13:55 +00:00
|
|
|
[Use libtcmalloc_minimal for faster dynamic memory
|
2020-01-31 00:52:58 +00:00
|
|
|
management in Verilator binary@<:@default=check@:>@])],
|
2020-01-23 22:32:19 +00:00
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_WITH_TCMALLOC=yes ;;
|
|
|
|
no) CFG_WITH_TCMALLOC=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value '${enableval}' for --enable-tcmalloc]) ;;
|
|
|
|
esac],
|
|
|
|
[CFG_WITH_TCMALLOC=check;])
|
2020-02-01 00:13:55 +00:00
|
|
|
AC_MSG_RESULT($CFG_WITH_TCMALLOC)
|
2020-01-23 22:32:19 +00:00
|
|
|
|
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],
|
2020-01-31 00:52:58 +00:00
|
|
|
[disable using some hardcoded data paths extracted
|
|
|
|
from some default environment variables (the default
|
|
|
|
is to use hardcoded paths) in Verilator binary])],
|
2011-10-04 14:07:46 +00:00
|
|
|
[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],
|
2020-01-31 00:52:58 +00:00
|
|
|
[enable showing and stopping on compilation warnings
|
|
|
|
in Verilator binrary and Verilated makefiles])],
|
2011-10-07 10:48:40 +00:00
|
|
|
[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]
|
2017-10-07 19:25:23 +00:00
|
|
|
)
|
2011-10-07 10:48:40 +00:00
|
|
|
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]
|
2017-10-07 19:25:23 +00:00
|
|
|
)
|
2011-10-07 10:48:40 +00:00
|
|
|
AC_SUBST(CFG_WITH_LONGTESTS)
|
|
|
|
AC_MSG_RESULT($CFG_WITH_LONGTESTS)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2018-06-26 11:33:55 +00:00
|
|
|
# CFG_WITH_PREC11
|
|
|
|
AC_MSG_CHECKING(whether allow pre-C++11)
|
|
|
|
AC_ARG_ENABLE([prec11],
|
|
|
|
[AS_HELP_STRING([--enable-prec11],
|
2020-01-31 00:52:58 +00:00
|
|
|
[enable pre-C++11 compilers for Verilator binary
|
|
|
|
and Verilated makefiles])],
|
2018-06-26 11:33:55 +00:00
|
|
|
[case "${enableval}" in
|
|
|
|
yes) CFG_WITH_PREC11=yes ;;
|
|
|
|
no) CFG_WITH_PREC11=no ;;
|
|
|
|
*) AC_MSG_ERROR([bad value ${enableval} for --enable-prec11]) ;;
|
|
|
|
esac],
|
|
|
|
[CFG_WITH_PREC11=no;]
|
|
|
|
)
|
|
|
|
AC_SUBST(CFG_WITH_PREC11)
|
|
|
|
AC_MSG_RESULT($CFG_WITH_PREC11)
|
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Compiler flags
|
2019-07-06 17:02:36 +00:00
|
|
|
CFLAGS+=" -I${includedir}"
|
|
|
|
CPPFLAGS+=" -I${includedir}"
|
|
|
|
CXXFLAGS+=" -I${includedir}"
|
|
|
|
LDFLAGS+=" -L${libdir}"
|
2008-06-24 18:50:34 +00:00
|
|
|
|
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++)
|
2018-02-07 23:58:21 +00:00
|
|
|
cxx_version=$($CXX --version | head -1)
|
|
|
|
AC_MSG_RESULT([compiler is $CXX --version = $cxx_version])
|
2008-06-12 01:00:42 +00:00
|
|
|
AC_MSG_CHECKING([that C++ compiler can compile simple program])
|
2011-10-04 12:48:37 +00:00
|
|
|
AC_RUN_IFELSE(
|
2017-10-07 19:25:23 +00:00
|
|
|
[AC_LANG_SOURCE([int main() { return 0; }])],
|
|
|
|
AC_MSG_RESULT(yes),
|
|
|
|
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
|
|
|
|
2020-04-05 20:10:33 +00:00
|
|
|
AC_CHECK_PROG(OBJCACHE,ccache,ccache)
|
|
|
|
if test "x$OBJCACHE" != "x" ; then
|
|
|
|
objcache_version=$($OBJCACHE --version | head -1)
|
|
|
|
AC_MSG_RESULT([objcache is $OBJCACHE --version = $objcache_version])
|
|
|
|
fi
|
|
|
|
|
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
|
|
|
|
|
2017-10-14 17:20:58 +00:00
|
|
|
AC_LINK_IFELSE(
|
2017-10-15 14:36:50 +00:00
|
|
|
[AC_LANG_PROGRAM([#include <new>], [[int* a=new int; delete a; ]])],
|
2017-10-14 17:20:58 +00:00
|
|
|
[], [AC_MSG_ERROR([$CXX does not seem to successfully compile a simple C++ program])])
|
|
|
|
|
2017-10-07 19:25:23 +00:00
|
|
|
AC_DEFUN([_MY_CXX_CHECK_FLAG],
|
|
|
|
[# _MY_CXX_CHECK_FLAG(flag) -- Check if compiler supports specific options
|
|
|
|
# Set $_my_result appropriately
|
2011-10-12 23:04:57 +00:00
|
|
|
ACO_SAVE_CXXFLAGS="$CXXFLAGS"
|
|
|
|
# -Werror needed otherwise unknown -Wno-div-by-zero won't report problems
|
2017-10-14 16:56:16 +00:00
|
|
|
# new/delete is needed to find -faligned-new link problem on Darwin
|
2017-10-07 19:25:23 +00:00
|
|
|
CXXFLAGS="$CXXFLAGS $1 -Werror"
|
|
|
|
AC_MSG_CHECKING([whether $CXX accepts $1])
|
2017-10-14 16:56:16 +00:00
|
|
|
AC_LINK_IFELSE(
|
2017-10-15 14:36:50 +00:00
|
|
|
[AC_LANG_PROGRAM([#include <new>], [[int* a=new int; delete a; ]])],
|
2017-10-07 19:25:23 +00:00
|
|
|
[_my_result=yes
|
|
|
|
if test -s conftest.err; then
|
|
|
|
if grep -e "$1" conftest.err >/dev/null; then
|
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi],
|
|
|
|
[_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"
|
2017-10-07 19:25:23 +00:00
|
|
|
]],[])],
|
2016-11-19 00:27:29 +00:00
|
|
|
[], # Ignore ok exit
|
|
|
|
[if test -s conftest.err; then
|
2017-10-07 19:25:23 +00:00
|
|
|
if grep -e "$1" conftest.err >/dev/null; then
|
2016-11-19 00:27:29 +00:00
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi])
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_MSG_RESULT($_my_result)
|
2017-10-07 19:25:23 +00:00
|
|
|
CXXFLAGS="$ACO_SAVE_CXXFLAGS"
|
|
|
|
])
|
|
|
|
|
|
|
|
AC_DEFUN([_MY_CXX_CHECK_SET],
|
|
|
|
[# _MY_CXX_CHECK_SET(variable,flag) -- Check if compiler supports specific options
|
2017-10-08 01:29:57 +00:00
|
|
|
# If it does, set variable to flag, only if not previously set
|
|
|
|
if test "$$1" = ""; then
|
|
|
|
_MY_CXX_CHECK_FLAG($2)
|
|
|
|
if test "$_my_result" = "yes" ; then
|
|
|
|
$1="$2"
|
|
|
|
fi
|
2011-10-12 23:04:57 +00:00
|
|
|
fi
|
2017-10-07 19:25:23 +00:00
|
|
|
])
|
|
|
|
|
|
|
|
AC_DEFUN([_MY_CXX_CHECK_OPT],
|
|
|
|
[# _MY_CXX_CHECK_OPT(flag) -- Check if compiler supports specific options
|
|
|
|
# If it does, append flag to variable
|
|
|
|
_MY_CXX_CHECK_FLAG($2)
|
|
|
|
if test "$_my_result" = "yes" ; then
|
|
|
|
$1="$$1 $2"
|
|
|
|
fi
|
|
|
|
])
|
2011-10-12 23:04:57 +00:00
|
|
|
|
2018-05-13 23:47:35 +00:00
|
|
|
AC_DEFUN([_MY_LDLIBS_CHECK_FLAG],
|
|
|
|
[# _MY_LDLIBS_CHECK_FLAG(flag) -- Check if linker supports specific options
|
|
|
|
# Set $_my_result appropriately
|
|
|
|
ACO_SAVE_LIBS="$LIBS"
|
|
|
|
LIBS="$LIBS $1"
|
|
|
|
AC_MSG_CHECKING([whether $CXX linker accepts $1])
|
|
|
|
AC_LINK_IFELSE(
|
|
|
|
[AC_LANG_PROGRAM([[]])],
|
|
|
|
[_my_result=yes
|
|
|
|
if test -s conftest.err; then
|
|
|
|
if grep -e "$1" conftest.err >/dev/null; then
|
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi],
|
|
|
|
[_my_result=no])
|
|
|
|
AC_MSG_RESULT($_my_result)
|
|
|
|
LIBS="$ACO_SAVE_LIBS"
|
|
|
|
])
|
|
|
|
|
2020-01-23 22:32:19 +00:00
|
|
|
AC_DEFUN([_MY_LDLIBS_CHECK_IFELSE],
|
|
|
|
[# _MY_LDLIBS_CHECK_IFELSE(flag,action-if-supported,action-if-not-supported)
|
|
|
|
# Check if linker supports specific flag, if it does do action-if-supported
|
|
|
|
# otherwise do action-if-not-supported
|
|
|
|
_MY_LDLIBS_CHECK_FLAG($1)
|
2018-05-13 23:47:35 +00:00
|
|
|
if test "$_my_result" = "yes" ; then
|
2020-01-23 22:32:19 +00:00
|
|
|
true
|
|
|
|
$2
|
|
|
|
else
|
|
|
|
true
|
|
|
|
$3
|
2018-05-13 23:47:35 +00:00
|
|
|
fi
|
|
|
|
])
|
|
|
|
|
2020-01-23 22:32:19 +00:00
|
|
|
AC_DEFUN([_MY_LDLIBS_CHECK_OPT],
|
|
|
|
[# _MY_LDLIBS_CHECK_OPT(variable, flag) -- Check if linker supports specific
|
|
|
|
# options. If it does, append flag to variable.
|
|
|
|
_MY_LDLIBS_CHECK_IFELSE($2, $1="$$1 $2")
|
|
|
|
])
|
|
|
|
|
2017-10-08 01:29:57 +00:00
|
|
|
# Flag to select newest language standard supported
|
|
|
|
# Macros work such that first option that passes is the one we take
|
2018-09-03 12:19:43 +00:00
|
|
|
# gnu++17 code is clean, but SystemC in 2018 doesn't link with it (bug1339)
|
2017-10-08 01:29:57 +00:00
|
|
|
# gnu++14 is the newest that Verilator supports
|
|
|
|
# std++03 is the oldest that Verilator supports
|
2018-09-03 12:19:43 +00:00
|
|
|
#_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=gnu++17)
|
2017-10-08 01:29:57 +00:00
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=gnu++14)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=gnu++11)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=gnu++03)
|
2018-09-03 12:19:43 +00:00
|
|
|
#_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=c++17)
|
2017-10-08 01:29:57 +00:00
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=c++14)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=c++11)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_NEWEST,-std=c++03)
|
|
|
|
AC_SUBST(CFG_CXXFLAGS_STD_NEWEST)
|
|
|
|
# And likewise oldest standard (same list above, backwards)
|
|
|
|
# This is used for internal testing
|
2018-09-18 01:47:35 +00:00
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=c++03)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=c++11)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=c++14)
|
2018-09-03 12:19:43 +00:00
|
|
|
#_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=std++17)
|
2017-10-08 01:29:57 +00:00
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=gnu++03)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=gnu++11)
|
|
|
|
_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=gnu++14)
|
2018-09-03 12:19:43 +00:00
|
|
|
#_MY_CXX_CHECK_SET(CFG_CXXFLAGS_STD_OLDEST,-std=gnu++17)
|
2017-10-08 01:29:57 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_STD_OLDEST)
|
|
|
|
|
2017-09-15 03:28:02 +00:00
|
|
|
# Flags for compiling Verilator internals including parser, and Verilated files
|
|
|
|
# These turn on extra warnings and are only used with 'configure --enable-ccwarn'
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_WEXTRA,-Wextra)
|
2017-10-11 23:01:37 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_WEXTRA,-Wfloat-conversion)
|
2017-09-15 03:28:02 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_WEXTRA,-Wlogical-op)
|
2017-10-21 20:41:43 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_WEXTRA,-Wthread-safety)
|
2017-09-15 03:28:02 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_WEXTRA)
|
|
|
|
|
|
|
|
# Flags for compiling Verilator internals including parser always
|
2015-02-11 03:38:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Qunused-arguments)
|
2017-08-14 23:59:21 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-faligned-new)
|
2017-08-15 00:15:24 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Wno-unused-parameter)
|
2017-09-15 03:28:02 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-Wno-shadow)
|
2020-02-01 00:13:55 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_SRC)
|
2015-02-11 03:38:05 +00:00
|
|
|
|
2017-09-15 03:28:02 +00:00
|
|
|
# Flags for compiling Verilator parser always (in addition to above CFG_CXXFLAGS_SRC)
|
2017-08-15 00:15:24 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-char-subscripts)
|
2015-02-11 03:38:05 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-null-conversion)
|
2017-08-15 00:15:24 +00:00
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-parentheses-equality)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_PARSER,-Wno-unused)
|
2015-02-11 03:38:05 +00:00
|
|
|
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
|
|
|
|
# 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)
|
2019-07-18 09:31:02 +00:00
|
|
|
# For some reason -faligned-new does not work under Travis w/ clang but the
|
|
|
|
# configure test doesn't catch this either
|
|
|
|
AS_IF([test "x$TRAVIS_COMPILER" != xclang], [_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,-faligned-new)])
|
2019-10-17 23:44:10 +00:00
|
|
|
CFG_CXX_FLAGS_CMAKE="-faligned-new"
|
|
|
|
m4_foreach([cflag],[
|
|
|
|
[-fbracket-depth=4096],
|
2019-10-18 00:43:45 +00:00
|
|
|
[-fcf-protection=none],
|
|
|
|
[-mno-cet],
|
2019-10-17 23:44:10 +00:00
|
|
|
[-Qunused-arguments],
|
|
|
|
[-Wno-bool-operation],
|
2020-04-25 15:29:42 +00:00
|
|
|
[-Wno-tautological-bitwise-compare],
|
2019-10-17 23:44:10 +00:00
|
|
|
[-Wno-parentheses-equality],
|
|
|
|
[-Wno-sign-compare],
|
|
|
|
[-Wno-uninitialized],
|
|
|
|
[-Wno-unused-but-set-variable],
|
|
|
|
[-Wno-unused-parameter],
|
|
|
|
[-Wno-unused-variable],
|
|
|
|
[-Wno-shadow]],[
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_NO_UNUSED,cflag)
|
|
|
|
# CMake will test what flags work itself, so pass all flags through to it
|
|
|
|
CFG_CXX_FLAGS_CMAKE="$CFG_CXX_FLAGS_CMAKE cflag"
|
|
|
|
])
|
2011-10-12 23:04:57 +00:00
|
|
|
AC_SUBST(CFG_CXXFLAGS_NO_UNUSED)
|
2019-10-17 23:44:10 +00:00
|
|
|
AC_SUBST(CFG_CXX_FLAGS_CMAKE)
|
2011-10-12 23:04:57 +00:00
|
|
|
|
2018-05-13 23:47:35 +00:00
|
|
|
# Find multithread linker flags
|
2019-10-17 23:44:10 +00:00
|
|
|
m4_foreach([ldflag], [
|
|
|
|
[-mt],
|
|
|
|
[-pthread],
|
|
|
|
[-lpthread],
|
|
|
|
[-latomic]],[
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LDLIBS_THREADS,ldflag)
|
|
|
|
# CMake will test what flags work itself, so pass all flags through to it
|
|
|
|
CFG_LDFLAGS_THREADS_CMAKE="$CFG_LDFLAGS_THREADS_CMAKE ldflag"
|
|
|
|
])
|
2018-05-13 23:47:35 +00:00
|
|
|
AC_SUBST(CFG_LDLIBS_THREADS)
|
2019-10-17 23:44:10 +00:00
|
|
|
AC_SUBST(CFG_LDFLAGS_THREADS_CMAKE)
|
2018-05-13 23:47:35 +00:00
|
|
|
|
2020-02-01 00:13:55 +00:00
|
|
|
# When linking partially statically
|
|
|
|
if test "$CFG_ENABLE_PARTIAL_STATIC" = "yes"; then
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LDFLAGS_SRC, -static-libgcc)
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LDFLAGS_SRC, -static-libstdc++)
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LDFLAGS_SRC, -Xlinker -gc-sections)
|
|
|
|
LTCMALLOC=-l:libtcmalloc_minimal.a
|
|
|
|
else
|
|
|
|
LTCMALLOC=-ltcmalloc_minimal
|
|
|
|
fi
|
|
|
|
AC_SUBST(CFG_LDFLAGS_SRC)
|
|
|
|
|
|
|
|
# The pthread library is required by tcmalloc, so add it if it exists. If it
|
|
|
|
# does not, the tcmalloc check below will fail anyway, and linking against
|
|
|
|
# pthreads is harmless otherwise.
|
2020-03-29 16:29:40 +00:00
|
|
|
CFG_LIBS="$LIBS $CFG_LIBS"
|
2020-02-01 00:13:55 +00:00
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LIBS, -lpthread)
|
|
|
|
|
2020-03-29 16:29:40 +00:00
|
|
|
# Check libraries for MingW
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LIBS, -lbcrypt)
|
|
|
|
_MY_LDLIBS_CHECK_OPT(CFG_LIBS, -lpsapi)
|
|
|
|
|
2020-01-23 22:32:19 +00:00
|
|
|
# Check if tcmalloc is available based on --enable-tcmalloc
|
|
|
|
_MY_LDLIBS_CHECK_IFELSE(
|
2020-02-01 00:13:55 +00:00
|
|
|
$LTCMALLOC,
|
2020-01-23 22:32:19 +00:00
|
|
|
[if test "$CFG_WITH_TCMALLOC" != "no"; then
|
2020-02-01 00:13:55 +00:00
|
|
|
CFG_LIBS="$LTCMALLOC $CFG_LIBS";
|
2020-01-23 22:32:19 +00:00
|
|
|
# If using tcmalloc, add some extra options to make the compiler not assume
|
|
|
|
# it is using it's own versions of the standard library functions
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-fno-builtin-malloc)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-fno-builtin-calloc)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-fno-builtin-realloc)
|
|
|
|
_MY_CXX_CHECK_OPT(CFG_CXXFLAGS_SRC,-fno-builtin-free)
|
|
|
|
fi],
|
|
|
|
[if test "$CFG_WITH_TCMALLOC" = "yes"; then
|
2020-02-01 00:13:55 +00:00
|
|
|
AC_MSG_ERROR([--enable-tcmalloc was given but test for ${LTCMALLOC} failed])
|
2020-01-23 22:32:19 +00:00
|
|
|
fi])
|
|
|
|
AC_SUBST(CFG_LIBS)
|
|
|
|
|
2017-10-27 01:48:45 +00:00
|
|
|
# Set CFG_WITH_THREADED if can support threading
|
|
|
|
AC_MSG_CHECKING(whether $CXX supports Verilated threads)
|
|
|
|
ACO_SAVE_CXXFLAGS="$CXXFLAGS"
|
|
|
|
CXXFLAGS="$CXXFLAGS $CFG_CXXFLAGS_STD_NEWEST $CFG_CXXFLAGS_NO_UNUSED"
|
|
|
|
AC_LINK_IFELSE(
|
|
|
|
[AC_LANG_PROGRAM([#include <thread>], [[ ]])],
|
|
|
|
[_my_result=yes
|
|
|
|
if test -s conftest.err; then
|
|
|
|
if grep -e "$1" conftest.err >/dev/null; then
|
|
|
|
_my_result=no
|
|
|
|
fi
|
|
|
|
fi],
|
|
|
|
[_my_result=no])
|
|
|
|
CFG_WITH_THREADED=$_my_result
|
|
|
|
AC_SUBST(CFG_WITH_THREADED)
|
|
|
|
AC_MSG_RESULT($CFG_WITH_THREADED)
|
2020-05-27 12:45:11 +00:00
|
|
|
CXXFLAGS="$ACO_SAVE_CXXFLAGS"
|
2017-10-27 01:48:45 +00:00
|
|
|
|
2018-06-26 11:33:55 +00:00
|
|
|
# Check compiler flag
|
|
|
|
if test "$CFG_WITH_THREADED" = "no" ; then
|
|
|
|
if test "$CFG_WITH_PREC11" = "no" ; then
|
|
|
|
AC_MSG_NOTICE([[]])
|
|
|
|
AC_MSG_ERROR([[the $CXX compiler appears to not support C++11.
|
|
|
|
|
|
|
|
Verilator plans to require a C++11 or newer compiler in a future release,
|
|
|
|
unless sufficient people report problems. Therefore, if you do not have a
|
|
|
|
C++11 compiler, please post a message to
|
|
|
|
https://www.veripool.org/boards/3/topics/2580-Verilator-Requiring-C-11-compiler
|
|
|
|
indicating your OS and when you think C++11 might be ok, and then rerun
|
|
|
|
configure with the --enable-prec11 argument. Thanks.]])
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2011-10-04 14:07:46 +00:00
|
|
|
# Checks for library functions.
|
2017-10-14 13:00:39 +00:00
|
|
|
AC_CHECK_MEMBER([struct stat.st_mtim.tv_nsec],
|
2017-10-14 16:56:16 +00:00
|
|
|
[AC_DEFINE([HAVE_STAT_NSEC],[1],[Defined if struct stat has st_mtim.tv_nsec])],
|
2017-10-14 13:00:39 +00:00
|
|
|
[], [#include <sys/stat.h>])
|
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([])
|