The present description relates to the field of mapping data from a local area network to a wide area fiber optic network, and, in particular, to performing buffering when framing high speed LAN packets onto a subrate optical channel.
With the advent of digital optical communications and newer higher speed electrical communications, different communication systems with different frame structures and different data rates are interconnected. This requires two kinds of buffering. A first buffer is used to hold incoming packets of one format so that they can be converted to the outgoing format. This buffer is also used adapt the instantaneous rate difference between this device and the receiving device of these packets. Another buffer is used to hold packets of data that are coming in at one rate until it can be transmitted as packets of data going out at another rate.
Fibre Channel has become popular for SANs (Storage Area Networks) and is defined as an ANSI (American National Standards Institute) communications standard for both twisted pair copper wire and for optical fiber. Due to its high speed and flexibility it has also become popular for other data communications applications beyond SANs. Sonet (Synchronous Optical Networking defined by Telcordia) and SDH (Synchronous Digital Hierarchy defined by the ITU (International Telecommunication Union)) are popular standards for long distance optical fiber data and telephone communications.
When clients on a Fibre Channel network send data over a WAN (Wide Area Network), using, for example SONET or SDH a transparent mapping approach is typically used. In order to transition the Fibre Channel packets to the WAN format, Fibre Channel offers a credit-based flow control. This is at the data link layer (FC1) which implements the 8B/10B mapping of the data. The credit-based flow control is a near-end flow control for data from the Fibre Channel client side). It asynchronously maps the 8B/10B encoded Fibre Channel client data to the WAN encoding and packet structure.
GFP (Generic Framing Procedure, defined by the ITU) allows variable length, higher-layer client signals to be mapped to a WAN transport network like SONET or SDH. GFP can be used with client data in the form of PDUs (Protocol Data Units), such as IP/PPP (Internet Protocol/Point-to-Point Protocol) or Ethernet Media access control or block codes as in Fibre Channel. GFP-T (GFP-Transparent) is particularly suited for a Fibre Channel to SONET transition because it allows multiple 8B/10B client data frames to be mapped into an efficient 64B/65B block code for transport in SONET within a GFP frame.
GFP-T applies sub-rate mapping, that is, it maps higher rate client data (e.g., 1G Fibre Channel) into lower rate SONET payload (e.g., STS-3c or 155 Mbps). GFP-T sub-rate may be used whether or not the device at the other end of the WAN implements far-end flow control. Far-end flow control is applied to data coming from a SONET connection to transition the data to another communications standard.
For Fibre Channel data, near-end flow control is typically effective for distances over the WAN of up to 80 km. So for distances of up to 80 km, the on-chip memory of a transition device is normally sufficient to provide the buffer to store the data. In an implementation where the GFP-T adaptation function is implemented in one device and the GFP framing function is implemented in a second separate device, two buffers, typically FIFOs (First In First Out) are required in the first device. For GFP-T adaptation in the direction from client to SONET a first FIFO is used for near-end flow control, and a second FIFO is used for the packet interface (e.g., SPI-4 (System Packet Interface rev. 4 of the Optical Networking Forum)) between the GFP-T rate adaptation device and the GFP framing device. Multiple buffers add expense and delay to the system in the cost of memory as well as any protocols and processes for moving packets into and out of the buffers.
Embodiments of the present invention will be understood more fully from the detailed description given below and from the accompanying drawings of various embodiments of the invention. The drawings, however, should not be taken to be limiting, but are for explanation and understanding only.
A single buffer, such as a FIFO may be shared by a SPI-4.2 interface (System Packet Interface Level 4 (SPI-4) Phase 2 Revision 1: OC-192 System Interface for Physical and Link Layer Devices, published Jun. 12, 1992), or any other packet interface, and a near-end flow control function for Fibre Channel or similar clients. The single buffer may also be used to effectively reduce the total buffer size to approximately half the typical size without losing functionality in the GFP functions. This reduces cost and complexity and, when the functions are implemented in standardized modules, such as an FPGA (Field Programmable Gate Array), the choice of available modules is greatly enhanced.
This allows Fibre Channel clients to be transported over SONET at much less cost. When the two buffers are combined the size of the combined FIFO may often be approximately equal to the size of the larger of the two FIFOs. The particular size will depend, in part, on the required FIFO size for each function.
In one embodiment, the invention may be part of a client adaptation FPGA, a companion chip for a service framer, such a device may be sold as a Bandwidth Aggregation and Channelizer Devices with Virtual Concatenation. A client adaptation FPGA expands the service framer's capabilities to transport multiple types of data clients (e.g. Fiber Channel, Gigabit Ethernet, FICON (Fiber Connectivity defined by IBM Corp.), ESCON (Enterprise Systems Connection defined by IBM Corp.), etc), and thereby allows the service framer to be used in more applications and in applications in which it will be coupled to several different networks simultaneously. The client adaptation FPGA may also be useful when Fibre Channel data is transparently encoded then transported over a SONET channel. It may also be useful when the GFP framing function is implemented in a different device than the GFP-T adaptation function.
The interface of
A service framer 116 is coupled to the Client Adaptation FPGA using, for example SPI-4.2, a packet based interface. The service framer performs the GFP framing function. The service framer is coupled to a Backplane SERDES (Serializer/Deserializer) 118 that couples the reframed data to the STS cross-connect.
When a Fibre Channel client transmits data to send over a SONET network, it is transparently mapped over a SONET payload, typically using virtual or contiguous concatenation, although other approaches may also be used. Due to the difference in data rates, or more specifically, when the SONET payload rate is less than the Fibre Channel data rate, near-end flow control is used to prevent the Fibre Channel data source from transmitting data when the SONET side cannot handle it. The near-end flow control is normally used irrespective of whether FC-BB-3_SONET far-end flow control or some other far-end flow control is used at the other end of the WAN. A popular near-end flow control approach is a credit based Fibre Channel buffer-to-buffer flow control.
According to the credit based approach, for a 1G Fibre Channel client approximately 1 credit is required for every 2 km, plus 2 credits to store 2 extra Fibre Channel frames to account for any partial frames in transmission. For 2G/4G Fibre Channel clients, the number of credits required per kilometer is proportional to that for a 1G Fibre Channel. In other words, the 2G client requires 2 credits for every 2 km and the 4G client requires 4 credits for every 2 km. To support 20 km of near-end flow control for a network of 1G Fibre Channel clients, the number of required credits can be computed as 20 km/2 km per credit+2 buffer credits=12 credits. Each credit represents 1 Fibre Channel frame and in a typical Fibre Channel network, the maximum frame size is 2148 bytes. Accordingly, the required FIFO size is about 25.2 Kbytes.
The packets are then passed to a Fibre Channel Client Management module 226 to remove IDLE, R_RDY and control frames, if necessary. The packets are then stored in a near-end flow control FIFO 228 before being passed, when ready to a GFP-T client adaptation module 230. This module performs 64B/65B encoding and assembles the superblocks for the WAN. Any one or more of these blocks may be consolidated into other blocks and some functions may be removed while others are added, depending on the implementation.
From the ingress channels section, the reformatted and buffered packets are passed to a SPI-4.2 system interface 232 that includes its own ingress FIFO buffer 234. After conversion to SPI-4, the FPGA offers K logical egress ports 236 to the service framer. While the present description is in the context of SPI-4 Phase 2, it may also be adapted to later versions of SPI as well as other data communication protocols.
As shown in
The two FIFOs support different functionality and are logically implemented separately. The flow control FIFO (FIFO 1) stores Fibre Channel frames and interfaces with the Fibre Channel network. For example when a frame is sent out of this FIFO , the near-end flow control may determine when to send R_RDY back to the Fibre Channel source indicating that it is ready to receive another frame. In the SPI-4 FIFO (FIFO 2), only N superblocks are counted as a packet and there is no connection or interface with Fibre Channel and Fibre Channel frames do not exist here. In the present example N indicates the number of superblocks; for example, N=13 for Fibre Channel.
The two large FIFOs consume significant resources on the FPGA. In many FPGA designs, the amount RAM available for all purposes is limited. In addition, in FPGA design, where the size of the RAMs are fixed, it may be more efficient to use the RAMs to implement one large FIFO rather than two smaller FIFOs. As shown in
From the ingress section 322, the packets go to a SPI-4 system interface 332 that includes a single FIFO 334 for the ingress SPI packets and for near-end flow control. The packets then exit through one of K logical ports 336 to the service framer.
To accommodate the lack of a dedicated flow control FIFO, the SPI-4 FIFO may be adapted to keep track of the end of the frames in the 64B/65B encoded data from the GFP-T mapping 330. In one example, when data is received from the client and passes through the Fibre Channel Client Management block 326, the end of each frame is detected and then stored in the SPI-4 FIFO. The end of each frame may be tracked by recording the address of each end-of-frame in the SPI-4 FIFO. This storage of EOF (end-of-frame) records may normally be done by the dedicated flow control FIFO (FIFO 1).
The maximum number of EOF records that is stored may be set as the maximum number of credits that can be supported. For example, if the maximum number of supported credits is 12, then only 12 EOF addresses need to be stored. Some near end buffer-to-buffer flow control systems are limited so that no more than 12 frames should be sent by the Fibre Channel source at any point of time. No additional resources or very little additional resources are required for this operation. To manage near-end flow, an EOF record may be sent out on the SPI-4 interface to the SPI-4 system interface module when the end of a frame is reached in the FIFO. The SPI-4 system interface may then instruct other blocks in the FPGA to send an R-RDY back to the Fibre Channel source to indicate that another credit is available. The Fibre channel source may then send another packet.
From the ingress section 422, the packets go to a SPI-4 system interface 432 that does not include a FIFO for the ingress SPI packets. The packets then exit through one of K logical ports 436 to the service framer.
To accommodate the lack of a dedicated SPI-4 ingress FIFO, the near-end flow control FIFO may be adapted to keep track of the ingress demands of the SPI-4 system interface and send data to the GFP-T mapping module at a rate that will satisfy the demands of the SPI-4 system interface.
The embodiment of
On the other hand, the implementation of the GFP-T 64B/65B enconding and the FC-BB-3 WAN functions (ASFC) is more complex because these functions are centralized into a single time-sliced machine processing K different client flows simultaneously. In addition, this configuration in which the 64B/65B enconding and the FC-BB-3 WAN blocks appear between the Ingress FIFOs and the SPI-4.2 interface complicates the support of store-and-forward transfers through the SPI-4.2 interface.
At block 518, the SPI-4 system interface reads the EOF record and sends a command to the packet source indicating that there is additional room in the buffer. For a Fibre Channel source, the command may be an R-RDY command. In response to such a command, at block 520, the Fibre channel source sends another packet.
With 64B/65B encoding, a packet consists of N×superblocks and is only completed when all N superblocks are encoded. In the store-and-forward mode of SPI-4, a packet will not be sent until N superblocks are received by the SPI-4 FIFO. In the cut-through mode, if the last part of a packet is not sent in time, an underflow will occur in the GFP mapper in the GFP framing device. Therefore, when the SPI-4 FIFO is close to empty (in store-and-forward mode) and when there is only one partial packet remaining in the SPI-4 FIFO and the partial packet is insufficient to fill the 64B/65B packet, then the last part of a packet (N×superblocks) may be sent to the SPI-4 FIFO by filling up the last part of the packet with 65B_PAD. This function may be performed with or without a dedicated near-end control FIFO. Padding the end of a 64B/65B packet will not increase the size requirement for the flow control FIFO, because this padding only happens when the SPI-4 FIFO is close to empty and the output rate from the SPI-4 is constant. In other words, it is matched to the input rate of the SONET WAN.
In one example, the required size of the combined FIFO may be calculated as follows. For each frame, with the maximum frame size of 2148 bytes, the required buffer after 64B/65B encoding (including CRC-16 (Cyclic Redundancy Check)) is 2148×67/64 or about 2249 bytes. To support 20 km of near-end flow control, 12 credits or 2249×12=26.4 Kbytes are used. If a SPI-4 FIFO of 32 Kbytes is required for the
A lesser or more complicated line router, client adaptation module, client management module, near-end or far-end flow control, buffer-to-buffer flow control, encoding/decoding, packetizing, serializing/desterilizing, wired or optical network may be used than those shown and described herein. Therefore, the configurations may vary from implementation to implementation depending upon numerous factors, such as price constraints, performance requirements, technological improvements, or other circumstances. Embodiments of the invention may also be applied to other types of systems that use different inputs and outputs than those shown and described herein.
Embodiments of the present invention may be provided as a microcode, firmware, embedded instructions, or a computer program product which may include a machine-readable medium having stored thereon instructions which may be used to program a general purpose processor, embedded processor or application specific device (or other electronic devices) to perform a process according to the present invention. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnet or optical cards, flash memory, or other type of media/machine-readable medium suitable for storing electronic instructions. Moreover, the present invention may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
Many of the methods and apparatus are described in their most basic form but steps may be added to or deleted from any of the methods and components may be added or subtracted from any of the described apparatus without departing from the basic scope of the present invention. It will be apparent to those skilled in the art that many further modifications and adaptations may be made. The particular embodiments are not provided to limit the invention but to illustrate it. The scope of the present invention is not to be determined by the specific examples provided above but only by the claims below.