Skip to content

Commit

Permalink
[Link Event Damping] Serialization/deserialization logic for link event
Browse files Browse the repository at this point in the history
damping config attr.

- Adding serialization/deserialization logic for link event damping
  config so that when libsai is sending link event damping algo and
  config to syncd for set request, it uses serialization logic to
  serialize the requested data before sending the set request and when
  syncd receives the link event damping port attribute set request, it
  uses the deserialization logic to deserialize the data.

HLD: sonic-net/SONiC#1071
  • Loading branch information
Ashish Singh committed Nov 29, 2023
1 parent 4ee9c25 commit 3891355
Show file tree
Hide file tree
Showing 3 changed files with 223 additions and 0 deletions.
113 changes: 113 additions & 0 deletions meta/SaiSerialize.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,14 @@

using json = nlohmann::json;

const std::unordered_map<sai_link_event_damping_algorithm_t, std::string> sai_link_event_damping_algorithm_to_name_map = {
{SAI_LINK_EVENT_DAMPING_ALGORITHM_DISABLED, "SAI_LINK_EVENT_DAMPING_ALGORITHM_DISABLED"},
{SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED, "SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED"}};

const std::unordered_map<sai_redis_port_attr_t, std::string> sai_redis_port_attr_to_name_map = {
{SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGORITHM, "SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGORITHM"},
{SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG, "SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG"}};

static int char_to_int(
_In_ const char c)
{
Expand Down Expand Up @@ -2617,6 +2625,54 @@ std::string sai_serialize_redis_communication_mode(
}
}

std::string sai_serialize_redis_port_attr_id(
_In_ const sai_redis_port_attr_t value)
{
SWSS_LOG_ENTER();

auto it = sai_redis_port_attr_to_name_map.find(value);
if (it != sai_redis_port_attr_to_name_map.end())
{
return it->second;
}

SWSS_LOG_WARN("enum value %d not found in enum sai_redis_port_attr_t.", value);

return sai_serialize_number(value, false);
}

std::string sai_serialize_link_event_damping_algorithm(
_In_ const sai_link_event_damping_algorithm_t value)
{
SWSS_LOG_ENTER();

auto it = sai_link_event_damping_algorithm_to_name_map.find(value);
if (it != sai_link_event_damping_algorithm_to_name_map.end())
{
return it->second;
}

SWSS_LOG_WARN("enum value %d not found in enum sai_link_event_damping_algorithm_t.", value);

return sai_serialize_number(value, false);
}

std::string sai_serialize_link_event_damping_aied_config(
_In_ const sai_redis_link_event_damping_algo_aied_config_t& value)
{
SWSS_LOG_ENTER();

json j;

j["max_suppress_time"] = sai_serialize_number(value.max_suppress_time, false);
j["suppress_threshold"] = sai_serialize_number(value.suppress_threshold, false);
j["reuse_threshold"] = sai_serialize_number(value.reuse_threshold, false);
j["decay_half_life"] = sai_serialize_number(value.decay_half_life, false);
j["flap_penalty"] = sai_serialize_number(value.flap_penalty, false);

return j.dump();
}

// deserialize

void sai_deserialize_bool(
Expand Down Expand Up @@ -5059,3 +5115,60 @@ void sai_deserialize_redis_communication_mode(
SWSS_LOG_THROW("enum '%s' not found in sai_redis_communication_mode_t", s.c_str());
}
}

void sai_deserialize_redis_port_attr_id(
_In_ const std::string& s,
_Out_ sai_redis_port_attr_t& value)
{
SWSS_LOG_ENTER();

for (const auto& entry : sai_redis_port_attr_to_name_map)
{
if (s == entry.second)
{
value = entry.first;
return;
}
}

SWSS_LOG_WARN("%s is not found in sai_redis_port_attr_to_name_map.", s.c_str());

sai_deserialize_number(s, value, false);
}

// Link event damping.

void sai_deserialize_link_event_damping_algorithm(
_In_ const std::string& s,
_Out_ sai_link_event_damping_algorithm_t& value)
{
SWSS_LOG_ENTER();

for (const auto& entry : sai_link_event_damping_algorithm_to_name_map)
{
if (s == entry.second)
{
value = entry.first;
return;
}
}

SWSS_LOG_WARN("%s is not found in sai_link_event_damping_algorithm_to_name_map.", s.c_str());

sai_deserialize_number(s, value, false);
}

void sai_deserialize_link_event_damping_aied_config(
_In_ const std::string& s,
_Out_ sai_redis_link_event_damping_algo_aied_config_t& value)
{
SWSS_LOG_ENTER();

json j = json::parse(s);

sai_deserialize_number(j["max_suppress_time"], value.max_suppress_time, false);
sai_deserialize_number(j["suppress_threshold"], value.suppress_threshold, false);
sai_deserialize_number(j["reuse_threshold"], value.reuse_threshold, false);
sai_deserialize_number(j["decay_half_life"], value.decay_half_life, false);
sai_deserialize_number(j["flap_penalty"], value.flap_penalty, false);
}
30 changes: 30 additions & 0 deletions meta/sai_serialize.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,18 @@ extern "C" {
#include <streambuf>
#include <iomanip>
#include <map>
#include <unordered_map>
#include <tuple>
#include <cstring>

#include "swss/logger.h"

#include "sairedis.h"

extern const std::unordered_map<sai_link_event_damping_algorithm_t, std::string> sai_link_event_damping_algorithm_to_name_map;

extern const std::unordered_map<sai_redis_port_attr_t, std::string> sai_redis_port_attr_to_name_map;

// util

sai_status_t transfer_attributes(
Expand Down Expand Up @@ -288,6 +293,17 @@ std::string sai_serialize(
std::string sai_serialize_redis_communication_mode(
_In_ sai_redis_communication_mode_t value);

std::string sai_serialize_redis_port_attr_id(
_In_ const sai_redis_port_attr_t value);

// Link event damping.

std::string sai_serialize_link_event_damping_algorithm(
_In_ const sai_link_event_damping_algorithm_t value);

std::string sai_serialize_link_event_damping_aied_config(
_In_ const sai_redis_link_event_damping_algo_aied_config_t& value);

// deserialize

void sai_deserialize_enum(
Expand Down Expand Up @@ -541,3 +557,17 @@ sai_redis_notify_syncd_t sai_deserialize_redis_notify_syncd(
void sai_deserialize_redis_communication_mode(
_In_ const std::string& s,
_Out_ sai_redis_communication_mode_t& value);

void sai_deserialize_redis_port_attr_id(
_In_ const std::string& s,
_Out_ sai_redis_port_attr_t& value);

// Link event damping.

void sai_deserialize_link_event_damping_algorithm(
_In_ const std::string& s,
_Out_ sai_link_event_damping_algorithm_t& value);

void sai_deserialize_link_event_damping_aied_config(
_In_ const std::string& s,
_Out_ sai_redis_link_event_damping_algo_aied_config_t& value);
80 changes: 80 additions & 0 deletions unittest/meta/TestSaiSerialize.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
#include "sairedis.h"
#include "sairediscommon.h"

#include <nlohmann/json.hpp>

#include <inttypes.h>
#include <arpa/inet.h>

Expand All @@ -14,6 +16,8 @@

using namespace saimeta;

using json = nlohmann::json;

TEST(SaiSerialize, transfer_attributes)
{
SWSS_LOG_ENTER();
Expand Down Expand Up @@ -539,6 +543,82 @@ TEST(SaiSerialize, sai_serialize_redis_communication_mode)
REDIS_COMMUNICATION_MODE_REDIS_SYNC_STRING);
}

TEST(SaiSerialize, sai_serialize_redis_port_attr_id)
{
for (const auto& attr :
{SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGORITHM, SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG})
{
sai_redis_port_attr_t deserialized_attr;
sai_deserialize_redis_port_attr_id(
sai_serialize_redis_port_attr_id(attr), deserialized_attr);

EXPECT_EQ(deserialized_attr, attr);
}

// Undefined enum.
int index = 1000;
std::string serialized_attr = sai_serialize_redis_port_attr_id(
static_cast<sai_redis_port_attr_t>(SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG + index));

EXPECT_EQ(serialized_attr,
std::to_string(SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG + index));

sai_redis_port_attr_t deserialized_attr;
sai_deserialize_redis_port_attr_id(serialized_attr, deserialized_attr);
EXPECT_EQ(deserialized_attr, SAI_REDIS_PORT_ATTR_LINK_EVENT_DAMPING_ALGO_AIED_CONFIG + index);
}

TEST(SaiSerialize, sai_serialize_link_event_damping_algorithm)
{
for (const auto& algo : {SAI_LINK_EVENT_DAMPING_ALGORITHM_DISABLED,
SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED})
{
sai_link_event_damping_algorithm_t deserialized_algo;
sai_deserialize_link_event_damping_algorithm(
sai_serialize_link_event_damping_algorithm(algo), deserialized_algo);

EXPECT_EQ(deserialized_algo, algo);
}

// Undefined enum.
int index = 1000;
std::string serialized_attr = sai_serialize_link_event_damping_algorithm(
static_cast<sai_link_event_damping_algorithm_t>(SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED + index));

EXPECT_EQ(serialized_attr,
std::to_string(SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED + index));

sai_link_event_damping_algorithm_t deserialized_attr;
sai_deserialize_link_event_damping_algorithm(serialized_attr, deserialized_attr);
EXPECT_EQ(deserialized_attr, SAI_LINK_EVENT_DAMPING_ALGORITHM_AIED + index);
}

TEST(SaiSerialize, sai_serialize_link_event_damping_aied_config)
{
SWSS_LOG_ENTER();

sai_redis_link_event_damping_algo_aied_config_t config = {
.max_suppress_time = 500,
.suppress_threshold = 2500,
.reuse_threshold = 1000,
.decay_half_life = 100,
.flap_penalty = 100};

std::string expected = "{\"max_suppress_time\":\"500\",\"suppress_threshold\":\"2500\",\"reuse_threshold\":\"1000\",\"decay_half_life\":\"100\",\"flap_penalty\":\"100\"}";
std::string serialized_config = sai_serialize_link_event_damping_aied_config(config);

EXPECT_EQ(json::parse(serialized_config), json::parse(expected));

sai_redis_link_event_damping_algo_aied_config_t deserialized_config;
sai_deserialize_link_event_damping_aied_config(serialized_config, deserialized_config);

EXPECT_EQ(deserialized_config.max_suppress_time, config.max_suppress_time);
EXPECT_EQ(deserialized_config.suppress_threshold, config.suppress_threshold);
EXPECT_EQ(deserialized_config.reuse_threshold, config.reuse_threshold);
EXPECT_EQ(deserialized_config.decay_half_life, config.decay_half_life);
EXPECT_EQ(deserialized_config.flap_penalty, config.flap_penalty);
}

TEST(SaiSerialize, sai_deserialize_queue_attr)
{
sai_queue_attr_t attr = SAI_QUEUE_ATTR_PORT;
Expand Down

0 comments on commit 3891355

Please sign in to comment.