Fix config_build.h issues (#4380) (#4381)

This commit is contained in:
Andrew Miloradovsky 2023-07-27 09:42:35 +00:00 committed by GitHub
parent a5eccc199b
commit 106a9fe67f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 53 additions and 34 deletions

View File

@ -449,8 +449,8 @@ install-msg:
IN_WILD := ${srcdir}/*.in ${srcdir}/*/*.in IN_WILD := ${srcdir}/*.in ${srcdir}/*/*.in
# autoheader might not change config_build.h.in, so touch it # autoheader might not change config_package.h.in, so touch it
${srcdir}/config_build.h: ${srcdir}/config_build.h.in configure ${srcdir}/config_package.h: ${srcdir}/config_package.h.in configure
cd ${srcdir} && autoheader cd ${srcdir} && autoheader
touch $@ touch $@
Makefile: Makefile.in config.status $(IN_WILD) Makefile: Makefile.in config.status $(IN_WILD)

View File

@ -14,7 +14,7 @@ AC_INIT([Verilator],[5.013 devel],
[https://verilator.org], [https://verilator.org],
[verilator],[https://verilator.org]) [verilator],[https://verilator.org])
AC_CONFIG_HEADERS(src/config_build.h) AC_CONFIG_HEADERS(src/config_package.h)
AC_CONFIG_FILES(Makefile src/Makefile src/Makefile_obj include/verilated.mk include/verilated_config.h verilator.pc verilator-config.cmake verilator-config-version.cmake) AC_CONFIG_FILES(Makefile src/Makefile src/Makefile_obj include/verilated.mk include/verilated_config.h verilator.pc verilator-config.cmake verilator-config-version.cmake)
# Version # Version

View File

@ -13,6 +13,7 @@ Aliaksei Chapyzhenka
Ameya Vikram Singh Ameya Vikram Singh
Andreas Kuster Andreas Kuster
Andrei Kostovski Andrei Kostovski
Andrew Miloradovsky
Andrew Nolte Andrew Nolte
Anthony Donlon Anthony Donlon
Arkadiusz Kozdra Arkadiusz Kozdra

View File

@ -165,7 +165,7 @@ compiled on the different target system.
To support this, none of the files that Verilator produces will reference To support this, none of the files that Verilator produces will reference
any configure-generated build-system-specific files, such as any configure-generated build-system-specific files, such as
:file:`config.h` (which is renamed in Verilator to :file:`config_build.h` :file:`config.h` (which is renamed in Verilator to :file:`config_package.h`
to reduce confusion.) The disadvantage of this approach is that to reduce confusion.) The disadvantage of this approach is that
:file:`include/verilatedos.h` must self-detect the requirements of the :file:`include/verilatedos.h` must self-detect the requirements of the
target system, rather than using configure. target system, rather than using configure.

2
src/.gitignore vendored
View File

@ -1,6 +1,6 @@
*~ *~
*.old *.old
config_build.h config_package.h
Makefile Makefile
Makefile_obj Makefile_obj
.objcache* .objcache*

View File

@ -324,7 +324,7 @@ file(TO_NATIVE_PATH ${srcdir}/../bin/verilator_includer VERILATOR_INCLUDER)
file(TO_NATIVE_PATH ${srcdir}/vlcovgen VLCOVGEN) file(TO_NATIVE_PATH ${srcdir}/vlcovgen VLCOVGEN)
file(TO_NATIVE_PATH ${srcdir}/config_rev CONFIG_REV) file(TO_NATIVE_PATH ${srcdir}/config_rev CONFIG_REV)
configure_file(config_build.h.in config_build.h @ONLY) configure_file(config_package.h.in config_package.h @ONLY)
add_custom_command( add_custom_command(
OUTPUT V3Ast__gen_forward_class_decls.h V3Dfg__gen_forward_class_decls.h OUTPUT V3Ast__gen_forward_class_decls.h V3Dfg__gen_forward_class_decls.h

View File

@ -95,7 +95,7 @@ clean mostlyclean distclean maintainer-clean::
-rm -f .objcache* -rm -f .objcache*
distclean maintainer-clean:: distclean maintainer-clean::
-rm -f Makefile Makefile_obj config_build.h -rm -f Makefile Makefile_obj config_package.h
maintainer-clean:: maintainer-clean::
-rm -f config_rev.h -rm -f config_rev.h

View File

@ -19,8 +19,8 @@
// clang-format off // clang-format off
#include "config_build.h" #include "config_build.h"
#ifndef HAVE_CONFIG_BUILD #ifndef HAVE_CONFIG_PACKAGE
# error "Something failed during ./configure as config_build.h is incomplete. Perhaps you used autoreconf, don't." # error "Something failed during ./configure as config_package.h is incomplete. Perhaps you used autoreconf, don't."
#endif #endif
// clang-format on // clang-format on

View File

@ -896,7 +896,7 @@ void V3Options::notify() {
// V3 Options accessors // V3 Options accessors
string V3Options::version() VL_PURE { string V3Options::version() VL_PURE {
string ver = DTVERSION; string ver = PACKAGE_STRING;
ver += " rev " + cvtToStr(DTVERSION_rev); ver += " rev " + cvtToStr(DTVERSION_rev);
return ver; return ver;
} }

View File

@ -16,8 +16,8 @@
// clang-format off // clang-format off
#include "config_build.h" #include "config_build.h"
#ifndef HAVE_CONFIG_BUILD #ifndef HAVE_CONFIG_PACKAGE
# error "Something failed during ./configure as config_build.h is incomplete. Perhaps you used autoreconf, don't." # error "Something failed during ./configure as config_package.h is incomplete. Perhaps you used autoreconf, don't."
#endif #endif
// clang-format on // clang-format on
@ -48,7 +48,7 @@ static int debug() { return V3Error::debugDefault(); }
void VlcOptions::addReadFile(const string& filename) { m_readFiles.insert(filename); } void VlcOptions::addReadFile(const string& filename) { m_readFiles.insert(filename); }
string VlcOptions::version() { string VlcOptions::version() {
string ver = DTVERSION; string ver = PACKAGE_STRING;
ver += " rev " + cvtToStr(DTVERSION_rev); ver += " rev " + cvtToStr(DTVERSION_rev);
return ver; return ver;
} }

View File

@ -19,12 +19,7 @@
//********************************************************************** //**********************************************************************
//**** Version and host name //**** Version and host name
// Autoconf substitutes this with the strings from AC_INIT. #include "config_package.h"
#define PACKAGE_STRING ""
#define PACKAGE_VERSION_NUMBER_STRING "0.000"
#define DTVERSION PACKAGE_STRING
//********************************************************************** //**********************************************************************
//**** Functions //**** Functions
@ -73,22 +68,7 @@ using string = std::string;
using std::cout; using std::cout;
using std::endl; using std::endl;
//**********************************************************************
//**** Configure-discovered library options
// Define if struct stat has st_mtim.tv_nsec (from configure)
#undef HAVE_STAT_NSEC
// Define if SystemC found
// - If defined, the default search path has it, so support is always enabled.
// - If undef, not system-wide, user can set SYSTEMC_INCLUDE.
#undef HAVE_SYSTEMC
#undef HAVE_COROUTINES
//********************************************************************** //**********************************************************************
//**** OS and compiler specifics //**** OS and compiler specifics
#include "verilatedos.h" #include "verilatedos.h"
//**********************************************************************
//**** This file sometimes gets truncated, so check in consumers
#define HAVE_CONFIG_BUILD

38
src/config_package.h.in Normal file
View File

@ -0,0 +1,38 @@
// -*- mode: C++; c-file-style: "cc-mode" -*-
// DESCRIPTION: Verilator: Configure source; system configuration
//
// This file is part of Verilator.
//
// Code available from: https://verilator.org
//
// Copyright 2003-2023 by Wilson Snyder. This program is free software;
// you can 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.
//
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
// Autoconf substitutes this with the strings from AC_INIT.
#define PACKAGE_STRING ""
#define PACKAGE_VERSION_NUMBER_STRING "0.000"
// Otherwise Autoheader generates it (with all the same macros and more)
//**********************************************************************
//**** Configure-discovered library options
// Define if struct stat has st_mtim.tv_nsec (from configure)
#undef HAVE_STAT_NSEC
// Define if SystemC found
// - If defined, the default search path has it, so support is always enabled.
// - If undef, not system-wide, user can set SYSTEMC_INCLUDE.
#undef HAVE_SYSTEMC
// Define if coroutines are supported on this platform
#undef HAVE_COROUTINES
//**********************************************************************
//**** This file sometimes gets truncated, so check in consumers
#define HAVE_CONFIG_PACKAGE