From ce60ed5a30c62e9a3d833ff1636fd7b7a0728c05 Mon Sep 17 00:00:00 2001 From: Jean-Paul Chaput Date: Fri, 10 May 2019 11:54:32 +0200 Subject: [PATCH] In Etesian & Anabatic, use the "anabatic.routingGauge" conf. parameter. * Change: In Etesian::Configuration CTOR, use the gauge from the configuration parameter "anabatic.routinGauge" instead of the default one. * Change: In Anabatic::Configuration CTOR, use the gauge from the configuration parameter "anabatic.routinGauge" instead of the default one. --- anabatic/src/Configuration.cpp | 10 ++++++---- etesian/src/Configuration.cpp | 16 ++++++++++++++-- 2 files changed, 20 insertions(+), 6 deletions(-) diff --git a/anabatic/src/Configuration.cpp b/anabatic/src/Configuration.cpp index 4ea94084..d0389c66 100644 --- a/anabatic/src/Configuration.cpp +++ b/anabatic/src/Configuration.cpp @@ -91,12 +91,14 @@ namespace Anabatic { { GCell::setDisplayMode( Cfg::getParamEnumerate("anabatic.gcell.displayMode", GCell::Boundary)->asInt() ); - if (cg == NULL) cg = AllianceFramework::get()->getCellGauge(); - if (cg == NULL) - throw Error( "AnabaticEngine::Configuration(): Unable to find default cell gauge." ); + string gaugeName = Cfg::getParamString("anabatic.routingGauge","sxlib")->asString(); + if (cg == NULL) { + cg = AllianceFramework::get()->getCellGauge( gaugeName ); + if (cg == NULL) + throw Error( "AnabaticEngine::Configuration(): Unable to find default cell gauge." ); + } if (rg == NULL) { - string gaugeName = Cfg::getParamString("anabatic.routingGauge","sxlib")->asString(); rg = AllianceFramework::get()->getRoutingGauge( gaugeName ); if (rg == NULL) throw Error( "AnabaticEngine::Configuration(): No routing gauge named \"%s\"", gaugeName.c_str() ); diff --git a/etesian/src/Configuration.cpp b/etesian/src/Configuration.cpp index b588c861..d1170df0 100644 --- a/etesian/src/Configuration.cpp +++ b/etesian/src/Configuration.cpp @@ -18,6 +18,7 @@ #include #include #include "vlsisapd/configuration/Configuration.h" +#include "hurricane/Error.h" #include "hurricane/Warning.h" #include "hurricane/Technology.h" #include "hurricane/DataBase.h" @@ -38,6 +39,7 @@ namespace Etesian { using std::ostringstream; using std::vector; using Hurricane::tab; + using Hurricane::Error; using Hurricane::Warning; using Hurricane::Technology; using Hurricane::DataBase; @@ -59,8 +61,18 @@ namespace Etesian { , _aspectRatio ( Cfg::getParamPercentage("etesian.aspectRatio" ,100.0)->asDouble() ) , _feedNames ( Cfg::getParamString ("etesian.feedNames" ,"tie_x0,rowend_x0")->asString() ) { - if (rg == NULL) rg = AllianceFramework::get()->getRoutingGauge(); - if (cg == NULL) cg = AllianceFramework::get()->getCellGauge(); + string gaugeName = Cfg::getParamString("anabatic.routingGauge","sxlib")->asString(); + if (cg == NULL) { + cg = AllianceFramework::get()->getCellGauge( gaugeName ); + if (cg == NULL) + throw Error( "AnabaticEngine::Configuration(): Unable to find default cell gauge." ); + } + + if (rg == NULL) { + rg = AllianceFramework::get()->getRoutingGauge( gaugeName ); + if (rg == NULL) + throw Error( "AnabaticEngine::Configuration(): No routing gauge named \"%s\"", gaugeName.c_str() ); + } _rg = rg->getClone(); _cg = cg->getClone();