This helps working around missing C functions like strcasecmp that do not exist everywhere (e.g. on Cygwin), and for which lib/ supplies a replacement. Unfortunately we do not have such build in our current continuous integration suite, so we cannot easily detect files where such config.h inclusion would be useful. Therefore this patch simply makes it mandatory to include config.h in *.cc files. Including this in public *.hh file is currently forbidden. * spot/gen/automata.cc, spot/gen/formulas.cc, spot/kripke/fairkripke.cc, spot/kripke/kripke.cc, spot/ltsmin/ltsmin.cc, spot/misc/game.cc, spot/parseaut/fmterror.cc, spot/parsetl/fmterror.cc, spot/parsetl/parsetl.yy, spot/priv/bddalloc.cc, spot/priv/freelist.cc, spot/priv/satcommon.cc, spot/priv/trim.cc, spot/priv/weight.cc, spot/ta/ta.cc, spot/ta/taexplicit.cc, spot/ta/taproduct.cc, spot/ta/tgtaexplicit.cc, spot/ta/tgtaproduct.cc, spot/taalgos/dot.cc, spot/taalgos/emptinessta.cc, spot/taalgos/minimize.cc, spot/taalgos/reachiter.cc, spot/taalgos/statessetbuilder.cc, spot/taalgos/stats.cc, spot/taalgos/tgba2ta.cc, spot/tl/apcollect.cc, spot/tl/contain.cc, spot/tl/declenv.cc, spot/tl/defaultenv.cc, spot/tl/dot.cc, spot/tl/exclusive.cc, spot/tl/hierarchy.cc, spot/tl/length.cc, spot/tl/ltlf.cc, spot/tl/mark.cc, spot/tl/mutation.cc, spot/tl/nenoform.cc, spot/tl/print.cc, spot/tl/randomltl.cc, spot/tl/relabel.cc, spot/tl/remove_x.cc, spot/tl/simplify.cc, spot/tl/snf.cc, spot/tl/unabbrev.cc, spot/twa/acc.cc, spot/twa/bdddict.cc, spot/twa/bddprint.cc, spot/twa/formula2bdd.cc, spot/twa/taatgba.cc, spot/twa/twa.cc, spot/twa/twagraph.cc, spot/twa/twaproduct.cc, spot/twaalgos/aiger.cc, spot/twaalgos/alternation.cc, spot/twaalgos/are_isomorphic.cc, spot/twaalgos/bfssteps.cc, spot/twaalgos/canonicalize.cc, spot/twaalgos/cleanacc.cc, spot/twaalgos/cobuchi.cc, spot/twaalgos/complement.cc, spot/twaalgos/complete.cc, spot/twaalgos/compsusp.cc, spot/twaalgos/couvreurnew.cc, spot/twaalgos/cycles.cc, spot/twaalgos/degen.cc, spot/twaalgos/determinize.cc, spot/twaalgos/dot.cc, spot/twaalgos/dtbasat.cc, spot/twaalgos/dtwasat.cc, spot/twaalgos/dualize.cc, spot/twaalgos/emptiness.cc, spot/twaalgos/gtec/ce.cc, spot/twaalgos/gtec/gtec.cc, spot/twaalgos/gtec/sccstack.cc, spot/twaalgos/gtec/status.cc, spot/twaalgos/gv04.cc, spot/twaalgos/hoa.cc, spot/twaalgos/iscolored.cc, spot/twaalgos/isdet.cc, spot/twaalgos/isunamb.cc, spot/twaalgos/isweakscc.cc, spot/twaalgos/langmap.cc, spot/twaalgos/lbtt.cc, spot/twaalgos/ltl2taa.cc, spot/twaalgos/ltl2tgba_fm.cc, spot/twaalgos/magic.cc, spot/twaalgos/mask.cc, spot/twaalgos/minimize.cc, spot/twaalgos/neverclaim.cc, spot/twaalgos/parity.cc, spot/twaalgos/postproc.cc, spot/twaalgos/powerset.cc, spot/twaalgos/product.cc, spot/twaalgos/rabin2parity.cc, spot/twaalgos/randomgraph.cc, spot/twaalgos/randomize.cc, spot/twaalgos/reachiter.cc, spot/twaalgos/relabel.cc, spot/twaalgos/remfin.cc, spot/twaalgos/remprop.cc, spot/twaalgos/sbacc.cc, spot/twaalgos/sccfilter.cc, spot/twaalgos/sccinfo.cc, spot/twaalgos/se05.cc, spot/twaalgos/sepsets.cc, spot/twaalgos/simulation.cc, spot/twaalgos/split.cc, spot/twaalgos/stats.cc, spot/twaalgos/strength.cc, spot/twaalgos/stripacc.cc, spot/twaalgos/stutter.cc, spot/twaalgos/sum.cc, spot/twaalgos/tau03.cc, spot/twaalgos/tau03opt.cc, spot/twaalgos/totgba.cc, spot/twaalgos/toweak.cc, spot/twaalgos/translate.cc, spot/twaalgos/word.cc, tests/core/acc.cc, tests/core/bitvect.cc, tests/core/checkpsl.cc, tests/core/checkta.cc, tests/core/consterm.cc, tests/core/emptchk.cc, tests/core/equalsf.cc, tests/core/graph.cc, tests/core/ikwiad.cc, tests/core/intvcmp2.cc, tests/core/intvcomp.cc, tests/core/kind.cc, tests/core/kripkecat.cc, tests/core/length.cc, tests/core/ltlrel.cc, tests/core/ngraph.cc, tests/core/parity.cc, tests/core/randtgba.cc, tests/core/readltl.cc, tests/core/reduc.cc, tests/core/safra.cc, tests/core/sccif.cc, tests/core/syntimpl.cc, tests/core/taatgba.cc, tests/core/tostring.cc, tests/core/trival.cc, tests/core/twagraph.cc, tests/ltsmin/modelcheck.cc, spot/parseaut/scanaut.ll, spot/parsetl/scantl.ll: Include config.h. * spot/gen/Makefile.am, spot/graph/Makefile.am, spot/kripke/Makefile.am, spot/ltsmin/Makefile.am, spot/parseaut/Makefile.am, spot/parsetl/Makefile.am, spot/priv/Makefile.am, spot/ta/Makefile.am, spot/taalgos/Makefile.am, spot/tl/Makefile.am, spot/twa/Makefile.am, spot/twaalgos/Makefile.am, spot/twaalgos/gtec/Makefile.am, tests/Makefile.am: Add the -I lib/ flags. * tests/sanity/includes.test: Catch missing config.h in *.cc, and diagnose config.h in *.hh. * tests/sanity/style.test: Better diagnostics.
161 lines
4.5 KiB
C++
161 lines
4.5 KiB
C++
// -*- coding: utf-8 -*-
|
|
// Copyright (C) 2007, 2011, 2014, 2015, 2017, 2018 Laboratoire de
|
|
// Recherche et Développement de l'Epita (LRDE).
|
|
// Copyright (C) 2003, 2004, 2006, 2007 Laboratoire d'Informatique de
|
|
// Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
|
// Université Pierre et Marie Curie.
|
|
//
|
|
// This file is part of Spot, a model checking library.
|
|
//
|
|
// Spot is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation; either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Spot is distributed in the hope that it will be useful, but WITHOUT
|
|
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
// License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#include "config.h"
|
|
#include <bddx.h>
|
|
#include <cassert>
|
|
#include <cstdlib>
|
|
#include <ctime>
|
|
#include "spot/priv/bddalloc.hh"
|
|
|
|
namespace spot
|
|
{
|
|
|
|
bool bdd_allocator::initialized = false;
|
|
|
|
static void show_bdd_stats()
|
|
{
|
|
bddStat s;
|
|
bdd_stats(&s);
|
|
std::cerr << "spot: BDD stats: produced=" << s.produced
|
|
<< " nodenum=" << s.nodenum
|
|
<< " freenodes=" << s.freenodes
|
|
<< " (" << (s.freenodes * 100 / s.nodenum)
|
|
<< "%) minfreenodes=" << s.minfreenodes
|
|
<< "% varnum=" << s.varnum
|
|
<< " cachesize=" << s.cachesize
|
|
<< " hashsize=" << s.hashsize
|
|
<< " gbcnum=" << s.gbcnum
|
|
<< '\n';
|
|
}
|
|
|
|
static void resize_handler(int oldsize, int newsize)
|
|
{
|
|
std::cerr << "spot: BDD resize "
|
|
<< oldsize << " -> " << newsize << '\n';
|
|
}
|
|
|
|
static void gbc_handler(int pre, bddGbcStat *s)
|
|
{
|
|
if (!pre)
|
|
std::cerr << "spot: BDD GC #" << s->num
|
|
<< " in " << ((float)s->time)/CLOCKS_PER_SEC << "s / "
|
|
<< ((float)s->sumtime)/CLOCKS_PER_SEC << "s total\n";
|
|
show_bdd_stats();
|
|
}
|
|
|
|
bdd_allocator::bdd_allocator()
|
|
{
|
|
initialize();
|
|
lvarnum = bdd_varnum();
|
|
fl.emplace_front(0, lvarnum);
|
|
}
|
|
|
|
void
|
|
bdd_allocator::initialize()
|
|
{
|
|
if (initialized)
|
|
return;
|
|
initialized = true;
|
|
// Buddy might have been initialized by a third-party library.
|
|
if (bdd_isrunning())
|
|
return;
|
|
// The values passed to bdd_init should depends on the problem
|
|
// the library is solving. It would be nice to allow users
|
|
// to tune this. By the meantime, we take the typical values
|
|
// for large examples advocated by the BuDDy manual.
|
|
bdd_init(1 << 19, 2);
|
|
bdd_setcacheratio(40);
|
|
bdd_setvarnum(2);
|
|
// When the node table is full, add 2**19 nodes; this requires 10MB.
|
|
bdd_setmaxincrease(1 << 19);
|
|
// Disable the default GC handler. (Note that this will only be
|
|
// done if Buddy is initialized by Spot. Otherwise we prefer not
|
|
// to overwrite a handler that might have been set by the user.)
|
|
if (getenv("SPOT_BDD_TRACE"))
|
|
{
|
|
bdd_gbc_hook(gbc_handler);
|
|
bdd_resize_hook(resize_handler);
|
|
std::cerr << "spot: BDD package initialized\n";
|
|
show_bdd_stats();
|
|
}
|
|
else
|
|
{
|
|
bdd_gbc_hook(nullptr);
|
|
}
|
|
}
|
|
|
|
void
|
|
bdd_allocator::extvarnum(int more)
|
|
{
|
|
int varnum = bdd_varnum();
|
|
// If varnum has been extended from another allocator (or
|
|
// externally), use the new variables.
|
|
if (lvarnum < varnum)
|
|
{
|
|
more -= varnum - lvarnum;
|
|
lvarnum = varnum;
|
|
}
|
|
// If we still need more variable, do allocate them.
|
|
if (more > 0)
|
|
{
|
|
bdd_extvarnum(more);
|
|
varnum += more;
|
|
lvarnum = varnum;
|
|
}
|
|
}
|
|
|
|
int
|
|
bdd_allocator::allocate_variables(int n)
|
|
{
|
|
return register_n(n);
|
|
}
|
|
|
|
void
|
|
bdd_allocator::release_variables(int base, int n)
|
|
{
|
|
release_n(base, n);
|
|
}
|
|
|
|
int
|
|
bdd_allocator::extend(int n)
|
|
{
|
|
// If we already have some free variable at the end
|
|
// of the variable space, allocate just the difference.
|
|
if (!fl.empty() && fl.back().first + fl.back().second == lvarnum)
|
|
{
|
|
int res = fl.back().first;
|
|
int endvar = fl.back().second;
|
|
assert(n > endvar);
|
|
extvarnum(n - endvar);
|
|
fl.pop_back();
|
|
return res;
|
|
}
|
|
else
|
|
{
|
|
// Otherwise, allocate as much variables as we need.
|
|
int res = lvarnum;
|
|
extvarnum(n);
|
|
return res;
|
|
}
|
|
}
|
|
}
|