coriolis/katabatic/doc/man/man3/Katabatic_Session.3

333 lines
14 KiB
Groff

.TH "Session" 3 "Sun Nov 21 2021" "Version 1.0" "Katabatic - Routing Toolbox" \" -*- nroff -*-
.ad l
.nh
.SH NAME
Session \- Modification \fBSession\fP for \fBKatabatic\fP\&.
.SH SYNOPSIS
.br
.PP
.SS "Static Public Member Functions"
.in +1c
.ti -1c
.RI "static bool \fBisInDemoMode\fP ()"
.br
.ti -1c
.RI "static bool \fBdoWarnGCellOverload\fP ()"
.br
.ti -1c
.RI "static \fBSession\fP * \fBget\fP (const char *message=NULL)"
.br
.ti -1c
.RI "static \fBTechnology\fP * \fBgetTechnology\fP ()"
.br
.ti -1c
.RI "static \fBKatabaticEngine\fP * \fBgetKatabatic\fP ()"
.br
.ti -1c
.RI "static const Configuration * \fBgetConfiguration\fP ()"
.br
.ti -1c
.RI "static float \fBgetSaturateRatio\fP ()"
.br
.ti -1c
.RI "static size_t \fBgetSaturateRp\fP ()"
.br
.ti -1c
.RI "static \fBDbU::Unit\fP \fBgetExtensionCap\fP ()"
.br
.ti -1c
.RI "static \fBRoutingGauge\fP * \fBgetRoutingGauge\fP ()"
.br
.ti -1c
.RI "static const \fBLayer\fP * \fBgetRoutingLayer\fP (size_t)"
.br
.ti -1c
.RI "static const \fBLayer\fP * \fBgetContactLayer\fP (size_t)"
.br
.ti -1c
.RI "static size_t \fBgetSegmentStackSize\fP ()"
.br
.ti -1c
.RI "static size_t \fBgetContactStackSize\fP ()"
.br
.ti -1c
.RI "static const vector< \fBAutoSegment\fP * > & \fBgetInvalidateds\fP ()"
.br
.ti -1c
.RI "static const vector< \fBAutoSegment\fP * > & \fBgetRevalidateds\fP ()"
.br
.ti -1c
.RI "static const vector< \fBAutoSegment\fP * > & \fBgetDoglegs\fP ()"
.br
.ti -1c
.RI "static const set< \fBNet\fP * > & \fBgetNetsModificateds\fP ()"
.br
.ti -1c
.RI "static \fBSession\fP * \fBopen\fP (\fBKatabaticEngine\fP *)"
.br
.ti -1c
.RI "static void \fBclose\fP ()"
.br
.ti -1c
.RI "static void \fBsetKatabaticFlags\fP (unsigned int)"
.br
.ti -1c
.RI "static void \fBdogleg\fP (\fBAutoSegment\fP *)"
.br
.ti -1c
.RI "static void \fBrevalidateTopology\fP ()"
.br
.ti -1c
.RI "static void \fBsetInvalidateMask\fP (unsigned int)"
.br
.ti -1c
.RI "static void \fBinvalidate\fP (\fBNet\fP *)"
.br
.ti -1c
.RI "static void \fBinvalidate\fP (\fBAutoContact\fP *)"
.br
.ti -1c
.RI "static void \fBinvalidate\fP (\fBAutoSegment\fP *)"
.br
.ti -1c
.RI "static size_t \fBrevalidate\fP ()"
.br
.ti -1c
.RI "static void \fBlink\fP (\fBAutoContact\fP *)"
.br
.ti -1c
.RI "static void \fBlink\fP (\fBAutoSegment\fP *)"
.br
.ti -1c
.RI "static void \fBunlink\fP (\fBAutoContact\fP *)"
.br
.ti -1c
.RI "static void \fBunlink\fP (\fBAutoSegment\fP *)"
.br
.ti -1c
.RI "static \fBAutoContact\fP * \fBlookup\fP (\fBContact\fP *)"
.br
.ti -1c
.RI "static \fBAutoSegment\fP * \fBlookup\fP (\fBSegment\fP *)"
.br
.in -1c
.SH "Detailed Description"
.PP
Modification \fBSession\fP for \fBKatabatic\fP\&.
To perform modifications, the \fBKatabatic\fP data structure uses a session mechanism built on top of the \fBHurricane::UpdateSession\fP one\&. Sessions obeys very simples rules:
.IP "\(bu" 2
Only one \fBSession\fP can be opened at a time with \fBSession::open()\fP\&.
.IP "\(bu" 2
Subsequent calls to \fBSession::open()\fP returns the currently opened session until \fBSession::close()\fP is called\&.
.IP "\(bu" 2
Revalidation can take place whithout closing the \fBSession\fP by calling \fBSession::revalidate()\fP\&.
.PP
.PP
The task of a \fBSession\fP is to keep track of the \fBAutoContact\fP and \fBAutoSegment\fP that have been modificateds (i\&.e\&. invalidated) and, to restore connexity and/or topology when closed\&.
.PP
Two kinds of revalidation could be performed:
.PD 0
.IP "\(bu" 2
\fBGeometrical\fP : only positions of AutoContacts and AutoSegments extensions are recomputed\&.
.IP "\(bu" 2
\fBTopological\fP : a whole net have been invalidated because of a dogleg creation or a move up/move down of a segment\&.
.PD 0
.IP " \(bu" 4
\fBDogleg\fP : needs to insert the newly created AutoSegments and AutoContacts\&.
.IP " \(bu" 4
\fBMove up/Move down\fP : may needs to create additional dogleg to restore connexity (gaps), and then insert them like above\&.
.PP
After a topological mofication has been done, the net needs to be re-canonized then the geometrical step takes place\&.
.PP
.PP
The kind of revalidation needed is automatically detected by the \fBSession\fP\&.
.PP
In addition to it's main purpose, \fBSession\fP also provides cached access to frequently needed variables either from Hurricane or \fBKatabatic\fP Configuration and access to the \fBAutoContact\fP & \fBAutoSegment\fP LUTs of \fBKatabaticEngine\fP\&.
.PP
From a software point of view, \fBSession\fP is a singleton object\&.
.SH "Session Algorithm"
.PP
Main attributes of a \fBSession\fP:
.IP "\(bu" 2
\fC_netInvalidateds\fP, nets on which topology has changed\&.
.IP "\(bu" 2
\fC_autoSegments\fP, that have been moved or createds\&.
.IP "\(bu" 2
\fC_autoContacts\fP, that have been created or one of their slave segment has moved\&.
.IP "\(bu" 2
\fC_revalidateds\fP, the list of AutoSegments that have just been revalidated (after calling \fC\fBrevalidate()\fP\fP)\&.
.PP
.PP
Schematic description of how a \fBSession\fP works:
.PP
.PD 0
.IP "\(bu" 2
If at least one net has been invalidated, meaning that it's topology has changed, perform \fC_revalidateTopology()\fP\&.
.PD 0
.IP " \(bu" 4
Update net topology: correct the topology of each contacts, making dogleg when needed\&. The \fBAutoContact\fP segment caching is updated at this point\&.
.IP " \(bu" 4
Compute net constraints (on AutoContacts & AutoSegments)\&.
.IP " \(bu" 4
Compute net optimal positions (on AutoSegments)\&.
.IP " \(bu" 4
Compute the state of the segments regarding to terminals\&.
.IP " \(bu" 4
Canonize sets of aligneds segments\&. The canonical segment is the one with the lowest \fCid\fP\&.
.IP " \(bu" 4
If the segments has just been created, put it on its optimal axis\&.
.PP
This stage can add itself more invalidated AutoSegments and AutoContacts as it create doglegs\&.
.PP
.IP "\(bu" 2
Revalidate geometry of AutoContacts\&. That is, expand or shrink the extremities of the invalidated AutoSegments\&. Note that AutoSegments are already at on their final axis position\&.
.PP
.IP "\(bu" 2
Revalidate AutoSegments\&. Just before this stage, they are on the correct axis and their extensions are also correct, so we may update the caching of their characteristics (mostly the extension)\&.
.PP
.SH "Member Function Documentation"
.PP
.SS "bool isInDemoMode ()\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References KatabaticEngine::isInDemoMode()\&.
.PP
Referenced by GCell::checkDensity()\&.
.SS "bool doWarnGCellOverload ()\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References KatabaticEngine::doWarnOnGCellOverload()\&.
.PP
Referenced by GCell::checkDensity()\&.
.SS "\fBSession\fP * get (const char * message = \fCNULL\fP)\fC [static]\fP"
Return the \fBSession\fP singleton, if no session is currently open throw an exception carrying \fCmessage\fP\&.
.SS "\fBTechnology\fP * getTechnology ()\fC [inline]\fP, \fC [static]\fP"
Hurricane shortcut\&.
.SS "\fBKatabaticEngine\fP * getKatabatic ()\fC [inline]\fP, \fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
Referenced by AutoSegment::create(), GCellTopology::doRp_AccessPad(), GCellTopology::doRp_AutoContacts(), AutoSegment::makeDogleg(), and Session::open()\&.
.SS "const Configuration * getConfiguration ()\fC [inline]\fP, \fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
Referenced by AutoHorizontal::_makeDogleg(), AutoVertical::_makeDogleg(), and AutoSegment::canMoveUp()\&.
.SS "float getSaturateRatio ()\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References KatabaticEngine::getSaturateRatio()\&.
.PP
Referenced by GCell::isSaturated()\&.
.SS "size_t getSaturateRp ()\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References KatabaticEngine::getSaturateRp()\&.
.PP
Referenced by GCell::rpDesaturate()\&.
.SS "\fBDbU::Unit\fP getExtensionCap ()\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
Referenced by AutoHorizontal::checkPositions(), AutoVertical::checkPositions(), AutoHorizontal::updatePositions(), and AutoVertical::updatePositions()\&.
.SS "\fBRoutingGauge\fP * getRoutingGauge ()\fC [inline]\fP, \fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
Referenced by AutoHorizontal::_makeDogleg(), AutoVertical::_makeDogleg(), AutoHorizontal::canMoveULeft(), AutoVertical::canMoveULeft(), AutoSegment::canMoveUp(), AutoHorizontal::canMoveURight(), AutoVertical::canMoveURight(), AutoSegment::canPivotDown(), AutoSegment::canPivotUp(), GCell::checkDensity(), Session::getContactLayer(), Session::getRoutingLayer(), GCell::hasFreeTrack(), AutoSegment::makeDogleg(), anonymous_namespace{LoadGrByNet\&.cpp}::singleGCell(), GCell::stepDesaturate(), GCell::stepNetDesaturate(), GCell::updateDensity(), AutoContactVTee::updateTopology(), AutoContactTurn::updateTopology(), AutoContactHTee::updateTopology(), and AutoContactTerminal::updateTopology()\&.
.SS "const \fBLayer\fP * getRoutingLayer (size_t depth)\fC [inline]\fP, \fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References Session::getRoutingGauge(), and RoutingGauge::getRoutingLayer()\&.
.PP
Referenced by GCellTopology::_do_xG_1M1_1M2(), GCellTopology::_do_xG_xM1_xM3(), AutoSegment::create(), GCellTopology::doRp_AccessPad(), AutoSegment::reduceDoglegLayer(), and GCell::rpDesaturate()\&.
.SS "const \fBLayer\fP * getContactLayer (size_t depth)\fC [inline]\fP, \fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References RoutingGauge::getContactLayer(), and Session::getRoutingGauge()\&.
.PP
Referenced by GCellTopology::_do_1G_1M3(), GCellTopology::_do_1G_xM1(), GCellTopology::_do_xG(), GCellTopology::_do_xG_1M1_1M2(), GCellTopology::_do_xG_1Pad(), GCellTopology::_do_xG_xM1_xM3(), GCellTopology::_do_xG_xM2(), GCellTopology::_do_xG_xM3(), GCellTopology::doRp_Access(), GCellTopology::doRp_AccessPad(), GCellTopology::doRp_AutoContacts(), GCellTopology::doRp_StairCaseH(), GCellTopology::doRp_StairCaseV(), and anonymous_namespace{LoadGrByNet\&.cpp}::singleGCell()\&.
.SS "size_t getSegmentStackSize ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The number of \fBAutoSegment\fP in the invalidated stack\&.
.SS "size_t getContactStackSize ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The number of \fBAutoSegment\fP in the invalidated stack\&.
.SS "const vector< \fBAutoSegment\fP * > & getInvalidateds ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The stack (vector) of invalidateds AutoSegments\&.
.SS "const vector< \fBAutoSegment\fP * > & getRevalidateds ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The stack (vector) of AutoSegments that have been revalidateds\&.
.SS "const vector< \fBAutoSegment\fP * > & getDoglegs ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The vector of AutoSegments part of a newly created dogleg\&. The dogleg creation functions in \fBAutoHorizontal\fP and \fBAutoVertical\fP put a triplet (for example in horizontal direction \fC\fP(h1,v1,h2) ) for each dogleg composed of:
.IP "\(bu" 2
\fBh1\fP the segment \fIbefore\fP the dogleg (which is also the original one)\&.
.IP "\(bu" 2
\fBv1\fP the segment \fBperpandicular\fP (new)\&.
.IP "\(bu" 2
\fBh2\fP the segment \fBafter\fP (new)\&.
.PP
.PP
Referenced by AutoSegment::makeDogleg()\&.
.SS "const set< \fBNet\fP * > & getNetsModificateds ()\fC [inline]\fP, \fC [static]\fP"
\fBReturns:\fP The set of Nets that needs either a topological update or a new canonization\&.
.SS "\fBSession\fP * open (\fBKatabaticEngine\fP * ktbt)\fC [static]\fP"
Opens a new session or returns the already opened one, if any\&.
.PP
References Session::getKatabatic()\&.
.PP
Referenced by GCellGrid::updateContacts()\&.
.SS "void close ()\fC [static]\fP"
Close the \fBSession\fP, triggering the revalidation of the AutoSegemnts and AutoContacts\&. If no \fBSession\fP is opened, throws an execption\&.
.PP
Referenced by GCellGrid::updateContacts()\&.
.SS "void setKatabaticFlags (unsigned int flags)\fC [static]\fP"
\fBKatabatic\fP shortcut\&.
.PP
References KatabaticEngine::setFlags()\&.
.SS "void dogleg (\fBAutoSegment\fP * autoSegment)\fC [inline]\fP, \fC [static]\fP"
Adds an \fBAutoSegment\fP to the dogleg vector\&.
.PP
Referenced by AutoHorizontal::_makeDogleg(), and AutoVertical::_makeDogleg()\&.
.SS "void revalidateTopology ()\fC [inline]\fP, \fC [static]\fP"
Revalidate Net that have been invalidateds and re-canonize them\&.
.SS "void setInvalidateMask (unsigned int flags)\fC [inline]\fP, \fC [static]\fP"
Tells what kind of revalidation must be performed\&.
.SS "void invalidate (\fBNet\fP * net)\fC [inline]\fP, \fC [static]\fP"
Schedule \fCnet\fP for a full revalidation, topological correction and canonization\&.
.PP
Referenced by AutoSegment::_invalidate(), and AutoSegment::_postCreate()\&.
.SS "void invalidate (\fBAutoContact\fP * contact)\fC [inline]\fP, \fC [static]\fP"
Schedule \fCcontact\fP for revalidation\&.
.SS "void invalidate (\fBAutoSegment\fP * segment)\fC [inline]\fP, \fC [static]\fP"
Schedule \fCsegment\fP for revalidation\&.
.SS "size_t revalidate ()\fC [inline]\fP, \fC [static]\fP"
Perform the revalidation\&. Returns the sum of AutoContacts and AutoSegemnts that have been revalidated\&.
.PP
Referenced by KatabaticEngine::createDetailedGrid()\&.
.SS "void link (\fBAutoContact\fP * ac)\fC [static]\fP"
Adds \fCac\fP in the \fBAutoContact\fP lookup table (allow to retrieve an \fBAutoContact\fP by it's base Contact)\&.
.PP
Referenced by AutoSegment::_postCreate()\&.
.SS "void link (\fBAutoSegment\fP * as)\fC [static]\fP"
Adds \fCas\fP in the \fBAutoSegment\fP lookup table (allow to retrieve an \fBAutoSegment\fP by it's base Segment)\&.
.SS "void unlink (\fBAutoContact\fP * ac)\fC [static]\fP"
Removes \fCac\fP from the \fBAutoContact\fP lookup table\&.
.PP
Referenced by AutoSegment::_preDestroy()\&.
.SS "void unlink (\fBAutoSegment\fP * as)\fC [static]\fP"
Removes \fCas\fP from the \fBAutoSegment\fP lookup table\&.
.SS "\fBAutoContact\fP * lookup (\fBContact\fP * contact)\fC [static]\fP"
Lookup the \fBAutoContact\fP associated with \fCcontact\fP\&. \fCNULL\fP if not found\&.
.PP
Referenced by AutoSegment::AutoSegment(), GCell::checkEdgeSaturation(), AutoSegment::create(), AutoSegment::getAutoSource(), AutoSegment::getAutoTarget(), AutoSegment::getOppositeAnchor(), and AutoSegment::getPerpandicularsBound()\&.
.SS "\fBAutoSegment\fP * lookup (\fBSegment\fP * segment)\fC [static]\fP"
Lookup the \fBAutoSegment\fP associated with \fCsegment\fP\&. \fCNULL\fP if not found\&.
.SH "Author"
.PP
Generated automatically by Doxygen for Katabatic - Routing Toolbox from the source code\&.