- Modified: Matrix is now correctly updated for irregular floorplans.
Dijkstra:
   - Modified: Source and Target contacts are now correctly chosen in _materialize.
This commit is contained in:
EricLaoGitHub 2016-08-18 11:59:19 +02:00
parent 6d0b26b956
commit 128f654ecf
10 changed files with 103 additions and 48 deletions

View File

@ -405,6 +405,14 @@ namespace Anabatic {
} }
void AnabaticEngine::updateMatrix()
{
_matrix.setCell( getCell(), Session::getSliceHeight() );
for ( GCell* gcell : _gcells ){
gcell->_revalidate();
}
}
size_t AnabaticEngine::getNetsFromEdge ( const Edge* edge, NetSet& nets ) size_t AnabaticEngine::getNetsFromEdge ( const Edge* edge, NetSet& nets )
{ {
size_t count = 0; size_t count = 0;

View File

@ -31,11 +31,13 @@ namespace Anabatic {
const unsigned int Flags::Invalidated = (1 << 4); const unsigned int Flags::Invalidated = (1 << 4);
// Flags for GCell objects states only. // Flags for GCell objects states only.
const unsigned int Flags::DeviceGCell = (1 << 5); const unsigned int Flags::DeviceGCell = (1 << 5);
const unsigned int Flags::ChannelGCell = (1 << 6); const unsigned int Flags::HChannelGCell = (1 << 6);
const unsigned int Flags::StrutGCell = (1 << 7); const unsigned int Flags::VChannelGCell = (1 << 7);
const unsigned int Flags::MatrixGCell = (1 << 8); const unsigned int Flags::HStrutGCell = (1 << 8);
const unsigned int Flags::IoPadGCell = (1 << 9); const unsigned int Flags::VStrutGCell = (1 << 9);
const unsigned int Flags::Saturated = (1 << 10); const unsigned int Flags::MatrixGCell = (1 << 10);
const unsigned int Flags::IoPadGCell = (1 << 11);
const unsigned int Flags::Saturated = (1 << 12);
// Flags for Anabatic objects states only. // Flags for Anabatic objects states only.
const unsigned int Flags::DemoMode = (1 << 5); const unsigned int Flags::DemoMode = (1 << 5);
const unsigned int Flags::WarnOnGCellOverload = (1 << 6); const unsigned int Flags::WarnOnGCellOverload = (1 << 6);
@ -53,7 +55,7 @@ namespace Anabatic {
const unsigned int Flags::EndsMask = Source|Target; const unsigned int Flags::EndsMask = Source|Target;
const unsigned int Flags::DirectionMask = Horizontal|Vertical; const unsigned int Flags::DirectionMask = Horizontal|Vertical;
const unsigned int Flags::DestroyMask = DestroyGCell|DestroyBaseContact|DestroyBaseSegment; const unsigned int Flags::DestroyMask = DestroyGCell|DestroyBaseContact|DestroyBaseSegment;
const unsigned int Flags::GCellTypeMask = DeviceGCell|ChannelGCell|StrutGCell|MatrixGCell|IoPadGCell; const unsigned int Flags::GCellTypeMask = DeviceGCell|HChannelGCell|VChannelGCell|HStrutGCell|VStrutGCell|MatrixGCell|IoPadGCell;
// Flags for functions arguments only. // Flags for functions arguments only.
const unsigned int Flags::Create = (1 << 5); const unsigned int Flags::Create = (1 << 5);
const unsigned int Flags::WithPerpands = (1 << 6); const unsigned int Flags::WithPerpands = (1 << 6);
@ -99,8 +101,10 @@ namespace Anabatic {
s += (_flags & Source ) ? 'S' : '-'; s += (_flags & Source ) ? 'S' : '-';
s += (_flags & Target ) ? 'T' : '-'; s += (_flags & Target ) ? 'T' : '-';
s += (_flags & DeviceGCell ) ? 'd' : '-'; s += (_flags & DeviceGCell ) ? 'd' : '-';
s += (_flags & ChannelGCell) ? 'c' : '-'; s += (_flags & HChannelGCell) ? 'c' : '-';
s += (_flags & StrutGCell ) ? 's' : '-'; s += (_flags & VChannelGCell) ? 'c' : '-';
s += (_flags & HStrutGCell ) ? 's' : '-';
s += (_flags & VStrutGCell ) ? 's' : '-';
s += (_flags & MatrixGCell ) ? 'm' : '-'; s += (_flags & MatrixGCell ) ? 'm' : '-';
s += ","; s += ",";
s += (_flags & Invalidated ) ? 'i' : '-'; s += (_flags & Invalidated ) ? 'i' : '-';

View File

@ -498,11 +498,10 @@ namespace Anabatic {
else targetContact = target->breakGoThrough( _net ); else targetContact = target->breakGoThrough( _net );
} }
if ( (source->getGCell()->getXMin() > target->getGCell()->getXMin()) if (aligneds.front()->isHorizontal()) {
or (source->getGCell()->getYMin() > target->getGCell()->getYMin()) ) if (sourceContact->getX() > targetContact->getX())
std::swap( sourceContact, targetContact ); std::swap( sourceContact, targetContact );
if (aligneds.front()->isHorizontal()) {
segment = Horizontal::create( sourceContact segment = Horizontal::create( sourceContact
, targetContact , targetContact
, _anabatic->getConfiguration()->getGHorizontalLayer() , _anabatic->getConfiguration()->getGHorizontalLayer()
@ -511,6 +510,9 @@ namespace Anabatic {
); );
for ( Edge* through : aligneds ) through->add( segment ); for ( Edge* through : aligneds ) through->add( segment );
} else { } else {
if (sourceContact->getY() > targetContact->getY())
std::swap( sourceContact, targetContact );
segment = Vertical::create( sourceContact segment = Vertical::create( sourceContact
, targetContact , targetContact
, _anabatic->getConfiguration()->getGVerticalLayer() , _anabatic->getConfiguration()->getGVerticalLayer()

View File

@ -277,7 +277,7 @@ namespace Anabatic {
: Super(anabatic->getCell()) : Super(anabatic->getCell())
, _observable () , _observable ()
, _anabatic (anabatic) , _anabatic (anabatic)
, _flags (Flags::ChannelGCell|Flags::Invalidated) , _flags (Flags::HChannelGCell|Flags::Invalidated)
, _westEdges () , _westEdges ()
, _eastEdges () , _eastEdges ()
, _southEdges () , _southEdges ()
@ -796,7 +796,7 @@ namespace Anabatic {
cerr << Error( "GCell::_revalidate(): %s, Y Min is greater than Max.", getString(this).c_str() ); cerr << Error( "GCell::_revalidate(): %s, Y Min is greater than Max.", getString(this).c_str() );
_anabatic->_updateLookup( this ); _anabatic->_updateLookup( this );
//_anabatic->getMatrix()->show(); _anabatic->getMatrix()->show();
cdebug_tabw(110,-1); cdebug_tabw(110,-1);
} }

View File

@ -658,9 +658,11 @@ namespace {
void _do_xG_xM2 (); void _do_xG_xM2 ();
void _do_1G_1M3 (); void _do_1G_1M3 ();
void _do_xG_xM3 (); void _do_xG_xM3 ();
void _doChannel (); void _doHChannel ();
void _doVChannel ();
void _doHStrut ();
void _doVStrut ();
void _doDevice (); void _doDevice ();
void _doStrut ();
void _doIoPad (); void _doIoPad ();
private: private:
@ -1086,8 +1088,10 @@ namespace {
} }
} else { } else {
if (_gcell->isDevice ()) _doDevice(); if (_gcell->isDevice ()) _doDevice();
else if (_gcell->isChannel()) _doChannel(); else if (_gcell->isHChannel()) _doHChannel();
else if (_gcell->isStrut ()) _doStrut(); else if (_gcell->isVChannel()) _doVChannel();
else if (_gcell->isHStrut ()) _doHStrut();
else if (_gcell->isVStrut ()) _doVStrut();
else if (_gcell->isIoPad ()) _doIoPad(); else if (_gcell->isIoPad ()) _doIoPad();
else else
throw Bug( "Unmanaged GCell type: %s in %s\n" throw Bug( "Unmanaged GCell type: %s in %s\n"
@ -2091,7 +2095,7 @@ namespace {
void GCellTopology::_doDevice () void GCellTopology::_doDevice ()
{ {
cdebug_log(145,1) << "void GCellTopology::_doDevice ()" << _gcell << endl; cdebug_log(145,1) << "void GCellTopology::_doDevice ()" << _gcell << endl;
/*
// Find NE and SW routing pads // Find NE and SW routing pads
Horizontal* hne = NULL; Horizontal* hne = NULL;
Vertical* vne = NULL; Vertical* vne = NULL;
@ -2140,30 +2144,55 @@ namespace {
} }
} }
} }
// SetExternal + create AutoContact northEast + southWest, Placed center of segment
if (hne) cerr << "NE: " << hne << endl; if (hne) cerr << "NE: " << hne << endl;
else cerr << "NE: " << vne << endl; else cerr << "NE: " << vne << endl;
if (hsw) cerr << "SW: " << hsw << endl; if (hsw) cerr << "SW: " << hsw << endl;
else cerr << "SW: " << vsw << endl; else cerr << "SW: " << vsw << endl;
*/
/*problem: How to create routing pad with segment only without plugs /*problem: How to create routing pad with segment only without plugs
*/ */
// _north, _south, _west, _east => segment GContact
// if nort or east
// detach wire from GContact to AutoContact
// move Segment to wire X (vertical), Y (horizontal) given by AutoContact
// do accordingly for _south and _west
//throw Error( "GCellTopology::_doDevice() Unimplemented, blame goes to E. Lao." ); //throw Error( "GCellTopology::_doDevice() Unimplemented, blame goes to E. Lao." );
} }
void GCellTopology::_doChannel () void GCellTopology::_doHChannel ()
{ {
/*throw Error( "GCellTopology::_doChannel() Unimplemented, blame goes to E. Lao.\n"
/*throw Error( "GCellTopology::_doHChannel() Unimplemented, blame goes to E. Lao.\n"
" On: %s." " On: %s."
, getString(_gcell).c_str() , getString(_gcell).c_str()
);*/ );*/
} }
void GCellTopology::_doStrut () void GCellTopology::_doVChannel ()
{ {
//throw Error( "GCellTopology::_doStrut() Unimplemented, blame goes to E. Lao." );
/*throw Error( "GCellTopology::_doVChannel() Unimplemented, blame goes to E. Lao.\n"
" On: %s."
, getString(_gcell).c_str()
);*/
}
void GCellTopology::_doHStrut ()
{
//throw Error( "GCellTopology::_doHStrut() Unimplemented, blame goes to E. Lao." );
}
void GCellTopology::_doVStrut ()
{
//throw Error( "GCellTopology::_doVStrut() Unimplemented, blame goes to E. Lao." );
} }

View File

@ -122,23 +122,27 @@ namespace Anabatic {
int index = indexMin.index(); int index = indexMin.index();
while ( index <= indexMax.index() ) { while ( index <= indexMax.index() ) {
cdebug_log(110,0) << "i,j = " << index2i(index) << "," << index2j(index)
<< " " << getGridPoint(index) << endl;
if (updateArea.contains(getGridPoint(index))) _gcells[index] = gcell; if (updateArea.contains(getGridPoint(index))) _gcells[index] = gcell;
if (index <= indexMax.j()) ++index; if (index2j(index) <= indexMax.j()) ++index;
else index += _imax - xspan; else index += _imax - xspan;
} }
cdebug_tabw(110,-1); cdebug_tabw(110,-1);
} }
void Matrix::show () const void Matrix::show () const
{ {
cdebug_log(111,0) << this << endl; cdebug_log(111,0) << this << endl;
for ( size_t i=0 ; i<_gcells.size() ; ++i ) { for ( size_t i=0 ; i<_gcells.size() ; ++i ) {
cdebug_log(111,0) << "[" << setw(3) << setfill('0') << i << setfill(' ') << "] (" //cdebug_log(111,0) << "[" << setw(3) << setfill('0') << i << setfill(' ') << "] ("
<< setw(3) << index2i(i) << "," // << setw(3) << index2i(i) << ","
<< setw(3) << index2j(i) << ") " << _gcells[i] << endl; // << setw(3) << index2j(i) << ") " << _gcells[i] << endl;
cdebug_log(111,0) << "[" << i << "] ("
<< index2i(i) << ","
<< index2j(i) << ") " << _gcells[i] << endl;
} }
} }

View File

@ -208,6 +208,7 @@ namespace Anabatic {
inline const NetDatas& getNetDatas () const; inline const NetDatas& getNetDatas () const;
NetData* getNetData ( Net*, unsigned int flags=Flags::NoFlags ); NetData* getNetData ( Net*, unsigned int flags=Flags::NoFlags );
void setupNetDatas (); void setupNetDatas ();
void updateMatrix ();
// Dijkstra related functions. // Dijkstra related functions.
inline int getStamp () const; inline int getStamp () const;
inline int incStamp (); inline int incStamp ();

View File

@ -33,8 +33,10 @@ namespace Anabatic {
static const unsigned int Invalidated ; // = (1 << 4); static const unsigned int Invalidated ; // = (1 << 4);
// Flags for GCell objects states only. // Flags for GCell objects states only.
static const unsigned int DeviceGCell ; // = (1 << 5); static const unsigned int DeviceGCell ; // = (1 << 5);
static const unsigned int ChannelGCell ; // = (1 << 6); static const unsigned int HChannelGCell ; // = (1 << 6);
static const unsigned int StrutGCell ; // = (1 << 7); static const unsigned int VChannelGCell ; // = (1 << 6);
static const unsigned int HStrutGCell ; // = (1 << 7);
static const unsigned int VStrutGCell ; // = (1 << 7);
static const unsigned int MatrixGCell ; // = (1 << 8); static const unsigned int MatrixGCell ; // = (1 << 8);
static const unsigned int IoPadGCell ; // = (1 << 9); static const unsigned int IoPadGCell ; // = (1 << 9);
static const unsigned int Saturated ; // = (1 << 10); static const unsigned int Saturated ; // = (1 << 10);
@ -55,7 +57,7 @@ namespace Anabatic {
static const unsigned int EndsMask ; // = Source|Target; static const unsigned int EndsMask ; // = Source|Target;
static const unsigned int DirectionMask ; // = Horizontal|Vertical; static const unsigned int DirectionMask ; // = Horizontal|Vertical;
static const unsigned int DestroyMask ; // = DestroyGCell|DestroyBaseContact|DestroyBaseSegment; static const unsigned int DestroyMask ; // = DestroyGCell|DestroyBaseContact|DestroyBaseSegment;
static const unsigned int GCellTypeMask ; // = DeviceGCell|ChannelGCell|StrutGCell|MatrixGCell|IoPadGCell; static const unsigned int GCellTypeMask ; // = DeviceGCell|HChannelGCell|VChannelGCell|HStrutGCell|VStrutGCell|MatrixGCell|IoPadGCell;
// Flags for functions arguments only. // Flags for functions arguments only.
static const unsigned int Create ; // = (1 << 5); static const unsigned int Create ; // = (1 << 5);
static const unsigned int WithPerpands ; static const unsigned int WithPerpands ;

View File

@ -131,8 +131,10 @@ namespace Anabatic {
inline bool isVFlat () const; inline bool isVFlat () const;
inline bool isFlat () const; inline bool isFlat () const;
inline bool isDevice () const; inline bool isDevice () const;
inline bool isChannel () const; inline bool isHChannel () const;
inline bool isStrut () const; inline bool isVChannel () const;
inline bool isHStrut () const;
inline bool isVStrut () const;
inline bool isMatrix () const; inline bool isMatrix () const;
inline bool isIoPad () const; inline bool isIoPad () const;
bool isWest ( GCell* ) const; bool isWest ( GCell* ) const;
@ -231,8 +233,8 @@ namespace Anabatic {
void _add ( Edge* edge, Flags side ); void _add ( Edge* edge, Flags side );
void _remove ( Edge* edge, Flags side=Flags::AllSides ); void _remove ( Edge* edge, Flags side=Flags::AllSides );
void _destroyEdges (); void _destroyEdges ();
private:
void _revalidate (); void _revalidate ();
private:
void _moveEdges ( GCell* dest, size_t ibegin, Flags flags ); void _moveEdges ( GCell* dest, size_t ibegin, Flags flags );
public: public:
// Observers. // Observers.
@ -290,8 +292,10 @@ namespace Anabatic {
inline bool GCell::isVFlat () const { return getXMin() == getXMax(); } inline bool GCell::isVFlat () const { return getXMin() == getXMax(); }
inline bool GCell::isFlat () const { return isHFlat() or isVFlat(); } inline bool GCell::isFlat () const { return isHFlat() or isVFlat(); }
inline bool GCell::isDevice () const { return _flags & Flags::DeviceGCell; } inline bool GCell::isDevice () const { return _flags & Flags::DeviceGCell; }
inline bool GCell::isChannel () const { return _flags & Flags::ChannelGCell; } inline bool GCell::isHChannel () const { return _flags & Flags::HChannelGCell; }
inline bool GCell::isStrut () const { return _flags & Flags::StrutGCell; } inline bool GCell::isVChannel () const { return _flags & Flags::VChannelGCell; }
inline bool GCell::isHStrut () const { return _flags & Flags::HStrutGCell; }
inline bool GCell::isVStrut () const { return _flags & Flags::VStrutGCell; }
inline bool GCell::isMatrix () const { return _flags & Flags::MatrixGCell; } inline bool GCell::isMatrix () const { return _flags & Flags::MatrixGCell; }
inline bool GCell::isIoPad () const { return _flags & Flags::IoPadGCell; } inline bool GCell::isIoPad () const { return _flags & Flags::IoPadGCell; }
inline bool GCell::isSaturated () const { return _flags & Flags::Saturated; } inline bool GCell::isSaturated () const { return _flags & Flags::Saturated; }

View File

@ -94,6 +94,7 @@ namespace Anabatic {
inline GCell* getUnder ( Point ) const; inline GCell* getUnder ( Point ) const;
void setCell ( Cell*, DbU::Unit side ); void setCell ( Cell*, DbU::Unit side );
void updateLookup ( GCell* ); void updateLookup ( GCell* );
void resize ( Box area, DbU::Unit side );
void show () const; void show () const;
// Inspector support. // Inspector support.
virtual Record* _getRecord () const; virtual Record* _getRecord () const;