An interface for a Controller of OpenFlowSwitchNetDevices.
More...
#include <openflow-interface.h>
|
virtual | ~Controller () |
|
virtual void | AddSwitch (Ptr< OpenFlowSwitchNetDevice > swtch) |
| Adds a switch to the controller. More...
|
|
virtual void | ReceiveFromSwitch (Ptr< OpenFlowSwitchNetDevice > swtch, ofpbuf *buffer) |
| A switch calls this method to pass a message on to the Controller. More...
|
|
void | StartDump (StatsDumpCallback *cb) |
| Starts a callback-based, reliable, possibly multi-message reply to a request made by the controller. More...
|
|
| Object () |
|
virtual | ~Object () |
|
void | AggregateObject (Ptr< Object > other) |
|
void | Dispose (void) |
| Run the DoDispose methods of this object and all the objects aggregated to it. More...
|
|
AggregateIterator | GetAggregateIterator (void) const |
|
virtual TypeId | GetInstanceTypeId (void) const |
|
template<typename T > |
Ptr< T > | GetObject (void) const |
|
template<typename T > |
Ptr< T > | GetObject (TypeId tid) const |
|
void | Initialize (void) |
| This method calls the virtual DoInitialize method on all the objects aggregated to this object. More...
|
|
| SimpleRefCount () |
| Constructor. More...
|
|
| SimpleRefCount (const SimpleRefCount &o) |
| Copy constructor. More...
|
|
uint32_t | GetReferenceCount (void) const |
| Get the reference count of the object. More...
|
|
SimpleRefCount & | operator= (const SimpleRefCount &o) |
| Assignment. More...
|
|
void | Ref (void) const |
| Increment the reference count. More...
|
|
void | Unref (void) const |
| Decrement the reference count. More...
|
|
virtual | ~ObjectBase () |
| Virtual destructor. More...
|
|
void | GetAttribute (std::string name, AttributeValue &value) const |
|
bool | GetAttributeFailSafe (std::string name, AttributeValue &attribute) const |
|
void | SetAttribute (std::string name, const AttributeValue &value) |
|
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
|
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
|
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
|
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
|
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
|
An interface for a Controller of OpenFlowSwitchNetDevices.
Follows the OpenFlow specification for a controller.
Definition at line 346 of file openflow-interface.h.
virtual ns3::ofi::Controller::~Controller |
( |
| ) |
|
|
inlinevirtual |
Adds a switch to the controller.
- Parameters
-
swtch | The switch to register. |
ofp_flow_mod* ns3::ofi::Controller::BuildFlow |
( |
sw_flow_key |
key, |
|
|
uint32_t |
buffer_id, |
|
|
uint16_t |
command, |
|
|
void * |
acts, |
|
|
size_t |
actions_len, |
|
|
int |
idle_timeout, |
|
|
int |
hard_timeout |
|
) |
| |
|
protected |
- Internal:
Construct flow data from a matching key to build a flow entry for adding, modifying, or deleting a flow.
- Parameters
-
key | The matching key data; used to create a flow that matches the packet. |
buffer_id | The OpenFlow Buffer ID; used to run the actions on the packet if we add or modify the flow. |
command | Whether to add, modify, or delete this flow. |
acts | List of actions to execute. |
actions_len | Length of the actions buffer. |
idle_timeout | Flow expires if left inactive for this amount of time (specify OFP_FLOW_PERMANENT to disable feature). |
hard_timeout | Flow expires after this amount of time (specify OFP_FLOW_PERMANENT to disable feature). |
- Returns
- Flow data that when passed to SetFlow will add, modify, or delete a flow it defines.
uint8_t ns3::ofi::Controller::GetPacketType |
( |
ofpbuf * |
buffer | ) |
|
|
protected |
- Internal:
Get the packet type on the buffer, which can then be used to determine how to handle the buffer.
- Parameters
-
buffer | The packet in OpenFlow buffer format. |
- Returns
- The packet type, as defined in the ofp_type struct.
static TypeId ns3::ofi::Controller::GetTypeId |
( |
void |
| ) |
|
|
inlinestatic |
- Internal:
However the controller is implemented, this method is to be used to pass a message on to a switch.
- Parameters
-
swtch | The switch to receive the message. |
msg | The message to send. |
length | The length of the message. |
Starts a callback-based, reliable, possibly multi-message reply to a request made by the controller.
If an incoming request needs to have a reliable reply that might require multiple messages, it can use StartDump() to set up a callback that will be called as buffer space for replies.
A stats request made by the controller is processed by the switch, the switch then calls this method to tell the controller to start asking for information. By default (it can be overridden), the controller stops all work to run through the callback. ReceiveFromSwitch must be defined appropriately to handle the status reply messages generated by the switch, or otherwise the status reply messages will be sent and discarded.
- Parameters
-
The documentation for this class was generated from the following file: