2022-07-20 01:48:15 -05:00
|
|
|
{#
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
Copyright (c) 2020-2023 NVIDIA CORPORATION & AFFILIATES.
|
2022-07-20 01:48:15 -05:00
|
|
|
Apache-2.0
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
#}
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
|
|
|
|
{% if (('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'LeafRouter') or
|
|
|
|
('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'ToRRouter') and
|
|
|
|
('subtype' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['subtype'] == 'DualToR')) %}
|
2022-07-20 01:48:15 -05:00
|
|
|
{% set different_dscp_to_tc_map = true %}
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
{%- macro generate_normal_dscp_to_tc_map(tc_mapped_from_dscp_33) -%}
|
|
|
|
{
|
2022-07-20 01:48:15 -05:00
|
|
|
"0" : "1",
|
|
|
|
"1" : "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"2" : "1",
|
2022-07-20 01:48:15 -05:00
|
|
|
"3" : "3",
|
|
|
|
"4" : "4",
|
|
|
|
"5" : "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"6" : "1",
|
2022-07-20 01:48:15 -05:00
|
|
|
"7" : "1",
|
|
|
|
"8" : "0",
|
|
|
|
"9" : "1",
|
|
|
|
"10": "1",
|
|
|
|
"11": "1",
|
|
|
|
"12": "1",
|
|
|
|
"13": "1",
|
|
|
|
"14": "1",
|
|
|
|
"15": "1",
|
|
|
|
"16": "1",
|
|
|
|
"17": "1",
|
|
|
|
"18": "1",
|
|
|
|
"19": "1",
|
|
|
|
"20": "1",
|
|
|
|
"21": "1",
|
|
|
|
"22": "1",
|
|
|
|
"23": "1",
|
|
|
|
"24": "1",
|
|
|
|
"25": "1",
|
|
|
|
"26": "1",
|
|
|
|
"27": "1",
|
|
|
|
"28": "1",
|
|
|
|
"29": "1",
|
|
|
|
"30": "1",
|
|
|
|
"31": "1",
|
|
|
|
"32": "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"33": "{{tc_mapped_from_dscp_33}}",
|
2022-07-20 01:48:15 -05:00
|
|
|
"34": "1",
|
|
|
|
"35": "1",
|
|
|
|
"36": "1",
|
|
|
|
"37": "1",
|
|
|
|
"38": "1",
|
|
|
|
"39": "1",
|
|
|
|
"40": "1",
|
|
|
|
"41": "1",
|
|
|
|
"42": "1",
|
|
|
|
"43": "1",
|
|
|
|
"44": "1",
|
|
|
|
"45": "1",
|
|
|
|
"46": "5",
|
|
|
|
"47": "1",
|
|
|
|
"48": "7",
|
|
|
|
"49": "1",
|
|
|
|
"50": "1",
|
|
|
|
"51": "1",
|
|
|
|
"52": "1",
|
|
|
|
"53": "1",
|
|
|
|
"54": "1",
|
|
|
|
"55": "1",
|
|
|
|
"56": "1",
|
|
|
|
"57": "1",
|
|
|
|
"58": "1",
|
|
|
|
"59": "1",
|
|
|
|
"60": "1",
|
|
|
|
"61": "1",
|
|
|
|
"62": "1",
|
|
|
|
"63": "1"
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
}
|
|
|
|
{%- endmacro -%}
|
|
|
|
{%- macro generate_dscp_to_tc_map_with_addition_lossless_pgs_n_queues(tc_mapped_from_dscp_33) -%}
|
|
|
|
{
|
2022-07-20 01:48:15 -05:00
|
|
|
"0" : "1",
|
|
|
|
"1" : "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"2" : "2",
|
2022-07-20 01:48:15 -05:00
|
|
|
"3" : "3",
|
|
|
|
"4" : "4",
|
|
|
|
"5" : "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"6" : "6",
|
2022-07-20 01:48:15 -05:00
|
|
|
"7" : "1",
|
|
|
|
"8" : "0",
|
|
|
|
"9" : "1",
|
|
|
|
"10": "1",
|
|
|
|
"11": "1",
|
|
|
|
"12": "1",
|
|
|
|
"13": "1",
|
|
|
|
"14": "1",
|
|
|
|
"15": "1",
|
|
|
|
"16": "1",
|
|
|
|
"17": "1",
|
|
|
|
"18": "1",
|
|
|
|
"19": "1",
|
|
|
|
"20": "1",
|
|
|
|
"21": "1",
|
|
|
|
"22": "1",
|
|
|
|
"23": "1",
|
|
|
|
"24": "1",
|
|
|
|
"25": "1",
|
|
|
|
"26": "1",
|
|
|
|
"27": "1",
|
|
|
|
"28": "1",
|
|
|
|
"29": "1",
|
|
|
|
"30": "1",
|
|
|
|
"31": "1",
|
|
|
|
"32": "1",
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
"33": "{{tc_mapped_from_dscp_33}}",
|
2022-07-20 01:48:15 -05:00
|
|
|
"34": "1",
|
|
|
|
"35": "1",
|
|
|
|
"36": "1",
|
|
|
|
"37": "1",
|
|
|
|
"38": "1",
|
|
|
|
"39": "1",
|
|
|
|
"40": "1",
|
|
|
|
"41": "1",
|
|
|
|
"42": "1",
|
|
|
|
"43": "1",
|
|
|
|
"44": "1",
|
|
|
|
"45": "1",
|
|
|
|
"46": "5",
|
|
|
|
"47": "1",
|
|
|
|
"48": "7",
|
|
|
|
"49": "1",
|
|
|
|
"50": "1",
|
|
|
|
"51": "1",
|
|
|
|
"52": "1",
|
|
|
|
"53": "1",
|
|
|
|
"54": "1",
|
|
|
|
"55": "1",
|
|
|
|
"56": "1",
|
|
|
|
"57": "1",
|
|
|
|
"58": "1",
|
|
|
|
"59": "1",
|
|
|
|
"60": "1",
|
|
|
|
"61": "1",
|
|
|
|
"62": "1",
|
|
|
|
"63": "1"
|
|
|
|
}
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
{%- endmacro -%}
|
|
|
|
{%- macro generate_dscp_to_tc_map() %}
|
|
|
|
"DSCP_TO_TC_MAP": {
|
|
|
|
{% if ('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'LeafRouter') %}
|
|
|
|
"AZURE_UPLINK":
|
|
|
|
{{ generate_normal_dscp_to_tc_map("1") }},
|
|
|
|
"AZURE":
|
|
|
|
{{ generate_dscp_to_tc_map_with_addition_lossless_pgs_n_queues("1") }}
|
|
|
|
{% endif %}
|
|
|
|
{% if ('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'ToRRouter') %}
|
|
|
|
"AZURE_UPLINK":
|
|
|
|
{{ generate_dscp_to_tc_map_with_addition_lossless_pgs_n_queues("8") }},
|
|
|
|
"AZURE_TUNNEL":
|
|
|
|
{{ generate_normal_dscp_to_tc_map("8") }},
|
|
|
|
"AZURE":
|
|
|
|
{{ generate_normal_dscp_to_tc_map("8") }}
|
|
|
|
{% endif %}
|
2022-07-20 01:48:15 -05:00
|
|
|
},
|
|
|
|
{%- endmacro %}
|
|
|
|
{%- macro generate_tc_to_pg_map() %}
|
|
|
|
"TC_TO_PRIORITY_GROUP_MAP": {
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
{% if (('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'ToRRouter') and
|
|
|
|
('subtype' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['subtype'] == 'DualToR')) %}
|
|
|
|
"AZURE_TUNNEL": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "0",
|
|
|
|
"2": "0",
|
|
|
|
"3": "2",
|
|
|
|
"4": "6",
|
|
|
|
"5": "0",
|
|
|
|
"6": "0",
|
|
|
|
"7": "0",
|
|
|
|
"8": "0"
|
|
|
|
},
|
|
|
|
"AZURE": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "0",
|
|
|
|
"2": "2",
|
|
|
|
"3": "3",
|
|
|
|
"4": "4",
|
|
|
|
"5": "0",
|
|
|
|
"6": "6",
|
|
|
|
"7": "0",
|
|
|
|
"8": "0"
|
|
|
|
}
|
|
|
|
{% else %}
|
2022-07-20 01:48:15 -05:00
|
|
|
"AZURE": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "0",
|
|
|
|
"2": "2",
|
|
|
|
"3": "3",
|
|
|
|
"4": "4",
|
|
|
|
"5": "0",
|
|
|
|
"6": "6",
|
|
|
|
"7": "0"
|
|
|
|
}
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
{% endif %}
|
|
|
|
},
|
|
|
|
{%- endmacro %}
|
|
|
|
{%- macro generate_tc_to_queue_map() %}
|
|
|
|
"TC_TO_QUEUE_MAP": {
|
|
|
|
{% if (('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'ToRRouter') and
|
|
|
|
('subtype' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['subtype'] == 'DualToR')) %}
|
|
|
|
"AZURE_TUNNEL": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "1",
|
|
|
|
"2": "2",
|
|
|
|
"3": "2",
|
|
|
|
"4": "6",
|
|
|
|
"5": "5",
|
|
|
|
"6": "6",
|
|
|
|
"7": "7",
|
|
|
|
"8": "1"
|
|
|
|
},
|
|
|
|
"AZURE": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "1",
|
|
|
|
"2": "2",
|
|
|
|
"3": "3",
|
|
|
|
"4": "4",
|
|
|
|
"5": "5",
|
|
|
|
"6": "6",
|
|
|
|
"7": "7",
|
|
|
|
"8": "1"
|
|
|
|
}
|
|
|
|
{% else %}
|
|
|
|
"AZURE": {
|
|
|
|
"0": "0",
|
|
|
|
"1": "1",
|
|
|
|
"2": "2",
|
|
|
|
"3": "3",
|
|
|
|
"4": "4",
|
|
|
|
"5": "5",
|
|
|
|
"6": "6",
|
|
|
|
"7": "7"
|
|
|
|
}
|
|
|
|
{% endif %}
|
|
|
|
},
|
|
|
|
{%- endmacro %}
|
|
|
|
{% if (('type' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['type'] == 'ToRRouter') and
|
|
|
|
('subtype' in DEVICE_METADATA['localhost'] and DEVICE_METADATA['localhost']['subtype'] == 'DualToR')) %}
|
|
|
|
{%- macro generate_tc_to_dscp_map() %}
|
|
|
|
"TC_TO_DSCP_MAP": {
|
|
|
|
"AZURE_TUNNEL": {
|
|
|
|
"0": "8",
|
|
|
|
"1": "0",
|
|
|
|
"2": "2",
|
|
|
|
"3": "2",
|
|
|
|
"4": "6",
|
|
|
|
"5": "46",
|
|
|
|
"6": "6",
|
|
|
|
"7": "48",
|
|
|
|
"8": "33"
|
|
|
|
}
|
2022-07-20 01:48:15 -05:00
|
|
|
},
|
|
|
|
{%- endmacro %}
|
[Mellanox] Support DSCP remapping in dual ToR topo on T0 switch (#12605) (#13745)
- Why I did it
Support DSCP remapping in dual ToR topo on T0 switch for SKU Mellanox-SN4600c-C64, Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8.
- How I did it
Regarding buffer settings, originally, there are two lossless PGs and queues 3, 4. In dual ToR scenario, the lossless traffic from the leaf switch to the uplink of the ToR switch can be bounced back.
To avoid PFC deadlock, we need to map the bounce-back lossless traffic to different PGs and queues. Therefore, 2 additional lossless PGs and queues are allocated on uplink ports on ToR switches.
On uplink ports, map DSCP 2/6 to TC 2/6 respectively
On downlink ports, both DSCP 2/6 are still mapped to TC 1
Buffer adjusted according to the ports information:
Mellanox-SN4600c-C64:
56 downlinks 50G + 8 uplinks 100G
Mellanox-SN4600c-D48C40, Mellanox-SN2700, Mellanox-SN2700-D48C8:
24 downlinks 50G + 8 uplinks 100G
- How to verify it
Unit test.
Signed-off-by: Stephen Sun <stephens@nvidia.com>
Co-authored-by: Stephen Sun <5379172+stephenxs@users.noreply.github.com>
2023-02-10 11:16:56 -06:00
|
|
|
{%- endif %}
|
2022-07-20 01:48:15 -05:00
|
|
|
{%- macro generate_global_dscp_to_tc_map() %}
|
|
|
|
{# This is an empty macro since the global DSCP_TO_TC map is not required #}
|
|
|
|
{%- endmacro %}
|
|
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
{%- include 'qos_config.j2' %}
|