NCS-5500 Interface and QoS 1D Scale

6 minutes read

Introduction

This tutorial will discuss single dimensional interface and QoS scale of the NCS-5500 series.

The first section will introduce the basic L2 and L3 interface scale, without enabling QoS.

The next section will discuss the impact of HQOS mode on bundle interface scale.

Then we will discuss the impact of enabling QoS on interface scale, with respect to both ingress and egress.

Non-QoS L2 and L3 Interface Scale

Below interface scales are effective from IOS XR 6.6.3 and 7.0.1. No QoS and no HQOS mode for these scales. Maximum bundle interface scale is assumed to be the maximum 1024, and more details will be discussed on bundle scale in the next section.

L3 Interface and Subinterface Scale

For L3 main interfaces, it is the number of physical interfaces present on a particular fixed or modular chassis, whatever the speed. Please note for breakout, it is counted as the number of interfaces after the breakout.

L3 subinterfaces scale is both per interface and per system, relevant limits are:

L3 subinterfaces <= 2000
L3 bundle subinterfaces <= 1024
L3 subinterfaces + L3 bundle subinterfaces <= 2000
L3 bundle main interfaces + L3 bundle subinterfaces <= 1790
L3 main interfaces + L3 subinterfaces < 2558
L3 (main + subinterfaces) + L3 bundle (main + subinterfaces) < 2558

L2 Interface and Subinterface Scale

Max subinterfaces per interface is 4094 (0,4095 reserved), relevant limits are:

L2 subinterfaces <= 4094/4095 per interface/system
L2 (main + subinterfaces) <= 4094/4095 per system
L2 bundle subinterfaces <= 4094/4096 per interface/system
L2 (bundle main + bundle subinterfaces) <= 4097 per system
L2 (subinterfaces + bundle subinterfaces) <= 8191 per system
L2 (main + subinterfaces + bundle main + bundle subinterfaces) <=8192 per system

Mixed L2 and L3 Interface and Subinterface Scale

For mixed L2 and L2, relevant limits are:

(L3 + L2) subinterfaces <= 6095 system
(L3 + L2) main interfaces <= 2304 system
(L3 + L2) main + subinterfaces <= 6652 per system
(L3 + L2) subinterfaces + bundle subinterfaces <= 8192 per system
(L3 + L2) maian and subinterfaces + bundle main and subinterfaces <= 10496 per system

Below table will present the above scale limits in graphical format for ease of visualization:

Non-QoS L2 and L3 Interface Scale
Physical InterfacesBundle InterfacesTotal Scale
MainSubinterfaceMainSubinterface
L2L3L2L3L2L3L2L3
Non-HQOS Bundle interfaces only
1024
4096
4096
1024
1024
1024
1790
4097
5120
5120
5120
Physical Interfaces only
2000
4095
6095
2304
2304
2304
2557
4095
6399
6652
6652
Non-HQOS Mixed Physical and Bundle Interfaces
2000
8191
5119
6096
8192
2557
8192
10496

Non-QoS Bundle Interface Scale

Bundle interface scale is configurable in IOS XR, with less bundle members support for higher bundle interface scale.

Let N be the maximum number of bundle interfaces supported. Default N is 256, and can be changed by:

RP/0/RP0/CPU0:NCS5500(config)#hw-module profile bundle-scale ?
  1024  Max 1024 trunks, Max 16 members (128 main + 896 sub)
  512   Max 512 trunks, Max 32 members  (128 main + 384 sub)
  256   Max 256 trunks, Max 64 members  (128 main + 128 sub)

Non-HQOS Mode Bundle Interface Scale

The bundle interface scale is independent of N for non-HQOS mode, and relevant limits are:

L3 Bundle subinterfaces <= 1024 per system
L2 Bundle subinterfaces <= 4094/4096 per interface/system
L2 Bundle subinterfaces + L3 Bundle subinterfaces <= 4096 per system
L2 Bundle main interfaces + L3 Bundle main interfaces <=1024
L2 Bundle main interfaces + L2 Bundle subinterfaces <=4097
L2 Bundle main interfaces + L3 Bundle subinterfaces <=2047
(L2 + L3) Bundle main interfaces + (L2 + L3) Bundle subinterfaces <= 5120

HQOS mode Bundle Interface Scale

HQOS mode is needed to enable egress hierarchical QoS policies on main interfaces, or to enable egress flat or hierarchical QoS policies on subinterfaces.

HQOS mode is disabled by default, and can be enabled by below command:

hw-module profile qos hqos-enable

HQOS mode will impose additional limits on bundle interface scale, depending on N:

L3 Bundle subinterfaces + L2 Bundle subinterfaces < N
L3 Bundle main interfaces + L2 Bundle main interfaces <= N
(L2 + L3) Bundle main interfaces + (L2 + L3) Bundle subinterfaces <= N

Below table will present the above scale limits in graphical format for ease of visualization:

Non-QoS Bundle Scale N (256/512/1024)
MainSubinterfaceTotal Scale
L2L3L2L3
Non-HQOS Mode
1024
4096
4096
1024
1024
1024
1790
4097
5120
5120
5120
HQOS Mode
N-1
N-1
N-1
N
N
N
N

Ingress and Egress QoS Interface Scale

Enabling QoS will have impact on interface scale, and the effect will be different for ingress and egress, due to the difference in hardware resources required.

Ingress QoS Interface Scale

Ingress QoS scale is impacted by the available counters for statistics.

In Normal QoS mode, 2 counters are used per ingress policy-map, and support the best interface scale.

If Enhanced QoS mode is enabled, 4 counters are used per ingress policy-map, providing better statistics, but also used more hardware resources, resulting in lower interface scale:

hw-module profile stats qos-enhanced

The default maximum number of class-maps per ingress policy-map is 32. If you configure a smaller max-classmap-size, it will result in higher interface scale:

hw-module profile qos max-classmap-size [4|8|16|32]

The maximum number of unique ingress policy-maps per NPU is increased from 30 to 250 from IOS XR 6.6.3/7.0.1. However, this does not impact on the ingress QoS interface scale.

HQOS mode is not required for ingress qos, even with hierarchical policy-maps, and HQOS mode does not impact ingress QoS interface scale.

A main interface consume the same resources as a subinterface with ingress QoS, so we would just refer to number of interfaces for scale purpose.

For each bundle member with ingress QoS on a core of a NPU, QoS resources are consumed on both of the 2 cores of that NPU, so per core and per NPU interface scale are the same.

Therefore a bundle main/subinterface with M bundle members will consume the equivalent resources of 2xM interfaces with ingress QoS.

Below table is the number of interfaces with ingress policy-map attached:

QoS ModeClass-Map SizeScale per CoreScale per NPU BundleScale per NPU Physical
Normal4102310232046
Normal85115111022
Normal16255255510
Normal32127127254
Enhanced48718711742
Enhanced8435435870
Enhanced16217217434
Enhanced32108108216

Egress QoS Interface Scale

Egress QoS scale is impacted by the available queues (VOQ Virtual Output Queues).

In NCS-5500 architecture, the egress queues are actually mapped to the buffer on ingress, and organized as virtual output queues. The benefits of this approach are minimized egress buffers, and allows single lookup on ingress for forwarding.

In this model, the ingress NPU has to store information for all egress NPU/Linecard, so scale will vary with number of egress NPU/Linecards.

Egress qos policy-map supports a maximum of 8 class-maps and each with 1 queue, by default, and no configuration is required.

Each physical interface will always be assigned 8 queues, which is fixed.

Each physical subinterface will be assigned 8 additional queues when it is created and with egress QoS configured.

Bundle main interface with M bundle members does not consume additional queues other than the queues of the M bundle members.

Each bundle member of a bundle subinterface will be assigned 8 additional qeueus when the bundle subinterface is created and with egress QoS configured.

Therefore a bundle subinterface with M bundle members will consume the equivalent resources of M interfaces with egress QoS.

HQOS mode is required if you use egress hierarchical policy-maps on a main/subinterface, and also egress flat policy-map on a subinterface. HQOS mode will not impact egress QoS interface scale, but will impact bundle interface scale as in above section.

Below table is the number of main/subinterfaces with egress policy-map attached:

Scale per CoreFixed550455085516
Before IOS XR 7.0.1512484848
IOS XR 7.0.110241929648

Updated:

Leave a Comment