Internet Engineering Task Force (IETF)                     D. Black, Ed.
Request for Comments: 6307                               EMC Corporation
Category: Standards Track                                 L. Dunbar, Ed.
ISSN: 2070-1721                                      Huawei Technologies
                                                                M. Roth
                                                               Infinera
                                                             R. Solomon
                                                       Orckit-Corrigent
                                                             April 2012


                Encapsulation Methods for Transport of
               Fibre Channel Traffic over MPLS Networks

Abstract

  A Fibre Channel pseudowire (PW) is used to carry Fibre Channel
  traffic over an MPLS network.  This enables service providers to take
  advantage of MPLS to offer "emulated" Fibre Channel services.  This
  document specifies the encapsulation of Fibre Channel traffic within
  a pseudowire.  It also specifies the common procedures for using a PW
  to provide a Fibre Channel service.

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 5741.

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















Black, et al.                Standards Track                    [Page 1]

RFC 6307                    FC Encapsulation                  April 2012


Copyright Notice

  Copyright (c) 2012 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
  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. Transparency ...............................................3
     1.2. Bandwidth Efficiency .......................................4
     1.3. Reliability ................................................5
     1.4. Conventions Used in This Document ..........................5
  2. Reference Model .................................................6
  3. Encapsulation ...................................................8
     3.1. The Control Word ..........................................10
     3.2. MTU Requirements ..........................................11
     3.3. Mapping of FC Traffic to PW Packets........................11
          3.3.1. FC Data Frames (PT=0) and FC Login Frames (PT=1) ...11
          3.3.2. FC Primitive Sequences and Primitive
                 Signals (PT=2) .....................................12
          3.3.3. FC PW Control Frames (PT=6) ........................14
     3.4. PW Failure Mapping ........................................15
  4. Signaling of FC Pseudowires ....................................15
  5. Timing Considerations ..........................................15
  6. Security Considerations ........................................17
  7. Applicability Statement ........................................17
  8. IANA Considerations ............................................18
  9. Acknowledgments ................................................19
  10. Normative References ..........................................19
  11. Informative References ........................................20











Black, et al.                Standards Track                    [Page 2]

RFC 6307                    FC Encapsulation                  April 2012


1.  Introduction

  Fibre Channel (FC) is a high-speed communications technology, used
  primarily for Storage Area Networks (SANs).  Within a single site
  (e.g., data center), an FC-based SAN connects servers to storage
  systems, and FC can be extended across sites.  When FC is extended
  across multiple sites, the most common usage is storage replication
  in support of recovery from disasters (e.g., flood or fire that takes
  a site out of operation).  This is particularly the case over longer
  distances where network latency results in unacceptable performance
  for a server whose storage is not at the same site.  Fibre Channel is
  standardized by the INternational Committee for Information
  Technology Standards (INCITS) Technical Committee T11 [T11], and
  multiple methods for encapsulating and transporting FC traffic over
  other networks have been developed [FC-BB-6].

  Fibre Channel Over TCP/IP (FCIP), as described in [RFC3821] and
  [FC-BB-6], interconnects otherwise isolated FC SANs over IP Networks.
  FCIP uses FC Frame Encapsulation [RFC3643] to encapsulate FC frames
  for tunneling over an IP-based network.  Since IP networks may drop
  or reorder packets, FCIP relies on TCP to retransmit dropped frames
  and restore the delivery order of reordered frames.  Due to possible
  delay variation and TCP timeouts, special timing mechanisms are
  required to ensure correct Fibre Channel operation over FCIP
  [FC-BB-6].

  MPLS networks can be provisioned and operated with very low loss
  rates and very low probability of reordering, making it possible to
  directly interconnect Fibre Channel ports over MPLS.  A Fibre Channel
  pseudowire (FC PW) is a method to transparently transport FC traffic
  over an MPLS network resulting in behavior similar to a pair of FC
  ports that are directly connected by a physical FC link.  The result
  is simpler control processing in comparison to FCIP.

  This document specifies the encapsulation of FC traffic into an MPLS
  pseudowire and related PW procedures to transport FC traffic over
  MPLS PWs.  The complete FC pseudowire specification consists of this
  document and the FC PW portion of the T11 [FC-BB-5/AM1] standard.
  The following subsections describe some of the requirements for
  transporting FC traffic over an MPLS network.

1.1.  Transparency

  Transparent extension of an FC link is a key requirement for
  transporting FC traffic over a PW.  This requires the FC PW to
  emulate an FC link between two FC ports, similar to the approach
  defined for FC over GFPT in [FC-BB-6].  GFPT is an Asynchronous
  Transparent Generic Framing Procedure specified by ITU-T; see



Black, et al.                Standards Track                    [Page 3]

RFC 6307                    FC Encapsulation                  April 2012


  [FC-BB-6] for details and reference to the ITU-T specifications.
  This results in transparent forwarding of FC traffic over the MPLS
  network from both the FC fabric and the network operator points of
  view.

  Transparency distinguishes the FC PW approach from FCIP.  An FC PW
  logically connects the FC port on the FC link attached to one end of
  the PW directly with the FC port on the far end of the FC link
  attached to the other end of the PW, whereas FCIP introduces FC
  B_Ports at both ends of the extended FC link; each FC B_Port is
  connected to an FC E_Port in an FC switch on the same side of the
  link extension.

1.2.  Bandwidth Efficiency

  The bandwidth allocated to a PW may be less than the rate of the
  attached FC port.  When there is no data exchange on a native FC
  link, Idle Primitive Signals are continuously exchanged between the
  two FC ports.  In order to improve the bandwidth efficiency across
  the MPLS network, it is necessary for the FC PW Provider Edge (PE) to
  suppress (or drop) the Idle Primitive Signals generated by its
  adjacent FC ports.  The far-end FC PW PE regenerates Idle Primitive
  Signals to send to its adjacent FC port as required; see
  [FC-BB-5/AM1].

  FC link control protocols require an FC port to continuously send the
  same FC Primitive Sequence [FC-FS-2] until a reply is received or
  some other event occurs.  To improve bandwidth efficiency, the FC PW
  PE encapsulates a subset of repeated FC Primitive Sequences to send
  across the WAN [FC-BB-5/AM1].  For example, in a sequence of
  identical received primitives, only every fourth primitive may be
  sent across the MPLS network.  Alternatively, a time-based approach
  may be used to send a copy of the repeated FC Primitive Sequence once
  every few milliseconds.  The far-end FC PW PE regenerates the FC link
  behavior by continuously sending the Primitive Sequence most recently
  received from the WAN until a new primitive signal, primitive
  sequence, or data frame is received from the WAN.

  The sending FC PW PE may unilaterally choose any convenient subset
  for sending the same FC Primitive Sequence.  This is acceptable
  because the receiving FC PW PE generates a continuous stream of the
  most recently received FC Primitive Sequence on the outgoing native
  FC link, independent of the arrival rate of that FC Primitive
  Sequence from the WAN.  In practice, a 10:1 reduction in FC Primitive
  Sequence transmission rate achieves 90% of the bandwidth benefits
  without loss of FC functionality, and sending a copy every few
  milliseconds does not pose a serious risk of exceeding the timeouts
  specified in Section 5 below.



Black, et al.                Standards Track                    [Page 4]

RFC 6307                    FC Encapsulation                  April 2012


  These bandwidth-efficiency techniques may cause changes in the FC
  traffic that traverses an FC PW (e.g., number of Idle Primitive
  Signals or number of identical Primitive Sequences), but the far-end
  FC PW PE's regeneration of FC link behavior on the attached FC port
  is transparent to the FC ports connected to each PW PE.

1.3.  Reliability

  Fibre Channel does not employ a native frame retransmission protocol
  and treats most frame delivery failures as errors.  FC SAN traffic
  requires a very low frame loss rate because the typical result of a
  failure to deliver a frame is an I/O operation failure.  Recovery
  from such I/O failures involves I/O operation retries after what may
  be a significant delay (30-second and 60-second timeouts are common).
  In addition, such retries are likely to be logged as errors
  indicating possible problems with FC equipment or cables.  Hence,
  drops, errors, and discards of FC frames must be very rare for an FC
  PW.

  FC SAN implementations have limited tolerance for frame reordering.
  Any reordering affecting more than a few frames within a single
  higher-level operation (e.g., a read or write I/O) is usually treated
  as an error by the destination FC port, resulting in discards of the
  frames involved; some deployed FC implementations treat all such
  within-operation frame reordering as errors that result in frame
  discards.  As a result, FC frame reordering must be minimized for an
  FC PW.

  The FC PW does not compensate for frame drops, discards, or
  reordering.  The MPLS network that hosts the FC PW is expected to be
  designed and operated in a fashion that makes such events very rare.

  In contrast to the Time to Live (TTL) field in an IP packet, FC uses
  a constant delivery timeout value (R_A_TOV) for which 10 seconds is
  the default.  Each FC frame must be delivered or discarded within
  that timeout period after it is sent; see Section 5.

1.4.  Conventions Used in This Document

  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].









Black, et al.                Standards Track                    [Page 5]

RFC 6307                    FC Encapsulation                  April 2012


2.  Reference Model

  An FC PW extends a native FC link over an MPLS network.  This
  document specifies the PW encapsulation for FC.  Figure 1 describes
  the reference models (derived from [RFC3985]) that support the FC PW.
  FC traffic is received by PE1's FC attachment channel, encapsulated
  at PE1, transported across MPLS network, decapsulated at PE2, and
  transmitted onward via the PE2's FC attachment channel.  This
  document assumes that a pseudowire can be provisioned statically or
  via a signaling protocol as defined in [RFC4447].

          |<-------------- Emulated Service ----------------->|
          |                                                   |
          |          |<------- Pseudowire -------->|          |
          |          |                             |          |
          |          |    |<-- MPLS Tunnel -->|    |          |
          |          V    V                   V    V          |
          V   AC     +----+                   +----+    AC    V
    +-----+    |     | PE1|===================| PE2|     |    +-----+
    |     |----------|............PW1..............|----------|     |
    | CE1 |    |     |    |                   |    |     |    | CE2 |
    |     |----------|............PW2..............|----------|     |
    +-----+  ^ |     |    |===================|    |     | ^  +-----+
          ^  |       +----+                   +----+     | |  ^
          |  |   Provider Edge 1          Provider Edge 2  |  |
          |  |                                             |  |
    Customer |                                             | Customer
    Edge 1   |                                             | Edge 2
             |                                             |
             |                                             |
      Native FC service                             Native FC service

          Figure 1 - PWE3 FC Interface Reference Configuration


















Black, et al.                Standards Track                    [Page 6]

RFC 6307                    FC Encapsulation                  April 2012


  The following reference model describes the termination point of each
  end of the PW within the PE:

              +-----------------------------------+
              |                PE                 |
      +---+   +-+  +-----+  +------+  +------+  +-+
      |   |   |P|  |     |  |PW ter|  | MPLS |  |P|
      |   |<==|h|<=| NSP |<=|minati|<=|Tunnel|<=|h|<== From network
      |   |   |y|  |     |  |on    |  |      |  |y|
      | C |   +-+  +-----+  +------+  +------+  +-+
      | E |   |                                   |
      |   |   +-+  +-----+  +------+  +------+  +-+
      |   |   |P|  |     |  |PW ter|  | MPLS |  |P|
      |   |==>|h|=>| NSP |=>|minati|=>|Tunnel|=>|h|==> To network
      |   |   |y|  |     |  |on    |  |      |  |y|
      +---+   +-+  +-----+  +------+  +------+  +-+
              |                                   |
              +-----------------------------------+

              Figure 2 - PW Reference Diagram

  The Native Service Processing (NSP) function includes the following
  functionality:

  o  Idle Suppression: any FC Idle Primitive Signals received from the
     source PE's attached FC port are suppressed and regenerated at the
     destination PE to send on its attached FC port when there is no
     other FC traffic to send;

  o  FC Primitive Sequence Reduction: a subset of repetitive FC
     Primitive Sequences received from the attached FC port at the
     source PE is selected for WAN transmission, with the destination
     PE sending the FC Primitive Sequence most recently received from
     the WAN on the destination PE's attached FC port continuously
     until a new packet is received from the WAN; and

  o  Flow Control: the Alternate Simple Flow Control (ASFC) protocol is
     used for buffer management in concert with the peer PW PE's NSP
     function so that FC traffic is not dropped.  ASFC is a simple
     pause/resume protocol that allows operation repetition; the
     receiver responds to the first pause or resume operation in an
     identical sequence of operations and ignores the rest of the
     sequence.

  The NSP flow control functionality is required to extend FC's credit-
  based flow control to address situations where the number of buffer
  credits available to an FC link is insufficient to utilize the
  available bandwidth over the additional distance and latency



Black, et al.                Standards Track                    [Page 7]

RFC 6307                    FC Encapsulation                  April 2012


  represented by the FC pseudowire.  The NSPs avoid this problem by
  inserting ASFC into FC's link flow control used on the attached FC
  ports; see [FC-BB-5/AM1].

  In contrast, Idle Suppression and FC Primitive Sequence Reduction are
  bandwidth optimizations that are included in the NSP for clarity in
  this document.  Analogous optimizations are not treated as part of
  the NSP by other pseudowires (e.g., Asynchronous Transfer Mode (ATM)
  idle frame suppression is not considered to be an NSP function by
  [RFC4717]).

  The NSP function is specified in detail by [FC-BB-5/AM1].

3.  Encapsulation

  This specification provides port-to-port transport of FC-encapsulated
  traffic.  There are a number of port types defined by Fibre Channel,
  including:

  o  N_port:  a port on the node (e.g., host or storage device) used
     with both FC-P2P (Point to Point) or FC-SW (switched fabric)
     topologies.  Also known as a Node port.

  o  NL_port:  a port on the node used with an FC-AL (Arbitrated Loop)
     topology.  Also known as a Node Loop port.

  o  F_port:  a port on the switch that connects to a node point- to-
     point (i.e., connects to an N_port).  Also known as a Fabric port.
     An F_port is not loop capable.

  o  FL_port:  a port on the switch that connects to an FC-AL loop
     (i.e., to NL_ports).  Also known as a Fabric Loop port.

  o  E_port:  a port used to connect two Fibre Channel switches.  Also
     known as an Expansion port.  When E_ports between two switches are
     connected to form a link, that link is referred to as an inter-
     switch link (ISL).

  Among the port types listed above, only the following FC connections
  (as specified in [FC-BB-5/AM1]) are supported by an FC PW over MPLS:

  o  N_Port to N_Port, established by an FC PLOGI (Port Login)
     operation

  o  N_Port to F_Port, established by an FC FLOGI (Fabric Login)
     operation





Black, et al.                Standards Track                    [Page 8]

RFC 6307                    FC Encapsulation                  April 2012


  o  E_Port to E_Port, established by an FC ELP (Exchange Link
     Parameters) operation

  FC traffic flowing over an FC PW is subdivided into four payload
  types (PTs) that are encoded in the PW Control Word (see Section
  3.1):

  1.  FC login traffic (PT = 1): FC login operations and responses that
      establish connections between FC ports.  The three FC login
      operations are PLOGI, FLOGI, and ELP.  These operations and their
      responses may require the NSP to allocate buffer resources.  See
      the specification of Login Exchange Monitors in [FC-BB-5/AM1].

  2.  FC data traffic (PT = 0): All FC frames other than those involved
      in an FC login operation.

  3.  FC Primitive Sequences and Signals (PT = 2): Native FC link
      control operations; 4-character primitive sequences and signals
      that are not encapsulated in FC frames.  See [FC-BB-5/AM1] and
      [FC-FS-2].

  4.  FC PW Control (PT = 6): FC PW control operations exchanged only
      between the endpoints of the PW.  FC PW control operations are
      used for ASFC flow control, ping (e.g., for round-trip latency
      measurement), and reporting native FC link errors.  See
      [FC-BB-5/AM1].

  This FC PW specification is limited to use with FC service classes 2,
  3, and F; see [FC-FS-2].  Other FC service classes (e.g., 1, 4, and
  6) MUST NOT be used with an FC PW.  Numbered FC service classes are
  used for end-to-end FC traffic, whereas service class F is used for
  inter-switch traffic in an FC switched fabric.

  This FC PW specification is limited to native FC attachment links
  that employ an 8b/10b transmission code (see [FC-FS-2]).  The
  protocol specified in this document converts a received 10b code to
  its 8b counterpart for PW encapsulation and hence does not support
  attached FC links that use a 64b/66b transmission code (e.g., 10GFC
  and 16GFC); such links MUST NOT be attached to an FC PW PE unless
  their link speed can be negotiated to one that uses 8b/10b encoding.
  If an invalid 10b code that cannot be converted to an 8b code is
  received from an FC link, the PE sends an FC PW control frame to
  report the error (see [FC-BB-5/AM1]).








Black, et al.                Standards Track                    [Page 9]

RFC 6307                    FC Encapsulation                  April 2012


3.1.  The Control Word

  The Generic PW Control Word, as defined in "Pseudowire Emulation
  Edge-to-Edge (PWE3) Control Word for Use over an MPLS PSN" [RFC4385],
  MUST be used for FC PW to facilitate the transport of short packets
  (by setting the Length field as detailed below) and convey the flag
  bits defined below.  The structure of the Control Word for the FC PW
  is as follows:

                          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
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |0 0 0 0| PT  |X|0 0|  Length   |     Sequence Number           |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

                    Figure 3 - Control Word Structure

  The first four bits of the PW Control Word MUST be set to 0 by the
  ingress PE to indicate PW data.

  Three of the four flag bits are used to convey the Payload Type (PT)
  indication.  The 3-bit binary value in this field identifies the
  payload type carried by a PW packet.  The following types are
  defined:

           PT = 0: FC data frame.

           PT = 1: FC login frame.

           PT = 2: FC Primitive Sequence(s) and/or Primitive Signal(s).

           PT = 6: FC PW control frame (refer to [FC-BB-5/AM1] for
           usage).

  Packets with other values in the PT field are not valid for the FC PW
  and MUST be discarded by the receiving FC PW PE.

  The X flag bit is not used by this version of the protocol.  It
  SHOULD be set to zero by the sender and MUST be ignored by the
  receiver.

  The fragmentation bits (bits 8-9) are not used by the FC PW protocol.
  These bits may be used in the future for FC-specific indications as
  defined in [RFC4385].  The fragmentation bits SHOULD be set to zero
  by the ingress PE and MUST be ignored by the egress PE.






Black, et al.                Standards Track                   [Page 10]

RFC 6307                    FC Encapsulation                  April 2012


  The Length field enables recovery of the original pseudowire packet
  when a short packet is padded to the minimum 64-octet packet size
  required for Ethernet; see [RFC4385].  The Length field MUST be used
  for packets shorter than 64 octets, MUST be set to zero for longer
  packets, and MUST be processed according to the rules specified in
  [RFC4385].

  The sequence number is not used for the FC PW; it MUST be set to 0 by
  the ingress PE and MUST be ignored by the egress PE.

3.2.  MTU Requirements

  The MPLS network MUST be able to transport the largest Fibre Channel
  frame after encapsulation, including the overhead associated with the
  encapsulation.  The maximum FC frame size is 2164 octets without PW
  and MPLS labels (refer to Figure 4); this maximum size is a constant
  value that is required for all FC implementations [FC-FS-2].  The
  MPLS network SHOULD accommodate frames of up to 2500 octets in order
  to support possible future increases in the maximum FC frame size.

  Fragmentation, as described in [RFC4623], SHALL NOT be used for an FC
  PW; therefore, the network MUST be configured with a minimum MTU that
  is sufficient to transport the largest encapsulated FC frame.

3.3.  Mapping of FC Traffic to PW Packets

  FC frames, Primitive Sequences, and Primitive Signals are transported
  over the PW.  All packet types are carried over a single PW.  In
  addition to the PW Control Word, an FC Encapsulation Header is
  included in the PW packet.  This FC Encapsulation Header is not used
  in this version of the protocol; it SHOULD be set to zero by the
  sender and MUST be ignored by the receiver.

3.3.1.  FC Data Frames (PT=0) and FC Login Frames (PT=1)

  FC data frames and FC login frames share a common encapsulation
  format, except that the PT field in the FC PW Control Word is set to
  0 for data frames and is set to 1 for login frames.  An FC login
  frame contains an FC PLOGI, FLOGI, or ELP operation or response that
  requires special processing by the NSP in support of flow control;
  see [FC-BB-5/AM1].

  Each FC data frame or login frame is mapped to a PW packet, including
  the Start Of Frame (SOF) delimiter, frame header, Cyclic Redundancy
  Check (CRC) field, and the End Of Frame (EOF) delimiter, as shown in
  Figure 4.





Black, et al.                Standards Track                   [Page 11]

RFC 6307                    FC Encapsulation                  April 2012


                          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
     +---------------------------------------------------------------+
     |                    FC PW Control Word                         |
     +---------------------------------------------------------------+
     |                  FC Encapsulation Header                      |
     +---------------+-----------------------------------------------+
     |     SOF Code  |             Reserved                          |
     +---------------+-----------------------------------------------+
     |                                                               |
     +-----                        FC Frame                      ----+
     |                                                               |
     +---------------------------------------------------------------+
     |                              CRC                              |
     +---------------+-----------------------------------------------+
     |     EOF Code  |                Reserved                       |
     +---------------+-----------------------------------------------+

     Figure 4 - FC Frame (SOF/Data/CRC/EOF) Encapsulation in PW Packet

  The SOF and EOF frame delimiters are each encoded into a single octet
  as specified in [RFC3643], except that the codes for delimiters that
  apply only to FC service class 4 (SOFi4, SOFc4, SOFn4, EOFdt, EOFdti,
  EOFrt, and EOFrti -- see [FC-FS-2]) MUST NOT be used.

  The CRC in the frame is obtained directly from the FC attachment
  channel, so that the PW PE is not required to recalculate the CRC or
  to check the CRC in the received frame.  The CRC will be checked by
  the FC port that receives the frame, ensuring that coverage is
  provided for data errors that occur between the PW endpoints.  This
  CRC behavior differs from the Frame Check Sequence (FCS) retention
  technique for PWs defined in [RFC4720], which states that "as usual,
  the FCS MUST be examined at the ingress PE, and errored frames MUST
  be discarded".

3.3.2.  FC Primitive Sequences and Primitive Signals (PT=2)

  FC Primitive Sequences and Primitive Signals are FC Ordered Sets.  On
  an 8b/10b-coded FC link, an Ordered Set consists of four 10b
  characters, starting with the K28.5 character, followed by three
  Dxx.y data characters.  All FC Ordered Sets start with a K28.5
  control character, but the three following Dxx.y data characters
  differ depending on the Ordered Set.  A Kxx.y control character has a
  different 10b code from the corresponding Dxx.y data character but
  uses the same 8b code (e.g., K28.5 and D28.5 both use the 8b code
  0xBC).  Here are two examples of Ordered Sets:





Black, et al.                Standards Track                   [Page 12]

RFC 6307                    FC Encapsulation                  April 2012


  o  Idle (IDLE) is K28.5 - D21.4 - D21.5 - D21.5.  This FC Primitive
     Signal is sent when the FC link is idle; it is suppressed by the
     FC PW NSP and not sent over the WAN.

  o  Link Reset Response (LRR) is K28.5 - D21.1 - D31.5 - D9.2.  This
     FC Primitive Sequence is used as part of FC link initialization
     and recovery.

  Each Ordered Set is encapsulated in a PW packet containing the
  encoded K28.5 control character [FC-BB-5/AM1], followed by three
  encoded data characters, as shown in Figure 5.

                          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
     +---------------------------------------------------------------+
     |                    FC PW Control Word                         |
     +---------------------------------------------------------------+
     |                  FC Encapsulation Header                      |
     +---------------+---------------+---------------+---------------+
     |     K28.5     |     Dxx.y     |     Dxx.y     |     Dxx.y     |
     +---------------+---------------+---------------+---------------+
     |                                                               |
     +----                                                       ----+
     |                                                               |
     +---------------+---------------+---------------+---------------+
     |     K28.5     |     Dxx.y     |     Dxx.y     |     Dxx.y     |
     +---------------+---------------+---------------+---------------+

            Figure 5 - FC Ordered Sets Encapsulation in PW Packet

  The K28.5 10b control character received from the PE's attached FC
  link is encoded for the FC PW as its 8b counterpart (0xBC).  Because
  the same 8b value (0xBC) is used to encode a D28.5 data word, the
  receiving FC PW PE:

  o  MUST check for presence of an 8b K28.5 value (0xBC) at the start
     of each Ordered Set (see Figure 5) and MUST send that value as a
     10b K28.5 character on the attached FC link.

  o  MUST send the following three Dxx.y 8b values as Dxx.y 10b
     characters on the attached FC link and MUST NOT send any of these
     Dxx.y 8b values as 10b Kxx.y characters on the attached FC link.

  A PW packet may contain one or more encoded FC Ordered Sets
  [FC-BB-5/AM1].  The Length field in the FC PW Control Word is used to
  indicate the packet length when the PW packet contains multiple
  Ordered Sets.  For this reason, FC PW packets that contain FC Ordered




Black, et al.                Standards Track                   [Page 13]

RFC 6307                    FC Encapsulation                  April 2012


  Sets MUST NOT be larger than 60 octets (8 octets of header words plus
  at most 13 Ordered Sets), in order to ensure that the Length field
  contains a non-zero value (see [RFC4385]).

  Idle Primitive Signals could be carried over the PW in the same
  manner as Primitive Sequences.  However, [FC-BB-5/AM1] requires that
  Idle Primitive Signals be dropped by the Ingress PE and regenerated
  by the egress PE in order to reduce bandwidth consumption (see
  [FC-BB-5/AM1] for further details).

  The egress PE extracts the Primitive Sequence or Primitive Signal
  from the received PW packet.  For a Primitive Sequence, the PE
  continues transmitting the same FC Ordered Set to its attached FC
  port until an FC frame or another Ordered Set is received over the
  PW; see Section 1.2 above for discussion of ingress PE transmission
  behavior for Primitive Sequences.  A Primitive Signal is sent once,
  except that Idle Primitive Signals are sent continuously when there
  is nothing else to send.

3.3.3.  FC PW Control Frames (PT=6)

  FC PW control frames are transported over the PW by encapsulating
  each frame in a PW packet with PT=6 in the Control Word.  FC PW
  control frame payloads are generated and terminated by the
  corresponding FC entity.  FC PW control frames are used for FC PW
  flow control (ASFC), ping, and transmission of error indications.
  [FC-BB-5/AM1] specifies the generation and processing of FC PW
  control frames.  FC PW control frames are always shorter than 64
  octets, and hence the Length field in the FC Control Word indicates
  their length.

                          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
     +---------------------------------------------------------------+
     |                    FC PW Control Word                         |
     +---------------------------------------------------------------+
     |                  FC Encapsulation Header                      |
     +---------------------------------------------------------------+
     |                                                               |
     +-----              FC PW Control Frame                     ----+
     |                                                               |
     +---------------------------------------------------------------+

            Figure 6 - FC PW Control Frame Encapsulation in PW Packet







Black, et al.                Standards Track                   [Page 14]

RFC 6307                    FC Encapsulation                  April 2012


3.4.  PW Failure Mapping

  PW failures are detected through PW signaling failure, PW status
  notifications as defined in [RFC4447], or PW Operations,
  Administration, and Maintenance (OAM) mechanisms and MUST be mapped
  to emulated signal failure indications.  Sending the FC link failure
  indication to its attached FC link is performed by the NSP, as
  defined by [FC-BB-5/AM1].

4.  Signaling of FC Pseudowires

  [RFC4447] specifies the use of the MPLS Label Distribution Protocol
  (LDP) as a protocol for setting up and maintaining pseudowires.  This
  section describes the use of specific fields and error codes used to
  control FC PW.

  The PW Type field in the PWid Forwarding Equivalence Class (FEC)
  element and PW generalized ID FEC elements MUST be set to the "FC
  Port Mode" value in Section 8.

  The Control Word is REQUIRED for FC pseudowires.  Therefore, the
  C-Bit in the PWid FEC element and PW generalized ID FEC elements MUST
  be set.  If the C-Bit is not set, the pseudowire MUST NOT be
  established, and a Label Release MUST be sent with an "Illegal C-Bit"
  status code [RFC4447].

  The Fragmentation Indicator (Parameter ID = 0x09) is specified in
  [RFC4446], and its usage is defined in [RFC4623].  Since
  fragmentation is not used in FC PW, the fragmentation indicator
  parameter MUST be omitted from the Interface Parameter Sub-TLV.

  The Interface MTU Parameter (Parameter ID = 0x01) is specified in
  [RFC4447].  Since all FC interfaces have the same MTU, this parameter
  MUST be omitted from the Interface Parameter Sub-TLV.

  The FCS Retention Indicator (Parameter ID = 0x0A) is specified in
  [RFC4720].  Since the CRC treatment defined in this document differs
  from one that is specified in [RFC4720], this parameter MUST be
  omitted from the Interface Parameter Sub-TLV.

5.  Timing Considerations

  Correct Fibre Channel link operation requires that the FC link
  latency between CE1 and CE2 (refer to Figure 1) be:

  o  no more than one-half of the R_T_TOV (Receiver Transmitter Timeout
     Value, default value: 100 milliseconds) of the attached devices
     for Primitive Sequences;



Black, et al.                Standards Track                   [Page 15]

RFC 6307                    FC Encapsulation                  April 2012


  o  no more than one-half of the E_D_TOV (Error Detect Timeout Value,
     default value: 2 seconds) of the attached devices for frames; and

  o  within the R_A_TOV (Resource Allocation Timeout Value, default
     value: 10 seconds) of the attached fabric(s), if any.  The FC
     standards require that the E_D_TOV value for each FC link be set
     so that the R_A_TOV value for the fabric is respected when the
     worst-case latency occurs for each link (see [FC-FS-2]).

  An FC PW MUST adhere to these three timing requirements and MUST NOT
  be used in environments where high or variable latency may cause
  these requirements to be violated.

  These three timeout values are ordered (R_T_TOV < E_D_TOV < R_A_TOV),
  so adherence to one-half of R_T_TOV for all FC PW traffic is
  sufficient.  See [FC-FS-2] for definitions of the FC timeout values.

  The R_T_TOV is used by the FC link initialization protocol.  If an FC
  PW's latency exceeds one-half R_T_TOV, initialization of the FC link
  that is encapsulated by the FC PW may fail, leaving that FC link in a
  non-operational state.

  The E_D_TOV is used to detect failures of operational FC links.  If
  an FC PW's latency exceeds the one-half E_D_TOV requirement, the FC
  link that is encapsulated by the FC PW may fail.  The usual FC
  response to such a link failure is to attempt to recover the FC link
  by initializing it.  That initialization will also fail if the FC PW
  latency exceeds one-half R_T_TOV (a tighter requirement).

  The R_A_TOV is used to determine when FC communication resources
  (e.g., values that identify FC frames) may be reused.  If an FC PW's
  violation of the one-half E_D_TOV requirement is sufficient to also
  cause the FC fabric to violate the R_A_TOV requirement, then FC reuse
  of frame identification values after an R_A_TOV timeout may result in
  multiple FC frames with the same identification values, causing
  incorrect Fibre Channel operation.  For example, if two such frames
  are swapped between I/O operations, the result may corrupt data in
  the I/O operations.

  The PING and PING_ACK FC PW control frames defined in Section 6.4.7
  of [FC-BB-5/AM1] SHOULD be used to measure the current FC pseudowire
  latency between the Customer Edge (CE) devices.  If the measured
  latency violates any of the timing requirements, then the FC PW PE
  MUST generate a WAN Down event as specified in [FC-BB-5/AM1].

  The WAN Down event causes the PE to continuously send NOS (an FC
  Primitive Sequence) on the native FC link to the FC port at the other
  end of that link (typically an E_Port on a switch in this case).



Black, et al.                Standards Track                   [Page 16]

RFC 6307                    FC Encapsulation                  April 2012


  This immediately causes the FC link that is carried by the PW to
  become non-operational, halting transmission of FC traffic.  However,
  it is not necessary to tear down the pseudowire itself in this
  situation (e.g., destroy the MPLS path set up by LDP).

  The Transparent FC-BB initialization state machine in [FC-BB-5/AM1]
  specifies the protocol used to attempt to recover from a WAN Down
  event (i.e., bring the WAN back up).  If that protocol brings the WAN
  back up, FC traffic will resume and the standard FC link recovery
  protocol will bring the encapsulated FC link back up.  If the
  previous pseudowire was destroyed, attempts will be made to
  re-establish the path via LDP as part of recovering from the WAN Down
  event.  If the PW round-trip latency remains above R_T_TOV, the
  initialization protocol for the FC PW will repeatedly time out in
  attempting to recover from the WAN Down event, preventing recovery of
  the FC link carried by the PW; see [FC-BB-5/AM1].

6.  Security Considerations

  The FC PW is an MPLS pseudowire; for MPLS pseudowire security
  considerations, see the security considerations sections of [RFC3985]
  and [RFC4385].

  The protocols used to implement security in a Fibre Channel fabric
  are defined in [FC-SP].  These protocols operate at higher layers of
  the FC hierarchy and are transparent to the FC PW.

  The FC timing requirements (see Section 5) create an exposure of the
  FC PW to inserted latency.  Injection of latency sufficient to cause
  the round-trip time for an FC PW to exceed R_T_TOV (default: 100 ms)
  may cause the FC PW to fail in an active fashion because the FC link
  initialization protocol repeatedly times out.  OAM functionality for
  deployed FC PWs SHOULD monitor for persistence of this situation and
  respond accordingly (e.g., shut down the FC PW in order to avoid
  wasting WAN bandwidth on an FC PW whose FC link cannot be
  successfully initialized due to excessive latency).

7.  Applicability Statement

  FC PW allows the transparent transport of FC traffic between Fibre
  Channel ports while saving network bandwidth by removing FC Idle
  Primitive Signals and reducing the number of FC Primitive Sequences.

  o  The pair of CE devices operates as if they were directly connected
     by an FC link.  In particular, they react to Primitive Sequences
     on their local FC links as specified by the FC standards.





Black, et al.                Standards Track                   [Page 17]

RFC 6307                    FC Encapsulation                  April 2012


  o  The FC PW carries only FC data frames, FC Primitive Signals, and a
     subset of the copies of an FC Primitive Sequence.  Idle Primitive
     Signals are suppressed, and long streams of the same Primitive
     Sequence are reduced over the PW, thus saving bandwidth.

  o  The PW PE MUST generate Idle Primitive Signals to the attached FC
     link when there is no other traffic to transmit on the attached FC
     link [FC-FS-2].

  o  The PW PE MUST send Primitive Sequences continuously to the
     attached FC port, as required by the FC standards [FC-FS-2].

  FC PW traffic should only traverse MPLS networks that are provisioned
  based on traffic engineering to provide dedicated bandwidth for FC PW
  traffic.  The MPLS network should enforce ingress traffic policing so
  that delivery of FC PW traffic can be assured.  To extend FC across a
  network that does not satisfy these requirements, FCIP SHOULD be used
  instead of an FC PW (see [RFC3821] and [FC-BB-6]).

  This document does not provide any mechanisms for protecting an FC PW
  against network outages.  As a consequence, resilience of the
  emulated FC service to such outages is dependent upon the underlying
  MPLS network, which should be protected against failures.  When a
  network outage is detected, the PE SHOULD use a WAN Down event (as
  specified in [FC-BB-5/AM1]) to convey the PW status to the CE and
  enable faster outage handling.

8.  IANA Considerations

  IANA has assigned a new MPLS Pseudowire (PW) type as follows:

     PW type      Description           Reference
     --------     --------------        ----------
     0x001F       FC Port Mode          RFC 6307

  IANA has reserved the following Pseudowire Interface Parameters
  Sub-TLV Types.  These Sub-TLV types were used for the FC PW Selective
  Retransmission protocol, which the PWE3 working group has decided to
  eliminate.  This action prevents future use of these values for other
  purposes, as there is at least one implementation of the Selective
  Retransmission protocol that has been deployed.

     Parameter  ID Length  Description  Reference
     ---------  ---------  -----------  ---------
     0x12                  Reserved     RFC 6307
     0x13                  Reserved     RFC 6307
     0x14                  Reserved     RFC 6307
     0x15                  Reserved     RFC 6307



Black, et al.                Standards Track                   [Page 18]

RFC 6307                    FC Encapsulation                  April 2012


9.  Acknowledgments

  Previous versions of this document were authored by Moran Roth, Ronen
  Solomon, and Munefumi Tsurusawa; their efforts and contributions are
  gratefully acknowledged.  The authors would like to thank Stewart
  Bryant, Elwyn Davies, Steve Hanna, Dave Peterson, Yaakov Stein,
  Alexander Vainshtein, and the members of the IESG for helpful
  comments on this document.

  The protocol specified in this document is intended to be used in
  conjunction with the Fibre Channel pseudowire portion of the FC-BB-5
  Amendment 1 specification developed by INCITS Technical Committee
  T11.  The authors would like to thank the members of both the IETF
  and T11 organizations who have supported and contributed to this
  work.

10.  Normative References

  [FC-BB-5/AM1]  "Fibre Channel - Backbone-5 / Amendment 1", INCITS
                 462-2010/AM 1-2012, June 2012.

  [FC-FS-2]      "Fibre Channel - Framing and Signaling-2 (FC-FS-2)",
                 ANSI INCITS 424:2007, August 2007.

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

  [RFC3643]      Weber, R., Rajagopal, M., Travostino, F., O'Donnell,
                 M., Monia, C., and M. Merhar, "Fibre Channel (FC)
                 Frame Encapsulation", RFC 3643, December 2003.

  [RFC3985]      Bryant, S., Ed., and P. Pate, Ed., "Pseudo Wire
                 Emulation Edge-to-Edge (PWE3) Architecture", RFC 3985,
                 March 2005.

  [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.

  [RFC4446]      Martini, L., "IANA Allocations for Pseudowire Edge to
                 Edge Emulation (PWE3)", BCP 116, RFC 4446, April 2006.

  [RFC4447]      Martini, L., Ed., Rosen, E., El-Aawar, N., Smith, T.,
                 and G. Heron, "Pseudowire Setup and Maintenance Using
                 the Label Distribution Protocol (LDP)", RFC 4447,
                 April 2006.




Black, et al.                Standards Track                   [Page 19]

RFC 6307                    FC Encapsulation                  April 2012


  [RFC4623]      Malis, A. and M. Townsley, "Pseudowire Emulation Edge-
                 to-Edge (PWE3) Fragmentation and Reassembly", RFC
                 4623, August 2006.

  [RFC4720]      Malis, A., Allan, D., and N. Del Regno, "Pseudowire
                 Emulation Edge-to-Edge (PWE3) Frame Check Sequence
                 Retention", RFC 4720, November 2006.

11.  Informative References

  [FC-BB-6]      "Fibre Channel Backbone-6" (FC-BB-6), T11 Project
                 2159-D, Rev 1.04, Work in Progress, January 2012.

  [FC-SP]        "Fibre Channel - Security Protocols" (FC-SP), ANSI
                 INCITS 426:2007, February 2007.

  [RFC3821]      Rajagopal, M., Rodriguez, E., and R. Weber, "Fibre
                 Channel Over TCP/IP (FCIP)", RFC 3821, July 2004.

  [RFC4717]      Martini, L., Jayakumar, J., Bocci, M., El-Aawar, N.,
                 Brayley, J., and G. Koleyni, "Encapsulation Methods
                 for Transport of Asynchronous Transfer Mode (ATM) over
                 MPLS Networks", RFC 4717, December 2006.

  [T11]          INCITS Technical Committee T11, http://www.t11.org,
                 January 2011.

























Black, et al.                Standards Track                   [Page 20]

RFC 6307                    FC Encapsulation                  April 2012


Authors' Addresses

  David L. Black (editor)
  EMC Corporation
  176 South Street
  Hopkinton, MA 01748
  USA
  Phone: +1 (508) 293-7953
  EMail: [email protected]

  Linda Dunbar (editor)
  Huawei Technologies
  1700 Alma Drive, Suite 500
  Plano, TX 75075
  USA
  Phone: +1 (972) 543-5849
  EMail: [email protected]

  Moran Roth
  Infinera Corporation
  169 Java Drive
  Sunnyvale, CA 94089
  USA
  Phone: (408) 572-5200
  EMail: [email protected]

  Ronen Solomon
  Orckit-Corrigent Systems
  126, Yigal Alon st.
  Tel Aviv
  Israel
  Phone: +972-3-6945316
  EMail: [email protected]


















Black, et al.                Standards Track                   [Page 21]