diff --git a/orchagent/portsorch.cpp b/orchagent/portsorch.cpp index 4a96d74473..986c9bfa66 100644 --- a/orchagent/portsorch.cpp +++ b/orchagent/portsorch.cpp @@ -7291,7 +7291,9 @@ bool PortsOrch::addTunnel(string tunnel_alias, sai_object_id_t tunnel_id, bool h { tunnel.m_learn_mode = SAI_BRIDGE_PORT_FDB_LEARNING_MODE_DISABLE; } + tunnel.m_oper_status = SAI_PORT_OPER_STATUS_DOWN; m_portList[tunnel_alias] = tunnel; + saiOidToAlias[tunnel_id] = tunnel_alias; SWSS_LOG_INFO("addTunnel:: %" PRIx64, tunnel_id); @@ -7302,6 +7304,7 @@ bool PortsOrch::removeTunnel(Port tunnel) { SWSS_LOG_ENTER(); + saiOidToAlias.erase(tunnel.m_tunnel_id); m_portList.erase(tunnel.m_alias); return true; @@ -8251,9 +8254,10 @@ void PortsOrch::updatePortOperStatus(Port &port, sai_port_oper_status_t status) return; } + updateDbPortOperStatus(port, status); + if (port.m_type == Port::PHY) { - updateDbPortOperStatus(port, status); updateDbPortFlapCount(port, status); updateGearboxPortOperStatus(port); diff --git a/orchagent/vxlanorch.cpp b/orchagent/vxlanorch.cpp index 05a2d3e603..c96b3cb3c7 100644 --- a/orchagent/vxlanorch.cpp +++ b/orchagent/vxlanorch.cpp @@ -275,7 +275,7 @@ create_tunnel( sai_ip_address_t *dst_ip, sai_object_id_t underlay_rif, bool p2p, - sai_uint8_t encap_ttl=0) + sai_uint8_t encap_ttl) { sai_attribute_t attr; std::vector tunnel_attrs; @@ -349,16 +349,13 @@ create_tunnel( tunnel_attrs.push_back(attr); } - if (encap_ttl != 0) - { - attr.id = SAI_TUNNEL_ATTR_ENCAP_TTL_MODE; - attr.value.s32 = SAI_TUNNEL_TTL_MODE_PIPE_MODEL; - tunnel_attrs.push_back(attr); + attr.id = SAI_TUNNEL_ATTR_ENCAP_TTL_MODE; + attr.value.s32 = SAI_TUNNEL_TTL_MODE_PIPE_MODEL; + tunnel_attrs.push_back(attr); - attr.id = SAI_TUNNEL_ATTR_ENCAP_TTL_VAL; - attr.value.u8 = encap_ttl; - tunnel_attrs.push_back(attr); - } + attr.id = SAI_TUNNEL_ATTR_ENCAP_TTL_VAL; + attr.value.u8 = encap_ttl; + tunnel_attrs.push_back(attr); sai_object_id_t tunnel_id; sai_status_t status = sai_tunnel_api->create_tunnel( diff --git a/orchagent/vxlanorch.h b/orchagent/vxlanorch.h index 695f7441e0..4d3e3c94b2 100644 --- a/orchagent/vxlanorch.h +++ b/orchagent/vxlanorch.h @@ -46,6 +46,7 @@ typedef enum #define MAX_VLAN_ID 4095 #define MAX_VNI_ID 16777215 +#define DEFAULT_TUNNEL_ENCAP_TTL 64 typedef enum { @@ -196,7 +197,7 @@ class VxlanTunnel bool deleteMapperHw(uint8_t mapper_list, tunnel_map_use_t map_src); bool createMapperHw(uint8_t mapper_list, tunnel_map_use_t map_src); - bool createTunnelHw(uint8_t mapper_list, tunnel_map_use_t map_src, bool with_term = true, sai_uint8_t encap_ttl=0); + bool createTunnelHw(uint8_t mapper_list, tunnel_map_use_t map_src, bool with_term = true, sai_uint8_t encap_ttl=DEFAULT_TUNNEL_ENCAP_TTL); bool deleteTunnelHw(uint8_t mapper_list, tunnel_map_use_t map_src, bool with_term = true); void deletePendingSIPTunnel(); void increment_spurious_imr_add(const std::string remote_vtep); @@ -299,7 +300,7 @@ class VxlanTunnelOrch : public Orch2 bool createVxlanTunnelMap(string tunnelName, tunnel_map_type_t mapType, uint32_t vni, - sai_object_id_t encap, sai_object_id_t decap, uint8_t encap_ttl=0); + sai_object_id_t encap, sai_object_id_t decap, uint8_t encap_ttl=DEFAULT_TUNNEL_ENCAP_TTL); bool removeVxlanTunnelMap(string tunnelName, uint32_t vni);