summaryrefslogtreecommitdiffstats
path: root/src/vpp-api/vom/acl_binding.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/vpp-api/vom/acl_binding.cpp')
-rw-r--r--src/vpp-api/vom/acl_binding.cpp72
1 files changed, 69 insertions, 3 deletions
diff --git a/src/vpp-api/vom/acl_binding.cpp b/src/vpp-api/vom/acl_binding.cpp
index 1ebefda6650..832e232f871 100644
--- a/src/vpp-api/vom/acl_binding.cpp
+++ b/src/vpp-api/vom/acl_binding.cpp
@@ -14,7 +14,7 @@
*/
#include "vom/acl_binding.hpp"
-#include "vom/om.hpp"
+#include "vom/acl_binding_cmds.hpp"
namespace VOM {
namespace ACL {
@@ -25,7 +25,8 @@ l2_binding::event_handler::handle_populate(const client_db::key_t& key)
/*
* dump VPP Bridge domains
*/
- std::shared_ptr<l2_binding::dump_cmd> cmd(new l2_binding::dump_cmd());
+ std::shared_ptr<binding_cmds::l2_dump_cmd> cmd(
+ new binding_cmds::l2_dump_cmd());
HW::enqueue(cmd);
HW::write();
@@ -49,7 +50,8 @@ template <>
void
l3_binding::event_handler::handle_populate(const client_db::key_t& key)
{
- std::shared_ptr<l3_binding::dump_cmd> cmd(new l3_binding::dump_cmd());
+ std::shared_ptr<binding_cmds::l3_dump_cmd> cmd(
+ new binding_cmds::l3_dump_cmd());
HW::enqueue(cmd);
HW::write();
@@ -74,6 +76,70 @@ l3_binding::event_handler::handle_populate(const client_db::key_t& key)
}
}
}
+
+template <>
+void
+l3_binding::update(const binding& obj)
+{
+ if (!m_binding) {
+ HW::enqueue(new binding_cmds::l3_bind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+ HW::write();
+}
+
+template <>
+void
+l3_binding::sweep(void)
+{
+ if (m_binding) {
+ HW::enqueue(new binding_cmds::l3_unbind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+ HW::write();
+}
+
+template <>
+void
+l3_binding::replay(void)
+{
+ if (m_binding) {
+ HW::enqueue(new binding_cmds::l3_bind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+}
+
+template <>
+void
+l2_binding::update(const binding& obj)
+{
+ if (!m_binding) {
+ HW::enqueue(new binding_cmds::l2_bind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+ HW::write();
+}
+
+template <>
+void
+l2_binding::sweep(void)
+{
+ if (m_binding) {
+ HW::enqueue(new binding_cmds::l2_unbind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+ HW::write();
+}
+
+template <>
+void
+l2_binding::replay(void)
+{
+ if (m_binding) {
+ HW::enqueue(new binding_cmds::l2_bind_cmd(
+ m_binding, m_direction, m_itf->handle(), m_acl->handle()));
+ }
+}
};
std::ostream&