CA2336465A1 - System and method for switching packets in a network - Google Patents

System and method for switching packets in a network Download PDF

Info

Publication number
CA2336465A1
CA2336465A1 CA002336465A CA2336465A CA2336465A1 CA 2336465 A1 CA2336465 A1 CA 2336465A1 CA 002336465 A CA002336465 A CA 002336465A CA 2336465 A CA2336465 A CA 2336465A CA 2336465 A1 CA2336465 A1 CA 2336465A1
Authority
CA
Canada
Prior art keywords
packet
data
module
meta
port module
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA002336465A
Other languages
French (fr)
Inventor
Steven J. Schwartz
Yuval Peduel
Michael Hathaway
James D. Carlson
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
IronBridge Networks Inc
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Publication of CA2336465A1 publication Critical patent/CA2336465A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/15Interconnection of switching modules
    • H04L49/1515Non-blocking multistage, e.g. Clos
    • H04L49/153ATM switching fabrics having parallel switch planes
    • H04L49/1538Cell slicing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/30Flow control; Congestion control in combination with information about buffer occupancy at either end or at transit nodes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/32Flow control; Congestion control by discarding or delaying data units, e.g. packets or frames
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/104Asynchronous transfer mode [ATM] switching fabrics
    • H04L49/105ATM switching elements
    • H04L49/108ATM switching elements using shared central buffer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/111Switch interfaces, e.g. port details
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/113Arrangements for redundant switching, e.g. using parallel planes
    • H04L49/118Address processing within a device, e.g. using internal ID or tags for routing within a switch
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/253Routing or path finding in a switch fabric using establishment or release of connections between ports
    • H04L49/254Centralised controller, i.e. arbitration or scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/253Routing or path finding in a switch fabric using establishment or release of connections between ports
    • H04L49/255Control mechanisms for ATM switching fabrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • H04L49/3081ATM peripheral units, e.g. policing, insertion or extraction
    • H04L49/309Header conversion, routing tables or routing tags
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/60Software-defined switches
    • H04L49/606Hybrid ATM switches, e.g. ATM&STM, ATM&Frame Relay or ATM&IP
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5679Arbitration or scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5681Buffer or queue management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/43Assembling or disassembling of packets, e.g. segmentation and reassembly [SAR]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/15Interconnection of switching modules
    • H04L49/1515Non-blocking multistage, e.g. Clos
    • H04L49/1523Parallel switch fabric planes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • H04L49/3009Header conversion, routing tables or routing tags
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/50Overload detection or protection within a single switching element
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/60Software-defined switches
    • H04L49/602Multilayer or multiprotocol switching, e.g. IP switching

Abstract

A switching node for transferring packets, each including a destination address, in a network includes a plurality of input port modules, a plurality of output port modules and a switching fabric, including a packet meta-data processor and a packet switch. Each input port module is connected to a communication link for receiving packets thereover, and each output port module is connected to a communication link for transmitting packets thereover. Each input port module, upon receiving a packet, buffers the packet and generates a meta-data packet therefore identifying the output port module that is to transmit the packet and packet identifier information, and provides it to the packet meta-data processor. The packet meta-data processor receives the meta-data packets generated by all of the input port modules and operational status information from all of the output port modules and for each output port module, processes the meta-data packets received from all of the input port modules in connection with the operational status information to determine whether the packet should be passed or dropped. If the packet meta-data processor determines that a packet associated with a meta-data packet is to be dropped, it will notify the input port module in which the packet is buffered, which, in turn, will discard the packet. On the other hand if the packet meta-data processor determines that the packet associated with the meta-data packet is not to be dropped, it will enqueue the meta-data packet for the associated output port module. Each output port module retrieves meta-data packets from its respective meta-data packet queue maintained therefor by the packet meta-data processor. For each meta-data packet retrieved by an ouput port module, the output port module will request that the input port module identified in the meta-data packet transfer the packet identified in the input port module thereto through the packet switch.
When the output port module receives the packet, it will transmit it over the communication link connected thereto.

Description

SYSTEM AND METHOD FOR SWITCHING.PACKETS IN A NETWORK
FIELD OF THE INVENTION
The invention relates generally to the field of digital communications, and more particularly to systems and method fox switching packets of digital data in a switching node used in a digital data network.
BACKGROUND OF THE INVENTION
Digital networks have been developed to facilitate the transfer of information, including data and programs, among digital computer systems and numerous other types of devices. A variety of types of networks have been developed and implemented using diverse information transfer methodologies. In modern networks, information is transferred through a mesh of switching nodes which are interconnected by communication links in a variety of patterns. The mesh interconnected pattern can allow for a number of paths to be available through the network from each computer system or other device which may transmit information as a source device, to another computer system or other device, which is to receive the information as a destination device, so that if congestion develops in particular regions of the network, or if components of the network become inoperative information can be routed around the congested or inoperative portion of the network.
Information transferred from a source device to a destination device is generally transferred in the form of fixed-or variable-length packets; which are received by a switching node over one communication link connected thereto, and transmitted over another communication link to facilitate transfer of the packet to the destination device or another switching node along a path to the destination device.
Each packet typically includes address information, including a source address that identifies the particular device that generated the packet, and a destination address that identifies the particular device or devices to receive the packet.
_I_ WO 00!02347 PCT/US99/15028 Typically, a switching node includes one or more input ports, each of which is connected to a communication link to receive packets, a plurality of output ports, each of which is connected to a communication link to transmit packets, and a "switching fabric" that couples packets from the input ports to the respective outport ports for transmission: After an input port receives a packet, it will typically buffer the packet, identify from the destination address the particular output port that into transmit the packet and transfer the packet to the output port through the switching fabric. After the output port receives the packet, it (that is, the output port) will typically buffer the packet in a queue for transmission over the cornrnunication link connected thereto. While buffering and scheduling by the output port can provide for efficient packet transmission by the output port, since the output port can be kept continually busy, several problems can arise with output port buffering.
Generally, each output port will effectively provide one queue for each input port, in which case the total number of queues provided by the switching node will be on the order of Nz, where "N" is the number of input ports, which, in tum, corresponds to the number of output ports, if, as is typical, each communication link provides for bi-directional transmission of packets. Thus, as "N," the number of input/ouput ports, increases, the number of queues maintained by the output ports increases quadratically, at a much faster rate, and so output queuing does not scale well.
Instead of using output queuing of packets to be transmitted, switching nodes have been developed which can provide input queuing, in which packets are buffered and queued at the input ports. Only one queue is needed for each input port, and so, as the number of input (and output) ports increases, the number of queues increases at a linear rate, avoiding the quadratic increase with output queuing.
However, input queuing results in much lower efficiency of usage of the switching fabric, since the input ports must, after buffering received packets, essentially contend and arbitrate for use of the switching fabric to facilitate transfer of the packets to the respective output ports for transmission.
SUMMARY OF THE INVENTION
The invention provides a new and improved switching node which provi~s for the efficient use of the switching fabric interconnecting input and output ports that is characteristic of a switching node that provides for output-queuing of packets transferred by the switching node, while avoiding the quadratic increase in packet queues, relative to increasing numbers of input/output ports, that is characteristic of switching nodes that provide for output-queuing. Similarly, the invention provides a new and improved switching node which provides for the linear increase in packet queues, relative to increasing numbers of input/output ports, that is characteristic of switching nodes that provide for input queuing, while avoiding the relative inefficient usage of the switching fabric interconnecting input and output ports that is characteristic of a switching node that provides for input-queuing of packets transferred by the switching node.
In brief summary, the invention provides a switching node, including a plurality of input port modules, a plurality of output port modules and a switching fabric for transferring packets in a network, each packet including a destination address. Each input port module is connected to a communication link for receiving packets thereover, and each output port module is connected to a communication link for transmitting packets thereover. Each input port module, upon receiving a packet from the communication link connected thereto, buffers the packet and generates a meta-data packet therefor, the meta-data packet identifying the output port module that is to transmit the packet, and generates identif er information for the packet, in particular the identification of the input port module in which the packet is buffered and a pointer to the location in the input port module in which the packet is buffered.
After generating the meta-data packet, the input port module provides it to the switching fabric, in particular to a packet meta-data-processor portion thereof.
The switching fabric includes both the packet meta-data processor portion and a packet switch portion. The packet meta-data processor portion receives the meta-data packets generated by all of the input port modules and operational status information from all of the output port modules. The operational status information for each output port module includes information that is useful in making a determination for each respective output port module as to whether or not packets that would be transmitted by the respective output port module are to be discarded, or' dropped. For each output port module, the packet meta-data processor processes the meta data packets received from all of the input port modules in connection with the operational status information. If, in processing a rneta-data packet, the packet meta-data processor determines that the packet associated. with the meta-data packet is to be dropped, it will notify the input port module in which the packet is buffered, which, in turn, will discard the packet. On the other. hand,, if the packet meta-data processor determines that the packet associated with the meta-data packet is not to be i 0 dropped, it will enqueue the meta-data packet for the associated output port module.
Each output port module retrieves meta-data packets from its respective meta-data packet queue maintained therefor by the packet rneta-data processor. For each meta-data packet retrieved by an output port module, the output port module will issue a request to the input port module identified in the meta-data packet to transfer the packet identified in the input port module to it {that is, to the output port module that issued the request). The input port module, after receiving the request from the output port module, will transfer the requested packet through the packet switch portion of the switching fabric. The packet switch portion, in turn, will transfer the packet to the output port module, for transmission thereby over the communication link connected thereto.
A switching node constructed in accordance with the invention provides the scalability of a input-queued switching node, while maintaining substantially the efficiency of switching fabric usage of an output-queued switching node. Since the packets are buffered at the input port modules until the determination has been made by the packet meta-data processor that they are to be transmitted by respective output port modules, and further until they are requested by the respective output port modules for to be transferred thereto for transmission, only "N" buffers, or queues, are needed, one for each input port module, whereas in an output-queued switching node NZ buffers would be required. However, the determination as to which packets should be discarded (that is, which packets should be dropped) and which should not be {that is, which packets should be passed), is made separately for each output port WO 00/02347 PCTlUS99IIS028 module effectively-in a queue established therefor, and so the pass/drop determinations are effectively made in a manner similar to that for an output queued ' switching node. Thus, the packet switch portion of the switching fabric an achieve efficiencies similar to those achieved in output quea~ed switching nodes.
BRIEF DESCRIPTION OF THE DRAWINGS
This invention is pointed out with particularity in the appended claims. The above and further advantages of this invention may be better understood by referring to the following description taken in conjunction with the accompanying drawings, in which:
FIG. 1 schematically depicts a computer network including at least one switching node constructed in accordance with the invention;
FIG. 2 is a functional block diagram of a switching node for use in the network depicted in FIG. 1, constructed in accordance with the invention;
FIG. 3 is a functional block diagram of an input port module used in the switching node depicted in FIG. 2;
FIG. 4 is a functional block diagram of one switch plane in the inter-port packet switch used in the switching node depicted an FIG. 2;
FIG. 5 is a functional block diagram of a meta-data packet processor for processing packet meta-data in the switching node depicted in FIG. 2;
FIG. 6 is a functional block diagram of an output part module used in the switching node depicted in FIG. 1;
FIG. 7 is a functional block diagram of one embodiment of a frame forwarding engine useful in the input port module depicted in FIG. 3; and FIG. 8 is a functional block diagram of a second embodiment of a frame forwarding engine useful in the input port module depicted in FIG. 3.
DETAILED DESCRIPTION OF AN ILLUSTRATIVE-EMBODIMENT
FIG. 1 schematically depicts a computer network i 0 including a plurality of switching nodes 11(I) through 11{I~ (generally identified by reference numeral (n)) for transferring signals representing data among a number of devices, which in FIG. 1 are represented by packet source/destination devices 12{1).through 12(M) (generally identified by reference numeral 12(m)) in a wide area network {"WAN").
The packet source/destination devices 12(m), as is conventional, include a particular device; such as a computer system or other device that stores, generates, processes or otherwise uses digital data, a local area network of such devices, or the like {not separately shown) to the wide area network 10: Each packet sourceldestination device 12(m) is connected over a communication link, generally identified by reference numeral 13(p), to a switching node 11(n) to facilitate transmission of data thereto or the reception of data therefrom. The switching nodes 11 (n) are interconnected by communication links, also generally identified by reference numeral 13(p) to facilitate the transfer of information among the respective switching nodes 11(n). The communication links 13(p) may utilize any convenient information transmission medium, including, for example, wires for carrying electrical signals, optical fiber Iinks for carrying optical signals, and so forth. Each communication link 13(p) is preferably bi-directional, allowing the switching nodes I 1(n) to transmit and receive signals among each other and with customer premises equipment 12(m) connected thereto over the same Iink; depending on the particular type of medium selected for respective communication links 13(p), multiple media may be provided for transferring signals in opposite directions thereby to provide the bidirectional link.
Data is transferred in the network 10 in the form of packets. Generally, a packet includes a header portion and a data portion: The header portion includes information that assists in routing the packet through the network, with the specific information depending on the particular packet routing protocol that is used in routing packets through the network. In connection with network 10, any of a number of well-known packet routing protocols may be used; in one embodiment, 7 ' PCT/US99/150Z8 w the well-known Internet protocol ("IP")- is used. In any case, the header typically includes address information including a source address identifying the particulaf~
source device 12(ms) that generated the packet and a destination address identifying the particular destination address 12(mD) that is to receive the packet. In the IP
protocol, a packet may be of variable length and the header typically will also include length information to identify the length of the packet. The header also typically includes other information, including, for example, protocol identifier information that identifies the particular protocol that defines the stnzcture of the packet. The data portion contains the data payload of the packet: The packet may also include, as part of the data portion or otherwise, error detection information that can be used to determine whether an error occured in transferring the packet.
A source device 12(m$), after generating a packet for transfer to a destination device 12(mD), will provide the packet to the switching node 1 I (n) connected thereto.
The switching node 11(n) will use the destination address in the packet to attempt to identify a "route" which associates a destination address with one of the communication links 13(p) connected thereto over which it is to transfer the packet to forward it (that is, the packet) to either the destination device 12(mD), if the switching node 11 (n) is connected to the destination device 12 (mD),or to another switching node 11{n) (ri gin) along a path to the destination device 12(rnD).
If the switching node can identify a route for the received packet, it will forward the packet over the communication link identified by the route. Each switching node 11 (n), 11 (n"),..., which receives the packet will perform a similar operation. If all of the switching nodes have respective routes for the destination address, the packet will eventually arrive at the destination device 12(mD).
The invention provides a new switching node 11 (n), a functional block diagram of which is depicted in FIG. 2, that provides for the efficient transfer of packets through the network. With reference to FIG. 2; the switching node 11 (n) includes a number of input port modules 20( 1 ) through 20{N) (generally identified by reference numeral 20{n)) and a like number of output port modules 21 ( 1 ) through 21 (N) (generally identified by reference number 2 R (n)) interconnected by a switching fabric consisting of an inter-port packet switch 22, a packet meta-data processor 23, _7_ and a switching node management processor 27. Each input port module 20(n) includes one or more input ports 25(n)(1) through 25(n)(M) (generally identified'~by reference numeral 25(n)(m)), which are connected to respective one of the communication links 13(p) for receiving packets; represented by PKT_IN (n)(m) packet in (n)(m) signals, thereover. For each packet received, the input port module 20(n} buffers the packet and identifies from the destination address contained in the packet's header the appropriate route therefor, in the process identifying the particular output port module 21 (n) to which the packet is to be sent and one of one or more output ports 26(n)(1) through 26(n)(M) (generally identified by reference numeral 26(n)(m)) on the output port module 21(n) through which the packet is to be transmitted to facilitate forwarding of the packet to the destination device 12(rnp) or to the next switching node 11 (n~ along the path to facilitate routing of the packet to the destination device 12(rnD). Generally, the input port module 20(n) will transfer the packet to the switching fabric, in particular to the inter-port packet switch 22, as represented by INP(n)_PKT DATA input (n) packet data signals (index "n" being an integer between one and "N," inclusive). The inter-port switch,22, in turn, couples the packet, as represented by OP(n)_PKT DATA output (n) packet data signals (index "n" being an integer between one and "N," inclusive), to the identified output port module for transmission.
As noted above, each output port module 21 (n) includes one or more output ports 26(n)(rn), each of which is connected to one or more communication links 13(p). The output port module 21(n), in turn, transmits over the communication Iinks 13(p) respective ones of the packets, as represented by: PKT OUT packet out signals, that are provided thereto by the switching fabric.
The inter-port packet switch 22, which couples packets from the input port modules 20{n) to the respective output port modules 21 (n), is in the form of a crosspoint switch. More specifically, the inter-port packet switch 22 is in the form of a plurality of switch planes 22(1 ) through 22(P) (generally identified by the reference numeral 22(p)), each of which is in the form of a crosspoint switch.
Generally, each input port module 20(n), when it transfers a packet to the inter-port packet switch 22, divides the packet into a series of segments which are transferred to the successive _g_ switch planes-22(m) of the inter-port packet switch 22 on a round-robin basis:
Similarly, each output port module 21(n), when it receives a packet from the inter=
port packet switch 22, will receive successive packet segments from the successive switch planes 22(m) on a round-robin basis, and will re-assemble the segments into a S packet prior to transfer through their respective output ports 26(n)(m).
Providing multiple switch planes 22(p) in the inter-port packet switch 22 allows for more rapid switching of packets through the inter-port packet switch, allowing for higher through-put of packets from the input port modules 20(n) to the output port modules 21 (n). In addition, if a switch plane 22(p) fails or otherwise malfunctions, it can be taken out of the round-robin, and the inter-port packet switch 22 will allow for continued satisfactory switching using the other switch planes 22(p'} (p'~p}.
In one embodiment, the determination of whether a switch plane 22(p) has failed or otherwise malfunctioned, such that it should be taken out of the round-robin, is based on the bit error rate of the switch plane 22(p) in transferring packet segments from i5 the input port modules 20(n) to the respective output part modules 21 (n}.
The switching node management processor 27 performs a number of management functions for the switching node 11 (n}, which will be apparent to those skilled in the art, including, for example; maintaining and updating the route information used by the input port modules 20(n) in identifying, for respective packets, an appropriate output port module 21 (n) and output port 26(n)(m) through which the packets are to be transmitted. In addition, the switching node management processor 27 receives bit error rate information for the respective switching planes 22(p) and controls switching of the switch planes 22(p) into and out of the round-robin in response thereto.
In accordance with the invention, in connection with controlling the transfer of packets from each input port module 20(n) to the respective output part modules 21 (n) through the switching fabric, after an input port module 20(n) receives a packet over a communication link 13(p) connected thereto, it will buffer the packet and generate a mesa-data packet therefor describing the packet, including a pointer to the packet in the input port module 20{n) and the route information, including identification of the output port module 21 (n) that is to receive the packet and the output port 26(n)(m) through which the. packet is to be transmitted, and perhaps and indication of the length of the packet. After the input port module 20(n) generatds a meta-data packet for the packet, it will provide the meta-data packet, as represented by INP(n) META-DATA/RESP input (n) meta-datalresponse signals, to the packet meta-data processor 23 in the switching fabric for processing.
The packet meta-data processor 23 also receives information, represented by OP(n) CTRL/STATUS output port module 21 (n) control/status signals, from the respective output port modules 21 (n) concerning their operational status, in particular their respective capacities at any point in time to receive additional packets from the input port modules 20(n) for transmission. The output port module 2I (n) status information may reflect the conditions ofa number of factors, including, for example, the arriount of buffering that the output port module 21 (n) has available for packets received from the input port modules 20(n) prior to transmission (ar, conversely, the amount of buffering currently occupied with packets to be transmitted) whether the available buffering is decreasing, increasing or substantially constant, and the like, all of which will provide an indication of the output part module's capacity to receive packets associated with respective meta-data packets.
After receiving a meta-data packet for each packet from the respective input port module 20(n), the packet meta-data processor 23 will determine whether the current status information that is associated with the output port module 21 (n) which is to transmit the packet, indicates that the output port module 21 (n) has sufficient capacity to receive the packet from the input port module 20{n) and transmit it (that is, the packet) over the respective communication link I3(p). If the packet meta-data processor 23 makes a positive determination, that is, if it determines that the current status information associated with the output port module 21 (n) which is to transmit the packet indicates that it (that is, the output port module 21 (n)) has sufficient capacity to receive the packet and transmit it, then the packet rneta-data processor 23 will provide the meta-data packet, represented by the OP(n) CTRL/STATUS
signals, to the respective output port module 21(n)~
The output port module 21 (n), after it receives a meta-data packet from the packet meta-data processor 23 associated with a packet which it (that is, the output WO 00/02347 PCT/US9911502$
port module 21{n)) is to transmit; will subsequently provide a packet request, represented by the OP(n)IINP(n) PKT REQ output(n)linput(n) packet request st'gnaI
(indices "n" in both cases being integers, whose values may differ); to enable the input port module 20{n) that is buffering the packet to transfer the packet thereto through the inter-port packet switch 22. After receiving the packet request from the output port module 21(n), the input port module 20(n), transmits the packet, represented by INP(n)TPKT DATA input (n) packet data signals, to the inter-port packet switch 22, which, in turn, couples the packet, represented by OP(n) PKT DATA output{n) packet data signals, to the output port module 21{n) , for transmission as described above.
On the other hand, if the packet meta-data processor 23, after receiving from an input port module 20(n) a meta-data packet for a packet, determines that the operational status of the output port module 21 (n) that is to transmit the packet indicates that the capacity of the output port module 21(n) is such that the output port module 21(n) will not be able to transmit the packet, it (that is, the packet meta-data processor 23) will provide a notification, represented by the INP(n) META-DATAlRESP input(n) meta-datalresponse signals, to the input port module 20(n) from which the meta-data packet was received. This may occur if, for example, the status information associated with the output port module 21(n) as maintained by the packet meta data processor 23 indicates that the output port module 21(n) is congested when the input port module 20(n) provides to the packet meta-data processor 23 the meta-data packet for a packet that would otherwise be transmitted by the to output port module 21{n). In that case, since the output port module 21(n) will be unable to transmit the packet, the input port module 20{n) can discard it {that is, the packet) to free buffer space for additional packets that may be received over the communication Links connected thereto. In addition, the packet meta-data processor 23 will discard the meta-data packet associated with the packet to be discarded, instead of forwarding the meta-data packet to the output port module 21 (n). Unless the input port module 20(n) receives a notification from the packet meta-data processor 23 that the packet is to be discarded, it will normally be requested by the output port module 21 (n) for transmission over one of the w0 00/02347 PCT/(JS99/1502$
communication links 13(p) connected thereto.
Accordingly, it will be appreciated that decisions within the switching node 11 (n) as to whether a packet that is received over the network, will be transmitted by the switching node, is made by the packet meta-data processor 23, in response to a S meta-data packet provided thereto by the input port module 20(n) and based on operational status information provided thereto by the output port modules 21 (n). If the packet meta-data processor 23 determines, after receiving a meta-data packet for a packet, that the output port module 21(n) that is to transmit the packet has the capacity to receive and transmit the packet, the packet meta-data processor 23 will provide the rneta-data packet for the packet to the output port module 21 (n), which, in turn, will initiate forwarding of the packet to it (that is, the output port module 21(n)) by the input port module 20(n) to facilitate transmission of the packet by the output port module 21 (n). On the other hand, if the packet meta-data processor 23 determines, after receiviing the meta-data packet for a packet, that the output port module 21 (n) that would transmit the packet does not have the capacity to receive and transmit the packet, the output port module 21 (n) will not receive the meta-data packet for the packet, but instead the packet meta-data processor 23 will enable the input port module 20(n) to discard the packet. The input port module 20(n) will buffer the packet until it receives either notification from the output port module 21 (n) to forward ("pass") the packet to it (that is, the output port module 21 (n)) for transmission, or notification from the packet meta-data processor 23 to discard ("drop") the packet, thus the input port module 20(n) provides for input queuing of the packets received thereby.
On the other hand, the packet meta-data processor 23 effectively provides for output queuing of information used in making the pass/drop decision. However, since the packet "pass/drop" decision made by the packet meta-data processor 23 can be made on a meta-data packet which typically will be much smaller that the size of the packet, and which need include only a pointer to the packet in the input port module 20(n) which received the packet, the identification of the output port module 2I(n) which is to receive the packet for transmission, and perhaps the length of the packet, the amount of data transferred to the packet meta-data processor 23 is significantly smaller that the amount of data typically transferred in a conventional output-queued arrangement, which is generally the entire packet. Thus, the switching node 11 (n) constructed in accordance with the invention avoids use of packet-switching bandwidth to transfer packets to the output port module 21 (n) that will ultimately be discarded thereby, as is typical of output-queued switching nodes.
Further, since the output port module 2I(n) that is to transmit a packet enables the input port module 20(n) that is buffering the packet to transfer it (that is, the packet) through the inter-port packet switch 22 to the respective output port module 21 (n) when it, is to transmit the packet, the inter-port switch 22 is able to operate at a much higher degree of efficiency that is characteristic of input-queued switching nodes.
Functional block diagrams of an input port module 20(n), a switch plane 22(m), a packet meta-data processor 23 and an output-port module 21 (n) used in the switching node 11 {n) depicted in FIG. 2 are depicted in FIGs. 3, 4, 5, and 6, respectively. With reference to FIG. 3, an input port module 20(n) used in the switching node 11(n) includes a network input interface 30, a packet memory 31, a .
meta-data packet generator 32, all controlled by an input port module 20(n) control circuit 33. The network input interface 30 includes the input ports 25(n){m), which are connected to receive the PKT IN(n)( 1 ) through PKT_IN(n)(M) (generally;
PKT IN(n)(m)) packet input signals that are representative of packets over respective communication links 13(p}. In one embodiment, each input port 25(n)(m} farms part of an add/drop multiplexer constructed in accordance with the well-known SONET
specification, although it will be appreciated that other types of input ports may be used. The network input interface 30 couples the received packets as PKT_DATA
packet data signals to the input port module 20(n) control circuit 33. The input port module 20(n) control circuit 33, in turn, buffers the packets received from the network interface 30 in the packet memory 31.
In addition, for each buffered packet, the input port module 20(n) control circuit 33 provides information to the meta-data packet generator 32 to enable it (that is, the mesa-data packet generator 32) to generate meta-data packet for the packet.
The information provided to the meta-data packet generator includes such WO 00102347 PCT/US9911502$
information as the destination address for the packet; a pointer to the packet in the packet memory 31, and perhaps information as to the length of the packet. The ~net~-data packet generator 32, which stores route information provided thereto by the switching node management processor 27, uses the destination address for the packet to identify the output port module 21 (n) and the output port 26(n)(m) thereof that is connected to the communication link 13(p) over which the packet is to be transmitted. If the meta-data packet generator 32 is able to identify, from the route information, an appropriate output port module 21 {n} and output port 26(n)(m), the meta-data packet generator 32 generates therefrom and from the 'pointer to the packet in the packet memory, and perhaps the packet length information, a meta-data packet for the packet and provides the meta-data packet to the packet meta-data processor 23, as represented by INP(n) M-D ENQ input(n) meta-data packet enqueue signals.
As will be described below, the meta-data packet generator 32 specifically determines, from the destination address provided by the input port module 20(n) control module 53, the identification of the output port module 21(n) that is to receive the packet and the output port module 26(n)(m) through which the packet is to be transmitted, and provides that identification along with an identifier for the input port module 20(n), the pointer to the packet in the packet memory, and perhaps the length information, to the packet meta-data processor 23 as the meta-data packet.
As noted above; the switching node may not have appropriate route information for Borne destination addresses. If the meta-data packet generator determines that it does not have route information for a destination address provided thereto by the input port module 20{n) control circuit 33, it (that is, the meta-data packet generator) can so notify the input port module 20(n) control circuit 33. The input port module 20(n) control circuit 33 can, in turn, perform predetermined operations as will be apparent to those skilled in the art, which may include, for example; discarding the packet associated with the destination address from the packet memory. In addition, the input port module 20(n) control circuit 33 can itself generate a packet for transmission to the source device I2(ms) for the packet indicating that the packet was not delivered to the destination device 12(rnD) to which it was addressed. The input port module 20(n) control circuit 33 can enable the WO 0010234? PCT/US99/15028 generated packet to be transferred in the same manner-as packets received thereby.
The mete-data packet generator 32 also receives two control signals from the ' packet mete-data processor, including an INP(n) EN~DRP input(n) enqueue drop signal and an INP(n) PKT DRP input(n) packet drop signal. If the packet mete-data processor 23 is unable to receive the mete-data packet from the mete-data packet generator 32, which may occur if the packet mete-data processor 23 is congested as described below in connection with FIG. 5, when the mete-data packet generator attempts to provide a mete-data packet thereto, the packet mete-data processor will assert the INP(n) EN~DRP input(n) enqueue drop signal to indicate that it is.
unable to accept the mete-data packet. If the mete-data packet generator 32 receives the asserted INP(n) ENQ_DRP input(n) enqueue drop signal from the packet mete-data processor 23 when it (that is the mete-data packet generator 32) provides a mete-data packet thereto, the mete-data generator 32 will enable the input port module 20(n) control circuit 33 to discard the packet from the packet memory 3I . On the other hand, if the packet mesa-data processor 23 is able to receive the mete-data packet from the mete-data packet generator 32, it will not assert the INP(n) EN~DRP input(n) enqueue drop signal, but instead will accept the rneta-data packet for processing.
As noted above, the packet mete-data processor 23 processses mete-data packets accepted thereby to determine whether the current status information that is associated with the output port module 2l{n) which is to transmit the packet, indicates that the output port module 21 (n) has sufficient capacity to receive the packet from the input port module 20{n) and transmit it (that is, the packet) over the respective communication link 13(p). If the packet mete-data processor 23, after accepting the mete-data packet for processing, makes a negative determination, that is, if it determines that the output port module 2I {n)-does net have sufficient capacity to receive and transmit the packet, it (that is, the packet mete-data processor 23) will assert the INP(n) PKT DRP input(n) packet drop signal, in the process providing an identification of the particular packet buffered by input port module 20(n) that is to be dropped. If the mete-data packet generator 32 receives the asserted INP(n) PKT DRP input(n) packet drop signal from the packet mesa-data processor 23, it will notify the input port module 20(n) control circuit 33, which, in turn; will discard the packet identified by the INP(n)_PKT DRP input(n) packet drop sigxi~l from the packet memory.
The input port module 20(n) control circuit 33 also receives packet transfer requests from the output port modules 21 (n) and, using a packet segment generator 34, controls retrieval and transfer of packets from the packet memory 31 to the inter-port packet switch 22 for transfer to the output pork modules 21 (n). The packet transfer requests are represented by OUT(1}/TNP(n) PKT REQ output (1)/input(n) packet request through OUT(I~/INP(n) PKT REQ output(N)/input (n) packet request signal (generally, "OUT(n')/INP(n} PKT REQ," where index "n" is an integer between one and "N," and may, but need not, equal the value of index "n"), and the packet data provided by the input port module 20(n) is represented by the INP(n) PKT DATA input (n) packet data signal. After the input port module 20(n) control module 33 receives a packet transfer request from an output part module 21 (ri ), which packet transfer request includes a pointer to the packet to be provided in response to the request, the input port module 20(n) control circuit 33 enables the packet segment generator 34 to retrieve the requested packet from the packet memory 31, divide the packet into the respective segments transfers them, as INP(n)_PKT DATA PLN( 1 } input packet data plane ( 1 ) through INP(n)_PKT DATA PLN(P) input packet data plane (P) signals (which together form the INP(n) PKT DATA input (n) packet data signals) to the inter-port packet switch 22, along with the identification of the output part module 21 {ri }
that is to transmit the packet. As described-above in connection with FIG. 2; the inter-port packet switch 22, in turn, will transfer the packet received from the input port module 20(n) to the output port module 2I(ri ) for transmission.
A functional block diagram of a switch plane 22(p) used in the inter-port packet switch 22 is depicted in FIG. 4. With reference to FIG. 4, the switch plane 22(p) includes a plurality of switch modules 60(p)(1) though 60 (p)(N) (generally identified by reference numeral 60(p)(n)), each of which is associated with and provides packet segments from packets to be transferred to the correspondingly-indexed output port module 21 (n). Each switch module 60(p)(n) includes a FIFO

WO 00/02347 P~'1US99/15028 {first-in-first out buffer) module 61 (p)( 1 ) though 61 (p){N) (generally identified by reference numeral 61 {p)(n)), each of which includes a plurality of FIFO's 62(p)(n')( I )' through 62(p)(n)(F) (generally identified by reference numeral 62(p)(n)(fj).
Each switch module 60(p)(n) also includes a plurality of input multiplexers 63(p}(n)(1) through 63(p)(n)(F) (generally identified by reference numeral 63{p)(n)(f)), each of which provides an input to the correspondingly indexed FIFO 62I (p)(n)(f), end one output multiplexes 64(p)(n). Each input multiplexes 62(p)(n)(f) controlled by the switching node management processor-27 (FIG. 2) to enable it to couple the INPUT(n)-PKT DATA (PLN~) input (n) packet data (plane (p)) signals from an input port module 20(n) to the FIFO 62(p)(n)(f) connected thereto, when the packet segment represented by those signals is to be transferred to the correspondingly-indexed output port module 21 (n) for transfer over the network. The output multiplexes 64(p)(n) in each switch module 60(p)(n) is controlled by the respective output port module 21 {n) to enable it (that is, the output port module 21 (n) to receive packet segments from the various FIFO's 62(p)(n)(f} in the switch module 60(p)(n) associated therewith. Generally, each output port module 21(n) will control the multiplexes 64(p)(n) to enable it (that is, the output port module 21 (n)) to receive packet segments from all of the various FiFO's 62(p)(n)(f) in which input port modules 20(n) are loading packet segments on a round-robin basis, so as to avoid having one or more of the FIFO's becoming full which may occur if the output port module 21 (n} receives packet segments for a complete packet from one FIFO
62(p)(n}(f) at a time.
It will be appreciated that, if there are "N" FIFO's in each switch module 60(p)( 1 ) (that is, if "F" is edual to "N"), then the inter-port packet switch 22 will effectively be non-blocking, all of the input packet modules 20(n) will be able to transfer packets to any of the output port modules at any point in time.
A functional block diagram of packet meta-data processor 23 used in the switching node 11 (n) depicted in FIG. 2 is depicted in FIG: 5. With reference to FIG. 5, the packet meta-data processor 23 comprises a plurality of processor modules 40(1) through 40(N) (generally identified by reference numeral 40(n)), each of which is associated with, and makes packet passldrop determinations for, the _I7_ WO 00l0Z347 PCT/US99115028 - correspondingly-indexed output port module 2I(n). The processor modules 40(n) are all generally similar. Each processor module 40(n) includes an input queue 41 (n~; a packet pass/drop circuit 42(n), an output port module (n) status information store 43(n) and an output FIFO (first in/first out buffer) 44(n). The input queue 41(n) receives meta-data packets from all of the input port modules 20(n) and organizes them in a single queue for processing by the packet passldrop circuit 42{n).
The input queue 41 (n) receives the meta-data packet enqueue requests, represented by the INP( 1 ) M-D_ENQ input( 1 ) meta-data packet enqueue through INP(N) M-D ENQ
input(N) meta-data packet enqueue signals (generally, "INP(n) M-D ENQ"). Each meta-data packet enqueue request includes the meta-data packet as generated by the meta-data generator 32, which, as rioted includes an identifier for the input part module 20(n), the pointer to the packet in the packet memory, and perhaps the length information identifying the length of the packet associated with the meta-data packet.
If, when a meta-data packet enqueue request is received from an input port i 5 module 20(n), the processor module 40(n) is able to receive and enqueue the meta-data packet in the input queue 41 (n), it will do so. However, if, when a meta-data packet enqueue request is received from an input port module 20(n), the processor module 40(n) is not able to receive and enqueue the meta-data packet in the input queue 41 {n), it will so notify the input port module 20(n) by asserting the INP(n) ENQ_DRP input(n) enqueue drop signal. This may occur if, for example, the input queue 41 (n) is full or if the population of rneta-data packets in the input queue 41 (n) is above a predetermined threshold. As noted above, if the processor module 40(n) notifies an input port module 20(n) that it is not able to receive and enqueue a meta-data packet therefrom, by asserting the lNP(n) ENQ_DRP input (n) enqueue drop signal, the input port module 20(n) will discard the packet associated with the meta-data packet.
The input queue 41 (n) couples the meta-data packets enqueued therein in order to the packet pass/drop circuit 42(n). The packet pass/drop circuit 42(n), in turn, for each meta-data packet coupled thereto by the input queue 41 (n), makes a passliirop determination based on status information for the output port module 21 (n) associated with the processor module 40(n), which is stored in the output port module {n) status information store 43(n}. The status information in the providei'~ ' store 43(n) is provided by the associated output port module. 21(n), as represented by the OP PORT(n) STATUS output port (n) status signal; which forms one of the OUT(n)_CTRL/STATUS output (n) control/status signals that is depicted in FIG.

as being transferred between the packet meta-data processor 23 and output port module 21(n). The output port status information stored in the store 43(n) reflects the output port module's operational status, in particular its capacity at any point in time to receive additional packets from the input port modules 20(n) for transmission, and may be a function of the amount of buffering that the output port module 21 (n) has available to buffer packets retrieved from the input port modules 20(n) for transmission, and whether the available buffering is increasing, decreasing or substantially constant. When the packet pass/drop circuit 42(n) receives a meta-data packet from the input queue 41 and makes a passldrop determination in connection therewith, if the status information in the store 43(n) indicates that the output port module 21 (n) has the capacity to receive additional packets from the input port modules 20(n) for transmission, it (that is, the packet pass/drop circuit 42{n) will load the meta-data packet in the output FIFO 44(n). The packet pass/drop circuit 42 can also adjust the status information as stared in the status information store 43(n) to reflect the fact that a meta-data packet for an additional packet to be retrieved and transmitted by the output port module 21 (n) has been loaded into FIFO
44(n). For example, if the meta-data packet provides length information identifying the length of the packet associated with the meta-data packet, and if the status information in store 43(n) provides information as to the amount of buffering the output port module 21(n) has available, the packet pass/drop circuit 42(n) can, for example, decrement the status information stored in the store 43(n) to reflect the length of the packet associated with the meta-data packet.
On the other hand, when the packet pass/drop circuit 42(n) receives a meta-data packet from the input queue 41 and makes a pass/drop determination in connection therewith, if the status information in the store 43(n) indicates that the output port module 2I (n) does not have the capacity to receive additional packets from the input port modules 20(n) for transmission, it will provide a drop notification to the input port module 20(n) from which the meta-data packet was received, as'~
represented by the asserted INP(n) PKT DRP input (n) packet drop signal, and provide therewith a pointer to the packet that is associated with the meta-data packet.
As described above, when the input port module 20(n) receives the notification from the processor module 40(n), it (that is, the input part module 20(n)) can discard the packet.
The output FIFO 44(n) is connected to provide the meta-data packets to the output port module 21 (n) that is associated with the processor module 40(n).
When the output port module 21 (n) deten~nines that it is in condition to receive the packet from the input port module 20(n), it will provide an output FIFO retrieval request, represented by the asserted OUT(n) FIFO RETR EN output(n} FIFO retrieval enable signal, which comprises one of the OUT(n)~CTRL/STATLTS output(n) control status signals that is depicted on FIG. 2 as being transferred between the packet meta-data processor 23 and the output port module 21 (n). In response to the output FIFO retrieval request from the output port module 2I (n), the processor module 40(n) will transfer to the output port module 21 (n) the meta-data packet, as represented by a PKT NiETA-DATA packet meta-data signals, which comprises OUT(n} CTRL/STATUS output(n) control status signals that is depicted on FIG. 2 as being transferred between the packet meta-data processor 23 and the output port module 21(n), that is at the head of the output FIFO 44(n}.
After an output port module 21 (n) retrieves a meta-data packet from its associated processor module 40(n) (FIG. 5) in the packet meta-data processor (FiG. 2), it (that is, the output port module 2I(n}) will enable the input port module 20(n) in which the packet is buffered to transfer the packet to it through the inter. port packet switch 22. A functional block diagram of the output port module 21 (n}
used in switch 11 (n) is depicted in FIG. 6. With reference to FIG. 6, the output port module 21(n) includes an output port module 21(n) control circuit 50, a packet memory 51 and a network output interface 52. The output port module 21 (n) control circuit 50 connects to the other components of the switching node 11 (n) and - (i) provides, to the processor module 40(n) associated with the output port module 2i(n) in the packet meta-data processor 23 for use in its pass/drop '' determinations, and 'updates the operational status information that reflects the current capacity of the output port module 21 (n) to receive packets from the input port modules 20(n) for transmission over the communication Iinks 13(p) connected thereto;
(ii) retrieves meta-data packets from the processor module 40(n) which the packet passldrop circuit 42(n) has passed and loaded into the output FIFO
44(n), and (iii) initiates transfer by the respective input fort modules 2U(n) of the packets associated with the retrieved meta-data packets (reference item (ii) above) to the output port module 21 (n) through the inter-port packet switch 22.
Generally, the output port module 21 (n) control circuit 50 generates meta-data packet retrieval requests, represented by the OUT(I~ FIFO RETR EN output port module 21 (n) FIFO retrieval enable signal, and provides them to the packet meta-data . processor 23, in particular to the output FIFO 44(n) of the processor module 40(n) that is associated with the output port module 21(n) to initiate retrieval of a rneta-data packet (reference item (ii) above). In response to each rneta-data packet retrieval request, the output FIFO 44(n) will, if it has a rneta-data packet for the output port module 21(n), provides a meta-data packet, as represented bythe PKT META-DATA signals, to the output port module 21 (n) control circuit 50.
After retrieving a meta-data packet, the output port module 21 (n) control circuit 50 will enable the input port module 20(n) identified in the meta-data packet to transfer the packet to the output port module 21{n) (item {iii) above). In that operation, the output port module 21 (n) control circuit 50 will generate a packet transfer request, represented by the OUT{n)IiNP(n ) PKT REQ
output{n)/input(n') packet request signal, for transfer to the input port module 20(ri ) that is buffering the packet. Each packet transfer request includes the pointer to the packet to be transferred, which the output port module 2I (n) control circuit 50 obtains from the retrieved meta-data packet. As noted above in connection with FIG. 3, after the input port module 20(ri ) receives the packet transfer request, it retrieves the packet from its internal buffer and pxovides the packet to the inter-port packet switch 22 for transfer to the output port module 21 (n).
The inter-port packet switch 22, in turn, will transfer the packet to the out~iut port module 21 (n) control circuit 50, as represented by the OUT(ri) PKT DATA
output(n} packet data signal. More specifically, the various switch planes 22(p) comprising the inter-port packet switch 22 provide respective OP(n) PKT DATA~PLN 1 ) output (n) packet data (plane 1 ) through OP(n} PKT DATA (PLN P) output (n) packet data (plane P) signals, representing respective packet segments, to a segment/packet generator 54. The segment/packet generator 54 serves to regenerate the various packets to be received from the inter-port packet switch 22, which will be buffered in the packet memory 51 prior to transfer.
After the output port module 21 (n) control circuit 50 receives a packet from the inter-port packet switch 22, it will be provided to the network interface 52 for transmission over the appropriate communication link 13(p). Generally, prior to transmission, the output port module 21(n) control circuit 50 will buffer the packet in the packet memory 5I . The network output interface 52 includes the output ports 26(n}(m), which are connected to conununication links 13(p) to facilitate transmission of packets, represented by PKT_OUT(n)(I) through PKT OUT(n)(M}
(generally, PKT~OUT(n)(m)) packet input signals. In one ennbodiment, each output 20' port 26(n}(m) forms part of an add/drop multiplexer constructed in accordance with the well-known SONET specification, although it will be appreciated that other types of input ports may be used.
As noted-above, the output port module 21 {n) control circuit 50 also provides and updates the operational status information that reflects the current capacity of the output port module 21{n) to receive packets from fhe input port modules 20(n) for transmission over the communication links 13(p} connected thereto, to the processor module 40(n) associated with the output port module 21 (n) in the packet meta-data processor 23 for use in its pass/drop determinations {reference item (i) above). In that connection, the operational status information will preferably reflect the amount ofbuffering that is available in the packet memory 51, and may also indicate whether the amount is increasing, decreasing or remaining constant, all of which provide information as to the capacity of the output port module's current ability to receive packets from the input port modules 20(n). It will be appreciated that, if the operational status information reflects the amount of buffering available in the packet memory, as the output port module 21(n) transmits packets it can update the operational status information by enabling the information in the status information store 43(n) to be incremented by a value reflecting the lengths of the respective packets.
As noted above, and with reference to FIG. 3, the input part module 20(n) control circuit 33 provides to the metes data generator 32 information regarding each packet received from the network input interface 30 and buffered in packet memory 3I, including the destination address and a pointer to the packet in the memory 31, and the metes-data generator 32 generates a metes-data packet therefor for transfer to the packet metes-data processor 23. In generating the metes-data packet, the metes-data generator 32 identifies, from the destination address, the appropriate route, if it has one, which identifies the particular output port module 21 (n) that is to receive the packet and the one of the output ports 26(n)(m) through which the packet is to be transmitted to transmit the packet to the destination device 12(mD) or the next switching node in the network along the path to the destination device 12(mD).
By way of background, in one embodiment, in which the IP packet routing protocol is used, the appropriate route for a packet is not necessarily identified based on an exact match between the destination address in the packet and the switching node's route information. Instead, the appropriate route is selected based on a match between the longest "prefix" in the destixsation address, the prefix comprising the high-order bits of the destination address. As noted above, each route includes address information and the identification of an output port module 21 (n) and the output port 26(n)(m), and a match is determined by comparing the prefix and the address information portion of the route. Currently, an IP address (a source address or a destination address as used above) is in the form of a thirty-two bit integer having the form A3,...Ao, where each "A;" is a binary digit. Thus, the appropriate route is the one for which the longest series of bits A3,...A~ (that is, for which index "j" is a minimum) matches the address information in a route as maintained by the switching node. If no match is found for a destination address, then the switching node does not have a route for the particular destination address. ~ ' Several mechanisms may be used to determine such matches. For example, routing information may be organized in the form of a plurality of tables, with each table storing routing information for a particular prefix length. In that case,-the tables can be processed in order, from the table associated with the longest prefix length to the shorter prefix lengths. The first route far which a match is found in a table between the destination address's prefix and the address information stored in the table is the appropriate route; if not match is found in any of the tables, then the switching node does not have a mute for the destination address. However, several problems arise in connection with such an arrangement, most notably that a number of tables may need to be generated and maintained by the switching node, which can add to the complexity of the switching node and the amount of memory required to store the respective tables. In addition, in the general case, a number of tables may be accessed when obtaining routing information for an address, in particular to identify the table which has the appropriate routing information for the address.
These problems will be exacerbated if, as currently proposed, the number of address bits used in Internet addresses increases to 128 bits.
To address these problems, the meta-data generator 32, in one embodiment, makes use of a compressed retrieval tree ("trie") arrangement, and, in an alternate embodiment, makes use of a binary search tree arrangement, to generate the routing information for Internet addresses coupled thereto by the input port module control circuit 33 (FIG. 2). A functional block diagram of the compressed retrieval tree arrangement, identified by reference numeral 70, is depicted in FIG. 7, and a functional block diagram of the binary search tree arrangement, identified by reference numeral 90, is depicted in FIG. 8. In both embodiments, the meta-data generator 32 generates routing information in a pipelined fashion in a plurality of pipeline stages, in each stage performing an operation, as described below in connection with FIGS. 7 and 8, in generating the appropriate routing information.
Since the information is generated in a pipeiined fashion, the meta-data generator 32 can be performing various processing operations in connection with Internet WO 00/0234'7 PCT/US99II5028 _. addresses from a plurality of packets contemporaneously, while reducing the number of tables which might otherwise need to be accessed. '~ ' With reference initially to FIG. 7, the compressed retrieval tree arrangement 70 includes a plurality of address registers 71 ( 1 ) through 71 (N-1 ) (generally identified by reference numeral 71(n)), each associated with one of a plurality of stages 72(1) through 72{N-1). An "N-th" stage 72(N) is also provided, for use as described below. Stages ?2(1) through 72(1 will generally be identified herein by reference numeral 72(n). Generation of the routing information proceeds in a series of pipeline stages in which, (i) in a first pipeline stage, address register 71(1) initially receives the Internet address for the packet for which routing information is to be generated, and thereafter the associated stage 72(1) uses a predetermined number of high-order address bits; in two address fields, identified in FIG. 7 as "ADRS FIELD 0" and "ADRS FIELD_l" to generate information that is coupled to stage 72(2);
(ii) in a second pipeline stage, the Internet address in stage 71(1) is transferred to address register 71{2). The information coupled by stage 72(1) to stage 72(2), along with a predetermined number of address bits following the high-order address bits, identified in FIG. 7 as "ADRS FIELD 2," from the Internet address now in address register 7I(2), is used by stage 72(2) to generate information that is coupled to stage 72(3), and so forth until, (N-1) in a last~'N-1st" pipeline stage, the Internet address in stage "N-1" is transferred to address register 71 (N-1 ). The information coupled by stage 72(N-2) to stage 72{N-1), along with a predetermined number low-address address bits, identified in FIG. 7 as "ADRS FIELD N-1 "
from the Internet address now in address register 71(N-1), is used by stage 72(N-1) to generate information that is coupled to stage 72(N).
It will be appreciated that, for each pipeline stage as described above, when an Internet address is transferred from address register 71(1) to address register 71(2), another Internet address can be shifted into address register 71(1), and so forth for the successive address registers 71 (n), facilitating pipelining of processing of the Internet addresses. -Each stage 72(n) includes a table 73(n) and associated storage and/or %~ ' processing circuitry. Each of stages 72(1) through 71(N-1) includes a table 73(n), each of which includes a plurality of entries 73(n){y,~). Each entry 73(n){y") in turn, includes a plurality of fields, including a data/pointer flag 75, a map field 76 and a data/pointer field 77 {explicity shown in table 73(2}}. The map field 76 includes a series of bits MB.,..:Mo (generally identified by "Mb') each of which is associated with one of the possible binary encoded values represented by the address bits in the ADRS FIELD n in the address register 72(n). Generally, if the data/pointer flag 75 is set, then the data/pointer field 77 contains muting information for all addresses associated with the address bits in ADRS FIELD_n in the address register 72(n). On the other hand, if data/pointer flag 75 is clear; but the bit Mb in the map field 76 that is associated with the binary coded value of the address bits in the ADRS_FIELD n in the address register 72(n) is set, then the datalpointer field 77 is used, along with a portion of the map field 76, in generating a pointer to an entry 73(n+1)(y"+,) in a table 73(n+1) in the next stage 72(n+1).
The map field 76 further includes a default flag MB, which, if the data/pointer flag 75 is clear, is used if the bit Mb associated with the binary-encoded value of the ADRS FIELD n in the address register 72(n) is clear. If the bit Mb is clear, but the default flag MB is set, then the data/pointer field 77 is used, along with the entire map field 76, other than the default flag M$ itself, in generating a pointer to an entry 73(n+1 )(y+"+~) in a table 73(n+1) in the next stage 72(n+I ). Finally, if the data/pointer flag 75, bit Mb associated with the binary-encoded value of the ADRS FIELD n in the address register 72(n), and the default flag Ms are all clear, there is not routing information for the Internet address in the address register 71 (n).
Stage 72(I~ also includes a table 73(I~ including a plurality of entries 73(I~(YN). In table 73(N), however, each entry includes just one field, which, in turn, includes routing information.
The information in the tables 73(n)(Y,;) are processed to generate routing information as follows. In stage 72(I), the particular entry of the table 73(1} that is to be used is pointed to by the binary-encoded value of the ADRS FIELD_0. Each stage 72(1) through 72(N-1) further includes a stage (n) processor 80{n) that operates as follows. The stage (1) processor 80(1) receives the ADRS FIELD 1 from the ' address register 72(1 ) and the contents of the fields 75, 76 and 77 from an entry 73(1)(y,) in table 73(1) pointed to by ADRS FIELD 0 and performs a number of operations in response thereto. In particular, the stage (1) processor 80(1).
(i) determines whether the data/pointer flag 75 is set, and, if so, provides the data/poiriter flag and the contents of the datalpointer field 77 to the next.stage 72(1}, with the set datalpointer flag indicating that the information provided from the datalpointer field 77 comprise routing information ("RT INFO"), (ii) if the data/pointer flag 75 is clear, but the bit Mb in the map field 76 of the selected entry 73( 1 )(y,) that is associated with the binary-encoded value of the ,ADRS FIELDlI in address register 72( 1 ) is set, counts the number of bits Mo, M,; .., up to, but not including, bit Mb, which are set, adds that number to the value contained in the data/pointer field 77, and provides the sum and the data/pointer flag to the next stage 72(2), with the clear data/pointer flag indicating that the sum is to be used in identifying an entry 73(2)(y2) in the table 73{2} of that stage 72(2), (iii) if the data/pointer flag 75 and bit Mb in the map field 75 of the selected entry 73(1)(y,) that is associated with the binary-encoded value of the ADRS_FIELD_1 in address register 72(1} are both clear, determines whether the bit MH is set, and if so, counts the number ofbits Mo, M3,..., up to, but not including, bit MB, which are set, adds that number to the value cantained in the data/pointer field 77, and provides the sum and the datalpointer flag to the next stage 72(2), with the clear data/pointer flag indicating that the sum is to be used in identifying an entry 73{2)(y2) in the table 73(2) of that stage 72(2); and (iv) if the data/pointer flag 75, the bit Mb in the map field 76 of the selected entry 73 ( 1 }(y, ) that is associated with the binary-encoded value of the ADRS FIELD_1 in address register 72( 1 ), and the bit MB are all clear, it (that is, the stage ( 1 ) processor 80( 1 )) provides a notification to the next stage 72(2) that there is no routing information for the address in the address register 72( 1).
Thus, in connection with items (ii) and (iii) above, it will be appreciated that table 73(2} need only have at most a number of entries 73(2}(y2} corresponding to the number ofbits Mo, M,, MB, in the map fields 76 of entries 73(1)(y,) which are set (up to a maximum of "B" entries 73(2)(y2)) for those entries 73(1)(y,) for which the data/pointer flags 75 are clear (indicating, as noted above, that the datalpointer field 77 contains a pointer), which can be significantly fewer than if one entry 73(2)(y2) were provided for each entry 73(1)(y,) and for each possible binary-encoded value of the address bits in ADRS FIELD 2 of address register 72(2).
After the stage (1) processor 80(1) has generated the output information as described above, the Internet address in address register 72(1) will be transferred to address register 72(2) for processing by stage 72(2). The stage 72(2) processes the address bits from the next address field, ADRS FIELD 2 (not separately shown), in the address in address register 72(2) in connection with the output from the stage 72(1 ). As noted above, the stage 72(2) includes a table 73(2), which is structured similarly to the table 73{1) in stage 72{1). In addition, the stage 72(2) includes a stage (2) processor 80(2) which operates in a manner similar to that described above in connection with the stage {1) processor 80(1), except that, if the stage 72(2) receives information, from the stage 72{1) for which the data/pointer flag is set, indicating that the information received from stage 72(1) is either the routing information, or notification to the stage 72(2) that the meta-data generator 32 dyes not have routing information for the Internet address that is now in the address register 72(2), the stage (2) processor 80(2) will couple that information to the next stage 72(3), and will not perform processing operations in connection with an entry 73(2)(y2) of the table 73(2) of that stage 72(2).
These operations will be repeated for successive stages 72(3) through the stage 72(N-1), as the address is transferred through successive address registers 71(3) through 71 (N-1 ). After the address field ADRS FIELD N-1 of an Internet address is process in stage 72(N-i ), that stage 72(N-1} also will provide either routing information or a pointer to stage 72(N). Stage 72{N) also includes a stage (N) processor 80(N). If the stage (I~ processor 80(N) receives routing information (including default routing information or a notification that the meta-data generator 32 does not have routing information for the address) from stage 72(N-1), it will provide that routing infornnation as the output routing information for the rneta-data generator 32. On the other hand, if the stage 72(N) receives a pointer from the.stage 72(N-1), pointing to an entry 73(N)(YN) in its table 73(N), the stage (N) processo't' 80(N) will provide the contents of the entry as the routing information for the Internet address.
FIG. 8 depicts a functional block diagram of the alternate embodiment, comprising a binary search tree arrangement, for generating the routing information for Internet addresses coupled thereto by the input port module control circuit 33 (FIG. 2). A functional block diagram of the binary search tree arrangement, identified by reference numeral 90, is depicted in FIG. 8. Preliminarily, the binary search tree arrangement actually defines a plurality of binary search trees.
Each binary search tree has nodes organized in a plurality of levels from a single "root"
node in the highest level to a plurality of leaves in the lowest level. Each node in a binary search tree between the root node and the leaf nodes has one parent in a higher level and two children in a lower level; the root node also has two children (but no parent), and each leaf has one parent (but no children). For each node, one of the children will be termed herein a "right-hand" child and the other of the children will be termed a "left-hand" child. It will be appreciated that, for each binary tree, the number of levels "NUM LEVELS" is a function of the logarithm, to the base two;
of the number of leaves "NUM LEAVES"; specifically, NUM LEVELS=Logz (NLTM'LEVELS)+1.
Generally, a binary search tree is used to attempt to associate an input value with one of the leaves, in a plurality of iterations cozxesponding to the number of non-leaf node levels, as follows. Each of the nodes in the binary tree above the leaf Ievel, is associated with a comparison value, and the leaf nodes in the leaf are associated with the various values that are to be associated with the input values. In a first iteration, the input value is compared to the comparison value associated with the root node and, (i) if the input value is greater that or equal to the comparison value, the right-hand child will be selected, but, (ii) if the input value is less than the comparison value, the left-hand child will be selected.

Thereafter, if the nodes in the second level are not leaf nodes, in a second iteration, comparison will be performed in connection with the comparison value associat'~d with the selected node in the second level, and one of its children will be selected in the same manner as for the root node (reference items (i) and (ii) above).
These operations will be repeated respective iterations through the nodes in the respective levels above the leaf level. When the operation is performed in connection with a node at a Ievel immediately above the leaf level, in the same manner as described above (reference items (i) and (ii) above), a child node in the leaf level is selected which, in turn, is associated with the value that is to be associated with the input value.
From this description of the operations performed in connection with a binary search tree, it will be appreciated that the comparison values associated with the nodes in each level, above the leaf level, essentially serve to divide the range of possible input values into a plurality of intervals. Thus, if the range of possible input values is [0, Max], where "Max" represents the maximum possible input value and "[x, y]" indicates that the range includes the endpoints "x" and "y," the root node divides the entire range into two intervals, [0,A], and [A, Max], where "A" is the comparison value associated with the root node, and "[x,y)" indicates an interval that includes the Iower endpoint "x," but does not include the upper endpoint "y°'. Thus, if the input value falls in the lower interval [O,A), the left child node will be selected, but if the input value falls in the upper interval [A,Max], right child node will be selected. The left child of the root node further divides the interval [O,A], into two intervals [0,B) and [B,A], and the right child of the root node further divides the interval [A,Max] into two intervals [A,C} and [C,Max]. Generally, the nodes of the lower Level, above the leaf Level, serve to further divide the set of intervals defined by the next higher level into successively smaller intervals. Thus, it will be appreciated that the binary search tree essentially serves to associate the input value with an interval, with each interval being associated with a leaf node.
In the context of the invention, the input value is an Tnternet address and the values associated with the leaf nodes comprise routing information.

With this background, the binary search tree arrangement 90 will-be described in connection with FIG. 8. With reference to FIG. 8, the binary search~tree' arrangement includes an input register 91, an input table 92, a series of tree stages 9S(I) through 9S(1~ (generally identified by reference numeral 9S{n)) and a routing information table I12. Generally, the tree stages 9S{1) through 95(l~ store node information for nodes of the binary search trees comprising the binary search tree arrangement 90 above the leaf level, and the routing information table stores the routing information far the leaf nodes for the binary search trees comprising the binary search tree arrangement. As noted above, the binary search tree arrangement 90 defines a plurality of binary search trees, but the binary search trees can have different numbers of levels, and so the number "N" of stages 95(n) is a function of the maximum number of levels, above the leaf level, for all of the binary search trees.
However, since all of the leaf nodes are essentially associated with the routing information table 112, the root nodes for the various binary search trees can be 1 S associate with various ones of the stages 9S(n). That is, if a binary search tree has relatively few levels, its root nods will be associated with a stage 95(n) for which index "n" is relatively close to "I," the index associated with the last stage 9S(1). On the other hand, if a binary search tree has relatively many levels, its root node will be associated with a stage 9S(n) for which index "n" is relatively close to "N", the index associated with the first stage 9S(1~. The particular binary search tree with which an Internet address will be associated is determined by the high-order portion of the Internet address. The input table 92 contains, for each binary-encoded value of the high-order portion of the Internet address, a pointer that identifies the stage 95(n) that is associated with the root node for the binary search tree to be used for that binary-2S encoded value.
More specifically, the input table 92 includes a plurality of entries 92(1) through 92(I~ {generally identified by reference numeral 92(n)), each of which is associated with one binary encoded value of the high-order portion of the Internet address. Each entry 92{n) comprises two fields, namely, a table delay field 93 and a next table index field 94. The table delay field 93 contains a value that is used in identifying the stage 9S{n) that is associated with the raot node for the tree, and the next table index field 94 contains a pointer to an entry in a table (as described below) maintained by that stage 95(n) which contains a comparison value that is to be used ' in the comparison with a low-order portion of the Internet address.
Stages 95(I~ through 95(1) are all similar, and only stage 95(N) is shown in detail in FIG. 8. As shown in FIG. 8, stage 95(N) includes a low-order address store 97, a table 96(N), and processing components as described below. The low-order address store 97, after the entry 92(n) in input table 92 has been accessed, receives and stores the low-order portion of the Internet address from the address register 91. .
Contemporaneously, the contents of the table delay faeld 93 and next table index 94 from the entry 92(n) of input table 92 that is associated with the high-order portion of the Internet address in address register 91 will be stored in a store 100. The table 96(N) includes a plurality of entries 96(N)(0) through 96(I~{YN) {generally identified by reference nurnerai 96(N)(yN)), each of which is associated with a node in a binary comparison tree and includes an comparison value field 101. The comparison value field 101 in each of the entries 96(1~(yN) corresponds to the node information for the root nodes of the largest binary comparison trees, that is; the binary comparison trees which have "N" levels above the leaf level. The comparison value field 101 stores a comparison value that will be compared to the low-order portion of the Internet address in store 97.
It will be appreciated that each of stages 95(leT-1),...,95(1) (generally identified by reference numeral 95(n)) also will have a table 96(N-1),...96(1) (generally identified by reference numeral 96(n)), each of which will have a number YN_,,...Y, (generally, Y"} of entries, each of which also stores comparison values. At least some of the entries in each table 96(N-1),...,96(1) will correspond to child nodes of respective binary comparison trees of the entries in the table 96(N},...,96(2) in the respective preceding stage, and so each table 96(N-1),...,96(1) will have two times the number of entries in the preceding table 96(N),...,96(2) to accommodate the child nodes. In addition, for a stage 95(N-1),...,95(1) for which a binary comparison tree begins with that stage, the table 96(N-1),...,96(1) associated with the stage will also have an additional number of entries each associated with the root of each binary comparison tree which begins with that stage, and in those cases the table 96(N-1 ),...,96( 1 ) can have more that two times the number of.entries in the table 96(N),:..,96(2) associated with the preceding stage.
The processing components ofthe stage 95(N) perform a number of operations including:
(i) selecting an entry 96(I~(y) in the table 96(N) that is painted to by the table index "TBL IDX" portion of the store 100, which, in turn, corresponds to the contents of the next table index field 94 from the selected entry 92(n) of the input table, (ii) comparing the binary-encoded value of the low-order portion of the Internet address, in store 97, fo the comparison value from field 101 of the selected entry 96(1~(yj), (iii) generating a pointer to an entry in the table of the next stage 76(N-I ) based on the results of the comparison in item (ii) above, and (iv) selecting either the pointer generated in item (iii) above or the table index from store 100 to couple to the next stage 95(N-1 ), based on a comparison between the value of the table delay value from store 100 and the stage's index "N".
If the table delay value in store I 00 corresponds to the index "N" of the stage 95{N), then the entry pointed to by the table index in store 100 points to an entry 96(N)(yN) in stage 95(N) that is the root node for the binary search tree to be used for the Internet address whose low-order portion is in store 97. Similarly, if the table delay value in store 100 is less than the index "N" of the stage 95(N), then the entry pointed to by the table index in store 100 points to an entry 96(N)(yN) in stage 95(N) that is in the binary search tree to be used for the Internet address whose low-order portion is , in store 97, but below the root node. In either case, the processing components will couple one of the generated pointers, based on the results of the comparison of the binary-encoded value of the low-order portion of the Internet address, in store 97, to the comparison value from field I OI of the selected entry 96(N)(yN), to the store 100 of the next stage 95(N-1) for use as the table index, along with the table delay value from store 100 in stage 95(N).
On the other hand, if the table delay value in store I00 is greater than the index for thestage, then the entry pointed to by the table index in store 100 does not point to an entry in the stage's table that is a node in the binary search tree that is to be used for the Internet address whose low-order portion is in the store 97.
In that case, the processing components will couple the index value from store 100 to the next stage 95(N-1) for use as the table index, along with the.table delay value in store 100.
The processing components in stage 95(I~ include a number of elements, including comparators 98 and 99, multiplexers 104 and 105, a multiplier 106 and an adder 107. The multiplier 106 and adder 107 serve to generate pointers to entries in the next stage 95(N-1 ). As described above, in a binary comparison tree, each node has two children. Thus, in one embodiment, the pointers to entries in the next stage are generated so that the children for entry 96(N)(0) will be in entries 96(N-1)(0) and 96(N-i)(1) in the table for stage 95(N-1}, the children for entry 96(N)(1) will be in entries 96(N-1)(2) and 96(N-1)(3), and so forth. Thus, in that embodiment, the multiplier 106 and adder 107 can generate the pointers by multiplying the table index value in store 100 by the value "two" (which will be performed by the multiplier 106) to generate the pointer for one of the children of the node of the binary tree which is associated with the entry 96(I~(yN), and adding the value "one" to the value generated by the multiplier 106 to generate the pointer for the other child.
In that case, the entries 96(N-1)(0) through 96(N-I)(2YN-1) in the table 96(N-1) of the next stage 95(N-1) will be associated with child nodes in the binary comparison trees whose root nodes are associated with entries 96{N){yN) in the table 96(I~
associated with stage 95(N). If any binary comparison trees have root nodes associated with stage 95(N-1), those root nodes will be associated with respective additional entries 96(N-I)(2YN),...in the table 96(N-1). Tables 96(N-2),...,96(1) are similarly organized.
The comparator 98 serves to compare the Iow-order portion of the Internet address from store 97 and the comparison value from field 1 O1 of the selected entry 96(l~(Y) and controls the multiplexes i 04 in response thereto. If the comparator 98 determines that the low-order portion of the Internet address from store 97 is greater than or equal to the comparison value from f eld 101 of the selected entry 96(N)(Y), the multiplexes I04 will couple the pointer generated by adder 107 to one input of multipiexer 105. On the other hand, if the comparator 98 determines that the low-order portion of the Internet address from store 97 is less than the comparison valkre from field 101 of the selected entry 96(1~(Y), the muitiplexer 104 will couple the pointer generated by the multiplier 106 to the same input of multiplexes .105.
The table index from store 100 is coupled to the second input of multiplexes 105.
The multiplexes 105, in turn, is controlled by a signal from the comparator 99. The comparator 99 receives the table delay value from store 100, and also a value corresponding to the stage index "N". If the table delay value is less than or equal to the stage index, the multiplier 105 will couple the value provided by multiplexes 104, that is, the pointer generated by the multiplier I 06 or the adder I 07 to the next stage 95(N-1). On the other hand, if the table delay in store 100 has a value that is greater than the stage index, the multiplexes 105 will couple the table index from store 100 to the next stage 95(N-1).
It will be appreciated that the functions described as being provided by multiplier 106, adder 107 and multiplexes 104 can be implemented without provided explicit components therefor. Since multiplication of the table index by "two"
corresponds to shifting the binary digits comprising the table index in store 100 to the "left" by one bit position, and adding "one" corresponds to setting the binary digit in the low-order bit position, the functions can be provided by coupling bits TIH...TIo (not seperately shown) comprising the table index in store 100, onto signal paths SH+~...5, {also not separately shown) of the associated input terminal of multiplex 105 (that is, the input terminal shown as receiving a signal from multiplexes 104). A
low-order signal path So receives the signal from the comparator 98, thus, the result of the comparison between the comparison value in the selected entry of table 96(N) with the low-order portion of the address in store 97 controls which of the entries 96(N-1)(yN_,) in the table 96(N-1) associated with the next stage 95(N-i) that is selected.
It will be appreciated that the entries 96(N){y~),...,96(2)(y2) in the tables 96(N),...,96(2) of respective stages 95(N),...,95(2) can include explicit pointers to entries 96(N-1)(y~,.,),...,96(1)(y,) ofthe respective next stages 95(1V-1),...,95(1), if the association between entries and nodes of the respective binary comparison trees is not constrained as described above.
The invention provides a number of advantages. in particular, it provides ~
switching node that provides the scalability of a input-queued switching node, while maintaining substantially the efficiency of switching fabric usage of an output-queued switching node. Since the packets are buffered at the input port modules 20(n) until the determination has been made (by the packet meta-data processor 23) that they are to be transmitted by respective output port modules 21 (n), and further until they are requested by the respective output port modules 21(n) for to be transferred thereto for transmission, only "N" buffers, or queue, is needed, one for each input port module 20(n), whereas in an output-queued switching node NZ
buffers would be required. On the other hand, since the determination as to whether to pass or drop a packet is made for each output port module 21 (n) in connection with meta-data packets queued therefor from alI of the input port modules 20{n); the pass/drop detemlination is made for all input port modules 20(n) in a manner that is essentially the same as in an output-queued switching node. However, since the pass/drop determination is made on a rneta-data packet that is generally much smaller than the size of a typical.packet transferred through the network, by providing that packets that are dropped do not pass through the packet switch 22, as would occur in output-queued switching nodes, switching bandwidth that would otherwise be taken up by transferring packets that are Iater dropped by the output port modules 21 (n) can be reduced.
in addition, since the pass/drop decision for a packet is made before the packet is transferred from the respective input port module 20(n) to the respective output port module Zl(n), bandwidth between the input and output port modules through the inter-port packet switch 22 will not be taken up by packets which will likely be dropped by the output port module 21{n) if the output port module 21(n) is congested. This serves to optimize packet traffic between the input and the output port modules by ensuring that only packets that are likely to be transmitted when they reach the output port modules will be transferred by the input port modules thereto. This provides the switching node 11 (n) with the ability to handle a relatively high traffic capacity, since resources are not wasted in transferring packets through w0 00!02347 PCTIU899/15028 the switching node 11 (n) which will be dropped when they reach the respective output port module 21(n) which would otherwise transmit them, but is unable to dire to congestion.
Mare generally, since the pass/drop decision is made by the packet meta-data processor for each output port module 21 (n) based on the "global" information which provided to it by all of the input port modules 20(n), the switching node 11 (n) is able to operate as a single monolithic entity rather that as a collection of smaller entities.
This global information provides the respective output port module 21 (n) with a global view representing the states of all of the input port modules 20(n). In devices IO which do not provide this view, decisions can be made on information provided by groups of input port modules 20(n}, which group information is aggregated into a common view which is used by the respective output port module 21 (n):
Depending on how the input port modules 20{n) are grouped and how the information provided by each group is aggregated, important information concerning the states of the respective input port modules 20{n) in each group can be ignored, which, in turn, can cause the output port module 21(n) to operate as though the switching node were a collection of smaller entities based on the association of the input port modules 20(n) with the respective groups. This, in tum, can the reduce the traffic handling capacity of the switching node as a whole.
It will be appreciated that numerous modifications may be made to the switching node 11 (n} described above in connection with FIGS. 2 through 6.
For example, although the switching node 11 (n) has been described as making use of the IP routing protocol for transferring messages, it will be appreciated that a number of convenient routing protocols, making 'use of variable-or fixed-length packets, may be used, including, but not limited to, IP packets, ATM cells, frame relay packets and the like.
In addition, although the meta-data processors 40(n) have been described as providing a separate status information store 43(n} associated with the respective output port module 21 (n}, it will be appreciated that the meta-data processor 23 may instead have a cache memory (not shown) which stores the identifications of the output port modules 21 (n) which are congested, which can be used by the packet pass/drop circuits 42(n) of all of the meta-data processors 40(n). If, as would be expected, only a small number of output-port modules 21 (n) would be congested at%r h any point in time, the amount of memory required by using the cache memory may be less than would by required if a store 43(n) were provided for each meta-data processor 40(n).
Furthermore, although the switching node I i(n) has been described as making use of a cross-point switch as the inter-port packet switch, it will be appreciated that any of a number of other forms of switches can be used.
In addition, although the packet meta-data processor 23 has been described as I O providing one processor module 40(n) associated with each output port module .
21 (n), it will be appreciated that it may instead provide a processor module associated with each output port 26(n)(m). In that case, the respective output port module 21 (n) would provide to the processor module operational status information associated with the respective output port 26(n)(m), which the processor module would use in making the pass/drop determination. In addition, each output port module 21 (n) can schedule retrievals of meta-data packets which have been passed by the respective processor modules associated with its output ports 26(n)(m), and subsequent retrievals of packets associated therewith, so as to be able to maximize packet transmission through all of the output ports 26{n)(m).
In addition, although the meta-data generator 32 has been described as making use of a single comparison tree in identifying the appropriate route for a destination address, it will be appreciated that the meta-data generator 32 can be structured to use a number of such comparison trees, with the selection of the particular comparison tree to be used to be determined by, for example, the binary-encoded value represented by selected ones of the high order bits of the destination address. In that case, the comparison tables would be structured based on the remaining low-order bits, and the comparisons would be made in connection with the Iow-order bits of the destination address.
in addition, although the switching node 11 (n) has been described as making use of SONET addldrop multiplexers as input ports 25(n)(m} and output ports 26(n)(m), it will be appreciated that other types of devices for interfacing to WO 00102347 PCTIUS99/1502$
communication. Links miay conveniently be used.
It will be appreciated that a system in accordance with the invention can beg constructed in whole or in part from special purpose hardware or a general purpose computer system, or any combination thereof, any portion of which may be controlled by a suitable program. .Any program may in whole or in part comprise part of or be stored on the system in a conventional manner, yr it may in whole or in part be provided in to the system over a network or other mechanism for transferring information in a conventional manner. In addition, it will be appreciated that the system may be operated and/or otherwise controlled by means of information provided by an operator using operator input elements (not shown) which may be connected directly to the system or which may transfer the information to the system over a network or other mechanism for transferring information in a conventional manner.
The foregoing description has been limited to a specific embodiment of this invention. It will be apparent; however, that various variations and modifications may be made to the invention, with the attainment of some or all of the advantages of the invention. It is the object of the appended claims to cover these and such other variations and modifications as come within the true spirit and scope of the invention.
What is claimed as new and desired to be secured by Letters Patent of the United States is:

Claims (54)

1. A switching node for transferring data on a network, the switching node comprising:
an input port module for receiving and buffering packets of data from the network, the input port module generating packet meta-data associated with a received packet to be transferred, the packet meta-data including information identifying the input port module that received the packet of data from the network;
a packet meta-data processor for receiving the packet meta-data from the input port;
an output port module for transmitting a packet of data onto the network, the output port module (i) receiving the packet meta-data from the packet meta-data processor, (ii) queuing the packet meta-data, (iii) reading the queued packet meta-data, and (iv) transmitting a request signal to the input port module to initiate transmission from the input port module of the packet of data associated with the packet meta-data; and a switch module between the input port module and the output port module for transferring packets of data from the input port module to the output port module.
2. The switching node of claim 1 wherein the switch module comprises a plurality of switches for transferring a respective plurality of portions of a packet of data being transferred through the switch module.
3. The switching node of claim 2 wherein the plurality of switches transfer the plurality of portions of the packet of data in round robin fashion.
4. The switching node of claim 1 wherein the output port module provides information to the meta-data processor related to operational status of the output port module.
5. The switching node of claim 4 wherein the information related to operational status of the output port module is used by the meta-data processor to determine whether packet meta data will be transferred to the output port module.
6. The switching node of claim 4 wherein the information related to operational status of the output port module includes information related to availability of the output port module to receive a packet of data from the input port module.
7. The switching node of claim 6 wherein if the information related to availability of the output port module to receive a packet of data from the input port module indicates that the output port module is available, then the meta-data processor transfers packet meta-data to the output port module.
8. The switching node of claim 6 wherein if the information related to availability of the output part module to receive a packet of data from the input port module indicates that the output port module is unavailable, then a packet of data is dropped.
9. The switching node of claim 4 wherein the information related to operational status of the output port module includes information related to data congestion at the output port module.
10. The switching node of claim 1 wherein the input port module comprises a packet memory for buffering packets of data received from the network.
11. The switching node of claim 1 wherein the input port module comprises a plurality of input ports for receiving packets of data from the network.
12. The switching node of claim 1 wherein the output port module comprises a plurality of output ports for transmitting packets of data onto the network.
13. The switching node of claim 1 wherein the switch module can transfer data packets between a plurality of input port modules and a plurality of output port modules.
14. A method of transfernng data an a network comprising:
at an input port module, (i) receiving packets of data from the network; (ii) buffering the packets of data received from the network, and (iii) generating packet meta-data associated with a received packet to be transferred, the packet meta-data including information identifying the input port module that received the packet of data from the network;
providing a packet meta-data processor for receiving the packet meta-data from the input port module;
at an output port module for transmitting packets of data onto the network, (i) receiving the packet meta-data from the packet meta-data processor, (ii) queuing the packet meta-data, (iii) reading the queued packet meta-data, and (iv) transmitting a request signal to the input port module to initiate transmission from the input port module of the packet of data associated with the packet meta-data; and providing a switch module between the-input port module and the output port module for transferring packets of data from the input port module to the output port module.
15. The method of claim 14 wherein providing a switch module comprises providing a plurality of switches for transferring a respective plurality of portions of a packet of data being transferred through the switch module.
16. The method of claim 15 wherein the plurality of switches transfer the plurality of portions of the packet of data in round robin fashion.
17. The method of claim 14 wherein the output pert module provides information to the meta-data processor related to the operational status of the output port module.
18. The method of claim 17 wherein the information related to operational status of the output port module is used by the meta-data processor to determine whether packet meta-data will be transferred to the output port module.
19. The method of claim 17 wherein the information related to operational status of the output port module includes information related to availability of the output port module to receive a packet of data from the input port module.
20. The method of claim 19 wherein if the information related to availability of the output port module to receive a packet of data from the input port module indicates that the output port module is unavailable, then the meta-data processor transfers packet meta-data to the output port module.
21. The method of claim 19 wherein if the information related to availability of the output port module to receive a packet of data from the input port module indicates that the output port module is unavailable, then a packet of data is dropped.
22. The method of claim 17 wherein the information related to operational status of the output port module includes information related to data congestion at the output port module.
23. The method of claim 14 wherein the input port module comprises a packet memory for buffering packets of data received from the network.
24. The method of claim 14 wherein the input port module comprises a plurality of input ports for receiving packets of data from the network.
25. The method of claim 14 wherein the output port module comprises a plurality of output ports for transmitting packets of data on to the network.
26. The method of claim 14 wherein the switch module can transfer data packets between a plurality of input port modules and output port modules.
27. A method of forwarding a packet of data across a switching node on a network, said packet of data including a destination address identifying a destination node on the network toward which the packet of data is to be forwarded along an output path out of the switching node, the destination address being dividable into a plurality of subaddress fields holding a respective plurality of subaddresses, said method comprising:
storing in a memory a table that associates each of a plurality of destination addresses with an output path out of the switching node over which a packet can be forwarded toward the destination node identified by the destination address, each of a plurality of portions of the table being associated with a respective subaddress field and being accessible by use of the subaddress held by the associated subaddress field;
providing a series of subaddress processors, each of the subaddress processors being associated with a respective subaddress field and receiving the subaddress held by its associated respective subaddress field and using the subaddress to access the portion of the table associated with the subaddress field to receive information related to the output path associated with the destination address;
receiving a series of destination addresses from a respective series of packets of data to be forwarded across the switching node;
using the series of subaddress processors to access the table in a pipelined fashion to retrieve an output path for each of the received packets of data, such that:
during a first addressing interval, a first subaddress processor, associated with a first subaddress field, uses the subaddress held by the first subaddress field of a first received destination address to access a first portion of the table associated with the first subaddress field; and, during a second addressing interval, (i) a second subaddress processor, associated with a second subaddress field, uses the subaddress held by the second subaddress field of the first destination address to access a second portion of the table associated with the second subaddress field; and (ii) the first subaddress processor uses the subaddress held by the first subaddress field of a second received destination address to access the first portion of the table associated with the first subaddress field.
28. The method of claim 27 wherein, during the addressing intervals, the first subaddress processor provides an item of information to the second subaddress processor, the item of information being used by the second subaddress processor to access the second portion of the table.
29. The method of claim 28 wherein the item of information is a start address in the table used by the second subaddress processor to access the second portion of the table.
30. The method of claim 29 wherein:
the subaddress held by the second subaddress field is an address offset; and the second subaddress processor combines the stark address and the address offset to access the second portion of the table.
31. The method of claim 27 wherein the table is a packet routing table.
32. The method of claim 27 wherein the table is a packet routing table compatible with the Internet protocol.
33. An apparatus for forwarding a packet of data across a switching node on a network, said packet of data including a destination address identifying a destination node on the network toward which the packet of data is to be forwarded along an output path out of the switching node, the destination address being dividable into a plurality of subaddress fields holding a respective plurality of subaddresses, said apparatus comprising:
a memory for storing a table that associates each of a plurality of destination addresses with an output path out of the switching node over which a packet can be forwarded toward the destination node identified by the destination address, each of a plurality of portions of the table being associated with a respective subaddress field and being accessible by the subaddress held by the associated subaddress field;
a series of subaddress processors, each of the subaddress processors being associated with a respective subaddress field and receiving the subaddress held by its associated respective subaddress field and using the subaddress to access the portion of the table associated with the subaddress field to receive information related to the output path associated with the destination address;
a receiver for receiving a series of destination addresses from a respective series of packets of data to be forwarded across the switching node; wherein the series of subaddress processors access the table in a pipelined fashion to retrieve an output path for each of the received packets of data, such that:
during a first addressing interval, a first subaddress processor, associated with a first subaddress field, uses the subaddress held by the first subaddress field of a first received destination address to access a first portion of the table associated with the first subaddress field; and, during a second addressing interval, (i) a second subaddress processor, associated with a second subaddress field, uses the subaddress held by the second subaddress field of the first destination address to access a second portion of the table associated with the second subaddress field, and (ii) the first subaddress processor uses the subaddress held by the first subaddress field of a second received destination address to access the first portion of the table associated with the first subaddress field.
34. The apparatus of claim 33 wherein, during the addressing intervals, the first subaddress processor provides an item of information to the second subaddress processor, the item of information being used by the second subaddress processor to access the second portion of the table.
35. The apparatus of claim 34 wherein the item of information is a start address in the table used by the second subaddress processor to access the second portion of the table:
36. The apparatus of claim 35 wherein:
the subaddress held by the second subaddress field is an address offset; and the second subaddress processor combines the start address and the address offset to access the second portion of the table.
37. The apparatus of claim 33 wherein the table is a packet routing table.
38. The apparatus of claim 33 wherein the table is a packet routing table compatible with the Internet protocol.
39. A method of controlling the transfer of data from an input module to an output module on a network, said method comprising:
providing a control module for controlling communication between the input module and the output module;
receiving a packet of data at the input module, the input module generating a meta-data packet in response to the packet of data; the meta-data packet including information identifying the output module to which the packet of data is to be transferred, the input module transferring the meta-data packet to the control module; and at the control module, (i) receiving the meta-data packet from the input module, (ii) receiving from the identified output module a first item of information which indicates a status of the identified output module, and (iii) based on the first item of information, determining whether the packet of data will be transferred to the identified output module.
40. The method of claim 39 further comprising coupling the input module to the output module through a switching module such that packets of data are transferred from the input module to the output module over the switching module.
41. The method of claim 39 wherein the first item of information indicates congestion of data at the identified output module.
42. The method of claim 39 wherein the first item of information indicates availability of the identified output module to receive packets of data.
43. The method of claim 39 further comprising transferring a second item of information from the control module to the input module, said second item of information indicating that the packet of data will not be transferred to the identified output module.
44. The method of claim 39 further comprising storing the packet of data in at least one buffer associated with the input module.
45. The method of claim 44 further comprising, in response to the second item of information, transferring from the control module to the input module a command for the input module to clear the at least one buffer that stores the packet of data without transferring the packet of data to the identified output module.
46. The method of claim 44 further comprising, in response to the second item of information, transferring from the control module to the input module a command for the input module to reallocate the at least one buffer that stores the packet of data without transferring the packet of data to the identified output module.
47. An apparatus for transfernng data on a network, said apparatus comprising:
an input module for receiving packets of data from the network;
an output module for receiving packets of data from the input module and transfernng packets of data onto the network; and a control module for controlling communication between the input module and the output module; wherein:
the input module is adapted to (i) generate a meta-data packet in response to a received packet of data, the meta-data packet including information identifying the output module to which the packet of data is to be transferred, and (ii) transfer the meta-data packet to the control module; and the control module is adapted to (i) receive the meta-data packet from the input module, (ii) receive from the identified output module a first item of information which indicates a status of the identified output module, and (iii) -based on the first item of information, determine whether the packet of data will be transferred to the identified output module.
48. The apparatus of claim 47 further comprising a switching module over which packets of data are transferred from the input module to the output module.
49. The apparatus of claim 47 wherein the first item of information indicates congestion of data at the identified output module.
50. The apparatus of claim 47 wherein the first item of information indicates availability of the identified output module to receive packets of data.
51. The apparatus of claim 47 wherein the control module is adapted to transfer a second item of information from the control module to the input module, said second item of information indicating that the packet of data will not be transferred to the identified output module.
52. The apparatus of claim 47 wherein the input module is associated with at least one buffer for storing the received packet of data.
53. The apparatus of claim 52 wherein the control module is adapted to transfer to the input module, in response to the second item of information, a command for the input module to clear the at least one buffer that stores the received packet of data without transferring the packet of data to the identified output module.
54. The apparatus of claim 52 wherein the control module is adapted to transfer from the control module to the input module, in response to the second item of information, a command for the input module to reallocate the at least one buffer that stores the received packet of data without transferring the packet of data to the identified output module.
CA002336465A 1998-07-02 1999-07-01 System and method for switching packets in a network Abandoned CA2336465A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US09/108,771 1998-07-02
US09/108,771 US6434115B1 (en) 1998-07-02 1998-07-02 System and method for switching packets in a network
PCT/US1999/015028 WO2000002347A2 (en) 1998-07-02 1999-07-01 System and method for switching packets in a network

Publications (1)

Publication Number Publication Date
CA2336465A1 true CA2336465A1 (en) 2000-01-13

Family

ID=22323950

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002336465A Abandoned CA2336465A1 (en) 1998-07-02 1999-07-01 System and method for switching packets in a network

Country Status (10)

Country Link
US (4) US6434115B1 (en)
EP (1) EP1092298A2 (en)
JP (1) JP2002520907A (en)
CN (1) CN1317189A (en)
AU (1) AU4854799A (en)
CA (1) CA2336465A1 (en)
MX (1) MXPA01000218A (en)
RU (1) RU2001102964A (en)
TW (1) TW461202B (en)
WO (1) WO2000002347A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101373556B (en) * 2007-08-23 2012-08-01 瑞斯康微电子(深圳)有限公司 Method for transmitting and receiving low pressure carrier wave centralized type network and apparatus thereof

Families Citing this family (107)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6791947B2 (en) 1996-12-16 2004-09-14 Juniper Networks In-line packet processing
US7089331B1 (en) 1998-05-29 2006-08-08 Oracle International Corporation Method and mechanism for reducing client-side memory footprint of transmitted data
US6434115B1 (en) * 1998-07-02 2002-08-13 Pluris, Inc. System and method for switching packets in a network
US6580721B1 (en) * 1998-08-11 2003-06-17 Nortel Networks Limited Routing and rate control in a universal transfer mode network
IT1305140B1 (en) * 1998-10-27 2001-04-10 Cselt Centro Studi Lab Telecom MEMORY FOR SEARCHING FOR INFORMATION THROUGH ANALYSIS OF INPARTICULAR PREFIXES FOR THE CREATION OF ROAD TABLES IN KNOTS
US7480242B2 (en) * 1998-11-24 2009-01-20 Pluris, Inc. Pass/drop apparatus and method for network switching node
US6952401B1 (en) * 1999-03-17 2005-10-04 Broadcom Corporation Method for load balancing in a network switch
US6889260B1 (en) * 1999-06-10 2005-05-03 Ec Enabler, Ltd Method and system for transferring information
US6891823B1 (en) * 1999-06-15 2005-05-10 Pluris, Inc. Apparatus and method for scaling a switching fabric in a network switching node
US6973079B1 (en) * 1999-06-15 2005-12-06 Pluris, Inc. Apparatus and method for scaling a switching fabric in a network switching node
US6934250B1 (en) 1999-10-14 2005-08-23 Nokia, Inc. Method and apparatus for an output packet organizer
US6757249B1 (en) * 1999-10-14 2004-06-29 Nokia Inc. Method and apparatus for output rate regulation and control associated with a packet pipeline
US6882642B1 (en) 1999-10-14 2005-04-19 Nokia, Inc. Method and apparatus for input rate regulation associated with a packet processing pipeline
US6704782B1 (en) * 1999-12-09 2004-03-09 International Business Machines Corporation System and methods for real time progress monitoring in a computer network
US6735214B1 (en) * 2000-01-12 2004-05-11 New Jersey Institute Of Technology Method and system for a hierarchical traffic shaper
US7389284B1 (en) 2000-02-29 2008-06-17 Oracle International Corporation Method and mechanism for efficient processing of remote-mapped queries
US6704794B1 (en) 2000-03-03 2004-03-09 Nokia Intelligent Edge Routers Inc. Cell reassembly for packet based networks
GB2365661A (en) * 2000-03-10 2002-02-20 British Telecomm Allocating switch requests within a packet switch
US6697363B1 (en) * 2000-06-28 2004-02-24 Alcatel Canada Inc. Method and apparatus for longest matching prefix determination in a communication network
US6956858B2 (en) * 2000-06-30 2005-10-18 Mayan Networks Corporation Network routing table and packet routing method
US7385965B2 (en) * 2000-08-10 2008-06-10 Alcatel-Lucent Canada Inc. Multiprocessor control block for use in a communication switch and method therefore
US20020080780A1 (en) * 2000-08-10 2002-06-27 Mccormick James S. Buffering system for use in a communication switch that includes a multiprocessor control block and method therefore
KR100686732B1 (en) * 2000-08-26 2007-02-23 삼성전자주식회사 Method for foriming database for routing data packet from plural prefix and method for routing and router using the method
US7287089B1 (en) * 2000-10-25 2007-10-23 Thomson Financial Inc. Electronic commerce infrastructure system
US7305360B1 (en) 2000-10-25 2007-12-04 Thomson Financial Inc. Electronic sales system
US7058662B2 (en) * 2000-11-30 2006-06-06 Xythos Software, Inc. Maintenance of data integrity during transfer among computer networks
KR20020053664A (en) * 2000-12-27 2002-07-05 오길록 Terabit Packet Switching Apparatus with Brief Communicating Information for intermediation
US6973072B1 (en) * 2001-02-22 2005-12-06 Cisco Technology, Inc. High performance protocol for an interconnect system of an intermediate network node
US7230917B1 (en) * 2001-02-22 2007-06-12 Cisco Technology, Inc. Apparatus and technique for conveying per-channel flow control information to a forwarding engine of an intermediate network node
US6831891B2 (en) * 2001-03-06 2004-12-14 Pluris, Inc. System for fabric packet control
JP2002325087A (en) * 2001-04-25 2002-11-08 Nec Corp Unblocked switch system, its switching method and program
US7203170B2 (en) * 2001-05-01 2007-04-10 Integrated Device Technology, Inc. Network switch port with weighted random early discard
EP1393498B1 (en) * 2001-05-17 2011-01-05 Alcatel Lucent Distributed shared memory packet switch
US7167480B1 (en) * 2001-06-21 2007-01-23 Lighthouse Capital Partners Iv, Lp Multi-service data transport architecture
US7245614B1 (en) * 2001-06-27 2007-07-17 Cisco Technology, Inc. Managing access to internet protocol (IP) multicast traffic
US7068603B2 (en) * 2001-07-06 2006-06-27 Juniper Networks, Inc. Cross-bar switch
US7103590B1 (en) * 2001-08-24 2006-09-05 Oracle International Corporation Method and system for pipelined database table functions
EP1464144A4 (en) * 2001-11-09 2010-09-22 Vitesse Semiconductor Corp A means and a method for switching data packets or frames
US7007101B1 (en) * 2001-11-09 2006-02-28 Radisys Microware Communications Software Division, Inc. Routing and forwarding table management for network processor architectures
US7180887B1 (en) 2002-01-04 2007-02-20 Radisys Patent Properties Routing and forwarding table management for network processor architectures
US7158510B1 (en) * 2002-02-14 2007-01-02 Alcatel Look-up table arbitration system and method for a fast switching element
US20030163595A1 (en) * 2002-02-26 2003-08-28 John Ta Task manager - method of forwarding messages among task blocks
US7191259B2 (en) * 2002-04-10 2007-03-13 Avago Technologies General Ip (Singapore) Pte. Ltd. Method and apparatus for fast integer within-range compare
FR2838590B1 (en) * 2002-04-16 2005-12-30 St Microelectronics Sa ROUTING METHOD FOR A TELECOMMUNICATION NETWORK AND ROUTER FOR IMPLEMENTING SAID METHOD
US7610351B1 (en) * 2002-05-10 2009-10-27 Oracle International Corporation Method and mechanism for pipelined prefetching
US6973457B1 (en) 2002-05-10 2005-12-06 Oracle International Corporation Method and system for scrollable cursors
US7397768B1 (en) 2002-09-11 2008-07-08 Qlogic, Corporation Zone management in a multi-module fibre channel switch
US8660427B2 (en) 2002-09-13 2014-02-25 Intel Corporation Method and apparatus of the architecture and operation of control processing unit in wavelenght-division-multiplexed photonic burst-switched networks
US6934252B2 (en) * 2002-09-16 2005-08-23 North Carolina State University Methods and systems for fast binary network address lookups using parent node information stored in routing table entries
US20040098509A1 (en) * 2002-11-14 2004-05-20 Vic Alfano System for reordering sequenced based packet segments in a switching network
US7397794B1 (en) * 2002-11-21 2008-07-08 Juniper Networks, Inc. Systems and methods for implementing virtual switch planes in a physical switch fabric
KR100489685B1 (en) * 2003-02-20 2005-05-17 삼성전자주식회사 Apparatus for transmitting packet between packet controller and network processor and method thereof
US7428383B2 (en) * 2003-02-28 2008-09-23 Intel Corporation Architecture, method and system of WDM-based photonic burst switched networks
US7848649B2 (en) 2003-02-28 2010-12-07 Intel Corporation Method and system to frame and format optical control and data bursts in WDM-based photonic burst switched networks
US7298973B2 (en) 2003-04-16 2007-11-20 Intel Corporation Architecture, method and system of multiple high-speed servers to network in WDM based photonic burst-switched networks
US7266295B2 (en) 2003-04-17 2007-09-04 Intel Corporation Modular reconfigurable multi-server system and method for high-speed networking within photonic burst-switched network
US7526202B2 (en) 2003-05-19 2009-04-28 Intel Corporation Architecture and method for framing optical control and data bursts within optical transport unit structures in photonic burst-switched networks
US7266296B2 (en) * 2003-06-11 2007-09-04 Intel Corporation Architecture and method for framing control and data bursts over 10 Gbit Ethernet with and without WAN interface sublayer support
US20040252685A1 (en) * 2003-06-13 2004-12-16 Mellanox Technologies Ltd. Channel adapter with integrated switch
US7310480B2 (en) 2003-06-18 2007-12-18 Intel Corporation Adaptive framework for closed-loop protocols over photonic burst switched networks
US7272310B2 (en) * 2003-06-24 2007-09-18 Intel Corporation Generic multi-protocol label switching (GMPLS)-based label space architecture for optical switched networks
US7107423B2 (en) * 2003-07-10 2006-09-12 Hewlett-Packard Development Company, L.P. Methods and apparatus for data retrieval
US7471635B2 (en) 2003-07-16 2008-12-30 Qlogic, Corporation Method and apparatus for test pattern generation
US7525910B2 (en) 2003-07-16 2009-04-28 Qlogic, Corporation Method and system for non-disruptive data capture in networks
US7792115B2 (en) 2003-07-21 2010-09-07 Qlogic, Corporation Method and system for routing and filtering network data packets in fibre channel systems
US7684401B2 (en) 2003-07-21 2010-03-23 Qlogic, Corporation Method and system for using extended fabric features with fibre channel switch elements
US7420982B2 (en) * 2003-07-21 2008-09-02 Qlogic, Corporation Method and system for keeping a fibre channel arbitrated loop open during frame gaps
US7583597B2 (en) * 2003-07-21 2009-09-01 Qlogic Corporation Method and system for improving bandwidth and reducing idles in fibre channel switches
US7466700B2 (en) 2003-07-21 2008-12-16 Qlogic, Corporation LUN based hard zoning in fibre channel switches
US7406092B2 (en) * 2003-07-21 2008-07-29 Qlogic, Corporation Programmable pseudo virtual lanes for fibre channel systems
US7430175B2 (en) * 2003-07-21 2008-09-30 Qlogic, Corporation Method and system for managing traffic in fibre channel systems
US7512067B2 (en) 2003-07-21 2009-03-31 Qlogic, Corporation Method and system for congestion control based on optimum bandwidth allocation in a fibre channel switch
US7646767B2 (en) 2003-07-21 2010-01-12 Qlogic, Corporation Method and system for programmable data dependant network routing
US7894348B2 (en) 2003-07-21 2011-02-22 Qlogic, Corporation Method and system for congestion control in a fibre channel switch
CN1313903C (en) * 2003-09-02 2007-05-02 华为技术有限公司 Method and apparatus for obtaining physical layer chip condition information
US7290071B2 (en) * 2003-09-30 2007-10-30 Agere Systems Inc. Processor with input data block discard mechanism for use in an oversubscription condition
US7315693B2 (en) 2003-10-22 2008-01-01 Intel Corporation Dynamic route discovery for optical switched networks
US7340169B2 (en) * 2003-11-13 2008-03-04 Intel Corporation Dynamic route discovery for optical switched networks using peer routing
US20050111366A1 (en) * 2003-11-25 2005-05-26 Whittaker Stewart Mark A. Strictly non-interfering network
US20050111465A1 (en) * 2003-11-25 2005-05-26 Stewart Mark Andrew W. Infiniband switch operating in a clos network
US7734176B2 (en) 2003-12-22 2010-06-08 Intel Corporation Hybrid optical burst switching with fixed time slot architecture
US20050163107A1 (en) * 2004-01-27 2005-07-28 Gunturi Ravi P. Packet processing pipeline
US7359381B2 (en) * 2004-01-30 2008-04-15 Hewlett-Packard Development Company, L.P. Parallel hardware arrangement for correlating an external transport address pair with a local endpoint association
US7480293B2 (en) 2004-02-05 2009-01-20 Qlogic, Corporation Method and system for preventing deadlock in fibre channel fabrics using frame priorities
US7930377B2 (en) 2004-04-23 2011-04-19 Qlogic, Corporation Method and system for using boot servers in networks
US7340167B2 (en) * 2004-04-23 2008-03-04 Qlogic, Corporation Fibre channel transparent switch for mixed switch fabrics
JP4150701B2 (en) * 2004-06-30 2008-09-17 株式会社東芝 Information processing apparatus, information processing method, and information processing program
US8098676B2 (en) * 2004-08-12 2012-01-17 Intel Corporation Techniques to utilize queues for network interface devices
US8295299B2 (en) 2004-10-01 2012-10-23 Qlogic, Corporation High speed fibre channel switch element
US9225632B2 (en) * 2005-09-16 2015-12-29 Hewlett Packard Enterprise Development Lp Globally fair polling for packet switched routers using dynamically biased arbitration
US7969966B2 (en) * 2005-12-19 2011-06-28 Alcatel Lucent System and method for port mapping in a communications network switch
US7548560B1 (en) 2006-02-27 2009-06-16 Qlogic, Corporation Method and system for checking frame-length in fibre channel frames
CN101039212B (en) * 2006-03-15 2010-11-03 中兴通讯股份有限公司 Fast data storage method
EP1860033B1 (en) * 2006-05-26 2011-01-12 MTC - Macchine Trasformazione Carta Srl Banding machine for logs of sheet material
CN101150426B (en) * 2006-09-21 2010-08-25 大唐移动通信设备有限公司 A method and system for reporting buffer status
US8050257B2 (en) * 2006-12-12 2011-11-01 Maged E Beshai Network with a fast-switching optical core
US8335780B2 (en) * 2008-03-11 2012-12-18 James Madison Kelley Scalable high speed relational processor for databases and networks
US20100054128A1 (en) * 2008-08-29 2010-03-04 O'hern William Near Real-Time Alerting of IP Traffic Flow to Subscribers
US8018958B1 (en) * 2009-06-23 2011-09-13 Juniper Networks, Inc. System and method for fair shared de-queue and drop arbitration in a buffer
US8724503B2 (en) * 2010-03-10 2014-05-13 Telefonaktiebolaget L M Ericsson (Publ) Sub-path E2E probing
US20130311609A1 (en) * 2011-01-28 2013-11-21 Napatech A/S An apparatus and a method for receiving and forwarding data packets
US9047417B2 (en) 2012-10-29 2015-06-02 Intel Corporation NUMA aware network interface
US10684973B2 (en) 2013-08-30 2020-06-16 Intel Corporation NUMA node peripheral switch
US9210090B1 (en) * 2014-01-22 2015-12-08 Narus, Inc. Efficient storage and flexible retrieval of full packets captured from network traffic
US9391884B2 (en) * 2014-01-31 2016-07-12 Google Inc. Consistent hashing using exact matching with application to hardware load balancing
US9843530B2 (en) * 2015-12-15 2017-12-12 International Business Machines Corporation System, method, and recording medium for queue management in a forwarder
US10055336B1 (en) * 2016-06-23 2018-08-21 VCE IP Holding Company LLC Computer implemented system and method and computer program product for testing a software component by simulating an interface to a computing component using randomized network packet information

Family Cites Families (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5130984A (en) 1990-12-18 1992-07-14 Bell Communications Research, Inc. Large fault tolerant packet switch particularly suited for asynchronous transfer mode (ATM) communication
JP2751698B2 (en) 1991-12-13 1998-05-18 日本電気株式会社 Self-routing switch circuit
ES2164042T3 (en) 1991-12-23 2002-02-16 Cit Alcatel PROCEDURE TO REDUCE THE NUMBER OF BITS OF A BINARY WORD THAT REPRESENTS A SERIES OF ADDRESSES.
ES1021789Y (en) * 1992-06-25 1993-06-16 CLOSURE FOR NECKLACES, BRACELETS AND OTHER SIMILAR ITEMS OF JEWELRY AND JEWELERY.
JP2655464B2 (en) 1992-12-25 1997-09-17 日本電気株式会社 Packet switching method
US5386413A (en) * 1993-03-19 1995-01-31 Bell Communications Research, Inc. Fast multilevel hierarchical routing table lookup using content addressable memory
US5583861A (en) * 1994-04-28 1996-12-10 Integrated Telecom Technology ATM switching element and method having independently accessible cell memories
KR0132960B1 (en) * 1994-12-22 1998-04-21 양승택 Method and apparatus for detecting congestion status of
US5546390A (en) 1994-12-29 1996-08-13 Storage Technology Corporation Method and apparatus for radix decision packet processing
JPH08288965A (en) * 1995-04-18 1996-11-01 Hitachi Ltd Switching system
US5917805A (en) * 1995-07-19 1999-06-29 Fujitsu Network Communications, Inc. Network switch utilizing centralized and partitioned memory for connection topology information storage
JP3409966B2 (en) * 1996-06-21 2003-05-26 株式会社日立製作所 Packet switch and packet transfer control method
US6442172B1 (en) * 1996-07-11 2002-08-27 Alcatel Internetworking, Inc. Input buffering and queue status-based output control for a digital traffic switch
US5768257A (en) 1996-07-11 1998-06-16 Xylan Corporation Input buffering/output control for a digital traffic switch
JPH10126419A (en) * 1996-10-23 1998-05-15 Nec Corp Atm exchange system
US5870396A (en) 1996-12-31 1999-02-09 Northern Telecom Limited Output queueing in a broadband multi-media satellite and terrestrial communications network
US5938736A (en) * 1997-06-30 1999-08-17 Sun Microsystems, Inc. Search engine architecture for a high performance multi-layer switch element
US6018524A (en) * 1997-09-09 2000-01-25 Washington University Scalable high speed IP routing lookups
US6434115B1 (en) * 1998-07-02 2002-08-13 Pluris, Inc. System and method for switching packets in a network

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101373556B (en) * 2007-08-23 2012-08-01 瑞斯康微电子(深圳)有限公司 Method for transmitting and receiving low pressure carrier wave centralized type network and apparatus thereof

Also Published As

Publication number Publication date
MXPA01000218A (en) 2003-07-14
JP2002520907A (en) 2002-07-09
AU4854799A (en) 2000-01-24
WO2000002347A3 (en) 2000-05-11
US6434115B1 (en) 2002-08-13
US6804241B2 (en) 2004-10-12
US6529478B1 (en) 2003-03-04
EP1092298A2 (en) 2001-04-18
TW461202B (en) 2001-10-21
CN1317189A (en) 2001-10-10
WO2000002347A2 (en) 2000-01-13
RU2001102964A (en) 2003-01-27
US6421342B1 (en) 2002-07-16
US20020186695A1 (en) 2002-12-12

Similar Documents

Publication Publication Date Title
US6421342B1 (en) Packet forwarding apparatus and method using pipelined node address processing
US7480242B2 (en) Pass/drop apparatus and method for network switching node
JP3577188B2 (en) Buffering of multicast cells in multistage networks
JP3443264B2 (en) Improved multicast routing in multistage networks
US9143459B2 (en) Queue speed-up by using multiple linked lists
US8995445B2 (en) System and method for re-sequencing data packets on a per-flow basis
US5732087A (en) ATM local area network switch with dual queues
JP3832816B2 (en) Network processor, memory configuration and method
US5521916A (en) Implementation of selective pushout for space priorities in a shared memory asynchronous transfer mode switch
US7773602B2 (en) CAM based system and method for re-sequencing data packets
US7921241B2 (en) Instruction set for programmable queuing
US7403536B2 (en) Method and system for resequencing data packets switched through a parallel packet switch
JPH09247189A (en) Multi-stage network having multicast routing congestion feedback
KR20020024330A (en) Network switch and components and method of operation
KR19990087752A (en) Efficient Output Request Packet Switch and Method
KR20020026265A (en) Network processor processing complex and mrthods
US7269158B2 (en) Method of operating a crossbar switch
JP2000083055A (en) Router
US20020027909A1 (en) Multientity queue pointer chain technique
US6636952B1 (en) Systems and methods for processing packet streams in a network device
US6320858B1 (en) Asynchronous transfer mode switch with logical multicasting
JP2739949B2 (en) Communication buffer device
Feng Design of per Flow Queuing Buffer Management and Scheduling for IP Routers
Shobatake A Cell Buffer Implementation Realizing CLP and Its Application

Legal Events

Date Code Title Description
FZDE Discontinued