From a45c7b58c7543df7d9e1ace35794bd45241f021c Mon Sep 17 00:00:00 2001 From: Mykola F <37578614+mykolaf@users.noreply.github.com> Date: Sun, 23 Dec 2018 20:58:44 +0200 Subject: [PATCH] [watermark] fix watermark clear not working for PG (#729) --- orchagent/watermarkorch.cpp | 83 ++++++++++++++++++++----------------- 1 file changed, 44 insertions(+), 39 deletions(-) diff --git a/orchagent/watermarkorch.cpp b/orchagent/watermarkorch.cpp index 4e4bda916fa8..bef7de89826b 100644 --- a/orchagent/watermarkorch.cpp +++ b/orchagent/watermarkorch.cpp @@ -107,41 +107,50 @@ void WatermarkOrch::doTask(NotificationConsumer &consumer) consumer.pop(op, data, values); - if(&consumer == m_clearNotificationConsumer){ - string wm_name = ""; - vector &obj_ids = m_pg_ids; - if(data == CLEAR_PG_HEADROOM_REQUEST) - { - wm_name = "SAI_INGRESS_PRIORITY_GROUP_STAT_XOFF_ROOM_WATERMARK_BYTES"; - obj_ids = m_pg_ids; - } - else if(data == CLEAR_PG_SHARED_REQUEST) - { - wm_name = "SAI_INGRESS_PRIORITY_GROUP_STAT_SHARED_WATERMARK_BYTES"; - obj_ids = m_pg_ids; - } - else if(data == CLEAR_QUEUE_SHARED_UNI_REQUEST) - { - wm_name = "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES"; - obj_ids = m_unicast_queue_ids; - } - else if(data == CLEAR_QUEUE_SHARED_MULTI_REQUEST) - { - wm_name = "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES"; - obj_ids = m_multicast_queue_ids; - } - if(op == "USER") - { - clearSingleWm(m_userWatermarkTable.get(), wm_name, obj_ids); - } - else if (op == "PERSISTENT") - { - clearSingleWm(m_persistentWatermarkTable.get(), wm_name, obj_ids); - } - else - { - SWSS_LOG_WARN("Unknown watermark clear request op: %s", op.c_str()); - } + Table * table = NULL; + + if (op == "PERSISTENT") + { + table = m_persistentWatermarkTable.get(); + } + else if (op == "USER") + { + table = m_userWatermarkTable.get(); + } + else + { + SWSS_LOG_WARN("Unknown watermark clear request op: %s", op.c_str()); + return; + } + + if(data == CLEAR_PG_HEADROOM_REQUEST) + { + clearSingleWm(table, + "SAI_INGRESS_PRIORITY_GROUP_STAT_XOFF_ROOM_WATERMARK_BYTES", + m_pg_ids); + } + else if(data == CLEAR_PG_SHARED_REQUEST) + { + clearSingleWm(table, + "SAI_INGRESS_PRIORITY_GROUP_STAT_SHARED_WATERMARK_BYTES", + m_pg_ids); + } + else if(data == CLEAR_QUEUE_SHARED_UNI_REQUEST) + { + clearSingleWm(table, + "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES", + m_unicast_queue_ids); + } + else if(data == CLEAR_QUEUE_SHARED_MULTI_REQUEST) + { + clearSingleWm(table, + "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES", + m_multicast_queue_ids); + } + else + { + SWSS_LOG_WARN("Unknown watermark clear request data: %s", data.c_str()); + return; } } @@ -162,14 +171,12 @@ void WatermarkOrch::doTask(SelectableTimer &timer) m_telemetryTimer->setInterval(intervT); m_telemetryTimer->reset(); - /* TODO: replace with removing all PG and queue entries? */ clearSingleWm(m_periodicWatermarkTable.get(), "SAI_INGRESS_PRIORITY_GROUP_STAT_XOFF_ROOM_WATERMARK_BYTES", m_pg_ids); clearSingleWm(m_periodicWatermarkTable.get(), "SAI_INGRESS_PRIORITY_GROUP_STAT_SHARED_WATERMARK_BYTES", m_pg_ids); clearSingleWm(m_periodicWatermarkTable.get(), "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES", m_unicast_queue_ids); clearSingleWm(m_periodicWatermarkTable.get(), "SAI_QUEUE_STAT_SHARED_WATERMARK_BYTES", m_multicast_queue_ids); SWSS_LOG_INFO("Periodic watermark cleared by timer!"); } - } void WatermarkOrch::init_pg_ids() @@ -220,5 +227,3 @@ void WatermarkOrch::clearSingleWm(Table *table, string wm_name, vectorset(sai_serialize_object_id(id), vfvt); } } - -