1. Field of the Invention
The present invention relates to Fibre Channel networks, and more particularly, to using a time to live field in a Fibre Channel switch.
2. Background of the Invention
Fibre Channel is a set of American National Standard Institute (ANSI) standards, which provide a serial transmission protocol for storage and network protocols such as HIPPI, SCSI, IP, ATM and others. Fibre Channel provides an input/output interface to meet the requirements of both channel and network users.
Fibre Channel supports three different topologies: point-to-point, arbitrated loop and Fibre Channel fabric. The point-to-point topology attaches two devices directly. The arbitrated loop topology attaches devices in a loop. The Fibre Channel fabric topology attaches host systems directly to a fabric, which are then connected to multiple devices. The Fibre Channel fabric topology allows several media types to be interconnected.
Fibre Channel fabric devices include a node port or “N_Port” that manages fabric connections. The N_port establishes a connection to a fabric element (e.g., a switch) having a fabric port or “F_port”.
A Fibre Channel switch is a multi-port device where each port manages a point-to-point connection between itself and its attached system. Each port can be attached to a server, peripheral, I/O subsystem, bridge, hub, router, or even another switch. A switch receives messages from one port and routes it to another port.
Fibre Channel switches use memory buffers to hold frames received and sent across a network. Associated with these buffers are credits, which are the number of frames that a buffer can hold per fabric port.
Fibre Channel standards are now being extended for use with expanded Fabrics. Fibre Channel proposal, T11/04-520v1 (proposed for standardization in ANSI/INCITS Project Number 1745-D(FC-IFR)), incorporated herein by reference in its entirety, describes multiple Fabrics and how they should be interconnected.
A proposed Fibre Channel Inter-Fabric routing header (FR_Header) provides for a “time out” field based on which frames will be “timed out” (i.e. expired) and then discarded.
The proposed standard field (107) and methodology has disadvantages.
Therefore, there is a need for a method and system for efficiently discarding frames in Fibre Channel networks.
In one aspect of the present invention, a method for processing frames in a fibre channel network is provided. The method includes, determining if an incoming frame in a port of a fibre channel switch element includes a FR_Header with a time to live time (“TTLT”) field value; determining if the TTLT field value is greater than a certain number; adjusting the TTLT field value at a pre-determined time interval if the TTLT field value is greater than the certain number; and inserting an adjusted TTLT field value in the incoming frame before it is sent out to another port, wherein the adjusted TTLT field value is based on a difference between the TTLT field value and a duration that the incoming frame spends in the port.
In another aspect of the present invention, a fibre channel switch element is provided. The switch element includes, a port that receives an incoming frame and determines if a FR_Header with a time to live time (“TTLT”) field value is received with the FR_Header, and using a timer adjusts the TTLT field value and inserts the adjusted TTLT field value in the incoming frame, before it is sent out. The TTLT field value in the incoming frame is decreased after a certain period, if the TTLT field value in the incoming frame is greater than zero. If the TTLT field value is equal to or less than zero, the incoming frame is considered expired.
This brief summary has been provided so that the nature of the invention may be understood quickly. A more complete understanding of the invention can be obtained by reference to the following detailed description of the preferred embodiments thereof concerning the attached drawings.
The foregoing features and other features of the present invention will now be described with reference to the drawings of a preferred embodiment. In the drawings, the same components have the same reference numerals. The illustrated embodiment is intended to illustrate, but not to limit the invention. The drawings include the following Figures:
Definitions:
The following definitions are provided as they are typically (but not exclusively) used in the Fibre Channel environment, implementing the various adaptive aspects of the present invention.
“D_ID”: A 24-bit Fibre Channel header field that contains the destination address for a frame.
“E_Port”: A fabric expansion port that attaches to another Interconnect port to create an Inter-Switch Link.
“F_Port”: A port to which non-loop N_Ports are attached to a fabric and does not include FL_ports.
“Fibre Channel ANSI Standard” (“FC-FS”): The standard (incorporated herein by reference in its entirety) describes the physical interface, transmission and signaling protocol of a high performance serial link for support of other high level protocols associated with IPI, SCSI, IP, ATM and others.
“Fabric”: The structure or organization of a group of switches, target and host devices (NL_Port, N_ports etc.).
“Fabric Identifier” (may also be referred to as “Fabric ID”): An identifier that is used to identify a Fabric for a Fabric Router function.
“Fabric Router”: A Fibre Channel device that allows Fibre Channel Devices, via N_Ports to be shared among multiple independent Fibre Channel Fabrics.
“Fabric Topology”: This is a topology where a device is directly attached to a Fibre Channel Fabric that uses destination identifiers embedded in frame headers to route frames through a Fibre Channel fabric to a desired destination.
“FR_Header”: A header format (shown in
“N_Port”: A direct fabric attached port, for example, a disk drive or a HBA.
“NL_Port”: A L_Port that can perform the function of a N_Port.
“Port”: A general reference to N. Sub.—Port or F.Sub.—Port.
“SAN”: Storage Area Network
“S_ID”: A 24-bit field in a Fibre Channel frame header that contains the source address for a frame.
“Switch”: A fabric element conforming to the Fibre Channel Switch standards.
In one aspect of the present invention, a new field for the FR_Header is provided instead of the Exp_Time field 107. This new field is referred to herein as the “Time to Live Time Field” (“TTLT”). The TTLT field is set to a maximum amount of time that a frame can exist while the frame is in transit from a source to its destination. The field may be set by an ingress routing function that is described in T11 standard 04-520v1. The maximum time may be any value that is decided by the Fibre Channel standard or can be based on network demands/congestion. The TTLT field is used to monitor the elapsed time in a local switch and hence does not require synchronization of time between plural Fabric elements.
Each Fabric switch element that receives a frame with a FR_Header checks the TTLT field value. If the field is already zero then the frame is ignored. If the field has a certain value, then the time value is reduced by a certain amount. If the field value reaches a certain predefined value, for example, 0, then the frame is discarded. This signifies that the frame has out-lived its life. If the TTLT has not reached a certain value, for example, 0, then the field value is reduced and the frame is transmitted.
To facilitate an understanding of the preferred embodiment, the general architecture and operation of a Fibre channel System and a Fibre Channel switch element will be described. The specific architecture and operation of the preferred embodiment will then be described with reference to the general architecture.
Fibre Channel System:
The devices of
Fibre Channel Switch Element:
The fabric element of the present invention is presently implemented as a single CMOS ASIC, and for this reason the term “fabric element” and ASIC are used interchangeably to refer to the preferred embodiments in this specification. Although
ASIC 20 has 20 ports numbered in
For illustration purposes only, all GL ports are drawn on the same side of ASIC 20 in
Each port GL0-GL19 has transmit and receive connections to switch crossbar 50. One connection is through receive buffer 52, which functions to receive and temporarily hold a frame during a routing operation. The other connection is through a transmit buffer 54.
Switch crossbar 50 includes a number of switch crossbars for handling specific types of data and data flow control information. For illustration purposes only, switch crossbar 50 is shown as a single crossbar. Switch crossbar 50 is a connectionless crossbar (packet switch) of known conventional design, sized to connect 21×21 paths. This is to accommodate 20 GL ports plus a port for connection to a fabric controller, which may be external to ASIC 20.
In the preferred embodiments of switch chassis described herein, the fabric controller is a firmware-programmed microprocessor, also referred to as the input/output processor (“IOP”). IOP 66 is shown in
Control register 62 receives and holds control information from IOP 66, so that IOP 66 can change characteristics or operating configuration of ASIC 20 by placing certain control words in register 62. IOP 66 can read status of ASIC 20 by monitoring various codes that are placed in status register 64 by monitoring circuits (not shown).
Each GL_Port may have an optical-electric converter, designated as OE0-OE19 connected with its SERDES through serial lines, for providing fibre optic input/output connections, as is well known in the high performance switch design. The converters connect to switch channels C0-C19. It is noteworthy that the ports can connect through copper paths or other means instead of optical-electric converters.
TTLT Field Value Usage:
When an incoming frame 201 is received by receive port 200, the receive pipeline determines if the frame has an FR_Header with a TTLT field set. If the frame has a FR-Header with a set TTLT field, then the TTLT field value 204 is stored in storage 204B (shown as “time to live values” in
Timer 205 can be programmed by switch firmware to decrement after a certain period, for example, after 100 milliseconds or any other value. If the TTLT field value reaches a certain value, for example, 0, then a status 206 is sent to receive buffer 203 and the frame is timed out. The response and how a timed out frame should be disposed can be determined by switch firmware/software, as described below.
If the TTLT value 204 does not become zero and the frame is to be sent to the transmit port 208, then an updated (adjusted or decreased) TTLT field value 204A is sent to a cyclic redundancy check (“CRC”) module 207 that calculates a new CRC for the outgoing frame. CRC values are calculated using standard techniques to determine frame errors.
The adjusted TTLT value 204A is merged in the outgoing frame. The frame with the updated TTLT and updated CRC value is then sent to the transmit port 208.
If the CRC value for the incoming frame 201 was bad when it was received, then the frame is tagged by changing the End of Frame (“EOF”) code to indicate a bad frame.
It is noteworthy that the logic shown above with respect to the receive port 200 may be used in the transmit port to adjust the TTLT field values.
Incoming frames are received in step S300. The frames are stored in receive buffer 203, after passing through receive pipeline 202.
If the incoming frame has a FR_Header with a TTLT field value, then the TTLT field value 204 is stored (shown as 204B).
If the TTLT field value is not equal to zero, then in step S304, the TTLT field value 204 is adjusted (decreased or modified) at a pre-determined time interval. Timer 205 is used to decrease the TTLT value. For example, the TTLT field value can be decreased every 100 milliseconds (or any other interval) while the frame is in the receive port 200 before being sent to the transmit port 208.
The TTLT field value can also be decreased by a value that is proportional to the amount of time a frame spends on an active fibre channel link medium (or fibre or “wire”). This is especially useful where the optical fibre length is long. For example, if a frame has traveled on a fibre channel cable that is say 1 mile long, then the receive port deducts a value “t” from the TTLT field value when the frame enters the switch element. This adjusts the TTLT field value based on the time that a frame spent on the fibre itself. This decrement is in addition to the adjustment that takes place in step S304.
In step S306, the TTLT field value is compared to a certain value X, for example, zero. If TTLT field value is equal to (or less than) zero, then in step S312, a status is sent to receive buffer 203 to discard frame 201 in step S314. The frame can be tagged so that it is discarded at the transmit port.
It is noteworthy that frames can be discarded based on the class of the frame. For example, a Class 2 fibre channel frame is not discarded and instead sent to IOP 66. IOP 66 maintains a count for the timed out frames. IOP 66 (and/or other counters, not shown) saves information regarding the timed out frames for any analysis that may be performed. For example, a network administrator may want to know the source, destination or type of the timed out frames to optimize overall network performance. Also, the switch element itself (besides IOP 66) can maintain a count for the timed out (and/or discarded frames) using local switch element resources.
A class 3 frame can be discarded by one of the ports (receive and/or transmit port) based on a priority scheme that is programmed by the switch element firmware and may not be sent to IOP 66.
If the TTLT field value is greater than zero, then in step S308, a new CRC value is determined by CRC module 207. An adjusted TTLT field value 204A is inserted in the outgoing frame and the frame is sent to the transmit port with the new CRC value and a new TTLT value. The adjusted TTLT field value 204A is based on the difference between the original TTLT field value 204 and the time the frame spends in receive port 200.
One advantage of using the TTLT field value instead of an expiration value (Exp_Time) is that switches in different Fabrics do not have to synchronize their clocks. This is illustrated in
When frame 201 with TTLT value 204 enters switch 1 in Fabric 1, then the TTLT value is adjusted based on how long the frame stays in switch 1, before it is sent to switch 2. The adjustment to the TTLT value is based strictly on the local time domain of switch 1 and Fabric 1. Switch 2 in Fabric 2 and switch 3 and Fabric 3 adjust the TTLT value based on their own local time domains. No synchronization is required between the different clock domains for Fabric 1, Fabric 2 and Fabric 3, to determine when a frame should be timed out.
It is noteworthy that although the foregoing process steps have been described to occur in a receive port of a switch element, the present invention is not limited to the receive port. For example, the foregoing TTLT field modifications can take place anywhere between the receive port and the transmit port of a switch element.
Although the present invention has been described with reference to specific embodiments, these embodiments are illustrative only and not limiting. Many other applications and embodiments of the present invention will be apparent in light of this disclosure and the following claims.