Skip to content

Commit

Permalink
[MACsec]: Set macsec to bypass by default (sonic-net#1719)
Browse files Browse the repository at this point in the history
In adapting to the MACsec driver for Arista 7280Cr3, we found it is necessary to set SAI_MACSEC_ATTR_PHYSICAL_BYPASS_ENABLE to True, to successfully change the MACsec status from enable to disable (expecting that the traffic can pass through without encryption thereafter). The reason behind is that the default value of the attribute is False, if it is False, the driver understands it as the user is not allowing to bypass MACsec, yielding the result of disabling MACsec not as expected.
  • Loading branch information
byu343 authored and raphaelt-nvidia committed Oct 5, 2021
1 parent b3197aa commit 1a22c6c
Showing 1 changed file with 10 additions and 0 deletions.
10 changes: 10 additions & 0 deletions orchagent/macsecorch.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -789,6 +789,11 @@ bool MACsecOrch::initMACsecObject(sai_object_id_t switch_id)
attr.id = SAI_MACSEC_ATTR_DIRECTION;
attr.value.s32 = SAI_MACSEC_DIRECTION_EGRESS;
attrs.push_back(attr);

attr.id = SAI_MACSEC_ATTR_PHYSICAL_BYPASS_ENABLE;
attr.value.booldata = true;
attrs.push_back(attr);

sai_status_t status = sai_macsec_api->create_macsec(
&macsec_obj.first->second.m_egress_id,
switch_id,
Expand All @@ -809,6 +814,11 @@ bool MACsecOrch::initMACsecObject(sai_object_id_t switch_id)
attr.id = SAI_MACSEC_ATTR_DIRECTION;
attr.value.s32 = SAI_MACSEC_DIRECTION_INGRESS;
attrs.push_back(attr);

attr.id = SAI_MACSEC_ATTR_PHYSICAL_BYPASS_ENABLE;
attr.value.booldata = true;
attrs.push_back(attr);

status = sai_macsec_api->create_macsec(
&macsec_obj.first->second.m_ingress_id,
switch_id,
Expand Down

0 comments on commit 1a22c6c

Please sign in to comment.