From b8cd4264bdda79d90b9f6df4fb96bd22a70582a6 Mon Sep 17 00:00:00 2001 From: Jean-Paul Chaput Date: Fri, 16 Dec 2022 20:02:11 +0100 Subject: [PATCH] Bug in topology management switch in NetBuilder::construct(). * Bug: In NetBuilder::construct(), the xG_xM1 topologies where wrongly redirected towards xG_1M1, so only one M1 was connected, all others left floating. Now direct them towards xG_xM1_xM3. * Bug: In NetBuilderHybridVH, activate topology management for 2G_1M1. --- anabatic/src/NetBuilder.cpp | 4 ++-- anabatic/src/NetBuilderHybridVH.cpp | 16 ++++++++++++---- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/anabatic/src/NetBuilder.cpp b/anabatic/src/NetBuilder.cpp index 7b05273f..47170b67 100644 --- a/anabatic/src/NetBuilder.cpp +++ b/anabatic/src/NetBuilder.cpp @@ -719,7 +719,7 @@ namespace Anabatic { case Conn_2G_6M1: case Conn_2G_7M1: case Conn_2G_8M1: - case Conn_2G_9M1: + case Conn_2G_9M1: _do_xG_xM1_xM3(); break; case Conn_3G_1M1: if (_do_xG_1M1()) break; case Conn_3G_2M1: case Conn_3G_3M1: @@ -731,7 +731,7 @@ namespace Anabatic { case Conn_3G_9M1: case Conn_3G_2M3: case Conn_3G_3M3: - case Conn_3G_4M3: + case Conn_3G_4M3: _do_xG_xM1_xM3(); break; case Conn_4G_1M1: if (_do_xG_1M1()) break; case Conn_4G_2M1: case Conn_4G_3M1: diff --git a/anabatic/src/NetBuilderHybridVH.cpp b/anabatic/src/NetBuilderHybridVH.cpp index b292393d..45c36445 100644 --- a/anabatic/src/NetBuilderHybridVH.cpp +++ b/anabatic/src/NetBuilderHybridVH.cpp @@ -86,7 +86,7 @@ namespace Anabatic { cdebug_log(145,0) << rp << endl; const Layer* rpLayer = rp->getLayer(); - const Layer* viaLayer = Session::getDContactLayer(); + //const Layer* viaLayer = Session::getDContactLayer(); DbU::Unit viaSide = Session::getDContactWidth(); Point position = rp->getCenter(); AutoContact* rpContact = AutoContactTerminal::create( gcell, rp, rpLayer, position, viaSide, viaSide ); @@ -215,6 +215,17 @@ namespace Anabatic { } + bool NetBuilderHybridVH::_do_2G_1M1 () + { + cdebug_log(145,1) << getTypeName() << "::_do_2G_1M1()" << endl; + + doRp_xG_1M1( getRoutingPads()[0] ); + + cdebug_tabw(145,-1); + return true; + } + + bool NetBuilderHybridVH::doRp_xG_xM1_xM3 ( const vector& rps ) { cdebug_log(145,1) << getTypeName() << "::doRp_xG_xM1()" << endl; @@ -396,8 +407,6 @@ namespace Anabatic { else doRp_xG_1M1( rpsM1[0] ); - Pin* pin = dynamic_cast( rpM2->getOccurrence().getEntity() ); - Pin::AccessDirection pinDir = pin->getAccessDirection(); AutoContact* rpContact = doRp_AccessNorthSouthPin( getGCell(), rpM2 ); AutoContact* rpM1Contact = doRp_Access( getGCell(), rpsM1.front(), NoFlags ); AutoContact* turn1 = AutoContactTurn::create( getGCell(), getNet(), Session::getContactLayer(0) ); @@ -511,7 +520,6 @@ namespace Anabatic { bool NetBuilderHybridVH::_do_1G_1M1 () { return false; } - bool NetBuilderHybridVH::_do_2G_1M1 () { return false; } // bool NetBuilderHybridVH::_do_xG_1Pad () { return false; } // bool NetBuilderHybridVH::_do_xG_xM2 () { return false; } // bool NetBuilderHybridVH::_do_1G_1M3 () { return false; }