-
Notifications
You must be signed in to change notification settings - Fork 546
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
Expose the capability to config wred drop probability #571
Conversation
(green, yellow, and red) Signed-off-by: Wenda <wenni@microsoft.com>
orchagent/qosorch.cpp
Outdated
attr.id = SAI_WRED_ATTR_YELLOW_DROP_PROBABILITY; | ||
attr.value.s32 = 100; | ||
attrs.push_back(attr); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This chunk of code looks like providing some default values for these settings. By removing them, you also removed the 'default' value.
I don't see other enforcement to make sure we pass down the configuration all the time. Maybe that belongs to a different PR?
If 'default' value is desirable, then you can create 2 attr objects for them, set the default value before going through the if - else lists. But don't add them until the whole if-else block is done. like following:
type attr_green_drop;
attr_green_drop.s32 = 100;
... ...
if ...
else if ...
...
attrs.push(attr_green_drops);
@lguohan do we need to do this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see your other review. But we don't apply qos.json unless we have buffer configuration. So maybe default value is still needed. If we have default value, then the other PR is no longer needed. right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hardware has a default value if you do not set. This is the case with RED_DROP_PROBABILITY, which is interestingly not set default here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with @yxieca , the pr can be modified as follows. if the user does not provide drop probability, we should set the default value in swss to be 100. In this case, your other pr is not needed.
specified in qos.json Signed-off-by: Wenda <wenni@microsoft.com>
the vs check is broken. It used to succeed before retest. |
retest this please |
retest this please |
1 similar comment
retest this please |
* Add the capability to set wred drop probability of all packet colors (green, yellow, and red) Signed-off-by: Wenda <wenni@microsoft.com> * Ensure drop probability takes default value 100% if not explicitly specified in qos.json Signed-off-by: Wenda <wenni@microsoft.com>
…a queue (#584) * Expose the capability to config wred drop probability (#571) * Add the capability to set wred drop probability of all packet colors (green, yellow, and red) Signed-off-by: Wenda <wenni@microsoft.com> * Ensure drop probability takes default value 100% if not explicitly specified in qos.json Signed-off-by: Wenda <wenni@microsoft.com> * Use "[WRED_PROFILE|]" as a CLI signal to unbind wred profile from a queue or a list of queues; Add the parsing and processing logic in qosorch to support such an operation Signed-off-by: Wenda <wenni@microsoft.com> * Add print out for debugging purpose modified: orchagent/qosorch.cpp * Adjust log level Signed-off-by: Wenda <wenni@microsoft.com> * Change to use "[]" as a signal to unbind wred profile from a queue or a list of queues Signed-off-by: Wenda <wenni@microsoft.com> * Remove logs for debugging * Adjust code format * Address comments Signed-off-by: Wenda <wenni@microsoft.com>
…#2422) What I did Do not enforce drop probability for a color whose WRED is disabled. Signed-off-by: Stephen Sun stephens@nvidia.com Why I did it Currently, there is a logic to enforce the drop probability if it is not explicitly designated for a color. However, the drop probability is not a mandatory attribute. It can incur vendor SAI complaints to set it when the color is disabled. The logic was introduced from the very beginning (by PR #571) because no drop probability was defined in the QoS template at the time, which is no longer true. So we will enforce drop probability only if it is not configured and the color is enabled. How I verified it Unit test and manual test
…sonic-net#2422) What I did Do not enforce drop probability for a color whose WRED is disabled. Signed-off-by: Stephen Sun stephens@nvidia.com Why I did it Currently, there is a logic to enforce the drop probability if it is not explicitly designated for a color. However, the drop probability is not a mandatory attribute. It can incur vendor SAI complaints to set it when the color is disabled. The logic was introduced from the very beginning (by PR sonic-net#571) because no drop probability was defined in the QoS template at the time, which is no longer true. So we will enforce drop probability only if it is not configured and the color is enabled. How I verified it Unit test and manual test
…#2422) What I did Do not enforce drop probability for a color whose WRED is disabled. Signed-off-by: Stephen Sun stephens@nvidia.com Why I did it Currently, there is a logic to enforce the drop probability if it is not explicitly designated for a color. However, the drop probability is not a mandatory attribute. It can incur vendor SAI complaints to set it when the color is disabled. The logic was introduced from the very beginning (by PR #571) because no drop probability was defined in the QoS template at the time, which is no longer true. So we will enforce drop probability only if it is not configured and the color is enabled. How I verified it Unit test and manual test
Expose the capability to config wred drop probability of all packet colors (green, yellow, and red)
Signed-off-by: Wenda wenni@microsoft.com
What I did
Why I did it
How I verified it
Tested on dut 3 cases:
Details if related