25 namespace interface_cmds {
28 const std::string&
name)
29 : create_cmd(item, name)
36 msg_t req(con.
ctx(), std::ref(*
this));
38 auto& payload = req.get_request().get_payload();
40 payload.user_instance = ~0;
62 const std::string&
name)
70 msg_t req(con.
ctx(), std::ref(*
this));
92 const std::string&
name)
100 msg_t req(con.
ctx(), std::ref(*
this));
102 auto& payload = req.get_request().get_payload();
104 payload.use_random_hw_addr = 1;
105 memset(payload.host_if_name, 0,
sizeof(payload.host_if_name));
106 memcpy(payload.host_if_name,
m_name.c_str(),
107 std::min(
m_name.length(),
sizeof(payload.host_if_name)));
122 std::ostringstream s;
129 const std::string&
name,
130 const std::string& tag)
139 msg_t req(con.
ctx(), std::ref(*
this));
141 auto& payload = req.get_request().get_payload();
142 memset(payload.sock_filename, 0,
sizeof(payload.sock_filename));
143 memcpy(payload.sock_filename,
m_name.c_str(),
144 std::min(
m_name.length(),
sizeof(payload.sock_filename)));
145 memset(payload.tag, 0,
sizeof(payload.tag));
148 memcpy(payload.tag, m_tag.c_str(),
149 std::min(m_tag.length(),
sizeof(payload.tag)));
151 payload.is_server = 0;
152 payload.use_custom_mac = 0;
153 payload.renumber = 0;
169 std::ostringstream s;
184 msg_t req(con.
ctx(), std::ref(*
this));
186 auto& payload = req.get_request().get_payload();
201 std::ostringstream s;
215 msg_t req(con.
ctx(), std::ref(*
this));
217 auto& payload = req.get_request().get_payload();
232 std::ostringstream s;
239 const std::string&
name)
247 msg_t req(con.
ctx(), std::ref(*
this));
249 auto& payload = req.get_request().get_payload();
250 memset(payload.host_if_name, 0,
sizeof(payload.host_if_name));
251 memcpy(payload.host_if_name,
m_name.c_str(),
252 std::min(
m_name.length(),
sizeof(payload.host_if_name)));
265 std::ostringstream s;
272 const std::string&
name)
280 msg_t req(con.
ctx(), std::ref(*
this));
282 auto& payload = req.get_request().get_payload();
295 std::ostringstream s;
317 msg_t req(con.
ctx(), std::ref(*
this));
319 auto& payload = req.get_request().get_payload();
320 payload.sw_if_index = m_hdl.
data().
value();
331 std::ostringstream s;
349 return ((m_hdl == other.m_hdl) && (m_proto == other.m_proto) &&
356 msg_t req(con.
ctx(), std::ref(*
this));
358 auto& payload = req.get_request().get_payload();
359 payload.sw_if_index = m_hdl.
data().
value();
360 payload.is_ipv6 = m_proto.
is_ipv6();
371 std::ostringstream s;
393 msg_t req(con.
ctx(), std::ref(*
this));
395 auto& payload = req.get_request().get_payload();
396 payload.sw_if_index = m_hdl.
data().
value();
398 sizeof(payload.mac_address));
408 std::ostringstream s;
428 (m_enable == other.m_enable));
434 msg_t req(con.
ctx(), std::ref(*
this));
436 auto& payload = req.get_request().get_payload();
437 payload.sw_if_index = m_hdl.
value();
438 payload.enable_disable = m_enable;
448 std::ostringstream s;
471 m_reg.reset(
new reg_t(con.
ctx(), std::ref(*(static_cast<event_cmd*>(
this)))));
476 msg_t req(con.
ctx(), std::ref(*(static_cast<rpc_cmd*>(
this))));
478 auto& payload = req.get_request().get_payload();
479 payload.enable_disable = 1;
480 payload.pid = getpid();
495 msg_t req(con.
ctx(), std::ref(*(static_cast<rpc_cmd*>(
this))));
497 auto& payload = req.get_request().get_payload();
498 payload.enable_disable = 0;
499 payload.pid = getpid();
509 std::lock_guard<interface_cmds::events_cmd> lg(*
this);
510 std::vector<interface::event> events;
512 for (
auto& msg : *
this) {
513 auto& payload = msg.get_payload();
515 handle_t handle(payload.sw_if_index);
526 events.push_back({ *sp, oper_state });
538 return (
"itf-events");
554 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
556 auto& payload = m_dump->get_request().get_payload();
557 payload.name_filter_valid = 0;
585 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
597 return (
"vhost-itf-dump");
609 m_dump.reset(
new msg_t(con.
ctx(), std::ref(*
this)));
621 return (
"af-packet-itf-dump");
633 msg_t req(con.
ctx(), std::ref(*
this));
635 auto& payload = req.get_request().get_payload();
638 memset(payload.tag, 0,
sizeof(payload.tag));
639 memcpy(payload.tag, m_name.c_str(), m_name.length());
648 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.
std::string to_string() const
convert to string format for debug purposes
vhost_create_cmd(HW::item< handle_t > &item, const std::string &name, const std::string &tag)
DEFINE_VAPI_MSG_IDS_AF_PACKET_API_JSON
std::string to_string() const
convert to string format for debug purposes
int value() const
Return the value of the enum - same as integer conversion.
bvi_delete_cmd(HW::item< handle_t > &item)
Constructor taking the HW::item to update.
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
static std::shared_ptr< interface > find(const handle_t &h)
The the singular instance of the interface in the DB by 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.
rc_t issue(connection &con)
Issue the command to VPP/HW.
rc_t issue(connection &con)
Issue the command to VPP/HW.
A command class to set tag on interfaces.
Error codes that VPP will return during a HW write.
static const log_level_t DEBUG
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.
void flush()
flush/free all the events thus far reeived.
create_cmd(HW::item< handle_t > &item, const std::string &name)
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
The oper state of the interface.
rc_t wait()
Wait on the commands promise.
T & data()
Return the data read/written.
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...
DEFINE_VAPI_MSG_IDS_VHOST_USER_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.
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.
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.
#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.
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.
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.
bvi_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.
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.
static oper_state_t from_int(uint8_t val)
Convert VPP's numerical value to enum type.
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
virtual void handle_interface_event(std::vector< event > es)=0
Virtual function called on the listener when the command has data ready to process.
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)
An Event command base class.
const std::string & to_string() const
convert to string format for debug purposes
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 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::Bvi_create msg_t
convenient typedef
rc_t issue(connection &con)
Issue the command to VPP/HW.