coriolis/hurricane/doc/hurricane/Net.dox

339 lines
12 KiB
C++

// -*- C++ -*-
namespace Hurricane {
//! \class Net
//! \brief Net description (\b API)
//!
//! \section secNetPredefinedFilters Predefined filters
//!
//! - <b>Hurricane::Net::getIsGlobalFilter</b>
//! - <b>Hurricane::Net::getIsExternalFilter</b>
//! - <b>Hurricane::Net::getIsInternalFilter</b>
//! - <b>Hurricane::Net::getIsClockFilter</b>
//! - <b>Hurricane::Net::getIsSupplyFilter</b>
/*! \typedef Net::Inherit
* Useful for calling upon methods of the base class without
* knowing it.
*/
/*! \typedef Net::Arity
* This type allows to represent the number of bits associated
* to a net (a null value meaning undefined).
*/
/*! \class Net::Type
* Encapsulate the Net::Type::Code enumeration that defines the
* signal category.
*/
//! \enum Net::Type::Code
//! This enumeration defines the signal category inside the Net::Type.
//! \var Net::Type::Code Net::Type::UNDEFINED
//! Type undefined.
//! \var Net::Type::Code Net::Type::LOGICAL
//! Type assigned to ordinary signals.
//! \var Net::Type::Code Net::Type::CLOCK
//! Type assigned to clock signals.
//! \var Net::Type::Code Net::Type::POWER
//! Type assigned to supply signals.
//! \var Net::Type::Code Net::Type::GROUND
//! Type assigned to supply signals.
//! \class Net::Direction
//! Encapsulate the Net::Direction::Code enumeration that defines the
//! signal direction. This direction is meaningful for external nets only.
//!
//! \enum Net::Direction::Code
//! This enumeration defines the signal direction inside the Net::Direction.
//! It is build upon two kind of atomic flags, one telling were the sources
//! and sinks are located regarding the Cell and the other indicating the
//! nature of the driver (normal, tristate, wired-or).
//!
//! \var Net::Direction::Code Net::Direction::DirUndefined
//! Undefined direction (<em>atomic</em>).
//!
//! \var Net::Direction::Code Net::Direction::DirIn
//! There is at least one sink on this net (<em>atomic</em>).
//!
//! \var Net::Direction::Code Net::Direction::DirOut
//! There is at least one source on this net (<em>atomic</em>).
//!
//! \var Net::Direction::Code Net::Direction::ConnTristate
//! The sources are <b>tristates</b>, this a bus (<em>atomic</em>).
//!
//! \var Net::Direction::Code Net::Direction::ConnWiredOr
//! The sources are <b>wired or</b>, this a bus (<em>atomic</em>).
//!
//! \var Net::Direction::Code Net::Direction::UNDEFINED
//! Undefined direction.
//!
//! \var Net::Direction::Code Net::Direction::IN
//! There must be only sinks inside and a single permanent driver
//! outside.
//!
//! \var Net::Direction::Code Net::Direction::OUT
//! There must be no driver outside and a single permanent driver
//! inside (and no sinks inside).
//!
//! \var Net::Direction::Code Net::Direction::INOUT
//! There must be one permanent driver inside withs at least one
//! sink inside.
//!
//! \var Net::Direction::Code Net::Direction::TRISTATE
//! An OUT signal with a tristate driver (bus).
//!
//! \var Net::Direction::Code Net::Direction::TRANSCV
//! An INOUT signal with a tristate driver (bus).
//!
//! \var Net::Direction::Code Net::Direction::WOR_OUT
//! An OUT signal with a wired-or driver (bus).
//!
//! \var Net::Direction::Code Net::Direction::WOR_INOUT
//! An INOUT signal with a wired-or driver (bus).
/*! \function Net* Net::create(Cell* cell, const Name& name);
* Creates and returns a new net named \c \<name\> for the cell
* \c \<cell\>.
*
* \caution Throws an exception if the cell is null, if the name empty or
* if a net with same name already exists.
*/
/*! \function const Name& Net::getName() const;
* \Return the net name.
*/
/*! \function const Net::Arity& Net::getArity() const;
* \Return the signal arity (by default set to 1).
*/
/*! \function const Net::Type& Net::getType() const;
* \Return the signal type (by default set to UNDEFINED).
*/
/*! \function const Net::Direction& Net::getDirection() const;
* \Return the signal direction (by default set to UNDEFINED).
*
* \remark This direction is meaningfull only for external nets.
*/
/*! \function const Point& Net::getPosition() const;
* \Return the X,Y position of the net. This position is used for
* computing the location of the plugs (on slave instances
* calling the cell owning this net) having that net as master.
*/
/*! \function const Unit& Net::getX() const;
* \Return net abscissa.
*/
/*! \function const Unit& Net::getY() const;
* \Return net ordinate.
*/
/*! \function Rubbers Net::getRubbers() const;
* \Return the collection of net's rubbers.
*/
/*! \function Components Net::getComponents() const;
* \Return the collection of net's components.
*/
/*! \function Plugs Net::getPlugs() const;
* \Return the collection of net's plugs.
*/
/*! \function Contacts Net::getContacts() const;
* \Return the collection of net's contacts.
*/
/*! \function Segments Net::getSegments() const;
* \Return the collection of net's segments.
*/
/*! \function Verticals Net::getVerticals() const;
* \Return the collection of net's vertical segments.
*/
/*! \function Horizontals Net::getHorizontals() const;
* \Return the collection of net's horizontal segments.
*/
/*! \function Pads Net::getPads() const;
* \Return the collection of net's pads.
*/
//! \function RoutingPads Net::getRoutingPads() const;
//! \Return the collection of net's RoutingPads.
/*! \function Plugs Net::getSlavePlugs() const;
* \Return the collection of plugs which have this net as master.
*
* \remark Meaningfull only for external nets.
*/
/*! \function Plugs Net::getConnectedSlavePlugs() const;
* \Return the collection of connected plugs which have this net as
* master.
*
* \remark Meaningfull only for external nets.
*/
/*! \function Plugs Net::getUnconnectedSlavePlugs() const;
* \Return the collection of unconnected plugs which have this net as
* master.
*
* \remark Meaningfull only for external nets.
*/
/*! \function bool Net::isGlobal() const;
* \Return \true if the net is global else \false.
*/
/*! \function bool Net::isExternal() const;
* \Return \true if the net is external else \false.
*/
/*! \function bool Net::isLogical() const;
* \Return \true if the net is logical else \false.
*/
/* \function bool Net::IsTriState() const;
* \Return \true if the net is tri-state else \false.
*/
/*! \function bool Net::isClock() const;
* \Return \true if the net is a clock else \false.
*/
/*! \function bool Net::isSupply() const;
* \Return \true if the net is a supply else \false.
*/
/*! \function void Net::setName(const Name& name);
* Allows to change net name.
*
* \remark Throws an exception if the new name is empty, or if a net
* with same net already exists in the cell.
*/
/*! \function void Net::setArity(const Net::Arity& arity);
* Sets the signal arity to \c \<arity\>.
*/
/*! \function void Net::setGlobal(bool state);
* Sets global signal status to \c \<state\>.
*/
/*! \function void Net::setExternal(bool state);
* Sets the external net status to \c \<state\>.
*
* \remark This function will throw an exception if the net switches to
* internal and there is a plug refering to it.
*/
/*! \function void Net::setType(const Net::Type& type);
* Sets the signal type of the net.
*/
/*! \function void Net::setDirection(const Net::Direction& direction);
* Sets the signal direction of the net.
*/
/*! \function void Net::setPosition(const Point& position);
* Sets the X,Y location of the net. By default it is located at
* the coordinates origin of the cell (point 0,0).
*/
/*! \function void Net::materialize();;
* Materializes all the rubbers and components of a net.
*/
/*! \function void Net::unmaterialize();;
* De-materializes all rubbers and the components of a net.
*/
/*! \function void Net::merge(Net* net);
* Merges the net \c \<net\> to the net \c \<this\> which keeps
* its characteristics (arity, global, external and direction).
*
* \caution An exception is thrown if the \c \<net\> is null or equal to
* \c \<this\>, if the two nets don't belong to the same cell or
* if \c \<net\> is external and master net of a connected plug
* while net \c \<this\> is not external.
*
* \remark All the rubbers and the components of the \c \<net\> (and
* also the plugs) become rubbers or components of the net
* \c \<this\>. Nevertheless if for a particular slave instance
* there was both a plug referencing the \c \<net\> and an other
* plug referencing \c \<this\>, the first is deleted to the
* advantage of the second, because a net can't have more than
* one plug for a given instance (the rings of the body hooks
* are then merged).
*
* \remark Once the merger done the net \c \<net\> is definitively
* deleted. Its properties and those of its deleted plugs, if
* any, are lost (as well as the ones which could be attached to
* their occurences).
*/
//! \name Net Collection
// \{
/*! \typedef Nets
* Generic collection representing a set of nets.
*/
/*! \typedef NetLocator
* Generic locator for traversing a collection of nets.
*/
/*! \typedef NetFilter
* Generic filter allowing to select a subset of nets matching
* some criteria.
*/
/*! \def for_each_net(net, nets)
* Macro for visiting all the nets of a collection of nets.
*/
// \}
/*! \function NetFilter Net::getIsGlobalFilter();
* \Return the filter selecting global nets.
*/
/*! \function NetFilter Net::getIsExternalFilter();
* \Return the filter selecting external nets.
*/
/*! \function NetFilter Net::getIsInternalFilter();
* \Return the filter selecting internal nets.
*/
/*! \function NetFilter Net::getIsClockFilter();
* \Return the filter selecting clock nets.
*/
/*! \function NetFilter Net::getIsSupplyFilter();
* \Return the filter selecting supply nets.
*/
}