US20030107996A1 - Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost - Google Patents
Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost Download PDFInfo
- Publication number
- US20030107996A1 US20030107996A1 US10/349,739 US34973903A US2003107996A1 US 20030107996 A1 US20030107996 A1 US 20030107996A1 US 34973903 A US34973903 A US 34973903A US 2003107996 A1 US2003107996 A1 US 2003107996A1
- Authority
- US
- United States
- Prior art keywords
- port
- fcal
- node
- switch
- data
- 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
Links
- 239000000835 fiber Substances 0.000 title claims description 47
- 239000000872 buffer Substances 0.000 claims abstract description 125
- 238000000034 method Methods 0.000 claims abstract description 63
- 230000008569 process Effects 0.000 claims abstract description 56
- 230000015654 memory Effects 0.000 claims abstract description 54
- 230000009977 dual effect Effects 0.000 claims description 94
- 238000012546 transfer Methods 0.000 claims description 48
- 238000004891 communication Methods 0.000 claims description 34
- 239000004744 fabric Substances 0.000 claims description 34
- 230000006870 function Effects 0.000 claims description 32
- 230000004044 response Effects 0.000 claims description 32
- 230000008878 coupling Effects 0.000 claims description 31
- 238000010168 coupling process Methods 0.000 claims description 31
- 238000005859 coupling reaction Methods 0.000 claims description 31
- 230000005540 biological transmission Effects 0.000 claims description 27
- 238000011084 recovery Methods 0.000 claims description 13
- 230000000903 blocking effect Effects 0.000 claims description 7
- 230000003139 buffering effect Effects 0.000 claims description 6
- 238000013507 mapping Methods 0.000 claims description 6
- 238000002156 mixing Methods 0.000 claims description 5
- 230000002194 synthesizing effect Effects 0.000 claims description 2
- 238000013506 data mapping Methods 0.000 claims 3
- 238000007726 management method Methods 0.000 claims 2
- 241000894007 species Species 0.000 description 30
- 229940125364 angiotensin receptor blocker Drugs 0.000 description 19
- 238000013461 design Methods 0.000 description 17
- 238000012545 processing Methods 0.000 description 17
- 230000007704 transition Effects 0.000 description 16
- 230000008901 benefit Effects 0.000 description 15
- 238000010586 diagram Methods 0.000 description 15
- 238000012360 testing method Methods 0.000 description 14
- 230000007246 mechanism Effects 0.000 description 7
- 235000003642 hunger Nutrition 0.000 description 6
- 230000037351 starvation Effects 0.000 description 6
- 238000006243 chemical reaction Methods 0.000 description 5
- 238000012544 monitoring process Methods 0.000 description 5
- 230000010354 integration Effects 0.000 description 4
- 230000001360 synchronised effect Effects 0.000 description 4
- 238000013459 approach Methods 0.000 description 3
- 230000003247 decreasing effect Effects 0.000 description 3
- 230000001934 delay Effects 0.000 description 3
- 230000006872 improvement Effects 0.000 description 3
- 230000011218 segmentation Effects 0.000 description 3
- 230000011664 signaling Effects 0.000 description 3
- 238000003860 storage Methods 0.000 description 3
- 230000001960 triggered effect Effects 0.000 description 3
- 239000002699 waste material Substances 0.000 description 3
- 230000006399 behavior Effects 0.000 description 2
- 230000002457 bidirectional effect Effects 0.000 description 2
- 238000010276 construction Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000000977 initiatory effect Effects 0.000 description 2
- 238000003780 insertion Methods 0.000 description 2
- 230000037431 insertion Effects 0.000 description 2
- 239000011159 matrix material Substances 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000008439 repair process Effects 0.000 description 2
- 239000013598 vector Substances 0.000 description 2
- 241001522296 Erithacus rubecula Species 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 239000002333 angiotensin II receptor antagonist Substances 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- TZCXTZWJZNENPQ-UHFFFAOYSA-L barium sulfate Chemical compound [Ba+2].[O-]S([O-])(=O)=O TZCXTZWJZNENPQ-UHFFFAOYSA-L 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 230000009172 bursting Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000012508 change request Methods 0.000 description 1
- 239000004020 conductor Substances 0.000 description 1
- 238000005520 cutting process Methods 0.000 description 1
- 230000001351 cycling effect Effects 0.000 description 1
- 238000012217 deletion Methods 0.000 description 1
- 230000037430 deletion Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000011049 filling Methods 0.000 description 1
- 238000009499 grossing Methods 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 239000012464 large buffer Substances 0.000 description 1
- 230000036961 partial effect Effects 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 238000002360 preparation method Methods 0.000 description 1
- 230000000135 prohibitive effect Effects 0.000 description 1
- 230000000644 propagated effect Effects 0.000 description 1
- 238000010926 purge Methods 0.000 description 1
- 230000008929 regeneration Effects 0.000 description 1
- 238000011069 regeneration method Methods 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000009747 swallowing Effects 0.000 description 1
- 238000003786 synthesis reaction Methods 0.000 description 1
- 238000011144 upstream manufacturing Methods 0.000 description 1
- WDQKVWDSAIJUTF-GPENDAJRSA-N via protocol Chemical compound ClCCNP1(=O)OCCCN1CCCl.O([C@H]1C[C@@](O)(CC=2C(O)=C3C(=O)C=4C=CC=C(C=4C(=O)C3=C(O)C=21)OC)C(=O)CO)[C@H]1C[C@H](N)[C@H](O)[C@H](C)O1.C([C@H](C[C@]1(C(=O)OC)C=2C(=C3C([C@]45[C@H]([C@@]([C@H](OC(C)=O)[C@]6(CC)C=CCN([C@H]56)CC4)(O)C(=O)OC)N3C=O)=CC=2)OC)C[C@@](C2)(O)CC)N2CCC2=C1NC1=CC=CC=C21 WDQKVWDSAIJUTF-GPENDAJRSA-N 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04J—MULTIPLEX COMMUNICATION
- H04J3/00—Time-division multiplex systems
- H04J3/24—Time-division multiplex systems in which the allocation is indicated by an address the different channels being transmitted sequentially
- H04J3/245—Time-division multiplex systems in which the allocation is indicated by an address the different channels being transmitted sequentially in which the allocation protocols between more than two stations share the same transmission medium
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/35—Switches specially adapted for specific applications
- H04L49/356—Switches specially adapted for specific applications for storage area networks
- H04L49/357—Fibre channel switches
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/10—Packet switching elements characterised by the switching fabric construction
- H04L49/101—Packet switching elements characterised by the switching fabric construction using crossbar or matrix
Definitions
- Fibre Channel networks are known loop configuration networks that have a plurality of known type nodes such as servers, printers, disk arrays etc. all connected together by the loop. Such networks use a unique protocol involving a plurality of 40 bit primitives that are used to arbitrate for loop control, to establish connections and to carry out flow control for data transfers of frames of data.
- the flow control inherent to the Fibre Channel Arbitrated Loop network (hereafter FCAL nets) protocol has the advantage of eliminating the need for the nodes to have extensive buffering capabilities since the destination node controls the amount of data it receives by transmission of an RRDY primitive to the source node each time the destination node is ready to receive another frame.
- Fibre Channel networks emerged as a family of interconnection topologies to increase bandwidth over fast-wide SCSI networks and to increase the number of server and storage elements that can be connected to 126 over the 16 device limit of SCSI.
- Advantages of FCAL include that devices may be farther apart (up to 10 km) and more numerous and that the size of data transfers is very large compared to the overhead that is required to set up every transfer. This makes FCAL very efficient and more attractive than less efficient protocols such as TCP/IP over Ethernet and SCSI over a bus connection.
- Hub based network topologies are generally desirable because they overcome certain limitations on the number of nodes that can be coupled to a network by breaking it up into segments coupled by the hub.
- Many Ethernet networks use hubs as do token ring networks.
- Hubs in FCAL networks receive packets from a source node on an input line coupled to the source node and rebroadcast the packet on an output line coupled to the next node which rebroadcasts the packet to the next node and so on. The rebroadcast by subsequent nodes in the chain wastes computing resources.
- Switched topologies work differently in that packets are not rebroadcast, but instead are connected directly to the line coupled to the destination node thereby eliminating processing by other nodes which are not the destination to receive and rebroadcast messages not destined for that node.
- each node contains an elasticity buffer or FIFO to absorb the differences between incoming and outgoing data rates. Data passing through a node enroute to its destination passes through the nodes elasticity buffer and suffers a typical delay of 3 words.
- disk clusters are 10 drives to a cluster with each drive being one node and imposing its own delay. If there are 10 clusters coupled to a server, this would represent typically 5.3 microseconds of delay in transition of each primitive and data frame travelling around the loop. In other words, this delay is imposed on each loop tenancy.
- In an I/O operation there are typically 4 tenancies for a write to disk, each involving 3 “round trips”: ARB, OPN-RRDY and Data/CLS (see ANSI standard X3T10 FCP which is hereby incorporated by reference). Thus, 12 delays would be suffered by each command transaction. On a 100 node loop, this translates to approximately 64 microseconds of delay per command.
- Prior art Fibre Channel switches are commercially available from Ancor and Brocade Communications which provide spatial reuse and efficient link utilization.
- the FL_ports connected to these switches also address physical delays as they pertain to FCAL.
- these switches require link rate frame buffering to accomplish their performance levels, and also operate on the entire 24-bit address contained in the FC frame.
- the invention described herein uses zero buffering and an 8-bit address decode for a much more efficient and inexpensive design.
- the Fibre Channel Arbitrated Loop (FCAL) topology emerged as a way of providing simple, low-cost connectivity to more nodes over a shared media than could be provided in point-to-point topologies without the requirement for an expensive fabric switch.
- FCAL networks allow up to 126 node ports to be coupled by a shared media using a simple protocol without the need for a separate fabric switch.
- switched fabric topology which has a centralized approach to routing
- FCAL networks distribute the routing function to each loop port. This reduces the cost of achieving interconnection since the loop functionality represents a relatively small addition to the normal port functionality that has to be present anyway.
- FCAL networks suffer the disadvantage that the number of concurrent interconnections possible is smaller than in switched-fabric networks because FCAL networks are fully blocking topologies such that only two pairs of nodes on the loop can communicate at any particular time. All other nodes have to wait until the first pair are done communicating before the loop is available for another pair to communicate. The address space is also limited to 126 nodes.
- Another problem with FCAL topologies is that traffic originating from a source node had to travel through each intermediary node on the loop portion between the source node and a destination node.
- each FCAL subloop must be coupled to the fabric switch by a complicated port called an FL_port.
- FL_ports These are ports which must be able to understand the FCAL loop protocol on one side of the port and interface it with the very different and substantially more complex fabric switch packet switching protocol on the other side of the port while also having bridging functionality.
- Such FL_ports must have protocol layers that understand each protocol and can do packet routing and communicate with each other.
- FL_ports are expensive to build. This is because of the inordinate amount of buffer memory that is needed in the front end of the FL_port to reconstruct the sequences of packets contained in one FCAL tenancy.
- Modern day connectionless fabric switch protocols are pure packet switching while FCAL loop tenancy protocols are single conversations which tend to be like a simple switched circuit and contain many packets. That is, the FCAL loop tenancy protocol starts with an OPN primitive directed to a destination node which responds with an RRDY directed to the source. These primitives set up switches in the nodes so that the source and destination nodes talk directly to each other through the loop segment between them and the intervening nodes by sending one or more frames of data until a CLS primitive is sent which ends the conversation.
- the packet switching done by an FL_port on the switch backplane side is not nearly this simple.
- the packet switching protocol requires the FCAL frames output by a source node to be treated as many individual packets. Those packets must be routed to the correct destination FL_port and reassembled there without loss of data and launched on the FCAL loop on which the destination port is resident.
- FL_ports will receive packets from the fabric switch side and data frames and primitives from the FCAL loop side and must have the memory and intelligence to convert between the two protocols.
- Kemble proposes a “Smart Hub” conceptual network.
- This network is comprised of a plurality of FCAL loops coupled together by a smart hub which has the intelligence to provide independent operations within each loop.
- a source node want to exchange data with a destination node, it arbitrates for its local loop and attempts to establish a loop connection with the destination. If the destination is local, the smart hub simply acts as a repeater.
- the smart hub intercepts the attempt to establish a loop connection, acquires access to the proper destination loop and establishes the loop connection between the source and destination loops acting like a bridge.
- one loop can talk to another without affecting activity which is purely local to the other loops not involved in the connection, but the other loops cannot set up simultaneous connections to nodes on other loops during the tenancy across the smart hub of the first cross-boundary connection between the two loops already connected across the smart hub.
- This type arrangement cannot satisfy the need for a fast switch which is affordable and provides the ability for multiple pairs of ports to communicate simultaneously across the switch.
- the assignees of the present invention devised a network topology using intelligent hubs each of which had routing intelligence and each of which had its own subloop coupled to a plurality of conventional L_port nodes of a type used in conventional FCAL topologies.
- Each hub was coupled to each other hub by a broadcast data path and a return data path.
- the hubs were able to deduce the location of the source and destination nodes and cut out all subloops and nodes thereon that were not necessary for communication between the source and destination nodes thereby decreasing unnecessary delay in completing each loop tenancy and increasing bandwidth.
- the assignee of the invention has also filed a co-pending patent application on a learning bridge for FCAL topologies such that two or more FCAL loops can be coupled together by bridges.
- the bridges have the intelligence to examine the destination addresses of OPN primitives received from their local loops and watch the primitives of loop tenancies and the loops from which they came and to learn the locations of various nodes on the loops to which they are coupled.
- Each bridge then forwards OPN primitives from one loop to another if the destination node is on a different loop than the source node, but keeps the OPN local to the same loop as the source is on using a local bypass data path if the destination and source nodes are on the same loop.
- This provides the ability for concurrent loop tenancies to be occurring on the two loops coupled to the bridge, although only one loop tenancy per loop is allowed at any particular time. This technology is described in the parent application incorporated by reference herein.
- Two important attributes of all species within genus of the invention are: first, the use of the destination address in an FCAL OPN primitive (hereafter referred to as an OPN) instead of a frame header of a frame of data to find the destination node and establish the connection through the switch; and, second, using the normal flow control primitives of the FCAL protocol for hold back purposes to eliminate the need for large buffer memories in the switch and so as to implement a switching protocol to stream complete data frames from source to destination without storing any data frames in the switch, and without any packetizing, and without any segmentation and reassembly processing, and without any error recovery protocols to retransmit dropped frames. Any species that shares these two characteristics is within the preferred genus of the invention.
- This preferred genus qualifies for class 2 Fibre Channel operation where frames cannot be dropped because the flow control nature of the switch prevents frames from ever being dropped because they are only transmitted when the destination node has indicated it can receive them.
- the preferred genus can also be operated in class 3 Fibre Channel operation where it is permissible to drop frames and upper level protocols do error recovery for dropped frames even though the switch never drops frames.
- a separate second genus of FCAL switches suitable for Class 3 Fibre Channel operation only, still uses the destination address in the OPN to find the remote port but uses buffers instead of hold back flow control to complete the transaction to busy remote ports. Specifically, species within this genus will use the destination address of the OPN from the source node to find the location of the remote port. Then the status of that port will be checked. If the status is available, a connection request will cause a connection to be set up. between the source node and the destination node via a source port connected to the source node and a destination port connected to the destination node. The buffer comes into play when the destination port is busy.
- the normal primitives of the FCAL protocol are used for flow control to prevent the source node from transmitting any frames of data until the destination port becomes available.
- a buffer big enough to hold one or more complete frames of data is included in the front end of each switch chip, or multiple buffers each big enough to store a frame of data are included with each switch chip front end.
- Each of these buffers will serve as an auxiliary switch port and have its own connection to the backplane in some species or a single shared connection to the backplane through a multiplexer can be used.
- the preferred species uses multiple buffers each with its own connection to the backplane in addition to a connection directly from the switch port to the backplane for direct connections without buffering.
- a single shared buffer or multiple shared buffers on the backplane or in some central location may be used.
- the way the buffers are used is for the source port to generate an RRDY sua sponte when it finds from a check of the scoreboard that the destination port is busy.
- the RRDY is sent to the source node and causes it to output a frame of data.
- This frame of data is stored in the switch port's buffer.
- a message is sent to the destination port indicating that the auxiliary buffer of the switch port is holding a frame of data for the destination port.
- This auxiliary buffer ID is added to the camp list for the destination port.
- a message is sent back on the protocol bus indicating that the destination port is now available and naming the backplane channel to use.
- a connection through the backplane is then established to this channel by the auxiliary buffer connection circuitry and the destination port, and the data in the auxiliary buffer is transmitted.
- the switch port has multiple auxiliary buffers, they each have their own IDs and, preferably, each has its own switching circuitry to make a connection to the backplane.
- each auxiliary buffer has circuitry coupled to the return path to recognize RRDYs transmitted back by the destination node and to count them (or store them) and to wait for a connection between the source port and the RRDY counting circuit if the connection is not continuous such as in some cases where multiple buffers are present in each switch port.
- These stored RRDYs (or self generated in the case of a count only) can be transmitted to the source node in the case of full duplex or mixed with frames from a third node in the case of a dual simplex connection and transmitted to the source node.
- Each source port also has shared circuitry for each FCAL net which recognizes incoming RRDYs from the source node and counts them or stores them. These source node generate RRDYs can be transmitted to the destination node in the case of full duplex or transmitted to a third node in the case of dual simplex.
- the FCAL OPN primitive is a small 40 bit quantity which includes a code indicating it is an OPN primitive and includes a destination address, and an optional source address if the OPN is full duplex. Receipt of the OPN starts the process carried out by the switch of finding the destination and causes establishment of the connection or a notification to the source that the connection could not be established before any data frame is ever transmitted to the switch. This lack of transmission of any large data frame before establishment of the connection means that the switching circuits connected to each FCAL loop coupled to the overall switch structure do not need to have buffer memories to store the data while the connection is being made or the fact that a connection is not possible is established. This allows for greatly simplified hardware. This means lower costs and greater density of ports per chip. This cost advantage is a significant improvement over prior art approaches.
- the major subclass of embodiments taught herein uses a plurality of ports for connection to individual FCAL loops, and a crossbar switch which couples the ports together and which can implement any number of separate data transfer channels under control of the ports with the port using the destination address information in the OPN primitives to determine whether or not a connection through the backplane from one port to another is needed.
- the ports are integrated circuits with many ports on one chip and a portion of a distributed crossbar switch also integrated on the chip to selectively couple the integrated circuit to one of the backplane data path channels.
- Each port is essentially a learning bridge front end with an interface to the crossbar switch on the backend.
- Fairness is provided, in the preferred embodiment, by a fairness token which circulates to all the ports and which, when held by a particular port, gives that port “high priority status”. This means that if an OPN comes in to a port with the fairness token in its possession and the destination node is on a remote port, the high priority status of that port means that it can “camp” on the remote port and wait for it to be available and it is guaranteed access to the destination node no matter how busy it is. Since the fairness token circulates, no port will ever be starved from communication with a busy node.
- Location of the destination node can be by any of several means since the OPN includes the destination address therein.
- the destination address from the OPN is use to address a lookup table which outputs data as to which loop the destination node is on and to which switch chip or port coupled to the destination loop the switching connection should be made.
- This embodiment has the advantage that all the connection information is immediately available. This allows the connection to occur more rapidly.
- the disadvantage of this species is that the look up table is larger and each port must carry a full copy of the routing table.
- One alternative embodiment uses a destination location process wherein the destination address of the OPN from the source node is used to address a lookup table (hereafter LUT) which only outputs a single bit indicating, in one logic state, that the destination node is “local”, i.e., on the same FCAL network as the source node, or indicating, in the opposite logic state, that the destination node is not on the local loop. If the destination is not local, the destination address is broadcast as a location request to the other switch chips coupled to the other FCAL networks connected to the switch. Each of the other switch chips then checks its local LUT using the destination address to determine if it has the destination node on its loop.
- LUT lookup table
- the switch chip that has the destination node finds this out from data returned from its local LUT and then sends a message to the switch chip coupled to the loop having the source node telling it to where the connection is to be made and whether the connection can be made, i.e., the loop upon which the destination node is not busy in another conversation and is available for the connection.
- the advantage of this species is a smaller routing lookup table may be used in each port.
- the disadvantage is the requirement of more message traffic between chips resulting in slower response.
- An example of an FCAL switch within the genus of the invention is a bufferless switch for coupling to a plurality of FCAL nets and having a crossbar switch and FCAL loop interface port circuits structured to use the OPN and RRDY primitives of the FCAL protocol for hold back flow control to eliminate the need for a buffer with the ports and crossbar switch structured to provide multiple simultaneous loop tenancies.
- Protocol within the genus of protocols which define the rules to set up a connection through an FCAL switch within the genus of the invention between a source node and a destination node and transfer data therebetween is:
- the preferred subclass of the switch utilizes the concepts of the learning bridge taught in the parent application incorporated by reference herein for front end circuitry coupled to the FCAL net with backend circuitry which is coupled to a crossbar switch.
- the bridging front end uses the destination address in the OPN to decide whether or not to connect the front end circuitry to the back end circuitry.
- the crossbar switch implements a plurality of completely separate data paths through the switch each of which can couple two port together. The provision of multiple separate data paths through the crossbar switch eliminates any bottlenecks which could occur if a multiplexed data bus were to be substituted for the crossbar switch. It is within the genus of the invention however to substitute a multiplexed bus for the crossbar switch using any form of multiplexing.
- the switch apparatus genus could be generally described as including multiples species, each comprised of a plurality of half bridges, each with a front end for connnecting to an FCAL loop and a backend coupled to either a crossbar switch or a multplexed bus along with suitable control circuitry to use the destination addresses in OPN primitives to determine whether a connection between two ports through the crossbar switch or multiplexed bus is necessary and, if necessary, for establishing the connection.
- each half bridge is one port.
- the half bridges are implemented as integrated circuits with a multiplicity of half bridges on every chip with each half bridge building its own routing table by a passive learning process.
- An alternative embodiment uses an active discovery process to build the routing table.
- the switch architecture can be thought of as a multi-port switch with a stack of learning half bridges substituted for each FL_port of a prior art fabric switch, with each half bridge on each layer being coupled to its own local FCAL loop or single NL node.
- the other side of each half bridge is connected to the high speed crossbar switch in the preferred embodiment so that it can be connected to the other half bridges.
- the crossbar switch can be though of a stack of separate layers of separate high speed backplane data paths connecting all the half bridges together by way of a switching network between the high speed backplane data path layers.
- the switching network functions to establish selective connections between layers and can be controlled such that any bridge on any layer can talk to any other bridge on any other layer.
- the switch architecture allows simultaneous purely local loop tenancies on any FCAL net coupled to any particular half bridge so long as another node on the FCAL net is not involved in a loop tenancy which involves communication across the switch from one port on one FCAL net to another port on another FCAL net.
- Another significant advantage of the invention is that the nodes on the individual FCAL nets can be conventional NL node designs which already exist.
- An NL node is a node on an FCAL net which understands and can implement the FCAL flow controlled loop connection protocol between source and destination nodes to transfer data using OPN, RRDY and CLS primitives and large data frames. Because the embodiments of the switches described herein are all compatible with conventional NL nodes, the genus of switches described herein has the advantage that when the network is upgraded, only the switch needs to be upgraded and all the nodes can remain the same thereby saving substantial expense to the customer.
- Dual simplex capability is also taught to improve the throughput of any network of FCAL nets coupled by any type of switch. Dual simplex capability allows a source node on a first FCAL net which is transmitting data on a front channel connection to a destination node on a second FCAL net through a switch connection to simultaneously receive data via a back channel connection from a third node on a third FCAL net. This is advantageous to improve throughput because in many cases, destination nodes to which data has been transmitted have no data to transmit back to the source node that sent them the data while other nodes do have data to be transmitted to the source node.
- Dual simplex capability is accomplished in all species within the genus of the invention to further increase throughput. It is accomplished by three basic steps, illustrated in FIG. 15:
- step 354 2) establishing a back channel data path between a third node and said source node but not transmitting to said source node any OPN primitive emitted by said third node (step 354 ), and transmitting a number of RRDYs either equal to the number of RRDYs output by said source node or the number of RRDYs needed by said third node to send all the data it has to said source node before closing said back channel connection (step 356 ), transmission of said RRDYs being one at a time—any excess RRDYs not used by the third node are saved for use by another third node in a subsequent dual simplex back channel connection; and
- FIG. 1 is a drawing of one example of an FCAL switched architecture according to the teachings of the invention.
- FIG. 2 is a drawing of another example of an FCAL switched architecture according to the teachings of the invention having multiple subloops within some of the FCAL coupled to the switch.
- FIG. 3 is a block diagram of the preferred switched FCAL architecture.
- FIG. 4 is a flow chart of the processing which occurs for a purely local transaction.
- FIG. 4 is a block diagram of the general preferred architecture of a switch to couple a plurality of FCAL nets to provide spatial reuse.
- FIG. 5 is a block diagram of the specific preferred “switch slice” architecture of a switch to couple a plurality of FCAL nets to provide spatial reuse with multiple port circuits and a portion of the crossbar switch integrated on each switch chip.
- FIGS. 6A through 6C are a flow diagram of a routing algorithm for general switch mode operation (non dual simplex).
- FIG. 7 is a block diagram of the preferred architecture of each switch chip in the FCAL switch system.
- FIG. 8 is a diagram of an FCAL switch with two switch chips configured to run in hub mode.
- FIG. 9 is a diagram of an FCAL switch system with two switch chips configured to run in switch mode and illustrating loop-local, chip-local and remote port simultaneous loop tenancies.
- FIG. 10 is a block diagram of the multiplexer structure in each switch chip that allows port bypass mode, parallel loopback mode and serial loopback mode to be implemented.
- FIG. 14 is a table describing and naming each state in the loop port state machines of each port of each switch chip.
- FIG. 12 is a table of the source port fill word generation for various input words and states.
- FIG. 13 is a table of the destination port fill word generation for various input words and states.
- FIGS. 14A through 14E are diagrams of the five different message formats on the protocol bus.
- FIG. 15 is a generic flow diagram illustrating the minimum basic steps each species in the genus of the invention would have to carry out to implement dual simplex operation.
- FIGS. 16A through 16D are a flow chart of the specific steps carried out by the preferred embodiment to carry out dual simplex communications.
- Fibre Channel Arbitrated Loop standards memorialized in the following ANSI standards are hereby incorporated by reference: X3.230-1994 describing the physical and signalling interface; X3.297-1996 describing the physical and signalling protocol; X3.272-1996 describing the general FCAL protocol and TR-20-199X, T11 Project 1235-DT, Fibre Channel Fabric Loop Attachment (FC-FLA).
- FCAL switch 10 is coupled to four FCAL networks (hereafter sometimes referred to as FCAL nets) 12 , 14 , 16 and 18 in this example.
- FCAL net can have one or more NL nodes thereon.
- Each of the four FCAL networks is coupled to a plurality of NL nodes which have conventional structure and which can carry out FCAL arbitration, data transfer and flow control operations on the FCAL networks.
- Each node is assigned an address from one of the 127 possible FCAL addresses.
- each node is given a number symbolizing its address designated in the figure by N and a number inside the circle symbolizing the node.
- the function of the switch 10 is to increase total throughput of the system by allowing concurrent conversations to be occurring between pairs of NL nodes, and by doing so in a manner that is not limited by any restriction against “crossing conversations” in the switch itself.
- a new standard for FCAL topology proposed by IBM involves counterrotating, separate FCAL rings with nodes coupled to both counterrotating rings. This allows concurrent conversations to occur, but the conversations cannot “cross”, i.e., it is illegal in this protocol for both conversations to require the same segment of an FCAL as part of the data path for the conversation.
- Conversation as that term is used herein, means a data transfer between two different nodes.
- the function of the switch 10 is to allow as many concurrent conversations as possible except that no two source nodes can be talking to different destination nodes on the same FCAL network.
- each of FCAL networks 12 , 14 , 16 and 18 is limited to only one conversation at a time even though data flow from multiple conversations may be simultaneously be flowing through switch 10 . This is done by establishing “virtual channels” for each conversation through the switch using separate data paths (or multiplexing techniques in some embodiments).
- the physical configuration of the switch 10 is not currently believed to be important so long as it uses the destination address in each OPN from a source node to control setting up a separate data path through the switch for transfer of data between that source node and a destination node and uses flow control primitives of the FCAL protocol to control the flow of data such that the switch does not need to have a buffer memory big enough to hold an entire FCAL frame.
- each FCAL network 12 , 14 , 16 and 18 has a one Gigabit/second data throughput capacity. Therefore, the maximum throughput of the system shown would be 4 Gigabits/second if each of the FCAL networks 12 , 14 , 16 and 18 had a purely local conversation occurring thereon.
- FIG. 2 An example of a topology that can take advantage of this feature is shown in FIG. 2.
- switch 10 is coupled to FCAL networks 12 , 14 , 16 and 18 .
- FCAL network 12 is divided into two FCAL subnetworks 12 and 20 by FCAL bridge 22
- FCAL network 14 is divided into two FCAL subnetworks 14 and 24 by FCAL bridge 26 .
- FCAL network 16 is divided into three FCAL subnetworks 16 , 28 and 30 by FCAL bridges 32 and 34 .
- FCAL bridges 22 , 26 , 34 and 32 can have the construction detailed in co-pending U.S.
- FIG. 3 is a high level block diagram of the internals of the FCAL switch 10 for the preferred embodiment using a crossbar switch 44 to make the switched electrical connections between FCAL networks 12 , 14 , 16 and 18 .
- Each of the FCAL networks 12 , 14 , 16 and 18 is coupled to its own switch control circuit, i.e., switch control circuits 36 , 38 , 40 and 42 , respectively.
- the switch control circuits 36 , 38 , 40 and 42 are distinguished from switch control circuits of prior art switch designs by the fact that none of them have buffer memory therein large enough to store an entire frame of data or enough memory to carry out the packetization process of prior art switch designs.
- the function of the switch control circuits 36 , 38 , 40 and 42 is to transmit primitives and data involved in FCAL arbitration, data transfer and flow control to the appropriate loop segment, do bypass switching when a conversation is completely local so as to bypass the crossbar switch 44 , to collectively locate the destination nodes when OPNs are received, and to send appropriate control signals to the crossbar switch once the destination node has been located so as to connect the appropriate FCAL networks together to complete the conversation.
- the crossbar switch 44 has 4 inputs and 4 outputs with 1 input and 1 output for each FCAL.
- the crossbar switch serves to make a data path through the appropriate switch control circuit to the input and output of one FCAL having the source node thereon to the output and input, respectively of another FCAL having the destination node thereon through the appropriate switch control circuit so as to provide a channel through which the conversation between the source node and the destination node may proceed.
- the crossbar switch must be able to simultaneously connect the input and output of another FCAL having another source node thereon to the output and input, respectively of yet another FCAL having another destination node thereon to provide a data path or channel for a second concurrent conversation. This concept is extended for as many pairs of FCAL as are connected to the switch.
- enable signals are generated by the switch control circuits based upon the locations of the destination nodes for the concurrent conversations. Any crossbar switch that can perform the above described function will suffice providing it can support the necessary data rate and traffic volume.
- the switch control circuits 36 , 38 , 40 and 42 are coupled by a protocol bus 54 .
- this protocol bus may be multiplexed using any multiplexing scheme such as TDMA.
- crossbar switch 44 can be omitted and a TDMA bus substituted with timeslot assignments taking the place of assignments of particular backplane channels through the crossbar switch and messages on the protocol bus updating all switch ports with information about which timeslots are in use and which timeslots are available.
- FIG. 4 there is shown a block diagram of the general architecture of the preferred Fibre Channel switch.
- the switch is comprised of a crossbar switch 100 coupled to a plurality of learning half bridges such as are represented typically by blocks 102 , 104 and 106 .
- Each learning half bridge has a port having an input and an output for coupling to separate input and output wires or fibers of the Fibre Channel link.
- the Fibre Channel link of each port can be coupled to an individual NL port such as block 108 or an FCAL net such as is represented by NL ports 110 and 112 and links 114 , 116 and 118 .
- An FCAL net can have one or more NL nodes on it, so even the connection to the single node 108 is an FCAL net using a Fibre Channel protocol as those terms are used in the claims.
- Each learning half bridge in the switch can have a similar front end structure and mode of operation as that described in the parent application Ser. No. 08/786,891, filed Jan. 23, 1997 which is incorporated by reference herein, but preferably has the structure described below in FIG. 7.
- the “front end” structure refers to the circuitry that is coupled to the port and any Fibre Channel link connected thereto.
- Each learning bridge port circuit (hereafter sometimes referred to as a port) is coupled to a 50 Mhz 24 bit protocol bus 121 .
- Link 123 represents this connection between port 106 and the protocol bus.
- the protocol bus is where each port posts its transactions indicating its local FCAL net is busy or has become available so as to update that port's status information in a local copy of scoreboard table 125 in memory.
- each port maintains a synchronized local copy of the scoreboard table and the contents are written to the scoreboard by learning from messages posted on the protocol bus.
- Synchronized means all copies of the scoreboard have the same information at all times to avoid “fatal embrace” scenarios (fatal embraces are discussed in the parent bridge case).
- the scoreboard 125 and routing table 127 are shown as central shared circuits, but in the preferred embodiment of FIG. 5, every port circuit 124 , 126 and 128 has its own copy of the scoreboard table and a routing table.
- the protocol bus is also the communication path used by a first port when an OPN to a remote destination node comes in to send a request for a connection to a second port coupled to the destination node.
- the connection request is sent on the protocol bus after the first port checks the scoreboard and determines that the second port is available.
- the request causes the second port to begin arbitrating for control of its local FCAL net.
- the scoreboard contains circuitry to read messages on said protocol bus and use the information therein regarding the identity of the sending port and the status codes in the message to update the status entry for the sending port.
- the structure of this circuitry is not critical, and anything that can perform this function will suffice.
- Each learning half bridge includes a streaming back end which drives a bidirectional port such as ports 120 and 122 coupled to the crossbar switch.
- This streaming backend allows large strings of data to be sent all the way from the source node to the destination node as a stream without the need to buffer any of it.
- the structure of the streaming backend and the half bridge front end is such that hold back flow control is used so that no frames are stored—they just stream all the way from the source to the destination under buffer by buffer accounting using primitives for buffer management in the nodes themselves and not in the switch. As a result, no frames are ever dropped and there is no need for buffer management in the switch itself nor any need for dropped frame error recovery protocols in the switch or nodes.
- the acknowledged, connectionless class of service in Fibre Channel does not eliminate or reduce the frequency of dropped frames.
- Class 2 has negative acknowledgements to the source node from the fabric or destination node if/when any frames are dropped.
- This negative acknowledgement may provide more timely notification of dropped or reected frames. It does not improve the intrinsic reliability of FC networks.
- the hold back flow control which is part of the FCAL protocol is used to advantage to eliminate the need for buffer memory in the switch.
- frames are not held in buffer memory, so they cannot ever be dropped because of congestion.
- the “hold back flow control” used by the invention prevents data from ever being transmitted from the source until the switch is ready to stream it to its destination. Therefore, there is no need for any complicated error recovery protocols in the switch or in the nodes and no need for massive amounts of memory in the switch. This is only possible in the Fibre Channel protocol where the possibility of using hold back flow control exists by virtue of the use of primitives and buffer by buffer accounting. There is no low level flow control in ATM or 1 GB Ethernet protocols.
- Those protocols have X-on and X-off flow control on a higher level of the ISO level.
- This X-on and X-off flow control is “embedded” in the data characters, in contrast to Fibre Channel where buffer-to-buffer flow control is external to any data or frames.
- the OPN primitive signals when a source node has data to send, and the destination node then signals with a RRDY primitive sent back to the source saying it has reserved space to receive a frame. One and only one frame is then sent and no other frames are sent until the source receives another RRDY primitive from the destination node.
- This use of primitives and reserved space and buffer by buffer accounting is the meaning of hold back flow control which is used in the invention.
- Prior art switch designs typically had a crossbar switch chip coupled to a plurality of switch module chips each of which had a substantial amount of the die area consumed by buffer memory cells. Thus two separate chip designs were necessary to implement a switch.
- the architecture of the invention since part of the crossbar switch and the port circuitry for several ports are on one IC die, only one chip design is necessary to implement a switch.
- This crossbar switch has 14 backplane channels, but they are not all available because each switch port chip also includes access circuitry to the backplane channels. If only two switch port chips having the architecture of FIG.
- each switch port chip is a network slice and a network can be fabricated with as many ports as needed, and the crossbar switch will automatically grow in available bandwidth in proportion to the number of ports adequately to handle the increased traffic.
- FIG. 5 illustrates the actual architecture of the preferred species of the separate channels backplane subclass of switches.
- Each block 124 , 126 and 128 represents an integrated switch chip having a plurality of ports (learning half bridges) and a portion of the crossbar switch thereon. The function of each of the half bridge ports is to provide switching capability between networks connected using the Fibre Channel physical layer and the Fibre Channel Arbitrated Loop transmission layer protocol.
- a point-to-point backplane data path 130 comprised of a plurality of channels through the distributed crossbar switch carries data from port to port. Each channel has a conductor in both directions.
- Each channel is a separate one gigabit per second data path which is selectively coupled by the crossbar switch to the two ports involved in a loop tenancy and is not shared by any other ports at that time.
- the function of the backplane data path 130 combined with the crossbar switch is to carry multiple conversations of data between ports simultaneously.
- each of the switch chips 124 , 126 and 128 contains a plurality of independent ports, spatial reuse and concurrency is achieved in the architecture of the invention in three ways: first, any purely local conversations between source and destination nodes on the same FCAL net can simultaneously occur on all FCAL nets without consuming either switch chip or backplane bandwidth; second, any conversations between different FCAL nets coupled to the same switch chip can occur purely within each switch chip without consuming any bandwidth on the backplane bus; and, third, the multiple backplane data paths allow multiple simultaneous conversations between nodes on FCAL nets coupled to different switch chips.
- a peak achievable bandwidth of 72 Gbits/sec is achievable with no backplane channel utilization representing 36 simultaneous local full-duplex conversations.
- the peak bandwidth through the switch is equal to 2 Gbits/sec per backplane channel (1 GB/sec send and 1 GB/sec receive), plus an additional 2 Gbits/sec for each purely local conversation that can be simultaneously serviced.
- each switch chip has 3 ports and there are 12 switch chips for a total of 36 ports in this embodiment.
- Each switch chip supports 14 backplane channels such that up to 14 remote full-duplex conversations through the switch 136 can be supported by 28 ports coupled to the 14 backplane data paths plus 8 purely local full-duplex conversations between the remaining 8 ports for an aggregate peak bandwidth of 44 Gbits/sec.
- Port and backplane contention will reduce the total bandwidth below this peak, but average throughput and arbitration latency of a switched system will still be faster than an arbitrated FCAL net of the same size.
- Spatial reuse provided by a switch allows applications which make use of concurrent conversations to use FCAL local loops and a switch to overcome the one loop tenancy at a time limitation of pure Fibre Channel Arbitrated Loop networks without a switch.
- Each switch chip is coupled to a fairness token bus 99 , which, in the preferred embodiment, takes the form of a two wire bus.
- a fairness token circulates to all ports on this bus enabling a “round robin” fairness algorithm.
- Each port has circuitry to receive the fairness token, hold it for a short time and forward it to the next port so that the token reaches all ports eventually.
- Each port has a priority level assigned to it that is used in arbitration within the switch of multiple access requests to a busy destination node. When the fairness token is in the possession of a port, that port has the highest priority level and is guaranteed access. When a port has the highest priority level, it can “camp” on a busy remote port, and be guaranteed that it will be given access when the port is available. When access has been granted, the token is forwarded. This prevents starvation of any port from communication with a busy node.
- data path 130 is comprised of metallic data paths on the printed circuit board on which the port chips are mounted couples the outputs of each crossbar switch portion of one of the port chips to the input of the crossbar switch portion of another port chip.
- Each bridge portion has three inputs and three outputs (one input and output for each of the three half bridges on each chip) for FCAL net primitives and frame data.
- Each pair of one input and one output is called a port and can be coupled to a single NL node or an FCAL net.
- the distributed nature of the crossbar switch and the full integration of the ports with the crossbar switch makes the architecture of the switch modular and easily expandable. That is, the architecture represents a sliceable architecture which can be built into as large a switch with as many ports as is necessary limited only by the maximum number of permissible addresses in the FCAL address space of 128 nodes. Integration of the ports with a crossbar switch slice on the same chip allows switches to be built with as few as two switch chips or many more because the crossbar switch is scaleable and because each chip can be coupled by its portion of the crossbar switch to any one of the plurality of separate backplane channels. Prior art fabric switches had separate, nonscaleable circuits for the crossbar switch.
- crossbar switch had to be built as complex as was necessary to handle up to the maximum number of ports. If fewer than the maximum number of ports were used, a large part of the prior art crossbar switch capacity was wasted.
- the crossbar switch because of the full integration of all necessary circuitry onto one chip including a portion of the crossbar switch, the crossbar switch is scaleable, and all sizes of switches are easily constructed and quite affordable because of the inexpensive, fully integrated construction with no buffer memory and no complicated error recovery protocols.
- FCAL NL nodes are capable of duplex communications in that they can send data at the same time they are receiving data.
- the problem that conventional FCAL nets and fabric FL port based switches fail to address is the fact that typically the destination node in more highly populated FCAL nets is less likely to have data for the source node but other nodes may have data for the source node which they cannot send since the source node is tied up in a conversation with the destination node. Thus, there is a waste of bandwidth.
- node adapter cards that interface a computer or disk drive to the FCAL net cannot re-shuffle their transmit queues in order to find a frame destined for the current source node and move it to the top of the transmit queue.
- head end blocking usually occurs and causes a full duplex connection to be effectively simplex.
- NL nodes can simultaneously burst out at 100 mbyte/sec while they are simultaneously bursting in at the same rate. If the destination node has no data to send to the source node, the 100 mbyte/sec of burst in bandwidth of the source node is wasted in conventional fabric switches with FL ports.
- the protocol requires that nodes must must reserve all resources required for a duplex conversation even in cases where there is only traffic in one direction. This means, in the context of FIG. 5, node 101 can be sending data to node 103 but node 103 is required by the rules of the protocol to be sending data only to node 101 during the same loop tenancy. This is true even though it may have no data to send to node 101 and even though it may have data to send to node 105 . Likewise, if the switch of FIG.
- node 103 would be restricted to sending data only to node 138 even if node 103 had no data for node 138 but did have data for node 140 .
- step 354 establishing a back channel data path between a third node and said source node if said source node is dual simplex capable but not transmitting to said source node any OPN primitive emitted by said third node (step 354 ), and transmitting a number of RRDYs either equal to the number of RRDYs output by said source node or the number of RRDYs needed by said third node to send all the data it has to said source node before closing said back channel connection (step 356 )—transmission of said RRDYs being one at a time—any excess RRDYs not used by the third node are saved for use by another third node in a subsequent dual simplex back channel connection; and
- the scoreboard memory is a memory that stores status data such as whether or not a port is busy, and, if busy, whether it is coupled to the source node of the conversation it is engaged in and is thus open to receive data from a third node in a dual simplex communication;
- the “back channel” is the data path going into the source node along with a connection through the switch ports and backplane if necessary to couple the third node to the source node and is the channel used by a third node to send dual simplex data frames into the source node.
- the format conversion mentioned above converts the OPN(Dest, Src) received from the source node 138 into an OPN(Dest, Dest). This conversion occurs as the OPN is propagated through the source port before it is sent to the remote port coupled to the destination node. Conversion of the OPN primitive format to OPN(Dest, Dest) and taking away the buffer credits from the destination node converts the normal full duplex loop tenancy to a half duplex or simplex loop tenancy where data flows in only one direction from the source node to the destination node and the destination node cannot send any frames back to the source.
- Port 126 would convert this to OPN( 103 , 103 ) and transmit it to switch port 128 when the connection through the backplane between switch ports 126 and 128 has been established in any of the ways described herein. Port 126 would latch the two RRDYs or increment a counter of buffer credits to a count of two and give them to node 144 one by one after a back channel connection was established between node 144 and node 138 .
- Swallowing or deleting the back channel OPN from the third node in the source port is important to dual simplex because it prevents the source node from receiving it and becoming confused. Because of the structure of the FCAL protocol, it is a protocol violation if a node receives an OPN, and that node has already established a previous connection.
- the third node sends an OPN.
- the port coupled to the third node uses the destination address in the OPN to look up the ID of the port coupled to the destination node. This search results in output from the routing table of the ID of the source port coupled to the source node in the original forward channel transmission. This ID is then used to search the scoreboard memory to determine the status of the source port.
- the source port sent a message to the scoreboard memory on the protocol bus updating the status entry in the scoreboard memory for the source port to busy when the source port established the front channel connection. In one alternative embodiment, this busy status will be found when the scoreboard is consulted, but that will not deter the third port from posting a connection request message on the protocol bus requesting connection to the source port.
- the source port will determine if it has any stored buffer credit and grant the request if it does by posting a reply message on the protocol bus naming the backplane channel to use. The third port and the source port then both connect to the named backplane channel.
- the source port posts a message to the protocol bus to update all scoreboards in every port to indicate that although it is busy, it is coupled to the source node of the loop tenancy and is thus available to receive data in a dual simplex mode.
- the third port checks its scoreboard, and if it determines that its destination node has the same address as the source node coupled to the source port, it then sends a connection request message. If it determines from the scoreboard data that the source port is not dual simplex capable, it does not send a connection request message.
- each switch port which utilizes dual simplex is only coupled to one node, because the switch ports are not expensive.
- the scoreboards are not updated with data indicating the address of the node connected to the source port so as save memory space in the scoreboards and traffic on the protocol bus.
- the third node simply transmits a connect request on the protocol bus naming the source port. The source port then determines if it is dual simplex capable by checking its own scoreboard for data indicating whether it is dual simplex capable and determines if its camp list is full. If it dual simplex capable and its camp list is not full, it grants all connection requests.
- the source port If there is no match, the source port generates a CLS and sends it to the third port. If there is a match, dual simplex mode is allowed, the OPN from the third port is quashed, and the stored RRDYs are sent to the third port from the source port, one RRDY at a time up to the number of RRDYs stored. In some alternative embodiments, the RRDYs are not actually stored but are counted and the count is maintained. This starts the transmission of data frames from the third node. The arrival of a data frame from the third node triggers release of another RRDY from the source port if another RRDY is available at the source port for release. These data frames are received by the source port and transmitted on the back channel to the source node.
- Any intervening nodes pass the data frames through because they, do not control the loop. Any subsequent RRDYs output by the source node are intercepted by the source port and transmitted on the backplane channel to the third port to cause the third node to transmit a data frame for each RRDY so intercepted.
- a CLS is received from the third node, any remaining stored RRDYs are preserved for use as buffer credit for the next third node that wishes to send data to the source node.
- the job of managing buffer credit falls to the state machine in every port in the preferred embodiment.
- Another embodiment for the source port to determine if it is dual simplex capable is to send post a message on the protocol bus instructing any port that has an OPN send the destination address of the OPN to the source port for comparison to the source node address. If there is a match, a reply message is posted directing the port to use a specified backplane channel and both the third port and the source port connect to that channel. The transaction then proceeds as above.
- the dual simplex process essentially tricks the link layer of the software of the source node into thinking the incoming frames are from the destination node, when they are actually from the third node. Since the frames internally contain all the information needed to get the data therein to the right place in the source node, no harm is done because the frames pass through the link layer and the upper layers of software read the frames and use them properly. However if an OPN from the third node were to arrive on the back channel, the link layer of conventional NL nodes becomes confused because it knows the source node just opened some other node and is not supposed to be receiving any OPNs until the current loop tenancy is terminated.
- the source port also mixes these frames of data from the third node in with RRDY primitives transmitted from the destination node of the original loop tenancy on the FCAL net back channel. Each time the source node receives an RRDY from the destination node, it outputs another frame of data to its destination node. The mixing in of RRDYs from the destination node with the frames of data from the third node on the FCAL net backchannel causes the source node to continue outputting data frames bound for the destination node.
- any port coupled to a source node and facilitating a dual simplex transaction (elsewhere herein sometimes referred to as a dual simplex port or source port) must insure that when a CLS is output by the source node that the CLS is not forwarded to the destination node until the third node has finished transmissions on the back channel and output its own CLS. Further, the state machine of any port coupled to a source node and facilitating a dual simplex transaction must not wait for a CLS in the case where access to the source node is denied to a third node because of the lack of any RRDYs transmitted by the source node to avoid possible deadlock. Thus, the state machine in a dual simplex port must therefore have the following behaviors as illustrated in the following discussion of four possible dual simplex close scenarios.
- a CLS is received from the source port—the CLS is replicated by the source port and sent to both the third port and the destination port.
- the third port transmits the CLS to the third node which handshakes with its own CLS which is returned to the source port.
- the source port deletes the CLS from the third node but remembers that it has arrived and releases the back channel connection.
- the CLS reaches the destination port and the destination node.
- the destination node handshakes by emitting its own CLS which is transmitted back to the source port and to the source node which closes.
- the source port drops the front channel connection.
- a CLS is received from the third node—the source port deletes the CLS so that it does not get forwarded to the source node and sends a CLS generated in the source port back to the third port, and then drops the back channel connection to the third port.
- the third port forwards the CLS to the third node. Any new third port can then initiate a new dual simplex connection.
- Destination node transmits a CLS—the CLS is received at the source port and held by the source port. A copy of the CLS is transmitted to the third port which transmits it to the third node.
- the third node closes under normal FCAL close protocol and handshakes by transmitting a CLS to the source port.
- the source port transmits the CLS to the source node which closes under normal FCAL close protocol rules and handshakes by transmitting a CLS to the source port. That CLS is forwarded by the source port to the destination port which forwards it to the destination node. The source port then drops both the front and back channel connections simultaneously.
- Destination node transmits a CLS—the CLS is received at the source port and held by the source port. A copy of the CLS is transmitted to the third port which transmits it to the third node.
- the source node closes under normal FCAL close protocol and handshakes by transmitting a CLS to the source port.
- the source port holds the CLS from the source node until a CLS is received from the third node.
- a CLS generated in the source port is simultaneously transmitted to the destination port and the source node. The source port then drops both the front and back channel connections simultaneously.
- FIGS. 16A to 16 D are a flowchart of the processing carried out by the ports to implement dual simplex communication.
- node 138 want to send data to node 101 .
- node 144 wants to send data to node 138 .
- Node 138 generates an OPN( 101 , 138 ), RRDY, RRDY and transmits these three primitives to port 126 (step 360 ).
- Port 126 converts the OPN to a simplex OPN( 101 , 101 ) and stores the original OPN including both the source and destination addresses of the OPN and stores the two RRDYs (steps 362 and 364 ).
- Port 126 looks up destination address 101 in the routing table and finds it is connected to port 128 (step 366 ). The scoreboard table is consulted, and port 128 is found to be available (step 368 ).
- Port 126 posts a message on the protocol bus 121 requesting port 128 to initiate arbitration for its local loop and pick a backplane channel (step 368 ).
- Ports 126 and 128 send commands to their portions of the distributed crossbar switches to connect to backplane channel 1 (step 372 ).
- Port 126 forwards the OPN( 101 , 101 ) to port 128 as soon as node 128 is available and it passes straight through port 128 without delay to node 101 (step 374 ).
- the two RRDY primitives of buffer credit transmitted by node 138 and intended for node 101 are stripped off the transmission to node 101 by port 126 and maintained as a count in the source port for award by regeneration and transmission to another node that wants to ship frames to node 138 .
- Node 101 replies with an RRDY (step 376 ).
- This RRDY is transmitted back on backplane channel 1 to port 126 where, as described below, it is mixed in with data frames from a third node (node 144 ) that is transmitting data frames in dual simplex mode to node 138 so as to keep the source node 138 outputting new frames to the destination node 101 .
- port 126 posts a message to the protocol bus to update all scoreboards that it is busy but is available for dual simplex connections.
- This message can be based upon the fact either that the source node knows by watching traffic or comparing source node addresses on its local FCAL net to the AL-PS value in the original OPN, that it is connected to a source node of the front channel and is capable receiving dual simplex transmissions, or its configuration bit indicates dual simplex connections are allowed.
- This message on the protocol bus would would result in update of all scoreboards (step 380 ). Node 114 then arbitrates for and wins control of its FCAL net and generates an OPN( 138 , 144 ).
- Port 124 receives this OPN, stores it (and converts it to half duplex in the preferred embodiment) and uses the destination node address 144 to search the routing table (step 384 ). This returns the ID of port 126 . This ID is used by port 124 to search its scoreboard table. Port 124 finds port 126 in its routing table, finding from its scoreboard that port 126 is busy but dual simplex capable (step 386 ) and posting a connection request on protocol bus 121 requesting a connection to source port 126 (step 388 ). This would result in a connect response reply message from port 126 granting the request and naming backplane channel 2 for use (step 390 ).
- Both ports 124 and 126 would connect to channel 2 (step 392 ), port 124 would send its OPN( 138 , 144 ) to port 126 (step 394 ) which would cause port 126 to compare the destination address 138 to the source node address (step 396 ), find a match, quash the OPN and forward one RRDY to port 124 via channel 2 (step 400 ).
- the backchannel transaction would proceed until buffer credit ran out, or third node had no more data frames to send or a CLS was sent by either node 138 or 144 (step 402 ).
- port 124 would simply post a connection requests which would automatically be granted by port 126 with a reply message saying use backplane channel 2 .
- Ports 124 and 126 would both connect to backplane channel 2 , and port 124 would send its OPN( 138 , 144 ) to port 126 .
- Port 126 would compare the source address it latched from the original OPN, which is 138 , to the destination address of the OPN received from node 124 , which is also 138 , and find a match.
- Port 126 would quash the OPN( 138 , 144 ) and transmit one RRDY back to port 124 which would reach node 144 and result in transmission of one frame of data.
- That frame of data would pass through backplane channel 2 , port 126 and the back channel path and reach node 138 .
- Port 126 would then send the remaining RRDY to port 124 which would result in another frame of data being transmitted. Any further RRDYs transmitted by node 138 would be latched or counted and sent to port 124 in the normal course of flow control, or if node 144 sent a CLS, the RRDYs stored by port 126 would be saved for grant to another third node until such time as the original loop tenancy was terminated with a CLS from either the source node or destination node.
- the port 126 can determine whether it is capable of dual simplex by a sending a message to port 124 asking for the destination address from the OPN ( 138 , 144 ) and then compare this destination address to the latched source address from the original OPN( 101 , 138 ). If there is a match, sending a reply message saying, “Use backplane channel X and send me your OPN” whereupon the transaction proceeds as defined above. If there is no match, generating a CLS and sending it to the third port or sending a message that causes the third port to generate a CLS and send it to the third node.
- port 126 mixes RRDYs received from node 101 on the front channel connection with data frames received from node 144 and sends the combined data stream to the source node over the back channel of the FCAL net coupled to the source port (step 404 ). This keeps source node 138 outputting data frames to destination node 101 .
- source node 138 issues a CLS (step 406 ).
- source port 126 duplicates the CLS and forwards it to destination port 128 and third port 124 simultaneously (step 408 ).
- the third node 144 replies with its own CLS which is forwarded to port 126 (step 410 ).
- Port 126 discards the CLS received from third node 144 but notes that it has arrived and both ports 124 and 126 relinquish their back channel connections through the backplane (step 410 ).
- the CLS reaches destination node 101 , it replies with its own CLS back to source node 138 , and ports 126 and 128 relinquish their front channel connections (step 412 ).
- third node 144 issues a CLS (step 414 ).
- the CLS is transmitted to source port 126 which deletes the CLS (it is not sent to the source node 138 —step 416 ), and ports 124 and 126 each relinquish their back channel connection through the backplane (step 418 ).
- Any new third node can initiate a new dual simplex connection.
- Source port 126 receives the CLS and holds it temporarily and does not send it to source node 138 (step 422 ).
- a copy of the CLS is sent to third port 124 and the third node (step 424 ).
- the third node replies with its own CLS which is received by the source port and sent to the source node (step 424 ).
- the source node replies with a CLS which is forwarded to the destination node (step 426 ).
- the source port and the destination and third ports then drop the front channel and back channel connections (step 428 ).
- Dual simplex mode allows many different third nodes to deliver frames to the source node during its “conversation” (loop tenancy) with the original destination node. Dual simplex almost doubles throughput of the switch.
- FIGS. 6A through 6C An example of normal, non dual simplex processing by the switch illustrated in FIG. 5 (or any of the alternative embodiments of non dual simplex switch operation) is illustrated by the flowchart of FIGS. 6A through 6C.
- This example is only a high level illustration of one path through the states of the loop port state machine of a single switch port such as loop port state machine (LPSM) 218 in FIG. 7 and is illustrative of typical processing for loop-local or chip-local or remote transactions.
- the LPSM in each switch port is a complex state machine which has many states and many transistions between states with the transitions between states depending upon the logical states of various input signals.
- Each loop port state machine is comprised of a plurality of individual component state machines which interact with each other.
- FIGS. 17 through 28 individual state diagrams for all the state machines in a single LPSM.
- Each circle represents one state.
- Each line from one state to another represents a transition from one state to another.
- the labels in boxes on each line represent the Boolean condition that must exist between the signals identified in the box for that transition to be made.
- Boolean logical operators are identified by & for an AND operation, a tilde preceding a signal name means NOT and a vertical line between two signals means OR between those two signals.
- Each state and each signal is defined in the verilog code appended hereto as Appendix A.
- the state diagrams coupled with the verilog code together comprise a complete and exact description of all states and transitions between states for every possible processing scenario performed by the preferred embodiment of the switch.
- a description of the verilog hardware description language and how to use it to define the functionality of an integrated circuit is given in the treatise, Palnitkar, “Verilog® HDL: A Guide to Digital Design and Synthesis” ISBN 0-13-451675-3 (Prentice Hall 1996) which is hereby incorporated by reference.
- node 138 wishes to send data to node 140 .
- Node 138 arbitrates for control of the FCAL net 142 comprised of data paths 142 A, B and C and nodes 138 and 140 (step 150 ).
- source node 138 sends an OPN primitive to port 126 with the destination address of destination node 140 therein (step 152 ).
- the source node follows the OPN with one or more RRDY primitives, each representing one frame buffer of credit which the source node has reserved for receiving frames of data from the destination node (step 152 ).
- Port 126 latches the OPN and any RRDY primitive following the OPN (step 154 ), and uses the destination address of the OPN as a search key to search a routing table stored in port 126 (step 156 ).
- a separate routing table is maintained in each port circuit.
- the routing table may be a single table 127 coupled to all the ports by the protocol bus 121 with each port checking the routing table contents by messages on the protocol bus. This embodiment is represented by FIG. 4.
- the contents of the routing table are updated by an active discovery process although this active discovery process may also be carried out in the preferred embodiment of FIG. 5.
- the contents of the routing table are destination addresses and the identification codes (hereafter IDs) of the ports or half bridges to which those destination nodes are coupled.
- IDs identification codes
- Each half bridge contains such a routing table.
- the contents of the routing table are learned by each half bridge by watching the traffic on its ports in the manner described in the parent case or by an active discovery process which will be described below.
- the search indicates that the destination node is local to FCAL net 142 , and that determination is represented by test 158 in FIG. 6A.
- Port 126 responds by setting an internal switch to connect an internal bypass data path to connect data path 142 C to data path 142 A (step 160 ), and sends the OPN to destination node 140 along with any RRDYs received from the source node (step 162 ).
- Node 140 responds either with one or more RRDY primitives if it has buffer capacity to receive one or more frames from the source node or a CLS primitive or one or more frames of data to be transmitted to the source node in accordance with the number of RRDY primitives received from the source node (step 164 ).
- step 164 represents the process of the switch port acting as a normal non participating FCAL node for the duration of the transaction by forwarding all data and primitives received from the local loop back onto the local loop.
- switch port 126 forwards the RRDY or data frame to the destination node via path 142 A.
- source node 138 responds by transmitting an entire frame to node 140 via data paths 142 C and 142 A and the internal bypass data path (not shown) within half bridge switch port 126 (or a number of frames equal to the number of RRDY primitives received from the destination node may be transmitted—step 164 ).
- the frame is stored in node 140 , and when it has been processed and the buffer is ready to receive another frame, another RRDY is output. If the destination node responded with a frame of data in response to an RRDY received from the source node, the source node stores it in its buffer.
- the source node relinquishes control of its FCAL net, and the transaction is ended according to normal FCAL close protocol.
- the process of exchanging RRDYs and frames of data continues until either node 140 outputs a CLS indicating it will send no more data to the source node or source node 138 outputs a CLS indicating it will send no more data to the destination node.
- the FCAL net 140 is then relinquished and other nodes including port 126 can arbitrate for control thereof.
- Test 166 is symbolic of one event that can occur after the loop-local transaction is completed. The loop-local transaction has to be completed since no other node can win control of the local loop in arbitration so as to be able to send an OPN until the loop local transaction is over. Test 166 determines if an OPN has been received from the local loop, and, if so, vectors processing to step 154 to latch the OPN, as symbolized by step 168 .
- Test 170 symbolizes a test for an event which can occur regardless of whether the loop-local transaction is over or not—receiving a connect request message on the protocol bus at the switch port involved in the loop-local transaction. If this happens, the switch port becomes the destination port for a remote transaction. In such a case, the switch port behaves as indicated in step 175 and the following steps to arbitrate for control of the local loop, as symbolized by block 172 .
- control is won (after the loop-local transaction is over)
- the switch port sends back a connect response message naming the backplane channel to use. The connection is then established by the source port and the destination port and the transaction is completed as indicated in the steps following step 175 .
- tests 166 and 170 do not detect either a new OPN from the local loop or a connect request on the protocol bus, the loop port state machine loops back to test 166 and stays in the-state represented by tests 166 and 170 until one of the events detailed there happens.
- node 140 has data to send to node 144 coupled to port 124 .
- Node 140 arbitrates for FCAL net 142 , and when control is won, outputs an OPN with the destination address of node 144 therein (steps 150 and 152 , FIG. 6A).
- the source node may also output one or more RRDY primitives.
- the OPN and any RRDY primitives are latched in the local node (step 154 ), and the local node uses the destination address in the OPN to search the routing table (step 156 ).
- search of the routing table indicates that node 144 is coupled to a remote port 124 , and an ID for the remote port is returned by the search (step 158 ).
- path 167 is taken for either a chip-local or a remote transaction.
- Step 168 represents a determination as to the status of the remote port coupled to the destination node.
- the combination of steps 168 and 176 represent a determination of the status of the remote port and branching to an appropriate routine depending upon the results. If the remote port status is “available” (path 170 ), source switch port 126 then sends a connect request message formatted as in FIG. 14A via a protocol bus 121 to the destination or chip-local switch port, as symbolized by step 172 .
- the requestor ID is the ID of the source switch port and the responder ID is the ID of the destination switch port.
- the status determination is accomplished by checking the status entry for the destination port in a copy of a scoreboard table stored by the switch port and kept up to date with the copies of the scoreboard table in all other switch ports by monitoring messages on the protocol bus.
- the local port can send a message to the remote port via the protocol bus asking it for its status or can send a message to a central scoreboard to get the status of the destination port.
- path 174 is taken from the status determination test 176 back to step 168 to read the status again and processing stays in this loop in the local port until the status changes to available or no privilege.
- a timeout function can be included to exit the busy-wait loop path 174 and send a CLS to the source node after a timeout event to keep head end blocking from barring all communications will all nodes coupled to the local port in case the remote node is broken and that would be equivalent to the claimed invention.
- test 176 determines there is no privilege for the source node to talk to the destination node, path 178 is taken to block 180 where the local port sends a CLS to the source node. Processing then returns to Start.
- the remote port then starts arbitrating for control of its local FCAL net (step 175 , FIG. 6B).
- control When control is won, the remote port sends back a response message informing the first port coupled to the source node to forward the OPN and any RRDY primitives it has latched, and telling the first port which backplane channel to use (step 177 ).
- the response message from the remote port causes both the first port and the remote port to generate commands to the distributed crossbar switch circuitry of each port to set switches to couple the two ports to the selected backplane channel to set up an FCAL loop connection between the first port and remote port through the crossbar switch.
- this data path couples port 126 and port 124 through the backplane data path 130 on the channel named in the reply message (step 179 ).
- the first port instead of sending a connection request to the remote port, the first port will simply establish a data path through the backplane and send the latched OPN and any following RRDYs to the remote port 124 .
- port 124 will then latch the OPN and any following RRDY primitives, arbitrate for control of the FCAL net coupled to node 144 , and when control is obtained, transmit the OPN and any following RRDYs to destination node 144 . If the local FCAL net is busy, the remote port will hold the OPN and any following RRDYs until the FCAL net is available, and repetitively arbitrate for control and then, when control is achieved, forward the OPN and RRDYs to the destination node.
- the destination node will respond to the OPN (and any following RRDYs) with either an RRDY if it has enough buffer space to receive a data frame or a CLS if it does not or with one or more data frames to be transmitted to the source node corresponding to the number of RRDY primitives received from the source node if any RRDY primitives were received.
- the transaction then proceeds by transmitting one frame for every RRDY received from the other node until one or the other of the source or destination nodes transmits a CLS primitive.
- the frame or frames stream through ports 126 and 124 and backplane data path 130 without ever being stored in any buffer memory and without ever being segmented into packets that require segmentation and reassembly.
- port 126 instead of sending the OPN and any RRDYs to port 124 to signal it to establish a connection, instead sends a connection request message via the protocol bus 121 .
- the connection request message tells the remote port 124 to arbitrate for its local loop and to notify port 126 when control is won and expect further traffic.
- the response message is received that control has been won by port 124 of its local loop and naming a channel to use on the backplane for data transfer
- the OPN and any RRDY primitives which were received by the first port from the source node are sent to port 124 which then forwards these primitives to node 144 (step 181 ).
- the destination node will respond with either an RRDY if it has enough buffer space to receive a data frame or a CLS if it does not or with one or more data frames to be transmitted to the source node corresponding to the number of RRDY primitives received from the source node if any RRDY primitives were received.
- the transaction then proceeds, by transmitting one frame for every RRDY received from the other node until one or the other of the source or destination nodes transmits a CLS primitive to complete the transaction.
- connection is closed with a handshaking type protocol that uses a switch control character to eliminate race conditions.
- the connection through the backplane can be closed by either the source node or the destination node sending a CLS.
- Test 182 represents branching to different protocols for closing depending upon whether the source node or destination node initiated the CLS. Processing branches to step 183 is the source node initiated the CLS. In step 183 , the source node outputs a CLS and that CLS is received by the source port and forwarded to the destination port over the backplane connection.
- the source port also sends an ARB(F7) or other innocuous fill word to the destination port.
- the purpose of this fill word is to send affirmative characters to the destination port to prevent any spurious characters from being transmitted to the destination port.
- Step 185 represents the process of receiving the CLS at the destination port and forwarding it onto the local loop so that the destination node receives it.
- the destination node responds with its own CLS.
- Step 187 represents the process of receiving the destination node's CLS at the destination port and forwarding it across the backplane connection to the source port followed by a switch control character (typically 20 consecutive zeroes).
- Step 189 represents the process of receiving the destination node's CLS at the source port and forwarding it onto the local loop so that it will be received by the source node.
- the source port also loops the switch control character back through the backplane connection to the destination port.
- Step 191 represents the process carried out in the destination port of receiving the switch control character transmitted by the source port and realizing the backplane channel in use is now clear.
- the destination port then drops the backplane connection and transmits a release frame on the protocol bus. All other ports see that release frame and update their scoreboards to indicate availability for that backplane channel.
- the switch ports involved in this transaction are now ready for a new transaction so processing returns to start state 148 .
- Step 195 represents the process of the destination node initiating a CLS.
- the CLS is received by the destination port and forwarded across the backplane connection to the source port followed by a switch control character (currently 20 consecutive zero bits).
- Step 197 represents the process that happens at the source port when the CLS and switch control character is received by the source port.
- the source port forwards the CLS onto the local loop and holds the switch control character.
- the CLS reaches the source node, and it responds with its own CLS.
- This CLS is received by the source port and forwarded to the destination port across the backplane connection.
- the switch control character is sent across the backplane connection.
- the source port then closes its backplane connection.
- Step 199 represents the process which occurs at the destination port when the CLS and switch control character are received there.
- the CLS is forwarded onto the local loop by the destination port. There it is received by the destination node which causes the destination node to close.
- the destination port then notes that it has received back the switch control character it originally sent to the source port and closes its backplane connection.
- the transaction is then over and the two switch ports are ready for a new transaction. Processing thus returns to a start state represented by block 148 as symbolized by step 193
- the frame or frames stream through ports 126 and 124 and backplane data path 130 without ever being stored in any buffer memory and without ever being segmented into packets that require segmentation and reassembly.
- the lookup table in each port circuit is slightly different than the lookup table in the bridge described in the parent described in the parent application. There, only two half bridges were coupled together, so the routing table could output only a 1 if the destination was local or a 0 if it was not, or vice versa. With the many half bridges of the switch, the routing table must store more bits for each destination address, those bits (6 ID bits plus one bit for validity of the port) define the unique ID of the particular port to which each node having a particular destination address is coupled.
- a scoreboard table is used to store port status and priviledge information. Whenever the local FCAL net of a port is busy, the port connected to that FCAL net sends a message to update its status in the scoreboard to “busy”. When the FCAL net becomes available again, the port connected to that net sends another message to the scoreboard to update its status to “available”.
- the scoreboard can also store privilege information to implement security rules to prevent certain ports from communicating with other ports.
- the status states map to the following actions by the switching circuit: “busy camp” equals wait and do not forward OPN so no RRDYs get back to source node and no data is sent; “available” equals connect and send OPN to destination; and “busy no camp” equals generate a CLS and send it back to the source node, and “no privilege” equals generate an OPN and send back—this will tell the source node that the destinat node is not available.
- the preferred embodiment includes the following steps for consulting the scoreboard (this method is reflected in FIGS. 6A and 6B).
- the port that latched the OPN determines the port ID of the port coupled to the destination node by consulting the routing table as described above. After determining the ID of the remote destination port, that port ID is used as a search key to consult the scoreboard table to determine if the port is available and if there is the privilege to talk to it. If the remote ports status is “busy camp” and camping is allowed, send a connect request message and wait for the remote port to finish its current conversation, grant the connect request and send back a connect response message naming the backplane channel to use. If the remote port's status is “no privilege”, generate an OPN and send it back to the source node.
- the remote port's status is “available”, send a connect request message to the remote port over the protocol bus. If the status if “busy no camp”, return a CLS to the source node. This causes the remote port to arbitrate for and win control of its local loop. When control is won, the remote port then sends a reply message to update its scoreboard status to busy and naming the backplane channel to use. The scoreboard circuitry sees the reply message and updates the status of the port whose ID is in the reply message to busy. The reply message causes the first port to generate signals to the crossbar switch to open a connection between the two ports.
- the first port then sends the latched OPN and any latched RRDYs to the second remote port coupled to the destination node, and the process proceeds as described above until the transaction is completed.
- both ports relinquish control of their FCAL nets and the destination port posts a message on the protocol bus that both the source and destination ports are availble.
- the scoreboard circuitry sees this messages and automatically updates the status of each of these ports to “available”.
- the status data in the scoreboard table will indicate a port is busy when the FCAL net coupled to the port is tied up in a loop tenancy.
- FIG. 7 there is shown a block diagram of a typical switch chip such as those represented by blocks 124 , 126 and 128 in FIG. 5.
- Three FCAL net ports, each having a transmit and receive terminal, are shown at 200 , 202 and 204 .
- Each port has an FCAL net interface comprised of a 1 Gbit/sec serializer/deserializer shown at 206 , 208 and 210 .
- the function of these SERDES interfaces is to transmit and receive serial data, converting the serial data stream to and from 10-bit characters used internally in the switch chip.
- the received 10-bit data data is re-timed in an elastic buffer, shown at 212 , 214 and 216 , producing a 10-bit data stream whose timing is identical to the transmitted data.
- a loop port state machine for each port, shown at 218 , 220 , 222 , functions to process received FCAL data and generate commands to establish the proper connection to either the local FCAL net or to a designated channel through the backplane so as to facilitate coupling of the received data on whatever data path the state machine establishes.
- the state machine also functions to receive data from the crossbar switch coming from a remote port and couple it onto the FCAL net local loop of that port.
- the state machine also functions to do the routing table searches and scoreboard table searches to determine when and FCAL transaction from the local loop must connect to the switch fabric and to post transaction messages on the protocol bus such as connection requests, reply messages, scoreboard updates etc.
- the switch fabric refers to the backplane data paths and switching circuitry that allows connections between different ports.
- the state machine also functions to arbitrate for control of the local FCAL net when a connection request is received from the switch fabric, and, when control is achieved, pick a backplane channel and generate the reply message.
- Another function of the state machines in every port in dual simplex mode is to store the buffer credit RRDYs output by the source node and forward these RRDYs to the third port, one RRDY at a time up to the buffer credit limit, when an OPN for a dual simplex transmission is received from a third node.
- all the logic and intelligence of each hub to carry out the functions described herein for the preferred or alternative embodiments resides in the states of the state machine.
- the particular design of the state machine is not critical, and any state machine (or programmable machine if it is fast enough such as a microprocessor) which can perform the functions defined herein will suffice to practice the invention.
- the novelty is not believed to be in the particular design of the state machine but in the functions it performs in each port.
- each switching circuit such as 124 in FIG. 5 contains three ports (only one port is shown in FIG. 5), each switching circuit contains a port multiplexer, shown at 224 in FIG. 7.
- the port multiplexer interfaces the three state machines or LPSMs to the backplane data channels 226 .
- the state machines control the multiplexer 224 to keep local destination traffic for each port local but to couple traffic between the port and a remote port to a channel on the backplane.
- the port multiplexer and the state machine jointly determine the nature of each new conversation (local or remote) by searching a routing table stored in memory 228 .
- memory 228 is a lookup table.
- the backplane 226 comprises the datapath and control logic required to receive and transmit the backplane data between switching circuits as well as multiplexing circuitry to shunt backplane data to and from the state machines via the port multiplexer 224 .
- Backplane connections and data channel availability are tracked by a backplane protocol circuit which manages scoreboards in each port which have their data synchronized via broadcasts over the protocol bus 121 .
- each switch chip is monitored by a management circuit that interfaces to the system through 2-wire bus 232 .
- JTAG circuit 234 is used for testing the switch chip.
- the serializer/deserializer function (hereafter SERDES) of each port at 206 , 208 and 210 is provided by the GigaBlaze SerialLinkTM megafunction circuitry which is commercially available from LSI logic or any equivalent SERDES circuitry, the details of which are hereby incorporated by reference.
- the SERDES circuits accepts differential, 8b/10b encoded serial data at the rate of 1 Gbit/sec, demultiplexes it into aligned 10-bit characters and recovers a receive clock from the data.
- the SERDES multiplexes outgoing 10-bit characters into a 1 Gbit/sec differential transmit data stream using a self-contained 10 ⁇ clock multiplier.
- Other currently available SERDES circuits may be used also either at macros in layout of the switch port chips or as external parts.
- the elastic buffers 212 , 214 and 216 absorb differences between receive and transmit data rates which can vary up to 100 ppm from the nominal rate of 1.0625 Gbits/sec.
- the elastic buffers re-time the incoming data stream so that its timing is compatible with the transmit data. This is achieved by storing received data in a FIFO as previously stored data is removed at a rate defined by the transmit clock. If the receive and transmit rates are not equivalent, the receive and transmit pointers will eventually converge. To prevent this, logic senses an impending pointer collision, and repeats or deletes data when the FC-AL fill word data is present in the FIFO.
- a fill word is a Fibre Channel ordered set defined to be insertable or deletable as elasticity requirements dictate.
- the FIFO also contains circuitry to perform a smoothing function to repair interframe gaps that have been made too small by the FIFO by deletions from a small interframe gap so as to make it so small that it creates problems downstream.
- the repair of interframe gaps is done by inserting fill words into small gaps and removing fill words from large gaps. Specifications for such a FIFO are provided in the FCAL standards documents which are incorporated by reference herein.
- the state machine in each port is similar to the FC-AL specification state machine but different in that it is passive and never transmits or receives frames itself.
- the state machines 218 , 220 and 222 relay OPNs and frames to remote destinations as well as performing the other functions defined above.
- a state machine receives data from the backplane, it arbitrates for control of its local FCAL net with high priority according to arbitration rules defined in the FCAL standards incorporated by reference herein. Once control is achieved, the switch port then relays the OPN and frames onto the local FCAL net.
- the state machines also implement the dual simplex process described above. Dual simplex mode can be turned on or off by management commands received on bus 232 . When this mode is on, the state machines convert full duplex OPNs to remote devices to half duplex OPNs to the same destination address. This leaves the source port available to receive an incoming connection from a third port.
- the state machines do not need to participate in loop initialization, but rather they optionally allow initialization to occur as it would in a prior art FCAL net configuration and then change the state of the switch to allow the state machine to active engage source and destination nodes and control data flow therebetween.
- the state machines Before switching from hub mode (the switch can be instructed to act as a hub instead of a switch), the state machines also function to learn the mapping between each destination node address and the port ID of the port to which that destination node is connected. This learning can be performed by either a discovery process or OPN trapping, and will be discussed below. The mappings learned in either process are written by the state machine to the routing table in memory 228 .
- the port multiplexer 224 selectively connects each port to each other within the switching circuit or to the backplane 226 .
- the port multiplexer has three multiplexer blocks each of which is controlled by a portmux state machine.
- Local traffic connections are implemented by connecting a transmit data path and a receive data path between the two state machines in the port multiplexer 224 .
- Remote connections are established by connecting the transmit data path and receive data path between the state machine and the backplane.
- Each channel through the port multiplexer actually implements two transmit and receive data paths. In full duplex operation, only one TX-RX pair is used to carry half or full duplex conversation.
- the outgoing conversation uses one TX-RX pair to transmit data to and receive flow control primitives from the destination node while the other pair is used to receive data from and transmit flow control to any third node in the event a third node connects to the source port.
- the port multiplexer 224 also contains a camplist FIFO for each of the three ports in the switch chip. These FIFOs are used to record the IDs of remote ports that have made a priority request to the switch port but which have not been serviced yet so as to implement the fairness token highest priority to these remote ports which have not yet been serviced and prevent any starvation of a port.
- the backplane 226 is a group of parallel point-to-point data paths which physically comprises 14 2-bit wide, 531.25 Mbit/sec data paths and a 265.625 MHz strobe signal imlemented using differential LVDS to drive the receiving switch chip.
- the switch chips are connected such that the backplanes form a ring of point-to-point connections.
- the strobe is generated by an integrated PLL 227 and is timed with outgoing data such that it can be used to latch the data at the destination switch chip which is the next chip in the ring.
- Each data channel on the backplane may operate in the pass-through mode, or it may be configured to align incoming data into 20-bit words and steer data to and from a port multiplexer channel, which typically happens when a remote connection is being serviced by a port.
- Each port can be configured to statically listen and transmit to certain channels to support broadcast.
- the backplane logic tracks the availability of each backplane channel, and can be configured to associate a data channel with a receiving port and only release it when no other channels are available. This is useful where backplane channels are underutilized to reduce latency.
- the protocol bus is an 18-bit wide data bus used for broadcasting connection requests and response messages to each switch chip in the switch.
- the bus is arbitrated by external logic that is asynchronous with respect to the main switch chip logic and thus can operate at any speed up to the limit determined by the system design.
- Each switch chip monitors the protocol bus and updates the status information in its copy of the scoreboard such that every port knows the busy/available status of every other port. This allows denial of full duplex connections at the source if the destination port is busy. Dual simplex is an exception to this rule.
- the scoreboard also prevents loops of camped devices by denying any camping connections to a port that is already camped on another port.
- the routing table in LUT memory 228 stores 6-bit mapping data between each destination address and its port ID. Each port in a switch chip must have received a unique ID assignment from external management software before the system can operate as a switch.
- the LUT memory has three 10-bit read address ports, one dedicated to each port on a switch chip.
- the LUT has one 10-bit write address port for writing associations from the state machines developed in the learning process and also has 7-bit read and write address ports used by management software which does not form part of the invention.
- Internal logic in the LUT converts the 10-bit AL-PA destination addresses to 7-bit addresses for the 128 ⁇ 8 SRAM.
- the output from the LUT is a 6-bit port ID that maps to the AL-PA input at the address port of the lookup table, a valid entry bit and a bit that indicates whether the destination node is local to the switch chip.
- a port uses LUT 228 to determined if the conversation will be loop-local (destination on local loop), chip-local (destination on the local loop of another port on the same chip) or remote.
- the LUT is initially loaded by a learning process called OPN trapping in which each port observes OPNs on its outbound local loop port and writes a destination address to LUT if a response to the outbound OPN on the local loop is detected on the local loop inbound data path.
- OPN trapping a learning process in which each port observes OPNs on its outbound local loop port and writes a destination address to LUT if a response to the outbound OPN on the local loop is detected on the local loop inbound data path.
- the port posts a message on the protocol bus that its local loop has the destination address of the outbound OPN and giving its switch port ID. All the other ports receive this message and write the mapping into their routing tables.
- the contents of the LUT are cleared by a state machine and counter triggered by a managment command or the rising edge of a chip reset signal. Clearing the LUT takes 128 clock cycles.
- the switch chips of FIG. 7 can be operated in three fundamental configurations: hub, switch and locked.
- Initial operation is in hub mode where each port is coupled to its neighbor ports to form one big Fibre Channel Arbitrated Loop (FC-AL).
- FC-AL Fibre Channel Arbitrated Loop
- locked mode each port is standing by in preparation for a mode switch or broadcast.
- switch mode each port forwards data back onto its local loop until an OPN to a remote node is detected, and then a connection to the port coupled to the remote node is initiated through the backplane.
- FIG. 8 illustrates hub mode.
- the state machines of all ports cooperate to forward loop data from the receiver of one port to the transmitter of the adjacent port through the port multiplexer 224 .
- each switch chip can specify to the management software through a management-programmable register which hub mode backplane channel it uses, it is possible to partition the switch into several distinct loops instead of one big one.
- the hub channel is selectable on a per port basis.
- Switch mode the state machine of each port monitors traffic on its local loop and forwards data from its receiver to its transmitter when an OPN designating a remote node is received on the local loop.
- the state machine breaks the local loop and substitutes fill words on the local loop transmitter so that nodes on the local loop do not know the loop has been broken.
- the OPN is held while a connection attempt to the remote port is made. If the connection can be made, the remote port conducts unfair arbitration to win control of the remote loop, breaks that loop if it wins control and transmit and receive connections between the two loops are initiated to form a loop across the backplane between the source and destination nodes.
- FIG. 9 shows a typical switch connection between two ports on different chips as data path 250 , a simultaneous loop-local conversation represented by data path 252 and a simultaneous chip-local conversation as data path 254 .
- connections may exist with the maximum number of chip to chip data paths limited by the number of backplane channels.
- the state machine also detects a local tenancy by monitoring the RRDY primitive, and the tenancy is terminated when a CLS is detected. At the time a CLS is detected, the state machine returns to either a monitoring state or to a remote arbitration state if a pending remote request exists in the camp on FIFO (not shown in FIG. 7).
- Chip-local transactions are handled by the port multiplexer 224 by arbitrating for local resources and physically multiplexing the data for all chip-local conversations.
- the state machine signals the port multiplexer and forwards the destination address after receiving an OPN from the local loop naming a destination on the same chip but a different FCAL net. A hit on one of the other two ports in the chip initiates the transmit request sequence.
- the port multiplexer forwards the request to the protocol bus logic 121 which arbitrates for the bus and assembles a request frame.
- the destination or remote port receives the frame and either begins unfair arbitration for the remote loop or queues the request in a FIFO-ordered list of campers.
- the request is serviced, and arb on the remote loop is won.
- the remote port issues a response frame on the protocol bus containing both grant and backplane channel ID on which to converse.
- the requesting port releases the OPN once the grant is received and awaits the first valid K28.5 primitive from the chose data channel.
- the remote port upon receiving the OPN primitive, releases its local traffic onto the data channel and enters the connected state.
- the remote tenancy is considered terminated when the state machine has detected a CLS from both the source node and the destination node.
- Each state machine implements a port bypass circuit and a parallel loopback mode, and each SERDES implements a serial loopback mode.
- the port bypass and parallel loopback modes are also used to bypass a faulty local loop while the switch is operating.
- Each switch chip has three multiplexers that may be used to control the flow of data without regard to the FCAL protocol as illustrated in FIG. 10. These three multiplexers control port bypass mode, parallel loopback mode and serial loopback mode.
- the port bypass circuit 260 when enabled, connects line 262 from the port multiplexer 224 in FIG. 7 back to the port multiplexer via line 264 and port bypass switch. This has the effect of forwarding data from the port multiplexer 224 back to its source without travelling across the local loop coupled to transmit interface circuit 266 and receive interface circuit 268 coupled to the inbound and outbound data paths of the local FCAL net.
- SerDes (serializer/deserializer) circuit 270 does the serialization and deserialization function described above. Data incoming from the local FCAL net is never sent to the port multiplexer 224 when port bypass mode is engaged.
- the port bypass circuit 260 may be engaged by the managment software, and is automatically activated under certain error conditions. It may only be disengaged by management. In normal operation, 10-bit words generated by Giga Blaze circuit 271 on output 270 are coupled through port bypass switch 260 to the port multiplexer via line 264 .
- Parallel loopback mode is manually engaged and disengaged by the management software, and is qualified by the port bypass enable. That is, parallel loopback mode is always disabled when port bypass is disabled.
- a switch chip When a switch chip is in parallel loopback mode, incoming local loop data received by Giga Blaze circuit 271 at input 278 from the receive interface circuit and output on line 270 is sent immediately to the transmit interface circuit 266 via line 272 , parallel loopback switch 274 , Giga Blaze circuit 271 and output 276 . This happens under all circumstances when parallel loopback mode is engaged. Data from the port multiplexer 224 is never sent to the local loop while parallel loopback mode is engaged. If port bypass is enabled an parallel loopback is disabled, the loop is broken at the parallel loopback switch and ARB(F7) primitives are transmitted onto the local loop.
- Serial loopback mode is primarily used for testing the data paths in the switch chip.
- All chip-local and remote connections fall into one of three priority classes: none, low and high. All connection requests from a switch port default to a static priority level (which is typically no priority) which can be set my management software. Priority for requests can be escalated to low or high by a number of mechanisms.
- Priority escalates from none to low after a management programmable number of consecutive denials. If management software sets 0 as the number of denials, this escalation is disabled. After the trigger level is exceeded, the priority deny count is reset and a low-priority request bit is set for exactly one arbitration interval. This arbitration interval begins after the low priority trigger value has been exceeded and an IDLE primitive has been detected on the inbound port of the state machine. All subsequent remote requests will use low priority until another IDLE is detected, ending the arbitration interval.
- the management software can also directly escalate priority on a port by enabling a rotating-token scheme in which each port requests at high priority for a period of time while other ports deny requests to a port.
- This mechanism guarantees each port a chance to service its local clients, at the expense of servicing any new remote requests.
- the token position is computed independently by each switch chip through use of a 6 bit token port ID location, a 6 bit token compare mask, a 16 bit token hold length register, and a single token priority enable bit.
- the token enable bit controls whether the token passing scheme is active in switch mode. If the enable bit is set to 1, the token passing scheme is enabled for the switch chip. All switch chips must set their token enable bit to the same value before transitioning to switch mode.
- This mechanism allows for fairness to be maintained throughout the system. This feature is critical in congested server environments where starvation of disk access can freeze an application. The circulating fairness token prevents this from happening.
- the token position counter identifies the port or port group that holds the token.
- a port holds the token if the port ID of the port AND 2 -ed with the 6 bit compare mask matches the token counter value AND-ed with the compare mask. If a port holds the token, its requests are made with high priority. Ports wishing to request a port that holds the token are denied so that the camp list of the port holding the token can drain and local requests can be serviced.
- the token position counter is incremented when a management-specified number of wall clock counter bits roll over to zero.
- the wall clock counter is a 24 bit counter which is incremented every word clock period of 40 ns, resulting in a range of approximately 2 ⁇ 3 of a second.
- the token position increment signal is computed OR-ing the lower 8 bits of the wall clock together with the bits resulting from an AND operation between the upper 16 bits of the wall clock and a 16 bit token length value, which should be set to a string of logic ones padded to the left with logic zero. When the resulting value is zero, the token counter is incremented.
- the length of the string of logic ones in the token length register determines the amount of time that each port will be assigned the token. For example, if the value of the token length register is 0 ⁇ 3 f, the token counter will be incremented every time the lower 14 bits (8 LSB's+6 additional bits) are zero, or every 2 14 *40 or about every 650 usec.
- camper is ordered in a camp list FIFO which has a depth of 8 entries.
- Low and high priority are allowed to camp on a port if the camp list for that port is not currently full and the desired port is not holding the token.
- High priority requests differ only in that at the destination port they may be queued up to the depth of the camp list, while low priority requests queue to the low-priority camp depth set by management. All requests are serviced by a single queue with FIFO discipline.
- An alternative embodiment uses separate queues for high and low priority thus allowing high priority to jump to the head of the line.
- the management software In order to transition the system from switch mode from hub mode, the system must first be locked. Before initiating a lock from hub mode, the management software should set all parameters necessary for switch mode transition while the system is in hub mode so that the time spent during the transition in the locked state is minimized. Since transactions cannot be initiated while the system is locked, it is possible that an NL-port could time out and LIP (initialize) if the system is locked for too long, causing the hub to switch transition to fail.
- APN trapping The associations between node addresses (AL_PAs) and their associated ports are determined at initialization time through a learning process referred to herein as OPN trapping.
- An OPN primitive is said to be trapped in hub mode when it has been transmitted onto a local FCAL net and an RRDY primitive received in its place.
- the switch chip has the destination node address (AL_PD) of the device residing on the FCAL net where the trap occurred as well as the port ID of the port servicing the loop. This information is stored in the LUT routing table 228 .
- the CAMs can also be synchronized as the OPNs are trapped through communications on the protocol bus. Since the protocol bus is only utilized for scoreboarding during switch mode, every trapped OPN results in a protocol bus transaction that advertises the node address and the port ID to all switch chips.
- AL_PA active discovery is a procedure by which the switch chip learning process is accelerrated by additional logic on each switch chip. Active discovery is initiated by asserting a signal on each switch chip while it is in locked state. Once active discovery is initiated, a signal BCST_BUSY is driven low, and a 10-bit counter cycles through the 1024 10-bit words. Each word is passed through an address encoder which generates a signal that is active whenever the 10-bit word corresponds to a legal AL_PA. For each such word, the discovery process is triggered for each port on the switch.
- the active discovery process starts with an OPN transmitted onto the local loop using the counter word as the AL_PD or destination address.
- the OPN is immediately followed by an interframe gap and a CLS. This sequence will travel around the loop and return to the discoverer if a device with that particular AL_PD is not on the local loop. If the node with that destination address is on the local loop and the node is not bypassed, the node will consume the OPN and CLS and send a CLS of its own. In this case, the discovery logic will write the AL_PA to port associated into the CAM. After an OPN or CLS is received at the receive port of the port which launched the OPN onto the local loop, the active discovery state machine pauses until the counter reaches another valid AL_PA.
- the loop port state machine is not a strict implementation of a conventional FCAL loop port state machine since it must switch OPN sequences and subsequent frames to and from the backplane and post messages to and read messages from the protocol bus and update the scoreboard and carry out the learning protocols.
- the LPSM must not disturb OPN-CLS or SOF-EOF symmetry, nor should it unintentionally disturb credit flow by removing and adding RRDYs. In dual simplex cases, the LPSM will intentionally manipulate credit by absorbing RRDYs and rerouting them to an alternate destination.
- the LPSM must conform to the FCAL requirements regarding interframe gaps. Also, the LPSM should avoid interframe gap conditions which are FCAL legal, but cause interoperability problems with current equipment.
- the LPSM may operate in unfair mode in order to prioritize remote connections over local connections, but it must not break arbitration by prematurely resetting the access window, or starvation may occur.
- the LPSM must allow loop initialization to be triggered and to proceed in a reasonably normal manner.
- FIG. 11 is state table describing the various LPSM states in the preferred embodiment.
- An LPSM always operates in unfair access mode in order to obtain the loop as soon as possible.
- the current arbitration window is not observed and the high priority ARB (usually ARB(0), but programmable by the management software to be any AL_PA) is used to gain control of the loop.
- the loop port state machine issues ARB on the loop whenever a remote request is pending and continues to do so until the same ARB is received back at the LPSM indicating that the LPSM has won arbitration.
- the LPSM receives an OPN or RRDY primitive, then another device on the loop won arbitration. In this case, the LPSM continues to issue its ARB, and monitors the loop until arbitration is won. While arbitrating, an OPN may arrive from the loop; the AL_PD of the OPN is then used to search the LUT to determine whether the OPN is to a remote or local device. If the OPN is remote, the LPSM synthesizes a CLS in an attempt to end the tenancy of the device on the local loop which sent the OPN which is interfering with the arbitration attempt of the LPSM. Thus, remote tenancies which have already traversed the protocol bus and are present camped are heavily favored over local devices who are attempting to make a remote connection. If however the OPN received from the local loop during arbitration by the LPSM is directed to a local device, the LPSM continues to arbitrate while processing the local transaction normally.
- the two primitives RRDY and CLS are used according to FCAL net interframe gap policy.
- the specific policy that the switch chips use is that if a current primitive is a fill word and two consecutive fill words have previously been detected, then insertion of the RRDY or CLS may take place.
- fill words are defined as ARB(x) and IDLE primitives.
- Fill words are generated and inserted onto the local loop when the LPSM is not in the LPSM _MON state (hereafter the states of the LPSM will be referred to by the acronym that follows LPSM _ in FIG. 11).
- Rules governing fill word generation ensure that the current arbitration state of each loop is maintained independently.
- the problem for each switch chip when it is coupled to a source loop, i.e., the loop having the source node, is that it must send fill words that are relatively innocuous.
- An NL_port in an OPEN state will transmit ARB(F0) which it uses to determine if any other ports on the loop are currently participating in arbitration.
- the open NL_port receives ARB(F0) in return, the NL_port has the option of retaining the loop and sets it current fill word to IDLE, thereby resetting the arbitration interval.
- the LPSM needs to send a management programmable low priority ARB that does not possess the potential to disturb the local loop access state like ARB(F0) does.
- the ARB(F7) is suitable, as it is only used by a non-participating port to quiesce the loop prior to sending a loop initialization primitive LIP in order to receive a valid AL_PA.
- the fill word generation matrix for the source loop is given in FIG. 12, and the destination fill word generation matrix is given in FIG. 13.
- the ARB(F7) state is entered when a local OPN is received, and a minimum of 6 current fill word primitives are sent when relinquishing the loop.
- the ARB(F0) state is entered when a remote connection request is received, and the ARB(F0) state is entered when a tenancy is established and an OPN is passed. A minimum of 6 current fill words are sent when relinquishing the loop.
- the most common primitives that the switch chips must deal with are: IDLE, RRDY, ARB, OPN, SOF, EOF, CLS and LIP.
- the other primitives that may be encountered include: NOS, OLS, LR, LRR, MRK, LPB AND DHD. The handling of these other primitives is described below.
- the OLD_PORT detect flag of the port is set so that the management software can detect the condition. LR and LRR primitives will be fed back onto the local loop, but not through the backplane.
- the MRK primitive is discarded if issued during a remote tenancy in dual-simplex. Otherwise, MRK primitives are passed around the local loop and across any remote connection. However, it is unlikely that a MRK will find its destination unless it is issued inside of a tenancy in which the target is on the destination loop.
- the LPB and LPE primitives are trapped and written to management software.
- a detection flag is set for either an LPB or an LPE, and the AL_PD and AL_PS are written to a 20-bit register that is accessible by the management software.
- the protocol bus is the medium by which the scoreboards for each switch chip are kep current. It also serves to communicate switch connection requests and responses between switch ports.
- the protocol bus is defined as an 18 bit bidirectional data bus named PBD, a request output PBREQ0 for each switch chip, a grant input named PGGRNT1 to each switch chip, a shared bus idle input signal PBIDLE1, and shared frame available input signals named PBFRM1.
- PBD 18 bit bidirectional data bus
- PBREQ0 for each switch chip
- PGGRNT1 grant input
- PBIDLE1 shared bus idle input signal
- PBFRM1 shared frame available input signals
- a switch chip When a switch chip wishes to transmit a data frame on the protocol bus, it drives its PBREQ0 output.
- the PBREQ0 of each switch chip in the system is fed into external arbitration logic which prioritizes the inputs and asserts a single PBGRNT1 output in the same cycle.
- the chip that receives the asserted PBGRNT1 deasserts PBREQ0 and then drives the PBD bus in the next cycle.
- the arbiter asserts PBFRM1 in the cycle following any PBGRNT1 to notify each switch chip that a data frame is present on the protocol bus.
- PBIDLE1 asserted whenever no chip is requesting the bus in a cycle, indicating that the protocol bus arbitration window may be reset.
- Each protocol bus data frame possesses a slightly different format. These formats are depicted in FIGS. 14A through 14E.
- the abbreviations BP CHNL in FIGS. 14B and 14C stand for backplane channel.
- the abbreviation PID in FIG. 14E stands for port ID.
- connection request data frame of FIG. 14A is sent by a port that wishes to initiate a connection to a remote destination port and has found that the destination camp list can accept a request of the desired priority, and that the destination port is not current requesting a destination for itself.
- every switch chip marks its 64 bit requester scoreboard and increments its camp list depth scoreboard for the destination and priority.
- Chip remote request frames have a 0 ⁇ 0 pattern in the LCL field shown at 300 in FIG. 14A while chip local requests place a 0 ⁇ 3 in this field. This difference in format allows switch chips to update channel allocation scoreboards only on chip remote requests. If a chip remote request hits a channel that has been placed in an age list, a channel idle scoreboard for the channel owned by the destination port is cleared; otherwise, a need counter is incremented as will be explained in the next section.
- a connection response having the format of FIG. 14B is broadcast by a port that has serviced a camp list entry, and indicates that a connection may be initiated over a backplane data channel specified in field 302 .
- a connection response results in the clearing of the requestor scoreboard for the requestor ID given in field 304 of the response frame, and it also results in setting the responder scoreboard for the destination port.
- the port that own the allocated channel and the channel number are entered into the age list on the initial allocation of the channel.
- a responder port that resides on the same switch chip as the requestor, indicating a chip-local connection must still broadcast a response frame so that the responder scoreboard is updated in all the other switch chips. This type of chip-local connect respose carries an invalid channel ID code of 0 ⁇ f, which indicates to receiving switch chips that the backplane usage scoreboard should not be modified.
- a responder channel idle frame having the format of FIG. 14C is driven on the protocol bus when a backplane channel completes a transaction.
- the channel is retained by the responder until the channel is required by another responder, thus reducing setup overhead if the destination node that just finished a tenancy over the channel is a frequently accessed destination.
- each switch chip updates its channel idle scoreboard to indicate the channel is available.
- the no-op frame of FIG. 14D is used as a late abort of a response due to channel allocation. This may occur when a request has been queued for transmission but a conflicting request is received before the queued request can be transmitted.
- the queued request is checked a final time before transmission, and if a local deny must take place, the frame is converted to a no-op and sent to get it out of the queue. Any other way of purging the queue will also suffice.
- the lookup table update frame of FIG. 14E is transmitted when an OPN is trapped on a local loop in hub or locked mode.
- the frame is then used by each switch chip to enter a node address AL_PA equal to the content of field into its LUT with a port ID mapping as specified in field 308 .
- the example given herein for the configuration of the backplane has 14 separate backplane data channels, three of which may be dedicated to other uses such as broadcast. Channels are allocated by destination ports and remain assigned to them for as long as possible. A channel scoreboard indicates if any channels are free and is used to hold off any pending responses from ports which are not already connected to a data channel. If this is not the case, a need counter is incremented. When this need counter exceeds the physical number of data channels, then the backplane attempts to free up a channel while the destination port attempts to obtain a connection grant response from its LPSM. All data channel connections (identified by response frames on the protocol bus) are stored in the age list which indicates the channels that have been held the longest and the port that currently own those channels.
- each switch chip consults its age list and selectes the channel to be relinquished. Idle channels are broadcast on the protocol bus using the frame of FIG. 17 when the camp list of the port owning the channel empties completely. The oldest owned channel is freed by the switch chips that owns the channel and all switch chips update their scoreboards to reflect the new state. For every channel that is freed, the need count is decremented by one.
- Channels can also be freed in blocks of size greater than one.
- the size of the block of channels freed is determined by management-programmable parameter.
- the switch chip management logic can also instruct the backplane to always free a channel when it becomes idle, rather than only freeing the channel when the need arises.
- Starvation is a problem because most of the fairness policies implemented by the switch chips guarantee remote access fairness to switch ports and not to the individual NL_ports.
- an NL_port is guaranteed access to its local loop and is guaranteed to win arbitration within one FCAL net access window, its tenancy will not be successful if the NL_port attempts to transmit to a remote port and is denied connection by the switch.
- randomness of access patterns will result in statistical fairnesss.
- each switch chip's LPSM includes logic to support three possible broadcast modes: that of the broadcast sender, the broadcast server transceiver, and the broadcast receiver.
- a switch chip For a switch chip to be able to send broadcasts, it must include logic to decode a broadcast sequence as described below, logic to determine whether the broadcast channel, if it exists, is busy, logic to forward a broadcast sequence directly to the local loop as it is received, and logic to write a preamble to the broadcast sequence and place the sequence on the broadcast channel if it is available.
- each switch chip should have the following structure. Broadcast sequences are detected on the inbound port from the local loop.
- a broadcast sequence is defined to be the sequence of one or more broadcast OPN groups terminated by a CLS primitive.
- a broadcast OPN group is defined to be one or more selective or broadcast OPNs followed by data frames.
- the LPSM always forwards a broadcast OPN group back to its local loop, guaranteeing that all local NL_ports see the broadcast and that the sender of the broadcast can clean up the local loop.
- the switch port also attempts to forward the broadcast to the predefined backplane broadcast channel. If the channel is not already busy with a broadcast that is already in flight, the switch chip will prepend a unique, identifier sequence to the broadcast sequence and transmit the prepended sequence onto the broadcast channel. During the transmission, any broadcasts on the channel but upstream from the broadcasting switch chip will be discarded. As a result, only one broadcast may reach the broadcast server. When the server receives a broadcast, it reads the broadcaster ID prepended to the sequence. This identification mechanism excludes the original broadcaster from transmitting data onto the local loop a second time. The broadcast server then sends unicast to each of the destinations on the broadcast list.
- the server comprises one port of a switch chip that is configured to only listen and transmit on the broadcast channel, and a broadcast server board that is connected to the switch chip by its serial loop port. Broadcast sequences are received by the dedicated broadcast port and forwarded to the switch port connected to the broadcast server board for storage.
- the LPSM In order for a switch chip to be able to receive broadcasts, the LPSM must include logic that discriminates whether an incoming broadcast originated at the port or at some other port from the data in the preamble prepended to the broadcast sequence.
- a switch port In order for a switch chip to be able to function as the transceiver interface to the broadcast server, a switch port must be configurable so that it only forwards data from the broadcast channel to the loop port and forwards data from the loop port back to the broadcast channel. This port should not be effected by state change requests or other exceptional conditions if it is configured as a broadcast transceiver.
- FIG. 29 there is shown a species of a buffered FCAL switch which falls within a separate second genus of FCAL switches, suitable for Class 3 Fibre Channel operation only. Switches in this genus still uses the destination address in the OPN to find the remote port but uses buffers instead of hold back flow control to complete the transaction to busy remote ports. Specifically, species within this genus will use the destination address of the OPN from the source node to find the location of the remote port. The destination address is used to look up the port ID of the switch port couped to the destination address. Suppose Then the status of that port will be checked.
- a connection request will cause a connection to be set up between the source node and the destination node via a source port connected to the source node and a destination port connected to the destination node.
- the buffer comes into play when the destination port is busy.
- the normal primitives of the FCAL protocol are used for flow control to prevent the source node from transmitting any frames of data until the destination port becomes available.
- a buffer big enough to hold one or more complete frames of data is included in the front end of each switch chip, or multiple buffers each big enough to store a frame of data are included with each switch chip front end.
- Each of these buffers will serve as an auxiliary switch port and have its own connection to the backplane in some species or a single shared connection to the backplane through a multiplexer can be used.
- the preferred species uses multiple buffers each with its own connection to the backplane in addition to a connection directly from the switch port to the backplane for direct connections without buffering.
- a single shared buffer or multiple shared buffers on the backplane or in some central location may be used.
- the way the buffers are used is for the source port to generate an RRDY sua sponte when it finds from a check of the scoreboard that the destination port is busy.
- the RRDY is sent to the source node and causes it to output a frame of data.
- This frame of data is stored in the switch port's buffer.
- a message is sent to the destination port indicating that the auxiliary buffer of the switch port is holding a frame of data for the destination port.
- This auxiliary buffer ID is added to the camp list for the destination port.
- a message is sent back on the protocol bus indicating that the destination port is now available and naming the backplane channel to use.
- a connection through the backplane is then established to this channel by the auxiliary buffer connection circuitry and the destination port, and the data in the auxiliary buffer is transmitted.
- the switch port has multiple auxiliary buffers, they each have their own IDs and, preferably, each has its own switching circuitry to make a connection to the backplane.
- each auxiliary buffer has circuitry coupled to the return path to recognize RRDYs transmitted back by the destination node and to count them (or store them) and to wait for a connection between the source port and the RRDY counting circuit if the connection is not continuous such as in some cases where multiple buffers are present in each switch port.
- These stored RRDYs (or self generated in the case of a count only) can be transmitted to the source node in the case of full duplex or mixed with frames from a third node in the case of a dual simplex connection and transmitted to the source node.
- Each source port also has shared circuitry for each FCAL net which recognizes incoming RRDYs from the source node and counts them or stores them. These source node generate RRDYs can be transmitted to the destination node in the case of full duplex or transmitted to a third node in the case of dual simplex.
- an OPN/RRDY detector and RRDY generator circuit 450 detects any incoming OPN or RRDY primitives coming in from the source node 452 on the local FCAL net 454 .
- the destination address of the OPN is latched and sent to the lookup table circuitry represented by block 456 via line .
- the lookup table looks up the ID of the port connected to the destination node and determines its status.
- a first OPN with a destination address for node 451 is received from source node 452 and the status of destination node 451 and its switch port 453 is available.
- protocol bus interface circuitry in block 456 sends a connection request via protocol bus 458 to protocol bus interface circuitry in block 457 of switch port 453 requesting a connection. This results in a connect response message naming the backplane channel to use.
- the loop port state machines in blocks 456 and 457 then send commands via buses 466 and 467 , respectively, to their respective port multiplexers 460 and 459 to establish connections between “straight through” data paths 462 and 464 to the designated backplane channel in backplane 465 .
- the LPSM in block 456 also controls switches 468 and 470 to make connections to wires 462 and 464 , and the LPSM in block 457 control switches 469 and 471 to make connections to “straight through lines 473 and 475 .
- Destination node responds with an RRDY and that gets passed to source node 452 through the connection just described and the transaction proceeds normally until completed and the backplane channel is relinquished.
- the lookup process using the destination address in the OPN determines that an immediate connection is not possible.
- the LPSM in block 456 controls switch 470 to make an outbound connection to buffer 1 A via wire 472 and controls switch 468 to make an inbound connection via wire 474 .
- the LPSM then commands switch 476 to open long enough for an RRDY to be sent to source node 452 and commands RRDY generator circuit 450 to generate an RRDY on line 478 and send it to source node 452 .
- the RRDY causes source node 452 to output a frame of data.
- This frame passes through line 480 , SERDES 482 , switch 470 and line 472 into buffer 1 A and is stored there.
- the circuit 450 then generates a CLS and sends it to source node 452 .
- switch 476 is closed.
- LPSM in block 456 then sends a message on protocol bus 458 to the protocol bus interface circuitry and LPSM in block 457 that it has a frame of data waiting for destination node 451 .
- This message gives the ID for the buffer 1 A and causes that ID to be put on a camp list for destination node 451 .
- LPSM in block 457 sends a message back to LPSM in block 456 saying “send data in buffer 1 A on backplane channel X”.
- the LPSM in block 456 then controls port multiplexer 460 to establish a connection between wires 484 and 486 to the designated backplane channel.
- LPSM in block 458 controls switchs 469 and 471 to establish connections to wires 473 and 475 and controls port multiplexer 459 to connect wires 473 and 475 to the designated backplane channel.
- the LPSM in block 456 then causes a switch 490 to close and causes Buffer 1 A to output its frame of data onto the backplane channel where it gets transmitted to the destination node 451 via straight through wires 473 and 475 .
- the circuit 450 will not send a CLS to the source node 452 after it sends a frame of data into the buffer 1 A.
- the connections will be maintained so that if there is more than one frame, it can be sent as soon as the destination node becomes free by a straight through connection.
- the LPSM in block 456 also causes switch 492 to close for a return path and causes switch 468 to make a connection to return path wire 474 so any RRDYs output by the destination node are transmitted to the source node 452 once the destination node becomes available.
- the LPSM also then causes switch 470 to make a connection between outbound path 480 from source node 452 and “straight through” outbound wire 464 so subsequent frames can be sent straight through.
- the transaction then completes as a straight through transaction. Buffers in the switch ports such as buffers 1 A and 1 B may be big enough to hold more than one frame in some species to avoid having to establish a separate tenancy for each frame.
- the preferred method in the buffered switch is to close the source node after it outputs one frame into the buffer, it is then free to generate new OPNs to other destination nodes.
- Those OPNs can cause either straight through or buffered connections to their destinations depending upon the status of the destination port.
- the LPSMs can cooperate after the table lookup using the new OPN destination address to control the switches 468 and 470 and their counterparts in the destination port to establish a straight through connection to the new destination via another backplane channel.
- the buffer 1 A and its associated switches and the LPSM are cooperating to act as an independent switch port such that when the destination node for the data in the buffer becomes available and a connect response message is received, it can independently send its data to the destination node the different backplane channel assigned in the connect request message.
- This increases throughput since the same switch port may be simultaneously be sending data to two or more different destinations.
- Buffered FCAL switches such as that shown in FIG. 29 have the additional advantage in that it prevents source blocking. The source may download one or more frames into the buffer for a destination node and then move on to its next transaction thereby reducing or eliminating head end blocking.
- Dual simplex is also possible to increase throughput further by using circuit 450 to count RRDYs emitted by the source node and using LPSM in block 456 to award those RRDYs to a third node.
- the RRDYs will cause the third node to send data inbound to the source node via a separate backchannel connection with LPSM in block 456 controlling switch 468 to establish the inbound path to source node 452 via the backplane channel assigned by the third node and straight through wire 462 .
- Outbound data from the source node to a destination node can be sent by straight through wire 464 or through one of the buffers.
- RRDYs emitted by the destination node are received by the destination port and sent via the protocol bus to the LPSM of the source port or a message is sent each time an RRDY is received from the destination node by the destination port informing the source port of this fact.
- the source port LPSM then controls circuit 450 to generate an equivalent number of RRDYs and mix them in with the data frames from the third node on the inbound path 492 to the source node 452 to keep the source node outputting data frames destined for the destination node.
- the RRDY capture circuits are used in species where RRDYs are emitted by the destination node, but the switches 468 and 470 are in states such that the RRDYs cannot be immediately be sent to the destination node such as where the source port is generating multiple OPNs to different destinations and filling up all its buffers one by one.
- the nodes will have to be non standard in that they will have to OPN a destination, download one or more frames into a buffer, receive a CLS from circuit 450 , OPN a new destination, download another one or more frames into another buffer, receive another CLS from circuit 450 and continue this process until all buffers have been used.
- the LPSM will commutate the switches to make successive connections to the buffers and straight through connections as needed and keep cycling through these connections.
- the RRDY capture circuits will count the number or RRDYs received or emitted by the destination nodes, and when the switches 468 and 470 and 490 and 492 are again in position for communication with the destination node, the source node will open itself spontaneously for that destination, receive any stored RRDYs from that destination and send an appropriate number of frames to that destination either by a straight through connection or a buffered connection.
- Fairness is implemented in the species within the second genus in the same way as in the species of the first genus.
- a fairness token is circulated, and when any switch port has the token, it assumes the highest priority.
- the fairness token can be circulated amond the switch ports on a separate fairness token bus (not shown in FIG. 29) or via the protocol bus which is the embodiment symbolized by FIG. 29.
- each switch port also includes a local loop bypass data path to keep purely local transactions confined to the local FCAL net.
- each FCAL net is FIG. 29 is shown as having only one node, multiple nodes on each FCAL net are also possible.
- FIG. 29 shows only one switch port per switch chip, multiple switch ports per switch chip are also possible similar to the structure shown in FIG. 7 but using the architecture of FIG. 29 for each switch port.
- Appendix B attached is the UUencoded Verilog description of the preferred embodiment of the entire switch chip integrated circuit.
- Appendix B is the C language source code for the UUencoding and decoding program to enable decoding of the Verilog and documentation for using the UUencoding and decoding program.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- Astronomy & Astrophysics (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Small-Scale Networks (AREA)
Abstract
Description
- This is a continuation in part of a co-pending patent application entitled FIBRE CHANNEL LEARNING BRIDGE, LEARNING HALF BRIDGE, AND PROTOCOL, Ser. No. 08/786,891, filed Jan. 23, 1997, which is hereby incorporated by reference.
- Fibre Channel networks are known loop configuration networks that have a plurality of known type nodes such as servers, printers, disk arrays etc. all connected together by the loop. Such networks use a unique protocol involving a plurality of 40 bit primitives that are used to arbitrate for loop control, to establish connections and to carry out flow control for data transfers of frames of data. The flow control inherent to the Fibre Channel Arbitrated Loop network (hereafter FCAL nets) protocol has the advantage of eliminating the need for the nodes to have extensive buffering capabilities since the destination node controls the amount of data it receives by transmission of an RRDY primitive to the source node each time the destination node is ready to receive another frame.
- Fibre Channel networks emerged as a family of interconnection topologies to increase bandwidth over fast-wide SCSI networks and to increase the number of server and storage elements that can be connected to 126 over the 16 device limit of SCSI. Advantages of FCAL include that devices may be farther apart (up to 10 km) and more numerous and that the size of data transfers is very large compared to the overhead that is required to set up every transfer. This makes FCAL very efficient and more attractive than less efficient protocols such as TCP/IP over Ethernet and SCSI over a bus connection.
- Hub based network topologies are generally desirable because they overcome certain limitations on the number of nodes that can be coupled to a network by breaking it up into segments coupled by the hub. Many Ethernet networks use hubs as do token ring networks. Hubs in FCAL networks receive packets from a source node on an input line coupled to the source node and rebroadcast the packet on an output line coupled to the next node which rebroadcasts the packet to the next node and so on. The rebroadcast by subsequent nodes in the chain wastes computing resources. Switched topologies work differently in that packets are not rebroadcast, but instead are connected directly to the line coupled to the destination node thereby eliminating processing by other nodes which are not the destination to receive and rebroadcast messages not destined for that node.
- Despite their advantages, a significant problem in FCAL networks is delay and this delay increases as the network scales up in size. Each meter of cable contributes 5 ns of delay. Further, each node contains an elasticity buffer or FIFO to absorb the differences between incoming and outgoing data rates. Data passing through a node enroute to its destination passes through the nodes elasticity buffer and suffers a typical delay of 3 words.
- Typically, disk clusters are 10 drives to a cluster with each drive being one node and imposing its own delay. If there are 10 clusters coupled to a server, this would represent typically 5.3 microseconds of delay in transition of each primitive and data frame travelling around the loop. In other words, this delay is imposed on each loop tenancy. In an I/O operation, there are typically 4 tenancies for a write to disk, each involving 3 “round trips”: ARB, OPN-RRDY and Data/CLS (see ANSI standard X3T10 FCP which is hereby incorporated by reference). Thus, 12 delays would be suffered by each command transaction. On a 100 node loop, this translates to approximately 64 microseconds of delay per command.
- The command overhead of modern disk drives is around 200 microseconds and failing. The delay per command coupled to the command overhead of the drive imposes a significant penaly on performance of approximately 32%. For random access benchmarks with small I/O payloads typical of database queries, the performance penalty becomes more pronounced. The problem manifests itself as the inability of the server to achieve more I/O operations per second, regardless of how many more disk drives are added to the system.
- Spatial reuse provided by switches or hubs which allow concurrent loop tenancies is one way of reducing the delay problem. The IBM serial storage architecture in the prior art is one method of providing spatial reuse.
- Connection oriented switched topologies were tried in early Fibre Channel Fabric networks to attempt to overcome the delay problems of loops by cutting down the number of nodes each primitive and data frame passes through in getting from source to destination and providing spatial reuse. These early fabric switches were complicated, expensive and slow, all of these characteristics being found quite undesirable by artisans of FCAL networks. In the early FC Fabric switches, an entire frame of data with a header that indicated the destination node to which the frame was directed was sent to the switch for purposes of requesting a connection. These early switch designs had microprocessors which were used to implement several layers of software architecture to receive the frame, pass it up through various layers of processing to find the frame boundaries, crack the frame open, determine its destination address and then attempt to find the destination node and make the switching connection. The entire frame of data had to be buffered during this process of attempting to find the destination and make the proper connection. It was possible in this early design that the connection was never made, because, for example, the destination node was busy with another conversation. The switch would then have to send a message back to the source that no connection was made and to try again later. Because of limited buffer space in the switch, the data in the original frame might need to be overwritten by other data from a frame of data embodying another request. In such a case, the switch would have to send another message to the source saying, “Sorry, I lost your data. Execute error recovery protocol.” Error recovery protocols further complicated the operation and contruction of such systems. If a connection is made, the switch receives another frame of data back from the destination. This frame also must be received, have its boundaries detected and must be cracked open to examine its contents to see if the destination is saying, “Yes, I am available for a connection.” This type of switch proved to be unworkable and FCAL loops became the standard interconnect for disks and servers.
- Prior art Fibre Channel switches are commercially available from Ancor and Brocade Communications which provide spatial reuse and efficient link utilization. The FL_ports connected to these switches also address physical delays as they pertain to FCAL. However, these switches require link rate frame buffering to accomplish their performance levels, and also operate on the entire 24-bit address contained in the FC frame. In contrast, the invention described herein uses zero buffering and an 8-bit address decode for a much more efficient and inexpensive design.
- Many network switched topologies that use entire frames of data to request a connection through the switch suffer these same drawbacks. The need for errory recovery protocols arise because of the potential for lost data arising from the fact that only limited amount of memory can be put in the switch at realistic costs, and in heavy traffic situations, the memory may be exhausted and some portion thereof may have to be rewritten with new data before the original data is delivered. Memory is expensive, takes up space and complicates the design.
- Examples of other network topologies other than Fibre Channel Fabric that suffer these same drawbacks are the 1 Gigabit Ethernet® and ATM protocol networks now in public use.
- The Fibre Channel Arbitrated Loop (FCAL) topology emerged as a way of providing simple, low-cost connectivity to more nodes over a shared media than could be provided in point-to-point topologies without the requirement for an expensive fabric switch. FCAL networks allow up to 126 node ports to be coupled by a shared media using a simple protocol without the need for a separate fabric switch. Unlike the switched fabric topology which has a centralized approach to routing, FCAL networks distribute the routing function to each loop port. This reduces the cost of achieving interconnection since the loop functionality represents a relatively small addition to the normal port functionality that has to be present anyway. However, FCAL networks suffer the disadvantage that the number of concurrent interconnections possible is smaller than in switched-fabric networks because FCAL networks are fully blocking topologies such that only two pairs of nodes on the loop can communicate at any particular time. All other nodes have to wait until the first pair are done communicating before the loop is available for another pair to communicate. The address space is also limited to 126 nodes. Another problem with FCAL topologies is that traffic originating from a source node had to travel through each intermediary node on the loop portion between the source node and a destination node. Since each node imposed a delay, the overall bandwidth was decreased since each loop tenancy involved a protocol wherein OPN, RRDY and CLS primitives and data frames had to travel through all these intermediary nodes in order to complete the loop tenancy. Since no other pair of nodes could communicate until the loop tenancy was complete, the delays in transmission imposed by each node on each portion of the protocol decreased overall bandwidth and throughput.
- In an attempt to further increase bandwidth and concurrency without the extremely high cost of fabric switches, combinations of FCAL loops with smaller fabric switches have been devised. This allows the cost per port of the fabric switch to be amortized over the the total number of ports including those coupled to the subloops coupled to the switch.
- The problem with the approach of coupling multiple FCAL loops together by a fabric switch is that each FCAL subloop must be coupled to the fabric switch by a complicated port called an FL_port. These are ports which must be able to understand the FCAL loop protocol on one side of the port and interface it with the very different and substantially more complex fabric switch packet switching protocol on the other side of the port while also having bridging functionality. Such FL_ports must have protocol layers that understand each protocol and can do packet routing and communicate with each other.
- Further, FL_ports are expensive to build. This is because of the inordinate amount of buffer memory that is needed in the front end of the FL_port to reconstruct the sequences of packets contained in one FCAL tenancy. Modern day connectionless fabric switch protocols are pure packet switching while FCAL loop tenancy protocols are single conversations which tend to be like a simple switched circuit and contain many packets. That is, the FCAL loop tenancy protocol starts with an OPN primitive directed to a destination node which responds with an RRDY directed to the source. These primitives set up switches in the nodes so that the source and destination nodes talk directly to each other through the loop segment between them and the intervening nodes by sending one or more frames of data until a CLS primitive is sent which ends the conversation.
- In contrast, the packet switching done by an FL_port on the switch backplane side is not nearly this simple. The packet switching protocol requires the FCAL frames output by a source node to be treated as many individual packets. Those packets must be routed to the correct destination FL_port and reassembled there without loss of data and launched on the FCAL loop on which the destination port is resident. Thus, FL_ports will receive packets from the fabric switch side and data frames and primitives from the FCAL loop side and must have the memory and intelligence to convert between the two protocols.
- In the treatise Kemble,Arbitrated Loop, Chap. 1, pp. 18-19, FIG. 12, Published by Connectivity Solutions, Tucson, Ariz. (1996), ISBN 0-931836-82-4, Kemble proposes a “Smart Hub” conceptual network. This network is comprised of a plurality of FCAL loops coupled together by a smart hub which has the intelligence to provide independent operations within each loop. When a source node want to exchange data with a destination node, it arbitrates for its local loop and attempts to establish a loop connection with the destination. If the destination is local, the smart hub simply acts as a repeater. If the destination port is not local, the smart hub intercepts the attempt to establish a loop connection, acquires access to the proper destination loop and establishes the loop connection between the source and destination loops acting like a bridge. Thus one loop can talk to another without affecting activity which is purely local to the other loops not involved in the connection, but the other loops cannot set up simultaneous connections to nodes on other loops during the tenancy across the smart hub of the first cross-boundary connection between the two loops already connected across the smart hub. This type arrangement cannot satisfy the need for a fast switch which is affordable and provides the ability for multiple pairs of ports to communicate simultaneously across the switch.
- As a response to the limitations on concurrency present in conventional FCAL topologies, the assignees of the present invention devised a network topology using intelligent hubs each of which had routing intelligence and each of which had its own subloop coupled to a plurality of conventional L_port nodes of a type used in conventional FCAL topologies. Each hub was coupled to each other hub by a broadcast data path and a return data path. By watching the addresses in the OPN primitives and the flow of primitives, the hubs were able to deduce the location of the source and destination nodes and cut out all subloops and nodes thereon that were not necessary for communication between the source and destination nodes thereby decreasing unnecessary delay in completing each loop tenancy and increasing bandwidth. Further, some concurrency was supported in that tenancies between source and destination nodes on the same subloop could be completed simultaneously on each subloop, thereby further increasing throughput. This technology is described in U.S. Pat. No. 5,751,715 which is hereby incorporated by reference.
- The assignee of the invention has also filed a co-pending patent application on a learning bridge for FCAL topologies such that two or more FCAL loops can be coupled together by bridges. The bridges have the intelligence to examine the destination addresses of OPN primitives received from their local loops and watch the primitives of loop tenancies and the loops from which they came and to learn the locations of various nodes on the loops to which they are coupled. Each bridge then forwards OPN primitives from one loop to another if the destination node is on a different loop than the source node, but keeps the OPN local to the same loop as the source is on using a local bypass data path if the destination and source nodes are on the same loop. This provides the ability for concurrent loop tenancies to be occurring on the two loops coupled to the bridge, although only one loop tenancy per loop is allowed at any particular time. This technology is described in the parent application incorporated by reference herein.
- Despite these improvements over standard FCAL topologies provided by the assignee, there is still a need for further improvements in concurrency without the increased cost and increased protocol complexity of fabric switches. What is needed is a way to achieve the high concurrency and bandwidth of fabric switch topologies without the high cost thereof.
- Therefore, a need has arisen for a relatively simple, FCAL switch which has little or no buffer memory needed therein and which is capable of establishing connections very fast.
- Fundamentally, what the prior art is missing is a switch which can couple multiple FCAL loops together with high concurrency and the speed of a fabric switch that uses N-ports and does not couple FCAL loops together without the expense, complexity, memory demands and slowness of fabric switches that use FL-ports (FL-ports can support fast switching, but the amount of memory needed makes the cost prohibitive). This switch, in an ideal world, would have multiple ports, each of which is coupled to an FCAL loop or an NL node and provide concurrency such that each port can talk to any other port at any time the other port is not already tied up in another loop tenancy.
- Two important attributes of all species within genus of the invention are: first, the use of the destination address in an FCAL OPN primitive (hereafter referred to as an OPN) instead of a frame header of a frame of data to find the destination node and establish the connection through the switch; and, second, using the normal flow control primitives of the FCAL protocol for hold back purposes to eliminate the need for large buffer memories in the switch and so as to implement a switching protocol to stream complete data frames from source to destination without storing any data frames in the switch, and without any packetizing, and without any segmentation and reassembly processing, and without any error recovery protocols to retransmit dropped frames. Any species that shares these two characteristics is within the preferred genus of the invention. This preferred genus qualifies for
class 2 Fibre Channel operation where frames cannot be dropped because the flow control nature of the switch prevents frames from ever being dropped because they are only transmitted when the destination node has indicated it can receive them. The preferred genus can also be operated inclass 3 Fibre Channel operation where it is permissible to drop frames and upper level protocols do error recovery for dropped frames even though the switch never drops frames. - A separate second genus of FCAL switches, suitable for
Class 3 Fibre Channel operation only, still uses the destination address in the OPN to find the remote port but uses buffers instead of hold back flow control to complete the transaction to busy remote ports. Specifically, species within this genus will use the destination address of the OPN from the source node to find the location of the remote port. Then the status of that port will be checked. If the status is available, a connection request will cause a connection to be set up. between the source node and the destination node via a source port connected to the source node and a destination port connected to the destination node. The buffer comes into play when the destination port is busy. In this situation, in the first genus described above, the normal primitives of the FCAL protocol are used for flow control to prevent the source node from transmitting any frames of data until the destination port becomes available. In the second genus defined in this paragraph, a buffer big enough to hold one or more complete frames of data is included in the front end of each switch chip, or multiple buffers each big enough to store a frame of data are included with each switch chip front end. Each of these buffers will serve as an auxiliary switch port and have its own connection to the backplane in some species or a single shared connection to the backplane through a multiplexer can be used. The preferred species uses multiple buffers each with its own connection to the backplane in addition to a connection directly from the switch port to the backplane for direct connections without buffering. In some species, a single shared buffer or multiple shared buffers on the backplane or in some central location may be used. - In this second genus, the way the buffers are used is for the source port to generate an RRDY sua sponte when it finds from a check of the scoreboard that the destination port is busy. The RRDY is sent to the source node and causes it to output a frame of data. This frame of data is stored in the switch port's buffer. Then a message is sent to the destination port indicating that the auxiliary buffer of the switch port is holding a frame of data for the destination port. This auxiliary buffer ID is added to the camp list for the destination port. When the destination port becomes available, a message is sent back on the protocol bus indicating that the destination port is now available and naming the backplane channel to use. A connection through the backplane is then established to this channel by the auxiliary buffer connection circuitry and the destination port, and the data in the auxiliary buffer is transmitted. If the switch port has multiple auxiliary buffers, they each have their own IDs and, preferably, each has its own switching circuitry to make a connection to the backplane.
- In this second genus, each auxiliary buffer has circuitry coupled to the return path to recognize RRDYs transmitted back by the destination node and to count them (or store them) and to wait for a connection between the source port and the RRDY counting circuit if the connection is not continuous such as in some cases where multiple buffers are present in each switch port. These stored RRDYs (or self generated in the case of a count only) can be transmitted to the source node in the case of full duplex or mixed with frames from a third node in the case of a dual simplex connection and transmitted to the source node. Each source port also has shared circuitry for each FCAL net which recognizes incoming RRDYs from the source node and counts them or stores them. These source node generate RRDYs can be transmitted to the destination node in the case of full duplex or transmitted to a third node in the case of dual simplex.
- Returning to consideration of the first genus, the normal buffer by buffer accounting and the hold back, handshaking nature of the FCAL loop protocol with large data frames makes this genus of switches possible and also very efficient.
- The FCAL OPN primitive is a small 40 bit quantity which includes a code indicating it is an OPN primitive and includes a destination address, and an optional source address if the OPN is full duplex. Receipt of the OPN starts the process carried out by the switch of finding the destination and causes establishment of the connection or a notification to the source that the connection could not be established before any data frame is ever transmitted to the switch. This lack of transmission of any large data frame before establishment of the connection means that the switching circuits connected to each FCAL loop coupled to the overall switch structure do not need to have buffer memories to store the data while the connection is being made or the fact that a connection is not possible is established. This allows for greatly simplified hardware. This means lower costs and greater density of ports per chip. This cost advantage is a significant improvement over prior art approaches.
- The major subclass of embodiments taught herein uses a plurality of ports for connection to individual FCAL loops, and a crossbar switch which couples the ports together and which can implement any number of separate data transfer channels under control of the ports with the port using the destination address information in the OPN primitives to determine whether or not a connection through the backplane from one port to another is needed. In the preferred species, the ports are integrated circuits with many ports on one chip and a portion of a distributed crossbar switch also integrated on the chip to selectively couple the integrated circuit to one of the backplane data path channels. Each port is essentially a learning bridge front end with an interface to the crossbar switch on the backend.
- Fairness is provided, in the preferred embodiment, by a fairness token which circulates to all the ports and which, when held by a particular port, gives that port “high priority status”. This means that if an OPN comes in to a port with the fairness token in its possession and the destination node is on a remote port, the high priority status of that port means that it can “camp” on the remote port and wait for it to be available and it is guaranteed access to the destination node no matter how busy it is. Since the fairness token circulates, no port will ever be starved from communication with a busy node.
- Different variations or species within the subclass are taught. Distinctions between species within the subclass are based upon: the way the destination node is found; the way in which the first port coupled to the source node signals the second, remote port that there is traffic waiting for one of the NL nodes to which it is coupled; whether the crossbar switch is central or distributed; whether the complete routing table is stored in each port or there is a single separate routing table, or whether there are partial routing tables stored in each port; whether a scoreboard is used or not to determine the status of a remote node; and, if a scoreboard is used, whether it is distributed with a copy in each port or centralized and shared by all ports. All these variations between species and combinations of variations are equivalent to each other even though each has its own peculiar advantages and disadvantages.
- As an example of variations between species within the inventive genus defined above consider the following. Location of the destination node can be by any of several means since the OPN includes the destination address therein. In one embodiment, the destination address from the OPN is use to address a lookup table which outputs data as to which loop the destination node is on and to which switch chip or port coupled to the destination loop the switching connection should be made. This embodiment has the advantage that all the connection information is immediately available. This allows the connection to occur more rapidly. The disadvantage of this species is that the look up table is larger and each port must carry a full copy of the routing table.
- One alternative embodiment uses a destination location process wherein the destination address of the OPN from the source node is used to address a lookup table (hereafter LUT) which only outputs a single bit indicating, in one logic state, that the destination node is “local”, i.e., on the same FCAL network as the source node, or indicating, in the opposite logic state, that the destination node is not on the local loop. If the destination is not local, the destination address is broadcast as a location request to the other switch chips coupled to the other FCAL networks connected to the switch. Each of the other switch chips then checks its local LUT using the destination address to determine if it has the destination node on its loop. The switch chip that has the destination node finds this out from data returned from its local LUT and then sends a message to the switch chip coupled to the loop having the source node telling it to where the connection is to be made and whether the connection can be made, i.e., the loop upon which the destination node is not busy in another conversation and is available for the connection. The advantage of this species is a smaller routing lookup table may be used in each port. The disadvantage is the requirement of more message traffic between chips resulting in slower response.
- An example of an FCAL switch within the genus of the invention is a bufferless switch for coupling to a plurality of FCAL nets and having a crossbar switch and FCAL loop interface port circuits structured to use the OPN and RRDY primitives of the FCAL protocol for hold back flow control to eliminate the need for a buffer with the ports and crossbar switch structured to provide multiple simultaneous loop tenancies.
- One embodiment for a protocol within the genus of protocols which define the rules to set up a connection through an FCAL switch within the genus of the invention between a source node and a destination node and transfer data therebetween is:
- 1) in a source node, arbitrating for and winning control of a first FCAL net and transmitting an OPN primitive thereon, the OPN primitive having a destination address of a destination node therein;
- 2) receiving and latching at a first port of an FCAL switch the OPN primitive from the source node coupled to the first port by the first FCAL net;
- 3) using the destination address in the OPN primitive as a search key to search a routing table to find the location of a destination node having the destination address in the OPN or the ID of a port coupled by an FCAL net to the destination node, or both, and, if the destination node is coupled to the first port, passing the OPN primitive to the destination node via the first port via a local bypass data path coupling an input of the first port to an output of the first port coupled to the first FCAL net, but, if the destination node is coupled to a second port other than the first port, controlling a crossbar switch to establish a data path between the first and second ports and determining if the second port is available, and, if so, sending the OPN primitive to the second port indicating traffic is waiting to be sent to said destination node and latching the OPN in said second port;
- 4) in the second node, arbitrating for control of a second FCAL net coupled to the second port;
- 5) when control of the second FCAL net is won following said arbitration, forwarding the OPN to the destination node;
- 6) receiving an RRDY primitive or a CLS primitive from the destination node in the second port and transmitting the primitive so received to the source node through a connection established across crossbar switch, and through the first port and the first FCAL net; and
- 7) for each RRDY received by the source node, transmitting a frame of data to the destination node through the first FCAL net, the first port, the data path through the crossbar switch, the second port and the second FCAL net without ever storing it in a buffer in the switch, and continuing to pass data frames and primitives between the source and destination nodes, until a CLS primitive is transmitted by either the source node or the destination node, and then closing the data path through the crossbar switch and relinquishing control of the first and second FCAL nets.
- The preferred subclass of the switch utilizes the concepts of the learning bridge taught in the parent application incorporated by reference herein for front end circuitry coupled to the FCAL net with backend circuitry which is coupled to a crossbar switch. The bridging front end uses the destination address in the OPN to decide whether or not to connect the front end circuitry to the back end circuitry. The crossbar switch implements a plurality of completely separate data paths through the switch each of which can couple two port together. The provision of multiple separate data paths through the crossbar switch eliminates any bottlenecks which could occur if a multiplexed data bus were to be substituted for the crossbar switch. It is within the genus of the invention however to substitute a multiplexed bus for the crossbar switch using any form of multiplexing.
- Thus, the switch apparatus genus could be generally described as including multiples species, each comprised of a plurality of half bridges, each with a front end for connnecting to an FCAL loop and a backend coupled to either a crossbar switch or a multplexed bus along with suitable control circuitry to use the destination addresses in OPN primitives to determine whether a connection between two ports through the crossbar switch or multiplexed bus is necessary and, if necessary, for establishing the connection.
- In the preferred embodiment, each half bridge is one port. In the preferred embodiment, the half bridges are implemented as integrated circuits with a multiplicity of half bridges on every chip with each half bridge building its own routing table by a passive learning process. An alternative embodiment uses an active discovery process to build the routing table.
- The switch architecture can be thought of as a multi-port switch with a stack of learning half bridges substituted for each FL_port of a prior art fabric switch, with each half bridge on each layer being coupled to its own local FCAL loop or single NL node. The other side of each half bridge is connected to the high speed crossbar switch in the preferred embodiment so that it can be connected to the other half bridges. The crossbar switch can be though of a stack of separate layers of separate high speed backplane data paths connecting all the half bridges together by way of a switching network between the high speed backplane data path layers. The switching network functions to establish selective connections between layers and can be controlled such that any bridge on any layer can talk to any other bridge on any other layer. This allows multiple concurrent connections across the switch between a plurality of pairs of source nodes on one loop and a plurality of pairs of destination nodes on other loops or source and destination nodes coupled individually to half bridges. The switch architecture allows simultaneous purely local loop tenancies on any FCAL net coupled to any particular half bridge so long as another node on the FCAL net is not involved in a loop tenancy which involves communication across the switch from one port on one FCAL net to another port on another FCAL net.
- Flow control using the OPN primitive only to establish connections across the switch is used to eliminate the need for large amounts of memory. As a result, the switch is capable of operating at a high throughput rate, but neither the half bridges nor the crossbar switches has the amount of memory of an FL_port of a fabric switch that would be required to make the fabric switch capable of operating at the same throughput rate.
- Another significant advantage of the invention is that the nodes on the individual FCAL nets can be conventional NL node designs which already exist. An NL node is a node on an FCAL net which understands and can implement the FCAL flow controlled loop connection protocol between source and destination nodes to transfer data using OPN, RRDY and CLS primitives and large data frames. Because the embodiments of the switches described herein are all compatible with conventional NL nodes, the genus of switches described herein has the advantage that when the network is upgraded, only the switch needs to be upgraded and all the nodes can remain the same thereby saving substantial expense to the customer.
- Dual simplex capability is also taught to improve the throughput of any network of FCAL nets coupled by any type of switch. Dual simplex capability allows a source node on a first FCAL net which is transmitting data on a front channel connection to a destination node on a second FCAL net through a switch connection to simultaneously receive data via a back channel connection from a third node on a third FCAL net. This is advantageous to improve throughput because in many cases, destination nodes to which data has been transmitted have no data to transmit back to the source node that sent them the data while other nodes do have data to be transmitted to the source node.
- Dual simplex capability is accomplished in all species within the genus of the invention to further increase throughput. It is accomplished by three basic steps, illustrated in FIG. 15:
- 1) establishing a front channel half duplex data path between a source node and destination node on different FCAL nets (step350) and stripping and storing or counting any buffer credit RRDY primitives output by the source node and not transmitting them to the destination node (step 352);
- 2) establishing a back channel data path between a third node and said source node but not transmitting to said source node any OPN primitive emitted by said third node (step354), and transmitting a number of RRDYs either equal to the number of RRDYs output by said source node or the number of RRDYs needed by said third node to send all the data it has to said source node before closing said back channel connection (step 356), transmission of said RRDYs being one at a time—any excess RRDYs not used by the third node are saved for use by another third node in a subsequent dual simplex back channel connection; and
- 3) receiving any RRDYs transmitted by said destination node and mixing them in with data frames and/or primitives transmitted on the back channel by the third node so as to exercise flow control on transmissions of data frames from the source node to said destination node (step358).
- FIG. 1 is a drawing of one example of an FCAL switched architecture according to the teachings of the invention.
- FIG. 2 is a drawing of another example of an FCAL switched architecture according to the teachings of the invention having multiple subloops within some of the FCAL coupled to the switch.
- FIG. 3 is a block diagram of the preferred switched FCAL architecture.
- FIG. 4 is a flow chart of the processing which occurs for a purely local transaction.
- FIG. 4 is a block diagram of the general preferred architecture of a switch to couple a plurality of FCAL nets to provide spatial reuse.
- FIG. 5 is a block diagram of the specific preferred “switch slice” architecture of a switch to couple a plurality of FCAL nets to provide spatial reuse with multiple port circuits and a portion of the crossbar switch integrated on each switch chip.
- FIGS. 6A through 6C are a flow diagram of a routing algorithm for general switch mode operation (non dual simplex).
- FIG. 7 is a block diagram of the preferred architecture of each switch chip in the FCAL switch system.
- FIG. 8 is a diagram of an FCAL switch with two switch chips configured to run in hub mode.
- FIG. 9 is a diagram of an FCAL switch system with two switch chips configured to run in switch mode and illustrating loop-local, chip-local and remote port simultaneous loop tenancies.
- FIG. 10 is a block diagram of the multiplexer structure in each switch chip that allows port bypass mode, parallel loopback mode and serial loopback mode to be implemented.
- FIG. 14 is a table describing and naming each state in the loop port state machines of each port of each switch chip.
- FIG. 12 is a table of the source port fill word generation for various input words and states.
- FIG. 13 is a table of the destination port fill word generation for various input words and states.
- FIGS. 14A through 14E are diagrams of the five different message formats on the protocol bus.
- FIG. 15 is a generic flow diagram illustrating the minimum basic steps each species in the genus of the invention would have to carry out to implement dual simplex operation.
- FIGS. 16A through 16D are a flow chart of the specific steps carried out by the preferred embodiment to carry out dual simplex communications.
- The published Fibre Channel Arbitrated Loop standards memorialized in the following ANSI standards are hereby incorporated by reference: X3.230-1994 describing the physical and signalling interface; X3.297-1996 describing the physical and signalling protocol; X3.272-1996 describing the general FCAL protocol and TR-20-199X, T11 Project 1235-DT, Fibre Channel Fabric Loop Attachment (FC-FLA).
- Referring to FIG. 1, there is shown one embodiment of a switched FCAL architecture.
FCAL switch 10 is coupled to four FCAL networks (hereafter sometimes referred to as FCAL nets) 12, 14, 16 and 18 in this example. Each FCAL net can have one or more NL nodes thereon. Each of the four FCAL networks is coupled to a plurality of NL nodes which have conventional structure and which can carry out FCAL arbitration, data transfer and flow control operations on the FCAL networks. Each node is assigned an address from one of the 127 possible FCAL addresses. - In FIG. 1, each node is given a number symbolizing its address designated in the figure by N and a number inside the circle symbolizing the node.
- The function of the
switch 10 is to increase total throughput of the system by allowing concurrent conversations to be occurring between pairs of NL nodes, and by doing so in a manner that is not limited by any restriction against “crossing conversations” in the switch itself. A new standard for FCAL topology proposed by IBM involves counterrotating, separate FCAL rings with nodes coupled to both counterrotating rings. This allows concurrent conversations to occur, but the conversations cannot “cross”, i.e., it is illegal in this protocol for both conversations to require the same segment of an FCAL as part of the data path for the conversation. “Conversation”, as that term is used herein, means a data transfer between two different nodes. The function of theswitch 10 according to the teachings of the invention is to allow as many concurrent conversations as possible except that no two source nodes can be talking to different destination nodes on the same FCAL network. In other words, each ofFCAL networks switch 10. This is done by establishing “virtual channels” for each conversation through the switch using separate data paths (or multiplexing techniques in some embodiments). The physical configuration of theswitch 10 is not currently believed to be important so long as it uses the destination address in each OPN from a source node to control setting up a separate data path through the switch for transfer of data between that source node and a destination node and uses flow control primitives of the FCAL protocol to control the flow of data such that the switch does not need to have a buffer memory big enough to hold an entire FCAL frame. - The fact that only 127 addresses are possible is an inherent limitation of the FCAL protocol but it is also an advantage in the following way. Because there are only 127 possible addresses, no microprocessor is needed in the switch. With a manageable address space, the location of the destination node can be determined by looking up the destination addresses using a state machine and a lookup table in each switch control circuit coupled to an FCAL network. The lack of a microprocessor both makes the switch faster and cheaper.
- In the topology of FIG. 1, each
FCAL network FCAL networks - One way that the FCAL switched architecture according to the teachings of the invention can increase throughput is to allow multiple local conversations to occur on each FCAL network through use of bridges. An example of a topology that can take advantage of this feature is shown in FIG. 2. There, switch10 is coupled to
FCAL networks FCAL network 12 is divided into twoFCAL subnetworks FCAL bridge 22, andFCAL network 14 is divided into twoFCAL subnetworks FCAL bridge 26. Likewise,FCAL network 16 is divided into threeFCAL subnetworks FCAL bridges - FIG. 3 is a high level block diagram of the internals of the
FCAL switch 10 for the preferred embodiment using acrossbar switch 44 to make the switched electrical connections betweenFCAL networks FCAL networks switch control circuits switch control circuits - The function of the
switch control circuits crossbar switch 44, to collectively locate the destination nodes when OPNs are received, and to send appropriate control signals to the crossbar switch once the destination node has been located so as to connect the appropriate FCAL networks together to complete the conversation. - The
crossbar switch 44 has 4 inputs and 4 outputs with 1 input and 1 output for each FCAL. The crossbar switch serves to make a data path through the appropriate switch control circuit to the input and output of one FCAL having the source node thereon to the output and input, respectively of another FCAL having the destination node thereon through the appropriate switch control circuit so as to provide a channel through which the conversation between the source node and the destination node may proceed. The crossbar switch must be able to simultaneously connect the input and output of another FCAL having another source node thereon to the output and input, respectively of yet another FCAL having another destination node thereon to provide a data path or channel for a second concurrent conversation. This concept is extended for as many pairs of FCAL as are connected to the switch. The particular connections that are made are controlled by enable signals oncontrol buses - The
switch control circuits crossbar switch 44 can be omitted and a TDMA bus substituted with timeslot assignments taking the place of assignments of particular backplane channels through the crossbar switch and messages on the protocol bus updating all switch ports with information about which timeslots are in use and which timeslots are available. - Referring to FIG. 4, there is shown a block diagram of the general architecture of the preferred Fibre Channel switch. The switch is comprised of a
crossbar switch 100 coupled to a plurality of learning half bridges such as are represented typically byblocks block 108 or an FCAL net such as is represented byNL ports links single node 108 is an FCAL net using a Fibre Channel protocol as those terms are used in the claims. - Each learning half bridge in the switch can have a similar front end structure and mode of operation as that described in the parent application Ser. No. 08/786,891, filed Jan. 23, 1997 which is incorporated by reference herein, but preferably has the structure described below in FIG. 7. The “front end” structure refers to the circuitry that is coupled to the port and any Fibre Channel link connected thereto. Each learning bridge port circuit (hereafter sometimes referred to as a port) is coupled to a 50
Mhz 24bit protocol bus 121.Link 123 represents this connection betweenport 106 and the protocol bus. The protocol bus is where each port posts its transactions indicating its local FCAL net is busy or has become available so as to update that port's status information in a local copy of scoreboard table 125 in memory. In the preferred embodiment, each port maintains a synchronized local copy of the scoreboard table and the contents are written to the scoreboard by learning from messages posted on the protocol bus. “Synchronized” means all copies of the scoreboard have the same information at all times to avoid “fatal embrace” scenarios (fatal embraces are discussed in the parent bridge case). - In the alternative embodiment of FIG. 4, the
scoreboard 125 and routing table 127 are shown as central shared circuits, but in the preferred embodiment of FIG. 5, everyport circuit - Each learning half bridge includes a streaming back end which drives a bidirectional port such as
ports - In sharp contrast, in the connectionless fabric switches of the prior art for both FCAL nets and other protocols, the conventional wisdom is that the essence of the problem is in buffer management. It is actually possible in the prior art fabric switches in the FCAL net environment to drop frames because of conjection related to traffic problems. When a frame is dropped, a complex error recovery protocol needs to be executed in the nodes (node can mean computer, disk drive or other computing machine coupled to the network) involved to retransmit the dropped frame, or the entire I/O transaction. The error recovery protocol is costly in-terms of overhead, and many I/O applications on the nodes are not designed to gracefully handle dropped frames thereby creating the possibility of errors and increasing the complexity of the nodes in requiring error recovery protocol software to exist in the node. The acknowledged, connectionless class of service in Fibre Channel (Class 2) does not eliminate or reduce the frequency of dropped frames. The only advantage is that
class 2 has negative acknowledgements to the source node from the fabric or destination node if/when any frames are dropped. The only advantage is that this negative acknowledgement may provide more timely notification of dropped or reected frames. It does not improve the intrinsic reliability of FC networks. - In the invention, the hold back flow control which is part of the FCAL protocol is used to advantage to eliminate the need for buffer memory in the switch. Thus, in the invention, frames are not held in buffer memory, so they cannot ever be dropped because of congestion. The “hold back flow control” used by the invention prevents data from ever being transmitted from the source until the switch is ready to stream it to its destination. Therefore, there is no need for any complicated error recovery protocols in the switch or in the nodes and no need for massive amounts of memory in the switch. This is only possible in the Fibre Channel protocol where the possibility of using hold back flow control exists by virtue of the use of primitives and buffer by buffer accounting. There is no low level flow control in ATM or 1 GB Ethernet protocols. Those protocols have X-on and X-off flow control on a higher level of the ISO level. This X-on and X-off flow control is “embedded” in the data characters, in contrast to Fibre Channel where buffer-to-buffer flow control is external to any data or frames. In FCAL, the OPN primitive signals when a source node has data to send, and the destination node then signals with a RRDY primitive sent back to the source saying it has reserved space to receive a frame. One and only one frame is then sent and no other frames are sent until the source receives another RRDY primitive from the destination node. This use of primitives and reserved space and buffer by buffer accounting is the meaning of hold back flow control which is used in the invention.
- The lack of buffer memory in the half bridges makes them highly compact and susceptible to full integration since memory is a large consumer of die area. The ability to integrate multiple half bridges on a single integrated circuit die reduces the cost per port to a substantially lower cost than for a corresponding number of FL_ports.
- Prior art switch designs typically had a crossbar switch chip coupled to a plurality of switch module chips each of which had a substantial amount of the die area consumed by buffer memory cells. Thus two separate chip designs were necessary to implement a switch. In the architecture of the invention since part of the crossbar switch and the port circuitry for several ports are on one IC die, only one chip design is necessary to implement a switch. The various portions of the distributed crossbar switch on different chips, when coupled together, form one complete crossbar switch. This crossbar switch has 14 backplane channels, but they are not all available because each switch port chip also includes access circuitry to the backplane channels. If only two switch port chips having the architecture of FIG. 7 are coupled together, the amount of backplane access circuitry present is not enough to access all 14 backplane channels. The number of backplane channels that can be accessed with the available access circuitry defines a concept of “available bandwidth”. As the number of switch port chips coupled together grows, the amount of available backplane access circuitry grows so that the number of backplane channels available grows, i.e., the available bandwidth grows which is as it should be because traffice volumen is increasing with an increasing number of ports. In other words, each switch port chip is a network slice and a network can be fabricated with as many ports as needed, and the crossbar switch will automatically grow in available bandwidth in proportion to the number of ports adequately to handle the increased traffic.
- FIG. 5 illustrates the actual architecture of the preferred species of the separate channels backplane subclass of switches. Each
block backplane data path 130 comprised of a plurality of channels through the distributed crossbar switch carries data from port to port. Each channel has a conductor in both directions. Each channel is a separate one gigabit per second data path which is selectively coupled by the crossbar switch to the two ports involved in a loop tenancy and is not shared by any other ports at that time. In one example of an architecture in accordance with the preferred embodiment, there are 14 switchable channels for a total of 28 Gbits/sec of bandwidth. The function of thebackplane data path 130 combined with the crossbar switch is to carry multiple conversations of data between ports simultaneously. - Since each of the switch chips124, 126 and 128 contains a plurality of independent ports, spatial reuse and concurrency is achieved in the architecture of the invention in three ways: first, any purely local conversations between source and destination nodes on the same FCAL net can simultaneously occur on all FCAL nets without consuming either switch chip or backplane bandwidth; second, any conversations between different FCAL nets coupled to the same switch chip can occur purely within each switch chip without consuming any bandwidth on the backplane bus; and, third, the multiple backplane data paths allow multiple simultaneous conversations between nodes on FCAL nets coupled to different switch chips. For a first example, with 36 ports coupled to 36 FCAL nets, a peak achievable bandwidth of 72 Gbits/sec is achievable with no backplane channel utilization representing 36 simultaneous local full-duplex conversations. The peak bandwidth through the switch is equal to 2 Gbits/sec per backplane channel (1 GB/sec send and 1 GB/sec receive), plus an additional 2 Gbits/sec for each purely local conversation that can be simultaneously serviced. Thus, with 14 backplane channels all in use and 36 ports coupled to 36 FCAL nets with all ports not coupled to one of the 14 backplane channels having local conversations ongoing, the total traffic volume is 28 GB/sec through the switch plus 22×2 GB/sec equalling 44 GB/sec for a total of 28+44=72 GB/sec.
- In an exemplary embodiment of an FCAL switch using the teachings of the invention, each switch chip has 3 ports and there are 12 switch chips for a total of 36 ports in this embodiment. Each switch chip supports 14 backplane channels such that up to 14 remote full-duplex conversations through the
switch 136 can be supported by 28 ports coupled to the 14 backplane data paths plus 8 purely local full-duplex conversations between the remaining 8 ports for an aggregate peak bandwidth of 44 Gbits/sec. Port and backplane contention will reduce the total bandwidth below this peak, but average throughput and arbitration latency of a switched system will still be faster than an arbitrated FCAL net of the same size. Spatial reuse provided by a switch allows applications which make use of concurrent conversations to use FCAL local loops and a switch to overcome the one loop tenancy at a time limitation of pure Fibre Channel Arbitrated Loop networks without a switch. - Each switch chip is coupled to a fairness
token bus 99, which, in the preferred embodiment, takes the form of a two wire bus. A fairness token circulates to all ports on this bus enabling a “round robin” fairness algorithm. Each port has circuitry to receive the fairness token, hold it for a short time and forward it to the next port so that the token reaches all ports eventually. Each port has a priority level assigned to it that is used in arbitration within the switch of multiple access requests to a busy destination node. When the fairness token is in the possession of a port, that port has the highest priority level and is guaranteed access. When a port has the highest priority level, it can “camp” on a busy remote port, and be guaranteed that it will be given access when the port is available. When access has been granted, the token is forwarded. This prevents starvation of any port from communication with a busy node. - In the preferred embodiment,
data path 130 is comprised of metallic data paths on the printed circuit board on which the port chips are mounted couples the outputs of each crossbar switch portion of one of the port chips to the input of the crossbar switch portion of another port chip. Each bridge portion has three inputs and three outputs (one input and output for each of the three half bridges on each chip) for FCAL net primitives and frame data. Each pair of one input and one output is called a port and can be coupled to a single NL node or an FCAL net. - Note that the distributed nature of the crossbar switch and the full integration of the ports with the crossbar switch makes the architecture of the switch modular and easily expandable. That is, the architecture represents a sliceable architecture which can be built into as large a switch with as many ports as is necessary limited only by the maximum number of permissible addresses in the FCAL address space of 128 nodes. Integration of the ports with a crossbar switch slice on the same chip allows switches to be built with as few as two switch chips or many more because the crossbar switch is scaleable and because each chip can be coupled by its portion of the crossbar switch to any one of the plurality of separate backplane channels. Prior art fabric switches had separate, nonscaleable circuits for the crossbar switch. This meant that the crossbar switch had to be built as complex as was necessary to handle up to the maximum number of ports. If fewer than the maximum number of ports were used, a large part of the prior art crossbar switch capacity was wasted. In contrast, in the invention, because of the full integration of all necessary circuitry onto one chip including a portion of the crossbar switch, the crossbar switch is scaleable, and all sizes of switches are easily constructed and quite affordable because of the inexpensive, fully integrated construction with no buffer memory and no complicated error recovery protocols.
- Dual Simplex
- FCAL NL nodes are capable of duplex communications in that they can send data at the same time they are receiving data. The problem that conventional FCAL nets and fabric FL port based switches fail to address is the fact that typically the destination node in more highly populated FCAL nets is less likely to have data for the source node but other nodes may have data for the source node which they cannot send since the source node is tied up in a conversation with the destination node. Thus, there is a waste of bandwidth. Typically, node adapter cards that interface a computer or disk drive to the FCAL net cannot re-shuffle their transmit queues in order to find a frame destined for the current source node and move it to the top of the transmit queue. Thus, head end blocking usually occurs and causes a full duplex connection to be effectively simplex. In a 100 mbyte/sec link for example, NL nodes can simultaneously burst out at 100 mbyte/sec while they are simultaneously bursting in at the same rate. If the destination node has no data to send to the source node, the 100 mbyte/sec of burst in bandwidth of the source node is wasted in conventional fabric switches with FL ports.
- In conventional FCAL nets, the protocol requires that nodes must must reserve all resources required for a duplex conversation even in cases where there is only traffic in one direction. This means, in the context of FIG. 5,
node 101 can be sending data tonode 103 butnode 103 is required by the rules of the protocol to be sending data only tonode 101 during the same loop tenancy. This is true even though it may have no data to send tonode 101 and even though it may have data to send tonode 105. Likewise, if the switch of FIG. 5 followed the normal FCAL protocol, ifnode 138 had frames to send tonode 103,node 103 would be restricted to sending data only tonode 138 even ifnode 103 had no data fornode 138 but did have data fornode 140. - This waste of bandwidth is remedied by the provision of dual simplex conversations across the switch of the invention. The ports and crossbar switch of the invention allow dual simplex conversations across the switch but not within any local loop coupled to a port. Simply put, dual simplex capability allows nodes other than the destination node to send data frames to the source node while that source node is sending data to its destination node. In the example of FIG. 5, a dual simplex connection for two separate one-way conversations could occur as follows. Suppose,
node 138 has data to send tonode 103 butnode 103 does not have any data fornode 138. Suppose also,node 144 has data fornode 138. With the dual simplex capability of the invention,node 138 can send its data tonode 103 while simultaneously receiving data fromnode 144. - Dual simplex capability is accomplished in all species within the genus of the invention by three basic steps, illustrated in FIG. 15:
- 1) establishing a front channel half duplex data path between a source node and destination node on different FCAL nets (step350) and stripping and storing or counting any buffer credit RRDY primitives output by the source node and not transmitting them to the destination node (step 352);
- 2) establishing a back channel data path between a third node and said source node if said source node is dual simplex capable but not transmitting to said source node any OPN primitive emitted by said third node (step354), and transmitting a number of RRDYs either equal to the number of RRDYs output by said source node or the number of RRDYs needed by said third node to send all the data it has to said source node before closing said back channel connection (step 356)—transmission of said RRDYs being one at a time—any excess RRDYs not used by the third node are saved for use by another third node in a subsequent dual simplex back channel connection; and
- 3) receiving any RRDYs transmitted by said destination node and mixing them in with data frames and/or primitives transmitted on the back channel by the third node so as to exercise flow control on transmissions of data frames from the source node to said destination node (step358).
- In the preferred species of switch within the genus, the following steps are carried out to implement dual simplex data exchanges:
- 1) in a port of the switch coupled to an FCAL net, receiving a full duplex OPN(Dest, Src) from a source node designating a destination node address, Dest, and a source node address, Src, and converting the full duplexformat OPN(Dest, Src) to a simplex or half duplex format OPN(Dest, Dest) and establishing a “front channel” connection through the crossbar switch to the destination node (in the preferred embodiment, conversion from full to half occurs if and only if a configuration bit is set in each port to allow dual simplex, and, if set to allow it, always converts all full duplex OPNs to half duplex OPNs even if no dual simplex connections are expected—in alternative embodiments, conversion from full to half duplex always occurs and is not configurable and in other embodiments, dual simplex is never allowed);
- 2) storing at least the source node address in the port of the switch coupled to the source node, hereafter referred to as the source port;
- 3) stripping buffer credit RRDYs output by the source node and not transmitting the RRDYs output by the source node to the destination node of the front channel connection, and either storing or counting the RRDYs output by the source node and making them available to a third node to send data to the source node either by transmitting stored RRDYs output by the source node one at a time to the third node or by conveying the number of RRDYs output by the source node to a third port coupled to the third node and synthesizing in the third node a number of RRDYs equal to the value of the count and sending the RRDYs to the third node one at a time (the preferred embodiment does not store the RRDYs—it just counts them and regenerates them in the source port when needed for transmission to a third node);
- 4) updating status data in a “scoreboard” memory of each port to indicate which busy ports are coupled to source nodes of front channel connections and thus are available to receive frames in dual simplex communication from third nodes—the scoreboard memory is a memory that stores status data such as whether or not a port is busy, and, if busy, whether it is coupled to the source node of the conversation it is engaged in and is thus open to receive data from a third node in a dual simplex communication;
- 5) establishing a “back channel” connection through the crossbar switch from the third node to the source node and transmitting an OPN from the third node to the source switch port—then the stored source node address in the source port is compared to the destination node address of the OPN transmitted from the third node and allowing dual simplex communication to proceed on the back channel if the addresses match, but blocking dual simplex communication with this particular third node if the addresses do not match by sending a CLS primitive to the third node;
- 6) in the event dual simplex communication is allowed, deleting the OPN from the third node and never transmitting it to the source node, and releasing stored RRDYs to the third node (either one at a time or all at once) thereby allowing the third node to start sending data frames to the source node; and
- 7) thereafter data frames are transmitted by the third node to the source port with one data frame transmitted in response to each RRDY received by the third node—these data frames are mixed with RRDYs received from the destination node via the front channel connection—the combined data frames and RRDYs are transmitted to the source node via the back channel connection.
- The “back channel” is the data path going into the source node along with a connection through the switch ports and backplane if necessary to couple the third node to the source node and is the channel used by a third node to send dual simplex data frames into the source node.
- The format conversion mentioned above converts the OPN(Dest, Src) received from the
source node 138 into an OPN(Dest, Dest). This conversion occurs as the OPN is propagated through the source port before it is sent to the remote port coupled to the destination node. Conversion of the OPN primitive format to OPN(Dest, Dest) and taking away the buffer credits from the destination node converts the normal full duplex loop tenancy to a half duplex or simplex loop tenancy where data flows in only one direction from the source node to the destination node and the destination node cannot send any frames back to the source. - Borrowing the buffer credit transmitted by the source node and giving it to another node that has data to send to the source node is important to dual simplex capability. In the specific example being considered, it means that any RRDY primitives output by
source node 138 that would otherwise givedestination node 103 one or more buffers of credit for return data are, instead, stripped by the source port before the OPN is transmitted to the remote port, and stored so that they may be given tonode 144 after a simplex back channel connection is established. Specifically, supposesource node 138 transmitted OPN(103, 138)RRDY RRDY. Port 126 would convert this to OPN(103, 103) and transmit it to switchport 128 when the connection through the backplane betweenswitch ports Port 126 would latch the two RRDYs or increment a counter of buffer credits to a count of two and give them tonode 144 one by one after a back channel connection was established betweennode 144 andnode 138. - Swallowing or deleting the back channel OPN from the third node in the source port is important to dual simplex because it prevents the source node from receiving it and becoming confused. Because of the structure of the FCAL protocol, it is a protocol violation if a node receives an OPN, and that node has already established a previous connection.
- However, when a node has opened another node, it is expecting possible data frames to be sent back to it from the destination node on the back channel (the part of the loop not being used for outgoing data from the source to the destination). Thus, if a node other than the destination node has frames to send to the source node, the following things happen. First, the third node sends an OPN. The port coupled to the third node uses the destination address in the OPN to look up the ID of the port coupled to the destination node. This search results in output from the routing table of the ID of the source port coupled to the source node in the original forward channel transmission. This ID is then used to search the scoreboard memory to determine the status of the source port. The source port sent a message to the scoreboard memory on the protocol bus updating the status entry in the scoreboard memory for the source port to busy when the source port established the front channel connection. In one alternative embodiment, this busy status will be found when the scoreboard is consulted, but that will not deter the third port from posting a connection request message on the protocol bus requesting connection to the source port. The source port will determine if it has any stored buffer credit and grant the request if it does by posting a reply message on the protocol bus naming the backplane channel to use. The third port and the source port then both connect to the named backplane channel.
- There are several alternative embodiments for establishing the back channel simplex connection through the backplane. One involves updating all the scoreboards of all ports with information as to which source node address is coupled to any port which is indicated in the scoreboard as having a busy status and is thus available for dual simplex. In this alternative embodiment, the source port posts a message to the protocol bus to update all scoreboards in every port to indicate that although it is busy, it is coupled to the source node of the loop tenancy and is thus available to receive data in a dual simplex mode. In this alternative embodiment, the third port checks its scoreboard, and if it determines that its destination node has the same address as the source node coupled to the source port, it then sends a connection request message. If it determines from the scoreboard data that the source port is not dual simplex capable, it does not send a connection request message.
- In the preferred embodiment each switch port which utilizes dual simplex is only coupled to one node, because the switch ports are not expensive. In this preferred embodiment, the scoreboards are not updated with data indicating the address of the node connected to the source port so as save memory space in the scoreboards and traffic on the protocol bus. In the preferred embodiment, the third node simply transmits a connect request on the protocol bus naming the source port. The source port then determines if it is dual simplex capable by checking its own scoreboard for data indicating whether it is dual simplex capable and determines if its camp list is full. If it dual simplex capable and its camp list is not full, it grants all connection requests. It then picks a backplane channel for the back channel connection and sends a response message on the protocol bus to the third node. Both the third node and the source node then establish a connection on the identified channel and the third node sends its OPN. The destination address in the OPN is then compared by the source port to the address of the source node using the latched OPN received from the source node.
- If there is no match, the source port generates a CLS and sends it to the third port. If there is a match, dual simplex mode is allowed, the OPN from the third port is quashed, and the stored RRDYs are sent to the third port from the source port, one RRDY at a time up to the number of RRDYs stored. In some alternative embodiments, the RRDYs are not actually stored but are counted and the count is maintained. This starts the transmission of data frames from the third node. The arrival of a data frame from the third node triggers release of another RRDY from the source port if another RRDY is available at the source port for release. These data frames are received by the source port and transmitted on the back channel to the source node. Any intervening nodes pass the data frames through because they, do not control the loop. Any subsequent RRDYs output by the source node are intercepted by the source port and transmitted on the backplane channel to the third port to cause the third node to transmit a data frame for each RRDY so intercepted. When a CLS is received from the third node, any remaining stored RRDYs are preserved for use as buffer credit for the next third node that wishes to send data to the source node. The job of managing buffer credit falls to the state machine in every port in the preferred embodiment.
- Another embodiment for the source port to determine if it is dual simplex capable is to send post a message on the protocol bus instructing any port that has an OPN send the destination address of the OPN to the source port for comparison to the source node address. If there is a match, a reply message is posted directing the port to use a specified backplane channel and both the third port and the source port connect to that channel. The transaction then proceeds as above.
- The dual simplex process essentially tricks the link layer of the software of the source node into thinking the incoming frames are from the destination node, when they are actually from the third node. Since the frames internally contain all the information needed to get the data therein to the right place in the source node, no harm is done because the frames pass through the link layer and the upper layers of software read the frames and use them properly. However if an OPN from the third node were to arrive on the back channel, the link layer of conventional NL nodes becomes confused because it knows the source node just opened some other node and is not supposed to be receiving any OPNs until the current loop tenancy is terminated.
- The source port also mixes these frames of data from the third node in with RRDY primitives transmitted from the destination node of the original loop tenancy on the FCAL net back channel. Each time the source node receives an RRDY from the destination node, it outputs another frame of data to its destination node. The mixing in of RRDYs from the destination node with the frames of data from the third node on the FCAL net backchannel causes the source node to continue outputting data frames bound for the destination node.
- Closing a dual simplex connection properly to avoid deadlock and sequence errors is important. The state machine of any port coupled to a source node and facilitating a dual simplex transaction (elsewhere herein sometimes referred to as a dual simplex port or source port) must insure that when a CLS is output by the source node that the CLS is not forwarded to the destination node until the third node has finished transmissions on the back channel and output its own CLS. Further, the state machine of any port coupled to a source node and facilitating a dual simplex transaction must not wait for a CLS in the case where access to the source node is denied to a third node because of the lack of any RRDYs transmitted by the source node to avoid possible deadlock. Thus, the state machine in a dual simplex port must therefore have the following behaviors as illustrated in the following discussion of four possible dual simplex close scenarios.
- 1) A CLS is received from the source port—the CLS is replicated by the source port and sent to both the third port and the destination port. The third port transmits the CLS to the third node which handshakes with its own CLS which is returned to the source port. The source port deletes the CLS from the third node but remembers that it has arrived and releases the back channel connection. The CLS reaches the destination port and the destination node. The destination node handshakes by emitting its own CLS which is transmitted back to the source port and to the source node which closes. The source port drops the front channel connection.
- 2) A CLS is received from the third node—the source port deletes the CLS so that it does not get forwarded to the source node and sends a CLS generated in the source port back to the third port, and then drops the back channel connection to the third port. The third port forwards the CLS to the third node. Any new third port can then initiate a new dual simplex connection.
- 3) Destination node transmits a CLS—the CLS is received at the source port and held by the source port. A copy of the CLS is transmitted to the third port which transmits it to the third node. The third node closes under normal FCAL close protocol and handshakes by transmitting a CLS to the source port. The source port transmits the CLS to the source node which closes under normal FCAL close protocol rules and handshakes by transmitting a CLS to the source port. That CLS is forwarded by the source port to the destination port which forwards it to the destination node. The source port then drops both the front and back channel connections simultaneously.
- 4) Destination node transmits a CLS—the CLS is received at the source port and held by the source port. A copy of the CLS is transmitted to the third port which transmits it to the third node. The source node closes under normal FCAL close protocol and handshakes by transmitting a CLS to the source port. The source port holds the CLS from the source node until a CLS is received from the third node. Upon receipt of a CLS from the third node, a CLS generated in the source port is simultaneously transmitted to the destination port and the source node. The source port then drops both the front and back channel connections simultaneously.
- Specific Dual Simplex Example
- As a specific example of dual simplex in the context of FIG. 5 using a scoreboard which indicates dual simplex capability, refer to FIGS. 16A to16D which are a flowchart of the processing carried out by the ports to implement dual simplex communication. In this example, suppose
node 138 want to send data tonode 101. Suppose also thatnode 144 wants to send data tonode 138.Node 138 generates an OPN(101, 138), RRDY, RRDY and transmits these three primitives to port 126 (step 360).Port 126 converts the OPN to a simplex OPN(101, 101) and stores the original OPN including both the source and destination addresses of the OPN and stores the two RRDYs (steps 362 and 364).Port 126 looks updestination address 101 in the routing table and finds it is connected to port 128 (step 366). The scoreboard table is consulted, andport 128 is found to be available (step 368).Port 126 posts a message on theprotocol bus 121 requestingport 128 to initiate arbitration for its local loop and pick a backplane channel (step 368).Port 128 wins control of its loop and sends a reply message naming thebackplane channel 1 for use (step 370).Ports Port 126 forwards the OPN(101, 101) toport 128 as soon asnode 128 is available and it passes straight throughport 128 without delay to node 101 (step 374). The two RRDY primitives of buffer credit transmitted bynode 138 and intended fornode 101 are stripped off the transmission tonode 101 byport 126 and maintained as a count in the source port for award by regeneration and transmission to another node that wants to ship frames tonode 138.Node 101 replies with an RRDY (step 376)., This RRDY is transmitted back onbackplane channel 1 toport 126 where, as described below, it is mixed in with data frames from a third node (node 144) that is transmitting data frames in dual simplex mode tonode 138 so as to keep thesource node 138 outputting new frames to thedestination node 101. - In the embodiment considered here,
port 126 posts a message to the protocol bus to update all scoreboards that it is busy but is available for dual simplex connections. This message can be based upon the fact either that the source node knows by watching traffic or comparing source node addresses on its local FCAL net to the AL-PS value in the original OPN, that it is connected to a source node of the front channel and is capable receiving dual simplex transmissions, or its configuration bit indicates dual simplex connections are allowed. This message on the protocol bus would would result in update of all scoreboards (step 380).Node 114 then arbitrates for and wins control of its FCAL net and generates an OPN(138, 144).Port 124 receives this OPN, stores it (and converts it to half duplex in the preferred embodiment) and uses thedestination node address 144 to search the routing table (step 384). This returns the ID ofport 126. This ID is used byport 124 to search its scoreboard table.Port 124 findsport 126 in its routing table, finding from its scoreboard thatport 126 is busy but dual simplex capable (step 386) and posting a connection request onprotocol bus 121 requesting a connection to source port 126 (step 388). This would result in a connect response reply message fromport 126 granting the request and namingbackplane channel 2 for use (step 390). Bothports port 124 would send its OPN(138, 144) to port 126 (step 394) which would causeport 126 to compare thedestination address 138 to the source node address (step 396), find a match, quash the OPN and forward one RRDY toport 124 via channel 2 (step 400). The backchannel transaction would proceed until buffer credit ran out, or third node had no more data frames to send or a CLS was sent by eithernode 138 or 144 (step 402). - In the preferred embodiment,
port 124 would simply post a connection requests which would automatically be granted byport 126 with a reply message sayinguse backplane channel 2.Ports backplane channel 2, andport 124 would send its OPN(138, 144) toport 126.Port 126 would compare the source address it latched from the original OPN, which is 138, to the destination address of the OPN received fromnode 124, which is also 138, and find a match.Port 126 would quash the OPN(138, 144) and transmit one RRDY back toport 124 which would reachnode 144 and result in transmission of one frame of data. That frame of data would pass throughbackplane channel 2,port 126 and the back channel path and reachnode 138.Port 126 would then send the remaining RRDY toport 124 which would result in another frame of data being transmitted. Any further RRDYs transmitted bynode 138 would be latched or counted and sent toport 124 in the normal course of flow control, or ifnode 144 sent a CLS, the RRDYs stored byport 126 would be saved for grant to another third node until such time as the original loop tenancy was terminated with a CLS from either the source node or destination node. - In alternative embodiments, the
port 126 can determine whether it is capable of dual simplex by a sending a message to port 124 asking for the destination address from the OPN (138, 144) and then compare this destination address to the latched source address from the original OPN(101, 138). If there is a match, sending a reply message saying, “Use backplane channel X and send me your OPN” whereupon the transaction proceeds as defined above. If there is no match, generating a CLS and sending it to the third port or sending a message that causes the third port to generate a CLS and send it to the third node. - Returning to the main example,
port 126 mixes RRDYs received fromnode 101 on the front channel connection with data frames received fromnode 144 and sends the combined data stream to the source node over the back channel of the FCAL net coupled to the source port (step 404). This keepssource node 138 outputting data frames todestination node 101. - There are three scenarios for closing the dual simplex data paths. An example of each will be discussed in the next three paragraphs.
- Suppose
source node 138 issues a CLS (step 406). In that case,source port 126 duplicates the CLS and forwards it todestination port 128 andthird port 124 simultaneously (step 408). Thethird node 144 replies with its own CLS which is forwarded to port 126 (step 410).Port 126 discards the CLS received fromthird node 144 but notes that it has arrived and bothports destination node 101, it replies with its own CLS back tosource node 138, andports - Now suppose
third node 144 issues a CLS (step 414). In this case, the CLS is transmitted to sourceport 126 which deletes the CLS (it is not sent to thesource node 138—step 416), andports - Finally, suppose
destination node 101 issues a CLS (step 420).Source port 126 receives the CLS and holds it temporarily and does not send it to source node 138 (step 422). A copy of the CLS is sent tothird port 124 and the third node (step 424). The third node replies with its own CLS which is received by the source port and sent to the source node (step 424). The source node replies with a CLS which is forwarded to the destination node (step 426). The source port and the destination and third ports then drop the front channel and back channel connections (step 428). - Dual simplex mode allows many different third nodes to deliver frames to the source node during its “conversation” (loop tenancy) with the original destination node. Dual simplex almost doubles throughput of the switch.
- The Process of the Preferred Embodiment
- An example of normal, non dual simplex processing by the switch illustrated in FIG. 5 (or any of the alternative embodiments of non dual simplex switch operation) is illustrated by the flowchart of FIGS. 6A through 6C. This example is only a high level illustration of one path through the states of the loop port state machine of a single switch port such as loop port state machine (LPSM)218 in FIG. 7 and is illustrative of typical processing for loop-local or chip-local or remote transactions. The LPSM in each switch port is a complex state machine which has many states and many transistions between states with the transitions between states depending upon the logical states of various input signals. Each loop port state machine is comprised of a plurality of individual component state machines which interact with each other. Some state machines generate output signals which are inputs to other state machines. This means that a large number of possible scenarios for the states of the state machine switch ports exist. To explain all these states and all the conditions for transition therebetween, would obscure the main ideas of the invention. To exactly illustrate all possible states and transitions, there is included herewith as FIGS. 17 through 28 individual state diagrams for all the state machines in a single LPSM. Each circle represents one state. Each line from one state to another represents a transition from one state to another. The labels in boxes on each line represent the Boolean condition that must exist between the signals identified in the box for that transition to be made. Boolean logical operators are identified by & for an AND operation, a tilde preceding a signal name means NOT and a vertical line between two signals means OR between those two signals. Each state and each signal is defined in the verilog code appended hereto as Appendix A. The state diagrams coupled with the verilog code together comprise a complete and exact description of all states and transitions between states for every possible processing scenario performed by the preferred embodiment of the switch. A description of the verilog hardware description language and how to use it to define the functionality of an integrated circuit is given in the treatise, Palnitkar, “Verilog® HDL: A Guide to Digital Design and Synthesis” ISBN 0-13-451675-3 (Prentice Hall 1996) which is hereby incorporated by reference.
- Local Destination Process
- As a first example, suppose
node 138 wishes to send data tonode 140.Node 138 arbitrates for control of the FCAL net 142 comprised ofdata paths 142 A, B and C andnodes 138 and 140 (step 150). When control is won,source node 138 sends an OPN primitive toport 126 with the destination address ofdestination node 140 therein (step 152). Optionally, the source node follows the OPN with one or more RRDY primitives, each representing one frame buffer of credit which the source node has reserved for receiving frames of data from the destination node (step 152).Port 126 latches the OPN and any RRDY primitive following the OPN (step 154), and uses the destination address of the OPN as a search key to search a routing table stored in port 126 (step 156). In the preferred embodiment, a separate routing table is maintained in each port circuit. In alternative embodiments such as represented by FIG. 4, the routing table may be a single table 127 coupled to all the ports by theprotocol bus 121 with each port checking the routing table contents by messages on the protocol bus. This embodiment is represented by FIG. 4. In the embodiment of FIG. 4, the contents of the routing table are updated by an active discovery process although this active discovery process may also be carried out in the preferred embodiment of FIG. 5. - The contents of the routing table are destination addresses and the identification codes (hereafter IDs) of the ports or half bridges to which those destination nodes are coupled. Each half bridge contains such a routing table. The contents of the routing table are learned by each half bridge by watching the traffic on its ports in the manner described in the parent case or by an active discovery process which will be described below.
- In this particular case, the search indicates that the destination node is local to FCAL net142, and that determination is represented by
test 158 in FIG.6A. Port 126 responds by setting an internal switch to connect an internal bypass data path to connectdata path 142C todata path 142A (step 160), and sends the OPN todestination node 140 along with any RRDYs received from the source node (step 162).Node 140 responds either with one or more RRDY primitives if it has buffer capacity to receive one or more frames from the source node or a CLS primitive or one or more frames of data to be transmitted to the source node in accordance with the number of RRDY primitives received from the source node (step 164). In general,step 164 represents the process of the switch port acting as a normal non participating FCAL node for the duration of the transaction by forwarding all data and primitives received from the local loop back onto the local loop. Thus, if a primitive or data frame is output by the destination node for transmission ondata path 142B to sourcenode 138 andnode 138 responds with an RRDY or data frame onpath 142C,switch port 126 forwards the RRDY or data frame to the destination node viapath 142A. If the destination node outputs an RRDY,source node 138 responds by transmitting an entire frame tonode 140 viadata paths node 140, and when it has been processed and the buffer is ready to receive another frame, another RRDY is output. If the destination node responded with a frame of data in response to an RRDY received from the source node, the source node stores it in its buffer. If the destination node responded with a CLS primitive, the source node relinquishes control of its FCAL net, and the transaction is ended according to normal FCAL close protocol. The process of exchanging RRDYs and frames of data continues until eithernode 140 outputs a CLS indicating it will send no more data to the source node orsource node 138 outputs a CLS indicating it will send no more data to the destination node. The FCAL net 140 is then relinquished and othernodes including port 126 can arbitrate for control thereof. -
Test 166 is symbolic of one event that can occur after the loop-local transaction is completed. The loop-local transaction has to be completed since no other node can win control of the local loop in arbitration so as to be able to send an OPN until the loop local transaction is over.Test 166 determines if an OPN has been received from the local loop, and, if so, vectors processing to step 154 to latch the OPN, as symbolized bystep 168. -
Test 170 symbolizes a test for an event which can occur regardless of whether the loop-local transaction is over or not—receiving a connect request message on the protocol bus at the switch port involved in the loop-local transaction. If this happens, the switch port becomes the destination port for a remote transaction. In such a case, the switch port behaves as indicated instep 175 and the following steps to arbitrate for control of the local loop, as symbolized byblock 172. When control is won (after the loop-local transaction is over), the switch port sends back a connect response message naming the backplane channel to use. The connection is then established by the source port and the destination port and the transaction is completed as indicated in thesteps following step 175. - If
tests test 166 and stays in the-state represented bytests - Remote Destination Process
- Now suppose
node 140 has data to send tonode 144 coupled toport 124.Node 140 arbitrates for FCAL net 142, and when control is won, outputs an OPN with the destination address ofnode 144 therein (steps node 144 is coupled to aremote port 124, and an ID for the remote port is returned by the search (step 158). If the search indicated the destinaton node was on an FCAL net coupled to a switch port on the same chip as the switch port coupled to the source node, the result would be the same in that processing would be vectored in either event to step 168 169. Thus, path 167 is taken for either a chip-local or a remote transaction. -
Step 168 represents a determination as to the status of the remote port coupled to the destination node. The combination ofsteps source switch port 126 then sends a connect request message formatted as in FIG. 14A via aprotocol bus 121 to the destination or chip-local switch port, as symbolized bystep 172. In FIG. 14A, the requestor ID is the ID of the source switch port and the responder ID is the ID of the destination switch port. Although this is the protocol of the preferred embodiment, in alternative embodiments, any protocol for determination of the status of the remote port and/or any other mechanism to establish a connection through the crossbar switch or other connection mechanism will suffice to practice the invention. In the preferred embodiment, the status determination is accomplished by checking the status entry for the destination port in a copy of a scoreboard table stored by the switch port and kept up to date with the copies of the scoreboard table in all other switch ports by monitoring messages on the protocol bus. In alternative embodiments, the local port can send a message to the remote port via the protocol bus asking it for its status or can send a message to a central scoreboard to get the status of the destination port. - If the remote port was busy,
path 174 is taken from thestatus determination test 176 back to step 168 to read the status again and processing stays in this loop in the local port until the status changes to available or no privilege. In some embodiments, a timeout function can be included to exit the busy-wait loop path 174 and send a CLS to the source node after a timeout event to keep head end blocking from barring all communications will all nodes coupled to the local port in case the remote node is broken and that would be equivalent to the claimed invention. - If
test 176 determines there is no privilege for the source node to talk to the destination node,path 178 is taken to block 180 where the local port sends a CLS to the source node. Processing then returns to Start. - Assuming the remote port was available and the connection request was received, the remote port then starts arbitrating for control of its local FCAL net (
step 175, FIG. 6B). When control is won, the remote port sends back a response message informing the first port coupled to the source node to forward the OPN and any RRDY primitives it has latched, and telling the first port which backplane channel to use (step 177). - As symbolized by
block 179, the response message from the remote port causes both the first port and the remote port to generate commands to the distributed crossbar switch circuitry of each port to set switches to couple the two ports to the selected backplane channel to set up an FCAL loop connection between the first port and remote port through the crossbar switch. In the example at bar, this data path couplesport 126 andport 124 through thebackplane data path 130 on the channel named in the reply message (step 179). - In some alternative embodiments, instead of sending a connection request to the remote port, the first port will simply establish a data path through the backplane and send the latched OPN and any following RRDYs to the
remote port 124. In response,port 124 will then latch the OPN and any following RRDY primitives, arbitrate for control of the FCAL net coupled tonode 144, and when control is obtained, transmit the OPN and any following RRDYs todestination node 144. If the local FCAL net is busy, the remote port will hold the OPN and any following RRDYs until the FCAL net is available, and repetitively arbitrate for control and then, when control is achieved, forward the OPN and RRDYs to the destination node. - In this alternative embodiment, the destination node will respond to the OPN (and any following RRDYs) with either an RRDY if it has enough buffer space to receive a data frame or a CLS if it does not or with one or more data frames to be transmitted to the source node corresponding to the number of RRDY primitives received from the source node if any RRDY primitives were received. The transaction then proceeds by transmitting one frame for every RRDY received from the other node until one or the other of the source or destination nodes transmits a CLS primitive. The frame or frames stream through
ports backplane data path 130 without ever being stored in any buffer memory and without ever being segmented into packets that require segmentation and reassembly. - In the preferred embodiment,
port 126 instead of sending the OPN and any RRDYs toport 124 to signal it to establish a connection, instead sends a connection request message via theprotocol bus 121. The connection request message tells theremote port 124 to arbitrate for its local loop and to notifyport 126 when control is won and expect further traffic. When the response message is received that control has been won byport 124 of its local loop and naming a channel to use on the backplane for data transfer, the OPN and any RRDY primitives which were received by the first port from the source node are sent to port 124 which then forwards these primitives to node 144 (step 181). As was the case for the alternative embodiment discussed in the paragraph above, the destination node will respond with either an RRDY if it has enough buffer space to receive a data frame or a CLS if it does not or with one or more data frames to be transmitted to the source node corresponding to the number of RRDY primitives received from the source node if any RRDY primitives were received. The transaction then proceeds, by transmitting one frame for every RRDY received from the other node until one or the other of the source or destination nodes transmits a CLS primitive to complete the transaction. - The connection is closed with a handshaking type protocol that uses a switch control character to eliminate race conditions. The connection through the backplane can be closed by either the source node or the destination node sending a CLS. Test182 represents branching to different protocols for closing depending upon whether the source node or destination node initiated the CLS. Processing branches to step 183 is the source node initiated the CLS. In
step 183, the source node outputs a CLS and that CLS is received by the source port and forwarded to the destination port over the backplane connection. - Optionally, the source port also sends an ARB(F7) or other innocuous fill word to the destination port. The purpose of this fill word is to send affirmative characters to the destination port to prevent any spurious characters from being transmitted to the destination port.
-
Step 185 represents the process of receiving the CLS at the destination port and forwarding it onto the local loop so that the destination node receives it. The destination node responds with its own CLS. -
Step 187 represents the process of receiving the destination node's CLS at the destination port and forwarding it across the backplane connection to the source port followed by a switch control character (typically 20 consecutive zeroes). -
Step 189 represents the process of receiving the destination node's CLS at the source port and forwarding it onto the local loop so that it will be received by the source node. The source port also loops the switch control character back through the backplane connection to the destination port. -
Step 191 represents the process carried out in the destination port of receiving the switch control character transmitted by the source port and realizing the backplane channel in use is now clear. The destination port then drops the backplane connection and transmits a release frame on the protocol bus. All other ports see that release frame and update their scoreboards to indicate availability for that backplane channel. The switch ports involved in this transaction are now ready for a new transaction so processing returns to startstate 148. - In the case where the destination node initiates the CLS, test182 vectors processing to the closing sequence which starts with
step 195. Step 195 represents the process of the destination node initiating a CLS. The CLS is received by the destination port and forwarded across the backplane connection to the source port followed by a switch control character (currently 20 consecutive zero bits). -
Step 197 represents the process that happens at the source port when the CLS and switch control character is received by the source port. The source port forwards the CLS onto the local loop and holds the switch control character. The CLS reaches the source node, and it responds with its own CLS. This CLS is received by the source port and forwarded to the destination port across the backplane connection. After forwarding the CLS onto the backplane connection, the switch control character is sent across the backplane connection. The source port then closes its backplane connection. -
Step 199 represents the process which occurs at the destination port when the CLS and switch control character are received there. The CLS is forwarded onto the local loop by the destination port. There it is received by the destination node which causes the destination node to close. The destination port then notes that it has received back the switch control character it originally sent to the source port and closes its backplane connection. The transaction is then over and the two switch ports are ready for a new transaction. Processing thus returns to a start state represented byblock 148 as symbolized bystep 193 - Note in all of the above embodiments, the frame or frames stream through
ports backplane data path 130 without ever being stored in any buffer memory and without ever being segmented into packets that require segmentation and reassembly. - The lookup table in each port circuit is slightly different than the lookup table in the bridge described in the parent described in the parent application. There, only two half bridges were coupled together, so the routing table could output only a 1 if the destination was local or a 0 if it was not, or vice versa. With the many half bridges of the switch, the routing table must store more bits for each destination address, those bits (6 ID bits plus one bit for validity of the port) define the unique ID of the particular port to which each node having a particular destination address is coupled.
- The Scoreboard Table
- In the preferred embodiment, a scoreboard table is used to store port status and priviledge information. Whenever the local FCAL net of a port is busy, the port connected to that FCAL net sends a message to update its status in the scoreboard to “busy”. When the FCAL net becomes available again, the port connected to that net sends another message to the scoreboard to update its status to “available”. The scoreboard can also store privilege information to implement security rules to prevent certain ports from communicating with other ports. The status states map to the following actions by the switching circuit: “busy camp” equals wait and do not forward OPN so no RRDYs get back to source node and no data is sent; “available” equals connect and send OPN to destination; and “busy no camp” equals generate a CLS and send it back to the source node, and “no privilege” equals generate an OPN and send back—this will tell the source node that the destinat node is not available.
- Summary of the Preferred Routing Algorithm Using a Scoreboard and Protocol Bus
- Thus, in the local and remote destination methods described above, the preferred embodiment includes the following steps for consulting the scoreboard (this method is reflected in FIGS. 6A and 6B).
- After the OPN and any following RRDYs from the source node are latched, the port that latched the OPN determines the port ID of the port coupled to the destination node by consulting the routing table as described above. After determining the ID of the remote destination port, that port ID is used as a search key to consult the scoreboard table to determine if the port is available and if there is the privilege to talk to it. If the remote ports status is “busy camp” and camping is allowed, send a connect request message and wait for the remote port to finish its current conversation, grant the connect request and send back a connect response message naming the backplane channel to use. If the remote port's status is “no privilege”, generate an OPN and send it back to the source node. If the remote port's status is “available”, send a connect request message to the remote port over the protocol bus. If the status if “busy no camp”, return a CLS to the source node. This causes the remote port to arbitrate for and win control of its local loop. When control is won, the remote port then sends a reply message to update its scoreboard status to busy and naming the backplane channel to use. The scoreboard circuitry sees the reply message and updates the status of the port whose ID is in the reply message to busy. The reply message causes the first port to generate signals to the crossbar switch to open a connection between the two ports. The first port then sends the latched OPN and any latched RRDYs to the second remote port coupled to the destination node, and the process proceeds as described above until the transaction is completed. When the transaction is completed, both ports relinquish control of their FCAL nets and the destination port posts a message on the protocol bus that both the source and destination ports are availble. The scoreboard circuitry sees this messages and automatically updates the status of each of these ports to “available”.
- When search of the routing table with the destination address of the OPN received at the first port from the source node indicates that the destination node is local, the scoreboard is not consulted and the bypass data path is activated. Then a message is sent by the first port to the scoreboard updating its status to “busy” to let all other ports know that the FCAL net coupled to the first port is temporarily unavailable for any other loop tenancy. Of course camping is allowed on local connection in the case of a “busy camp” status.
- The status data in the scoreboard table will indicate a port is busy when the FCAL net coupled to the port is tied up in a loop tenancy.
- Referring to FIG. 7, there is shown a block diagram of a typical switch chip such as those represented by
blocks - The received 10-bit data data is re-timed in an elastic buffer, shown at212, 214 and 216, producing a 10-bit data stream whose timing is identical to the transmitted data.
- A loop port state machine (LPSM) for each port, shown at218, 220, 222, functions to process received FCAL data and generate commands to establish the proper connection to either the local FCAL net or to a designated channel through the backplane so as to facilitate coupling of the received data on whatever data path the state machine establishes. The state machine also functions to receive data from the crossbar switch coming from a remote port and couple it onto the FCAL net local loop of that port. The state machine also functions to do the routing table searches and scoreboard table searches to determine when and FCAL transaction from the local loop must connect to the switch fabric and to post transaction messages on the protocol bus such as connection requests, reply messages, scoreboard updates etc. The switch fabric refers to the backplane data paths and switching circuitry that allows connections between different ports. The state machine also functions to arbitrate for control of the local FCAL net when a connection request is received from the switch fabric, and, when control is achieved, pick a backplane channel and generate the reply message. Another function of the state machines in every port in dual simplex mode is to store the buffer credit RRDYs output by the source node and forward these RRDYs to the third port, one RRDY at a time up to the buffer credit limit, when an OPN for a dual simplex transmission is received from a third node. Basically, all the logic and intelligence of each hub to carry out the functions described herein for the preferred or alternative embodiments resides in the states of the state machine. The particular design of the state machine is not critical, and any state machine (or programmable machine if it is fast enough such as a microprocessor) which can perform the functions defined herein will suffice to practice the invention. The novelty is not believed to be in the particular design of the state machine but in the functions it performs in each port.
- Since each switching circuit such as124 in FIG. 5 contains three ports (only one port is shown in FIG. 5), each switching circuit contains a port multiplexer, shown at 224 in FIG. 7. The port multiplexer interfaces the three state machines or LPSMs to the
backplane data channels 226. The state machines control themultiplexer 224 to keep local destination traffic for each port local but to couple traffic between the port and a remote port to a channel on the backplane. The port multiplexer and the state machine jointly determine the nature of each new conversation (local or remote) by searching a routing table stored inmemory 228. Preferably,memory 228 is a lookup table. - The
backplane 226 comprises the datapath and control logic required to receive and transmit the backplane data between switching circuits as well as multiplexing circuitry to shunt backplane data to and from the state machines via theport multiplexer 224. Backplane connections and data channel availability are tracked by a backplane protocol circuit which manages scoreboards in each port which have their data synchronized via broadcasts over theprotocol bus 121. - The state of each switch chip is monitored by a management circuit that interfaces to the system through 2-
wire bus 232.JTAG circuit 234 is used for testing the switch chip. - The serializer/deserializer function (hereafter SERDES) of each port at206, 208 and 210 is provided by the GigaBlaze SerialLink™ megafunction circuitry which is commercially available from LSI logic or any equivalent SERDES circuitry, the details of which are hereby incorporated by reference. The SERDES circuits accepts differential, 8b/10b encoded serial data at the rate of 1 Gbit/sec, demultiplexes it into aligned 10-bit characters and recovers a receive clock from the data. At the same time, the SERDES multiplexes outgoing 10-bit characters into a 1 Gbit/sec differential transmit data stream using a self-contained 10× clock multiplier. Other currently available SERDES circuits may be used also either at macros in layout of the switch port chips or as external parts.
- The
elastic buffers - The state machine in each port is similar to the FC-AL specification state machine but different in that it is passive and never transmits or receives frames itself. The
state machines - The state machines also implement the dual simplex process described above. Dual simplex mode can be turned on or off by management commands received on
bus 232. When this mode is on, the state machines convert full duplex OPNs to remote devices to half duplex OPNs to the same destination address. This leaves the source port available to receive an incoming connection from a third port. - The state machines do not need to participate in loop initialization, but rather they optionally allow initialization to occur as it would in a prior art FCAL net configuration and then change the state of the switch to allow the state machine to active engage source and destination nodes and control data flow therebetween. Before switching from hub mode (the switch can be instructed to act as a hub instead of a switch), the state machines also function to learn the mapping between each destination node address and the port ID of the port to which that destination node is connected. This learning can be performed by either a discovery process or OPN trapping, and will be discussed below. The mappings learned in either process are written by the state machine to the routing table in
memory 228. - The
port multiplexer 224 selectively connects each port to each other within the switching circuit or to thebackplane 226. The port multiplexer has three multiplexer blocks each of which is controlled by a portmux state machine. Local traffic connections are implemented by connecting a transmit data path and a receive data path between the two state machines in theport multiplexer 224. Remote connections are established by connecting the transmit data path and receive data path between the state machine and the backplane. Each channel through the port multiplexer actually implements two transmit and receive data paths. In full duplex operation, only one TX-RX pair is used to carry half or full duplex conversation. When a port is configured for dual-simplex operation, the outgoing conversation uses one TX-RX pair to transmit data to and receive flow control primitives from the destination node while the other pair is used to receive data from and transmit flow control to any third node in the event a third node connects to the source port. - The
port multiplexer 224 also contains a camplist FIFO for each of the three ports in the switch chip. These FIFOs are used to record the IDs of remote ports that have made a priority request to the switch port but which have not been serviced yet so as to implement the fairness token highest priority to these remote ports which have not yet been serviced and prevent any starvation of a port. - The
backplane 226 is a group of parallel point-to-point data paths which physically comprises 14 2-bit wide, 531.25 Mbit/sec data paths and a 265.625 MHz strobe signal imlemented using differential LVDS to drive the receiving switch chip. The switch chips are connected such that the backplanes form a ring of point-to-point connections. The strobe is generated by anintegrated PLL 227 and is timed with outgoing data such that it can be used to latch the data at the destination switch chip which is the next chip in the ring. Each data channel on the backplane may operate in the pass-through mode, or it may be configured to align incoming data into 20-bit words and steer data to and from a port multiplexer channel, which typically happens when a remote connection is being serviced by a port. Each port can be configured to statically listen and transmit to certain channels to support broadcast. - The backplane logic tracks the availability of each backplane channel, and can be configured to associate a data channel with a receiving port and only release it when no other channels are available. This is useful where backplane channels are underutilized to reduce latency.
- The protocol bus is an 18-bit wide data bus used for broadcasting connection requests and response messages to each switch chip in the switch. The bus is arbitrated by external logic that is asynchronous with respect to the main switch chip logic and thus can operate at any speed up to the limit determined by the system design. Each switch chip monitors the protocol bus and updates the status information in its copy of the scoreboard such that every port knows the busy/available status of every other port. This allows denial of full duplex connections at the source if the destination port is busy. Dual simplex is an exception to this rule. The scoreboard also prevents loops of camped devices by denying any camping connections to a port that is already camped on another port.
- The routing table in
LUT memory 228 stores 6-bit mapping data between each destination address and its port ID. Each port in a switch chip must have received a unique ID assignment from external management software before the system can operate as a switch. The LUT memory has three 10-bit read address ports, one dedicated to each port on a switch chip. The LUT has one 10-bit write address port for writing associations from the state machines developed in the learning process and also has 7-bit read and write address ports used by management software which does not form part of the invention. Internal logic in the LUT converts the 10-bit AL-PA destination addresses to 7-bit addresses for the 128×8 SRAM. The output from the LUT is a 6-bit port ID that maps to the AL-PA input at the address port of the lookup table, a valid entry bit and a bit that indicates whether the destination node is local to the switch chip. When a port receives an OPN from its local loop, it usesLUT 228 to determined if the conversation will be loop-local (destination on local loop), chip-local (destination on the local loop of another port on the same chip) or remote. - The LUT is initially loaded by a learning process called OPN trapping in which each port observes OPNs on its outbound local loop port and writes a destination address to LUT if a response to the outbound OPN on the local loop is detected on the local loop inbound data path. The port then posts a message on the protocol bus that its local loop has the destination address of the outbound OPN and giving its switch port ID. All the other ports receive this message and write the mapping into their routing tables.
- The contents of the LUT are cleared by a state machine and counter triggered by a managment command or the rising edge of a chip reset signal. Clearing the LUT takes128 clock cycles.
- Operational Overview
- The switch chips of FIG. 7 can be operated in three fundamental configurations: hub, switch and locked. Initial operation is in hub mode where each port is coupled to its neighbor ports to form one big Fibre Channel Arbitrated Loop (FC-AL). In locked mode, each port is standing by in preparation for a mode switch or broadcast. In switch mode, each port forwards data back onto its local loop until an OPN to a remote node is detected, and then a connection to the port coupled to the remote node is initiated through the backplane.
- FIG. 8 illustrates hub mode. In hub mode, the state machines of all ports cooperate to forward loop data from the receiver of one port to the transmitter of the adjacent port through the
port multiplexer 224. Because each switch chip can specify to the management software through a management-programmable register which hub mode backplane channel it uses, it is possible to partition the switch into several distinct loops instead of one big one. The hub channel is selectable on a per port basis. - Switch mode the state machine of each port monitors traffic on its local loop and forwards data from its receiver to its transmitter when an OPN designating a remote node is received on the local loop. When this happens, the state machine breaks the local loop and substitutes fill words on the local loop transmitter so that nodes on the local loop do not know the loop has been broken. The OPN is held while a connection attempt to the remote port is made. If the connection can be made, the remote port conducts unfair arbitration to win control of the remote loop, breaks that loop if it wins control and transmit and receive connections between the two loops are initiated to form a loop across the backplane between the source and destination nodes. FIG. 9 shows a typical switch connection between two ports on different chips as
data path 250, a simultaneous loop-local conversation represented bydata path 252 and a simultaneous chip-local conversation asdata path 254. - At any time, a number of these connections may exist with the maximum number of chip to chip data paths limited by the number of backplane channels.
- Transactions that are purely loop-local proceed without intervention of the state machine in the preferred embodiment with the exception that the state machine momentarily holds the OPN received while it checks the destination address in the
LUT 228. If the destination is on the local loop, then the OPN is forwarded onto the local loop and the state machine transitions into the busy monitoring state. - The state machine also detects a local tenancy by monitoring the RRDY primitive, and the tenancy is terminated when a CLS is detected. At the time a CLS is detected, the state machine returns to either a monitoring state or to a remote arbitration state if a pending remote request exists in the camp on FIFO (not shown in FIG. 7).
- Chip-local transactions are handled by the
port multiplexer 224 by arbitrating for local resources and physically multiplexing the data for all chip-local conversations. The state machine signals the port multiplexer and forwards the destination address after receiving an OPN from the local loop naming a destination on the same chip but a different FCAL net. A hit on one of the other two ports in the chip initiates the transmit request sequence. - The transmit requests to chip-local ports must be broadcast on the protocol bus to resolve port contentions and deadlock issues. Local requests proceed normally without posting to the protocol bus as no deadlock is possible for local only transactions.
- When a remote destination address is detected in an OPN from a local loop (done by the port multiplexer in some embodiments), the port multiplexer forwards the request to the
protocol bus logic 121 which arbitrates for the bus and assembles a request frame. The destination or remote port receives the frame and either begins unfair arbitration for the remote loop or queues the request in a FIFO-ordered list of campers. Eventually the request is serviced, and arb on the remote loop is won. At this time, the remote port issues a response frame on the protocol bus containing both grant and backplane channel ID on which to converse. The requesting port releases the OPN once the grant is received and awaits the first valid K28.5 primitive from the chose data channel. The remote port, upon receiving the OPN primitive, releases its local traffic onto the data channel and enters the connected state. The remote tenancy is considered terminated when the state machine has detected a CLS from both the source node and the destination node. - Each state machine implements a port bypass circuit and a parallel loopback mode, and each SERDES implements a serial loopback mode. The port bypass and parallel loopback modes are also used to bypass a faulty local loop while the switch is operating.
- Port Bypass, Parallel Loopback and Serial Loopback
- Each switch chip has three multiplexers that may be used to control the flow of data without regard to the FCAL protocol as illustrated in FIG. 10. These three multiplexers control port bypass mode, parallel loopback mode and serial loopback mode.
- The
port bypass circuit 260, when enabled, connectsline 262 from theport multiplexer 224 in FIG. 7 back to the port multiplexer vialine 264 and port bypass switch. This has the effect of forwarding data from theport multiplexer 224 back to its source without travelling across the local loop coupled to transmitinterface circuit 266 and receiveinterface circuit 268 coupled to the inbound and outbound data paths of the local FCAL net. SerDes (serializer/deserializer)circuit 270 does the serialization and deserialization function described above. Data incoming from the local FCAL net is never sent to theport multiplexer 224 when port bypass mode is engaged. Theport bypass circuit 260 may be engaged by the managment software, and is automatically activated under certain error conditions. It may only be disengaged by management. In normal operation, 10-bit words generated byGiga Blaze circuit 271 onoutput 270 are coupled throughport bypass switch 260 to the port multiplexer vialine 264. - Parallel loopback mode is manually engaged and disengaged by the management software, and is qualified by the port bypass enable. That is, parallel loopback mode is always disabled when port bypass is disabled. When a switch chip is in parallel loopback mode, incoming local loop data received by
Giga Blaze circuit 271 atinput 278 from the receive interface circuit and output online 270 is sent immediately to the transmitinterface circuit 266 vialine 272,parallel loopback switch 274,Giga Blaze circuit 271 andoutput 276. This happens under all circumstances when parallel loopback mode is engaged. Data from theport multiplexer 224 is never sent to the local loop while parallel loopback mode is engaged. If port bypass is enabled an parallel loopback is disabled, the loop is broken at the parallel loopback switch and ARB(F7) primitives are transmitted onto the local loop. - Serial loopback mode is primarily used for testing the data paths in the switch chip.
- Priority and Camping
- All chip-local and remote connections fall into one of three priority classes: none, low and high. All connection requests from a switch port default to a static priority level (which is typically no priority) which can be set my management software. Priority for requests can be escalated to low or high by a number of mechanisms.
- Priority escalates from none to low after a management programmable number of consecutive denials. If management software sets0 as the number of denials, this escalation is disabled. After the trigger level is exceeded, the priority deny count is reset and a low-priority request bit is set for exactly one arbitration interval. This arbitration interval begins after the low priority trigger value has been exceeded and an IDLE primitive has been detected on the inbound port of the state machine. All subsequent remote requests will use low priority until another IDLE is detected, ending the arbitration interval.
- The management software can also directly escalate priority on a port by enabling a rotating-token scheme in which each port requests at high priority for a period of time while other ports deny requests to a port.
- This mechanism guarantees each port a chance to service its local clients, at the expense of servicing any new remote requests. The token position is computed independently by each switch chip through use of a 6 bit token port ID location, a 6 bit token compare mask, a 16 bit token hold length register, and a single token priority enable bit. The token enable bit controls whether the token passing scheme is active in switch mode. If the enable bit is set to 1, the token passing scheme is enabled for the switch chip. All switch chips must set their token enable bit to the same value before transitioning to switch mode.
- This mechanism allows for fairness to be maintained throughout the system. This feature is critical in congested server environments where starvation of disk access can freeze an application. The circulating fairness token prevents this from happening.
- The token position counter identifies the port or port group that holds the token. A port holds the token if the port ID of the port AND2-ed with the 6 bit compare mask matches the token counter value AND-ed with the compare mask. If a port holds the token, its requests are made with high priority. Ports wishing to request a port that holds the token are denied so that the camp list of the port holding the token can drain and local requests can be serviced.
- The token position counter is incremented when a management-specified number of wall clock counter bits roll over to zero. The wall clock counter is a 24 bit counter which is incremented every word clock period of 40 ns, resulting in a range of approximately ⅔ of a second. The token position increment signal is computed OR-ing the lower 8 bits of the wall clock together with the bits resulting from an AND operation between the upper 16 bits of the wall clock and a 16 bit token length value, which should be set to a string of logic ones padded to the left with logic zero. When the resulting value is zero, the token counter is incremented.
- The length of the string of logic ones in the token length register determines the amount of time that each port will be assigned the token. For example, if the value of the token length register is 0 ¥ 3 f, the token counter will be incremented every time the lower 14 bits (8 LSB's+6 additional bits) are zero, or every 214*40 or about every 650 usec.
- Camping on a port means that a remote request waits on a busy destination port until that port becomes available. A non-camped request will simply be closed at the source if the destination port is busy. Campers are ordered in a camp list FIFO which has a depth of 8 entries.
- Low and high priority are allowed to camp on a port if the camp list for that port is not currently full and the desired port is not holding the token. High priority requests differ only in that at the destination port they may be queued up to the depth of the camp list, while low priority requests queue to the low-priority camp depth set by management. All requests are serviced by a single queue with FIFO discipline. An alternative embodiment uses separate queues for high and low priority thus allowing high priority to jump to the head of the line.
- Camping on a port that is already camping on another port can create a deadlock situation in which two or more camped ports form a cycle. No forward progress can be made when this occurs, resulting in a “fatal embrace”. Such deadlocks are prevented by scoreboarding all ports which have outstanding requests. If the request has been observed on the protocol bus but no response has been issued by the target port, then the requestor port is marked as camped in the scoreboard. All requests to ports marked in the scoreboard as camped are immediately denied. Once the port in question has been issued a response, implying a grant and an allocated backplane channel, the formerly camped port can begin accepting campers.
- One anomaly exists which involves no-priority campers. Due to implementation issues, it is easier to permit the very first request to camp regardless of priority. Thus, even a no-priority request, if issued to a port that is busy and has an empty set of camp lists, will be camped. This anomaly occurs because there are difficulties in detecting a busy port unless the port is involved in a remote conversation that can be reflected in the scoreboards.
- Transitions From Hub to Switch
- In order to transition the system from switch mode from hub mode, the system must first be locked. Before initiating a lock from hub mode, the management software should set all parameters necessary for switch mode transition while the system is in hub mode so that the time spent during the transition in the locked state is minimized. Since transactions cannot be initiated while the system is locked, it is possible that an NL-port could time out and LIP (initialize) if the system is locked for too long, causing the hub to switch transition to fail.
- Once the system is locked, external logic asserts a signal which sets the port multiplexers such that each port is partititioned from the system. During this time, each loop is broken, and IDLEs are driven onto the local loops in order to nullify ARBs that may still be present from hub mode arbitration. Next, the locking signal is deasserted, and, after a brief delay in which IDLEs are sent to the outbound port, the switching chips transition to the monitoring state and switch mode operation commences.
- If a LIP or other exceptional condition is detected during the switch mode transition, the system sets an output to a state that indicates the mode transition failed and the system is still in hub mode.
- Destination Node Address Discovery Processes
- The associations between node addresses (AL_PAs) and their associated ports are determined at initialization time through a learning process referred to herein as OPN trapping. An OPN primitive is said to be trapped in hub mode when it has been transmitted onto a local FCAL net and an RRDY primitive received in its place. When an OPN has been trapped, the switch chip has the destination node address (AL_PD) of the device residing on the FCAL net where the trap occurred as well as the port ID of the port servicing the loop. This information is stored in the LUT routing table228.
- Storing addresses into a single LUT is not sufficient for proper switch operation. The data in the LUT routing table of each switch chip in the system should be filled in before transitioning to switch mode. This can be achieved in two ways. The slower method, yet simpler to implement in the circuitry of the system, is to use the management interface to read every address in every LUT and build the LUT contents in software. The CAMs of every switch chip are then loaded through the management interface.
- The CAMs can also be synchronized as the OPNs are trapped through communications on the protocol bus. Since the protocol bus is only utilized for scoreboarding during switch mode, every trapped OPN results in a protocol bus transaction that advertises the node address and the port ID to all switch chips.
- The discovery of every utilized AL_PA through OPN trapping can be facilitated in a passive or an active manner. During hub mode, if passive OPN trapping is enabled, normal traffic will result in trapped OPNs which will eventually populate every LUT with the address-port associations of every NL-port in the system.
- AL_PA active discovery is a procedure by which the switch chip learning process is acelerated by additional logic on each switch chip. Active discovery is initiated by asserting a signal on each switch chip while it is in locked state. Once active discovery is initiated, a signal BCST_BUSY is driven low, and a 10-bit counter cycles through the 1024 10-bit words. Each word is passed through an address encoder which generates a signal that is active whenever the 10-bit word corresponds to a legal AL_PA. For each such word, the discovery process is triggered for each port on the switch.
- The active discovery process starts with an OPN transmitted onto the local loop using the counter word as the AL_PD or destination address. The OPN is immediately followed by an interframe gap and a CLS. This sequence will travel around the loop and return to the discoverer if a device with that particular AL_PD is not on the local loop. If the node with that destination address is on the local loop and the node is not bypassed, the node will consume the OPN and CLS and send a CLS of its own. In this case, the discovery logic will write the AL_PA to port associated into the CAM. After an OPN or CLS is received at the receive port of the port which launched the OPN onto the local loop, the active discovery state machine pauses until the counter reaches another valid AL_PA. Once all valid addresses are attempted, the entire Arbitrated Loop address space has been deterministically mapped. This causes the BCST_BUSY signal to be allowed to float to
logic 1, signalling that active discovery is complete. Active discovery may be aborted by deasserting the signal which initiated it which results in immediate reset of the discovery state machine. - Loop Port State Machine Policy
- The loop port state machine is not a strict implementation of a conventional FCAL loop port state machine since it must switch OPN sequences and subsequent frames to and from the backplane and post messages to and read messages from the protocol bus and update the scoreboard and carry out the learning protocols.
- While the exact design of the state machine is not critical to the invention, all designs must be able to perform the functions described above for at least one embodiment and, at least in the preferred embodiment, must adhere the following rules.
- 1) The LPSM must preserve word alignment unless it is absolutely impossible to do so. Since bugs exist in the HP Tachyon™ design which fill the loop with nonsensical transmissions if a K28.5 is followed by a character and another K28.5, any LPSM implementation that shares the loop with a Tachyon-based device must exercise great care in aligning output words.
- 2) The LPSM must not disturb OPN-CLS or SOF-EOF symmetry, nor should it unintentionally disturb credit flow by removing and adding RRDYs. In dual simplex cases, the LPSM will intentionally manipulate credit by absorbing RRDYs and rerouting them to an alternate destination.
- 3) The LPSM must conform to the FCAL requirements regarding interframe gaps. Also, the LPSM should avoid interframe gap conditions which are FCAL legal, but cause interoperability problems with current equipment.
- 4) The LPSM may operate in unfair mode in order to prioritize remote connections over local connections, but it must not break arbitration by prematurely resetting the access window, or starvation may occur.
- 5) The LPSM must allow loop initialization to be triggered and to proceed in a reasonably normal manner.
- FIG. 11 is state table describing the various LPSM states in the preferred embodiment.
- Loop Port Unfairness
- An LPSM always operates in unfair access mode in order to obtain the loop as soon as possible. The current arbitration window is not observed and the high priority ARB (usually ARB(0), but programmable by the management software to be any AL_PA) is used to gain control of the loop. Simply put, the loop port state machine issues ARB on the loop whenever a remote request is pending and continues to do so until the same ARB is received back at the LPSM indicating that the LPSM has won arbitration.
- If the LPSM receives an OPN or RRDY primitive, then another device on the loop won arbitration. In this case, the LPSM continues to issue its ARB, and monitors the loop until arbitration is won. While arbitrating, an OPN may arrive from the loop; the AL_PD of the OPN is then used to search the LUT to determine whether the OPN is to a remote or local device. If the OPN is remote, the LPSM synthesizes a CLS in an attempt to end the tenancy of the device on the local loop which sent the OPN which is interfering with the arbitration attempt of the LPSM. Thus, remote tenancies which have already traversed the protocol bus and are present camped are heavily favored over local devices who are attempting to make a remote connection. If however the OPN received from the local loop during arbitration by the LPSM is directed to a local device, the LPSM continues to arbitrate while processing the local transaction normally.
- Interframe Gaps
- The ports on every switch actively participate on their loops when they are facilitating a remote tenancy. The two primitives RRDY and CLS are used according to FCAL net interframe gap policy. The specific policy that the switch chips use is that if a current primitive is a fill word and two consecutive fill words have previously been detected, then insertion of the RRDY or CLS may take place. For purposes of this policy, fill words are defined as ARB(x) and IDLE primitives.
- Fill Word Insertion
- Fill words are generated and inserted onto the local loop when the LPSM is not in the LPSM _MON state (hereafter the states of the LPSM will be referred to by the acronym that follows LPSM _ in FIG. 11). Rules governing fill word generation ensure that the current arbitration state of each loop is maintained independently. The problem for each switch chip when it is coupled to a source loop, i.e., the loop having the source node, is that it must send fill words that are relatively innocuous. An NL_port in an OPEN state will transmit ARB(F0) which it uses to determine if any other ports on the loop are currently participating in arbitration. If the open NL_port receives ARB(F0) in return, the NL_port has the option of retaining the loop and sets it current fill word to IDLE, thereby resetting the arbitration interval. The LPSM needs to send a management programmable low priority ARB that does not possess the potential to disturb the local loop access state like ARB(F0) does. For this purpose, the ARB(F7) is suitable, as it is only used by a non-participating port to quiesce the loop prior to sending a loop initialization primitive LIP in order to receive a valid AL_PA.
- The fill word generation matrix for the source loop is given in FIG. 12, and the destination fill word generation matrix is given in FIG. 13. In the source loop LPSM, the ARB(F7) state is entered when a local OPN is received, and a minimum of 6 current fill word primitives are sent when relinquishing the loop. In the destinaton loop LPSM, the ARB(F0) state is entered when a remote connection request is received, and the ARB(F0) state is entered when a tenancy is established and an OPN is passed. A minimum of 6 current fill words are sent when relinquishing the loop.
- Remote Data Transfer
- In order to reduce the amount of decoding required to merge the data stream of a remote connection into the flow of data on the local loop, very few primitives are passed across the backplane.
- Miscellaneous Primitive Handling
- The most common primitives that the switch chips must deal with are: IDLE, RRDY, ARB, OPN, SOF, EOF, CLS and LIP. The other primitives that may be encountered include: NOS, OLS, LR, LRR, MRK, LPB AND DHD. The handling of these other primitives is described below.
- NOS, OLS, LR and LRR Primitives
- When NOS or OLS primitives are detected, on the inbound port of a loop, the OLD_PORT detect flag of the port is set so that the management software can detect the condition. LR and LRR primitives will be fed back onto the local loop, but not through the backplane.
- MRK Primitive
- The MRK primitive is discarded if issued during a remote tenancy in dual-simplex. Otherwise, MRK primitives are passed around the local loop and across any remote connection. However, it is unlikely that a MRK will find its destination unless it is issued inside of a tenancy in which the target is on the destination loop.
- LPB and LPE Primitives
- The LPB and LPE primitives are trapped and written to management software. A detection flag is set for either an LPB or an LPE, and the AL_PD and AL_PS are written to a 20-bit register that is accessible by the management software.
- DHD Primitives
- In dual simplex mode, all dynamic half duplex primitives are translated into CLS primitives. Otherwise, they are passed unaltered to their destination.
- Protocol Bus Definition
- The protocol bus is the medium by which the scoreboards for each switch chip are kep current. It also serves to communicate switch connection requests and responses between switch ports. The protocol bus is defined as an 18 bit bidirectional data bus named PBD, a request output PBREQ0 for each switch chip, a grant input named PGGRNT1 to each switch chip, a shared bus idle input signal PBIDLE1, and shared frame available input signals named PBFRM1. The protocol bus runs asynchronously with respect to the 106.25 MHz core circuitry to which it interfaces. It is only necessary to provide a clock of less than 50 MHz for the bus to function properly.
- When a switch chip wishes to transmit a data frame on the protocol bus, it drives its PBREQ0 output. The PBREQ0 of each switch chip in the system is fed into external arbitration logic which prioritizes the inputs and asserts a single PBGRNT1 output in the same cycle. The chip that receives the asserted PBGRNT1 deasserts PBREQ0 and then drives the PBD bus in the next cycle. The arbiter asserts PBFRM1 in the cycle following any PBGRNT1 to notify each switch chip that a data frame is present on the protocol bus.
- Once a switch chip obtains a PBGRNT1, it must not assert PBREQ0 until it sees PBIDLE1 asserted from the arbiter. The PBIDLE1 is asserted whenever no chip is requesting the bus in a cycle, indicating that the protocol bus arbitration window may be reset.
- Each protocol bus data frame possesses a slightly different format. These formats are depicted in FIGS. 14A through 14E. The abbreviations BP CHNL in FIGS. 14B and 14C stand for backplane channel. The abbreviation PID in FIG. 14E stands for port ID.
- The connection request data frame of FIG. 14A is sent by a port that wishes to initiate a connection to a remote destination port and has found that the destination camp list can accept a request of the desired priority, and that the destination port is not current requesting a destination for itself. When a connection request is broadcast, every switch chip marks its 64 bit requester scoreboard and increments its camp list depth scoreboard for the destination and priority.
- Chip remote request frames have a 0×0 pattern in the LCL field shown at300 in FIG. 14A while chip local requests place a 0×3 in this field. This difference in format allows switch chips to update channel allocation scoreboards only on chip remote requests. If a chip remote request hits a channel that has been placed in an age list, a channel idle scoreboard for the channel owned by the destination port is cleared; otherwise, a need counter is incremented as will be explained in the next section.
- A connection response having the format of FIG. 14B is broadcast by a port that has serviced a camp list entry, and indicates that a connection may be initiated over a backplane data channel specified in
field 302. A connection response results in the clearing of the requestor scoreboard for the requestor ID given infield 304 of the response frame, and it also results in setting the responder scoreboard for the destination port. The port that own the allocated channel and the channel number are entered into the age list on the initial allocation of the channel. A responder port that resides on the same switch chip as the requestor, indicating a chip-local connection, must still broadcast a response frame so that the responder scoreboard is updated in all the other switch chips. This type of chip-local connect respose carries an invalid channel ID code of 0×f, which indicates to receiving switch chips that the backplane usage scoreboard should not be modified. - A responder channel idle frame having the format of FIG. 14C is driven on the protocol bus when a backplane channel completes a transaction. In the default system configuration, the channel is retained by the responder until the channel is required by another responder, thus reducing setup overhead if the destination node that just finished a tenancy over the channel is a frequently accessed destination. When an idle frame is received, each switch chip updates its channel idle scoreboard to indicate the channel is available.
- The no-op frame of FIG. 14D is used as a late abort of a response due to channel allocation. This may occur when a request has been queued for transmission but a conflicting request is received before the queued request can be transmitted. The queued request is checked a final time before transmission, and if a local deny must take place, the frame is converted to a no-op and sent to get it out of the queue. Any other way of purging the queue will also suffice.
- The lookup table update frame of FIG. 14E is transmitted when an OPN is trapped on a local loop in hub or locked mode. The frame is then used by each switch chip to enter a node address AL_PA equal to the content of field into its LUT with a port ID mapping as specified in
field 308. - Backplane Channel Allocation
- The example given herein for the configuration of the backplane has 14 separate backplane data channels, three of which may be dedicated to other uses such as broadcast. Channels are allocated by destination ports and remain assigned to them for as long as possible. A channel scoreboard indicates if any channels are free and is used to hold off any pending responses from ports which are not already connected to a data channel. If this is not the case, a need counter is incremented. When this need counter exceeds the physical number of data channels, then the backplane attempts to free up a channel while the destination port attempts to obtain a connection grant response from its LPSM. All data channel connections (identified by response frames on the protocol bus) are stored in the age list which indicates the channels that have been held the longest and the port that currently own those channels. When the need counter exceeds the number of data channels, each switch chip consults its age list and selectes the channel to be relinquished. Idle channels are broadcast on the protocol bus using the frame of FIG. 17 when the camp list of the port owning the channel empties completely. The oldest owned channel is freed by the switch chips that owns the channel and all switch chips update their scoreboards to reflect the new state. For every channel that is freed, the need count is decremented by one.
- Channels can also be freed in blocks of size greater than one. The size of the block of channels freed is determined by management-programmable parameter. The switch chip management logic can also instruct the backplane to always free a channel when it becomes idle, rather than only freeing the channel when the need arises.
- Switch Fairness
- Starvation is a problem because most of the fairness policies implemented by the switch chips guarantee remote access fairness to switch ports and not to the individual NL_ports. Thus, while an NL_port is guaranteed access to its local loop and is guaranteed to win arbitration within one FCAL net access window, its tenancy will not be successful if the NL_port attempts to transmit to a remote port and is denied connection by the switch. Usually, randomness of access patterns will result in statistical fairnesss. However, it is not uncommon to encounter degenerate cases where this behavior can occur repeatedly on a given NL_port, resulting in starvation of the port.
- To improve the fairness of access to the switch at the NL_port granularity level, it is necessary to guarantee that all NL_ports on a local loop get some fraction of the switch bandwidth. Mechanisms exist for escalating from no-priority requests to low-priority requests based on the number of consecutive denials of access issued by a remote port state machine and for rotating a fairness token among all the ports to guarantee that each port gets a turn at high priority access.
- Broadcast Support
- In the preferred embodiment, each switch chip's LPSM includes logic to support three possible broadcast modes: that of the broadcast sender, the broadcast server transceiver, and the broadcast receiver. For a switch chip to be able to send broadcasts, it must include logic to decode a broadcast sequence as described below, logic to determine whether the broadcast channel, if it exists, is busy, logic to forward a broadcast sequence directly to the local loop as it is received, and logic to write a preamble to the broadcast sequence and place the sequence on the broadcast channel if it is available.
- To decode a broadcast sequence, each switch chip should have the the following structure. Broadcast sequences are detected on the inbound port from the local loop. A broadcast sequence is defined to be the sequence of one or more broadcast OPN groups terminated by a CLS primitive. A broadcast OPN group is defined to be one or more selective or broadcast OPNs followed by data frames.
- The LPSM always forwards a broadcast OPN group back to its local loop, guaranteeing that all local NL_ports see the broadcast and that the sender of the broadcast can clean up the local loop. If broadcast mode is enabled by the management software, the switch port also attempts to forward the broadcast to the predefined backplane broadcast channel. If the channel is not already busy with a broadcast that is already in flight, the switch chip will prepend a unique, identifier sequence to the broadcast sequence and transmit the prepended sequence onto the broadcast channel. During the transmission, any broadcasts on the channel but upstream from the broadcasting switch chip will be discarded. As a result, only one broadcast may reach the broadcast server. When the server receives a broadcast, it reads the broadcaster ID prepended to the sequence. This identification mechanism excludes the original broadcaster from transmitting data onto the local loop a second time. The broadcast server then sends unicast to each of the destinations on the broadcast list.
- The server comprises one port of a switch chip that is configured to only listen and transmit on the broadcast channel, and a broadcast server board that is connected to the switch chip by its serial loop port. Broadcast sequences are received by the dedicated broadcast port and forwarded to the switch port connected to the broadcast server board for storage.
- In order for a switch chip to be able to receive broadcasts, the LPSM must include logic that discriminates whether an incoming broadcast originated at the port or at some other port from the data in the preamble prepended to the broadcast sequence.
- In order for a switch chip to be able to function as the transceiver interface to the broadcast server, a switch port must be configurable so that it only forwards data from the broadcast channel to the loop port and forwards data from the loop port back to the broadcast channel. This port should not be effected by state change requests or other exceptional conditions if it is configured as a broadcast transceiver.
- Buffered FCAL Switch
- Referring to FIG. 29 there is shown a species of a buffered FCAL switch which falls within a separate second genus of FCAL switches, suitable for
Class 3 Fibre Channel operation only. Switches in this genus still uses the destination address in the OPN to find the remote port but uses buffers instead of hold back flow control to complete the transaction to busy remote ports. Specifically, species within this genus will use the destination address of the OPN from the source node to find the location of the remote port. The destination address is used to look up the port ID of the switch port couped to the destination address. Suppose Then the status of that port will be checked. If the status is available, a connection request will cause a connection to be set up between the source node and the destination node via a source port connected to the source node and a destination port connected to the destination node. The buffer comes into play when the destination port is busy. In this situation, in the first genus described above, the normal primitives of the FCAL protocol are used for flow control to prevent the source node from transmitting any frames of data until the destination port becomes available. In the second genus defined in this paragraph, a buffer big enough to hold one or more complete frames of data is included in the front end of each switch chip, or multiple buffers each big enough to store a frame of data are included with each switch chip front end. Each of these buffers will serve as an auxiliary switch port and have its own connection to the backplane in some species or a single shared connection to the backplane through a multiplexer can be used. The preferred species uses multiple buffers each with its own connection to the backplane in addition to a connection directly from the switch port to the backplane for direct connections without buffering. In some species, a single shared buffer or multiple shared buffers on the backplane or in some central location may be used. - In this second genus, the way the buffers are used is for the source port to generate an RRDY sua sponte when it finds from a check of the scoreboard that the destination port is busy. The RRDY is sent to the source node and causes it to output a frame of data. This frame of data is stored in the switch port's buffer. Then a message is sent to the destination port indicating that the auxiliary buffer of the switch port is holding a frame of data for the destination port. This auxiliary buffer ID is added to the camp list for the destination port. When the destination port becomes available, a message is sent back on the protocol bus indicating that the destination port is now available and naming the backplane channel to use. A connection through the backplane is then established to this channel by the auxiliary buffer connection circuitry and the destination port, and the data in the auxiliary buffer is transmitted. If the switch port has multiple auxiliary buffers, they each have their own IDs and, preferably, each has its own switching circuitry to make a connection to the backplane.
- In this second genus, each auxiliary buffer has circuitry coupled to the return path to recognize RRDYs transmitted back by the destination node and to count them (or store them) and to wait for a connection between the source port and the RRDY counting circuit if the connection is not continuous such as in some cases where multiple buffers are present in each switch port. These stored RRDYs (or self generated in the case of a count only) can be transmitted to the source node in the case of full duplex or mixed with frames from a third node in the case of a dual simplex connection and transmitted to the source node. Each source port also has shared circuitry for each FCAL net which recognizes incoming RRDYs from the source node and counts them or stores them. These source node generate RRDYs can be transmitted to the destination node in the case of full duplex or transmitted to a third node in the case of dual simplex.
- The operation of such a switch is now described with more specificity in connection with the species shown in FIG. 29. We first consider a full duplex transaction. In the species of FIG. 29, an OPN/RRDY detector and
RRDY generator circuit 450 detects any incoming OPN or RRDY primitives coming in from thesource node 452 on the local FCAL net 454. The destination address of the OPN is latched and sent to the lookup table circuitry represented byblock 456 via line . The lookup table looks up the ID of the port connected to the destination node and determines its status. Suppose a first OPN with a destination address fornode 451 is received fromsource node 452 and the status ofdestination node 451 and itsswitch port 453 is available. In this case, protocol bus interface circuitry inblock 456 sends a connection request viaprotocol bus 458 to protocol bus interface circuitry inblock 457 ofswitch port 453 requesting a connection. This results in a connect response message naming the backplane channel to use. The loop port state machines inblocks buses respective port multiplexers data paths block 456 also controlsswitches 468 and 470 to make connections towires block 457control switches lines node 452 through the connection just described and the transaction proceeds normally until completed and the backplane channel is relinquished. - Now suppose
switch port 453 was busy. In this scenario, the lookup process using the destination address in the OPN determines that an immediate connection is not possible. In this case, the LPSM inblock 456 controls switch 470 to make an outbound connection to buffer 1A viawire 472 and controls switch 468 to make an inbound connection viawire 474. The LPSM then commands switch 476 to open long enough for an RRDY to be sent to sourcenode 452 and commandsRRDY generator circuit 450 to generate an RRDY online 478 and send it to sourcenode 452. The RRDY causessource node 452 to output a frame of data. This frame passes throughline 480,SERDES 482, switch 470 andline 472 intobuffer 1A and is stored there. Thecircuit 450 then generates a CLS and sends it to sourcenode 452. Then switch 476 is closed. LPSM inblock 456 then sends a message onprotocol bus 458 to the protocol bus interface circuitry and LPSM inblock 457 that it has a frame of data waiting fordestination node 451. This message gives the ID for thebuffer 1A and causes that ID to be put on a camp list fordestination node 451. Whendestination node 451 becomes available, LPSM inblock 457 sends a message back to LPSM inblock 456 saying “send data inbuffer 1A on backplane channel X”. The LPSM inblock 456 then controlsport multiplexer 460 to establish a connection betweenwires 484 and 486 to the designated backplane channel. LPSM inblock 458 controls switchs 469 and 471 to establish connections towires port multiplexer 459 to connectwires block 456 then causes aswitch 490 to close and causesBuffer 1A to output its frame of data onto the backplane channel where it gets transmitted to thedestination node 451 via straight throughwires - In some embodiments, the
circuit 450 will not send a CLS to thesource node 452 after it sends a frame of data into thebuffer 1A. In these embodiments, the connections will be maintained so that if there is more than one frame, it can be sent as soon as the destination node becomes free by a straight through connection. In these embodiments, the LPSM inblock 456 also causes switch 492 to close for a return path and causes switch 468 to make a connection to returnpath wire 474 so any RRDYs output by the destination node are transmitted to thesource node 452 once the destination node becomes available. The LPSM also then causes switch 470 to make a connection betweenoutbound path 480 fromsource node 452 and “straight through”outbound wire 464 so subsequent frames can be sent straight through. The transaction then completes as a straight through transaction. Buffers in the switch ports such asbuffers - Since the preferred method in the buffered switch is to close the source node after it outputs one frame into the buffer, it is then free to generate new OPNs to other destination nodes. Those OPNs can cause either straight through or buffered connections to their destinations depending upon the status of the destination port. The LPSMs can cooperate after the table lookup using the new OPN destination address to control the
switches 468 and 470 and their counterparts in the destination port to establish a straight through connection to the new destination via another backplane channel. In the meantime, thebuffer 1A and its associated switches and the LPSM are cooperating to act as an independent switch port such that when the destination node for the data in the buffer becomes available and a connect response message is received, it can independently send its data to the destination node the different backplane channel assigned in the connect request message. This increases throughput since the same switch port may be simultaneously be sending data to two or more different destinations. Buffered FCAL switches such as that shown in FIG. 29 have the additional advantage in that it prevents source blocking. The source may download one or more frames into the buffer for a destination node and then move on to its next transaction thereby reducing or eliminating head end blocking. - Dual simplex is also possible to increase throughput further by using
circuit 450 to count RRDYs emitted by the source node and using LPSM inblock 456 to award those RRDYs to a third node. This way, the RRDYs will cause the third node to send data inbound to the source node via a separate backchannel connection with LPSM inblock 456 controllingswitch 468 to establish the inbound path to sourcenode 452 via the backplane channel assigned by the third node and straight throughwire 462. Outbound data from the source node to a destination node can be sent by straight throughwire 464 or through one of the buffers. RRDYs emitted by the destination node are received by the destination port and sent via the protocol bus to the LPSM of the source port or a message is sent each time an RRDY is received from the destination node by the destination port informing the source port of this fact. The source port LPSM then controlscircuit 450 to generate an equivalent number of RRDYs and mix them in with the data frames from the third node on the inbound path 492 to thesource node 452 to keep the source node outputting data frames destined for the destination node. - The RRDY capture circuits are used in species where RRDYs are emitted by the destination node, but the
switches 468 and 470 are in states such that the RRDYs cannot be immediately be sent to the destination node such as where the source port is generating multiple OPNs to different destinations and filling up all its buffers one by one. In these embodiments, the nodes will have to be non standard in that they will have to OPN a destination, download one or more frames into a buffer, receive a CLS fromcircuit 450, OPN a new destination, download another one or more frames into another buffer, receive another CLS fromcircuit 450 and continue this process until all buffers have been used. The LPSM will commutate the switches to make successive connections to the buffers and straight through connections as needed and keep cycling through these connections. The RRDY capture circuits will count the number or RRDYs received or emitted by the destination nodes, and when theswitches - Fairness is implemented in the species within the second genus in the same way as in the species of the first genus. A fairness token is circulated, and when any switch port has the token, it assumes the highest priority. The fairness token can be circulated amond the switch ports on a separate fairness token bus (not shown in FIG. 29) or via the protocol bus which is the embodiment symbolized by FIG. 29.
- Although not shown for simplicity in FIG. 29, each switch port also includes a local loop bypass data path to keep purely local transactions confined to the local FCAL net. Note also that although each FCAL net is FIG. 29 is shown as having only one node, multiple nodes on each FCAL net are also possible. Note also that although FIG. 29 shows only one switch port per switch chip, multiple switch ports per switch chip are also possible similar to the structure shown in FIG. 7 but using the architecture of FIG. 29 for each switch port.
- Appendix B attached is the UUencoded Verilog description of the preferred embodiment of the entire switch chip integrated circuit. At the end of Appendix B is the C language source code for the UUencoding and decoding program to enable decoding of the Verilog and documentation for using the UUencoding and decoding program.
- Although the invention has been described in terms of the preferred and alternative embodiments disclosed herein, those skilled in the art will appreciate numerous modifications that can be made. All such modifications and alternatives are intended to be included within the scope of the claims appended hereto.
Claims (52)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/349,739 US20030107996A1 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/195,846 US6614796B1 (en) | 1997-01-23 | 1998-11-19 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US10/349,739 US20030107996A1 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/195,846 Division US6614796B1 (en) | 1997-01-23 | 1998-11-19 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Publications (1)
Publication Number | Publication Date |
---|---|
US20030107996A1 true US20030107996A1 (en) | 2003-06-12 |
Family
ID=22723067
Family Applications (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/345,707 Expired - Fee Related US7430171B2 (en) | 1998-11-19 | 2003-01-15 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US10/348,642 Expired - Fee Related US7366190B2 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US10/349,739 Abandoned US20030107996A1 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US10/349,067 Expired - Fee Related US7362769B2 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US12/149,373 Expired - Fee Related US8798091B2 (en) | 1998-11-19 | 2008-04-30 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/345,707 Expired - Fee Related US7430171B2 (en) | 1998-11-19 | 2003-01-15 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US10/348,642 Expired - Fee Related US7366190B2 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/349,067 Expired - Fee Related US7362769B2 (en) | 1998-11-19 | 2003-01-21 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US12/149,373 Expired - Fee Related US8798091B2 (en) | 1998-11-19 | 2008-04-30 | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
Country Status (1)
Country | Link |
---|---|
US (5) | US7430171B2 (en) |
Cited By (47)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060277285A1 (en) * | 2005-06-03 | 2006-12-07 | Andrew Boyd | Distributed kernel operating system |
US20060277284A1 (en) * | 2005-06-03 | 2006-12-07 | Andrew Boyd | Distributed kernel operating system |
US20080205421A1 (en) * | 1998-11-19 | 2008-08-28 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US20080205410A1 (en) * | 2007-02-27 | 2008-08-28 | Alcatel Lucent | Asymmetrical forwarding in layer 3 IP VPNs |
US7796629B1 (en) * | 2007-12-12 | 2010-09-14 | Integrated Device Technology, Inc. | Packet switch with configurable bandwidth allocation precision |
US7849208B2 (en) | 2002-08-30 | 2010-12-07 | Broadcom Corporation | System and method for TCP offload |
US20110052191A1 (en) * | 2002-08-20 | 2011-03-03 | Beshai Maged E | Modular High-Capacity Switch |
US7907625B1 (en) | 2008-08-04 | 2011-03-15 | Integrated Device Technology, Inc. | Power reduction technique for buffered crossbar switch |
US7912064B2 (en) | 2002-08-30 | 2011-03-22 | Broadcom Corporation | System and method for handling out-of-order frames |
US7934021B2 (en) | 2002-08-29 | 2011-04-26 | Broadcom Corporation | System and method for network interfacing |
US8116203B2 (en) | 2001-07-23 | 2012-02-14 | Broadcom Corporation | Multiple virtual channels for use in network devices |
US8135016B2 (en) | 2002-03-08 | 2012-03-13 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US8180928B2 (en) | 2002-08-30 | 2012-05-15 | Broadcom Corporation | Method and system for supporting read operations with CRC for iSCSI and iSCSI chimney |
US8402142B2 (en) | 2002-08-30 | 2013-03-19 | Broadcom Corporation | System and method for TCP/IP offload independent of bandwidth delay product |
US20130156043A1 (en) * | 2011-12-15 | 2013-06-20 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US8750320B2 (en) | 1997-01-23 | 2014-06-10 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
CN104255004A (en) * | 2012-04-26 | 2014-12-31 | 飞思卡尔半导体公司 | A cut-through forwarding module and a method of receiving and transmitting data frames in a cut-through forwarding mode |
US9448965B2 (en) | 2013-03-15 | 2016-09-20 | Micron Technology, Inc. | Receiving data streams in parallel and providing a first portion of data to a first state machine engine and a second portion to a second state machine |
US9524248B2 (en) | 2012-07-18 | 2016-12-20 | Micron Technology, Inc. | Memory management for a hierarchical memory system |
US9703574B2 (en) | 2013-03-15 | 2017-07-11 | Micron Technology, Inc. | Overflow detection and correction in state machine engines |
US10019311B2 (en) | 2016-09-29 | 2018-07-10 | Micron Technology, Inc. | Validation of a symbol response memory |
US10146555B2 (en) | 2016-07-21 | 2018-12-04 | Micron Technology, Inc. | Adaptive routing to avoid non-repairable memory and logic defects on automata processor |
US20190028408A1 (en) * | 2017-07-21 | 2019-01-24 | Aruba Networks, Inc. | Arbiter circuit for crossbar |
US20190097949A1 (en) * | 2017-09-26 | 2019-03-28 | Hewlett Packard Enterprise Development Lp | Network switch with interconnected member nodes |
US10268602B2 (en) | 2016-09-29 | 2019-04-23 | Micron Technology, Inc. | System and method for individual addressing |
US10417236B2 (en) | 2008-12-01 | 2019-09-17 | Micron Technology, Inc. | Devices, systems, and methods to synchronize simultaneous DMA parallel processing of a single data stream by multiple devices |
CN110278126A (en) * | 2019-06-28 | 2019-09-24 | 苏州浪潮智能科技有限公司 | A kind of switch port self checking method, system, terminal and storage medium |
US10430210B2 (en) | 2014-12-30 | 2019-10-01 | Micron Technology, Inc. | Systems and devices for accessing a state machine |
US10505861B1 (en) * | 2017-07-23 | 2019-12-10 | Barefoot Networks, Inc. | Bus for providing traffic management statistics to processing pipeline |
US10592450B2 (en) | 2016-10-20 | 2020-03-17 | Micron Technology, Inc. | Custom compute cores in integrated circuit devices |
US10684983B2 (en) | 2009-12-15 | 2020-06-16 | Micron Technology, Inc. | Multi-level hierarchical routing matrices for pattern-recognition processors |
US10691964B2 (en) | 2015-10-06 | 2020-06-23 | Micron Technology, Inc. | Methods and systems for event reporting |
US10769099B2 (en) | 2014-12-30 | 2020-09-08 | Micron Technology, Inc. | Devices for time division multiplexing of state machine engine signals |
US10771387B1 (en) | 2017-09-28 | 2020-09-08 | Barefoot Networks, Inc. | Multiple packet data container types for a processing pipeline |
US10846103B2 (en) | 2015-10-06 | 2020-11-24 | Micron Technology, Inc. | Methods and systems for representing processing resources |
US10929764B2 (en) | 2016-10-20 | 2021-02-23 | Micron Technology, Inc. | Boolean satisfiability |
US10977309B2 (en) | 2015-10-06 | 2021-04-13 | Micron Technology, Inc. | Methods and systems for creating networks |
US11023758B2 (en) | 2009-01-07 | 2021-06-01 | Micron Technology, Inc. | Buses for pattern-recognition processors |
US11159455B1 (en) | 2018-12-28 | 2021-10-26 | Innovium, Inc. | Reducing power consumption in an electronic device |
US11308109B2 (en) * | 2018-10-12 | 2022-04-19 | International Business Machines Corporation | Transfer between different combinations of source and destination nodes |
US11366675B2 (en) | 2014-12-30 | 2022-06-21 | Micron Technology, Inc. | Systems and devices for accessing a state machine |
US11388053B2 (en) | 2014-12-27 | 2022-07-12 | Intel Corporation | Programmable protocol parser for NIC classification and queue assignments |
US11411870B2 (en) | 2015-08-26 | 2022-08-09 | Barefoot Networks, Inc. | Packet header field extraction |
US11425058B2 (en) | 2017-04-23 | 2022-08-23 | Barefoot Networks, Inc. | Generation of descriptive data for packet fields |
US11463385B2 (en) | 2017-01-31 | 2022-10-04 | Barefoot Networks, Inc. | Messaging between remote controller and forwarding element |
US11488645B2 (en) | 2012-04-12 | 2022-11-01 | Micron Technology, Inc. | Methods for reading data from a storage buffer including delaying activation of a column select |
US11677851B2 (en) | 2015-12-22 | 2023-06-13 | Intel Corporation | Accelerated network packet processing |
Families Citing this family (46)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6185203B1 (en) * | 1997-02-18 | 2001-02-06 | Vixel Corporation | Fibre channel switching fabric |
US6118776A (en) * | 1997-02-18 | 2000-09-12 | Vixel Corporation | Methods and apparatus for fiber channel interconnection of private loop devices |
US6868509B2 (en) * | 2001-12-07 | 2005-03-15 | Invensys Systems, Inc. | Method and apparatus for network fault correction via adaptive fault router |
US7397768B1 (en) | 2002-09-11 | 2008-07-08 | Qlogic, Corporation | Zone management in a multi-module fibre channel switch |
US7801033B2 (en) * | 2005-07-26 | 2010-09-21 | Nethra Imaging, Inc. | System of virtual data channels in an integrated circuit |
US7453802B2 (en) * | 2003-07-16 | 2008-11-18 | Qlogic, Corporation | Method and apparatus for detecting and removing orphaned primitives in a fibre channel network |
US7447224B2 (en) * | 2003-07-21 | 2008-11-04 | Qlogic, Corporation | Method and system for routing fibre channel frames |
US7646767B2 (en) | 2003-07-21 | 2010-01-12 | Qlogic, Corporation | Method and system for programmable data dependant network routing |
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 |
US7894348B2 (en) | 2003-07-21 | 2011-02-22 | Qlogic, Corporation | Method and system for congestion control in a fibre channel switch |
US7406092B2 (en) | 2003-07-21 | 2008-07-29 | Qlogic, Corporation | Programmable pseudo virtual lanes for fibre channel systems |
TWI227980B (en) * | 2003-10-08 | 2005-02-11 | Genesys Logic Inc | Method of relaying multi-cast package and device of the same |
US7930377B2 (en) | 2004-04-23 | 2011-04-19 | Qlogic, Corporation | Method and system for using boot servers in networks |
US8295299B2 (en) | 2004-10-01 | 2012-10-23 | Qlogic, Corporation | High speed fibre channel switch element |
US8095601B2 (en) * | 2004-10-22 | 2012-01-10 | Microsoft Corporation | Inter-proximity communication within a rendezvous federation |
US8392515B2 (en) * | 2004-10-22 | 2013-03-05 | Microsoft Corporation | Subfederation creation and maintenance in a federation infrastructure |
US8549180B2 (en) * | 2004-10-22 | 2013-10-01 | Microsoft Corporation | Optimizing access to federation infrastructure-based resources |
US8014321B2 (en) * | 2004-10-22 | 2011-09-06 | Microsoft Corporation | Rendezvousing resource requests with corresponding resources |
US20110082928A1 (en) * | 2004-10-22 | 2011-04-07 | Microsoft Corporation | Maintaining consistency within a federation infrastructure |
US20060090003A1 (en) * | 2004-10-22 | 2006-04-27 | Microsoft Corporation | Rendezvousing resource requests with corresponding resources |
US8090880B2 (en) * | 2006-11-09 | 2012-01-03 | Microsoft Corporation | Data consistency within a federation infrastructure |
US8095600B2 (en) * | 2004-10-22 | 2012-01-10 | Microsoft Corporation | Inter-proximity communication within a rendezvous federation |
EP1727320B8 (en) * | 2005-05-27 | 2008-07-16 | Tektronix International Sales GmbH | Method and apparatus to provide ATM cells ordered according to ATM channels in an interface of a communication sytem placed between a first and a second node |
US20070014230A1 (en) * | 2005-07-14 | 2007-01-18 | Fujitsu Limited | Automatically provisioning a network element |
US7860103B1 (en) * | 2006-12-18 | 2010-12-28 | Pmc-Sierra Us, Inc. | Method and apparatus for extended addressing in a fiber channel arbitrated loop |
US8902793B2 (en) * | 2007-02-15 | 2014-12-02 | Broadcom Corporation | Method and system for a low-complexity spanning tree algorithm in communication networks |
US8265071B2 (en) | 2008-09-11 | 2012-09-11 | Juniper Networks, Inc. | Methods and apparatus related to a flexible data center security architecture |
US8730954B2 (en) * | 2008-09-11 | 2014-05-20 | Juniper Networks, Inc. | Methods and apparatus related to any-to-any connectivity within a data center |
US11271871B2 (en) | 2008-09-11 | 2022-03-08 | Juniper Networks, Inc. | Methods and apparatus related to a flexible data center security architecture |
US8335213B2 (en) * | 2008-09-11 | 2012-12-18 | Juniper Networks, Inc. | Methods and apparatus related to low latency within a data center |
US8340088B2 (en) * | 2008-09-11 | 2012-12-25 | Juniper Networks, Inc. | Methods and apparatus related to a low cost data center architecture |
US8755396B2 (en) | 2008-09-11 | 2014-06-17 | Juniper Networks, Inc. | Methods and apparatus related to flow control within a data center switch fabric |
US9847953B2 (en) * | 2008-09-11 | 2017-12-19 | Juniper Networks, Inc. | Methods and apparatus related to virtualization of data center resources |
US8125985B1 (en) | 2008-12-29 | 2012-02-28 | Juniper Networks, Inc. | Methods and apparatus for chaining access switches coupled to a switch fabric |
US9240923B2 (en) | 2010-03-23 | 2016-01-19 | Juniper Networks, Inc. | Methods and apparatus for automatically provisioning resources within a distributed control plane of a switch |
US9813252B2 (en) | 2010-03-23 | 2017-11-07 | Juniper Networks, Inc. | Multicasting within a distributed control plane of a switch |
US9282060B2 (en) | 2010-12-15 | 2016-03-08 | Juniper Networks, Inc. | Methods and apparatus for dynamic resource management within a distributed control plane of a switch |
US8831021B2 (en) * | 2011-09-25 | 2014-09-09 | Qualcomm Incorporated | System and method for dynamically configurable multi-window divergent protocol bridge |
JP6107666B2 (en) * | 2012-01-25 | 2017-04-05 | 日本電気株式会社 | Available bandwidth search range control method and available bandwidth search range control system |
US8825915B2 (en) | 2012-03-12 | 2014-09-02 | International Business Machines Corporation | Input/output port rotation in a storage area network device |
US9736121B2 (en) * | 2012-07-16 | 2017-08-15 | Owl Cyber Defense Solutions, Llc | File manifest filter for unidirectional transfer of files |
WO2016081005A1 (en) * | 2014-11-20 | 2016-05-26 | Hewlett Packard Enterprise Development Lp | Virtual target port aggregation |
US9794120B2 (en) * | 2015-04-14 | 2017-10-17 | Quanta Computer, Inc. | Managing network configurations in a server system |
US10193507B1 (en) | 2017-07-31 | 2019-01-29 | Analog Devices Global | Current switching circuit |
US11755501B2 (en) * | 2020-03-27 | 2023-09-12 | Intel Corporation | Efficient data sharing for graphics data processing operations |
Citations (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4817082A (en) * | 1987-03-09 | 1989-03-28 | American Telephone And Telegraph Company, At&T Bell Laboratories | Crosspoint switching system using control rings with fast token circulation |
US5276681A (en) * | 1992-06-25 | 1994-01-04 | Starlight Networks | Process for fair and prioritized access to limited output buffers in a multi-port switch |
US5379291A (en) * | 1992-12-29 | 1995-01-03 | International Business Machines Corporation | Apparatus for fiber distributed data interface dynamic station bypass via skipping and hopping |
US5495475A (en) * | 1993-10-15 | 1996-02-27 | International Business Machines Corporation | Resolution of race conditions in cascaded switches |
US5528584A (en) * | 1994-10-27 | 1996-06-18 | Hewlett-Packard Company | High performance path allocation system and method with fairness insurance mechanism for a fiber optic switch |
US5566171A (en) * | 1995-03-15 | 1996-10-15 | Finisar Corporation | Multi-mode high speed network switch for node-to-node communication |
US5617421A (en) * | 1994-06-17 | 1997-04-01 | Cisco Systems, Inc. | Extended domain computer network using standard links |
US5619497A (en) * | 1994-12-22 | 1997-04-08 | Emc Corporation | Method and apparatus for reordering frames |
US5754549A (en) * | 1995-12-05 | 1998-05-19 | International Business Machines Corporation | Inexpensive two-way communications switch |
US5828475A (en) * | 1995-10-25 | 1998-10-27 | Mcdata Corporation | Bypass switching and messaging mechanism for providing intermix data transfer for a fiber optic switch using a bypass bus and buffer |
US5831985A (en) * | 1995-11-09 | 1998-11-03 | Emc Corporation | Method and apparatus for controlling concurrent data transmission from multiple sources in a channel communication system |
US5848251A (en) * | 1996-08-06 | 1998-12-08 | Compaq Computer Corporation | Secondary channel for command information for fibre channel system interface bus |
US5978379A (en) * | 1997-01-23 | 1999-11-02 | Gadzoox Networks, Inc. | Fiber channel learning bridge, learning half bridge, and protocol |
US6118776A (en) * | 1997-02-18 | 2000-09-12 | Vixel Corporation | Methods and apparatus for fiber channel interconnection of private loop devices |
US6212194B1 (en) * | 1998-08-05 | 2001-04-03 | I-Cube, Inc. | Network routing switch with non-blocking arbitration system |
US6324181B1 (en) * | 1998-04-16 | 2001-11-27 | 3Com Corporation | Fibre channel switched arbitrated loop |
US6396832B1 (en) * | 1998-09-04 | 2002-05-28 | 3Com Corporation | Method and apparatus for optimizing a switched arbitrated loop for maximum access fairness |
US6597691B1 (en) * | 1998-09-01 | 2003-07-22 | Ancor Communications, Inc. | High performance switching |
US6954285B2 (en) * | 2000-05-02 | 2005-10-11 | Canon Kabushiki Kaisha | Developing method and developing apparatus featuring two latent image developing operations using two electrical fields |
Family Cites Families (581)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US556171A (en) * | 1896-03-10 | John anderson | ||
US692892A (en) | 1901-03-02 | 1902-02-11 | Walter S Mckinney | Excavator. |
US1345382A (en) | 1918-07-18 | 1920-07-06 | Mckibbin Alexander | Valve |
US1460805A (en) | 1920-09-22 | 1923-07-03 | Sway Henry | Radiator core |
US3680774A (en) | 1970-04-15 | 1972-08-01 | Robins Industries Corp | Device for punching cards or the like |
US3749845A (en) | 1971-08-27 | 1973-07-31 | Bell Telephone Labor Inc | Digital data communication system |
DE2537589C3 (en) | 1975-08-23 | 1980-05-29 | Hoechst Ag, 6000 Frankfurt | Process for the continuous dyeing of sheet-like textile material consisting of synthetic fibers, essentially in rope form |
US4115759A (en) | 1977-08-08 | 1978-09-19 | Honeywell Information Systems Inc. | Multiple bit deskew buffer |
US4218756A (en) | 1978-06-19 | 1980-08-19 | Bell Telephone Laboratories, Incorporated | Control circuit for modifying contents of packet switch random access memory |
US4333020A (en) | 1979-05-23 | 1982-06-01 | Motorola, Inc. | MOS Latch circuit |
FR2494465B1 (en) | 1980-11-14 | 1987-02-13 | Epd Engineering Projectdevelop | POCKET COMPUTER |
US4395774A (en) | 1981-01-12 | 1983-07-26 | National Semiconductor Corporation | Low power CMOS frequency divider |
US4463424A (en) | 1981-02-19 | 1984-07-31 | International Business Machines Corporation | Method for dynamically allocating LRU/MRU managed memory among concurrent sequential processes |
US4445051A (en) | 1981-06-26 | 1984-04-24 | Burroughs Corporation | Field effect current mode logic gate |
US4433378A (en) | 1981-09-28 | 1984-02-21 | Western Digital | Chip topography for MOS packet network interface circuit |
US4500954A (en) | 1981-10-15 | 1985-02-19 | International Business Machines Corporation | Cache bypass system with post-block transfer directory examinations for updating cache and/or maintaining bypass |
US4449248A (en) | 1982-02-01 | 1984-05-15 | General Electric Company | Battery saving radio circuit and system |
JPS5968072A (en) | 1982-10-13 | 1984-04-17 | Sharp Corp | Small-sized electronic equipment for function conversion |
US4599526A (en) | 1983-05-13 | 1986-07-08 | At&T Bell Laboratories | Clocked latching circuit |
US4590550A (en) | 1983-06-29 | 1986-05-20 | International Business Machines Corporation | Internally distributed monitoring system |
US4519068A (en) | 1983-07-11 | 1985-05-21 | Motorola, Inc. | Method and apparatus for communicating variable length messages between a primary station and remote stations of a data communications system |
JPS6052147A (en) | 1983-09-01 | 1985-03-25 | Nec Corp | Timing synchronism system |
US4658250A (en) | 1984-06-15 | 1987-04-14 | Nering Douglas G | Computer network operating method and apparatus for detecting and exploiting data collisions to merge read transactions |
US4760571A (en) | 1984-07-25 | 1988-07-26 | Siegfried Schwarz | Ring network for communication between one chip processors |
NZ212899A (en) | 1984-07-31 | 1987-10-30 | Phillips Pty Ltd N J | Piston operated adjustable volume dose injector for animals |
US4737975A (en) | 1984-09-18 | 1988-04-12 | Metrofone, Inc. | Programmable system for interfacing a standard telephone set with a radio transceiver |
FR2573211B1 (en) | 1984-11-09 | 1986-12-12 | Labo Electronique Physique | SYNCHRONIZED COMPARATOR |
US4680787A (en) | 1984-11-21 | 1987-07-14 | Motorola, Inc. | Portable radiotelephone vehicular converter and remote handset |
GB8521159D0 (en) | 1985-08-23 | 1985-10-02 | Pa Consulting Services | Two-way radio communications system |
US4799215A (en) | 1985-10-07 | 1989-01-17 | Nec Corporation | High-speed packet-switched communications system with end-to-end flow control and retransmission |
GB2181907B (en) | 1985-10-18 | 1989-10-11 | Stc Plc | Phase rotation of signals |
US4620180A (en) | 1985-10-21 | 1986-10-28 | Northern Telecom Limited | Serial-to-parallel converter for high-speed bit streams |
US4721866A (en) | 1985-11-21 | 1988-01-26 | Digital Equipment Corporation | CMOS current switching circuit |
US4817054A (en) | 1985-12-04 | 1989-03-28 | Advanced Micro Devices, Inc. | High speed RAM based data serializers |
US4807282A (en) | 1985-12-30 | 1989-02-21 | International Business Machines Corp. | Programmable P/C compatible communications card |
NL8600889A (en) | 1986-04-09 | 1987-11-02 | Philips Nv | DEVICE FOR RECOVERING CHANNEL CLOCK INFORMATION FROM SYNCHRONOUS INFORMATION TRANSMISSION AND AN APPARATUS FOR RECOVERING THE INFORMATION PROVIDED WITH SUCH A DEVICE. |
JPH06105884B2 (en) | 1986-05-06 | 1994-12-21 | 日本電気株式会社 | Wireless telephone system |
US4850009A (en) | 1986-05-12 | 1989-07-18 | Clinicom Incorporated | Portable handheld terminal including optical bar code reader and electromagnetic transceiver means for interactive wireless communication with a base communications station |
US4763319A (en) | 1986-05-19 | 1988-08-09 | Bell Communications Research, Inc. | Multi-rate synchronous virtual circuit network for voice and data communications |
US5239662A (en) | 1986-09-15 | 1993-08-24 | Norand Corporation | System including multiple device communications controller which coverts data received from two different customer transaction devices each using different communications protocols into a single communications protocol |
US4717838A (en) | 1986-11-14 | 1988-01-05 | National Semiconductor Corporation | High input impedance, high gain CMOS strobed comparator |
US4727309A (en) | 1987-01-22 | 1988-02-23 | Intel Corporation | Current difference current source |
US4821034A (en) * | 1987-02-06 | 1989-04-11 | Ancor Communications, Inc. | Digital exchange switch element and network |
KR910008738B1 (en) | 1987-02-20 | 1991-10-19 | 닛본 덴기 가부시기가이샤 | Portable radio apparatus having battery saved channel scanning function |
US4817115A (en) | 1987-02-27 | 1989-03-28 | Telxon Corporation | Encoding and decoding system for electronic data communication system |
US4777657A (en) | 1987-04-01 | 1988-10-11 | Iss Engineering, Inc. | Computer controlled broadband receiver |
US4791324A (en) | 1987-04-10 | 1988-12-13 | Motorola, Inc. | CMOS differential-amplifier sense amplifier |
US4804954A (en) | 1987-04-30 | 1989-02-14 | Motorola, Inc. | Battery saving method for portable communications receivers |
US4763105A (en) | 1987-07-08 | 1988-08-09 | Tektronix, Inc. | Interleaved digitizer array with calibrated sample timing |
KR920001576B1 (en) * | 1987-09-09 | 1992-02-18 | 가부시끼가이샤 도시바 | Network system using token-passing bus with multiple priority levels |
US5249302A (en) | 1987-10-09 | 1993-09-28 | Motorola, Inc. | Mixed-mode transceiver system |
US5002057A (en) | 1987-12-28 | 1991-03-26 | G. L. Spaeth | Cover for prism of an applanation tonometer and method of application thereof |
US4970406A (en) | 1987-12-30 | 1990-11-13 | Gazelle Microcircuits, Inc. | Resettable latch circuit |
US5022057A (en) | 1988-03-11 | 1991-06-04 | Hitachi, Ltd. | Bit synchronization circuit |
US4806796A (en) | 1988-03-28 | 1989-02-21 | Motorola, Inc. | Active load for emitter coupled logic gate |
US4905231A (en) | 1988-05-03 | 1990-02-27 | American Telephone And Telegraph Company, At&T Bell Laboratories | Multi-media virtual circuit |
US5055660A (en) | 1988-06-16 | 1991-10-08 | Avicom International, Inc. | Portable transaction monitoring unit for transaction monitoring and security control systems |
US4910713A (en) | 1988-06-27 | 1990-03-20 | Digital Euipment Corporation | High input impedance, strobed CMOS differential sense amplifier |
JP2583578B2 (en) | 1988-07-01 | 1997-02-19 | 三菱電機株式会社 | Pocket phone |
US5117501A (en) | 1988-08-08 | 1992-05-26 | General Electric Company | Dynamic regrouping in a trunked radio communications system |
US5087099A (en) | 1988-09-02 | 1992-02-11 | Stolar, Inc. | Long range multiple point wireless control and monitoring system |
US4916441A (en) | 1988-09-19 | 1990-04-10 | Clinicom Incorporated | Portable handheld terminal |
JP2805767B2 (en) | 1988-09-26 | 1998-09-30 | 日本電気株式会社 | Wireless transceiver |
US4894792A (en) | 1988-09-30 | 1990-01-16 | Tandy Corporation | Portable computer with removable and replaceable add-on modules |
US4968986A (en) | 1988-10-06 | 1990-11-06 | Ideas, Inc. | Wide bandwidth analog-to-digital converter and method |
US5008879B1 (en) | 1988-11-14 | 2000-05-30 | Datapoint Corp | Lan with interoperative multiple operational capabilities |
US4995099A (en) | 1988-12-01 | 1991-02-19 | Motorola, Inc. | Power conservation method and apparatus for a portion of a predetermined signal |
US5025486A (en) | 1988-12-09 | 1991-06-18 | Dallas Semiconductor Corporation | Wireless communication system with parallel polling |
GB2226475A (en) | 1988-12-23 | 1990-06-27 | Philips Electronic Associated | Power economising in multiple user radio systems |
NL8900095A (en) | 1989-01-17 | 1990-08-16 | Philips Nv | TRANSISTOR SWITCH. |
US5150361A (en) | 1989-01-23 | 1992-09-22 | Motorola, Inc. | Energy saving protocol for a TDM radio |
US5128938A (en) | 1989-03-03 | 1992-07-07 | Motorola, Inc. | Energy saving protocol for a communication system |
US5428636A (en) | 1993-05-03 | 1995-06-27 | Norand Corporation | Radio frequency local area network |
US6014705A (en) | 1991-10-01 | 2000-01-11 | Intermec Ip Corp. | Modular portable data processing terminal having a higher layer and lower layer partitioned communication protocol stack for use in a radio frequency communications network |
US5680633A (en) | 1990-01-18 | 1997-10-21 | Norand Corporation | Modular, portable data processing terminal for use in a radio frequency communication network |
US5247656A (en) | 1989-06-01 | 1993-09-21 | Matsushita Electric Industrial Co., Ltd. | Method and apparatus for controlling a clock signal |
US5029183A (en) | 1989-06-29 | 1991-07-02 | Symbol Technologies, Inc. | Packet data communication network |
GB2234371A (en) | 1989-07-07 | 1991-01-30 | Inmos Ltd | Clock generation |
US4969206A (en) | 1989-07-18 | 1990-11-06 | Phyle Industries Limited | Portable data collection device with RF transmission |
DE3929351C1 (en) | 1989-09-04 | 1990-10-11 | Siemens Ag, 1000 Berlin Und 8000 Muenchen, De | |
US5163131A (en) | 1989-09-08 | 1992-11-10 | Auspex Systems, Inc. | Parallel i/o network file server architecture |
US5121408A (en) | 1989-10-16 | 1992-06-09 | Hughes Aircraft Company | Synchronization for entry to a network in a frequency hopping communication system |
JP2508298B2 (en) | 1989-10-18 | 1996-06-19 | 日本電気株式会社 | Digital signal receiving system and receiving apparatus |
AU6721890A (en) | 1989-11-03 | 1991-05-31 | Microcom Systems, Inc. | Method and apparatus for effecting efficient transmission of data |
EP0500794A4 (en) | 1989-11-22 | 1993-02-03 | David C. Russell | Computer control system |
US5153878A (en) | 1989-12-11 | 1992-10-06 | Motorola Inc. | Radio data communications system with diverse signaling capability |
US5055659A (en) | 1990-02-06 | 1991-10-08 | Amtech Technology Corp. | High speed system for reading and writing data from and into remote tags |
JPH0810995Y2 (en) | 1990-02-08 | 1996-03-29 | 沖電気工業株式会社 | Car phone adapter |
DE69126223T2 (en) | 1990-02-14 | 1997-09-18 | Fujitsu Ltd | System for creating a transmission path in a tightly coupled computer system |
DK0518926T3 (en) | 1990-03-03 | 1995-12-18 | Cedardell Ltd | communications systems |
US5084669A (en) | 1990-03-08 | 1992-01-28 | Telefonaktiebolaget L M Ericsson | Direct phase digitization |
GB2241851A (en) | 1990-03-09 | 1991-09-11 | Philips Electronic Associated | Optimising transmitter power in a communications system |
US5085927A (en) | 1990-04-10 | 1992-02-04 | Paragon Films, Inc. | Stretch film cling enhancement by addition of elastomers |
US5041740A (en) | 1990-04-30 | 1991-08-20 | Motorola, Inc. | Parallel clocked latch |
JPH0414314A (en) | 1990-05-08 | 1992-01-20 | Toshiba Corp | Source electrode coupling type logic circuit |
US5179666A (en) | 1990-06-07 | 1993-01-12 | Unisys Corporation | Block oriented peripheral device interface |
US5115151A (en) | 1990-06-08 | 1992-05-19 | Western Digital Corporation | Triple comparator circuit |
EP0778685A3 (en) | 1990-06-29 | 1997-09-17 | Digital Equipment Corp | Frame removal mechanism for token ring network |
US5363121A (en) | 1990-06-29 | 1994-11-08 | International Business Machines Corporation | Multiple protocol communication interface for distributed transaction processing |
US5079452A (en) | 1990-06-29 | 1992-01-07 | Digital Equipment Corporation | High speed ECL latch with clock enable |
FR2664765B1 (en) | 1990-07-11 | 2003-05-16 | Bull Sa | DEVICE FOR SERIALIZATION AND DESERIALIZATION OF DATA AND SYSTEM FOR DIGITAL TRANSMISSION OF SERIAL DATA THEREOF. |
US5584048A (en) | 1990-08-17 | 1996-12-10 | Motorola, Inc. | Beacon based packet radio standby energy saver |
US5119502A (en) | 1990-08-30 | 1992-06-02 | Telefonaktiebolaget L M Ericsson | Periodic system ordered rescan in a cellular communication system |
DE4031522C1 (en) | 1990-10-05 | 1992-04-02 | Horst Dipl.-Ing. 2000 Hamburg De Krauleidies | |
JP2646831B2 (en) | 1990-10-25 | 1997-08-27 | 日本電気株式会社 | Selective call receiver |
US5181200A (en) | 1990-10-29 | 1993-01-19 | International Business Machines Corporation | Handoff method and apparatus for mobile wireless workstation |
US5265270A (en) | 1990-10-31 | 1993-11-23 | Motorola, Inc. | Method and apparatus for providing power conservation in a communication system |
US5179721A (en) | 1990-11-05 | 1993-01-12 | Motorola Inc. | Method for inter operation of a cellular communication system and a trunking communication system |
WO1992010042A1 (en) | 1990-11-26 | 1992-06-11 | Motorola, Inc. | Method and apparatus for paging in a communication system |
US5230084A (en) | 1990-12-06 | 1993-07-20 | Motorola, Inc. | Selective call receiver having extended battery saving capability |
US5216671A (en) | 1990-12-13 | 1993-06-01 | Rca Licensing Corporation | High speed bit serial systems |
US5945585A (en) | 1990-12-20 | 1999-08-31 | E. I. Du Pont De Nemours And Company | Specific for palmitoyl, stearoyl and oleoyl-alp thioesters nucleic acid fragments encoding acyl-acp thiosesterase enzymes and the use of these fragments in altering plant oil composition |
JP2530060B2 (en) | 1991-01-17 | 1996-09-04 | 株式会社東芝 | Communication control device |
US5329192A (en) | 1991-01-17 | 1994-07-12 | Industrial Technology Research Institute | High speed CMOS current switching circuit |
US5297144A (en) | 1991-01-22 | 1994-03-22 | Spectrix Corporation | Reservation-based polling protocol for a wireless data communications network |
US5265238A (en) | 1991-01-25 | 1993-11-23 | International Business Machines Corporation | Automatic device configuration for dockable portable computers |
US5134347A (en) | 1991-02-22 | 1992-07-28 | Comfortex Corporation | Low power consumption wireless data transmission and control system |
US5081402A (en) | 1991-02-22 | 1992-01-14 | Comfortex Corporation | Low power consumption wireless data transmission and control system |
US5152006A (en) | 1991-02-25 | 1992-09-29 | Motorola, Inc. | Receiver controller method and apparatus |
US5148061A (en) | 1991-02-27 | 1992-09-15 | Motorola, Inc. | ECL to CMOS translation and latch logic circuit |
DE69126604T2 (en) | 1991-03-13 | 1998-01-08 | Ibm | Adaptation device and method for the effective connection of data processing devices and networks |
US5162666A (en) | 1991-03-15 | 1992-11-10 | Tran Dzung J | Transmission gate series multiplexer |
CA2040234C (en) | 1991-04-11 | 2000-01-04 | Steven Messenger | Wireless coupling of devices to wired network |
US5249220A (en) | 1991-04-18 | 1993-09-28 | Rts Electronics, Inc. | Handheld facsimile and alphanumeric message transceiver operating over telephone or wireless networks |
JP2930257B2 (en) | 1991-04-22 | 1999-08-03 | 株式会社東芝 | Portable electronic devices |
US5149992A (en) | 1991-04-30 | 1992-09-22 | The State Of Oregon Acting By And Through The State Board Of Higher Education On Behalf Of Oregon State University | MOS folded source-coupled logic |
US5162674A (en) | 1991-05-10 | 1992-11-10 | State Of Oregon Acting By And Through The State Board Of Higher Education On Behalf Of Oregon State University | Current-steering CMOS logic family |
US5940771A (en) | 1991-05-13 | 1999-08-17 | Norand Corporation | Network supporting roaming, sleeping terminals |
US5394436A (en) | 1991-10-01 | 1995-02-28 | Norand Corporation | Radio frequency local area network |
JP2846118B2 (en) | 1991-05-13 | 1999-01-13 | オムニポイント・コーポレイション | Dual mode transmitter and receiver |
US5121121A (en) | 1991-05-15 | 1992-06-09 | United Technologies Corporation | Fast A/D converter |
US5202901A (en) | 1991-05-21 | 1993-04-13 | General Electric Company | Digital discriminator for pulse shaped π/4 shifted differentially encoded quadrature phase shift keying |
JPH04352523A (en) | 1991-05-30 | 1992-12-07 | Oki Electric Ind Co Ltd | Data transmission demodulator |
US5245611A (en) | 1991-05-31 | 1993-09-14 | Motorola, Inc. | Method and apparatus for providing carrier frequency offset compensation in a tdma communication system |
US5123029A (en) | 1991-06-21 | 1992-06-16 | International Business Machines Corporation | Broadcast-initiated bipartite frame multi-access protocol |
US5440752A (en) | 1991-07-08 | 1995-08-08 | Seiko Epson Corporation | Microprocessor architecture with a switch network for data transfer between cache, memory port, and IOU |
GB9114808D0 (en) | 1991-07-09 | 1991-08-28 | Philips Electronic Associated | Information transmission system |
US5239299A (en) | 1991-08-06 | 1993-08-24 | Trw Inc. | Digital equalization of time interleaved analog to digital converters |
US5293639A (en) | 1991-08-09 | 1994-03-08 | Motorola, Inc. | Reduction of power consumption in a portable communication unit |
US5241542A (en) | 1991-08-23 | 1993-08-31 | International Business Machines Corporation | Battery efficient operation of scheduled access protocol |
US5361397A (en) | 1991-08-26 | 1994-11-01 | Motorola, Inc. | Communication device and system capable of automatic programmable energizing |
US5216295A (en) | 1991-08-30 | 1993-06-01 | General Instrument Corp. | Current mode logic circuits employing IGFETS |
US5392023A (en) | 1991-09-06 | 1995-02-21 | Motorola, Inc. | Data communication system with automatic power control |
US5390206A (en) | 1991-10-01 | 1995-02-14 | American Standard Inc. | Wireless communication system for air distribution system |
US5274666A (en) | 1991-10-16 | 1993-12-28 | Telephonics Corporation | Wireless communication system |
US5396224A (en) | 1991-11-22 | 1995-03-07 | Hewlett-Packard Company | Telemetered patient location system and method |
GB2261798B (en) | 1991-11-23 | 1995-09-06 | Dowty Communications Ltd | Packet switching networks |
US5861881A (en) | 1991-11-25 | 1999-01-19 | Actv, Inc. | Interactive computer system for providing an interactive presentation with personalized video, audio and graphics responses for multiple viewers |
JP2571655B2 (en) | 1991-11-27 | 1997-01-16 | インターナショナル・ビジネス・マシーンズ・コーポレイション | Protocol conversion mechanism, switching network and computer system |
US5440560A (en) | 1991-12-24 | 1995-08-08 | Rypinski; Chandos A. | Sleep mode and contention resolution within a common channel medium access method |
SE500357C2 (en) | 1992-01-31 | 1994-06-06 | Silicon Construction Sweden Ab | Arrangements for analogue / digital conversion |
US5196805A (en) | 1992-01-31 | 1993-03-23 | Motorola, Inc. | Distributed differential amplifier arrangement |
US5301196A (en) | 1992-03-16 | 1994-04-05 | International Business Machines Corporation | Half-speed clock recovery and demultiplexer circuit |
US5754792A (en) | 1992-03-19 | 1998-05-19 | Hitachi, Ltd. | Switch circuit comprised of logically split switches for parallel transfer of messages and a parallel processor system using the same |
US5304869A (en) | 1992-04-17 | 1994-04-19 | Intel Corporation | BiCMOS digital amplifier |
EP0567217B1 (en) | 1992-04-20 | 2001-10-24 | 3Com Corporation | System of extending network resources to remote networks |
US5744366A (en) | 1992-05-01 | 1998-04-28 | Trustees Of The University Of Pennsylvania | Mesoscale devices and methods for analysis of motile cells |
US5214317A (en) | 1992-05-04 | 1993-05-25 | National Semiconductor Corporation | CMOS to ECL translator with incorporated latch |
JPH0637797A (en) | 1992-05-20 | 1994-02-10 | Xerox Corp | Reserved ring mechanism of packet exchange network |
US5485490A (en) | 1992-05-28 | 1996-01-16 | Rambus, Inc. | Method and circuitry for clock synchronization |
US5313501A (en) | 1992-06-15 | 1994-05-17 | Digital Equipment Corporation | Method and apparatus for deskewing digital data |
ATE173877T1 (en) | 1992-06-29 | 1998-12-15 | Elonex Technologies Inc | MODULAR PORTABLE CALCULATOR |
SE515076C2 (en) | 1992-07-01 | 2001-06-05 | Ericsson Telefon Ab L M | Multiplexer / demultiplexer circuit |
US5974508A (en) | 1992-07-31 | 1999-10-26 | Fujitsu Limited | Cache memory system and method for automatically locking cache entries to prevent selected memory items from being replaced |
US5298810A (en) | 1992-09-11 | 1994-03-29 | Cypress Semiconductor Corporation | BiCMOS CMOS/ECL data multiplexer |
EP0587938B1 (en) | 1992-09-18 | 1996-03-13 | Siemens Aktiengesellschaft | Integrated buffer circuit |
US5579487A (en) | 1992-10-02 | 1996-11-26 | Teletransaction, Inc. | Portable work slate computer with multiple docking positions for interchangeably receiving removable modules |
EP0590818A3 (en) | 1992-10-02 | 1994-05-11 | Nat Semiconductor Corp | Ecl-to-bicmos/cmos translator |
US5519707A (en) | 1992-10-13 | 1996-05-21 | Synoptics Communications, Inc. | Multiplexing of communications services on a virtual service path in an ATM network or the like |
US5432932A (en) | 1992-10-23 | 1995-07-11 | International Business Machines Corporation | System and method for dynamically controlling remote processes from a performance monitor |
JPH06162782A (en) | 1992-11-17 | 1994-06-10 | Hitachi Ltd | Semiconductor integrated circuit device |
US5289055A (en) | 1992-11-17 | 1994-02-22 | At&T Bell Laboratories | Digital ECL bipolar logic gates suitable for low-voltage operation |
US5426637A (en) | 1992-12-14 | 1995-06-20 | International Business Machines Corporation | Methods and apparatus for interconnecting local area networks with wide area backbone networks |
US5619650A (en) | 1992-12-31 | 1997-04-08 | International Business Machines Corporation | Network processor for transforming a message transported from an I/O channel to a network by adding a message identifier and then converting the message |
US5422917A (en) | 1993-01-04 | 1995-06-06 | Novatel Communications Ltd. | Frequency offset estimation using the phase rotation of channel estimates |
US5355035A (en) | 1993-01-08 | 1994-10-11 | Vora Madhukar B | High speed BICMOS switches and multiplexers |
US5343094A (en) | 1993-01-13 | 1994-08-30 | National Semiconductor Corporation | Low noise logic amplifier with nondifferential to differential conversion |
US5373149A (en) | 1993-02-01 | 1994-12-13 | At&T Bell Laboratories | Folding electronic card assembly |
US5406643A (en) | 1993-02-11 | 1995-04-11 | Motorola, Inc. | Method and apparatus for selecting between a plurality of communication paths |
DE69432732T2 (en) | 1993-03-04 | 2004-04-01 | Telefonaktiebolaget Lm Ericsson | MODULAR RADIO TRANSMISSION ARRANGEMENT |
US5392044A (en) | 1993-03-08 | 1995-02-21 | Motorola, Inc. | Method and apparatus for digitizing a wide frequency bandwidth signal |
WO1994022220A1 (en) | 1993-03-24 | 1994-09-29 | Apple Computer, Inc. | Differential- to single-ended cmos converter |
JPH06284159A (en) | 1993-03-29 | 1994-10-07 | Toshiba Corp | Digital demodulator |
US5630061A (en) | 1993-04-19 | 1997-05-13 | International Business Machines Corporation | System for enabling first computer to communicate over switched network with second computer located within LAN by using media access control driver in different modes |
US5796727A (en) | 1993-04-30 | 1998-08-18 | International Business Machines Corporation | Wide-area wireless lan access |
US5394402A (en) | 1993-06-17 | 1995-02-28 | Ascom Timeplex Trading Ag | Hub for segmented virtual local area network with shared media access |
US5444763A (en) | 1993-06-17 | 1995-08-22 | Research In Motion Limited | Translation and connection device for radio frequency point of sale transaction systems |
US5598437A (en) | 1993-07-16 | 1997-01-28 | Litton Systems, Inc. | Multichannel frequency and phase variable radio frequency simulator |
JP3143277B2 (en) | 1993-07-21 | 2001-03-07 | 株式会社日立製作所 | Differential MOS transmission circuit |
US5418837A (en) | 1993-07-30 | 1995-05-23 | Ericsson-Ge Mobile Communications Inc. | Method and apparatus for upgrading cellular mobile telephones |
US5406615A (en) | 1993-08-04 | 1995-04-11 | At&T Corp. | Multi-band wireless radiotelephone operative in a plurality of air interface of differing wireless communications systems |
US5473607A (en) | 1993-08-09 | 1995-12-05 | Grand Junction Networks, Inc. | Packet filtering for data networks |
US5377182A (en) | 1993-08-18 | 1994-12-27 | The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration | Non-blocking crossbar permutation engine with constant routing latency |
FI97517C (en) | 1993-09-06 | 1996-12-27 | Nokia Mobile Phones Ltd | Packet data transmission in a digital cellular network |
US5548238A (en) | 1993-10-01 | 1996-08-20 | Cirrus Logic Inc. | Low power high speed CMOS current switching circuit |
US5802287A (en) | 1993-10-20 | 1998-09-01 | Lsi Logic Corporation | Single chip universal protocol multi-function ATM network interface |
US5668809A (en) | 1993-10-20 | 1997-09-16 | Lsi Logic Corporation | Single chip network hub with dynamic window filter |
US5887187A (en) | 1993-10-20 | 1999-03-23 | Lsi Logic Corporation | Single chip network adapter apparatus |
US5914955A (en) | 1993-10-20 | 1999-06-22 | Lsi Logic Corporation | Switched network hub on a chip |
US5640399A (en) | 1993-10-20 | 1997-06-17 | Lsi Logic Corporation | Single chip network router |
US5469076A (en) | 1993-10-20 | 1995-11-21 | Hewlett-Packard Corporation | Static current testing apparatus and method for current steering logic (CSL) |
US5544222A (en) | 1993-11-12 | 1996-08-06 | Pacific Communication Sciences, Inc. | Cellular digtial packet data mobile data base station |
US6380775B1 (en) | 1993-11-30 | 2002-04-30 | Analog Devices, Inc. | Multiplexed distribution system for CMOS signals |
JP3337795B2 (en) | 1993-12-10 | 2002-10-21 | 富士通株式会社 | Relay device |
US5510748A (en) | 1994-01-18 | 1996-04-23 | Vivid Semiconductor, Inc. | Integrated circuit having different power supplies for increased output voltage range while retaining small device geometries |
JPH07212421A (en) | 1994-01-19 | 1995-08-11 | Toshiba Corp | Afc circuit |
US5437329A (en) | 1994-01-25 | 1995-08-01 | Baker Hughes Incorporated | Method and apparatus for activation of furnace slag base cement |
US5805927A (en) | 1994-01-28 | 1998-09-08 | Apple Computer, Inc. | Direct memory access channel architecture and method for reception of network information |
US5554945A (en) | 1994-02-15 | 1996-09-10 | Rambus, Inc. | Voltage controlled phase shifter with unlimited range |
AU1841895A (en) | 1994-02-15 | 1995-08-29 | Rambus Inc. | Delay-locked loop |
JPH07302938A (en) | 1994-04-28 | 1995-11-14 | Sony Corp | Piezoelectric ceramic transformer and manufacture thereof |
US5420529A (en) | 1994-05-19 | 1995-05-30 | Northern Telecom Limited | Current steering switch and hybrid BiCMOS multiplexer with CMOS commutation signal and CML/ECL data signals |
EP0683457A1 (en) | 1994-05-20 | 1995-11-22 | Advanced Micro Devices, Inc. | A computer system including a snoop control circuit |
KR970002949B1 (en) | 1994-05-25 | 1997-03-13 | 삼성전자 주식회사 | A circuit and method for generating clock of digital communication system |
CA2124745C (en) | 1994-05-31 | 2001-11-20 | Brian D. Gerson | High-speed cmos pseudo-ecl output driver |
US5714904A (en) | 1994-06-06 | 1998-02-03 | Sun Microsystems, Inc. | High speed serial link for fully duplexed data communication |
US5465060A (en) | 1994-06-10 | 1995-11-07 | International Business Machines Corporation | Fast edge triggered self-resetting CMOS receiver with parallel L1/L2 (Master/Slave) latch |
JP2713167B2 (en) | 1994-06-14 | 1998-02-16 | 日本電気株式会社 | Comparator |
US5600267A (en) | 1994-06-24 | 1997-02-04 | Cypress Semiconductor Corporation | Apparatus for a programmable CML to CMOS translator for power/speed adjustment |
US5757857A (en) | 1994-07-21 | 1998-05-26 | The Regents Of The University Of California | High speed self-adjusting clock recovery circuit with frequency detection |
US5552489A (en) | 1994-07-22 | 1996-09-03 | Exxon Chemical Patents Inc. | Tackifiers and a process to obtain tackifiers |
FR2723282B1 (en) | 1994-07-29 | 1996-09-13 | Alcatel Telspace | METHOD FOR INTERLEAVING AND DE-INTERLACING SDH FRAMES AND SYSTEM THEREOF |
FR2723494B1 (en) | 1994-08-04 | 1996-09-06 | Bull Sa | METHOD FOR SAMPLING A SERIAL DIGITAL SIGNAL |
US5488319A (en) | 1994-08-18 | 1996-01-30 | International Business Machines Corporation | Latch interface for self-reset logic |
JP2630272B2 (en) | 1994-08-25 | 1997-07-16 | 日本電気株式会社 | Semiconductor integrated circuit |
US5583859A (en) | 1994-08-30 | 1996-12-10 | Bell Communications Research, Inc. | Data labeling technique for high performance protocol processing |
US5521530A (en) | 1994-08-31 | 1996-05-28 | Oki Semiconductor America, Inc. | Efficient method and resulting structure for integrated circuits with flexible I/O interface and power supply voltages |
JP2600619B2 (en) | 1994-09-28 | 1997-04-16 | 日本電気株式会社 | Current mode logic circuit |
US5566177A (en) * | 1994-10-09 | 1996-10-15 | International Business Machines Corporation | Priority-based arbitrator on a token-based communication medium |
FR2725573B1 (en) | 1994-10-11 | 1996-11-15 | Thomson Csf | METHOD AND DEVICE FOR CONTROLLING CONGESTION OF SPORADIC EXCHANGES OF DATA PACKETS IN A DIGITAL TRANSMISSION NETWORK |
US5598541A (en) | 1994-10-24 | 1997-01-28 | Lsi Logic Corporation | Node loop port communication interface super core for fibre channel |
FR2726141B1 (en) | 1994-10-25 | 1997-01-03 | Alcatel Mobile Comm France | CORRECTION OF A FREQUENCY OFFSET |
US5519695A (en) | 1994-10-27 | 1996-05-21 | Hewlett-Packard Company | Switch element for fiber channel networks |
US5502719A (en) * | 1994-10-27 | 1996-03-26 | Hewlett-Packard Company | Path allocation system and method having double link list queues implemented with a digital signal processor (DSP) for a high performance fiber optic switch |
JP3519143B2 (en) | 1994-11-17 | 2004-04-12 | 三菱電機株式会社 | Current type inverter circuit, current type logic circuit, current type latch circuit, semiconductor integrated circuit, current type ring oscillator, voltage controlled oscillator, and PLL circuit |
US5561655A (en) | 1994-12-02 | 1996-10-01 | Eastman Kodak Company | Apparatus and method for differential tracking in a magneto-optic data storage system using mark edge detection |
JP3234732B2 (en) | 1995-01-09 | 2001-12-04 | 株式会社東芝 | Level conversion circuit |
US5857075A (en) | 1995-01-11 | 1999-01-05 | Sony Corporation | Method and integrated circuit for high-bandwidth network server interfacing to a local area network |
US5525914A (en) | 1995-01-23 | 1996-06-11 | International Business Machines Corporation | CMOS driver circuit |
JP2728013B2 (en) | 1995-03-10 | 1998-03-18 | 日本電気株式会社 | BiCMOS logic gate circuit |
US5546433A (en) | 1995-03-21 | 1996-08-13 | National Semiconductor Corporation | Digital phase lock loop having frequency offset cancellation circuitry |
US5574724A (en) | 1995-05-26 | 1996-11-12 | Lucent Technologies Inc. | Adjustment of call bandwidth during a communication call |
US5675583A (en) | 1995-05-26 | 1997-10-07 | Lucent Technologies Inc. | Variable communication bandwidth for conference call initiation |
US5548231A (en) | 1995-06-02 | 1996-08-20 | Translogic Technology, Inc. | Serial differential pass gate logic design |
US5603051A (en) | 1995-06-06 | 1997-02-11 | Hewlett-Packard Company | Input/output processor with a local memory providing shared resources for a plurality of input/output interfaces on an I/O bus |
US5570356A (en) | 1995-06-07 | 1996-10-29 | International Business Machines Corporation | High bandwidth communications system having multiple serial links |
JPH08335860A (en) | 1995-06-08 | 1996-12-17 | Mitsubishi Electric Corp | Differential latch circuit |
US5798658A (en) | 1995-06-15 | 1998-08-25 | Werking; Paul M. | Source-coupled logic with reference controlled inputs |
US5906235A (en) | 1995-06-16 | 1999-05-25 | Thomas Robert Anthony | Pressurized squeeze casting apparatus and method and low pressure furnace for use therewith |
US5565794A (en) | 1995-06-23 | 1996-10-15 | Advanced Micro Devices, Inc. | Voltage range tolerant CMOS output buffer with reduced input capacitance |
US5768268A (en) | 1995-07-19 | 1998-06-16 | Watkins Johnson Company | Wideband base station architecture for digital cellular communications system |
GB9515842D0 (en) | 1995-08-02 | 1995-10-04 | British Tech Group Int | Frequency detection |
US5748612A (en) | 1995-08-10 | 1998-05-05 | Mcdata Corporation | Method and apparatus for implementing virtual circuits in a fibre channel system |
US5714906A (en) | 1995-08-14 | 1998-02-03 | Motamed; Ali | Constant transductance input stage and integrated circuit implementations thereof |
US5887146A (en) | 1995-08-14 | 1999-03-23 | Data General Corporation | Symmetric multiprocessing computer with non-uniform memory access architecture |
US5717871A (en) | 1995-08-17 | 1998-02-10 | I-Cube, Inc. | Crossbar switch with input/output buffers having multiplexed control inputs |
JPH0993118A (en) | 1995-09-22 | 1997-04-04 | Kawasaki Steel Corp | Path transistor logic circuit |
KR0179842B1 (en) | 1995-09-27 | 1999-04-01 | 문정환 | Current source circuit |
US5826027A (en) | 1995-10-11 | 1998-10-20 | Citrix Systems, Inc. | Method for supporting an extensible and dynamically bindable protocol stack in a distrubited process system |
US5760984A (en) | 1995-10-20 | 1998-06-02 | Cirrus Logic, Inc. | Cost reduced interpolated timing recovery in a sampled amplitude read channel |
AU7450496A (en) | 1995-10-20 | 1997-05-07 | Collagen Corporation | Production of recombinant procollagen in yeast |
US5610745A (en) | 1995-10-26 | 1997-03-11 | Hewlett-Packard Co. | Method and apparatus for tracking buffer availability |
JP3149759B2 (en) | 1995-11-17 | 2001-03-26 | 日本電気株式会社 | Latch circuit |
US5892932A (en) | 1995-11-21 | 1999-04-06 | Fore Systems, Inc. | Reprogrammable switching apparatus and method |
DE19649075B4 (en) | 1995-11-29 | 2005-04-14 | Matsushita Electric Industrial Co., Ltd., Kadoma | Digital recording and reproducing apparatus for audio / video data |
JPH09153593A (en) | 1995-11-30 | 1997-06-10 | Nec Corp | Bimos logic circuit |
US5684805A (en) | 1995-11-30 | 1997-11-04 | Brown; Anthony Kevin Dale | Microwave multiphase detector |
JP2978752B2 (en) | 1995-12-13 | 1999-11-15 | 日本電気株式会社 | ATM silence compression method |
US5909127A (en) | 1995-12-22 | 1999-06-01 | International Business Machines Corporation | Circuits with dynamically biased active loads |
US5777987A (en) | 1995-12-29 | 1998-07-07 | Symbios, Inc. | Method and apparatus for using multiple FIFOs to improve flow control and routing in a communications receiver |
US5640356A (en) | 1995-12-29 | 1997-06-17 | Cypress Semiconductor Corp. | Two-stage differential sense amplifier with positive feedback in the first and second stages |
US5793225A (en) | 1996-01-02 | 1998-08-11 | Pmc-Sierra, Inc. | CMOS SONET/ATM receiver suitable for use with pseudo ECL and TTL signaling environments |
US5748020A (en) | 1996-02-02 | 1998-05-05 | Lsi Logic Corporation | High speed capture latch |
US6373846B1 (en) | 1996-03-07 | 2002-04-16 | Lsi Logic Corporation | Single chip networking device with enhanced memory access co-processor |
US5724361A (en) | 1996-03-12 | 1998-03-03 | Lsi Logic Corporation | High performance n:1 multiplexer with overlap control of multi-phase clocks |
US5821908A (en) | 1996-03-22 | 1998-10-13 | Ball Aerospace And Technologies Corp. | Spherical lens antenna having an electronically steerable beam |
US5689644A (en) * | 1996-03-25 | 1997-11-18 | I-Cube, Inc. | Network switch with arbitration sytem |
US5742604A (en) | 1996-03-28 | 1998-04-21 | Cisco Systems, Inc. | Interswitch link mechanism for connecting high-performance network switches |
JP3047808B2 (en) | 1996-03-28 | 2000-06-05 | 日本電気株式会社 | Flip-flop circuit |
GB2311880A (en) | 1996-04-03 | 1997-10-08 | Advanced Risc Mach Ltd | Partitioned cache memory |
US5828653A (en) | 1996-04-26 | 1998-10-27 | Cascade Communications Corp. | Quality of service priority subclasses |
US5802258A (en) | 1996-05-03 | 1998-09-01 | International Business Machines Corporation | Loosely coupled system environment designed to handle a non-disruptive host connection switch after detection of an error condition or during a host outage or failure |
US5748631A (en) | 1996-05-09 | 1998-05-05 | Maker Communications, Inc. | Asynchronous transfer mode cell processing system with multiple cell source multiplexing |
US5821809A (en) | 1996-05-23 | 1998-10-13 | International Business Machines Corporation | CMOS high-speed differential to single-ended converter circuit |
US5767699A (en) | 1996-05-28 | 1998-06-16 | Sun Microsystems, Inc. | Fully complementary differential output driver for high speed digital communications |
US5859881A (en) | 1996-06-07 | 1999-01-12 | International Business Machines Corporation | Adaptive filtering method and apparatus to compensate for a frequency difference between two clock sources |
US5778414A (en) | 1996-06-13 | 1998-07-07 | Racal-Datacom, Inc. | Performance enhancing memory interleaver for data frame processing |
JP3230655B2 (en) | 1996-06-17 | 2001-11-19 | 日本電気株式会社 | Dynamic latch circuit and flip-flop circuit |
US5680038A (en) | 1996-06-20 | 1997-10-21 | Lsi Logic Corporation | High-swing cascode current mirror |
US5783953A (en) | 1996-07-01 | 1998-07-21 | Sun Microsystems, Inc. | CMOS current controlled delay element using cascoded complementary differential amplifiers with replicated bias clamp |
US5893150A (en) | 1996-07-01 | 1999-04-06 | Sun Microsystems, Inc. | Efficient allocation of cache memory space in a computer system |
US5802576A (en) | 1996-07-01 | 1998-09-01 | Sun Microsystems, Inc. | Speculative cache snoop during DMA line update |
US5859548A (en) | 1996-07-24 | 1999-01-12 | Lg Semicon Co., Ltd. | Charge recycling differential logic (CRDL) circuit and devices using the same |
US5893153A (en) | 1996-08-02 | 1999-04-06 | Sun Microsystems, Inc. | Method and apparatus for preventing a race condition and maintaining cache coherency in a processor with integrated cache memory and input/output control |
US5886541A (en) | 1996-08-05 | 1999-03-23 | Fujitsu Limited | Combined logic gate and latch |
US5991817A (en) | 1996-09-06 | 1999-11-23 | Cisco Systems, Inc. | Apparatus and method for a network router |
US5751715A (en) * | 1996-08-08 | 1998-05-12 | Gadzoox Microsystems, Inc. | Accelerator fiber channel hub and protocol |
US5903176A (en) | 1996-09-04 | 1999-05-11 | Litton Systems, Inc. | Clock circuit for generating a high resolution output from a low resolution clock |
US5805089A (en) | 1996-09-05 | 1998-09-08 | Lsi Logic Corporation | Time-division data multiplexer with feedback for clock cross-over adjustment |
US5894481A (en) | 1996-09-11 | 1999-04-13 | Mcdata Corporation | Fiber channel switch employing distributed queuing |
US5862355A (en) | 1996-09-12 | 1999-01-19 | Telxon Corporation | Method and apparatus for overriding bus prioritization scheme |
US6209020B1 (en) | 1996-09-20 | 2001-03-27 | Nortel Networks Limited | Distributed pipeline memory architecture for a computer system with even and odd pids |
JP3015747B2 (en) | 1996-10-29 | 2000-03-06 | 株式会社ミツトヨ | Encoder interpolation circuit |
JPH10143613A (en) | 1996-10-30 | 1998-05-29 | Hewlett Packard Co <Hp> | Pattern recognition method |
US6697931B1 (en) | 1996-10-31 | 2004-02-24 | Stmicroelectronics Limited | System and method for communicating information to and from a single chip computer system through an external communication port with translation circuitry |
US6202125B1 (en) | 1996-11-25 | 2001-03-13 | Intel Corporation | Processor-cache protocol using simple commands to implement a range of cache configurations |
US5859669A (en) | 1996-11-26 | 1999-01-12 | Texas Instruments Incorporated | System for encoding an image control signal onto a pixel clock signal |
US6097722A (en) | 1996-12-13 | 2000-08-01 | Nortel Networks Corporation | Bandwidth management processes and systems for asynchronous transfer mode networks using variable virtual paths |
US5953338A (en) | 1996-12-13 | 1999-09-14 | Northern Telecom Limited | Dynamic control processes and systems for asynchronous transfer mode networks |
US5829025A (en) | 1996-12-17 | 1998-10-27 | Intel Corporation | Computer system and method of allocating cache memories in a multilevel cache hierarchy utilizing a locality hint within an instruction |
US20020103988A1 (en) | 1996-12-18 | 2002-08-01 | Pascal Dornier | Microprocessor with integrated interfaces to system memory and multiplexed input/output bus |
US6025746A (en) | 1996-12-23 | 2000-02-15 | Stmicroelectronics, Inc. | ESD protection circuits |
US6266797B1 (en) | 1997-01-16 | 2001-07-24 | Advanced Micro Devices, Inc. | Data transfer network on a computer chip using a re-configurable path multiple ring topology |
US5908468A (en) | 1997-10-24 | 1999-06-01 | Advanced Micro Devices, Inc. | Data transfer network on a chip utilizing a multiple traffic circle topology |
US6111859A (en) | 1997-01-16 | 2000-08-29 | Advanced Micro Devices, Inc. | Data transfer network on a computer chip utilizing combined bus and ring topologies |
US5789989A (en) | 1997-01-23 | 1998-08-04 | International Business Machines Corporation | Delay interpolating voltage-controlled oscillator with linear transfer function |
US6128305A (en) | 1997-01-31 | 2000-10-03 | At&T Corp. | Architecture for lightweight signaling in ATM networks |
US6125157A (en) | 1997-02-06 | 2000-09-26 | Rambus, Inc. | Delay-locked loop circuitry for clock delay adjustment |
US6061358A (en) | 1997-02-13 | 2000-05-09 | Mcdata Corporation | Data communication system utilizing a scalable, non-blocking, high bandwidth central memory controller and method |
US6058427A (en) | 1997-02-14 | 2000-05-02 | Advanced Micro Devices, Inc. | Apparatus and method for generating a serial data stream carrying data for multiple network switch ports for use by a physical transceiver |
US6061351A (en) | 1997-02-14 | 2000-05-09 | Advanced Micro Devices, Inc. | Multicopy queue structure with searchable cache area |
US6185203B1 (en) | 1997-02-18 | 2001-02-06 | Vixel Corporation | Fibre channel switching fabric |
US6026075A (en) | 1997-02-25 | 2000-02-15 | International Business Machines Corporation | Flow control mechanism |
US5892922A (en) | 1997-02-28 | 1999-04-06 | 3Com Corporation | Virtual local area network memory access system |
JP3681497B2 (en) | 1997-03-05 | 2005-08-10 | 株式会社ルネサステクノロジ | Flip-flop circuit, shift register circuit, serial-parallel conversion circuit, parallel-serial conversion circuit, and latch circuit |
JP3579208B2 (en) | 1997-03-11 | 2004-10-20 | 株式会社東芝 | Node device and message exchange method |
US6160813A (en) | 1997-03-21 | 2000-12-12 | Brocade Communications Systems, Inc. | Fibre channel switching system and method |
JP3715066B2 (en) | 1997-03-25 | 2005-11-09 | 三菱電機株式会社 | Current mode logic circuit |
US6356944B1 (en) | 1997-03-31 | 2002-03-12 | Compaq Information Technologies Group, L.P. | System and method for increasing write performance in a fibre channel environment |
JP3060987B2 (en) | 1997-03-31 | 2000-07-10 | 日本電気株式会社 | Clock synchronous flip-flop circuit |
US6504817B2 (en) | 1997-03-31 | 2003-01-07 | Hewlett-Packard Company | Fiber channel arbitrated loop dynamic loop sizing |
US6038226A (en) * | 1997-03-31 | 2000-03-14 | Ericcson Inc. | Combined signalling and PCM cross-connect and packet engine |
US6000020A (en) | 1997-04-01 | 1999-12-07 | Gadzoox Networks, Inc. | Hierarchical storage management from a mirrored file system on a storage network segmented by a bridge |
US6141376A (en) | 1997-04-01 | 2000-10-31 | Lsi Logic Corporation | Single chip communication device that implements multiple simultaneous communication channels |
GB9707349D0 (en) | 1997-04-11 | 1997-05-28 | Univ Waterloo | A dynamic current mode logic family |
US5939899A (en) | 1997-04-23 | 1999-08-17 | Lucent Technologies Inc. | MOSFET substrate current logic |
JP3063721B2 (en) | 1997-04-30 | 2000-07-12 | 日本電気株式会社 | Topology information exchange device and machine-readable recording medium recording program |
US5951637A (en) | 1997-05-07 | 1999-09-14 | Intel Corporation | Bandwidth reservation system |
US5945847A (en) | 1997-05-20 | 1999-08-31 | Lucent Technologies | Distributed amplifier logic designs |
JP3003625B2 (en) | 1997-06-05 | 2000-01-31 | 日本電気株式会社 | CMLCMOS conversion circuit |
GB9711788D0 (en) | 1997-06-06 | 1997-08-06 | Northern Telecom Ltd | Method and interface for connecting communication traffic between narrowband and broadband networks |
JP3134810B2 (en) | 1997-06-09 | 2001-02-13 | 日本電気株式会社 | Bandwidth control method and bandwidth control method |
US6247138B1 (en) | 1997-06-12 | 2001-06-12 | Fujitsu Limited | Timing signal generating circuit, semiconductor integrated circuit device and semiconductor integrated circuit system to which the timing signal generating circuit is applied, and signal transmission system |
US5978849A (en) | 1997-06-13 | 1999-11-02 | International Business Machines Corporation | Systems, methods, and computer program products for establishing TCP connections using information from closed TCP connections in time-wait state |
US5945863A (en) | 1997-06-18 | 1999-08-31 | Applied Micro Circuits Corporation | Analog delay circuit |
US5909686A (en) | 1997-06-30 | 1999-06-01 | Sun Microsystems, Inc. | Hardware-assisted central processing unit access to a forwarding database |
US5961631A (en) | 1997-07-16 | 1999-10-05 | Arm Limited | Data processing apparatus and method for pre-fetching an instruction in to an instruction cache |
US6404525B1 (en) | 1997-07-31 | 2002-06-11 | Nec Corporation | Optical add-drop multiplexer |
US6018260A (en) | 1997-08-06 | 2000-01-25 | Lucent Technologies Inc. | High-speed clock-enabled latch circuit |
US6008670A (en) | 1997-08-19 | 1999-12-28 | Hewlett-Packard | Differential CMOS logic family |
US5970070A (en) | 1997-08-20 | 1999-10-19 | Sun Microsystems, Inc. | Communication controllers and methods therefor |
US6194950B1 (en) | 1997-08-28 | 2001-02-27 | Lucent Technologies Inc. | High-speed CMOS multiplexer |
US6122336A (en) | 1997-09-11 | 2000-09-19 | Lsi Logic Corporation | Digital clock recovery circuit with phase interpolation |
US6014041A (en) | 1997-09-26 | 2000-01-11 | Intel Corporation | Differential current switch logic gate |
JPH11103303A (en) | 1997-09-26 | 1999-04-13 | Sony Corp | Network resource reservation control method and system, reception terminal, transmission terminal and repeater |
US6266799B1 (en) | 1997-10-02 | 2001-07-24 | Xaqti, Corporation | Multi-phase data/clock recovery circuitry and methods for implementing same |
US6192048B1 (en) | 1997-10-02 | 2001-02-20 | Mcdata Corporation | Method and apparatus for implementing hunt group support for a crosspoint controller |
US6037841A (en) | 1997-10-07 | 2000-03-14 | Applied Micro Circuits Corporation | Impedance matched CMOS transimpedance amplifier for high-speed fiber optic communications |
US6307906B1 (en) | 1997-10-07 | 2001-10-23 | Applied Micro Circuits Corporation | Clock and data recovery scheme for multi-channel data communications receivers |
US5963053A (en) | 1997-10-09 | 1999-10-05 | Pericom Semiconductor Corp. | Self-biasing CMOS PECL receiver with wide common-mode range and multi-level-transmit to binary decoder |
US6133773A (en) | 1997-10-10 | 2000-10-17 | Rambus Inc | Variable delay element |
US6061742A (en) | 1997-10-10 | 2000-05-09 | Nortel Networks Corporation | Computer network adaptor |
US6389479B1 (en) | 1997-10-14 | 2002-05-14 | Alacritech, Inc. | Intelligent network interface device and system for accelerated communication |
US6434620B1 (en) | 1998-08-27 | 2002-08-13 | Alacritech, Inc. | TCP/IP offload network interface device |
US6697868B2 (en) | 2000-02-28 | 2004-02-24 | Alacritech, Inc. | Protocol processing stack for use with intelligent network interface device |
US6658480B2 (en) | 1997-10-14 | 2003-12-02 | Alacritech, Inc. | Intelligent network interface system and method for accelerated protocol processing |
US6427173B1 (en) | 1997-10-14 | 2002-07-30 | Alacritech, Inc. | Intelligent network interfaced device and system for accelerated communication |
US7185266B2 (en) | 2003-02-12 | 2007-02-27 | Alacritech, Inc. | Network interface device for error detection using partial CRCS of variable length message portions |
US7133940B2 (en) | 1997-10-14 | 2006-11-07 | Alacritech, Inc. | Network interface device employing a DMA command queue |
US7167927B2 (en) | 1997-10-14 | 2007-01-23 | Alacritech, Inc. | TCP/IP offload device with fast-path TCP ACK generating and transmitting mechanism |
US6226680B1 (en) | 1997-10-14 | 2001-05-01 | Alacritech, Inc. | Intelligent network interface system method for protocol processing |
US6687758B2 (en) | 2001-03-07 | 2004-02-03 | Alacritech, Inc. | Port aggregation for network connections that are offloaded to network interface devices |
US6757746B2 (en) | 1997-10-14 | 2004-06-29 | Alacritech, Inc. | Obtaining a destination address so that a network interface device can write network data without headers directly into host memory |
US6560305B1 (en) | 1997-10-15 | 2003-05-06 | Analog Devices, Inc. | Frequency detector |
US6424624B1 (en) | 1997-10-16 | 2002-07-23 | Cisco Technology, Inc. | Method and system for implementing congestion detection and flow control in high speed digital network |
US6061747A (en) | 1997-10-16 | 2000-05-09 | Lsi Logic Corporation | System for sending data from-and-to a computer monitor using a high speed serial line |
US5977800A (en) | 1997-10-20 | 1999-11-02 | Vlsi Technology, Inc. | Differential MOS current-mode logic circuit having high gain and fast speed |
US6002279A (en) | 1997-10-24 | 1999-12-14 | G2 Networks, Inc. | Clock recovery circuit |
US5937169A (en) | 1997-10-29 | 1999-08-10 | 3Com Corporation | Offload of TCP segmentation to a smart adapter |
JP3316744B2 (en) | 1997-10-30 | 2002-08-19 | 三菱電機株式会社 | AFC circuit, receiver having the same, and automatic frequency control communication system |
US6247139B1 (en) | 1997-11-11 | 2001-06-12 | Compaq Computer Corp. | Filesystem failover in a single system image environment |
US6128673A (en) | 1997-11-14 | 2000-10-03 | Aronson; Michael D. | Method and apparatus for communication and translation of a plurality of digital protocols |
US6201443B1 (en) | 1997-11-20 | 2001-03-13 | Applied Micro Circuits Corporation | Radio frequency variable gain amplifier fabricated in complementary metal oxide semiconductor technology |
US6185185B1 (en) | 1997-11-21 | 2001-02-06 | International Business Machines Corporation | Methods, systems and computer program products for suppressing multiple destination traffic in a computer network |
US6151662A (en) | 1997-12-02 | 2000-11-21 | Advanced Micro Devices, Inc. | Data transaction typing for improved caching and prefetching characteristics |
JP3109465B2 (en) | 1997-12-04 | 2000-11-13 | 日本電気株式会社 | Digital PLL circuit and signal reproducing method |
US6700890B1 (en) | 1997-12-22 | 2004-03-02 | Cisco Technology, Inc. | Method and apparatus for configuring permanent virtual connection (PVC) information stored on network devices in an ATM network logically configured with subnetworks |
US6810040B1 (en) | 1997-12-22 | 2004-10-26 | Cisco Technology, Inc. | Method and apparatus for configuring network devices |
US6167077A (en) | 1997-12-23 | 2000-12-26 | Lsi Logic Corporation | Using multiple high speed serial lines to transmit high data rates while compensating for overall skew |
SE513044C2 (en) | 1997-12-29 | 2000-06-26 | Ericsson Telefon Ab L M | Analog-digital converter with global clock and global switch |
US6343081B1 (en) | 1997-12-30 | 2002-01-29 | International Business Machines Corporation | Method and apparatus for managing contention in a self-routing switching architecture in a port expansion mode |
US6493343B1 (en) | 1998-01-07 | 2002-12-10 | Compaq Information Technologies Group | System and method for implementing multi-pathing data transfers in a system area network |
US5970110A (en) | 1998-01-09 | 1999-10-19 | Neomagic Corp. | Precise, low-jitter fractional divider using counter of rotating clock phases |
US6560290B2 (en) | 1998-01-20 | 2003-05-06 | Silicon Image, Inc. | CMOS driver and on-chip termination for gigabaud speed data communication |
US6188339B1 (en) | 1998-01-23 | 2001-02-13 | Fuji Photo Film Co., Ltd. | Differential multiplexer and differential logic circuit |
US6111445A (en) | 1998-01-30 | 2000-08-29 | Rambus Inc. | Phase interpolator with noise immunity |
US6016082A (en) | 1998-02-13 | 2000-01-18 | Sun Microsystems, Inc. | Low phase noise LC oscillator for microprocessor clock distribution |
US6178159B1 (en) | 1998-03-02 | 2001-01-23 | Lucent Technologies Inc. | Available bit rate flow control algorithms for ATM networks |
US6194949B1 (en) | 1998-03-04 | 2001-02-27 | Nortel Networks Limited | Driver circuit for high speed data |
US6397042B1 (en) | 1998-03-06 | 2002-05-28 | Texas Instruments Incorporated | Self test of an electronic device |
US6151647A (en) | 1998-03-26 | 2000-11-21 | Gemplus | Versatile interface smart card |
US6073132A (en) * | 1998-03-27 | 2000-06-06 | Lsi Logic Corporation | Priority arbiter with shifting sequential priority scheme |
US6202129B1 (en) | 1998-03-31 | 2001-03-13 | Intel Corporation | Shared cache structure for temporal and non-temporal information using indicative bits |
US6279035B1 (en) | 1998-04-10 | 2001-08-21 | Nortel Networks Limited | Optimizing flow detection and reducing control plane processing in a multi-protocol over ATM (MPOA) system |
US6349098B1 (en) | 1998-04-17 | 2002-02-19 | Paxonet Communications, Inc. | Method and apparatus for forming a virtual circuit |
US6426947B1 (en) | 1998-10-21 | 2002-07-30 | Kim K. Banker | Apparatus and method for unilateral topology discovery in network management |
US6037842A (en) | 1998-04-21 | 2000-03-14 | Applied Micro Circuits Corporation | Complementary metal-oxide semiconductor voltage controlled oscillator (CMOS VCO) |
US5955924A (en) | 1998-04-21 | 1999-09-21 | Applied Micro Circuits Corporation | Differential metal-oxide semiconductor (CMOS) push-pull buffer |
US6374361B1 (en) | 1998-04-23 | 2002-04-16 | Silicon Image, Inc. | Skew-insensitive low voltage differential receiver |
US6377571B1 (en) | 1998-04-23 | 2002-04-23 | 3Com Corporation | Virtual modem for dialout clients in virtual private network |
US6157652A (en) | 1998-05-01 | 2000-12-05 | Emulex Corporation | Hub port with constant phase |
US6314488B1 (en) | 1998-05-12 | 2001-11-06 | Crossroads Systems, Inc. | System for segmenting a fibre channel arbitrated loop to a plurality of logical sub-loops using segmentation router as a master to cause the segmentation of physical addresses |
US6636485B1 (en) | 1998-05-14 | 2003-10-21 | 3Com Corporation | Method and system for providing quality-of-service in a data-over-cable system |
US6121808A (en) | 1998-05-18 | 2000-09-19 | National Semiconductor Corporation | DLL calibrated phase multiplexer and interpolator |
US6065087A (en) | 1998-05-21 | 2000-05-16 | Hewlett-Packard Company | Architecture for a high-performance network/bus multiplexer interconnecting a network and a bus that transport data using multiple protocols |
US6098064A (en) | 1998-05-22 | 2000-08-01 | Xerox Corporation | Prefetching and caching documents according to probability ranked need S list |
GB2337905B (en) | 1998-05-28 | 2003-02-12 | 3Com Technologies Ltd | Buffer management in network devices |
US6085278A (en) | 1998-06-02 | 2000-07-04 | Adaptec, Inc. | Communications interface adapter for a computer system including posting of system interrupt status |
US6765901B1 (en) | 1998-06-11 | 2004-07-20 | Nvidia Corporation | TCP/IP/PPP modem |
US6141705A (en) | 1998-06-12 | 2000-10-31 | Microsoft Corporation | System for querying a peripheral device to determine its processing capabilities and then offloading specific processing tasks from a host to the peripheral device when needed |
US6904519B2 (en) | 1998-06-12 | 2005-06-07 | Microsoft Corporation | Method and computer program product for offloading processing tasks from software to hardware |
US6222380B1 (en) | 1998-06-15 | 2001-04-24 | International Business Machines Corporation | High speed parallel/serial link for data communication |
DE19829216C1 (en) * | 1998-06-30 | 2000-03-02 | Fraunhofer Ges Forschung | Electromechanical transducer and manufacturing method |
US6081215A (en) | 1998-07-06 | 2000-06-27 | Motorola, Inc. | High speed interlaced analog interface |
US6640248B1 (en) | 1998-07-10 | 2003-10-28 | Malibu Networks, Inc. | Application-aware, quality of service (QoS) sensitive, media access control (MAC) layer |
US20020089353A1 (en) | 1998-07-13 | 2002-07-11 | Abdellatif Bellaouar | Current mode logic gates for low-voltage high-speed applications |
US6094074A (en) | 1998-07-16 | 2000-07-25 | Seiko Epson Corporation | High speed common mode logic circuit |
JP3510794B2 (en) | 1998-07-21 | 2004-03-29 | シャープ株式会社 | Signal processing device and communication device |
US6483355B1 (en) | 1998-07-24 | 2002-11-19 | Gct Semiconductor, Inc. | Single chip CMOS transmitter/receiver and method of using same |
US6335952B1 (en) | 1998-07-24 | 2002-01-01 | Gct Semiconductor, Inc. | Single chip CMOS transmitter/receiver |
US6064626A (en) | 1998-07-31 | 2000-05-16 | Arm Limited | Peripheral buses for integrated circuit |
JP2000059203A (en) | 1998-08-10 | 2000-02-25 | Toshiba Corp | Logic circuit for deciding logic by current |
US6223239B1 (en) | 1998-08-12 | 2001-04-24 | Compaq Computer Corporation | Dual purpose apparatus, method and system for accelerated graphics port or system area network interface |
US6215497B1 (en) | 1998-08-12 | 2001-04-10 | Monolithic System Technology, Inc. | Method and apparatus for maximizing the random access bandwidth of a multi-bank DRAM in a computer graphics system |
US6114843A (en) | 1998-08-18 | 2000-09-05 | Xilinx, Inc. | Voltage down converter for multiple voltage levels |
JP2949624B1 (en) | 1998-09-01 | 1999-09-20 | 株式会社超高速ネットワーク・コンピュータ技術研究所 | Connection control method for Fiber Channel connection equipment |
US6104068A (en) | 1998-09-01 | 2000-08-15 | Micron Technology, Inc. | Structure and method for improved signal processing |
US6463092B1 (en) | 1998-09-10 | 2002-10-08 | Silicon Image, Inc. | System and method for sending and receiving data signals over a clock signal line |
US6337865B1 (en) * | 1998-09-23 | 2002-01-08 | Maxtor Corporation | Fair buffer credit distribution flow control |
US6111425A (en) | 1998-10-15 | 2000-08-29 | International Business Machines Corporation | Very low power logic circuit family with enhanced noise immunity |
US6134268A (en) | 1998-10-19 | 2000-10-17 | Motorola, Inc. | Apparatus for performing a non-integer sampling rate change in a multichannel polyphase filter |
GB2343092B (en) | 1998-10-22 | 2003-05-14 | 3Com Technologies Ltd | Framing codes for high-speed parallel data buses |
US6765919B1 (en) | 1998-10-23 | 2004-07-20 | Brocade Communications Systems, Inc. | Method and system for creating and implementing zones within a fibre channel system |
US6289406B1 (en) | 1998-11-06 | 2001-09-11 | Vlsi Technology, Inc. | Optimizing the performance of asynchronous bus bridges with dynamic transactions |
US6459681B1 (en) | 1998-11-13 | 2002-10-01 | Sprint Communications Company L.P. | Method and system for connection admission control |
US6219379B1 (en) | 1998-11-17 | 2001-04-17 | Philips Electronics North America Corporation | VSB receiver with complex equalization for improved multipath performance |
US7430171B2 (en) | 1998-11-19 | 2008-09-30 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
FR2786632B1 (en) | 1998-11-27 | 2002-08-23 | Texas Instruments France | HIGH SPEED PHASE ALIGNMENT METHOD AND DEVICE |
EP1006697A3 (en) | 1998-12-02 | 2004-01-02 | Lucent Technologies Inc. | Parellel signal processing for equalisation on fibre channels |
JP3156924B2 (en) | 1998-12-11 | 2001-04-16 | 日本電気株式会社 | Route control method and data exchange device used therefor |
US6597689B1 (en) | 1998-12-30 | 2003-07-22 | Nortel Networks Limited | SVC signaling system and method |
US6631134B1 (en) | 1999-01-15 | 2003-10-07 | Cisco Technology, Inc. | Method for allocating bandwidth in an optical network |
US6912221B1 (en) | 1999-01-15 | 2005-06-28 | Cisco Technology, Inc. | Method of providing network services |
JP3183343B2 (en) | 1999-02-26 | 2001-07-09 | 日本電気株式会社 | Data communication method, terminal device, relay device, data communication system and recording medium thereof |
WO2000056113A1 (en) | 1999-03-17 | 2000-09-21 | Nokia Networks Oy | Internet protocol switch and method |
US6269427B1 (en) | 1999-03-18 | 2001-07-31 | International Business Machines Corporation | Multiple load miss handling in a cache memory system |
US6345301B1 (en) | 1999-03-30 | 2002-02-05 | Unisys Corporation | Split data path distributed network protocol |
KR100382851B1 (en) | 1999-03-31 | 2003-05-09 | 인터내셔널 비지네스 머신즈 코포레이션 | A method and apparatus for managing client computers in a distributed data processing system |
US6223270B1 (en) | 1999-04-19 | 2001-04-24 | Silicon Graphics, Inc. | Method for efficient translation of memory addresses in computer systems |
JP3299219B2 (en) | 1999-05-07 | 2002-07-08 | 日本電気株式会社 | Digital PLL circuit |
US6614791B1 (en) | 1999-05-11 | 2003-09-02 | Nortel Networks Limited | System, device, and method for supporting virtual private networks |
US6718415B1 (en) | 1999-05-14 | 2004-04-06 | Acqis Technology, Inc. | Computer system and method including console housing multiple computer modules having independent processing units, mass storage devices, and graphics controllers |
JP3486576B2 (en) | 1999-05-18 | 2004-01-13 | シャープ株式会社 | OFDM receiver and frequency offset compensation method thereof |
US6452601B1 (en) | 1999-05-20 | 2002-09-17 | International Business Machines Corporation | Pixel component packing, unpacking, and modification |
US6442225B1 (en) | 1999-06-14 | 2002-08-27 | Realtek Semiconductor Corporation | Multi-phase-locked loop for data recovery |
US6081162A (en) | 1999-06-17 | 2000-06-27 | Intel Corporation | Robust method and apparatus for providing a digital single-ended output from a differential input |
US6897697B2 (en) | 1999-06-28 | 2005-05-24 | Broadcom Corporation | Current-controlled CMOS circuit using higher voltage supply in low voltage CMOS process |
US6911855B2 (en) | 1999-06-28 | 2005-06-28 | Broadcom Corporation | Current-controlled CMOS circuit using higher voltage supply in low voltage CMOS process |
US6424194B1 (en) | 1999-06-28 | 2002-07-23 | Broadcom Corporation | Current-controlled CMOS logic family |
US6526112B1 (en) | 1999-06-29 | 2003-02-25 | Agilent Technologies, Inc. | System for clock and data recovery for multi-channel parallel data streams |
US6477646B1 (en) | 1999-07-08 | 2002-11-05 | Broadcom Corporation | Security chip architecture and implementations for cryptography acceleration |
US6839393B1 (en) | 1999-07-14 | 2005-01-04 | Rambus Inc. | Apparatus and method for controlling a master/slave system via master device synchronization |
JP4193297B2 (en) | 1999-08-04 | 2008-12-10 | ソニー株式会社 | COMMUNICATION DEVICE AND METHOD, COMMUNICATION SYSTEM, AND RECORDING MEDIUM |
US6788704B1 (en) | 1999-08-05 | 2004-09-07 | Intel Corporation | Network adapter with TCP windowing support |
US6775328B1 (en) | 1999-08-11 | 2004-08-10 | Rambus Inc. | High-speed communication system with a feedback synchronization loop |
US6681283B1 (en) | 1999-08-12 | 2004-01-20 | Mips Technologies, Inc. | Coherent data apparatus for an on-chip split transaction system bus |
US6332179B1 (en) | 1999-08-19 | 2001-12-18 | International Business Machines Corporation | Allocation for back-to-back misses in a directory based cache |
CN1694445A (en) | 1999-08-27 | 2005-11-09 | 三菱电机株式会社 | Synchronizing pulse generating method and method of receiving OFDM signal |
US6631351B1 (en) | 1999-09-14 | 2003-10-07 | Aidentity Matrix | Smart toys |
JP2001084506A (en) | 1999-09-17 | 2001-03-30 | Fujitsu Ltd | Noise elimination circuit, amplifier circuit, and magnetic recorder |
JP3226906B2 (en) | 1999-09-24 | 2001-11-12 | 埼玉日本電気株式会社 | Local oscillation signal supply method and circuit thereof |
US6496199B1 (en) | 1999-10-01 | 2002-12-17 | Koninklijke Philips Electronics N.V. | Method for storing and retrieving data that conserves memory bandwidth |
US6349365B1 (en) | 1999-10-08 | 2002-02-19 | Advanced Micro Devices, Inc. | User-prioritized cache replacement |
US6859435B1 (en) | 1999-10-13 | 2005-02-22 | Lucent Technologies Inc. | Prevention of deadlocks and livelocks in lossless, backpressured packet networks |
US6643787B1 (en) | 1999-10-19 | 2003-11-04 | Rambus Inc. | Bus system optimization |
US6396329B1 (en) | 1999-10-19 | 2002-05-28 | Rambus, Inc | Method and apparatus for receiving high speed signals with low latency |
US6952431B1 (en) | 1999-10-28 | 2005-10-04 | Rambus Inc. | Clock multiplying delay-locked loop for data communications |
US6438651B1 (en) | 1999-11-01 | 2002-08-20 | International Business Machines Corporation | Method, system, and program for managing requests to a cache using flags to queue and dequeue data in a buffer |
US6262594B1 (en) | 1999-11-05 | 2001-07-17 | Ati International, Srl | Apparatus and method for configurable use of groups of pads of a system on chip |
US6564267B1 (en) | 1999-11-22 | 2003-05-13 | Intel Corporation | Network adapter with large frame transfer emulation |
US6601200B1 (en) | 1999-11-24 | 2003-07-29 | International Business Machines Corporation | Integrated circuit with a VLSI chip control and monitor interface, and apparatus and method for performing operations on an integrated circuit using the same |
US6484224B1 (en) | 1999-11-29 | 2002-11-19 | Cisco Technology Inc. | Multi-interface symmetric multiprocessor |
US6788686B1 (en) | 1999-11-30 | 2004-09-07 | Lucent Technologies Inc. | Method of maintaining packet order in multipath transmission systems having non-uniform traffic splitting |
JP3482996B2 (en) | 1999-12-03 | 2004-01-06 | 日本電気株式会社 | ATM switch |
US6643752B1 (en) | 1999-12-09 | 2003-11-04 | Rambus Inc. | Transceiver with latency alignment circuitry |
US6862296B1 (en) | 1999-12-21 | 2005-03-01 | Lsi Logic Corporation | Receive deserializer circuit for framing parallel data |
US6606321B1 (en) | 1999-12-29 | 2003-08-12 | 3Com Corporation | Method of establishing MPOA shortcut virtual channel connections |
US6606360B1 (en) | 1999-12-30 | 2003-08-12 | Intel Corporation | Method and apparatus for receiving data |
WO2001054361A1 (en) | 2000-01-20 | 2001-07-26 | Mci Worldcom, Inc. | Intelligent network and method for providing voice telephony over atm and closed user groups |
DE10005449B4 (en) | 2000-02-08 | 2008-06-12 | Siemens Ag | Overvoltage protection device for a matrix converter |
US6757291B1 (en) | 2000-02-10 | 2004-06-29 | Simpletech, Inc. | System for bypassing a server to achieve higher throughput between data network and data storage system |
US6366225B1 (en) | 2000-02-14 | 2002-04-02 | Stmicroelectronics, Inc. | Circuit and method for determining the phase difference between a sample clock and a sample signal by linear approximation |
GB2362045B (en) | 2000-02-23 | 2004-05-05 | Phoenix Vlsi Consultants Ltd | Analogue-Controlled phase interpolator |
US7227918B2 (en) | 2000-03-14 | 2007-06-05 | Altera Corporation | Clock data recovery circuitry associated with programmable logic device circuitry |
US6975629B2 (en) | 2000-03-22 | 2005-12-13 | Texas Instruments Incorporated | Processing packets based on deadline intervals |
US6329859B1 (en) | 2000-03-23 | 2001-12-11 | Bitblitz Communications, Inc. | N-way circular phase interpolator for generating a signal having arbitrary phase |
US6631135B1 (en) | 2000-03-27 | 2003-10-07 | Nortel Networks Limited | Method and apparatus for negotiating quality-of-service parameters for a network connection |
US6917366B1 (en) | 2000-04-04 | 2005-07-12 | Pixelworks, Inc. | System and method for aligning multi-channel coded data over multiple clock periods |
US20020018444A1 (en) | 2000-04-11 | 2002-02-14 | Cremin Con D. | Method and apparatus for multi-lane communication channel with deskewing capability |
JP2001298481A (en) | 2000-04-13 | 2001-10-26 | Nec Corp | Communication control method, communication controller and recording medium |
US6636906B1 (en) | 2000-04-28 | 2003-10-21 | Hewlett-Packard Development Company, L.P. | Apparatus and method for ensuring forward progress in coherent I/O systems |
WO2001084724A2 (en) | 2000-04-28 | 2001-11-08 | Broadcom Corporation | Methods and systems for adaptive receiver equalization |
US7826384B2 (en) | 2000-05-04 | 2010-11-02 | Nortel Networks Limited | Method and apparatus for negotiating bearer control parameters using property sets |
US6658599B1 (en) | 2000-06-22 | 2003-12-02 | International Business Machines Corporation | Method for recovering from a machine check interrupt during runtime |
US6629166B1 (en) | 2000-06-29 | 2003-09-30 | Intel Corporation | Methods and systems for efficient connection of I/O devices to a channel-based switched fabric |
US6757748B1 (en) | 2000-07-20 | 2004-06-29 | Rlx Technologies, Inc. | Modular network interface system and method |
US6633967B1 (en) | 2000-08-31 | 2003-10-14 | Hewlett-Packard Development Company, L.P. | Coherent translation look-aside buffer |
US6654817B1 (en) | 2000-09-01 | 2003-11-25 | Abocom Systems, Inc. | Integral peripheral device of USB local network card and USB modem |
US6658520B1 (en) | 2000-09-26 | 2003-12-02 | Intel Corporation | Method and system for keeping two independent busses coherent following a direct memory access |
US6633936B1 (en) | 2000-09-26 | 2003-10-14 | Broadcom Corporation | Adaptive retry mechanism |
US6822940B1 (en) | 2000-09-29 | 2004-11-23 | Cisco Technology, Inc. | Method and apparatus for adapting enforcement of network quality of service policies based on feedback about network conditions |
US6816932B2 (en) | 2000-10-06 | 2004-11-09 | Broadcom Corporation | Bus precharge during a phase of a clock signal to eliminate idle clock cycle |
US6522629B1 (en) | 2000-10-10 | 2003-02-18 | Tellicent Inc. | Traffic manager, gateway signaling and provisioning service for all packetized networks with total system-wide standards for broad-band applications including all legacy services |
US6985988B1 (en) | 2000-11-09 | 2006-01-10 | International Business Machines Corporation | System-on-a-Chip structure having a multiple channel bus bridge |
US7035255B2 (en) | 2000-11-14 | 2006-04-25 | Broadcom Corporation | Linked network switch configuration |
US20020085562A1 (en) | 2000-12-13 | 2002-07-04 | International Business Machines Corporation | IP headers for remote direct memory access and upper level protocol framing |
US20020078265A1 (en) | 2000-12-15 | 2002-06-20 | Frazier Giles Roger | Method and apparatus for transferring data in a network data processing system |
US6981087B1 (en) | 2001-01-02 | 2005-12-27 | Juniper Networks, Inc. | Multi-master and diverse serial bus in a complex electrical system |
US6957269B2 (en) | 2001-01-03 | 2005-10-18 | Advanced Micro Devices, Inc. | Method and apparatus for performing priority-based flow control |
US20020089927A1 (en) | 2001-01-11 | 2002-07-11 | Fischer Michael A. | System and method for synchronizing data trasnmission across a variable delay interface |
JP4512699B2 (en) | 2001-01-11 | 2010-07-28 | 富士通株式会社 | Flow control device and node device |
US6886049B2 (en) | 2001-01-16 | 2005-04-26 | Sierra Wireless, Inc. | Multi-function interface for connectivity between a communication device and a host |
US6552619B2 (en) | 2001-02-05 | 2003-04-22 | Pmc Sierra, Inc. | Multi-channel clock recovery circuit |
US20020110087A1 (en) | 2001-02-14 | 2002-08-15 | David Zelig | Efficient setup of label-switched connections |
US6665759B2 (en) | 2001-03-01 | 2003-12-16 | International Business Machines Corporation | Method and apparatus to implement logical partitioning of PCI I/O slots |
US20020149400A1 (en) | 2001-04-16 | 2002-10-17 | Namik Kocaman | Low voltage differential to single-ended converter |
US6574708B2 (en) | 2001-05-18 | 2003-06-03 | Broadcom Corporation | Source controlled cache allocation |
US6766389B2 (en) | 2001-05-18 | 2004-07-20 | Broadcom Corporation | System on a chip for networking |
JP4573470B2 (en) | 2001-06-08 | 2010-11-04 | 富士通株式会社 | Transmission apparatus and flow control method thereof |
US7318146B2 (en) | 2001-06-19 | 2008-01-08 | Micron Technology, Inc. | Peripheral device with hardware linked list |
US7212534B2 (en) | 2001-07-23 | 2007-05-01 | Broadcom Corporation | Flow based congestion control |
US7020716B2 (en) | 2001-08-31 | 2006-03-28 | Adaptec, Inc. | Method and system for verifying the hardware implementation of TCP/IP |
EP1421500A1 (en) | 2001-08-31 | 2004-05-26 | Adaptec, Inc. | Systems and methods for high speed data transmission using tcp/ip |
US20030046330A1 (en) | 2001-09-04 | 2003-03-06 | Hayes John W. | Selective offloading of protocol processing |
US6976205B1 (en) | 2001-09-21 | 2005-12-13 | Syrus Ziai | Method and apparatus for calculating TCP and UDP checksums while preserving CPU resources |
US7124198B2 (en) | 2001-10-30 | 2006-10-17 | Microsoft Corporation | Apparatus and method for scaling TCP off load buffer requirements by segment size |
US6845403B2 (en) | 2001-10-31 | 2005-01-18 | Hewlett-Packard Development Company, L.P. | System and method for storage virtualization |
US6888532B2 (en) | 2001-11-30 | 2005-05-03 | Palmone, Inc. | Automatic orientation-based user interface for an ambiguous handheld device |
US20030105977A1 (en) | 2001-12-05 | 2003-06-05 | International Business Machines Corporation | Offload processing for secure data transfer |
US7062568B1 (en) | 2002-01-31 | 2006-06-13 | Forcelo Networks, Inc. | Point-to-point protocol flow control extension |
US7295555B2 (en) | 2002-03-08 | 2007-11-13 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
EP1357721A3 (en) | 2002-04-16 | 2004-07-14 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US7496689B2 (en) | 2002-04-22 | 2009-02-24 | Alacritech, Inc. | TCP/IP offload device |
US7007103B2 (en) | 2002-04-30 | 2006-02-28 | Microsoft Corporation | Method to offload a network stack |
US7181531B2 (en) | 2002-04-30 | 2007-02-20 | Microsoft Corporation | Method to synchronize and upload an offloaded network stack connection with a network stack |
WO2003104943A2 (en) | 2002-06-11 | 2003-12-18 | Ashish A Pandya | High performance ip processor for tcp/ip, rdma and ip storage applications |
US7664018B2 (en) | 2002-07-02 | 2010-02-16 | Emulex Design & Manufacturing Corporation | Methods and apparatus for switching fibre channel arbitrated loop devices |
US7397788B2 (en) | 2002-07-02 | 2008-07-08 | Emulex Design & Manufacturing Corporation | Methods and apparatus for device zoning in fibre channel arbitrated loop systems |
US7630300B2 (en) | 2002-07-02 | 2009-12-08 | Emulex Design & Manufacturing Corporation | Methods and apparatus for trunking in fibre channel arbitrated loop systems |
US7660316B2 (en) | 2002-07-02 | 2010-02-09 | Emulex Design & Manufacturing Corporation | Methods and apparatus for device access fairness in fibre channel arbitrated loop systems |
US7382790B2 (en) | 2002-07-02 | 2008-06-03 | Emulex Design & Manufacturing Corporation | Methods and apparatus for switching fibre channel arbitrated loop systems |
US7403542B1 (en) | 2002-07-19 | 2008-07-22 | Qlogic, Corporation | Method and system for processing network data packets |
US6968358B2 (en) | 2002-07-25 | 2005-11-22 | International Business Machines Corporation | Method and apparatus for network communication card memory management |
US7480312B2 (en) | 2002-08-19 | 2009-01-20 | Tehuti Networks Ltd. | Network traffic accelerator system and method |
US7346701B2 (en) | 2002-08-30 | 2008-03-18 | Broadcom Corporation | System and method for TCP offload |
US8631162B2 (en) | 2002-08-30 | 2014-01-14 | Broadcom Corporation | System and method for network interfacing in a multiple network environment |
US7397800B2 (en) | 2002-08-30 | 2008-07-08 | Broadcom Corporation | Method and system for data placement of out-of-order (OOO) TCP segments |
US7313623B2 (en) | 2002-08-30 | 2007-12-25 | Broadcom Corporation | System and method for TCP/IP offload independent of bandwidth delay product |
EP1554842A4 (en) | 2002-08-30 | 2010-01-27 | Corporation Broadcom | System and method for handling out-of-order frames |
US7283522B2 (en) | 2002-09-27 | 2007-10-16 | Sun Microsystems, Inc. | Method and apparatus for offloading message segmentation to a network interface card |
US7433326B2 (en) | 2002-11-27 | 2008-10-07 | Cisco Technology, Inc. | Methods and devices for exchanging peer parameters between network devices |
US6874054B2 (en) | 2002-12-19 | 2005-03-29 | Emulex Design & Manufacturing Corporation | Direct memory access controller system with message-based programming |
EP1460804B1 (en) | 2003-03-20 | 2008-10-22 | Broadcom Corporation | System and method for handling out-of-order frames (fka reception of out-of-order tcp data with zero copy service) |
EP1460806A3 (en) | 2003-03-20 | 2006-03-22 | Broadcom Corporation | System and method for network interfacing in a multiple network environment |
US7400639B2 (en) | 2003-08-07 | 2008-07-15 | Intel Corporation | Method, system, and article of manufacture for utilizing host memory from an offload adapter |
US6996070B2 (en) | 2003-12-05 | 2006-02-07 | Alacritech, Inc. | TCP/IP offload device with reduced sequential processing |
US7562158B2 (en) | 2004-03-24 | 2009-07-14 | Intel Corporation | Message context based TCP transmission |
US7813360B2 (en) | 2005-01-26 | 2010-10-12 | Emulex Design & Manufacturing Corporation | Controlling device access fairness in switched fibre channel fabric loop attachment systems |
US7586850B2 (en) | 2005-02-23 | 2009-09-08 | Emulex Design & Manufacturing Corporation | Prevention of head of line blocking in a multi-rate switched Fibre Channel loop attached system |
DE102007024011A1 (en) | 2007-05-22 | 2008-11-27 | Lanxess Deutschland Gmbh | nitrile rubbers |
JP5268009B2 (en) | 2008-06-27 | 2013-08-21 | 独立行政法人産業技術総合研究所 | Methods for establishing and differentiating adult pancreatic stem cells |
-
2003
- 2003-01-15 US US10/345,707 patent/US7430171B2/en not_active Expired - Fee Related
- 2003-01-21 US US10/348,642 patent/US7366190B2/en not_active Expired - Fee Related
- 2003-01-21 US US10/349,739 patent/US20030107996A1/en not_active Abandoned
- 2003-01-21 US US10/349,067 patent/US7362769B2/en not_active Expired - Fee Related
-
2008
- 2008-04-30 US US12/149,373 patent/US8798091B2/en not_active Expired - Fee Related
Patent Citations (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4817082A (en) * | 1987-03-09 | 1989-03-28 | American Telephone And Telegraph Company, At&T Bell Laboratories | Crosspoint switching system using control rings with fast token circulation |
US5276681A (en) * | 1992-06-25 | 1994-01-04 | Starlight Networks | Process for fair and prioritized access to limited output buffers in a multi-port switch |
US5379291A (en) * | 1992-12-29 | 1995-01-03 | International Business Machines Corporation | Apparatus for fiber distributed data interface dynamic station bypass via skipping and hopping |
US5495475A (en) * | 1993-10-15 | 1996-02-27 | International Business Machines Corporation | Resolution of race conditions in cascaded switches |
US5617421A (en) * | 1994-06-17 | 1997-04-01 | Cisco Systems, Inc. | Extended domain computer network using standard links |
US5528584A (en) * | 1994-10-27 | 1996-06-18 | Hewlett-Packard Company | High performance path allocation system and method with fairness insurance mechanism for a fiber optic switch |
US5619497A (en) * | 1994-12-22 | 1997-04-08 | Emc Corporation | Method and apparatus for reordering frames |
US5566171A (en) * | 1995-03-15 | 1996-10-15 | Finisar Corporation | Multi-mode high speed network switch for node-to-node communication |
US5828475A (en) * | 1995-10-25 | 1998-10-27 | Mcdata Corporation | Bypass switching and messaging mechanism for providing intermix data transfer for a fiber optic switch using a bypass bus and buffer |
US5831985A (en) * | 1995-11-09 | 1998-11-03 | Emc Corporation | Method and apparatus for controlling concurrent data transmission from multiple sources in a channel communication system |
US5754549A (en) * | 1995-12-05 | 1998-05-19 | International Business Machines Corporation | Inexpensive two-way communications switch |
US5848251A (en) * | 1996-08-06 | 1998-12-08 | Compaq Computer Corporation | Secondary channel for command information for fibre channel system interface bus |
US20030108061A1 (en) * | 1997-01-23 | 2003-06-12 | Black Alistair D. | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US5978379A (en) * | 1997-01-23 | 1999-11-02 | Gadzoox Networks, Inc. | Fiber channel learning bridge, learning half bridge, and protocol |
US7471691B2 (en) * | 1997-01-23 | 2008-12-30 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US7009985B2 (en) * | 1997-01-23 | 2006-03-07 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US6614796B1 (en) * | 1997-01-23 | 2003-09-02 | Gadzoox Networks, Inc, | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US6118776A (en) * | 1997-02-18 | 2000-09-12 | Vixel Corporation | Methods and apparatus for fiber channel interconnection of private loop devices |
US6324181B1 (en) * | 1998-04-16 | 2001-11-27 | 3Com Corporation | Fibre channel switched arbitrated loop |
US6212194B1 (en) * | 1998-08-05 | 2001-04-03 | I-Cube, Inc. | Network routing switch with non-blocking arbitration system |
US6597691B1 (en) * | 1998-09-01 | 2003-07-22 | Ancor Communications, Inc. | High performance switching |
US6396832B1 (en) * | 1998-09-04 | 2002-05-28 | 3Com Corporation | Method and apparatus for optimizing a switched arbitrated loop for maximum access fairness |
US6954285B2 (en) * | 2000-05-02 | 2005-10-11 | Canon Kabushiki Kaisha | Developing method and developing apparatus featuring two latent image developing operations using two electrical fields |
Cited By (119)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8750320B2 (en) | 1997-01-23 | 2014-06-10 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US8774199B2 (en) | 1997-01-23 | 2014-07-08 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US8767756B2 (en) | 1997-01-23 | 2014-07-01 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US20080205421A1 (en) * | 1998-11-19 | 2008-08-28 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US8798091B2 (en) | 1998-11-19 | 2014-08-05 | Broadcom Corporation | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost |
US8493857B2 (en) | 2001-07-23 | 2013-07-23 | Broadcom Corporation | Multiple logical channels for use in network devices |
US9036643B2 (en) | 2001-07-23 | 2015-05-19 | Broadcom Corporation | Multiple logical channels for use in network devices |
US8116203B2 (en) | 2001-07-23 | 2012-02-14 | Broadcom Corporation | Multiple virtual channels for use in network devices |
US8958440B2 (en) | 2002-03-08 | 2015-02-17 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US8451863B2 (en) | 2002-03-08 | 2013-05-28 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US8345689B2 (en) | 2002-03-08 | 2013-01-01 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US8135016B2 (en) | 2002-03-08 | 2012-03-13 | Broadcom Corporation | System and method for identifying upper layer protocol message boundaries |
US20110052191A1 (en) * | 2002-08-20 | 2011-03-03 | Beshai Maged E | Modular High-Capacity Switch |
US8792516B2 (en) * | 2002-08-20 | 2014-07-29 | Rockstar Consortium Us Lp | Modular high-capacity switch |
US7934021B2 (en) | 2002-08-29 | 2011-04-26 | Broadcom Corporation | System and method for network interfacing |
US8549152B2 (en) | 2002-08-30 | 2013-10-01 | Broadcom Corporation | System and method for TCP/IP offload independent of bandwidth delay product |
US8402142B2 (en) | 2002-08-30 | 2013-03-19 | Broadcom Corporation | System and method for TCP/IP offload independent of bandwidth delay product |
US7849208B2 (en) | 2002-08-30 | 2010-12-07 | Broadcom Corporation | System and method for TCP offload |
US8677010B2 (en) | 2002-08-30 | 2014-03-18 | Broadcom Corporation | System and method for TCP offload |
US8180928B2 (en) | 2002-08-30 | 2012-05-15 | Broadcom Corporation | Method and system for supporting read operations with CRC for iSCSI and iSCSI chimney |
US7912064B2 (en) | 2002-08-30 | 2011-03-22 | Broadcom Corporation | System and method for handling out-of-order frames |
US7929540B2 (en) | 2002-08-30 | 2011-04-19 | Broadcom Corporation | System and method for handling out-of-order frames |
US8667184B2 (en) | 2005-06-03 | 2014-03-04 | Qnx Software Systems Limited | Distributed kernel operating system |
US20060277285A1 (en) * | 2005-06-03 | 2006-12-07 | Andrew Boyd | Distributed kernel operating system |
US8386586B2 (en) | 2005-06-03 | 2013-02-26 | Qnx Software Systems Limited | Distributed kernel operating system |
US20060277284A1 (en) * | 2005-06-03 | 2006-12-07 | Andrew Boyd | Distributed kernel operating system |
US7840682B2 (en) * | 2005-06-03 | 2010-11-23 | QNX Software Systems, GmbH & Co. KG | Distributed kernel operating system |
US8078716B2 (en) | 2005-06-03 | 2011-12-13 | Qnx Software Systems Limited | Distributed kernel operating system |
US20110035502A1 (en) * | 2005-06-03 | 2011-02-10 | Andrew Boyd | Distributed Kernel Operating System |
US20080205410A1 (en) * | 2007-02-27 | 2008-08-28 | Alcatel Lucent | Asymmetrical forwarding in layer 3 IP VPNs |
US8432894B2 (en) * | 2007-02-27 | 2013-04-30 | Alcatel Lucent | Asymmetrical forwarding in layer 3 IP VPNs |
US8081646B1 (en) | 2007-12-12 | 2011-12-20 | Integrated Device Technology, Inc. | Old virtual queues technique for routing data packets in a packet switch |
US7974278B1 (en) | 2007-12-12 | 2011-07-05 | Integrated Device Technology, Inc. | Packet switch with configurable virtual channels |
US7796629B1 (en) * | 2007-12-12 | 2010-09-14 | Integrated Device Technology, Inc. | Packet switch with configurable bandwidth allocation precision |
US8014288B1 (en) | 2007-12-12 | 2011-09-06 | Integrated Device Technology, Inc. | Packet latency based arbitration technique for a packet switch |
US7907625B1 (en) | 2008-08-04 | 2011-03-15 | Integrated Device Technology, Inc. | Power reduction technique for buffered crossbar switch |
US10417236B2 (en) | 2008-12-01 | 2019-09-17 | Micron Technology, Inc. | Devices, systems, and methods to synchronize simultaneous DMA parallel processing of a single data stream by multiple devices |
US10838966B2 (en) | 2008-12-01 | 2020-11-17 | Micron Technology, Inc. | Devices, systems, and methods to synchronize simultaneous DMA parallel processing of a single data stream by multiple devices |
US12067767B2 (en) | 2009-01-07 | 2024-08-20 | Micron Technology, Inc. | Buses for pattern-recognition processors |
US11023758B2 (en) | 2009-01-07 | 2021-06-01 | Micron Technology, Inc. | Buses for pattern-recognition processors |
US11226926B2 (en) | 2009-12-15 | 2022-01-18 | Micron Technology, Inc. | Multi-level hierarchical routing matrices for pattern-recognition processors |
US11768798B2 (en) | 2009-12-15 | 2023-09-26 | Micron Technology, Inc. | Multi-level hierarchical routing matrices for pattern-recognition processors |
US10684983B2 (en) | 2009-12-15 | 2020-06-16 | Micron Technology, Inc. | Multi-level hierarchical routing matrices for pattern-recognition processors |
US20130156043A1 (en) * | 2011-12-15 | 2013-06-20 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US9535861B2 (en) * | 2011-12-15 | 2017-01-03 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US20160239440A1 (en) * | 2011-12-15 | 2016-08-18 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US9275290B2 (en) * | 2011-12-15 | 2016-03-01 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US20140204956A1 (en) * | 2011-12-15 | 2014-07-24 | Micron Technology, Inc. | Methods and systems for routing in a state machine |
US8680888B2 (en) * | 2011-12-15 | 2014-03-25 | Micron Technologies, Inc. | Methods and systems for routing in a state machine |
US11488645B2 (en) | 2012-04-12 | 2022-11-01 | Micron Technology, Inc. | Methods for reading data from a storage buffer including delaying activation of a column select |
US9565137B2 (en) | 2012-04-26 | 2017-02-07 | Nxp Usa, Inc. | Cut-through forwarding module and a method of receiving and transmitting data frames in a cut-through forwarding mode |
CN104255004A (en) * | 2012-04-26 | 2014-12-31 | 飞思卡尔半导体公司 | A cut-through forwarding module and a method of receiving and transmitting data frames in a cut-through forwarding mode |
US9524248B2 (en) | 2012-07-18 | 2016-12-20 | Micron Technology, Inc. | Memory management for a hierarchical memory system |
US10089242B2 (en) | 2012-07-18 | 2018-10-02 | Micron Technology, Inc. | Memory management for a hierarchical memory system |
US10831672B2 (en) | 2012-07-18 | 2020-11-10 | Micron Technology, Inc | Memory management for a hierarchical memory system |
US11775320B2 (en) | 2013-03-15 | 2023-10-03 | Micron Technology, Inc. | Overflow detection and correction in state machine engines |
US10067901B2 (en) | 2013-03-15 | 2018-09-04 | Micron Technology, Inc. | Methods and apparatuses for providing data received by a state machine engine |
US9703574B2 (en) | 2013-03-15 | 2017-07-11 | Micron Technology, Inc. | Overflow detection and correction in state machine engines |
US9747242B2 (en) | 2013-03-15 | 2017-08-29 | Micron Technology, Inc. | Methods and apparatuses for providing data received by a plurality of state machine engines |
US10929154B2 (en) | 2013-03-15 | 2021-02-23 | Micron Technology, Inc. | Overflow detection and correction in state machine engines |
US10372653B2 (en) | 2013-03-15 | 2019-08-06 | Micron Technology, Inc. | Apparatuses for providing data received by a state machine engine |
US11016790B2 (en) | 2013-03-15 | 2021-05-25 | Micron Technology, Inc. | Overflow detection and correction in state machine engines |
US9448965B2 (en) | 2013-03-15 | 2016-09-20 | Micron Technology, Inc. | Receiving data streams in parallel and providing a first portion of data to a first state machine engine and a second portion to a second state machine |
US10606787B2 (en) | 2013-03-15 | 2020-03-31 | Mircron Technology, Inc. | Methods and apparatuses for providing data received by a state machine engine |
US11394611B2 (en) | 2014-12-27 | 2022-07-19 | Intel Corporation | Programmable protocol parser for NIC classification and queue assignments |
US12119991B2 (en) | 2014-12-27 | 2024-10-15 | Intel Corporation | Programmable protocol parser for NIC classification and queue assignments |
US11394610B2 (en) | 2014-12-27 | 2022-07-19 | Intel Corporation | Programmable protocol parser for NIC classification and queue assignments |
US11388053B2 (en) | 2014-12-27 | 2022-07-12 | Intel Corporation | Programmable protocol parser for NIC classification and queue assignments |
US12130774B2 (en) | 2014-12-30 | 2024-10-29 | Micron Technology, Inc. | Devices for time division multiplexing of state machine engine signals |
US11947979B2 (en) | 2014-12-30 | 2024-04-02 | Micron Technology, Inc. | Systems and devices for accessing a state machine |
US10430210B2 (en) | 2014-12-30 | 2019-10-01 | Micron Technology, Inc. | Systems and devices for accessing a state machine |
US10769099B2 (en) | 2014-12-30 | 2020-09-08 | Micron Technology, Inc. | Devices for time division multiplexing of state machine engine signals |
US11580055B2 (en) | 2014-12-30 | 2023-02-14 | Micron Technology, Inc. | Devices for time division multiplexing of state machine engine signals |
US11366675B2 (en) | 2014-12-30 | 2022-06-21 | Micron Technology, Inc. | Systems and devices for accessing a state machine |
US11425039B2 (en) | 2015-08-26 | 2022-08-23 | Barefoot Networks, Inc. | Packet header field extraction |
US11425038B2 (en) | 2015-08-26 | 2022-08-23 | Barefoot Networks, Inc. | Packet header field extraction |
US11411870B2 (en) | 2015-08-26 | 2022-08-09 | Barefoot Networks, Inc. | Packet header field extraction |
US12040976B2 (en) | 2015-08-26 | 2024-07-16 | Barefoot Networks, Inc | Packet header field extraction |
US10846103B2 (en) | 2015-10-06 | 2020-11-24 | Micron Technology, Inc. | Methods and systems for representing processing resources |
US10691964B2 (en) | 2015-10-06 | 2020-06-23 | Micron Technology, Inc. | Methods and systems for event reporting |
US10977309B2 (en) | 2015-10-06 | 2021-04-13 | Micron Technology, Inc. | Methods and systems for creating networks |
US11816493B2 (en) | 2015-10-06 | 2023-11-14 | Micron Technology, Inc. | Methods and systems for representing processing resources |
US11977902B2 (en) | 2015-10-06 | 2024-05-07 | Micron Technology, Inc. | Methods and systems for event reporting |
US12095882B2 (en) | 2015-12-22 | 2024-09-17 | Intel Corporation | Accelerated network packet processing |
US11677851B2 (en) | 2015-12-22 | 2023-06-13 | Intel Corporation | Accelerated network packet processing |
US10698697B2 (en) | 2016-07-21 | 2020-06-30 | Micron Technology, Inc. | Adaptive routing to avoid non-repairable memory and logic defects on automata processor |
US10146555B2 (en) | 2016-07-21 | 2018-12-04 | Micron Technology, Inc. | Adaptive routing to avoid non-repairable memory and logic defects on automata processor |
US10402265B2 (en) | 2016-09-29 | 2019-09-03 | Micron Technology, Inc. | Validation of a symbol response memory |
US10019311B2 (en) | 2016-09-29 | 2018-07-10 | Micron Technology, Inc. | Validation of a symbol response memory |
US10268602B2 (en) | 2016-09-29 | 2019-04-23 | Micron Technology, Inc. | System and method for individual addressing |
US10949290B2 (en) | 2016-09-29 | 2021-03-16 | Micron Technology, Inc. | Validation of a symbol response memory |
US10339071B2 (en) | 2016-09-29 | 2019-07-02 | Micron Technology, Inc. | System and method for individual addressing |
US10521366B2 (en) | 2016-09-29 | 2019-12-31 | Micron Technology, Inc. | System and method for individual addressing |
US10789182B2 (en) | 2016-09-29 | 2020-09-29 | Micron Technology, Inc. | System and method for individual addressing |
US11829311B2 (en) | 2016-10-20 | 2023-11-28 | Micron Technology, Inc. | Custom compute cores in integrated circuit devices |
US11194747B2 (en) | 2016-10-20 | 2021-12-07 | Micron Technology, Inc. | Custom compute cores in integrated circuit devices |
US10592450B2 (en) | 2016-10-20 | 2020-03-17 | Micron Technology, Inc. | Custom compute cores in integrated circuit devices |
US10929764B2 (en) | 2016-10-20 | 2021-02-23 | Micron Technology, Inc. | Boolean satisfiability |
US11606318B2 (en) | 2017-01-31 | 2023-03-14 | Barefoot Networks, Inc. | Messaging between remote controller and forwarding element |
US11463385B2 (en) | 2017-01-31 | 2022-10-04 | Barefoot Networks, Inc. | Messaging between remote controller and forwarding element |
US11425058B2 (en) | 2017-04-23 | 2022-08-23 | Barefoot Networks, Inc. | Generation of descriptive data for packet fields |
US10476814B2 (en) * | 2017-07-21 | 2019-11-12 | Aruba Networks Inc. | Arbiter circuit for crossbar |
US20190028408A1 (en) * | 2017-07-21 | 2019-01-24 | Aruba Networks, Inc. | Arbiter circuit for crossbar |
US10505861B1 (en) * | 2017-07-23 | 2019-12-10 | Barefoot Networks, Inc. | Bus for providing traffic management statistics to processing pipeline |
US10911377B1 (en) | 2017-07-23 | 2021-02-02 | Barefoot Networks, Inc. | Using stateful traffic management data to perform packet processing |
US12088504B2 (en) | 2017-07-23 | 2024-09-10 | Barefoot Networks, Inc. | Using stateful traffic management data to perform packet processing |
US11750526B2 (en) | 2017-07-23 | 2023-09-05 | Barefoot Networks, Inc. | Using stateful traffic management data to perform packet processing |
US10826840B1 (en) | 2017-07-23 | 2020-11-03 | Barefoot Networks, Inc. | Multiple copies of stateful tables |
US11503141B1 (en) | 2017-07-23 | 2022-11-15 | Barefoot Networks, Inc. | Stateful processing unit with min/max capability |
US10686734B2 (en) * | 2017-09-26 | 2020-06-16 | Hewlett Packard Enterprise Development Lp | Network switch with interconnected member nodes |
US20190097949A1 (en) * | 2017-09-26 | 2019-03-28 | Hewlett Packard Enterprise Development Lp | Network switch with interconnected member nodes |
US10771387B1 (en) | 2017-09-28 | 2020-09-08 | Barefoot Networks, Inc. | Multiple packet data container types for a processing pipeline |
US11700212B2 (en) | 2017-09-28 | 2023-07-11 | Barefoot Networks, Inc. | Expansion of packet data within processing pipeline |
US11362967B2 (en) | 2017-09-28 | 2022-06-14 | Barefoot Networks, Inc. | Expansion of packet data within processing pipeline |
US11308109B2 (en) * | 2018-10-12 | 2022-04-19 | International Business Machines Corporation | Transfer between different combinations of source and destination nodes |
US11570127B1 (en) | 2018-12-28 | 2023-01-31 | Innovium, Inc. | Reducing power consumption in an electronic device |
US11159455B1 (en) | 2018-12-28 | 2021-10-26 | Innovium, Inc. | Reducing power consumption in an electronic device |
US11171890B1 (en) * | 2018-12-28 | 2021-11-09 | Innovium, Inc. | Reducing power consumption in an electronic device |
CN110278126A (en) * | 2019-06-28 | 2019-09-24 | 苏州浪潮智能科技有限公司 | A kind of switch port self checking method, system, terminal and storage medium |
Also Published As
Publication number | Publication date |
---|---|
US7366190B2 (en) | 2008-04-29 |
US20030174721A1 (en) | 2003-09-18 |
US7430171B2 (en) | 2008-09-30 |
US7362769B2 (en) | 2008-04-22 |
US20030108050A1 (en) | 2003-06-12 |
US20080205421A1 (en) | 2008-08-28 |
US20030118040A1 (en) | 2003-06-26 |
US8798091B2 (en) | 2014-08-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7385972B2 (en) | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost | |
US7362769B2 (en) | Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost | |
EP0797335B1 (en) | Network adapter | |
US7042891B2 (en) | Dynamic selection of lowest latency path in a network switch | |
US6950394B1 (en) | Methods and systems to transfer information using an alternative routing associated with a communication network | |
US9094327B2 (en) | Prioritization and preemption of data frames over a switching fabric | |
JP3816530B2 (en) | Low latency, high clock frequency, pre-geo asynchronous packet-based crossbar switching chip system and method | |
US5546385A (en) | Flexible switching hub for a communication network | |
US7237016B1 (en) | Method and system to manage resource requests utilizing link-list queues within an arbiter associated with an interconnect device | |
US20020118692A1 (en) | Ensuring proper packet ordering in a cut-through and early-forwarding network switch | |
US7436845B1 (en) | Input and output buffering | |
JP2000503828A (en) | Method and apparatus for switching data packets over a data network | |
KR19980080498A (en) | Fibre Channel Switching Systems and Methods | |
WO2001067691A1 (en) | NxN CROSSBAR PACKET SWITCH | |
US6731601B1 (en) | Apparatus and method for resetting a retry counter in a network switch port in response to exerting backpressure | |
KR20040054721A (en) | Tagging and arbitration mechanism in an input/output node of computer system | |
US6760338B1 (en) | Apparatus and method for monitoring data frames by a shared switching logic during simultaneous accessing of multiple network switch buffers | |
US6891843B1 (en) | Apparatus and method for sharing memory using extra data path having multiple rings |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH CAROLINA Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:037806/0001 Effective date: 20160201 Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:037806/0001 Effective date: 20160201 |
|
AS | Assignment |
Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD., SINGAPORE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:041706/0001 Effective date: 20170120 Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:041706/0001 Effective date: 20170120 |
|
AS | Assignment |
Owner name: BROADCOM CORPORATION, CALIFORNIA Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041712/0001 Effective date: 20170119 |