Network Working Group                                      O. Aboul-Magd
Request for Comments: 4115                                      S. Rabie
Category: Informational                                  Nortel Networks
                                                               July 2005
       A Differentiated Service Two-Rate, Three-Color Marker with
               Efficient Handling of in-Profile Traffic
Status of This Memo
   This memo provides information for the Internet community.  It does
   not specify an Internet standard of any kind.  Distribution of this
   memo is unlimited.
Copyright Notice
   Copyright (C) The Internet Society (2005).
IESG Note
   This RFC is not a candidate for any level of Internet Standard.  The
   IETF disclaims any knowledge of the fitness of this RFC for any
   purpose and in particular notes that the decision to publish is not
   based on IETF review for such things as security, congestion control,
   or inappropriate interaction with deployed protocols.  The RFC Editor
   has chosen to publish this document at its discretion.  Readers of
   this document should exercise caution in evaluating its value for
   implementation and deployment.  See RFC 3932 for more information.
Abstract
   This document describes a two-rate, three-color marker that has been
   in use for data services including Frame Relay services.  This marker
   can be used for metering per-flow traffic in the emerging IP and L2
   VPN services.  The marker defined here is different from previously
   defined markers in the handling of the in-profile traffic.
   Furthermore, this marker doesn't impose peak-rate shaping
   requirements on customer edge (CE) devices.
1.  Introduction
   The differentiated service defines a quality-of-service (QoS)
   architecture for the Internet [RFC2475].  Two integral components of
   this architecture are traffic metering and marking.  This document
   describes a two-rate, three-color metering/marker algorithm that is
Aboul-Magd & Rabie           Informational                      [Page 1]
RFC 4115        Efficient Handling of in-Profile Traffic       July 2005
   suitable for the differentiated service applications such as IP and
   L2 VPNs.  This algorithm has been in use for data services including
   Frame Relay Service.
   The metering/marker defined here is different from those in [RFC2697]
   and [RFC2698].  It is different from [RFC2697] in that it is a two-
   rate, three-color marker.  In contrast, [RFC2697] is a single-rate
   marker.  It is different from [RFC2698] in the way its parameters are
   defined, which allows a better handling of in-profile traffic for
   predominant service scenarios over a wider range of traffic
   parameters.
   Furthermore, the algorithm described here eliminates the need for the
   CE to shape its traffic to a certain peak information rate (PIR), as
   might be the case for the marker defined in [RFC2698] when the value
   for the peak burst size (PBS) is smaller than that for the committed
   burst size (CBS).
   The marker described here operates for both color-blind and color-
   aware modes, as defined in [RFC2698].
2.  Configuration
   The operation of the marker is described by two rate values.  The
   committed information rate (CIR) and the excess information rate
   (EIR).  CIR and EIR define the token generation rate of a token
   bucket with size that is equal to committed burst size (CBS) and
   excess burst size (EBS), respectively.
   The CBS and EBS are measured in bytes and must configure to be
   greater than the expected maximum length of the incoming PDU.  The
   CIR and EIR are both measured in bits/s.  The CIR and EIR can be set
   independently of each other.  Alternatively, the CIR and EIR can be
   linked together by defining a burst duration parameter, T, where
   T=CBS/CIR=EBS/EIR.
3.  Metering and Marking
   The behavior of the meter is defined in terms of its mode and two
   token buckets, C and E, with the rates, CIR and EIR, respectively,
   and maximum sizes CBS and EBS.
   The token buckets C and E are initially (at time 0) full; i.e., the
   token count Tc(0) = CBS and Te(0) = EBS.  Thereafter, the token count
   Tc is incremented by one CIR times per second (up to CBS), and the
   token count Te is incremented by one EIR times per second (up to
   EBS).
Aboul-Magd & Rabie           Informational                      [Page 2]
RFC 4115        Efficient Handling of in-Profile Traffic       July 2005
   In the color-aware operation, it is assumed that the algorithm can
   recognize the color of the incoming packet (green, yellow, or red).
   The color-aware operation of the metering is described below.
   When a green packet of size B arrives at time t, then
      o  if Tc(t)- B > 0, the packet is green, and Tc(t) is decremented
         by B; else
      o  if Te(t)- B > 0, the packet is yellow, and Te(t) is decremented
         by B; else
      o  the packet is red.
   When a yellow packet of size B arrives at time t, then
      o  if Te(t)- B > 0, the packet is yellow, and Te(t) is decremented
         by B; else
      o  the packet is red.
   Incoming red packets are not tested against any of the two token
   buckets and remain red.
   In the color-blind operation, the meter assumes that all incoming
   packets are green.  The operation of the meter is similar to that in
   the color-aware operation for green packets.
   The salient feature of the algorithm described above is that traffic
   within the defined CIR is colored green directly, without the need to
   pass additional conformance tests.  This feature is the main
   differentiator of this algorithm from that described in [RFC2698],
   where traffic is marked green after it passes two conformance tests
   (those for PIR and CIR).  In either color-blind or color-aware mode,
   the need to pass two conformance tests could result in packets being
   dropped at the PIR token bucket even though they are perfectly within
   their CIR (in-profile traffic).  Furthermore, in the color-aware mode
   of operation, the need to pass two conformance tests could make
   yellow traffic starve incoming in-profile green packets.
Aboul-Magd & Rabie           Informational                      [Page 3]
RFC 4115        Efficient Handling of in-Profile Traffic       July 2005
   The operation of the algorithm is illustrated in the flow chart
   below:
                   +---------------------------------+
                   |periodically every T sec.        |
                   | Tc(t+)=MIN(CBS, Tc(t-)+CIR*T)   |
                   | Te(t+)=MIN(EBS, Te(t-)+EIR*T)   |
                   +---------------------------------+
          Packet of size
              B arrives   /----------------\
         ---------------->|color-blind mode|
                          |       OR       |YES  +---------------+
                          |  green packet  |---->|packet is green|
                          |      AND       |     |Tc(t+)=Tc(t-)-B|
                          |    B <= Tc(t-) |     +---------------+
                          \----------------/
                                  |
                                  | NO
                                  v
                          /----------------\
                          |color-blind mode|
                          |       OR       |YES  +----------------+
                          | NOT red packet |---->|packet is yellow|
                          |      AND       |     |Te(t+)=Te(t-)-B |
                          |    B <= Te(t-) |     +----------------+
                          \----------------/
                                  |
                                  | NO
                                  v
                          +---------------+
                          |packet is red  |
                          +---------------+
              Figure 1: Traffic Metering/Marking Algorithm
   In Figure 1, we have X(t-) and X(t+) to indicate the value of a
   parameter X right before and right after time t.
Aboul-Magd & Rabie           Informational                      [Page 4]
RFC 4115        Efficient Handling of in-Profile Traffic       July 2005
4.  Service Scenario
   The described marker can be used to mark an IP packet stream in a
   service where different, decreasing levels of assurances (either
   absolute or relative) are given to packets that are green, yellow, or
   red.  For example, a service may discard all red packets because they
   exceeded the service rates, forward yellow packets as best effort,
   and forward green packets with low drop probability.  The marker
   could also be used for metering L2 VPN services such as the emerging
   Ethernet transport over IP networks.
5.  Security Considerations
   Security issues resulting from this document are similar to those
   mentioned in [RFC2697] and [RFC2698].
6.  Informative References
   [RFC2475] Blake, S., Black, D., Carlson, M., Davies, E., Wang, Z.,
             and W. Weiss, "An Architecture for Differentiated Service",
             RFC 2475, December 1998.
   [RFC2697] Heinanen, J. and R. Guerin, "A Single Rate Three Color
             Marker", RFC 2697, September 1999.
   [RFC2698] Heinanen, J. and R. Guerin, "A Two Rate Three Color
             Marker", RFC 2698, September 1999.
   [RFC3932] Alvestrand, H., "The IESG and RFC Editor Documents:
             Procedures", BCP 92, RFC 3932, October 2004.
Authors' Addresses
   Osama Aboul-Magd
   Nortel Networks
   3500 Carling Ave
   Ottawa, ON K2H8E9
   EMail: osama@nortel.com
   Sameh Rabie
   Nortel Networks
   3500 Carling Ave
   Ottawa, ON K2H8E9
   EMail: rabie@nortel.com
Aboul-Magd & Rabie           Informational                      [Page 5]
RFC 4115        Efficient Handling of in-Profile Traffic       July 2005
Full Copyright Statement
   Copyright (C) The Internet Society (2005).
   This document is subject to the rights, licenses and restrictions
   contained in BCP 78 and at www.rfc-editor.org/copyright.html, and
   except as set forth therein, the authors retain all their rights.
   This document and the information contained herein are provided on an
   "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
   OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET
   ENGINEERING TASK FORCE DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED,
   INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE
   INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
   WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
Intellectual Property
   The IETF takes no position regarding the validity or scope of any
   Intellectual Property Rights or other rights that might be claimed to
   pertain to the implementation or use of the technology described in
   this document or the extent to which any license under such rights
   might or might not be available; nor does it represent that it has
   made any independent effort to identify any such rights.  Information
   on the procedures with respect to rights in RFC documents can be
   found in BCP 78 and BCP 79.
   Copies of IPR disclosures made to the IETF Secretariat and any
   assurances of licenses to be made available, or the result of an
   attempt made to obtain a general license or permission for the use of
   such proprietary rights by implementers or users of this
   specification can be obtained from the IETF on-line IPR repository at
   http://www.ietf.org/ipr.
   The IETF invites any interested party to bring to its attention any
   copyrights, patents or patent applications, or other proprietary
   rights that may cover technology that may be required to implement
   this standard.  Please address the information to the IETF at ietf-
   ipr@ietf.org.
Acknowledgement
   Funding for the RFC Editor function is currently provided by the
   Internet Society.
Aboul-Magd & Rabie           Informational                      [Page 6]