Network Working Group                                        J. Guichard
Internet-Draft                                         C. Pignataro, Ed.
Intended status:  Standards Track                             S. Spraggs
Expires:  December 14, 2013                                    S. Bryant
                                                                   Cisco
                                                           June 12, 2013


                   Carrying Metadata in MPLS Networks
                    draft-guichard-mpls-metadata-00

Abstract

   This document defines the mechanism for identifying the presence of
   metadata carried in addition to the payload in MPLS packets.

Requirements Language

   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
   document are to be interpreted as described in [RFC2119].

Status of this Memo

   This Internet-Draft is submitted in full conformance with the
   provisions of BCP 78 and BCP 79.

   Internet-Drafts are working documents of the Internet Engineering
   Task Force (IETF).  Note that other groups may also distribute
   working documents as Internet-Drafts.  The list of current Internet-
   Drafts is at http://datatracker.ietf.org/drafts/current/.

   Internet-Drafts are draft documents valid for a maximum of six months
   and may be updated, replaced, or obsoleted by other documents at any
   time.  It is inappropriate to use Internet-Drafts as reference
   material or to cite them other than as "work in progress."

   This Internet-Draft will expire on December 14, 2013.

Copyright Notice

   Copyright (c) 2013 IETF Trust and the persons identified as the
   document authors.  All rights reserved.

   This document is subject to BCP 78 and the IETF Trust's Legal
   Provisions Relating to IETF Documents
   (http://trustee.ietf.org/license-info) in effect on the date of
   publication of this document.  Please review these documents



Guichard, et al.        Expires December 14, 2013               [Page 1]


Internet-Draft                MPLS Metadata                    June 2013


   carefully, as they describe your rights and restrictions with respect
   to this document.  Code Components extracted from this document must
   include Simplified BSD License text as described in Section 4.e of
   the Trust Legal Provisions and are provided without warranty as
   described in the Simplified BSD License.


Table of Contents

   1.  Introduction . . . . . . . . . . . . . . . . . . . . . . . . .  3
     1.1.  Terminology  . . . . . . . . . . . . . . . . . . . . . . .  3
   2.  Metadata Component Structure . . . . . . . . . . . . . . . . .  3
   3.  Metadata Channel Header Format . . . . . . . . . . . . . . . .  4
     3.1.  Metadata Encapsulation Format  . . . . . . . . . . . . . .  4
   4.  Load-balancing Considerations  . . . . . . . . . . . . . . . .  5
   5.  Metadata and MPLS Label Stack  . . . . . . . . . . . . . . . .  5
   6.  Data Plane Processing of MPLS Packets Containing Metadata  . .  6
     6.1.  Egress LSR . . . . . . . . . . . . . . . . . . . . . . . .  6
     6.2.  Ingress LER/LSR  . . . . . . . . . . . . . . . . . . . . .  6
     6.3.  Transit LSR  . . . . . . . . . . . . . . . . . . . . . . .  7
     6.4.  Penultimate Hop LSR  . . . . . . . . . . . . . . . . . . .  7
   7.  Data Plane Processing of MPLS Packets Containing Metadata  . .  7
   8.  IANA Considerations  . . . . . . . . . . . . . . . . . . . . .  8
   9.  Security Considerations  . . . . . . . . . . . . . . . . . . .  8
   10. Contributing Authors . . . . . . . . . . . . . . . . . . . . .  8
   11. Acknowledgments  . . . . . . . . . . . . . . . . . . . . . . .  8
   12. References . . . . . . . . . . . . . . . . . . . . . . . . . .  9
     12.1. Normative References . . . . . . . . . . . . . . . . . . .  9
     12.2. Informative References . . . . . . . . . . . . . . . . . .  9
   Appendix A.  Alternative Options . . . . . . . . . . . . . . . . . 10
   Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 10




















Guichard, et al.        Expires December 14, 2013               [Page 2]


Internet-Draft                MPLS Metadata                    June 2013


1.  Introduction

   This document defines the mechanism for identifying the presence of
   metadata carried in addition to the payload in MPLS packets.  The
   metadata header is common across all encapsulations (including IPv4,
   IPv6, and MPLS) and is defined in [I-D.guichard-metadata-header].

1.1.  Terminology

   ACH   Associated Channel Header

   AL    Application Label

   EL    Entropy Label

   ELI   Entropy Label Indicator

   G-ACh Generic Associated Channel

   GAL   Generic Associated Channel Label

   TL    Top Label

   MCH   Metadata Channel Header

   MD    Metadata


2.  Metadata Component Structure

   The addition of metadata to packets enables the instrumentation of
   user packets, and service chaining, although it is anticipated that
   the ability to allow packets to carry metadata of use to the
   infrastructure and specific handling instructions will enable other
   uses.

   Metadata carried within an MPLS packet is prefaced by a Metadata
   Channel Header (MCH) as defined in [I-D.guichard-metadata-header],
   with the first nibble of the MCH set to 0000b.

   Metadata is distinguished from IP payloads using similar methods to
   those developed in pseudowires and MPLS-TP [RFC4385] [RFC5586].

   Two scenarios are presented for MPLS environments where metadata may
   be required.

   1.  IPv4, IPv6 or pseudo-wire payload.  In this case the metadata
       will be carried within MPLS packets between the MCH and the



Guichard, et al.        Expires December 14, 2013               [Page 3]


Internet-Draft                MPLS Metadata                    June 2013


       original MPLS payload.  A GAL reserved label [RFC5586] is used to
       indicate that metadata is carried within the MPLS packet and that
       an MCH immediately follows the bottom of the label stack.

   2.  MPLS payload.  In this case a new label stack will be created for
       the section over which the metadata is relevant and the original
       MPLS packet (MPLS label stack and MPLS payload) will be carried
       in the payload section described below.  An example where this
       type of scenario may be required is when a hierarchical LSP needs
       to be instrumented.  In this case, rather than pushing the labels
       associated with the hierarchical section onto the existing label
       stack, the original label stack is preserved and placed along
       with its associated payload in the payload section described
       below.  A new label stack, indicating the presence of metadata
       (by way of the GAL), the MCH, and the metadata itself is then
       built for the MPLS section requiring instrumentation and sent.


3.  Metadata Channel Header Format

   The presence of metadata within an MPLS packet must be indicated in
   the encapsulation.  This document defines that the G-ACh Generic
   Associated Channel Label (GAL) [RFC5586] with label value 13 is
   utilized for this purpose.  The GAL label provides a method to
   identify that a packet contains an "Associated Channel Header (ACH)"
   followed by a non-service payload.

   [RFC5586] identifies the G-ACh Generic Associated Channel by setting
   the first nibble of the ACH that immediately follows the bottom label
   in the stack if the GAL label is present, to 0001b.  Further
   [RFC5586] expects that the ACH not be used to carry user data
   traffic.  This document proposes an extension to allow the first
   nibble of the ACH to be set to 0000b and, when following the GAL, be
   interpreted using the semantics defined in
   [I-D.guichard-metadata-header] to allow metadata to be carried
   through the G-ACh channel.

   The metadata is distinguished from OAM by the use of 0000b in the
   first nibble.  This is consistent with the practise developed in
   pseudowire [RFC4928] which uses a first nibble of 0000b to indicate
   the presence of information to be used by the forwarding plane to
   correctly forward the packet (i.e. the PW control word [RFC4385]).

3.1.  Metadata Encapsulation Format

   Figure 1 depicts the Metadata encapsulation format:





Guichard, et al.        Expires December 14, 2013               [Page 4]


Internet-Draft                MPLS Metadata                    June 2013


      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
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |                GAL                    | EXP |1|      TTL      |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |0 0 0 0:         Metadata Channel Header (MCH)                 |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |                      Metadata (variable)                      |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |                Original L2, L3, MPLS Payload                  |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

                  Figure 1: Metadata Encapsulation Format

   The meanings of the fields in the metadata packet format are as
   follows:

   o  The GAL (reserved label of value 13) is used to indicate that an
      ACH or MCH appears immediately after the bottom of the label
      stack.  The first nibble of the channel header is used to identify
      whether the format is to be interpreted as an ACH or MCH.

   o  If the first nibble is set as 0000b, this indicates that an MCH
      will sit beneath the label stack.

   o  Immediately following the MCH will be the metadata.  The length
      and format of the metadata is outside the scope of this document
      and will vary depending upon the "Metadata Channel Type" specified
      in the MCH.

   o  Beneath the metadata will be the original packet payload.  This
      could be L2, L3 or MPLS payload.


4.  Load-balancing Considerations

   The approach in this document is consistent with the use of utilizing
   0000b as the first nibble after the MPLS label stack, as described in
   [RFC4928].  In this case, the MCH starts with 0000b.  Load balancing
   is achieved utilizing the entropy label and following the methods
   defined in [RFC6790].


5.  Metadata and MPLS Label Stack

   Only one piece of metadata can be carried for each payload (L2, L3,
   or MPLS).  As a consequence there MUST be only one GAL label in the
   label stack.  Entropy labels MAY be present in the label stack but



Guichard, et al.        Expires December 14, 2013               [Page 5]


Internet-Draft                MPLS Metadata                    June 2013


   they MUST be indicated using the Entropy Label Indicator (ELI) as
   described in [RFC6790].


6.  Data Plane Processing of MPLS Packets Containing Metadata

6.1.  Egress LSR

   Suppose egress LSR Y is capable of processing metadata.  LSR Y
   indicates this to all other LER's and LSR's via signaling (see
   Section 7 for more discussion on this subject) or through direct
   configuration.

   LSR Y MUST be prepared to process packets carrying metadata and those
   without.  If a GAL is present in the MPLS label stack, the receiving
   LSR MUST inspect the first nibble after the end of the label stack to
   identify the presence of an MCH or an ACH, and process the packet
   accordingly.  An LSR SHOULD NOT push a GAL on a packet that does not
   contain an MCH or an ACH.

   If a particular LER or LSR chooses to send traffic without metadata,
   LSR Y's processing of the received label stack (which might be empty)
   and payload is based on normal MPLS processing rules.  If LER/LSR X
   chooses to send metadata, then LSR Y will receive an MPLS packet
   constructed as follows:

      <Top Label (TL), AL, GAL> <MCH> <metadata> <remaining packet
      payload>

   LSR Y recognizes TL as the label it distributed to its upstream LER/
   LSR and pops the TL (note that the TL signalled by LSR Y may be an
   implicit null label, in which case it doesn't appear in the label
   stack and LSR Y MUST process the packet starting with the AL label
   (if present) and/or the GAL label.)  LSR Y recognizes the GAL with S
   bit set.  LSR Y then processes the metadata, starting with the MCH
   (0000b), which will determine how LSR Y processes the underlying
   payload.

6.2.  Ingress LER/LSR

   If an egress LSR Y indicates via signaling or through direct
   configuration of other LER's/LSR's that it can process metadata, the
   steps that Ingress LER/LSR X performs to insert metadata are as
   follows:

   1.  On an incoming packet, identify the application to which the
       packet belongs and from this the egress LSR; based on these two
       components determine whether metadata needs to be added to the



Guichard, et al.        Expires December 14, 2013               [Page 6]


Internet-Draft                MPLS Metadata                    June 2013


       incoming packet.

   2.  For packets requiring the insertion of metadata, build the
       appropriate MCH and prepend the metadata and the MCH to the
       existing payload; then, push the GAL label on to the label stack
       with the S bit set.  For packets not requiring insertion of
       metadata, this step is a NOOP.

   3.  Push the application label (AL) label (if required) on to the
       label stack.

   4.  If Entropy is required then pick appropriate fields as input to
       the load-balancing function; apply the load-balancing function to
       these input fields and generate the Entropy label (EL) value.

   5.  Push the EL and the ELI labels on to the label stack.

   6.  Determine the top label (TPL) and push it on top of the ELI and
       EL (if present).  The ordering of the AL and the ELI plus EL pair
       is not critical other than that the egress LSR processing the ELI
       MUST process all remaining labels in the stack and the metadata.
       The S bit for the ELI and EL MUST be zero (i.e., S bit is not
       set).  The TTL for the EL MUST be zero to ensure that it is not
       used inadvertently for forwarding.  The TC for the EL may be any
       value.

   7.  Determine the output interface, and transmit.

6.3.  Transit LSR

   Transit LSRs may operate with no change in forwarding behavior.

6.4.  Penultimate Hop LSR

   No change is needed at penultimate hop LSRs.


7.  Data Plane Processing of MPLS Packets Containing Metadata

   Two levels of set-up are required to support metadata.  The first is
   an indication that the device or LSP is capable of supporting
   metadata.  This could be done either using the NMS or by using
   capabilities exchange mechanisms.  For example an IGP ([RFC4971] in
   ISIS) or MPLS protocols such as [RFC5036], [RFC3209], or [RFC3107].
   The specific mechanism for signaling the support of metadata is
   outside the scope of this document and will be defined elsewhere.

   The second set-up required is by the actual application using the



Guichard, et al.        Expires December 14, 2013               [Page 7]


Internet-Draft                MPLS Metadata                    June 2013


   information contained in the metadata.  Again this could be done
   using either the NMS or a signaling protocol.  It is anticipated this
   type of signaling is specifically associated with the application and
   would be specified elsewhere.


8.  IANA Considerations

   This document makes no request of IANA.

   [Note to RFC Editor:  this section may be removed on publication as
   an RFC.]


9.  Security Considerations

   The addition of metadata to a packet increases the amount of
   processing required by the LSR receiving the packet, and thus may be
   a used in a denial of service attack vector.  However MPLS networks
   carefully manage their adjacencies and only accept labeled packets
   from trusted neighbors.  Provided this current level of neighbor
   verification remains in place no additional risk results.

   The metadata itelf may be an attack vector with either the
   originating LSR or a man in the middle inserting malicious content.
   The trust model of the MPLS network itself, described earlier in this
   section guards against a man in the middle attack and ensures that
   the originating LER/LSR is a trusted party.

   If the ingress LER/LSR is taking instructions from a third party in
   the specific medadata to insert, there MUST be a sufficient trust
   relationship between the ingress LER/LSR and the third party.

   The security considerations associated with each metadata type MUST
   be specified as part of its definition.


10.  Contributing Authors

   o  Clarence Filsfils <cfilsfil@cisco.com>

   o  Dan Frost <danfrost@cisco.com>


11.  Acknowledgments

   The authors would like to thank Giles Heron for his review and useful
   comments.



Guichard, et al.        Expires December 14, 2013               [Page 8]


Internet-Draft                MPLS Metadata                    June 2013


12.  References

12.1.  Normative References

   [I-D.guichard-metadata-header]
              Guichard, J., Spraggs, S., Pignataro, C., and S. Bryant,
              "Common Metadata Header Format for IP/MPLS Networks".

   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119, March 1997.

12.2.  Informative References

   [I-D.kompella-mpls-special-purpose-labels]
              Kompella, K. and A. Farrel, "Allocating and Retiring
              Special Purpose MPLS Labels",
              draft-kompella-mpls-special-purpose-labels-04 (work in
              progress), May 2013.

   [RFC3107]  Rekhter, Y. and E. Rosen, "Carrying Label Information in
              BGP-4", RFC 3107, May 2001.

   [RFC3209]  Awduche, D., Berger, L., Gan, D., Li, T., Srinivasan, V.,
              and G. Swallow, "RSVP-TE: Extensions to RSVP for LSP
              Tunnels", RFC 3209, December 2001.

   [RFC4385]  Bryant, S., Swallow, G., Martini, L., and D. McPherson,
              "Pseudowire Emulation Edge-to-Edge (PWE3) Control Word for
              Use over an MPLS PSN", RFC 4385, February 2006.

   [RFC4928]  Swallow, G., Bryant, S., and L. Andersson, "Avoiding Equal
              Cost Multipath Treatment in MPLS Networks", BCP 128,
              RFC 4928, June 2007.

   [RFC4971]  Vasseur, JP., Shen, N., and R. Aggarwal, "Intermediate
              System to Intermediate System (IS-IS) Extensions for
              Advertising Router Information", RFC 4971, July 2007.

   [RFC5036]  Andersson, L., Minei, I., and B. Thomas, "LDP
              Specification", RFC 5036, October 2007.

   [RFC5586]  Bocci, M., Vigoureux, M., and S. Bryant, "MPLS Generic
              Associated Channel", RFC 5586, June 2009.

   [RFC6790]  Kompella, K., Drake, J., Amante, S., Henderickx, W., and
              L. Yong, "The Use of Entropy Labels in MPLS Forwarding",
              RFC 6790, November 2012.




Guichard, et al.        Expires December 14, 2013               [Page 9]


Internet-Draft                MPLS Metadata                    June 2013


Appendix A.  Alternative Options

   This appendix lists alternative options for metadata indication that
   were considered but ultimately discarded:

   o  Starting the MCH with the first nibble as 0010b.  This first
      nibble is overloading the IP version field, and thus the creation
      of new first nibbles needs to be a conservative process, since
      each new nibble used for other purposes prevents that nibble being
      used to identify a new IP type at some time in the future.

   o  Extending a G-ACh to be able to carry user data.  This has been
      discussed at length within the IETF and it seems the consensus is
      this structure should not carry customer payload.

   o  Assign a new reserved label, either directly or as an extension
      label as proposed in [I-D.kompella-mpls-special-purpose-labels] to
      indicate the presence of metadata.  In the first case it utilizes
      another reserved label, which are becoming sparse.  In the second
      case it increases the size of the label stack.

   The method described in this document has more benefits and fewer
   drawbacks that these three.


Authors' Addresses

   Jim Guichard
   Cisco Systems, Inc.

   Email:  jguichar@cisco.com


   Carlos Pignataro (editor)
   Cisco Systems, Inc.
   7200-12 Kit Creek Road
   Research Triangle Park, NC  27709
   US

   Email:  cpignata@cisco.com











Guichard, et al.        Expires December 14, 2013              [Page 10]


Internet-Draft                MPLS Metadata                    June 2013


   Simon Spraggs
   Cisco Systems, Inc.
   10 New Square Park
   Bedfont Lakes, Feltham  TW14 8HA
   United Kingdom

   Email:  sspraggs@cisco.com


   Stewart Bryant
   Cisco Systems, Inc.
   10 New Square Park
   Bedfont Lakes, Feltham  TW14 8HA
   United Kingdom

   Email:  stbryant@cisco.com



































Guichard, et al.        Expires December 14, 2013              [Page 11]