Multiple virtual channels for use in network devices

Information

  • Patent Grant
  • 8116203
  • Patent Number
    8,116,203
  • Date Filed
    Thursday, May 31, 2007
    17 years ago
  • Date Issued
    Tuesday, February 14, 2012
    12 years ago
Abstract
A method for establishing a virtual channel between network devices is disclosed. In the case of a local network device establishing a virtual channel with a remote network device, a virtual channel request message is sent from the local network device to the remote network device. A virtual channel acknowledgement message and a remote capability list are received and a virtual channel resume message and a local capability list are sent. The virtual channel is then enabled. In the case of a remote network device establishing a virtual channel with a local network device, a virtual channel request message is received from a local network device by a remote network device. A virtual channel acknowledgement message and a remote capability list are sent and a virtual channel resume message and a local capability list are received. The virtual channel is then enabled.
Description
BACKGROUND OF THE INVENTION

1. Field of Invention


The present invention relates to a method and apparatus of selectively exchanging control and state information (extensible to exchange of upper layer application data) between network devices. The control and state information is exchanged via a frame that is scalable to support many different applications. More specifically, multiple virtual channels are established between network devices by blocking or control of certain data flows, without blocking the flow of other data through the same link, effectively increasing the bandwidth utilization of the link and the throughput of the network device.


2. Description of Related Art


Many types of network devices are necessary to allow a network to function properly. One such network device is commonly referred to as a switch. A switch is defined as a network component that receives incoming data, stores the data temporarily, and sends the data back out on another port. The switching is accomplished by determining a destination address from the incoming data and sending the data to a port or set of ports associated with the destination address. The control and monitoring of a switch is essential in handling the flow of data in high speed networks. The effective functioning of the switch can be enhanced by control of the traffic through the switch, including monitoring and modification of that traffic. One such function is the control of the selective flow of data through the switch in response to congestion, either internal or external to the switch. This function is also illustrative since it involves the exchange of control and state information between network devices


Ethernet switches generally support two common mechanisms to handle resource congestion inside the switch. The Ingress backpressure mechanism enables the switch to flow control the traffic sent by a remote link partner, i.e. another network connected to the switch. This process is illustrated in FIG. 1. The Ethernet Switch 100 keeps track of the number of packets or cells received on each Ingress Port, such as Port #1 connected to remote link partner 110. If the number of bytes or cells received on an Ingress Port exceed the configurable Ingress Back Pressure threshold, then the switch exerts Back Pressure. In another technique, if the number of packets received on an Egress Port, such as Egress Port #8 connected to the local or wide area networks 120, exceeds a pre-configured threshold value, then egress generates an Ingress Back Pressure request to the Ingress port.


In Full Duplex mode, this Back Pressure is achieved by sending a MAC Control Frame called a “Pause Frame.” Upon receiving the Pause Frame, the remote link partner stops sending further packets until the timer specified in the Pause Frame expires or the switch explicitly sends Resume Frame (Pause Frame with Timer=0). Thus, the entire link remains idle until communication resumes. This flow control mechanism on a full duplex port is specified in the IEEE std 802.3x, in which it has been specified that an ingress port in a full duplex mode should send Pause Frames for flow control.


In Half Duplex mode, this Back Pressure mechanism can be achieved by enabling a Jamming signal and thereby preventing any other station from sending the packet. For ports that are in half duplex mode, this prevents any other station from sending packets to the port. The enabling of jamming signal in half duplex is not a standard, but is done by many of the switch vendors.


These techniques help in avoiding losing any packet that was being received and forwarded by the ingress port and it is generally termed as a Zero-Loss mode of switching, or as a Zero Packet Loss mode of switching. This process has other side effects, however, including an adverse impact on the switch's throughput and wire speed switch rate.


In addition, Ethernet switches also support a mechanism to handle Head Of Line (HOL) blocking avoidance. This mechanism is illustrated in FIG. 2. The switch 200 keeps track of number of bytes or cells that are sitting on an Egress Port, such as Egress Port #8 connected to the local or wide area networks, or any type of networks 220. If the number of bytes or cells or packets exceed the Head Of Line (HOL) threshold value then all packets going to that Egress port are dropped at the Ingress port itself. The HOL values are generally configured by software depending on the size of the packet memory. This is generally termed as a HOL avoidance mode of switching. In this HOL avoidance mode, switch performance is sustained by sacrificing packets.


In a Zero-Loss mechanism, the switch never drops any packet for any traffic scenario, the worst case being all ingress ports are sending packets to one egress port. In this Zero-Loss mode, the switch will hit the Ingress Back Pressure threshold before hitting the Egress HOL limit, so that it exerts Ingress Back Pressure rather than dropping packet going to the congested port. As such, there are disadvantages to both types of mechanisms used for controlling the flow of data through a switch.


In terms of providing actual control of the flow of data through a network device, the above processes are often crude with respect to the aspects they allow to be controlled. The present implementations can achieve zero-packet loss but the throughput of the network is often decreased. Alternatively, implementations dealing with Head Of Line blocking can sustain throughput, but the loss of packets increases. Thus, there is a need for a mechanism in a network device that achieves Zero-Loss processing of data that does not have the detrimental effects on the performance of the network device found in the prior art processes. Additionally, there is also a need for selective flow control mechanism that can also be utilized to allow the flow of data having a certain priority to be unimpeded.


SUMMARY OF THE INVENTION

It is an object of this invention to overcome the drawbacks of the above-described conventional network devices and methods. The above control and monitoring of the processes of a network device can be accomplished through the establishment of multiple virtual channels between network devices. These virtual channels allow for the selective control of flows through the network device. The virtual channels also can provide for in-band management of the network device, as well as traffic shaping and rate control. The use of virtual channels facilitates operations, administration, and maintenance functions and simplifies device detection and remote monitoring of the functions of the network device.


According to one aspect of this invention, a method for establishing a virtual channel between network devices is disclosed. In the case of a local network device establishing a virtual channel with a remote network device, a virtual channel request message is sent from the local network device to the remote network device. A virtual channel acknowledgement message and a remote capability list are received and a virtual channel resume message and a local capability list are sent. The virtual channel is then enabled. Similarly, in the case of a remote network device establishing a virtual channel with a local network device, a virtual channel request message sent from a remote network device, is received by a local network device. A virtual channel acknowledgement message and a remote capability list are sent and a virtual channel resume message and a local capability list are received. The virtual channel is then enabled.


Additionally, the virtual channel request message may be an Ethernet frame that is interpreted as a pause frame when the remote network device is not virtual channel capable. Also, a request retry timer may be used to wait for a specified period after the request message is sent and then resent after the specified period when no virtual channel acknowledgement message has been received. A request retry limit value may be used to limit the number of times the request message is sent. Similarly, an acknowledgement retry timer may be used to wait a specified period after the acknowledgement message is sent and then resent after the specified period when no virtual channel resume message has been received. Also, an acknowledgement retry limit value may be used to limit the number of times the acknowledgement message is sent.


Also, the local and remote capability lists can be in the form of link advertisement registers where each bit of the registers refers to specific capabilities of the local and remote network devices, and these registers are sent and received in the steps of the method. Furthermore, the virtual channel request message, the virtual channel acknowledgement message and the virtual channel resume message can each have an Ethernet frame format with a source address and a destination address being one of an address of the local network device and an address of the remote network device.


In addition, the virtual channel may be established through auto-negotiation between the local network device and the remote network device and can use the sending and receipt of next pages to exchange virtual channel data.


In another aspect of the invention, a virtual channel capable network device is disclosed. The device includes means for sending or receiving a virtual channel request message from or to a second network device and means for sending or receiving a virtual channel acknowledgement message and a first capability list. The device also includes means for sending or receiving a virtual channel resume message and a second capability list and means for enabling the virtual channel. When the virtual channel acknowledgement message is sent by the virtual channel capable network device, the first capability list is a capability list for the virtual channel capable network device and when the virtual channel acknowledgement message is received by the virtual channel capable network device, the first capability list is a capability list for the second network device.


Additionally, the network device may include means for sending or receiving an Ethernet frame that is interpreted as a pause frame when the second network device is not virtual channel capable. Also, the device may have one or both of a request retry timer and an acknowledgement retry timer, used to determine the period after which either the request or acknowledgement messages should be resent if the proper reply is not received. The device may also use one or both of a request retry limit value and an acknowledgement retry limit value in determining the number of times a message should be resent.


Also, link advertisement registers may be used, where each bit of the registers refers to specific capabilities of the local and remote network devices. The virtual channel request message, the virtual channel acknowledgement message and the virtual channel resume message can each have an Ethernet frame format with a source address and a destination address being one of an address of the virtual channel capable network device and an address of the second network device.


The device may also include means for auto-negotiation (as specified in the IEEE std 802.3) between the virtual channel capable network device and the second network device to establish communications there between. Also, the device may also incorporate means for sending and receiving next pages used to exchange virtual channel data.


These and other objects of the present invention will be described in or be apparent from the following description of the preferred embodiments.





BRIEF DESCRIPTION OF THE DRAWINGS

For the present invention to be easily understood and readily practiced, preferred embodiments will now be described, for purposes of illustration and not limitation, in conjunction with the following figures:



FIG. 1 illustrates a Zero-Loss process of dealing with congestion in a network switch;



FIG. 2 illustrates the HOL avoidance process of dealing with congestion in a network switch;



FIG. 3 illustrates a Virtual Channel (VC) capable network device linked with remote link partner;



FIG. 4 illustrates the VC three-way handshake process, according to one embodiment of the present invention;



FIG. 5 illustrates an example of VC Handshake REQUEST encoding in the MAC-SA address field of “Pause control” Ethernet frame;



FIG. 6 illustrates an example of VC ACK frame format;



FIG. 7 illustrates an example of VC RESUME frame format;



FIG. 8 illustrates an example of VC frame format;



FIG. 9 illustrates an example of VC frame format for Type 0;



FIG. 10 illustrates an example of VC tag format for Type 1;



FIG. 11 illustrates an example of VC tag format for Type 2; and



FIG. 12 illustrates an example of VC tag for priority based selective flow control.





DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS

The Virtual Channel (VC) protocol is intended for exchange of proprietary control between network devices such as switches, routers, network interface cards (NICs), cable modems and related devices. The VC protocol, according to an embodiment of the invention, enables value add functions such as selective flow control, operations, administration and maintenance (OAM) functions, in-band management and many other functions between network devices. The VC protocol can be applied to any media between network devices that are so configured.


The VC protocol has many applications, including selective flow control, in-band management, rate control, traffic shaping, device detection, OAM functions, remote monitoring, and remote alarms.


An exemplary application of the virtual channels of the present invention is directed to Selective Flow Control (SFC). The IEEE 802.3 standard defines link level flow control between two Ethernet devices. For example, if a switch port is congested, it can send a flow control frame to the remote end to stop all incoming traffic. However, if the remote is sending both delay sensitive and delivery sensitive traffic, it is desirable to flow control only the delivery sensitive traffic and not the delay sensitive traffic. This is the feature referred to as Selective Flow Control.


In FIG. 3, a VC capable Server 310 is connected to a VC capable Switch 300 on port 2 and its clients 320-350 are connected on switch ports 5, 7, 18 and 24. As an example, if client #3 creates congestion on port 18 and port 18 hits the egress congestion threshold, the egress will inform the ingress port 2 of the congestion. Using the VC flow ID technique, Port 2 sends a VC frame to Server 310 indicating congestion for the given flow ID. The Server in turn will stop sending any packets for that Flow ID (mapped to the egress port 18); thereby there will be no packet loss for packets going to egress port 18. Now, the server can continue sending packets to other clients connected to other egress ports, thereby the link bandwidth is fully utilized.


Another important application of the VC protocol is in-band management. This functionality permits a management agent to control a device through a port, rather than through a dedicated bus, such as Peripheral Component Interconnect (PCI). In particular, an internal, VC enabled port can provide full access to the register and memory space of the device, as well as provide the ability to set up remote monitoring, RMON-like trap conditions which will generate an alert by sending a VC frame. The device can then be fully managed without the need for a dedicated CPU.


The architectural paradigm for the VC framework is as follows. The framework enables most common applications and has a minimal impact on link bandwidth. The VC is enabled based on a hardware mechanism with optional software control and the VC does not violate any layer standard (IEEE, IETF). The framework is flexible to allow multiple applications and functions, the architecture is scalable for complex applications and enables customer specific applications to provide differentiation among system vendors using VC-capable devices.


Each of the local and remote sides must indicate it is VC capable. This is accomplished by a three-way handshake. Once the local and remote sides are VC aware, a mechanism is necessary to pass application specific information between the local and remote devices. This is accomplished through a VC frame, which contains all the relevant control information.


When a device supporting VC establishes a link, it should determine whether its link partner is VC capable, and, if so, what functionality to activate. Two of the mechanisms are proposed to establish this are: using the three-way VC Handshake mechanism and/or using the Next Page capability of Auto-negotiation.


Once the capabilities are exchanged, VC control frames are sent to execute the supported functionalities. The actual triggering of the VC frame is dependent on several factors including the application, the state of the device and implementation dependencies.


VC Handshake


The VC Handshake is performed by the exchange of proprietary frames. It has at least two important tasks to perform: 1) to enable the VC mode between the two link partners and 2) to determine common VC capabilities of the two link partners.


The VC Handshake Mechanism is for Full Duplex ports and is based on the 802.3x Pause Control Frame used for flow control, as specified in the std. 802.3x. This mechanism has distinct advantages, including being 100% compatible with IEEE standard devices (non-VC mode) and 100% forward compatible with the future VC framework. The mechanism is extensible to new Ethernet standards (10 GE), is independent of Media type (copper, Fiber, etc.), is a hardware based handshake mechanism and has the flexibility to fine tune the Handshake parameters using software.


The VC Handshake specification expands upon the MAC Pause control Frames. It has the following requirements. The Handshake should be initiated immediately after link-up, which is after the completion of the auto-negotiation process. The Handshake may be initiated by each link partner. It should only be initiated on links in Full Duplex mode.


The VC Handshake is comprised of three steps. To successfully complete the VC Handshake, the third step should be completed. The steps are:


1. REQUEST phase to search for VC compliant link partner. This is initiated by the local side called the Requester;


2. ACK phase to confirm and pass VC feature list to the requester. This is a response from the remote side, called the Responder; and


3. RESUME phase to complete the handshake and pass requestor's VC feature list. This is sent by the Requester. It indicates the functionality to be supported over this link. These steps are illustrated in FIG. 4.


For all VC Handshake frames, the pause timer field should be set according to the current state of the port. The value used should be the same value that would be used if the port were sending a normal pause frame rather than a VC frame. This ensures that non-VC devices connected to this port will act appropriately.


In general, VC capabilities are asymmetrical and involve sending a specific type of VC control frame and involve obeying that type of VC control frame. In order for VC functionality to be enabled, the VC Handshake may be initiated from both link partners. Each device that is capable of generating VC frames may initiate a VC handshake by sending a VC REQUEST frame. FIG. 4 shows an overview of the packet flow during the VC handshake.


The Request phase, initiated by the local device, is an encoded Pause frame sent to the remote device on the link with pause timer value determined by the current state of the port. The frame format follow the standard pause control frame with following field settings:

    • 6 byte DA=as specified in standard.
    • 6 byte SA=REQUEST phase encoding
    • 2 byte Type=MAC Control: 88-08
    • 2 byte Op-Code=Pause Frame: 00-01
    • 2 byte Pause Timer value=According to port's state.
    • 42 byte of “Data Payload”=Reserved (all zeros), and
    • 4 byte FCS.


Request Phase encoding uses the 6 bytes of “don't care” SA address field of Pause control frame (Bit 40 of SA address set to “0” to avoid multicast source address). The frame encodes the VC REQUEST with following bit assignment, also shown in FIG. 5:

    • Bits 47:40 VC Negotiation Code (VC REQUEST)
    • Bits 39:24 VC Device ID
    • Bits 23:12 VC Vendor ID
    • Bit 11:8 VC Rev ID, and
    • Bits 7:0 VC Signature.


For the VC Signature, an 8-bit checksum is calculated (XOR of bytes in header) and is used as a signature. If this checksum is not correct, the frame should be treated as a normal pause frame. The VC Revision ID is an 8-bit VC Specification Revision ID field. It indicates the VC architectural framework compliance of the local device. This Rev ID is useful for backward compatibility as the VC specification evolves. For first Generation devices, the VC Revision ID is “1” and up to a maximum of 255 revisions of VC Specifications is supported.


The VC Vendor ID is an 8-bit Vendor ID field. It indicates the Vendor ID of the VC silicon. The Default value is 0x1. The allocation of the Vendor ID is performed when requested by the customer for a unique Vendor ID. The intent on providing Vendor ID is for system vendors to provide differentiated products and services to their customers. The VC Device Type is a 16-bit field. It is intended to provide an indication of the capabilities of the device by indicating the family to which it belongs.


The VC Negotiation Code is an 8-bit field with bit zero always set to “0” (to avoid a source routed frame). The Negotiation codes are instrumental in conducting the VC handshake mechanism. Support of up to a maximum of 127 unique Negotiation codes is provided. Following are a few example Negotiation codes, with others being developed based on future requirements:

    • VC REQUEST (from local to remote)=0x02;
    • VC ACK (from remote to local)=0x04;
    • VC RESUME (from local to remote)=0x06; and
    • Reserved Negotiation code: =0x0.


The local has an internal REQ Retry timer and REQ Retry limits (both programmable by software before link up). The REQ Timer is based on the standard pause timer mechanism, except that it is within the local device. If the local does not receive any VC ACK response from remote before the timer expires, the local device re-sends another VC request. The number of VC REQUEST retried by local is controlled by the REQ Retry limits value. The default for the Internal REQ Retry timer is 0x1FFF and the default for the Internal REQ Retry limits is 3.


The ACKNOWLEDGEMENT (ACK) response phase is an encoded Pause frame sent from the remote (Responder) back to the local (Requester) after receiving the initial VC Request packet. If the remote device does not support the VC protocol, the remote device enters a pause state as per the standard Pause frame. Otherwise, the fields have the following meaning:

    • 6 byte DA, as specified in std;
    • 6 byte SA, ACKNOWLEDGEMENT Phase Encoding;
    • 2 byte Type, MAC Control: 88-08;
    • 2 byte op-code, Pause Frame: 00-01;
    • 2 byte Pause Timer, According to port's state;
    • 42 byte Payload, VC Capability list; and
    • 4 byte FCS.


With respect to acknowledgement phase encoding, the 6 byte SA field of the remote device VC ACK and the remote VC identification is encoded with exactly the same semantics as the six bytes of SA address field in the VC REQUEST phase. The description of this field is exactly the same as outlined above in the VC REQUEST phase with remote response and shown in FIG. 5. The 42 bytes of data payload is used to encode the remote device VC capability feature list. This is also discussed in more detail below. The ACK Frame Format is illustrated in FIG. 6.


The remote has an internal ACK Retry timer and ACK Retry limits (both programmable by software). The ACK Timer is based on the std. Pause timer mechanism, except that it is within the remote device. If the remote does not receive any VC RESUME response from local before the timer expires, the remote device re-sends another VC ACK. The number of VC ACK sent by remote is controlled by the ACK Retry limits value. As an example, the default for the Internal ACK Retry timer is set to 0x1FFF and the default for the Internal ACK Retry limits is set to 3.


The RESUME response phase, initiated by the local device, is also an encoded Pause frame sent to the remote with pause timer value determined by the port's current state. After receiving the ACK from the remote device, the local device sends the local capability list in the Resume frame. The 42 bytes of data payload encode the list of VC functions that should be enabled on the link. FIG. 7 shows the RESUME Frame Format. The frame format follows 802.3 standard for Pause control frames with following field settings:

    • 6 byte DA=as specified in std;
    • 6 byte SA=RESUME phase encoding;
    • 2 byte Type=MAC Control: 88-08;
    • 2 byte Op-code=Pause Frame: 00-01;
    • 2 byte Pause Timer=According to port's state;
    • 42 byte Payload=Enabled Capability list; and
    • 4 byte FCS.


The 6 byte SA field of local device VC RESUME and local VC identification is encoded with exactly the same semantics as the six bytes of SA address field in the VC REQUEST phase. The description of this field is exactly the same as outlined in VC REQUEST phase, which is illustrated in FIG. 5.


In addition, the VC architecture is also capable of handling special conditions arising during the VC handshake mechanism. One such condition occurs if the VC REQUEST needs to be retried. If the VC ACK response does not come from the remote, the local re-sends another REQUEST, limited to maximum REQ Retry limit value. If the REQ Retry limit is reached and no ACK has arrived, the local MAC switches to non-VC (standard) mode and supports the standard Ethernet packet flow.


In the case when the VC ACK is retried, i.e. the VC RESUME response does not come from the local, the remote re-sends another ACK, limited to maximum ACK Retry limit value. If the ACK Retry limit is reached and no RESUME arrived, the remote MAC switches to non-VC (standard) mode.


In addition, a remote device may receive multiple VC REQUEST frames. This can happen if the local device did not receive the VC ACK frame from the remote or the VC ACK frame had CRC errors. The “remote” device should send an ACK frame for each request received. However, the “remote” may send one VC ACK frame if multiple REQUEST frames are received before an ACK is sent by the “remote”. Similarly, a local device may receive multiple VC ACK frames. This could happen if the “remote” did not receive the RESUME frame or the RESUME frame has CRC errors. The local should send an ACK frame for each RESUME frame it receives. However, the local may send one RESUME frame if multiple ACKS are received before a RESUME frame is sent.


Also, if the two VC link partners find during the handshake that the other link partner supports a different version of VC specification, then the two VC devices settle for the lowest common denominator feature set between the two versions.


In general, the pause timer value indicated in the VC Handshake frame should be obeyed. In this way, pause may be asserted during the VC Handshake if required. If a non-zero pause time is specified by the VC Handshake frame, then the receiver of the frame may send further VC Handshake frames, but it should not send normal frames until the Pause time is elapsed (or until pause has been de-asserted).


In order for VC Handshake operation to operate, certain registers need to be set. Guidelines for the design of the VC Handshake mechanism in the MAC are provided below, where the following items may entail the use of multiple registers. Control of VC subsystems, such as enabling handshake, forcing renegotiation, determining manner of function enabling (automatic or software) etc., should be supported. Registers devoted to VC Status should be supported, including a Per Port register, indicating successful completion of VC Handshake and other necessary status information. Registers for the REQUEST phase timer and the REQUEST Retry limit counter, discussed above, need to be included, as well as registers for the ACK phase timer and the ACK Retry limit counter.


Additional registers are required in respective devices for capability negotiation. These include read only VC capability registers indicating the capabilities of local and remote devices and VC Local and Remote Advertisement registers. The VC Advertisement registers are usually a copy of VC Capability, and this is the actual value that is advertised by the local and remote device during the handshake. In this way, software can disable some capabilities in local and/or remote device, if desired.


Since the handshake can be initiated by both the link partners, hardware implementation can provide two advertisement registers per device. For example: 1) VC Local Client Advertisement register (read/write register) containing the values to be advertised in the ACK frame sent during the VC Handshake. This register indicates the client functions supported by the local device (which VC frames will be obeyed by the local side). 2) VC Local Server Advertisement register (read/write register) containing the values to be sent in the RESUME frame sent during the VC Handshake. It indicates the server functions supported by the local device (which VC frames the local side may generate).


In addition, other registers are not strictly required and are thus optional VC registers. For example, a VC device may implement the VC Local and Remote Advertisement register as separate registers for the ACK (client functions) and RESUME (server functions) phases of the Handshake. Thus, the local device may have a VC Remote Advertisement register initialized with the values indicated in the ACK frame received during the VC Handshake. This indicates the client functions supported by the remote device. Similarly, the remote device may have a VC local Advertisement register initialized with the values indicated in the RESUME frames received during the VC Handshake. This indicates the functions supported by the local device.


A VC Functionality Enabled register may also be required that indicates what VC functionality is actually enabled. This may be configured by software or as a result of the VC Handshake.


Lastly, with respect to the VC Handshake triggering, the VC Handshake frames are typically the first frames exchanged between the devices involved. The handshake should immediately follow the link up state. Thus, a reliable indication of link up is required.


VC Capability Exchange


The VC Handshake mechanism allows the link partners to be VC aware. At the same time, VC capabilities are exchanged between the link partners during the ACK and RESUME phases of the handshake. The link partners participating in the VC Handshake must support the VC capability registers, which consist of VC Control, Local VC Capability, Local VC Advertisement and Remote VC Advertisement registers. It is noted that each of these may be a set of registers depending on implementation, for example, if the register size of the device is smaller than the number of VC capability bits. Each type is referred to as a single register to emphasize the parallel nature of the sets.


The exchange of the capabilities is done via the VC Link Advertisement register encoded in the data payload of the VC ACK and RESUME frame. Each bit in this sequence may refer to an individual application op-code or to a collection or related application op-codes. A “1” indicates that a specific capability is enabled and “0” indicates that it is disabled. The intent of VC Capability registers is to provide the required configuration settings for the VC applications supported by both local and remote devices. In addition VC devices may implement Configuration registers which give overall control to enable/disable hardware functionality. The size of all VC Capability registers is recommended to be 32 bits for the initial version.


The bits in each VC capability register can refer to the same functionality. However, the significance depends on whether the register represents the local or remote ability. The following TABLE 1 is an implementation example to show the applications supported in one version of the VC architecture.










TABLE 1





Bit
Description







0
Device can generate Priority Selective Flow Control frames


1
Device can obey Priority Selective Flow Control frames


2
Device can generate Flow ID Selective Flow Control frames


3
Device can obey Flow ID Selective Flow Control frames


4
Device can generate Egress Priority Selective Flow Control frames


5
Device can obey Egress Priority Selective Flow Control frames


31:6
Reserved.









Each VC aware device supports the following sets of registers. The Local VC Capability Register is a read only register set. The register defines the set of capabilities of which the local device is capable. The Local VC Advertisement Register is a read/write register set. This register advertises the local VC capability to the remote. It may be initialized in one of two ways: it may be 0 to advertise no abilities by default, and thus software is required to change the register, or it may be copied from the Local VC Ability register.


The Remote VC Advertisement Register is a read only register set, but its value is determined by the VC negotiation. This register is populated by the local when it receives the ACK frame, and by the remote when it receives the RESUME frame during the handshake.


The VC Functionality Enabled Register is a read/write register set. The purpose of this register is to enable the hardware functionality of the indicated VC operations. The default value of this register may be indicated in one of two ways depending on configuration settings and is determined by the result of the VC Handshake frames. The ability to generate a certain VC frame type (that is, to be a server for this operation) is enabled if the device is capable of this function (as indicated in the Local Ability register) and the corresponding VC Frame obey function is advertised by the remote device (as indicated in the Remote Advertisement register). Alternatively, the ability to obey a certain VC frame type (that is, to be a client for this operation) is enabled if the device is capable of this function (as indicated in the Local Ability register) and the remote device is capable of generating that frame type.


VC Frame Format


The VC frame format has been developed to meet many requirements. Included in these requirements is to provide point-to-point communication, to enable end-to-end communication and enable redirection of packet to a CPU. Other requirements include allowing customer specific functionality, a scalable frame format to allow complex applications, and to enable use of Ethertype for purposes other than VC. The various formats for VC frames are described below.



FIG. 8 illustrates one embodiment of the VC frame format. The VC frame is an Ethernet II frame with an Ethertype value assigned by IEEE. The destination MAC address should be the unicast address of the directly connected device or the reserved multicast address 01-80-c2-00-00-01. It is noted that although the reserved multicast address is reserved for IEEE802.3x PAUSE frame, a VC frame with this DA should be sent only when both ends are VC aware.


The source address should be that of the device sending the VC frame. The Ethertype field represents the Ethertype value assigned by IEEE. The Protocol field represents the type of application. For VC applications this field MUST be 1. This field permits applications other than VC to use frames with this Ethertype.


The VC tag may have one of the three formats as discussed below. In the VC_TAG_TYPE0 frame format, illustrated in FIG. 9, the OPCODE0 field is of 8 bits and parameters field is of 24 bits in the first word. The parameter field can be extended is necessary and is really dependent on the o-code.


The 8-bit OPCODE0 field represents the op-code of an application and the associated function. The value of 0xFF is a reserved value, which indicates that the next 8 bits is the op-code value. If the value of OPCODE0 is other than 0xFF, then the fields following the OPCODE0 is a parameter field. The rest of this word may be occupied by parameters for Type 0 opcodes.


In the VC_TYPE_TAG1 VC tag format, illustrated in FIG. 10, the OPCODE0 field is inactive (has a value of 0xFF) and OPCODE1 is active. For OPCODE1 to be active, the value must be less than 0xFF. Up to 16 bits are available for the parameters in the first word. The width of the parameter field is dependent on the OPCODE1 value.


In the VC_TYPE_TAG2 VC tag format, illustrated in FIG. 11, the OPCODE0 and OPCODE1 field are inactive and OPCODE2 is active. For OPCODE2 to be active, OPCODE0 must be 0xFF and OPCODE1 must be 0xFF. Any parameters to these opcodes must be placed in subsequent words. The format of those depends on the OPCODE2 value. In the VC tag for priority based selective flow control, illustrated in FIG. 12, VC tag includes a priority bit map.


Auto-Negotiation


The Auto-negotiation function allows a device to advertise enhanced modes of operation it possesses to a device at the remote end of a link segment and to detect corresponding enhanced operational modes that the other device may be advertising. The complete implementation details on auto-negotiation are explained in IEEE802.3 specifications. The Virtual Channel (VC) capability is established between the two link partners by adding new bits and new registers to the IEEE802.3 specifications.


VC capable devices can use the Next-page feature in the standard Auto-negotiation arbitration mechanism to allow exchange of VC capabilities. The next page format for VC capability exchange is implementation dependent.


The above-discussed configuration of the invention is, in one embodiment, embodied on a semiconductor substrate, such as silicon, with appropriate semiconductor manufacturing techniques and based upon a circuit layout which would, based upon the embodiments discussed above, be apparent to those skilled in the art. A person of skill in the art with respect to semiconductor design and manufacturing would be able to implement the various modules, interfaces, and components, etc. of the present invention onto a single semiconductor substrate, based upon the architectural description discussed above. It would also be within the scope of the invention to implement the disclosed elements of the invention in discrete electronic components, thereby taking advantage of the functional aspects of the invention without maximizing the advantages through the use of a single semiconductor substrate.


Although the invention has been described based upon these preferred embodiments, it would be apparent to those of skilled in the art that certain modifications, variations, and alternative constructions would be apparent, while remaining within the spirit and scope of the invention. In order to determine the metes and bounds of the invention, therefore, reference should be made to the appended claims.

Claims
  • 1. A method for controlling flow between virtual channel capable network devices, the method comprising: receiving a flow message from at least one of a plurality of first network devices by a second network device, the flow message indicating congestion at the at least one first network device;receiving by the second network device, an Ethernet frame that is interpreted as a pause frame after the second network device does not acknowledge virtual channel capability;halting, by the second network device, transmission of selected packets associated with the flow message; andcontinuing transmission, by the second network device, of packets not associated with the flow message.
  • 2. The method of claim 1, wherein the flow message includes a flow identifier and halting further comprises suspending transmission of the selected packets associated with the flow identifier.
  • 3. The method of claim 1, wherein the flow message identifies priority information of the packets, and halting further comprises suspending transmission of the selected packets associated with the priority information.
  • 4. The method of claim 3, wherein the at least one first network device comprises a switch and wherein the second network device is connected to the switch and transmits packets to the switch for forwarding to a plurality of network devices connected to the switch.
  • 5. The method of claim 3, wherein the flow message further includes a criterion for resuming transmission and wherein transmission of the selected packets associated with the flow message is resumed when the criterion for resuming transmission is satisfied.
  • 6. The method of claim 5, wherein the criterion is time duration for a selective halt.
  • 7. The method of claim 2, wherein suspending transmission includes resuming transmission of the selected packets associated with the flow message when an indication is received that the congestion at the first network device is reduced.
  • 8. A first network device configured to establish one or more virtual channels with a virtual channel capable switch, wherein the first network device comprises: at least one processor operable to: receive a flow message from the switch, the flow message indicating congestion in at least one virtual channel;receive an Ethernet frame that is interpreted as a pause frame if the switch does not acknowledge virtual channel capability;halt transmission of selected packets associated with the flow message; andcontinue transmission of packets not associated with the flow message.
  • 9. The first network device of claim 8, wherein the flow message identifies priority information of the packets, and halting further comprises selectively excluding selected packets associated with the priority information.
  • 10. The first network device of claim 9, wherein the first network device is a server.
  • 11. A virtual channel capable network device comprising: a plurality of data ports for transmitting and receiving data and being configured to establish a virtual channel between the virtual channel capable network device and other virtual channel capable network devices;a local capability list residing at the virtual channel capable device, wherein the virtual channel capable network device is configured to transmit the local capability list via the virtual channel between the other virtual channel network capable devices and wherein the local capability list provides priority information of data associated with the virtual channel capable device, and wherein the priority information enables a selective flow control of transmitted and received data between the virtual channel capable network device and other virtual channel capable network devices, and wherein the virtual channel capable network device transmits an Ethernet frame that is interpreted as a pause frame after at least one of the other virtual channel capable network devices does not acknowledge virtual channel capability.
  • 12. The virtual channel capable network device of claim 11, wherein at least one of the other virtual channel network capable devices has an associated remote capability list for indicating that at least one of the other virtual channel network capable devices can perform selective flow control of the transmitted and received data.
  • 13. The virtual channel capable network device of claim 12, wherein the local capability list indicates that the virtual channel capable device can generate selective priority flow control frames.
  • 14. The virtual channel capable network device of claim 13, wherein the associated remote capabilities list further indicates at least one of the other virtual channel capable devices can obey selective priority flow control frames.
  • 15. The virtual channel capable network device of claim 14, wherein the established virtual channel permits a flow message to be transmitted between the virtual channel capable network devices, the flow message indicating congestion at one of the virtual channel capable network devices.
  • 16. A switch configured to establish a virtual channel between network devices, the switch comprising: a plurality of ports, at least one of the plurality of ports being configured with the capability to process a first flow control message having priority information received by the port, to halt transmission on the port of packets associated with the priority information while continuing to transmit packets not associated with the first flow control message to the port, andthe port being further configured with the capability to send at least one other flow control message having priority information to devices connected to the switch, and wherein the port sends an Ethernet frame that is interpreted as a pause frame after at least one network device does not acknowledge virtual channel capability.
  • 17. The switch of claim 16, wherein the switch is configured to detect memory utilization by packets associated with at least one of the priority information and an ingress port.
  • 18. The switch of claim 16, wherein the switch is configured to send the flow control message based on the occurrence of a criterion at one of the plurality of ports.
  • 19. The switch of claim 16, wherein the switch is configured to send the flow control message based on the occurrence of a criterion at one of the plurality of ports.
  • 20. The switch of claim 16, wherein the switch is configured to send a flow control message having priority information to the ingress port when memory utilization exceeds a threshold.
  • 21. An end node configured to establish a virtual channel between network devices, the end node comprising: at least one port configured with the capability to process a first flow control message having priority information received by the port, to halt transmission on the port of packets associated with the priority information while continuing to transmit packets not associated with the first flow control message, and to send at least one other flow control message having priority information to the network devices connected to the end node,wherein the end node receives an Ethernet frame that is interpreted as a pause frame from a network device that is not virtual channel capable.
  • 22. The end node of claim 21, wherein the end node is configured to detect memory utilization by packets associated with at least one of the priority information and an ingress port.
REFERENCE TO RELATED APPLICATION

This application is a continuation of U.S. patent application Ser. No. 10/173,422, filed on Jun. 18, 2002, which claims priority of U.S. Provisional Patent Application No. 60/306,870, filed on Jul. 23, 2001. The subject matter of the earlier filed applications is hereby incorporated by reference.

US Referenced Citations (436)
Number Name Date Kind
3749845 Fraser Jul 1973 A
4218756 Fraser Aug 1980 A
4333020 Maeder Jun 1982 A
4395774 Rapp Jul 1983 A
4433378 Leger Feb 1984 A
4445051 Elmasry Apr 1984 A
4449248 Leslie May 1984 A
4463424 Mattson Jul 1984 A
4519068 Krebs May 1985 A
4545023 Mizzi Oct 1985 A
4590550 Eilert May 1986 A
4599526 Paski Jul 1986 A
4649293 Ducourant Mar 1987 A
4680787 Marry Jul 1987 A
4717838 Brehmer Jan 1988 A
4721866 Chi Jan 1988 A
4727309 Vajdic Feb 1988 A
4737975 Shafer Apr 1988 A
4760571 Schwarz Jul 1988 A
4761822 Maile Aug 1988 A
4763319 Rosenblit Aug 1988 A
4777657 Gillaspie Oct 1988 A
4791324 Hodapp Dec 1988 A
4794649 Fujiwara Dec 1988 A
4804954 Macnak Feb 1989 A
4806796 Bushey Feb 1989 A
4807282 Kazan Feb 1989 A
4817054 Banerjee Mar 1989 A
4817115 Campo Mar 1989 A
4821034 Anderson Apr 1989 A
4850009 Zook Jul 1989 A
4890832 Komaki Jan 1990 A
4894792 Mitchell Jan 1990 A
4905231 Leung Feb 1990 A
4916441 Gombrich Apr 1990 A
4964121 Moore Oct 1990 A
4969206 Desrochers Nov 1990 A
4970406 Fitzpatrick Nov 1990 A
4977611 Maru Dec 1990 A
4995099 Davis Feb 1991 A
5008879 Fischer Apr 1991 A
5025486 Klughart Jun 1991 A
5029183 Tymes Jul 1991 A
5031231 Miyazaki Jul 1991 A
5033109 Kawano Jul 1991 A
5041740 Smith Aug 1991 A
5055659 Hendrick Oct 1991 A
5055660 Bertagna Oct 1991 A
5079452 Lain Jan 1992 A
5081402 Koleda Jan 1992 A
5087099 Stolarczyk Feb 1992 A
5115151 Hull May 1992 A
5117501 Childress May 1992 A
5119502 Kallin Jun 1992 A
5121408 Cai Jun 1992 A
5122689 Barre Jun 1992 A
5123029 Bantz Jun 1992 A
5128938 Borras Jul 1992 A
5134347 Koleda Jul 1992 A
5142573 Umezawa Aug 1992 A
5149992 Allstot Sep 1992 A
5150361 Wieczorek Sep 1992 A
5152006 Klaus Sep 1992 A
5153878 Krebs Oct 1992 A
5162674 Allstot Nov 1992 A
5175870 Mabey Dec 1992 A
5177378 Nagasawa Jan 1993 A
5179721 Comroe Jan 1993 A
5181200 Harrison Jan 1993 A
5196805 Beckwith Mar 1993 A
5216295 Hoang Jun 1993 A
5230084 Nguyen Jul 1993 A
5239662 Danielson Aug 1993 A
5241542 Natarajan Aug 1993 A
5241691 Owen Aug 1993 A
5247656 Kabuo Sep 1993 A
5249220 Moskowitz Sep 1993 A
5249302 Metroka Sep 1993 A
5265238 Canova Nov 1993 A
5265270 Stengel Nov 1993 A
5274666 Dowdell Dec 1993 A
5276680 Messenger Jan 1994 A
5278831 Mabey Jan 1994 A
5289055 Razavi Feb 1994 A
5289469 Tanaka Feb 1994 A
5291516 Dixon Mar 1994 A
5293639 Wilson Mar 1994 A
5296849 Ide Mar 1994 A
5297144 Gilbert Mar 1994 A
5301196 Ewen Apr 1994 A
5304869 Greason Apr 1994 A
5315591 Brent May 1994 A
5323392 Ishii Jun 1994 A
5329192 Wu Jul 1994 A
5331509 Kikinis Jul 1994 A
5345449 Buckingham Sep 1994 A
5349649 Iijima Sep 1994 A
5361397 Wright Nov 1994 A
5363121 Freund Nov 1994 A
5373149 Rasmussen Dec 1994 A
5373506 Tayloe Dec 1994 A
5390206 Rein Feb 1995 A
5392023 D'Avello Feb 1995 A
5394402 Ross Feb 1995 A
5406615 Miller Apr 1995 A
5406643 Burke Apr 1995 A
5418837 Johansson May 1995 A
5420529 Guay May 1995 A
5423002 Hart Jun 1995 A
5426637 Derby Jun 1995 A
5428636 Meier Jun 1995 A
5430845 Rimmer Jul 1995 A
5434518 Sinh Jul 1995 A
5437329 Brooks Aug 1995 A
5440560 Rypinski Aug 1995 A
5455527 Murphy Oct 1995 A
5457412 Tamba Oct 1995 A
5459412 Mentzer Oct 1995 A
5465081 Todd Nov 1995 A
5473607 Hausman et al. Dec 1995 A
5481265 Russell Jan 1996 A
5481562 Pearson Jan 1996 A
5488319 Lo Jan 1996 A
5502719 Grant Mar 1996 A
5510734 Sone Apr 1996 A
5510748 Erhart Apr 1996 A
5519695 Purohit May 1996 A
5519707 Subramanian May 1996 A
5521530 Yao May 1996 A
5533029 Gardner Jul 1996 A
5535373 Olnowich Jul 1996 A
5544222 Robinson Aug 1996 A
5548230 Gerson Aug 1996 A
5548238 Zhang Aug 1996 A
5550491 Furuta Aug 1996 A
5574724 Bales Nov 1996 A
5576644 Pelella Nov 1996 A
5579487 Meyerson Nov 1996 A
5583456 Kimura Dec 1996 A
5583859 Feldmeier Dec 1996 A
5584048 Wieczorek Dec 1996 A
5600267 Wong Feb 1997 A
5603051 Ezzet Feb 1997 A
5606268 Van Brunt Feb 1997 A
5619497 Gallagher Apr 1997 A
5625308 Matsumoto Apr 1997 A
5628055 Stein May 1997 A
5630061 Richter May 1997 A
5640356 Gibbs Jun 1997 A
5640399 Rostoker Jun 1997 A
5668809 Rostoker Sep 1997 A
5675583 Bales Oct 1997 A
5675584 Jeong Oct 1997 A
5675585 Bonnot Oct 1997 A
5680038 Fiedler Oct 1997 A
5680633 Koenck Oct 1997 A
5689644 Chou Nov 1997 A
5724361 Fiedler Mar 1998 A
5726588 Fiedler Mar 1998 A
5732346 Lazaridia Mar 1998 A
5740366 Mahany Apr 1998 A
5742604 Edsall Apr 1998 A
5744366 Kricka Apr 1998 A
5744999 Kim Apr 1998 A
5748612 Stoevhase May 1998 A
5748631 Bergantino et al. May 1998 A
5754549 DeFoster May 1998 A
5757770 Lagoutte May 1998 A
5758078 Kurita May 1998 A
5767699 Bosnyak Jun 1998 A
5778414 Winter Jul 1998 A
5796727 Harrison Aug 1998 A
5798658 Werking Aug 1998 A
5802258 Chen Sep 1998 A
5802287 Rostoker Sep 1998 A
5802465 Hamalainen Sep 1998 A
5802576 Tzeng Sep 1998 A
5805927 Bowes Sep 1998 A
5821809 Boerstler Oct 1998 A
5826027 Pedersen et al. Oct 1998 A
5828653 Goss Oct 1998 A
5829025 Mittal Oct 1998 A
5831985 Sandorfi Nov 1998 A
5839051 Grimmett Nov 1998 A
5844437 Asazawa Dec 1998 A
5848251 Lomelino Dec 1998 A
5859669 Prentice Jan 1999 A
5861881 Freeman Jan 1999 A
5875465 Kilpatrick Feb 1999 A
5877642 Takahashi Mar 1999 A
5887146 Baxter Mar 1999 A
5887187 Rostoker Mar 1999 A
5892382 Ueda Apr 1999 A
5892922 Lorenz Apr 1999 A
5893150 Hagersten Apr 1999 A
5893153 Tzeng Apr 1999 A
5903176 Westgate May 1999 A
5905386 Gerson May 1999 A
5907553 Kelly et al. May 1999 A
5908468 Hartmann Jun 1999 A
5909127 Pearson Jun 1999 A
5909686 Muller et al. Jun 1999 A
5914955 Rostoker Jun 1999 A
5920705 Lyon et al. Jul 1999 A
5937169 Connery Aug 1999 A
5940771 Gollnick Aug 1999 A
5945847 Ransijn Aug 1999 A
5945858 Sato Aug 1999 A
5945863 Coy Aug 1999 A
5951637 Kuzma Sep 1999 A
5961631 Devereux Oct 1999 A
5969556 Hayakawa Oct 1999 A
5974508 Maheshwari Oct 1999 A
5977800 Iravani Nov 1999 A
5978379 Chan Nov 1999 A
5978849 Khanna Nov 1999 A
5987507 Creedon et al. Nov 1999 A
6002279 Evans Dec 1999 A
6008670 Pace Dec 1999 A
6014041 Somasekhar Jan 2000 A
6014705 Koenck Jan 2000 A
6025746 So Feb 2000 A
6026075 Linville Feb 2000 A
6028454 Elmasry Feb 2000 A
6037841 Tanji Mar 2000 A
6037842 Bryan Mar 2000 A
6038254 Ferraiolo Mar 2000 A
6061351 Erimli et al. May 2000 A
6061747 Ducaroir May 2000 A
6064626 Stevens May 2000 A
6081162 Johnson Jun 2000 A
6088356 Hendel et al. Jul 2000 A
6094074 Chi Jul 2000 A
6097722 Graham Aug 2000 A
6098064 Piroll Aug 2000 A
6104214 Ueda Aug 2000 A
6111425 Bertin Aug 2000 A
6111859 Godfrey Aug 2000 A
6114843 Olah Sep 2000 A
6118776 Berman Sep 2000 A
6122667 Chung Sep 2000 A
6128305 Hjalmtysson Oct 2000 A
6151662 Christie Nov 2000 A
6157623 Kerstein Dec 2000 A
6178159 He Jan 2001 B1
6185185 Bass et al. Feb 2001 B1
6188339 Hasegawa Feb 2001 B1
6194950 Kibar Feb 2001 B1
6202125 Patterson Mar 2001 B1
6202129 Palanca Mar 2001 B1
6209020 Angie Mar 2001 B1
6212582 Chong et al. Apr 2001 B1
6215497 Leung Apr 2001 B1
6218878 Ueno Apr 2001 B1
6222380 Gerowitz Apr 2001 B1
6223239 Olarig Apr 2001 B1
6226680 Boucher May 2001 B1
6232844 Talaga May 2001 B1
6243386 Chan Jun 2001 B1
6259312 Murtojarvi Jul 2001 B1
6265898 Bellaouar Jul 2001 B1
6266797 Godfrey Jul 2001 B1
6269427 Kuttanna Jul 2001 B1
6279035 Brown et al. Aug 2001 B1
6310501 Yamashita Oct 2001 B1
6324181 Wong Nov 2001 B1
6332179 Okpisz Dec 2001 B1
6349098 Parruck Feb 2002 B1
6349365 McBride Feb 2002 B1
6356944 McCarty Mar 2002 B1
6363011 Hirose Mar 2002 B1
6366583 Rowett Apr 2002 B2
6373846 Daniel Apr 2002 B1
6374311 Mahany Apr 2002 B1
6377571 Tai Apr 2002 B1
6385201 Iwata May 2002 B1
6396832 Kranzler May 2002 B1
6396840 Rose May 2002 B1
6424194 Hairapetian Jul 2002 B1
6424624 Galand Jul 2002 B1
6427171 Craft Jul 2002 B1
6434620 Boucher Aug 2002 B1
6438651 Slane Aug 2002 B1
6459681 Oliva Oct 2002 B1
6463052 Christie Oct 2002 B1
6463092 Kim Oct 2002 B1
6470029 Shimizu Oct 2002 B1
6484224 Robins Nov 2002 B1
6490622 Nagami Dec 2002 B1
6493343 Garcia et al. Dec 2002 B1
6496479 Shionozaki Dec 2002 B1
6535518 Hu et al. Mar 2003 B1
6538486 Chen Mar 2003 B1
6563827 Brueckheimer et al. May 2003 B1
6564267 Lindsay May 2003 B1
6597689 Chiu et al. Jul 2003 B1
6606321 Natanson et al. Aug 2003 B1
6614791 Luciani et al. Sep 2003 B1
6614796 Black Sep 2003 B1
6630135 Cagle Oct 2003 B1
6631351 Ramachandran et al. Oct 2003 B1
6633936 Keller Oct 2003 B1
6636485 Fijolek Oct 2003 B1
6636947 Neal Oct 2003 B1
6640248 Jorgensen Oct 2003 B1
6658599 Linam Dec 2003 B1
6665759 Dawkins Dec 2003 B2
6681283 Thekkah et al. Jan 2004 B1
6757291 Hu Jun 2004 B1
6757746 Boucher Jun 2004 B2
6766389 Hayter Jul 2004 B2
6771601 Aydemir et al. Aug 2004 B1
6771602 Benmohamed et al. Aug 2004 B1
6788686 Khotimsky Sep 2004 B1
6788704 Lindsay Sep 2004 B1
6810040 Lee Oct 2004 B1
6816932 Cho Nov 2004 B2
6822940 Zavalkovsky et al. Nov 2004 B1
6845403 Chadalapaka Jan 2005 B2
6850521 Kadambi Feb 2005 B1
6859435 Lee Feb 2005 B1
6862296 Desai Mar 2005 B1
6862621 Takada Mar 2005 B2
6865158 Iwamoto Mar 2005 B2
6874054 Clayton Mar 2005 B2
6897697 Yin May 2005 B2
6904519 Anand Jun 2005 B2
6911855 Yin Jun 2005 B2
6912221 Zadikian Jun 2005 B1
6912603 Kanazashi Jun 2005 B2
6927606 Kocaman Aug 2005 B2
6937080 Hairapetian Aug 2005 B2
6938092 Burns Aug 2005 B2
6957269 Williams et al. Oct 2005 B2
6971006 Krishna Nov 2005 B2
6976205 Ziai Dec 2005 B1
6982583 Yin Jan 2006 B2
7007103 Pinkerton Feb 2006 B2
7009985 Black Mar 2006 B2
7062568 Senevirathe Jun 2006 B1
7181531 Pinkerton Feb 2007 B2
7190676 Anderson Mar 2007 B2
7212534 Kadambi et al. May 2007 B2
7239636 Kadambi et al. Jul 2007 B2
7346701 Elzur Mar 2008 B2
7362769 Black Apr 2008 B2
7366190 Black Apr 2008 B2
7376755 Pandya May 2008 B2
7382790 Warren Jun 2008 B2
7385972 Black Jun 2008 B2
7397788 Mies Jul 2008 B2
7397800 Elzur Jul 2008 B2
7400639 Madukkarumukumana Jul 2008 B2
7411959 Elzur Aug 2008 B2
7411960 Langley Aug 2008 B1
7430171 Black Sep 2008 B2
7433326 Desai Oct 2008 B2
7515612 Thompson Apr 2009 B1
7586850 Warren Sep 2009 B2
7633949 Zadikian Dec 2009 B2
20010026553 Gallant Oct 2001 A1
20010032265 Tanaka Oct 2001 A1
20010037397 Boucher Nov 2001 A1
20020078265 Frazier Jun 2002 A1
20020085562 Hufferd Jul 2002 A1
20020087723 Williams et al. Jul 2002 A1
20020089927 Fischer Jul 2002 A1
20020089931 Takada et al. Jul 2002 A1
20020095519 Philbrick Jul 2002 A1
20020103988 Dornier Aug 2002 A1
20020110087 Zelig Aug 2002 A1
20020130692 Hairapetian Sep 2002 A1
20020174253 Hayter Nov 2002 A1
20020190770 Yin Dec 2002 A1
20020194400 Porterfield Dec 2002 A1
20030001646 Hairapetian Jan 2003 A1
20030016628 Kadambi Jan 2003 A1
20030021229 Kadambi Jan 2003 A1
20030038809 Peng Feb 2003 A1
20030046330 Hayes Mar 2003 A1
20030046418 Raval Mar 2003 A1
20030061505 Sperry Mar 2003 A1
20030067337 Yin Apr 2003 A1
20030079033 Craft Apr 2003 A1
20030084185 Pinkerton May 2003 A1
20030105977 Brabson Jun 2003 A1
20030107996 Black Jun 2003 A1
20030108050 Black Jun 2003 A1
20030108058 Black Jun 2003 A1
20030108060 Black Jun 2003 A1
20030108061 Black Jun 2003 A1
20030118040 Black Jun 2003 A1
20030140124 Burns Jul 2003 A1
20030169753 Black Sep 2003 A1
20030172342 Elzur Sep 2003 A1
20030174720 Black Sep 2003 A1
20030174721 Black Sep 2003 A1
20030174722 Black Sep 2003 A1
20030198251 Black Oct 2003 A1
20030204631 Pinkerton Oct 2003 A1
20030204634 Pinkerton Oct 2003 A1
20030227908 Scoggins Dec 2003 A1
20040019652 Freimuth Jan 2004 A1
20040042458 Elzur Mar 2004 A1
20040042464 Elzur Mar 2004 A1
20040042483 Elzur Mar 2004 A1
20040042487 Ossman Mar 2004 A1
20040044798 Elzur Mar 2004 A1
20040062245 Sharp Apr 2004 A1
20040062275 Siddabathuni Apr 2004 A1
20040081186 Warren Apr 2004 A1
20040085972 Warren May 2004 A1
20040085994 Warren May 2004 A1
20040093411 Elzur May 2004 A1
20040133713 Elzur Jul 2004 A1
20040227544 Yin Nov 2004 A1
20050027911 Hayter Feb 2005 A1
20050160139 Boucher Jul 2005 A1
20050165980 Clayton Jul 2005 A1
20050184765 Hairapetian Aug 2005 A1
20050185654 Zadikian Aug 2005 A1
20050216597 Shah Sep 2005 A1
20050278459 Boucher Dec 2005 A1
20060165115 Warren Jul 2006 A1
20060176094 Hairapetian Aug 2006 A1
20070170966 Hairapetian Jul 2007 A1
20070171914 Kadambi Jul 2007 A1
20070237163 Kadambi et al. Oct 2007 A1
20080025315 Elzur Jan 2008 A1
20080095182 Elzur Apr 2008 A1
20080151922 Elzur Jun 2008 A1
20080205421 Black Aug 2008 A1
20080276018 Hayter Nov 2008 A1
20080298369 Elzur Dec 2008 A1
20090074408 Black Mar 2009 A1
20090128380 Hairapetian May 2009 A1
Foreign Referenced Citations (37)
Number Date Country
465090 Jan 1992 EP
0465090 Jan 1992 EP
0692892 Jan 1996 EP
0692892 Jan 1996 EP
0465090 Apr 1996 EP
1039718 Sep 2000 EP
1 206 075 May 2002 EP
1 280 302 Jan 2003 EP
1280302 Jan 2003 EP
0692892 Apr 2003 EP
1345382 Sep 2003 EP
1357721 Oct 2003 EP
1460804 Sep 2004 EP
1460805 Sep 2004 EP
1460806 Sep 2004 EP
1280302 Mar 2005 EP
1206075 Nov 2007 EP
1537695 Feb 2009 EP
2725573 Nov 1994 FR
2725573 Apr 1996 FR
19940012105 Apr 1996 FR
1188301 Jul 1989 JP
3-237553 Oct 1991 JP
8-331124 Dec 1996 JP
9-098165 Apr 1997 JP
10-313314 Nov 1998 JP
WO 9728505 Aug 1997 WO
WO9728505 Aug 1997 WO
9900948 Jan 1999 WO
WO9900948 Jan 1999 WO
WO0056013 Sep 2000 WO
WO 0056113 Sep 2000 WO
WO0056113 Sep 2000 WO
WO 0186910 Nov 2001 WO
WO0186910 Nov 2001 WO
WO0235784 May 2002 WO
WO03079612 Sep 2003 WO
Related Publications (1)
Number Date Country
20070237163 A1 Oct 2007 US
Provisional Applications (1)
Number Date Country
60306870 Jul 2001 US
Continuations (1)
Number Date Country
Parent 10173422 Jun 2002 US
Child 11806427 US