From 84d25da1b84cbad07db68cc08394422be8e11e24 Mon Sep 17 00:00:00 2001 From: Jean-Paul Chaput Date: Thu, 3 Dec 2020 16:34:22 +0100 Subject: [PATCH] More thorough verification of outputs of tie low/tie high in Blif parser. * Change: In CRL::Model::staticInit(), when trying to guess the ouput of the tie low & tie high cells check if the net name is not a power or ground. A bad input was choosen with FlexLib as the vdd/vss nets where not typed as POWER/GROUND. --- .../src/ccore/alliance/vst/VhdlPortMap.cpp | 5 +- crlcore/src/ccore/blif/BlifParser.cpp | 46 +++++++++++-------- 2 files changed, 30 insertions(+), 21 deletions(-) diff --git a/crlcore/src/ccore/alliance/vst/VhdlPortMap.cpp b/crlcore/src/ccore/alliance/vst/VhdlPortMap.cpp index 306a52f2..434043f2 100644 --- a/crlcore/src/ccore/alliance/vst/VhdlPortMap.cpp +++ b/crlcore/src/ccore/alliance/vst/VhdlPortMap.cpp @@ -70,10 +70,9 @@ namespace Vhdl { ) << endl; } else { cerr << Error( "PortMap::_lookup() Unconnected \"%s\",\n" - " In instance \"%s\" of \"%s\"." + " In %s." , getString(plug).c_str() - , getString(instance->getName()).c_str() - , getString(instance->getMasterCell()->getName()).c_str() + , getString(instance).c_str() ) << endl; } } diff --git a/crlcore/src/ccore/blif/BlifParser.cpp b/crlcore/src/ccore/blif/BlifParser.cpp index d0129763..d073ea5b 100644 --- a/crlcore/src/ccore/blif/BlifParser.cpp +++ b/crlcore/src/ccore/blif/BlifParser.cpp @@ -376,21 +376,44 @@ namespace { _powerName = Cfg::getParamString("crlcore.powerName" ,"vdd")->asString(); if (_zeroCell) { - for ( Net* net : _zeroCell->getNets() ) + for ( Net* net : _zeroCell->getNets() ) { if ( not net->isSupply () and not net->isAutomatic() - and not net->isBlockage () ) { _masterNetZero = net; break; } + and not net->isBlockage () ) { + if (getString(net->getName()).find(_powerName) != string::npos) { + cerr << Error( "BlifParser::Model::staticInit(): Output \"%s\" of zero (tie low) cell \"%s\" match power supply name." + , getString(net->getName()).c_str(), zeroName.c_str() ) << endl; + } + if (getString(net->getName()).find(_groundName) != string::npos) { + cerr << Error( "BlifParser::Model::staticInit(): Output \"%s\" of zero (tie low) cell \"%s\" match ground name." + , getString(net->getName()).c_str(), zeroName.c_str() ) << endl; + } + _masterNetZero = net; + break; + } + } } else - cerr << Warning( "BlifParser::Model::connectSubckts(): The zero (tie high) cell \"%s\" has not been found." + cerr << Warning( "BlifParser::Model::staticInit(): The zero (tie low) cell \"%s\" has not been found." , zeroName.c_str() ) << endl; if (_oneCell) { for ( Net* net : _oneCell->getNets() ) if ( not net->isSupply () and not net->isAutomatic() - and not net->isBlockage () ) { _masterNetOne = net; break; } + and not net->isBlockage () ) { + if (getString(net->getName()).find(_powerName) != string::npos) { + cerr << Error( "BlifParser::Model::staticInit(): Output \"%s\" of one (tie high) cell \"%s\" match power supply name." + , getString(net->getName()).c_str(), zeroName.c_str() ) << endl; + } + if (getString(net->getName()).find(_groundName) != string::npos) { + cerr << Error( "BlifParser::Model::staticInit(): Output \"%s\" of one (tie high) cell \"%s\" match ground name." + , getString(net->getName()).c_str(), zeroName.c_str() ) << endl; + } + _masterNetOne = net; + break; + } } else - cerr << Warning( "BlifParser::Model::connectSubckts(): The one (tie low) cell \"%s\" has not been found." + cerr << Warning( "BlifParser::Model::staticInit(): The one (tie high) cell \"%s\" has not been found." , oneName.c_str() ) << endl; } @@ -549,11 +572,6 @@ namespace { Net* net1 = _cell->getNet( name1 ); Net* net2 = _cell->getNet( name2 ); - if (_cell->getName() == "sm0") { - cerr << "Merge: " << name1 << " + " << name2 << endl; - cerr << " net1:" << net1 << " net2:" << net2 << endl; - } - if (net1 and (net1 == net2)) return net1; if (net1 and net2) { if (net1->isSupply() and (net2->isExternal() and not net2->isSupply())) { @@ -829,16 +847,12 @@ namespace CRL { if (tokenize.state() == Tokenize::Inputs) { for ( size_t i=1 ; imergeNet( blifLine[i], true, Net::Direction::IN ); - if (blifModel->getCell()->getName() == "sm0") - cerr << "Blif model sm0: plug:" << blifLine[i] << endl; } } if (tokenize.state() == Tokenize::Outputs) { for ( size_t i=1 ; imergeNet( blifLine[i], true, Net::Direction::OUT ); - if (blifModel->getCell()->getName() == "sm0") - cerr << "Blif model sm0: plug:" << blifLine[i] << endl; } } @@ -889,10 +903,6 @@ namespace CRL { subckt->addConnection( make_pair(blifLine[i].substr(0,equal) ,blifLine[i].substr( equal+1)) ); - if (subckt->getModelName() == "sm0") { - cerr << "Blif sm0 plug:" << blifLine[i].substr(0,equal) - << " net:" << blifLine[i].substr( equal+1) << endl; - } } } }