2018-10-18 11:10:01 -05:00
|
|
|
// -*- C++ -*-
|
|
|
|
//
|
|
|
|
// This file is part of the Coriolis Software.
|
|
|
|
// Copyright (c) UPMC 2015-2018, All Rights Reserved
|
|
|
|
//
|
|
|
|
// +-----------------------------------------------------------------+
|
|
|
|
// | C O R I O L I S |
|
|
|
|
// | B o r a - A n a l o g S l i c i n g T r e e |
|
|
|
|
// | |
|
|
|
|
// | Authors : Eric LAO |
|
|
|
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
|
|
|
// | =============================================================== |
|
|
|
|
// | C++ Module : "./ChannelRouting.cpp" |
|
|
|
|
// +-----------------------------------------------------------------+
|
|
|
|
|
|
|
|
|
|
|
|
#include "bora/ChannelRouting.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace Bora {
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
|
|
// Class : "Bora::ChannelRouting".
|
|
|
|
|
|
|
|
|
|
|
|
ChannelRouting::ChannelRouting ()
|
2018-11-07 16:48:43 -06:00
|
|
|
: _wireIntervals()
|
2018-10-18 11:10:01 -05:00
|
|
|
{ }
|
|
|
|
|
|
|
|
|
|
|
|
ChannelRouting::~ChannelRouting ()
|
|
|
|
{ }
|
|
|
|
|
|
|
|
|
|
|
|
ChannelRouting* ChannelRouting::create ()
|
|
|
|
{
|
|
|
|
return new ChannelRouting();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ChannelRouting::destroy ()
|
|
|
|
{
|
|
|
|
delete this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ChannelRouting::reset ()
|
|
|
|
{
|
2018-11-07 16:48:43 -06:00
|
|
|
_wireIntervals.clear();
|
2018-10-18 11:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int ChannelRouting::getMaxCount () const
|
|
|
|
{
|
2018-11-07 16:48:43 -06:00
|
|
|
return _wireIntervals.getThickness();
|
2018-10-18 11:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ChannelRouting::insertChannel ( DbU::Unit xy1, DbU::Unit xy2, unsigned int w )
|
|
|
|
{
|
|
|
|
cdebug_log(535,0) << "ChannelRouting::insertChannel(DbU::Unit,DbU::Unit,unsigned) ["
|
|
|
|
<< DbU::getValueString(xy1) << " : "
|
|
|
|
<< DbU::getValueString(xy2) << "] width:"
|
|
|
|
<< w << endl;
|
|
|
|
|
2018-11-07 16:48:43 -06:00
|
|
|
for ( unsigned int i=0; i<w; ++i ) insertChannel( xy1, xy2, (Net*)NULL );
|
2018-10-18 11:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-11-07 16:48:43 -06:00
|
|
|
void ChannelRouting::insertChannel ( DbU::Unit xy1, DbU::Unit xy2, Net* net )
|
2018-10-18 11:10:01 -05:00
|
|
|
{
|
|
|
|
cdebug_log(535,0) << "ChannelRouting::insertChannel(DbU::Unit,DbU::Unit) ["
|
|
|
|
<< DbU::getValueString(xy1) << " : "
|
2018-11-07 16:48:43 -06:00
|
|
|
<< DbU::getValueString(xy2) << "] "
|
|
|
|
<< net
|
|
|
|
<< endl;
|
2018-10-18 11:10:01 -05:00
|
|
|
|
2018-11-07 16:48:43 -06:00
|
|
|
_wireIntervals.insert( WireInterval(net,xy1,xy2) );
|
2018-10-18 11:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ChannelRouting::print () const
|
|
|
|
{
|
2018-11-07 16:48:43 -06:00
|
|
|
cerr << "Thickness: " << getMaxCount() << endl;
|
|
|
|
cerr << "Wires:" << endl;
|
|
|
|
for ( const WireInterval& wire : _wireIntervals.getElements() )
|
|
|
|
cerr << "| " << wire << endl;
|
2018-10-18 11:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // Bora namespace.
|