Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

sonic-sairedis changes for MPLS support #815

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions lib/inc/RedisRemoteSaiInterface.h
Original file line number Diff line number Diff line change
Expand Up @@ -185,18 +185,21 @@ namespace sairedis
public: // bulk create ENTRY

SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(fdb_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(inseg_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(nat_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(route_entry);

public: // bulk remove ENTRY

SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(fdb_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(inseg_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(nat_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(route_entry);

public: // bulk set ENTRY

SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_SET_ENTRY(fdb_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_SET_ENTRY(inseg_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_SET_ENTRY(nat_entry);
SAIREDIS_REDISREMOTESAIINTERFACE_DECLARE_BULK_SET_ENTRY(route_entry);

Expand Down
3 changes: 3 additions & 0 deletions lib/inc/Sai.h
Original file line number Diff line number Diff line change
Expand Up @@ -177,18 +177,21 @@ namespace sairedis
public: // bulk create ENTRY

SAIREDIS_SAI_DECLARE_BULK_CREATE_ENTRY(fdb_entry);
SAIREDIS_SAI_DECLARE_BULK_CREATE_ENTRY(inseg_entry);
SAIREDIS_SAI_DECLARE_BULK_CREATE_ENTRY(nat_entry);
SAIREDIS_SAI_DECLARE_BULK_CREATE_ENTRY(route_entry);

public: // bulk remove ENTRY

SAIREDIS_SAI_DECLARE_BULK_REMOVE_ENTRY(fdb_entry);
SAIREDIS_SAI_DECLARE_BULK_REMOVE_ENTRY(inseg_entry);
SAIREDIS_SAI_DECLARE_BULK_REMOVE_ENTRY(nat_entry);
SAIREDIS_SAI_DECLARE_BULK_REMOVE_ENTRY(route_entry);

public: // bulk set ENTRY

SAIREDIS_SAI_DECLARE_BULK_SET_ENTRY(fdb_entry);
SAIREDIS_SAI_DECLARE_BULK_SET_ENTRY(inseg_entry);
SAIREDIS_SAI_DECLARE_BULK_SET_ENTRY(nat_entry);
SAIREDIS_SAI_DECLARE_BULK_SET_ENTRY(route_entry);

Expand Down
3 changes: 3 additions & 0 deletions lib/inc/SaiInterface.h
Original file line number Diff line number Diff line change
Expand Up @@ -168,18 +168,21 @@ namespace sairedis
public: // bulk create ENTRY

SAIREDIS_SAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(fdb_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(inseg_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(nat_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(route_entry);

public: // bulk remove ENTRY

SAIREDIS_SAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(fdb_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(inseg_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(nat_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(route_entry);

public: // bulk set ENTRY

SAIREDIS_SAIINTERFACE_DECLARE_BULK_SET_ENTRY(fdb_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_SET_ENTRY(inseg_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_SET_ENTRY(nat_entry);
SAIREDIS_SAIINTERFACE_DECLARE_BULK_SET_ENTRY(route_entry);

Expand Down
76 changes: 76 additions & 0 deletions lib/src/RedisRemoteSaiInterface.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1410,6 +1410,24 @@ sai_status_t RedisRemoteSaiInterface::bulkRemove(
return bulkRemove(SAI_OBJECT_TYPE_NAT_ENTRY, serializedObjectIds, mode, object_statuses);
}

sai_status_t RedisRemoteSaiInterface::bulkRemove(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t *inseg_entry,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

std::vector<std::string> serializedObjectIds;

for (uint32_t idx = 0; idx < object_count; idx++)
{
serializedObjectIds.emplace_back(sai_serialize_inseg_entry(inseg_entry[idx]));
}

return bulkRemove(SAI_OBJECT_TYPE_INSEG_ENTRY, serializedObjectIds, mode, object_statuses);
}

sai_status_t RedisRemoteSaiInterface::bulkRemove(
_In_ uint32_t object_count,
_In_ const sai_fdb_entry_t *fdb_entry,
Expand Down Expand Up @@ -1486,6 +1504,25 @@ sai_status_t RedisRemoteSaiInterface::bulkSet(
return bulkSet(SAI_OBJECT_TYPE_NAT_ENTRY, serializedObjectIds, attr_list, mode, object_statuses);
}

sai_status_t RedisRemoteSaiInterface::bulkSet(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t *inseg_entry,
_In_ const sai_attribute_t *attr_list,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

std::vector<std::string> serializedObjectIds;

for (uint32_t idx = 0; idx < object_count; idx++)
{
serializedObjectIds.emplace_back(sai_serialize_inseg_entry(inseg_entry[idx]));
}

return bulkSet(SAI_OBJECT_TYPE_INSEG_ENTRY, serializedObjectIds, attr_list, mode, object_statuses);
}

sai_status_t RedisRemoteSaiInterface::bulkSet(
_In_ uint32_t object_count,
_In_ const sai_fdb_entry_t *fdb_entry,
Expand Down Expand Up @@ -1714,6 +1751,45 @@ sai_status_t RedisRemoteSaiInterface::bulkCreate(
object_statuses);
}

sai_status_t RedisRemoteSaiInterface::bulkCreate(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t* inseg_entry,
_In_ const uint32_t *attr_count,
_In_ const sai_attribute_t **attr_list,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

// TODO support mode

static PerformanceIntervalTimer timer("RedisRemoteSaiInterface::bulkCreate(inseg_entry)");

timer.start();

std::vector<std::string> serialized_object_ids;

// on create vid is put in db by syncd
for (uint32_t idx = 0; idx < object_count; idx++)
{
std::string str_object_id = sai_serialize_inseg_entry(inseg_entry[idx]);
serialized_object_ids.push_back(str_object_id);
}

auto status = bulkCreate(
SAI_OBJECT_TYPE_INSEG_ENTRY,
serialized_object_ids,
attr_count,
attr_list,
mode,
object_statuses);

timer.stop();

timer.inc(object_count);

return status;
}

sai_status_t RedisRemoteSaiInterface::bulkCreate(
_In_ uint32_t object_count,
Expand Down
3 changes: 3 additions & 0 deletions lib/src/Sai.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -505,6 +505,7 @@ sai_status_t Sai::bulkCreate( \

DECLARE_BULK_CREATE_ENTRY(ROUTE_ENTRY,route_entry)
DECLARE_BULK_CREATE_ENTRY(FDB_ENTRY,fdb_entry);
DECLARE_BULK_CREATE_ENTRY(INSEG_ENTRY,inseg_entry);
DECLARE_BULK_CREATE_ENTRY(NAT_ENTRY,nat_entry)


Expand All @@ -530,6 +531,7 @@ sai_status_t Sai::bulkRemove( \

DECLARE_BULK_REMOVE_ENTRY(ROUTE_ENTRY,route_entry)
DECLARE_BULK_REMOVE_ENTRY(FDB_ENTRY,fdb_entry);
DECLARE_BULK_REMOVE_ENTRY(INSEG_ENTRY,inseg_entry);
DECLARE_BULK_REMOVE_ENTRY(NAT_ENTRY,nat_entry)

// BULK SET
Expand All @@ -556,6 +558,7 @@ sai_status_t Sai::bulkSet( \

DECLARE_BULK_SET_ENTRY(ROUTE_ENTRY,route_entry);
DECLARE_BULK_SET_ENTRY(FDB_ENTRY,fdb_entry);
DECLARE_BULK_SET_ENTRY(INSEG_ENTRY,inseg_entry);
DECLARE_BULK_SET_ENTRY(NAT_ENTRY,nat_entry);

// NON QUAD API
Expand Down
12 changes: 12 additions & 0 deletions lib/src/SaiInterface.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,9 @@ sai_status_t SaiInterface::create(
case SAI_OBJECT_TYPE_NAT_ENTRY:
return create(&metaKey.objectkey.key.nat_entry, attr_count, attr_list);

case SAI_OBJECT_TYPE_INSEG_ENTRY:
return create(&metaKey.objectkey.key.inseg_entry, attr_count, attr_list);

default:

SWSS_LOG_ERROR("object type %s not implemented, FIXME", info->objecttypename);
Expand Down Expand Up @@ -81,6 +84,9 @@ sai_status_t SaiInterface::remove(
case SAI_OBJECT_TYPE_NAT_ENTRY:
return remove(&metaKey.objectkey.key.nat_entry);

case SAI_OBJECT_TYPE_INSEG_ENTRY:
return remove(&metaKey.objectkey.key.inseg_entry);

default:

SWSS_LOG_ERROR("object type %s not implemented, FIXME", info->objecttypename);
Expand Down Expand Up @@ -123,6 +129,9 @@ sai_status_t SaiInterface::set(
case SAI_OBJECT_TYPE_NAT_ENTRY:
return set(&metaKey.objectkey.key.nat_entry, attr);

case SAI_OBJECT_TYPE_INSEG_ENTRY:
return set(&metaKey.objectkey.key.inseg_entry, attr);

default:

SWSS_LOG_ERROR("object type %s not implemented, FIXME", info->objecttypename);
Expand Down Expand Up @@ -166,6 +175,9 @@ sai_status_t SaiInterface::get(
case SAI_OBJECT_TYPE_NAT_ENTRY:
return get(&metaKey.objectkey.key.nat_entry, attr_count, attr_list);

case SAI_OBJECT_TYPE_INSEG_ENTRY:
return get(&metaKey.objectkey.key.inseg_entry, attr_count, attr_list);

default:

SWSS_LOG_ERROR("object type %s not implemented, FIXME", info->objecttypename);
Expand Down
2 changes: 2 additions & 0 deletions lib/src/sai_redis_mpls.cpp
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
#include "sai_redis.h"

REDIS_GENERIC_QUAD_ENTRY(INSEG_ENTRY,inseg_entry);
REDIS_BULK_QUAD_ENTRY(INSEG_ENTRY,inseg_entry);

const sai_mpls_api_t redis_mpls_api = {

REDIS_GENERIC_QUAD_API(inseg_entry)
REDIS_BULK_QUAD_API(inseg_entry)
};
45 changes: 45 additions & 0 deletions meta/DummySaiInterface.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,20 @@ sai_status_t DummySaiInterface::bulkRemove(
return m_status;
}

sai_status_t DummySaiInterface::bulkRemove(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t *inseg_entry,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

for (uint32_t idx = 0; idx < object_count; idx++)
object_statuses[idx] = m_status;

return m_status;
}

sai_status_t DummySaiInterface::bulkRemove(
_In_ uint32_t object_count,
_In_ const sai_fdb_entry_t *fdb_entry,
Expand Down Expand Up @@ -319,6 +333,21 @@ sai_status_t DummySaiInterface::bulkSet(
return m_status;
}

sai_status_t DummySaiInterface::bulkSet(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t *inseg_entry,
_In_ const sai_attribute_t *attr_list,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

for (uint32_t idx = 0; idx < object_count; idx++)
object_statuses[idx] = m_status;

return m_status;
}

sai_status_t DummySaiInterface::bulkSet(
_In_ uint32_t object_count,
_In_ const sai_fdb_entry_t *fdb_entry,
Expand Down Expand Up @@ -384,6 +413,22 @@ sai_status_t DummySaiInterface::bulkCreate(
return m_status;
}

sai_status_t DummySaiInterface::bulkCreate(
_In_ uint32_t object_count,
_In_ const sai_inseg_entry_t *inseg_entry,
_In_ const uint32_t *attr_count,
_In_ const sai_attribute_t **attr_list,
_In_ sai_bulk_op_error_mode_t mode,
_Out_ sai_status_t *object_statuses)
{
SWSS_LOG_ENTER();

for (uint32_t idx = 0; idx < object_count; idx++)
object_statuses[idx] = m_status;

return m_status;
}

sai_status_t DummySaiInterface::bulkCreate(
_In_ uint32_t object_count,
_In_ const sai_nat_entry_t *nat_entry,
Expand Down
3 changes: 3 additions & 0 deletions meta/DummySaiInterface.h
Original file line number Diff line number Diff line change
Expand Up @@ -176,18 +176,21 @@ namespace saimeta
public: // bulk create ENTRY

SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(fdb_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(inseg_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(nat_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_CREATE_ENTRY(route_entry);

public: // bulk remove ENTRY

SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(fdb_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(inseg_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(nat_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_REMOVE_ENTRY(route_entry);

public: // bulk set ENTRY

SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_SET_ENTRY(fdb_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_SET_ENTRY(inseg_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_SET_ENTRY(nat_entry);
SAIMETA_DUMMYSAIINTERFACE_DECLARE_BULK_SET_ENTRY(route_entry);

Expand Down
Loading