26 namespace interface_cmds {
28 const std::string&
name)
29 : create_cmd(item, name)
36 msg_t req(con.
ctx(), std::ref(*
this));
58 const std::string&
name)
66 msg_t req(con.
ctx(), std::ref(*
this));
68 auto& payload = req.get_request().get_payload();
70 payload.use_random_hw_addr = 1;
71 memset(payload.host_if_name, 0,
sizeof(payload.host_if_name));
72 memcpy(payload.host_if_name,
m_name.c_str(),
73 std::min(
m_name.length(),
sizeof(payload.host_if_name)));
95 const std::string&
name,
96 const std::string& tag)
105 msg_t req(con.
ctx(), std::ref(*
this));
107 auto& payload = req.get_request().get_payload();
108 memset(payload.sock_filename, 0,
sizeof(payload.sock_filename));
109 memcpy(payload.sock_filename,
m_name.c_str(),
110 std::min(
m_name.length(),
sizeof(payload.sock_filename)));
111 memset(payload.tag, 0,
sizeof(payload.tag));
114 memcpy(payload.tag, m_tag.c_str(),
115 std::min(m_tag.length(),
sizeof(payload.tag)));
117 payload.is_server = 0;
118 payload.use_custom_mac = 0;
119 payload.renumber = 0;
135 std::ostringstream s;
150 msg_t req(con.
ctx(), std::ref(*
this));
152 auto& payload = req.get_request().get_payload();
167 std::ostringstream s;
174 const std::string&
name)
182 msg_t req(con.
ctx(), std::ref(*
this));
184 auto& payload = req.get_request().get_payload();
185 memset(payload.host_if_name, 0,
sizeof(payload.host_if_name));
186 memcpy(payload.host_if_name,
m_name.c_str(),
187 std::min(
m_name.length(),
sizeof(payload.host_if_name)));
200 std::ostringstream s;
207 const std::string&
name)
215 msg_t req(con.
ctx(), std::ref(*
this));
217 auto& payload = req.get_request().get_payload();
230 std::ostringstream s;
252 msg_t req(con.
ctx(), std::ref(*
this));
254 auto& payload = req.get_request().get_payload();
255 payload.sw_if_index = m_hdl.
data().
value();
266 std::ostringstream s;
284 return ((m_hdl == other.m_hdl) && (m_proto == other.m_proto) &&
291 msg_t req(con.
ctx(), std::ref(*
this));
293 auto& payload = req.get_request().get_payload();
294 payload.sw_if_index = m_hdl.
data().
value();
295 payload.is_ipv6 = m_proto.
is_ipv6();
306 std::ostringstream s;
328 msg_t req(con.
ctx(), std::ref(*
this));
330 auto& payload = req.get_request().get_payload();
331 payload.sw_if_index = m_hdl.
data().
value();
333 sizeof(payload.mac_address));
343 std::ostringstream s;
363 (m_enable == other.m_enable));
369 msg_t req(con.
ctx(), std::ref(*
this));
371 auto& payload = req.get_request().get_payload();
372 payload.sw_if_index = m_hdl.
value();
373 payload.enable_disable = m_enable;
383 std::ostringstream s;
406 m_reg.reset(
new reg_t(con.
ctx(), std::ref(*(static_cast<event_cmd*>(
this)))));
411 msg_t req(con.
ctx(), std::ref(*(static_cast<rpc_cmd*>(
this))));
413 auto& payload = req.get_request().get_payload();
414 payload.enable_disable = 1;
415 payload.pid = getpid();
430 msg_t req(con.
ctx(), std::ref(*(static_cast<rpc_cmd*>(
this))));
432 auto& payload = req.get_request().get_payload();
433 payload.enable_disable = 0;
434 payload.pid = getpid();
450 return (
"itf-events");
460 , m_swifindex(handle)
476 m_reg.reset(
new reg_t(con.
ctx(), std::ref(*(static_cast<event_cmd*>(
this)))));
481 msg_t req(con.
ctx(), 1, std::ref(*(static_cast<rpc_cmd*>(
this))));
483 auto& payload = req.get_request().get_payload();
484 payload.enable_disable = 1;
485 payload.pid = getpid();
488 payload.sw_ifs[0] = m_swifindex.
value();
503 msg_t req(con.
ctx(), 1, std::ref(*(static_cast<rpc_cmd*>(
this))));
505 auto& payload = req.get_request().get_payload();
506 payload.enable_disable = 0;
507 payload.pid = getpid();
509 payload.sw_ifs[0] = m_swifindex.
value();
537 std::ostringstream s;
538 s <<
"itf-stats-enable itf:" << m_swifindex.
to_string();
544 , m_swifindex(handle)
560 msg_t req(con.
ctx(), 1, std::ref(*
this));
562 auto& payload = req.get_request().get_payload();
563 payload.enable_disable = 0;
564 payload.pid = getpid();
567 payload.sw_ifs[0] = m_swifindex.
value();
579 std::ostringstream s;
580 s <<
"itf-stats-disable itf:" << m_swifindex.
to_string();
597 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
599 auto& payload = m_dump->get_request().get_payload();
600 payload.name_filter_valid = 0;
628 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
640 return (
"vhost-itf-dump");
652 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
664 return (
"af-packet-itf-dump");
676 msg_t req(con.
ctx(), std::ref(*
this));
678 auto& payload = req.get_request().get_payload();
681 memset(payload.tag, 0,
sizeof(payload.tag));
682 memcpy(payload.tag, m_name.c_str(), m_name.length());
691 std::ostringstream s;
bool operator==(const set_tag &i) const
Comparison operator - only used for UT.
rc_t issue(connection &con)
Issue the command to VPP/HW.
std::string to_string() const
convert to string format for debug purposes
static const rc_t NOOP
The HW write/update action was/has not been attempted.
void retire(connection &con)
Retires the command - unsubscribe from the events.
delete_cmd(HW::item< handle_t > &item, const std::string &name)
bool operator==(const af_packet_dump_cmd &i) const
Comparison operator - only used for UT.
bool operator==(const set_mac_cmd &i) const
Comparison operator - only used for UT.
A command class represents our desire to recieve interface stats.
vhost_create_cmd(HW::item< handle_t > &item, const std::string &name, const std::string &tag)
DEFINE_VAPI_MSG_IDS_AF_PACKET_API_JSON
int value() const
Return the value of the enum - same as integer conversion.
std::string to_string() const
convert to string format for debug purposes
std::string to_string() const
convert to string format for debug purposes
void remove_interface()
remove the deleted interface from the DB
uint32_t value() const
get the value of the handle
set_tag(HW::item< handle_t > &item, const std::string &name)
Constructor taking the HW::item to update.
rc_t issue(connection &con)
Issue the command to VPP/HW.
A cmd class that Dumps all the Vpp interfaces.
std::string to_string() const
convert to string format for debug purposes
collect_detail_stats_change_cmd(HW::item< interface::stats_type_t > &item, const handle_t &h, bool enable)
Constructor taking the HW::item to update and the handle of the interface.
bool operator==(const set_table_cmd &i) const
Comparison operator - only used for UT.
void notify()
Called when it's time to poke the listeners.
rc_t issue(connection &con)
Issue the command to VPP/HW.
stats_disable_cmd(const handle_t &handle)
Constructor taking the listner to notify.
A command class to set tag on interfaces.
Error codes that VPP will return during a HW write.
std::string to_string() const
convert to string format for debug purposes
An L3 protocol can be used to construct a prefix that is used to match packets are part of a route...
set_mac_cmd(HW::item< l2_address_t > &item, const HW::item< handle_t > &h)
Constructor taking the HW::item to update and the handle of the interface.
create_cmd(HW::item< handle_t > &item, const std::string &name)
virtual void handle_interface_event(interface_cmds::events_cmd *cmd)=0
Virtual function called on the listener when the command has data ready to process.
A command class that enables detailed stats collection on an interface.
std::string to_string() const
convert to string format for debug purposes
std::string to_string() const
convert to string format for debug purposes
std::string to_string() const
convert to string format for debug purposes
rc_t wait()
Wait on the commands promise.
T & data()
Return the data read/written.
memset(h->entries, 0, sizeof(h->entries[0])*entries)
rc_t issue(connection &con)
Issue the command to VPP/HW.
DEFINE_VAPI_MSG_IDS_VPE_API_JSON
std::string to_string() const
convert to string format for debug purposes
rc_t issue(connection &con)
Issue the command to VPP/HW.
vhost_vring_state_t state
std::string to_string() const
convert to string format for debug purposes
rc_t issue(connection &con)
Issue the command to VPP/HW.
A command class that changes the MAC address on an interface.
rc_t rc() const
Get the HW return code.
const std::string & m_name
The name of the interface to be created.
dump_cmd()
Default Constructor.
A representation of the connection to VPP.
bool operator==(const events_cmd &i) const
Comparison operator - only used for UT.
set_table_cmd(HW::item< route::table_id_t > &item, const l3_proto_t &proto, const HW::item< handle_t > &h)
Constructor taking the HW::item to update and the name handle of the interface whose table is to chan...
A class that listens to interface Stats.
DEFINE_VAPI_MSG_IDS_VHOST_USER_API_JSON
std::string to_string() const
convert to string format for debug purposes
std::string to_string() const
convert to string format for debug purposes
rc_t issue(connection &con)
Issue the command to VPP/HW.
std::string to_string() const
convert to string format for debug purposes
state_change_cmd(HW::item< interface::admin_state_t > &s, const HW::item< handle_t > &h)
Constructor taking the HW::item to update and the name handle of the interface whose state is to chan...
rc_t issue(connection &con)
Issue the command to VPP/HW.
rc_t issue(connection &con)
Issue the command to VPP/HW.
rc_t issue(connection &con)
Issue the command to VPP/HW.
A class that listens to interface Events.
A base class for all RPC commands to VPP.
af_packet_delete_cmd(HW::item< handle_t > &item, const std::string &name)
Constructor taking the HW::item to update and the name of the interface to delete.
bool operator==(const stats_enable_cmd &i) const
Comparison operator - only used for UT.
#define VAPI_CALL(_stmt)
Convenince wrapper macro for error handling in VAPI sends.
A cmd class that changes the admin state.
std::string to_string() const
convert to string format for debug purposes
vhost_dump_cmd()
Default Constructor.
std::string to_string() const
convert to string format for debug purposes
af_packet_create_cmd(HW::item< handle_t > &item, const std::string &name)
Constructor taking the HW::item to update and the name of the interface to create.
A command class that binds an interface to an L3 table.
bool operator==(const dump_cmd &i) const
Comparison operator - only used for UT.
A command class represents our desire to recieve interface events.
stats_enable_cmd(interface::stat_listener &el, const handle_t &handle)
Constructor taking the listner to notify.
DEFINE_VAPI_MSG_IDS_STATS_API_JSON
std::unique_ptr< vapi::Event_registration< vapi::Sw_interface_event > > m_reg
The VAPI event registration.
A cmd class that Dumps all the Vpp Interfaces.
HW::item< bool > & status()
Return the HW::item representing the status.
rc_t issue(connection &con)
Issue the command to VPP/HW.
std::string to_string() const
convert to string format for debug purposes
A type declaration of an interface handle in VPP.
vapi::Event_registration< vapi::Sw_interface_event > reg_t
rc_t issue(connection &con)
Issue the command to VPP/HW.
bool operator==(const vhost_dump_cmd &i) const
Comparison operator - only used for UT.
rc_t issue(connection &con)
Issue the command to VPP/HW.
static const rc_t OK
The HW write was successfull.
bool operator==(const state_change_cmd &i) const
Comparison operator - only used for UT.
void notify()
Called when it's time to poke the listeners.
std::string to_string() const
convert to string format for debug purposes
const std::string m_name
The name of the interface to be created.
loopback_delete_cmd(HW::item< handle_t > &item)
Constructor taking the HW::item to update.
A command class represents our desire to recieve interface stats.
vapi::Connection & ctx()
Retrun the VAPI context the commands will use.
void to_bytes(uint8_t *array, uint8_t len) const
Convert to byte array.
rc_t issue(connection &con)
Issue the command to VPP/HW.
void insert_interface()
add the created interface to the DB
The VPP Object Model (VOM) library.
DEFINE_VAPI_MSG_IDS_INTERFACE_API_JSON
void set(const rc_t &rc)
(re)set status
rc_t issue(connection &con)
Issue the command to VPP/HW.
void set(const rc_t &rc)
Set the HW return code - should only be called from the family of Command objects.
vhost_delete_cmd(HW::item< handle_t > &item, const std::string &name)
virtual void handle_interface_stat(interface_cmds::stats_enable_cmd *cmd)=0
Virtual function called on the listener when the command has data ready to process.
interface::stat_listener & listener() const
get listener
An Event command base class.
const std::string & to_string() const
convert to string format for debug purposes
void retire(connection &con)
Retires the command - unsubscribe from the stats.
rc_t issue(connection &con)
Issue the command to VPP/HW.
events_cmd(interface::event_listener &el)
Constructor taking the listner to notify.
std::string to_string() const
convert to string format for debug purposes
A cmd class that Dumps all the Vpp interfaces.
std::string to_string() const
convert to string format for debug purposes
mac_address_t to_mac() const
MAC address conversion.
loopback_create_cmd(HW::item< handle_t > &item, const std::string &name)
Constructor taking the HW::item to update and the name of the interface to create.
bool operator==(const stats_disable_cmd &i) const
Comparison operator - only used for UT.
bool operator==(const collect_detail_stats_change_cmd &i) const
Comparison operator - only used for UT.
HW::item< handle_t > & m_hw_item
A reference to an object's HW::item that the command will update.
HW::item< handle_t > & item()
return the HW item the command updates
rc_t issue(connection &con)
Issue the command to VPP/HW.
vapi::Create_loopback msg_t
convenient typedef