RFC 9994 In-Stack MNA Sub-Stack May 2026
Rajamanickam, et al. Standards Track [Page]
Stream:
Internet Engineering Task Force (IETF)
RFC:
9994
Category:
Standards Track
Published:
ISSN:
2070-1721
Authors:
J. Rajamanickam, Ed.
Cisco Systems, Inc.
R. Gandhi, Ed.
Cisco Systems, Inc.
R. Zigler
Broadcom
H. Song
Futurewei Technologies
K. Kompella
Juniper Networks

RFC 9994

MPLS Network Action (MNA) Sub-Stack Specification Including In-Stack Network Actions and Data

Abstract

This document specifies the MPLS Network Action (MNA) sub-stack for carrying Network Actions and Ancillary Data (AD) in the MPLS label stack. MNA can be used to influence packet-forwarding decisions, carry additional Operations, Administration, and Maintenance (OAM) information in the MPLS packet, or perform user-defined operations.

Status of This Memo

This is an Internet Standards Track document.

This document is a product of the Internet Engineering Task Force (IETF). It represents the consensus of the IETF community. It has received public review and has been approved for publication by the Internet Engineering Steering Group (IESG). Further information on Internet Standards is available in Section 2 of RFC 7841.

Information about the current status of this document, any errata, and how to provide feedback on it may be obtained at https://www.rfc-editor.org/info/rfc9994.

Table of Contents

1. Introduction

[RFC3032] defines the encoding of the MPLS label stack, the basic structure used to define a forwarding path. There are applications that require MPLS packets to perform special network actions and carry optional Ancillary Data (AD) that can affect the packet-forwarding decision or trigger Operations, Administration, and Maintenance (OAM) logging, for example, as described in [RFC9791]. AD can be used to carry additional information, for example, for network slice purposes (see [RFC9791]).

The requirements for In-stack network action and In-Stack Data (ISD) are described in [RFC9613].

This document defines the syntax and semantics of network actions and AD encoded in an MPLS label stack. In-stack actions and AD are contained in a Network Action Sub-Stack (NAS), which is recognized by a new base Special-Purpose Label (bSPL). This document follows the framework specified in [RFC9789].

2. Conventions Used in This Document

2.1. Requirements Language

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.

2.2. Abbreviations

The abbreviations defined in [RFC9789] and [RFC9613] are used in this document.

Table 1: Abbreviations
Abbreviation Meaning Reference
AD Ancillary Data [RFC9613]
bSPL base Special Purpose Label [RFC9017]
BoS Bottom of Stack [RFC9789]
ECMP Equal-Cost Multipath [RFC6790]
HbH Hop-by-Hop [RFC9789]
I2E Ingress to Egress [RFC9789]
IHS I2E, HbH, or Select [RFC9789], This document
ISD In-Stack Data [RFC9613]
LSE Label Stack Entry [RFC9789]
LSP Label Switched Path [RFC3031]
MNA MPLS Network Action [RFC9789]
NAI Network Action Indicator [RFC9613]
NAL Network Action Length This document
NAS Network Action Sub-Stack [RFC9789]
NASI Network Action Sub-Stack Indicator This document
NASL Network Action Sub-Stack Length This document
OAM Operations, Administration, and Maintenance [RFC6291]
RLD Readable Label Depth [RFC9789]
TC Traffic Class [RFC5462]
TTL Time to Live [RFC3032]

2.3. Terminology

The following terms are used in this document.

MPLS Egress Node:
An MPLS edge node in its role in handling traffic as it leaves an MPLS domain [RFC3031].
MPLS Ingress Node:
An MPLS edge node in its role in handling traffic as it enters an MPLS domain [RFC3031].
MPLS Domain:
A contiguous set of nodes that operate MPLS routing and forwarding and that are also in one Routing or Administrative Domain [RFC3031].
Encapsulating Node:
A node that adds a NAS to the label stack.

3. Overview

The MPLS NAS is a set of Label Stack Entries (LSEs) that appear as part of an MPLS label stack and serve to encode information about the network actions that should be invoked for the packet. Multiple NASes may appear in a label stack and be placed as described in Section 5.

This document specifies how network actions and their optional AD are encoded as part of a NAS as a stack of LSEs. Mechanisms that allow sharing of AD between multiple network actions encoded in the same NAS can be described in other documents and do not rely on any explicit provision in the encodings described in this document.

This document defines new LSE formats beyond those in [RFC3032] that define behaviors or are processed in different ways than MPLS labels as defined in [RFC3031]. Three new LSE formats are defined to carry 7 bits of network action opcodes and varying amounts of opcode-specific AD. Specifically, Format-B LSE carries up to 13 bits of AD in an LSE. Format-C LSE carries up to 20 bits of AD in an LSE. Format-D LSE is used when additional AD is needed by the opcodes in Format-B or Format-C LSEs.

As shown in Figure 1, the first LSE in an MNA Sub-Stack uses Format-A. The second LSE uses Format-B and is followed by a Format-D LSE to carry additional data. Next, there may be a Format-C LSE for an additional network action followed by another Format-D LSE for additional data. Additional Format-C and Format-D LSEs may be added as needed for additional network actions and data.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|      MNA-Label=bSPL                   | TC  |S|    TTL        |A
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|   Opcode    |        13-bit Data      |R|IHS|S|  NASL |U| NAL |B
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|1|                    22-bit Data            |S|  8-bit Data   |D*
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|   Opcode    |        16-bit Data            |S|4b Data|U| NAL |C
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|1|                    22-bit Data            |S|  8-bit Data   |D*
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
|   Opcode    |        16-bit Data            |S|4b Data|U| NAL |C
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--
~                                                               ~
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--

* Format-D LSE presence indicated by NAL greater than one
Figure 1: An MNA Sub-Stack Encoding Example

4. Label Stack Entry Formats

The NAS uses a variety of different formats of LSEs for different purposes. This section describes the syntax of the various formats while the overall structure of the NAS and the semantics of the various LSEs are described in the sections below.

4.1. LSE Format A: The MNA Sub-Stack Indicator

LSE Format A is an LSE as described in [RFC3032] and [RFC5462]. The label value is 4 for the MNA bSPL label from the "Base Special-Purpose MPLS Label Values" IANA registry (see Section 13.1) to indicate the presence of an MNA in the packet and the beginning of an MNA Sub-Stack in the label stack.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      MNA-Label=bSPL                   | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 2: LSE Format A: The MNA Sub-Stack Indicator
S (1 bit):
The BoS [RFC3032]. MUST be set to 0 on transmitted packets. If a packet is received with an LSE containing the bSPL (4) and with S bit set to 1, then the packet MUST be dropped.

4.2. LSE Format B: The Initial Opcode

LSE Format B is used to encode the first opcode in the NAS, plus a number of other fields about the NAS. This LSE can carry up to 13 bits of AD.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Opcode    |        13-bit Data      |R|IHS|S|  NASL |U| NAL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 3: LSE Format B: The Initial Opcode
Opcode (7 bits):
The operation code for this LSE. See Section 5.1.
Data (13 bits):
Opcode-specific AD.
R (1 bit): Reserved.
This bit MUST be set to zero on transmission and ignored upon receipt.
IHS (2 bits):
The scope of all the network actions in this NAS. See Section 5.3.
S (1 bit):
The BoS [RFC3032]. If the NASL value is non-zero, then the S bit MUST be 0. If a packet is received with the S bit set to 1 and a non-zero NASL value, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the Last LSE in the MPLS header.
NASL (4 bits):
The Network Action Sub-Stack Length. The number of Format C and Format D LSEs in the NAS, i.e., not including the leading Format A LSE and the Format B LSE.
U (1 bit):
Unknown Network Action Handling. See Section 5.4.
NAL (3 bits):
Network Action Length. The number of LSEs of additional data, encoded in Format D LSEs (Section 4.4), following this Format B LSE. The NAL value MUST be less than or equal to the NASL value in the Format B LSE. If not, the packet MUST be dropped. A Format C LSE would be following when the NAL value is less than the NASL value.

4.3. LSE Format C: Subsequent Opcodes

LSE Format C is used to encode the subsequent opcodes in the NAS.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Opcode    |        16-bit Data            |S|4b Data|U| NAL |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 4: LSE Format C: Subsequent Opcodes
Opcode (7 bits):
The operation code for this LSE. See Section 5.1.
Data (16 bits + 4 bits):
Opcode-specific AD.
S (1 bit):
The BoS [RFC3032]. If the NAL value is non-zero and if the S bit is set to 1, then the packet MUST be dropped. If this is not the last LSE in the NAS and if the S bit is set to 1, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the Last LSE.
U (1 bit):
Unknown Network Action Handling. See Section 5.4.
NAL (3 bits):
Network Action Length. The number of LSEs of additional data, encoded in Format D LSEs (Section 4.4) following this Format C LSE. The NAL value MUST be less than or equal to the NASL value in the Format B LSE. If not, the packet MUST be dropped.

A Format A and a Format B LSE MUST be present when a Format C LSE is carried in the NAS.

4.4. LSE Format D: Additional Data

LSE Format D is used to encode additional data that did not fit in the LSE with the preceding opcode.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1|                    22-bit Data            |S|  8-bit Data   |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 5: LSE Format D: Additional Data
1 (1 bit):
The most significant bit MUST be set. This prevents legacy implementations from misinterpreting this LSE as containing a special purpose label if the data begins with zeros.
S (1 bit):
The BoS [RFC3032]. If this is not the last LSE for the Network Action based on the NAL value and if the S bit is set to 1, then the packet MUST be dropped. If this is not the last LSE in the NAS and if the S bit is set to 1, then the packet MUST be dropped. The encapsulating node MUST ensure that the S bit is set to 1 only in the Last LSE.
Data (22 bits + 8 bits):
Opcode-specific AD.

A Format A and a Format B LSE MUST be present when a Format D LSE is carried in the NAS.

5. The MNA Sub-Stack

The MNA Sub-Stack MUST begin with a Format A LSE (Section 4.1). The label value of the LSE contains the MNA bSPL (4) to indicate the presence of the MNA Sub-Stack.

The TC and TTL values of the Format A LSE retain their semantics as defined in [RFC3032] and [RFC5462]. The TTL and TC values in the Format A LSE are copied from the forwarding label at the top of the label stack. The penultimate node on the path copies the TTL and TC values from the preceding LSE to the next LSE on the label stack, overwriting the TTL and TC values of the next LSE, as specified in Section 3.5 of [RFC3443] and Section 2.6.3 of [RFC3270] in the Uniform Mode LSPs. If the node performing this copy is not aware of MNA, this could overwrite the values in the Format-A LSE of the NAS.

The second LSE in a NAS MUST be a Format B LSE (Section 4.2). This LSE contains an initial opcode plus additional fields that describe the NAS.

The Format B LSE (Section 4.2) could optionally carry additional data in Format D (Section 4.4) LSEs, up to the length encoded in the LSE's NAL value.

A NAS MAY contain more Format C (Section 4.3) and Format D (Section 4.4) LSEs, up to the length encoded in the NASL value. All Format D LSEs MUST follow a Format C or Format B LSE and be included in that LSE's NAL value.

5.1. Opcodes

The opcode is a 7-bit field that indicates the semantics of its LSE. Several opcodes are assigned special semantics (Section 6). Other opcodes act as NAIs and are assigned through IANA (see Sections 10 and 13.2.2).

5.2. Ancillary Data

The data field carries opcode-specific data that is AD for a network action. In the case of opcode 1, the data field carries Flag-Based Network Action Indicators without AD.

The label value (most significant 20 bits) in one or more consecutive LSEs is commonly used for load-balancing data flows in an ECMP environment. Modifying the first 20 bits in an LSE might alter a packet's path and result in out-of-order delivery of packets belonging to a given flow. To maintain the stability of deployed services in ECMP environments that rely on label value information for load-balancing, care must be taken when encoding network action data in the given LSE. If the network action data may differ among packets in the same flow or change during forwarding across the MPLS network, it MUST NOT be placed in the most significant 20 bits of a Format B LSE (Section 4.2), a Format C LSE (Section 4.3), or a Format D LSE (Section 4.4). Thus, the available bits for data that can change by a transit node or differ among packets of the same flow in Format A and Format B LSEs is 0, in a Format C LSE 7 (bits 20-22 and 25-28), and in a Format D LSE 11 (bits 20-22 and 24-31).

Similarly, to preserve service stability, such data also MUST NOT be carried in the most significant 23 bits of these LSEs when the legacy implementation also uses the TC value, in addition to the label value, in all LSEs when computing ECMP decisions.

The available mitigations for these problems are to use additional Format D LSEs to carry the data or to place the data in Post-Stack Data as described in [RFC9789].

In network deployments where it is known that a load-balancing of data flows is not used, or if only the explicitly signaled entropy value is used, and it is certain that the load-balancing path selection will not be based on the label value of the LSEs, then the data in the label value of the LSEs in the ISD MAY be mutable within the data flow without causing the out-of-order delivery of packets.

5.3. Scope

The IHS field in the Format B LSE indicates the scope of all the NAIs encoded in the NAS. Scope defines which nodes along the MPLS path should perform the network actions found within the NAS. The specific values of the IHS field are as follows:

Table 2: IHS Scope Values
Bits Scope
00 I2E
01 HbH
10 Select
11 Reserved for future use

Ingress to Egress (I2E):
The Network Actions in this NAS MUST NOT be processed by any node except the egress node.
Hop-by-Hop (HbH):
All nodes along the path MUST process the NAS.
Select:
Only specific nodes along the path that bring NAS to the top of the stack will perform the action.

A given NAS can only carry NAIs with the same scope (I2E/HbH/Select). To support multiple scopes for a single packet, multiple NASes MAY be included in a single label stack.

The egress node is included in the HbH scope. This implies that the penultimate node MUST NOT remove an HbH NAS. The egress node may receive a NAS at the top of the label stack as discussed in Section 9.

An I2E scope NAS, if present, MUST be encoded after any HbH or Select-scope NASes. This makes it easier for the transit nodes to process a NAS with HbH or Select scope.

If a packet is received with the IHS scope set to "Reserved for future use", the packet is processed based on the U bit in the Format B LSE in the NAS.

5.4. Unknown Network Action Handling

The Unknown Network Action Handling (U) field in a Format B LSE (Section 4.2) and Format C LSE (Section 4.3) is a 1-bit value that defines the action to be taken by a node that does not understand an action within the NAS. The different types of Unknown Network Action Handling actions are defined below.

Table 3: Unknown Network Action Handling
Bit Action
0 Skip to the next NA
1 Drop the packet

When a packet with an Unknown Network Action Handling is dropped, the node should maintain a local counter for this event and may send a rate-limited notification to the operator.

5.5. Ordering

The network actions encoded in the NAS MUST be processed in the order that they appear in the NAS, from the top of the NAS to the bottom. NAIs encoded as flags (see Section 6.2) MUST be processed from the most significant bit to the least significant bit. If a label stack contains multiple NASes, they MUST be processed in the order that they appear in the label stack, subject to the restrictions in Section 7.

6. Special Opcodes

Below are the special opcodes defined to build a basic In-stack MNA solution and assigned in the "Network Action Opcodes" IANA registry (see Section 13.2.2). In the future, additional special opcodes may be defined and their code points assigned from this registry.

6.1. bSPL Protection

Opcode:
0
Purpose:
Legacy implementations may scan the label stack looking for bSPL values. As long as the opcode field is non-zero, an LSE cannot be misinterpreted as containing a bSPL. Therefore, opcode 0 is reserved and not to be used.

6.2. Flag-Based NAIs Without AD

Opcode:
1
Purpose:
This opcode is used for Network actions that do not require AD. A single flag can be used to indicate each of these network actions.
LSE Formats:
B, C, D
Data:
The data field carries NAIs, which should be evaluated from the most significant bit to the least significant bit. If this opcode is used with LSE Format B only, then up to 13 flags may be carried. If this opcode is used with LSE Format C only, then up to 20 flags may be carried. Format D LSEs can be used with format C LSEs to encode more than 20 flags. Flags are assigned from the "Network Action Flags Without Ancillary Data" registry (Section 13.2.1). If flags need to be evaluated in a different order, multiple LSEs using this opcode may be used to specify the requested order. The Flag-Based NAIs MUST follow the procedure for data specified in Section 5.2.
Scope:
This opcode can be used with any scope.

6.3. No-Operation Opcode

Opcode:
2
Purpose:
This opcode is used to indicate that it does not perform any Network Action and MUST be skipped.
LSE Format:
B
Scope:
Any scope value may be set and MUST be ignored.

6.4. Extension Opcode

Opcode:
127
Purpose:
This opcode is used to extend the current opcode range beyond 127 in the future. If this opcode is not supported, then the packet with opcode 127 MUST be dropped regardless of the setting of the U bit. Use of this opcode is outside the scope of this document.

7. NAS Placement in the Label Stack

The node adding a NAS to the label stack places a copy of the NAS where the relevant nodes can read it. Each downstream node along the path has a Readable Label Depth (RLD). If the NAS is to be processed by a downstream MNA-capable node, then the entire NAS MUST be placed so that it is within RLD by the time the packet reaches the downstream MNA-capable node. The RLD of the downstream MNA-capable node MUST be learned as described in Section 2.3.1 of [RFC9789].

If the label stack is deep, several copies of the NAS may need to be encoded in the label stack.

For a NAS with HbH scope, every node will process the top copy of the NAS. However, the NAS MUST NOT appear at the top of the stack at any MNA-incapable node on the path that is ensured by the encapsulating node using the node capability, as described in Section 8.

A NAS MUST NOT appear at the top of the stack after popping the forwarding label on an MNA-incapable node on the path.

The behavior of a node where a NAS with I2E and HbH scopes is also removed along with popping the forwarding label on a PHP node is outside the scope of this document.

For a NAS with Select scope, it is processed by the node that brings it to the top of the stack (for example, in the case of using MPLS label pop operation in Segment Routing); then, the NAS is removed from the stack. The select-scoped NAS needs to be inserted after the forwarding label and before the next forwarding label. It could be inserted before or after an HbH NAS. Note that the case of a NAS with Select scope with an MPLS label swap operation (for example, with RSVP-TE LSPs) is for future study.

For I2E scope, only one copy of the NAS needs to be added at the bottom of the stack.

A transit node that is not the penultimate node that pops a forwarding label and exposes a copy of a NAS MUST remove that NAS.

An MNA-capable node performing Penultimate Hop Popping (PHP) that pops the forwarding label with only the NAS(es) remaining on the stack MUST NOT remove the NAS(es). Instead, it forwards the packet with the NAS(es) at the top of the stack to the next node. Note that the behavior of the PHP node, as defined in [RFC3270] for TC processing and as defined in [RFC3443] for TTL processing, is not modified regardless of whether the PHP node supports MNA.

The node that receives the NAS at the top of the label stack MUST process and remove it.

7.1. Actions When Pushing Labels

An MNA-capable node may need to push additional labels as well as push new network actions onto a received packet.

While pushing additional labels onto the label stack of the received packet, the MNA-capable node MUST verify that the entire topmost NAS with HbH scope is still within the RLD of the downstream MNA-capable nodes. If required, the MNA-capable node MAY create a copy of the topmost NAS with HbH scope and insert it within the RLD of the downstream MNA-capable nodes on the label stack.

When an MNA-capable node needs to push a new NAS with HbH scope on to a received packet that already has a NAS with HbH scope, it SHOULD copy (and merge) the network actions (including their AD) from the received topmost NAS with HbH scope in the new NAS with HbH scope. The new NAS MUST be placed within the RLD of the downstream MNA-capable nodes. This behavior can be based on local policy.

The new network actions added MUST NOT conflict with the network actions in the received NAS with HbH scope. The mechanism to resolve such conflicts depends on the network actions and can be based on local policy. The MNA-capable node that pushes entries MUST understand any network actions that it is pushing that may result in a conflict and MUST resolve any conflicts between new and received network actions. In the usual case of a conflict of duplicating a network action, the definition of a network action MUST give guidance on conflict resolution.

8. Node Capability Signaling

The encapsulating node MUST make sure that the NAS can be processed by the transit and egress nodes. In addition, the encapsulated packet MUST NOT exceed the path MTU as described in [RFC3032].

9. Processing the Network Action Sub-Stack

This section defines the specific responsibilities for nodes along an LSP [RFC3031].

9.1. Encapsulating Node Responsibilities

The encapsulating node MAY add NASes to the label stack in accordance with its policies, the placement restrictions in Section 7, and the capabilities learned from Section 8.

If there is an existing label stack, the encapsulating node MUST NOT modify the first 20 bits of any LSE in the label stack when the ECMP technique in the network uses hashing of the labels on the label stack.

9.2. Transit Node Responsibilities

The transit node is the node that processes a NAS in the Label stack but does not push any new NAS.

The transit node MUST follow the procedure for data specified in Section 5.2.

Transit nodes MUST process the NASes in the label stack according to the rules set out in Section 5.5.

A transit node that processes a NAS and does not recognize the value of an opcode MUST follow the rules according to the setting of the Unknown Network Action Handling value in the NAS as described in Section 5.4.

9.3. Penultimate Node Responsibilities

In addition to the transit node responsibilities, the penultimate node and penultimate SR-MPLS segment node MUST NOT remove the last copy of an HbH or I2E NAS when it is exposed after removing the forwarding (transport) label. This allows the egress node to process the NAS.

9.4. Egress Node Responsibilities

The egress node MUST remove any NAS it receives.

10. Network Action Indicator Opcode Definition

The following information MUST be defined for a new NAI opcode request in the document that specifies the Network Action.

Format:
The definition of the new Network Action MUST specify the LSE formats. The opcode can define Network Action in Format B or C or both Formats B and C. Both Format B and C LSEs MAY optionally carry Format D LSEs.
Scope:
The definition of the new Network Action MUST specify at least one scope (I2E, HbH, Select) for the Network Action and MAY specify more than one scope.
Ancillary Data:
The definition of the new Network Action MUST specify the quantity, syntax, and semantics of any associated AD. The AD MAY be variable length, but the NAL MUST be computable based on the data added in the NAS.
Processing:
The definition of the new Network Action MUST specify the detailed procedure for processing the network action.
Interactions:
The definition of the new Network Action MUST specify its interaction including merging with other currently defined Network Action if there is any.

An assignment for a NAI MAY make requests from any combination of the "Network Action Opcodes" or "Network Action Flags Without Ancillary Data" assignments (see Section 13). This decision should optimize for eventual encoding efficiency. If the NAI does not require any AD, then a flag is preferred as only one bit is used in the encoding.

11. Security Considerations

The security considerations in [RFC3032] and [RFC9789] also apply to this document.

In addition, MNA creates a new dimension in security concerns:

12. Operational Considerations

12.1. Manageability Considerations

An MNA implementation MAY collect the following counters:

  • Packets with MNA received
  • MNA sub-stacks processed
  • MNA per-network-action counters
  • Packets with MNA dropped due to unknown actions
  • Packets with MNA skipped due to unknown actions
  • Packets with MNA dropped due to malformed NAS

Additionally, tracking both successful invocations and failures for each specific Network Action is RECOMMENDED to provide granular visibility. Nodes MAY generate rate-limited notifications or alarms for significant operational events, such as sustained high rates of MNA packet drops or frequent encounters of malformed MNA sub-stacks, to alert operators to potential issues. Comprehensive logging of MNA processing details and outcomes can aid in the network diagnostics and post-mortem analysis.

12.2. Performance and Scale Considerations

The considerations for performance and scale assessments are outside the scope of this document but are encouraged to be addressed in the MNA application documents.

12.3. Backward Compatibility

This section discusses interactions between MNA-capable and MNA-incapable nodes.

An MNA encapsulating node MUST ensure that the MPLS Network Action Sub-Stack indicator is not at the top of the MPLS label stack when the packet arrives at an MNA-incapable node. If such a packet did arrive at an MNA-incapable node, it will most likely be dropped as described in Section 2.1.1 of [RFC7325].

Any node could scan the label stack, potentially looking for a label value containing a bSPL. To ensure that the LSE formats described herein do not appear to contain a bSPL value, the opcode value of 0 has been reserved. By ensuring that there is a non-zero value in the high-order 7 bits, we are assured that the high-order 20 bits cannot be misinterpreted as containing a bSPL value (0-15).

The TC and TTL values of the Format A LSE are not repurposed for encoding, as the penultimate node on the MPLS packet path may propagate TTL from the transport (or forwarding) label to the next label on the label stack, overwriting the TTL on the next label. If the penultimate node is a legacy node, it might perform this action, potentially corrupting other values stored in the TC and TTL values. To protect against this, we retain the TC and TTL values in the Format A LSE.

When adding the Entropy Label Indicator (ELI) (bSPL 7) and Entropy Label (EL) as defined in [RFC6790], along with an MNA NAS, the RLD MUST be considered for the placement of both, and they both can be placed in any order. If a transit LSR chooses to use as much of the whole label stack as feasible as a key for the load-balancing function, the MNA-reserved label MUST NOT be used as a key for the load-balancing function, as specified in Section 4.3 of [RFC6790]. Note that the behavior of an MNA-incapable transit LSR that scans the label stack for ELI and EL but encounters a different, unrecognized reserved label first, is not modified by this document.

Similarly, when adding the Flow-ID Label Indicator (FLI) (including the extension label 15) and Flow-ID Label (FL) as defined in [RFC9714], along with an MNA NAS, the RLD MUST be considered for the placement of both, and they both can be placed in any order. Note that the behavior of an MNA-incapable transit LSR that scans the label stack for FLI (including the extension label 15) and FL, but encounters a different, unrecognized reserved label first, is not modified by this document.

However, as the existing behavior is not specified for transit LSRs, upon encountering any unrecognized bSPLs or extended SPLs (eSPLs) below the top of the label stack, some existing implementations may have chosen to implement non-standardized actions, such as discarding packets. Any uses of a new bSPL or eSPL would cause issues with such existing implementations using the non-standardized actions upon encountering unrecognized bSPLs or eSPLs below the top of the label stack. Since this is a generic problem, any clarifications for the treatment of unrecognized bSPL or eSPL are outside the scope of this document.

13. IANA Considerations

13.1. MNA bSPL Label

IANA has allocated the value 4 for the MNA bSPL label from the "Base Special-Purpose MPLS Label Values" registry to indicate the presence of an MNA Sub-Stack in the label stack. The description of the value is "MPLS Network Actions".

13.2. MPLS Network Actions Parameters

IANA has created a registry group called "MPLS Network Actions" within the "Multiprotocol Label Switching Architecture (MPLS)" category. This registry group contains the "Network Action Flags Without Ancillary Data" registry (see Section 13.2.1) and the "Network Action Opcodes" registry (see Section 13.2.2).

13.2.1. Network Action Flags Without Ancillary Data

For the "Network Action Flags Without Ancillary Data" registry, registration requests should comply with Section 10. Depending on the range, the registration procedure for this registry is "IETF Review", "Experimental Use", or "Private Use" (as defined in [RFC8126]). The fields in this registry are "Bit Position" (integer), "Description" (string), and "Reference" (string).

Bit Position refers to the position relative to the most significant bit in LSE Format B or C Data fields and any subsequent Format D LSEs. Bit Position 0 is the most significant bit in an LSE Format B or C Data field. Bit Position 20 is the most significant bit in the first LSE Format D Data field. There are 20 bits available in LSE Format C and 30 bits available in LSE Format D. There are, at most, 14 Format D LSEs per opcode (due to the NASL limit of 15 and Format D requires Format C LSE), so there are at most 20 + 14 * 30 = 440 bit positions. The value listed in the Bit Position column is an integer with value between 0-439.

The registration procedures for code point allocation for this registry are defined in Table 4:

Table 4: Registration Procedures for the "Network Action Flags Without Ancillary Data" Registry
Range Registration Procedure
0-14 IETF Review
15-16 Experimental Use
17-19 Private Use
20-439 IETF Review

13.2.2. Network Action Opcodes

For the "Network Action Opcodes" registry, registration requests should comply with Section 10 as well as security review. Depending on the range, the registration procedure for this registry is "IETF Review", "Experimental Use", or "Private Use" (as defined in [RFC8126]). The fields are "Opcode" (integer), "Description" (string), and "Reference" (string). Opcode is an integer with value 1-126.

Table 5: Registration Procedures for the "Network Action Opcodes" Registry
Range Registration Procedure
1-110 IETF Review
111-114 Experimental Use
115-126 Private Use
127 IETF Review

IANA has allocated values for the following Network Action Opcodes from the "Network Action Opcodes" registry.

Table 6: Initial Contents of the "Network Action Opcodes" Registry
Opcode Description Reference
0 Reserved RFC 9994
1 Flag-Based Network Action Indicators without AD RFC 9994
2 No operation Opcode RFC 9994
127 Opcode Range Extension Beyond 127 RFC 9994

14. References

14.1. Normative References

[RFC2119]
Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, , <https://www.rfc-editor.org/info/rfc2119>.
[RFC3032]
Rosen, E., Tappan, D., Fedorkow, G., Rekhter, Y., Farinacci, D., Li, T., and A. Conta, "MPLS Label Stack Encoding", RFC 3032, DOI 10.17487/RFC3032, , <https://www.rfc-editor.org/info/rfc3032>.
[RFC3270]
Le Faucheur, F., Ed., Wu, L., Davie, B., Davari, S., Vaananen, P., Krishnan, R., Cheval, P., and J. Heinanen, "Multi-Protocol Label Switching (MPLS) Support of Differentiated Services", RFC 3270, DOI 10.17487/RFC3270, , <https://www.rfc-editor.org/info/rfc3270>.
[RFC3443]
Agarwal, P. and B. Akyol, "Time To Live (TTL) Processing in Multi-Protocol Label Switching (MPLS) Networks", RFC 3443, DOI 10.17487/RFC3443, , <https://www.rfc-editor.org/info/rfc3443>.
[RFC5462]
Andersson, L. and R. Asati, "Multiprotocol Label Switching (MPLS) Label Stack Entry: "EXP" Field Renamed to "Traffic Class" Field", RFC 5462, DOI 10.17487/RFC5462, , <https://www.rfc-editor.org/info/rfc5462>.
[RFC6790]
Kompella, K., Drake, J., Amante, S., Henderickx, W., and L. Yong, "The Use of Entropy Labels in MPLS Forwarding", RFC 6790, DOI 10.17487/RFC6790, , <https://www.rfc-editor.org/info/rfc6790>.
[RFC8126]
Cotton, M., Leiba, B., and T. Narten, "Guidelines for Writing an IANA Considerations Section in RFCs", BCP 26, RFC 8126, DOI 10.17487/RFC8126, , <https://www.rfc-editor.org/info/rfc8126>.
[RFC8174]
Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, , <https://www.rfc-editor.org/info/rfc8174>.
[RFC9017]
Andersson, L., Kompella, K., and A. Farrel, "Special-Purpose Label Terminology", RFC 9017, DOI 10.17487/RFC9017, , <https://www.rfc-editor.org/info/rfc9017>.
[RFC9789]
Andersson, L., Bryant, S., Bocci, M., and T. Li, "MPLS Network Actions (MNAs) Framework", RFC 9789, DOI 10.17487/RFC9789, , <https://www.rfc-editor.org/info/rfc9789>.

14.2. Informative References

[RFC3031]
Rosen, E., Viswanathan, A., and R. Callon, "Multiprotocol Label Switching Architecture", RFC 3031, DOI 10.17487/RFC3031, , <https://www.rfc-editor.org/info/rfc3031>.
[RFC6291]
Andersson, L., van Helvoort, H., Bonica, R., Romascanu, D., and S. Mansfield, "Guidelines for the Use of the "OAM" Acronym in the IETF", BCP 161, RFC 6291, DOI 10.17487/RFC6291, , <https://www.rfc-editor.org/info/rfc6291>.
[RFC7325]
Villamizar, C., Ed., Kompella, K., Amante, S., Malis, A., and C. Pignataro, "MPLS Forwarding Compliance and Performance Requirements", RFC 7325, DOI 10.17487/RFC7325, , <https://www.rfc-editor.org/info/rfc7325>.
[RFC8664]
Sivabalan, S., Filsfils, C., Tantsura, J., Henderickx, W., and J. Hardwick, "Path Computation Element Communication Protocol (PCEP) Extensions for Segment Routing", RFC 8664, DOI 10.17487/RFC8664, , <https://www.rfc-editor.org/info/rfc8664>.
[RFC9613]
Bocci, M., Ed., Bryant, S., and J. Drake, "Requirements for Solutions that Support MPLS Network Actions (MNAs)", RFC 9613, DOI 10.17487/RFC9613, , <https://www.rfc-editor.org/info/rfc9613>.
[RFC9714]
Cheng, W., Ed., Min, X., Ed., Zhou, T., Dai, J., and Y. Peleg, "Encapsulation for MPLS Performance Measurement with the Alternate-Marking Method", RFC 9714, DOI 10.17487/RFC9714, , <https://www.rfc-editor.org/info/rfc9714>.
[RFC9791]
Saad, T., Makhijani, K., Song, H., and G. Mirsky, "Use Cases for MPLS Network Action Indicators and Ancillary Data", RFC 9791, DOI 10.17487/RFC9791, , <https://www.rfc-editor.org/info/rfc9791>.

Appendix A. Examples

A.1. Network Action Encoding Examples

A.1.1. Network Action Flags Without AD

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|          MNA-Label=bSPL               | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=1   |        13-bit Flags     |R|IHS|S|NASL=0 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 6: NAS with Network Action Flags

This is an example of a NAS with Flag-Based NAIs without AD.

Details:

Opcode=1:
This opcode indicates that the LSE carries Flag-Based NAIs without AD.
Data:
The data field carries the Flag-Based NAIs.
S:
This is the bottom of the stack bit. Set if and only if this LSE is the bottom of the stack.
U:
Action to be taken if one of the NAIs is not recognized by the processing node.
NASL:
The NASL value is set to 0, as there are no additional LSEs.
NAL:
The NAL value is set to 0, as there are no additional AD encoded using Format D.
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      MNA-Label=bSPL                   | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=2   |        Data=0           |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=1   |        Flag-Based NAIs        |S| NAIs  |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1| Additional Flag-Based NAIs                |S|Flag-Based-NAIs|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 7: Network Action Flags Without AD Using LSE Format D

In this example, the NAS contains a Format B LSE with a No-Operation Opcode value 2. The next LSE uses Format C, but the Network Action Flag is not in a bit position contained within the Format C LSE, so a single Format D LSE has been added to the NAS to carry the flag.

NAL is set to 1 to indicate that Flag-Based NAIs are also encoded in the next LSE.

NASL is set to 2 to indicate that two additional LSEs are used.

A.1.2. Network Action Opcode with AD

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|      MNA-Label=bSPL                   | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=8   |      Ancillary Data     |R|IHS|S|NASL=0 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 8: Network Action Opcode with Ancillary Data

In this example, the NAS is carrying only one Network Action that requires 13 bits of AD.

Details on the Second LSE:

Opcode=8:
A network action allocation is outside of this document.
Data:
The data field contains 13 bits of AD.

A.1.3. Network Action Opcode with More AD with Format-B

A network action may require more AD than can fit in a single LSE. In this example, a Format D LSE is added to carry additional AD.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|          MNA-Label=bSPL               | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=10  |      Ancillary Data     |R|IHS|S|NASL=1 |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1|            Ancillary Data                 |S|Ancillary Data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 9: Network Action with Additional Ancillary Data

In this example, opcode 10 is encoded in Format B, and it requires more than one LSE's worth of AD, so a Format D LSE is added.

Details on the second LSE:

Opcode=10:
An opcode allocation is outside of this document.
Ancillary Data:
AD required to process the Network Action opcode 10.
NAL:
Length of additional LSEs used to encode its AD.

Details on the third LSE:

Ancillary Data:
22 bits of additional AD.
Ancillary Data:
8 bits of additional AD.

A.1.4. Network Action Opcode with More AD with Format C

A network action may require more AD than can fit in a single LSE. In this example, a Format D LSE is added to carry additional AD.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|          MNA-Label=bSPL               | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=2   |      Data=0             |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Opcode=9   |      Ancillary Data           |S|   AD  |U|NAL=1|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|1|            Ancillary Data                 |S|Ancillary Data |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 10: Network Action with Additional Ancillary Data

In this example, opcode 9 requires more than one LSE's worth of AD, so a Format D LSE is added.

Details on the third LSE:

Opcode=9:
An opcode allocation is outside of this document
Ancillary Data:
Most significant bits of AD
AD:
4 bits of additional AD

Details on the fourth LSE:

Ancillary Data:
22 bits of additional AD.
Ancillary Data:
8 bits of additional AD.

A.2. Network Action Processing Order

The semantics of a network action can vary widely and the results of processing one network action may affect the processing of a subsequent network action. See Section 5.5.

A.2.1. Network Action Processing Order

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|           MNA-Label=bSPL              | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=8    |      Ancillary Data     |R|IHS|S|NASL=2 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=7    |      Ancillary Data7          |S|  AD7  |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1    |      Flag-Based NAIs          |S|  NAI  |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 11: In-Stack NA Processing Order

In this example, opcode 8 is processed first, then opcode 7, and then the network action flags are processed from most significant to least significant.

In a different case, some Flag-Based NAIs may need to be processed before opcode 7, and some Flag-Based NAIs may need to be processed after opcode 7. This can be done by causing some NAIs to appear earlier in the NAS.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|              MNA-Label=bSPL           | TC  |S|    TTL        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=8    |      Ancillary Data     |R|IHS|S|NASL=3 |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1    |        0x01                   |S|  NAI  |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=7    |      Ancillary Data7          |S|  AD7  |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Opcode=1    |        0x02                   |S|  NAI  |U|NAL=0|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 12: Interleaving Network Actions

In the above example, opcode 8 is processed first, then Flag-Based NAI 0x01 is processed, then opcode 7 is processed, and finally NAI 0x02 is processed.

Acknowledgments

The authors of this document would like to thank the MPLS Working Group Open Design Team for the discussions and comments on this document. The authors would also like to thank Amanda Baber for reviewing the IANA Considerations and providing many useful suggestions. The authors would like to thank Loa Andersson, Stewart Bryant, Greg Mirsky, Joel M. Halpern, and Adrian Farrel for reviewing this document and providing many useful suggestions. The authors would like to thank Fabian Ihle and Michael Menth, both from the University of Tuebingen, for reviewing and implementing the solution defined in this document in P4 pipeline. Also, thank you to Tarek Saad for the Shepherd's review, Joe Clarke for the OpsDir review, Matthew Bocci for the Rtgdir review, Derrell Piper for the Secdir review, and James Guichard for the AD review, Mohamed Boucadair, Éric Vyncke, Deb Cooley, Ketan Talaulikar, and Mahesh Jethanandani for the IESG review, which helped improve this document.

Contributors

The following people have substantially contributed to this document:

Jisu Bhattacharya
Cisco Systems, Inc.
Bruno Decraene
Orange
Weiqiang Cheng
China Mobile
Xiao Min
ZTE Corp.
Luay Jalil
Verizon
Jie Dong
Huawei Technologies
Huawei Campus, No. 156 Beiqing Rd.
Beijing
100095
China
Tianran Zhou
Huawei Technologies
China
Bin Wen
Comcast
Sami Boutros
Ciena
Tony Li
Juniper Networks
United States of America
John Drake
Juniper Networks
United States of America

Authors' Addresses

Jaganbabu Rajamanickam (editor)
Cisco Systems, Inc.
Canada
Rakesh Gandhi (editor)
Cisco Systems, Inc.
Canada
Royi Zigler
Broadcom
Haoyu Song
Futurewei Technologies
Kireeti Kompella
Juniper Networks
United States