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

SwSS Changes for DHCP DoS Mitigation Feature #3130

Open
wants to merge 172 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
172 commits
Select commit Hold shift + click to select a range
5a8b39f
Add support for DHCP mitigation rate feature via kernel
asraza07 May 2, 2024
0fb822a
Fix for typo in portmgr.h
asraza07 May 2, 2024
dc20bf1
Fix for std namespace
asraza07 May 2, 2024
903a89d
Fix for typo
asraza07 May 2, 2024
132a6e0
Fix for unused variable
asraza07 May 2, 2024
312356d
Fix for failing portmgr test cases
asraza07 May 2, 2024
eb52c01
Remove write dhcp rate to appl_db
asraza07 May 3, 2024
4d10719
Fix for failed test case assertion
asraza07 May 3, 2024
6ec063c
Merge branch 'master' into dhcp_dos_mitigation_swss
asraza07 May 6, 2024
703e8a5
Dhcp rate changes to Appl Db
asraza07 May 7, 2024
79fea07
changed /sbin/tc to /usr/sbin/tc
muhammadalihussnain May 8, 2024
5279d61
Write DHCP rate to appldb
asraza07 May 10, 2024
c89f3d4
Portmgr test case fix for appldb addition of DHP rate
asraza07 May 10, 2024
d167ade
Fix for typo
asraza07 May 10, 2024
b761b27
Fix for TC command path
asraza07 May 10, 2024
d22882a
Changed set rate and erase delete rate
muhammadalihussnain May 16, 2024
893c800
/usr/sbin/tc to /sbin/tc
muhammadalihussnain May 16, 2024
462c777
not deleting queue
muhammadalihussnain May 17, 2024
768e1c9
erased config->appl DBs
muhammadalihussnain May 17, 2024
01331df
changed to_string(byte_rate)
muhammadalihussnain May 20, 2024
19cdea5
Added sudo to it
muhammadalihussnain May 20, 2024
4c2135a
removed comment from cmd_str=cmd.str()
muhammadalihussnain May 20, 2024
d5cf62b
insert sudo to original command
muhammadalihussnain May 20, 2024
11f2592
Merge branch 'master' into dhcp_dos_mitigation_swss
muhammadalihussnain May 20, 2024
5b850db
removed shellquote(aliase)
muhammadalihussnain May 20, 2024
d079550
changed if return to if not return)
muhammadalihussnain May 20, 2024
f71c0a7
changed dhcp_rate_limit to integer in do_task
muhammadalihussnain May 20, 2024
e242495
str(fvValue(i))
muhammadalihussnain May 20, 2024
3c7139a
std::str(fvValue(i))
muhammadalihussnain May 20, 2024
774eccd
to_string(fvVlaue(i))
muhammadalihussnain May 20, 2024
264efe0
dhcp_rate_limit=fvValue(i) and field_value.size() and and fvField(i)!…
muhammadalihussnain May 20, 2024
14b0a66
writeConfigToAppDb()
muhammadalihussnain May 20, 2024
7e2c5b2
to_string(byte_rate)
muhammadalihussnain May 20, 2024
04c723f
int ret = swss::exec(cmd_str,res);
muhammadalihussnain May 20, 2024
5a74163
/usr/sbin/tc instead of usr/sbin/tc
muhammadalihussnain May 20, 2024
9337839
reslove the scope of int
muhammadalihussnain May 20, 2024
6a70578
Merge branch 'dhcp_dos_mitigation_swss' of https://github.com/asraza0…
asraza07 May 21, 2024
ef712b5
removed writing to appl db
muhammadalihussnain May 21, 2024
e9881aa
removed if(not ret)
muhammadalihussnain May 21, 2024
b7c1fc4
error not used ret
muhammadalihussnain May 21, 2024
c640432
int ret=1;
muhammadalihussnain May 21, 2024
4ead285
if(ret)
muhammadalihussnain May 21, 2024
a14dad0
ret = swss::exec(cmd_str,res)
muhammadalihussnain May 21, 2024
7036b0f
change TEST(PORTMGR,DoTask)
muhammadalihussnain May 21, 2024
246d96a
Ethernet0 changed
muhammadalihussnain May 21, 2024
3381caf
ASERTION DHCP
muhammadalihussnain May 21, 2024
07a72f4
406bps
muhammadalihussnain May 21, 2024
f3a94c5
>
muhammadalihussnain May 21, 2024
0c51f71
sudo tc changed by /sbin/tc
muhammadalihussnain May 21, 2024
1b1cc19
Fix for set function return value
asraza07 May 30, 2024
d2d94c9
Merge branch 'master' into dhcp_dos_mitigation_swss
asraza07 Jun 20, 2024
efa1b55
Fix for functionality implementation and test cases
asraza07 Jun 20, 2024
05ea555
Fix for port helper header file
asraza07 Jun 20, 2024
68dadc9
Fix for tc command
asraza07 Jun 20, 2024
fc7fff5
Retrigger pipelines
asraza07 Jun 21, 2024
18e0f71
Fix for failing test cases
asraza07 Jun 24, 2024
1690ddc
Merge branch 'master' into dhcp_dos_mitigation_swss
prsunny Jun 25, 2024
400c702
Merge branch 'master' into dhcp_dos_mitigation_swss
ridahanif96 Jun 26, 2024
18fb715
Removed Failed cases
ridahanif96 Jun 26, 2024
fb0e7e1
inserted some logs in test cases for debuging
muhammadalihussnain Jun 26, 2024
aaa4f73
reverted the skip command
muhammadalihussnain Jun 26, 2024
3e3fa50
Removed the code which was setting rate to hardware size
muhammadalihussnain Jun 28, 2024
5e68783
removed warm reboot test file lines
muhammadalihussnain Jun 30, 2024
0a42fe6
remove lines which were writing rate into appl_db
muhammadalihussnain Jul 1, 2024
58fd4b3
added function to the portmgr.h
muhammadalihussnain Jul 1, 2024
0a30441
update do task test case
muhammadalihussnain Jul 1, 2024
855217a
eliminate getting value from app db for rate
muhammadalihussnain Jul 1, 2024
b7ad4d8
added logs to portmgr.cpp
muhammadalihussnain Jul 1, 2024
1980e65
Removed Logs from Portmgrd.cpp
muhammadalihussnain Jul 2, 2024
67d31c9
changed code rate/mtu
muhammadalihussnain Jul 2, 2024
710e6aa
remove line| rtnl_link_set_dhcp_rate_limit(nl_obj, dhcp_rate_limit);
muhammadalihussnain Jul 3, 2024
9d65c51
managed arguments to draft_nlmsg() function
muhammadalihussnain Jul 3, 2024
062ca41
added sudo b4 command
muhammadalihussnain Jul 3, 2024
a189347
changed in port_ut.cpp
muhammadalihussnain Jul 3, 2024
45c0287
add sudo at line 102 at portmgr_ut.cpp
muhammadalihussnain Jul 3, 2024
50a5d01
erased space from command
muhammadalihussnain Jul 3, 2024
f892368
removed extra line
muhammadalihussnain Jul 3, 2024
566cf98
.
muhammadalihussnain Jul 3, 2024
c1dbc9c
change rate to 20300 line 153 portmgr_ut.cpp
muhammadalihussnain Jul 3, 2024
e53e05c
populated config_db with rate 1 instead of 50
muhammadalihussnain Jul 4, 2024
e00d1d1
Merge branch 'master' into dhcp_dos_mitigation_swss
ridahanif96 Jul 4, 2024
ef7d365
Added a set_rate function in conftest.py file same as mtu
muhammadalihussnain Jul 5, 2024
ed8c0c1
added code in conftest.py
muhammadalihussnain Jul 8, 2024
c31c19c
not writing to appl_db
muhammadalihussnain Jul 9, 2024
03e41ae
sleep at line 1868 conftest.py
muhammadalihussnain Jul 9, 2024
b974eee
portmgr_ut.cpp line 76
muhammadalihussnain Jul 9, 2024
19f8424
skipped line 99 in portmgr-ut.cpp
muhammadalihussnain Jul 9, 2024
dae8b75
conftest.py line 1873 delayed to service start
muhammadalihussnain Jul 9, 2024
a19e91a
delayed 60 seconds after restart at 1875
muhammadalihussnain Jul 10, 2024
90cd544
delayed in dvs_common.py added some logs
muhammadalihussnain Jul 10, 2024
eaf0c2e
increase polling_interval from 0.01 to 0.1
muhammadalihussnain Jul 10, 2024
d5f4f1a
changed polling_interval 0.1 to o.o2
muhammadalihussnain Jul 11, 2024
9d61b92
typo fix
muhammadalihussnain Jul 11, 2024
9d40e2b
typo
muhammadalihussnain Jul 11, 2024
6d7ddff
typo
muhammadalihussnain Jul 11, 2024
d4b5f75
remove delay at line 58 and fix typo line1098
muhammadalihussnain Jul 11, 2024
4e03068
Fixing Errors
ridahanif96 Jul 23, 2024
adf5682
Merge remote-tracking branch 'origin/dhcp_dos_mitigation_swss' into d…
ridahanif96 Jul 23, 2024
8903a1a
Merge branch 'master' into dhcp_dos_mitigation_swss
ridahanif96 Jul 23, 2024
8434878
MOdified dvs_common.py
ridahanif96 Jul 23, 2024
7ab9069
Added testcase
ridahanif96 Aug 16, 2024
2089cbe
changed to fix for lines in test pr
muhammadalihussnain Aug 21, 2024
17b8e3c
delay 10 instead of 1 at 328,333 test_portAdvwithoutautoneg()
muhammadalihussnain Aug 22, 2024
08afacc
in test case{Ethernet24 down} we manually set it up and logs
muhammadalihussnain Aug 23, 2024
0facc0a
increases polling timeout 20 to 30 seconds to wait longer for pollin…
muhammadalihussnain Aug 26, 2024
ea59664
17 test cases still fail
muhammadalihussnain Aug 26, 2024
74d19c1
typo 84 line test_sub_port_intf.py
muhammadalihussnain Aug 26, 2024
4649e15
failures reduced to 17 to 10
muhammadalihussnain Aug 27, 2024
a01f989
type line 215 test_fgnhg.py
muhammadalihussnain Aug 27, 2024
0b22bfb
removing variable before assignmnt use
muhammadalihussnain Aug 28, 2024
0d0353b
changed in classTestFineGrainedNextHopGroup
muhammadalihussnain Aug 28, 2024
54aab00
ip_to_if_map = create_interface_n_fg_ecmp_config(dvs, 0, 24, fg_nhg_n…
muhammadalihussnain Aug 28, 2024
548d4c9
added some delays to set oper_status and admin_status up
muhammadalihussnain Aug 29, 2024
a69d1e4
added rate-limit to /swss/orchagent/port/portschem.h
muhammadalihussnain Aug 30, 2024
0d35b35
not writing to apple db
muhammadalihussnain Sep 2, 2024
993ced8
fixed errors
muhammadalihussnain Sep 2, 2024
4978f89
manually down
muhammadalihussnain Sep 2, 2024
b3beb1f
removed manually down to up
muhammadalihussnain Sep 2, 2024
9114f52
removed log portmgr.cpp line 104
muhammadalihussnain Sep 2, 2024
6a59c15
added some logs to debug
muhammadalihussnain Sep 4, 2024
24d943a
typo
muhammadalihussnain Sep 4, 2024
7cf982f
typo
muhammadalihussnain Sep 4, 2024
6f6f5b1
changed in portcnt.h porthlpr.h porthlpr.cpp
muhammadalihussnain Sep 5, 2024
029201e
changed code in portmgr.cpp
muhammadalihussnain Sep 5, 2024
3552d82
typo at 117 portmgr.cpp
muhammadalihussnain Sep 5, 2024
6011d06
typo
muhammadalihussnain Sep 5, 2024
531f590
changes made in test_warm reboot,test_port test_port_an
muhammadalihussnain Sep 5, 2024
71ac850
test_fgnhg
muhammadalihussnain Sep 5, 2024
60eef36
removed the delayed and logs
muhammadalihussnain Sep 6, 2024
934b537
Delay added
muhammadalihussnain Sep 6, 2024
27deb39
last passed point
muhammadalihussnain Sep 6, 2024
6b9fae7
removed from porthlpr to test
muhammadalihussnain Sep 10, 2024
fd88d5c
removed code from porthlpr
muhammadalihussnain Sep 10, 2024
c8d2a23
removed code from hlpr
muhammadalihussnain Sep 10, 2024
2590581
Merge branch 'passed-commit' into dhcp_dos_mitigation_swss
muhammadalihussnain Sep 10, 2024
4159740
Removed Spaces and updated
ridahanif96 Sep 19, 2024
9d3bf33
Removed Spaces
ridahanif96 Sep 19, 2024
eef26a6
Merge branch 'master' into dhcp_dos_mitigation_swss
ridahanif96 Oct 23, 2024
0116750
fine tuned timeout and remove unintended changes
muhammadalihussnain Nov 26, 2024
8ef09c0
update test cases to cover
muhammadalihussnain Nov 28, 2024
610311e
code-coverage
muhammadalihussnain Nov 28, 2024
158d51b
code-coverage
muhammadalihussnain Nov 28, 2024
40f5d38
code-coverage
muhammadalihussnain Nov 28, 2024
f0d5d32
code-coverage
muhammadalihussnain Nov 28, 2024
1d683cc
code-coverage
muhammadalihussnain Nov 28, 2024
36e4c75
code-coverage
muhammadalihussnain Nov 28, 2024
1c4daf6
code-coverage
muhammadalihussnain Nov 28, 2024
6abc4da
code-coverage
muhammadalihussnain Nov 28, 2024
9b94bea
code-coverage
muhammadalihussnain Nov 28, 2024
bd8cf95
code-coverage
muhammadalihussnain Nov 28, 2024
2eb9e75
code-coverage
muhammadalihussnain Nov 29, 2024
9e22d55
code-coverage
muhammadalihussnain Nov 29, 2024
cc5e246
code-coverage
muhammadalihussnain Nov 29, 2024
fb25005
code coverage
muhammadalihussnain Nov 29, 2024
bea9d80
code coverage
muhammadalihussnain Nov 29, 2024
1a4c03e
code coverage
muhammadalihussnain Nov 29, 2024
a3d6b2d
code coverage
muhammadalihussnain Nov 29, 2024
e1b1b8d
code-coverage
muhammadalihussnain Nov 29, 2024
0954291
Fixed spacing, extra lines, optimized timeout
muhammadalihussnain Dec 4, 2024
d69faa2
Fixed spacing, extra lines, optimized timeout
muhammadalihussnain Dec 4, 2024
f1ab66b
Fixed spacing, extra lines, optimized timeout
muhammadalihussnain Dec 4, 2024
98ebf69
remove spacing extralines, fine tuned timeout
muhammadalihussnain Dec 4, 2024
4aa6953
resolving formating issues
muhammadalihussnain Dec 4, 2024
eac36b8
Merge branch 'sonic-net:master' into dhcp_dos_mitigation_swss
muhammadalihussnain Dec 4, 2024
d28829a
trainling white spaces
muhammadalihussnain Dec 4, 2024
4443dd8
removed format mistakes
muhammadalihussnain Dec 10, 2024
76a85d0
Merge branch 'master' into dhcp_dos_mitigation_swss
muhammadalihussnain Dec 10, 2024
18dec77
Merge branch 'sonic-net:master' into dhcp_dos_mitigation_swss
muhammadalihussnain Dec 12, 2024
e11f7da
updating branch
muhammadalihussnain Dec 12, 2024
bb8b3de
Merge branch 'master' into dhcp_dos_mitigation_swss
muhammadalihussnain Dec 14, 2024
82f7152
Merge branch 'master' into dhcp_dos_mitigation_swss
muhammadalihussnain Jan 9, 2025
ad6b25e
resolve conflicts
muhammadalihussnain Jan 9, 2025
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
72 changes: 65 additions & 7 deletions cfgmgr/portmgr.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
#include "exec.h"
#include "shellcmd.h"
#include <swss/redisutility.h>
#include <iostream>

using namespace std;
using namespace swss;
Expand Down Expand Up @@ -76,6 +77,51 @@ bool PortMgr::setPortAdminStatus(const string &alias, const bool up)
return true;
}

bool PortMgr::setPortDHCPMitigationRate(const string &alias, const string &dhcp_rate_limit)
{
stringstream cmd;
string res, cmd_str;
int ret;
int byte_rate = stoi(dhcp_rate_limit) * DHCP_PACKET_SIZE;

if (dhcp_rate_limit != "0")
{
/* tc qdisc add dev <port_name> handle ffff: ingress
&&
tc filter add dev <port_name> protocol ip parent ffff: prio 1 u32 match ip protocol 17 0xff match ip dport 67 0xffff police rate <byte_rate>bps burst <byte_rate>b conform-exceed drop*/
cmd << TC_CMD << " qdisc add dev " << shellquote(alias) << " handle ffff: ingress" << " && " \
<< TC_CMD << " filter add dev " << shellquote(alias) << " protocol ip parent ffff: prio 1 u32 match ip protocol 17 0xff match ip dport 67 0xffff police rate " << to_string(byte_rate) << "bps burst " << to_string(byte_rate) << "b conform-exceed drop";
cmd_str = cmd.str();
ret = swss::exec(cmd_str, res);
if (!ret)
{
SWSS_LOG_INFO("writing dhcp_rate_limit to appl_db");
return writeConfigToAppDb(alias, "dhcp_rate_limit", dhcp_rate_limit);
}
else if (!isPortStateOk(alias))
{
// Can happen when a DEL notification is sent by portmgrd immediately followed by a new SET notif
SWSS_LOG_WARN("Setting dhcp_rate_limit to alias:%s netdev failed with cmd:%s, rc:%d, error:%s", alias.c_str(), cmd_str.c_str(), ret, res.c_str());
return false;
}
}
else
{
// tc qdisc del dev <port_name> handle ffff: ingress
cmd << TC_CMD << " qdisc del dev " << shellquote(alias) << " handle ffff: ingress";
cmd_str = cmd.str();
ret = swss::exec(cmd_str, res);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we not checking the value of ret here? What is the action if this command fails? Does it need to be logged?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

added logs on command failures

if (ret)
{
// Log the failure and return false to indicate an issue
SWSS_LOG_WARN("Failed to delete ingress qdisc ");
return false;
}
}

return true;
}

bool PortMgr::isPortStateOk(const string &alias)
{
vector<FieldValueTuple> temp;
Expand Down Expand Up @@ -155,19 +201,19 @@ void PortMgr::doTask(Consumer &consumer)
*/
bool portOk = isPortStateOk(alias);

string admin_status, mtu;
string admin_status, mtu, dhcp_rate_limit;
std::vector<FieldValueTuple> field_values;

bool configured = (m_portList.find(alias) != m_portList.end());

/* If this is the first time we set port settings
* assign default admin status and mtu
* assign default admin status and mtu and dhcp_rate_limit
*/
if (!configured)
{
admin_status = DEFAULT_ADMIN_STATUS_STR;
mtu = DEFAULT_MTU_STR;

dhcp_rate_limit = DEFAULT_DHCP_RATE_LIMIT_STR;
m_portList.insert(alias);
}
else if (!portOk)
Expand All @@ -182,6 +228,11 @@ void PortMgr::doTask(Consumer &consumer)
{
mtu = fvValue(i);
}
else if (fvField(i) == "dhcp_rate_limit")
{
dhcp_rate_limit = fvValue(i);

}
else if (fvField(i) == "admin_status")
{
admin_status = fvValue(i);
Expand All @@ -205,30 +256,37 @@ void PortMgr::doTask(Consumer &consumer)
{
writeConfigToAppDb(alias, field_values);
}

if (!portOk)
{
SWSS_LOG_INFO("Port %s is not ready, pending...", alias.c_str());
writeConfigToAppDb(alias, "mtu", mtu);
writeConfigToAppDb(alias, "admin_status", admin_status);
writeConfigToAppDb(alias, "dhcp_rate_limit", dhcp_rate_limit);

/* Retry setting these params after the netdev is created */
field_values.clear();
field_values.emplace_back("mtu", mtu);
field_values.emplace_back("admin_status", admin_status);
field_values.emplace_back("dhcp_rate_limit", dhcp_rate_limit);

it->second = KeyOpFieldsValuesTuple{alias, SET_COMMAND, field_values};
it++;
continue;
}

if (!mtu.empty())
{
setPortMtu(alias, mtu);
SWSS_LOG_NOTICE("Configure %s MTU to %s", alias.c_str(), mtu.c_str());
}

if (!admin_status.empty())
{
setPortAdminStatus(alias, admin_status == "up");
SWSS_LOG_NOTICE("Configure %s admin status to %s", alias.c_str(), admin_status.c_str());
}
if (!dhcp_rate_limit.empty())
{
setPortDHCPMitigationRate(alias, dhcp_rate_limit);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should be set only if there is explicit configuration of dhcp_rate_limit. It should stay the same as today (no kernel TC) if there is no config.

SWSS_LOG_NOTICE("Configure %s DHCP rate limit to %s", alias.c_str(), dhcp_rate_limit.c_str());
}
}
else if (op == DEL_COMMAND)
Expand Down Expand Up @@ -256,4 +314,4 @@ bool PortMgr::writeConfigToAppDb(const std::string &alias, std::vector<FieldValu
{
m_appPortTable.set(alias, field_values);
return true;
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What changed here? Please remove unintended changes wrt spacing and new lines

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

removed white spaces and new lines

}
6 changes: 4 additions & 2 deletions cfgmgr/portmgr.h
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ namespace swss {
/* Port default admin status is down */
#define DEFAULT_ADMIN_STATUS_STR "down"
#define DEFAULT_MTU_STR "9100"
#define DEFAULT_DHCP_RATE_LIMIT_STR "300"
#define DHCP_PACKET_SIZE 406

class PortMgr : public Orch
{
Expand All @@ -36,7 +38,7 @@ class PortMgr : public Orch
bool writeConfigToAppDb(const std::string &alias, std::vector<FieldValueTuple> &field_values);
bool setPortMtu(const std::string &alias, const std::string &mtu);
bool setPortAdminStatus(const std::string &alias, const bool up);
bool setPortDHCPMitigationRate(const std::string &alias, const std::string &dhcp_rate_limit);
bool isPortStateOk(const std::string &alias);
};

}
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fix newline?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed

5 changes: 1 addition & 4 deletions cfgmgr/portmgrd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,18 +35,15 @@ int main(int argc, char **argv)

PortMgr portmgr(&cfgDb, &appDb, &stateDb, cfg_port_tables);
vector<Orch *> cfgOrchList = {&portmgr};

swss::Select s;
for (Orch *o : cfgOrchList)
{
s.addSelectables(o->getSelectables());
}

while (true)
{
Selectable *sel;
int ret;

ret = s.select(&sel, SELECT_TIMEOUT);
if (ret == Select::ERROR)
{
Expand All @@ -68,4 +65,4 @@ int main(int argc, char **argv)
SWSS_LOG_ERROR("Runtime error: %s", e.what());
}
return -1;
}
}
3 changes: 2 additions & 1 deletion cfgmgr/shellcmd.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
#define TEAMDCTL_CMD "/usr/bin/teamdctl"
#define IPTABLES_CMD "/sbin/iptables"
#define CONNTRACK_CMD "/usr/sbin/conntrack"
#define TC_CMD "/sbin/tc"

#define EXEC_WITH_ERROR_THROW(cmd, res) ({ \
int ret = swss::exec(cmd, res); \
Expand All @@ -29,4 +30,4 @@ static inline std::string shellquote(const std::string& str)
return "\"" + std::regex_replace(str, re, "\\$1") + "\"";
}

#endif /* __SHELLCMD__ */
#endif /* __SHELLCMD__ */
4 changes: 3 additions & 1 deletion orchagent/port.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ extern "C" {
* hence setting to 1492 (1514 - 22)
*/
#define DEFAULT_MTU 1492
#define DEFAULT_DHCP_RATE_LIMIT 300

/*
* Default TPID is 8100
Expand Down Expand Up @@ -169,6 +170,7 @@ class Port
Type m_type = UNKNOWN;
uint16_t m_index = 0; // PHY_PORT: index
uint32_t m_mtu = DEFAULT_MTU;
uint32_t m_dhcp_rate_limit = DEFAULT_DHCP_RATE_LIMIT;
uint32_t m_speed = 0; // Mbps
port_learn_mode_t m_learn_mode = SAI_BRIDGE_PORT_FDB_LEARNING_MODE_HW;
bool m_autoneg = false;
Expand Down Expand Up @@ -272,4 +274,4 @@ class Port

}

#endif /* SWSS_PORT_H */
#endif /* SWSS_PORT_H */
5 changes: 5 additions & 0 deletions orchagent/port/portcnt.h
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,11 @@ class PortConfig final
bool is_set = false;
} mtu; // Port MTU

struct {
std::uint32_t value;
bool is_set = false;
} dhcp_rate_limit; // Port dhcp_rate_limit

struct {
std::uint16_t value;
bool is_set = false;
Expand Down
4 changes: 1 addition & 3 deletions orchagent/port/porthlpr.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1270,9 +1270,7 @@ bool PortHelper::validatePortConfig(PortConfig &port) const

port.admin_status.value = false;
port.admin_status.is_set = true;

port.fieldValueMap[PORT_ADMIN_STATUS] = PORT_STATUS_DOWN;
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please fix all these unintended changes..

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed


return true;
}
}
3 changes: 2 additions & 1 deletion orchagent/port/portschema.h
Original file line number Diff line number Diff line change
Expand Up @@ -101,4 +101,5 @@
#define PORT_SUPPRESS_THRESHOLD "suppress_threshold"
#define PORT_REUSE_THRESHOLD "reuse_threshold"
#define PORT_FLAP_PENALTY "flap_penalty"
#define PORT_MODE "mode"
#define PORT_DHCP_RATE_LIMIT "dhcp_rate_limit"
#define PORT_MODE "mode"
1 change: 0 additions & 1 deletion orchagent/portsorch.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
#include <tuple>
#include <sstream>
#include <unordered_set>

#include <netinet/if_ether.h>
#include "net/if.h"

Expand Down
15 changes: 11 additions & 4 deletions tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,7 @@ def _verify_db_contents():
return (True, None)

# Verify that ASIC DB has been fully initialized
init_polling_config = PollingConfig(2, 30, strict=True)
init_polling_config = PollingConfig(2, 40, strict=True)
wait_for_result(_verify_db_contents, init_polling_config)

def _generate_oid_to_interface_mapping(self) -> None:
Expand Down Expand Up @@ -1152,6 +1152,13 @@ def set_mtu(self, interface, mtu):
tbl.set(interface, fvs)
time.sleep(1)

def set_dhcp_rate_limit(self, interface, dhcp_rate_limit):
tbl_name = "PORT"
tbl = swsscommon.Table(self.cdb, tbl_name)
fvs = swsscommon.FieldValuePairs([("dhcp_rate_limit", dhcp_rate_limit)])
tbl.set(interface, fvs)
time.sleep(20)

# deps: acl, mirror_port_erspan
def add_neighbor(self, interface, ip, mac):
tbl = swsscommon.ProducerStateTable(self.pdb, "NEIGH_TABLE")
Expand Down Expand Up @@ -1701,12 +1708,10 @@ def get_topo_neigh(self):
def handle_neighconn(self):
if self.oper != "create":
return

instance_to_neighbor_map = self.get_topo_neigh()
for ctnname, nbraddrs in instance_to_neighbor_map.items():
if ctnname not in self.dvss:
continue

for server, neighbor_address in nbraddrs:
self.dvss[ctnname].servers[server].runcmd("ifconfig eth0 down")
self.dvss[ctnname].servers[server].runcmd("ifconfig eth0 up")
Expand Down Expand Up @@ -1863,6 +1868,7 @@ def update_dvs(log_path, new_dvs_env=[]):
dvs.destroy_servers()
dvs.create_servers()
dvs.restart()
time.sleep(60)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we need sleep here?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added a delay here to ensure that once the DVS switch starts, there is a pause before it performs any further actions, allowing sufficient time for the ports to initialize properly.


return dvs

Expand All @@ -1878,6 +1884,7 @@ def update_dvs(log_path, new_dvs_env=[]):
if dvs.persistent:
dvs.runcmd("mv /etc/sonic/config_db.json.orig /etc/sonic/config_db.json")
dvs.ctn_restart()
time.sleep(60)

@pytest.fixture(scope="module")
def dvs(request, manage_dvs) -> DockerVirtualSwitch:
Expand Down Expand Up @@ -2038,4 +2045,4 @@ def dpb_setup_fixture(dvs):
else:
dvs.vct.restart()
yield
remove_dpb_config_file(dvs)
remove_dpb_config_file(dvs)
4 changes: 1 addition & 3 deletions tests/dvslib/dvs_common.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,9 @@ def wait_for_result(

if status:
return (True, result)

time.sleep(polling_config.polling_interval)

if polling_config.strict:
message = failure_message or f"Operation timed out after {polling_config.timeout} seconds with result {result}"
assert False, message

return (False, result)
return (False, result)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fix new line?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed

6 changes: 1 addition & 5 deletions tests/dvslib/dvs_database.py
Original file line number Diff line number Diff line change
Expand Up @@ -155,14 +155,11 @@ def wait_for_entry(
Returns:
The entry stored at `key`. If no entry is found, then an empty Dict is returned.
"""

def access_function():
fv_pairs = self.get_entry(table_name, key)
return (bool(fv_pairs), fv_pairs)

message = failure_message or f'Entry not found: key="{key}", table="{table_name}"'
_, result = wait_for_result(access_function, polling_config, message)

_, result = wait_for_result(access_function, polling_config, message)
return result

def wait_for_fields(
Expand Down Expand Up @@ -242,7 +239,6 @@ def access_function():
status, result = wait_for_result(
access_function, self._disable_strict_polling(polling_config)
)

if not status:
message = failure_message or (
f"Expected field/value pairs not found: expected={expected_fields}, "
Expand Down
Loading