Change Net name merge policy in the Blif parser.
* Change: In CRL/BlifParser::Model::mergeAlias(), do not always merge the net2 with net1 (RHS with LHS of the ".name" instruction). This may result in a name change in the design interface (external net). Instead, merge any internal net with the external, so keep the external net name. If both are external, keep the one with the lower id (which should have been created first).
This commit is contained in:
parent
85e969bca9
commit
1359fe4ba6
|
@ -506,10 +506,17 @@ namespace {
|
||||||
Net* net2 = _cell->getNet( name2 );
|
Net* net2 = _cell->getNet( name2 );
|
||||||
|
|
||||||
if (net1 and (net1 == net2)) return net1;
|
if (net1 and (net1 == net2)) return net1;
|
||||||
if (net1 and net2) { net1->merge( net2 ); return net1; }
|
if (net1 and net2) {
|
||||||
|
if ( (not net1->isExternal() and net2->isExternal())
|
||||||
|
or ( net1->isExternal() and net2->isExternal() and (net1->getId() > net2->getId()) ) ) {
|
||||||
|
std::swap( net1 , net2 );
|
||||||
|
std::swap( name1, name2 );
|
||||||
|
}
|
||||||
|
net1->merge( net2 ); return net1;
|
||||||
|
}
|
||||||
if (net2) {
|
if (net2) {
|
||||||
swap( net1 , net2 );
|
std::swap( net1 , net2 );
|
||||||
swap( name1, name2 );
|
std::swap( name1, name2 );
|
||||||
}
|
}
|
||||||
|
|
||||||
if (not net1) {
|
if (not net1) {
|
||||||
|
|
Loading…
Reference in New Issue