// -*- C++ -*- // // This file is part of the Coriolis Software. // Copyright (c) UPMC 2008-2018, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | // | K i t e - D e t a i l e d R o u t e r | // | | // | Author : Jean-Paul CHAPUT | // | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | // | C++ Module : "./ProtectRoutingPads.cpp" | // +-----------------------------------------------------------------+ #include #include #include "hurricane/DataBase.h" #include "hurricane/Technology.h" #include "hurricane/BasicLayer.h" #include "hurricane/RegularLayer.h" #include "hurricane/Horizontal.h" #include "hurricane/Vertical.h" #include "hurricane/RoutingPad.h" #include "hurricane/Occurrence.h" #include "hurricane/Cell.h" #include "hurricane/NetExternalComponents.h" #include "hurricane/NetRoutingProperty.h" #include "crlcore/Catalog.h" #include "katabatic/AutoContact.h" #include "katabatic/AutoSegment.h" #include "katabatic/GCell.h" #include "katabatic/GCellGrid.h" #include "katabatic/KatabaticEngine.h" #include "kite/RoutingPlane.h" #include "kite/TrackSegment.h" #include "kite/TrackFixedSegment.h" #include "kite/Track.h" #include "kite/KiteEngine.h" namespace { using namespace std; using Hurricane::tab; using Hurricane::ForEachIterator; using Hurricane::DbU; using Hurricane::Box; using Hurricane::Interval; using Hurricane::Go; using Hurricane::Layer; using Hurricane::BasicLayer; using Hurricane::RegularLayer; using Hurricane::Horizontal; using Hurricane::Vertical; using Hurricane::Transformation; using Hurricane::RoutingPad; using Hurricane::Occurrence; using Hurricane::Path; using Hurricane::NetExternalComponents; using Hurricane::NetRoutingExtension; using Hurricane::NetRoutingState; using CRL::CatalogExtension; using Katabatic::GCellGrid; using Katabatic::AutoContact; using Katabatic::AutoSegment; using namespace Kite; void protectRoutingPad ( RoutingPad* rp ) { Name padNetName = "pad"; Component* usedComponent = rp->_getEntityAs(); Path path = rp->getOccurrence().getPath(); Net* masterNet = usedComponent->getNet(); Transformation transformation = path.getTransformation(); if ( CatalogExtension::isPad(masterNet->getCell()) ) { if ( rp->getNet()->isPower() or (rp->getNet()->getName() == padNetName) ) return; } vector segments; for( Segment* segment : masterNet->getSegments() ) { RoutingPlane* plane = Session::getKiteEngine()->getRoutingPlaneByLayer(segment->getLayer()); if ( plane == NULL ) continue; if ( usedComponent == dynamic_cast(segment) ) continue; if ( not NetExternalComponents::isExternal(segment) ) continue; //cerr << "Looking " << (void*)*isegment << ":" << *isegment << endl; segments.push_back ( segment ); } for ( size_t i=0 ; igetRoutingPlaneByLayer(segments[i]->getLayer()); unsigned int direction = plane->getDirection(); DbU::Unit wireWidth = plane->getLayerGauge()->getWireWidth(); DbU::Unit delta = plane->getLayerGauge()->getHalfPitch() + wireWidth/2 - DbU::fromLambda(0.1); DbU::Unit extension = segments[i]->getLayer()->getExtentionCap(); Box bb ( segments[i]->getBoundingBox() ); transformation.applyOn ( bb ); //cinfo << "bb: " << bb << endl; if ( direction == KbHorizontal ) { DbU::Unit axisMin = bb.getYMin() - delta; DbU::Unit axisMax = bb.getYMax() + delta; Track* track = plane->getTrackByPosition ( axisMin, Constant::Superior ); for ( ; track and (track->getAxis() <= axisMax) ; track = track->getNextTrack() ) { Horizontal* segment = Horizontal::create ( rp->getNet() , segments[i]->getLayer() , track->getAxis() , wireWidth , bb.getXMin()+extension , bb.getXMax()-extension ); TrackFixedSegment::create ( track, segment ); } } else { DbU::Unit axisMin = bb.getXMin() - delta; DbU::Unit axisMax = bb.getXMax() + delta; Track* track = plane->getTrackByPosition ( axisMin, Constant::Superior ); for ( ; track and (track->getAxis() <= axisMax) ; track = track->getNextTrack() ) { Vertical* segment = Vertical::create ( rp->getNet() , segments[i]->getLayer() , track->getAxis() , wireWidth , bb.getYMin()+extension , bb.getYMax()-extension ); TrackFixedSegment::create ( track, segment ); } } } } } // End of anonymous namespace. namespace Kite { using Hurricane::DataBase; using Hurricane::Technology; using Hurricane::BasicLayer; using Hurricane::ForEachIterator; using Hurricane::Cell; using Katabatic::NetRoutingState; void KiteEngine::protectRoutingPads () { cmess1 << " o Protect external components not useds as RoutingPads." << endl; for( Net* net : getCell()->getNets() ) { if ( net->isSupply() ) continue; NetRoutingState* state = getRoutingState( net ); if (state and state->isFixed()) continue; vector rps; for( RoutingPad* rp : net->getRoutingPads() ) { rps.push_back ( rp ); } for ( size_t i=0 ; i