summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--extras/vom/vom/gbp_subnet.cpp22
-rw-r--r--extras/vom/vom/gbp_subnet.hpp7
2 files changed, 18 insertions, 11 deletions
diff --git a/extras/vom/vom/gbp_subnet.cpp b/extras/vom/vom/gbp_subnet.cpp
index 304da3ef496..35422e2a6d4 100644
--- a/extras/vom/vom/gbp_subnet.cpp
+++ b/extras/vom/vom/gbp_subnet.cpp
@@ -47,6 +47,7 @@ gbp_subnet::gbp_subnet(const gbp_route_domain& rd,
, m_type(type)
, m_recirc(nullptr)
, m_epg(nullptr)
+ , m_sclass(~0)
{
}
@@ -60,18 +61,20 @@ gbp_subnet::gbp_subnet(const gbp_route_domain& rd,
, m_type(type_t::STITCHED_EXTERNAL)
, m_recirc(recirc.singular())
, m_epg(epg.singular())
+ , m_sclass(~0)
{
}
gbp_subnet::gbp_subnet(const gbp_route_domain& rd,
const route::prefix_t& prefix,
- const gbp_endpoint_group& epg)
+ sclass_t sclass)
: m_hw(false)
, m_rd(rd.singular())
, m_prefix(prefix)
, m_type(type_t::L3_OUT)
, m_recirc(nullptr)
- , m_epg(epg.singular())
+ , m_epg()
+ , m_sclass(sclass)
{
}
@@ -82,6 +85,7 @@ gbp_subnet::gbp_subnet(const gbp_subnet& o)
, m_type(o.m_type)
, m_recirc(o.m_recirc)
, m_epg(o.m_epg)
+ , m_sclass(o.m_sclass)
{
}
@@ -101,7 +105,8 @@ bool
gbp_subnet::operator==(const gbp_subnet& gs) const
{
return ((key() == gs.key()) && (m_type == gs.m_type) &&
- (m_recirc == gs.m_recirc) && (m_epg == gs.m_epg));
+ (m_recirc == gs.m_recirc) && (m_epg == gs.m_epg) &&
+ (m_sclass == gs.m_sclass));
}
void
@@ -120,7 +125,7 @@ gbp_subnet::replay()
HW::enqueue(new gbp_subnet_cmds::create_cmd(
m_hw, m_rd->id(), m_prefix, m_type,
(m_recirc ? m_recirc->handle() : handle_t::INVALID),
- (m_epg ? m_epg->sclass() : ~0)));
+ (m_epg ? m_epg->sclass() : m_sclass)));
}
}
@@ -147,7 +152,7 @@ gbp_subnet::update(const gbp_subnet& r)
HW::enqueue(new gbp_subnet_cmds::create_cmd(
m_hw, m_rd->id(), m_prefix, m_type,
(m_recirc ? m_recirc->handle() : handle_t::INVALID),
- (m_epg ? m_epg->sclass() : ~0)));
+ (m_epg ? m_epg->sclass() : m_sclass)));
} else {
if (m_type != r.m_type) {
m_epg = r.m_epg;
@@ -157,7 +162,7 @@ gbp_subnet::update(const gbp_subnet& r)
HW::enqueue(new gbp_subnet_cmds::create_cmd(
m_hw, m_rd->id(), m_prefix, m_type,
(m_recirc ? m_recirc->handle() : handle_t::INVALID),
- (m_epg ? m_epg->sclass() : ~0)));
+ (m_epg ? m_epg->sclass() : m_sclass)));
}
}
}
@@ -229,10 +234,7 @@ gbp_subnet::event_handler::handle_populate(const client_db::key_t& key)
break;
}
case GBP_API_SUBNET_L3_OUT: {
- std::shared_ptr<gbp_endpoint_group> epg =
- gbp_endpoint_group::find(payload.subnet.sclass);
-
- gbp_subnet gs(*rd, pfx, *epg);
+ gbp_subnet gs(*rd, pfx, payload.subnet.sclass);
OM::commit(key, gs);
VOM_LOG(log_level_t::DEBUG) << "read: " << gs.to_string();
break;
diff --git a/extras/vom/vom/gbp_subnet.hpp b/extras/vom/vom/gbp_subnet.hpp
index f18aa01431e..bff32ffaf2f 100644
--- a/extras/vom/vom/gbp_subnet.hpp
+++ b/extras/vom/vom/gbp_subnet.hpp
@@ -82,7 +82,7 @@ public:
*/
gbp_subnet(const gbp_route_domain& rd,
const route::prefix_t& prefix,
- const gbp_endpoint_group& epg);
+ sclass_t sclass);
/**
* Copy Construct
@@ -221,6 +221,11 @@ private:
std::shared_ptr<gbp_endpoint_group> m_epg;
/**
+ * Sclass for l3-out subnets
+ */
+ sclass_t m_sclass;
+
+ /**
* A map of all bridge_domains
*/
static singular_db<key_t, gbp_subnet> m_db;