WO1995020850A1 - Network having secure fast packet switching and guaranteed quality of service - Google Patents

Network having secure fast packet switching and guaranteed quality of service Download PDF

Info

Publication number
WO1995020850A1
WO1995020850A1 PCT/US1995/001026 US9501026W WO9520850A1 WO 1995020850 A1 WO1995020850 A1 WO 1995020850A1 US 9501026 W US9501026 W US 9501026W WO 9520850 A1 WO9520850 A1 WO 9520850A1
Authority
WO
WIPO (PCT)
Prior art keywords
path
network
sfps
switch
connection
Prior art date
Application number
PCT/US1995/001026
Other languages
French (fr)
Inventor
Kurt Dobbins
Phil Andlauer
Chris Oliver
Tom Parker
Andy Grimes
Bruce Nutbrown
Dan Hullette
Wallace Matthews
Roger Dev
Jason Jeffords
Original Assignee
Cabletron Systems, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Cabletron Systems, Inc. filed Critical Cabletron Systems, Inc.
Priority to DE69522666T priority Critical patent/DE69522666T2/en
Priority to AT95908127T priority patent/ATE205652T1/en
Priority to JP7520158A priority patent/JPH09508509A/en
Priority to AU16078/95A priority patent/AU678687B2/en
Priority to EP95908127A priority patent/EP0741937B1/en
Publication of WO1995020850A1 publication Critical patent/WO1995020850A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L12/5602Bandwidth control in ATM Networks, e.g. leaky bucket
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/02Topology update or discovery
    • H04L45/10Routing in connection-oriented networks, e.g. X.25 or ATM
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/36Backward learning
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/20Support for services
    • H04L49/201Multicast operation; Broadcast operation
    • H04L49/203ATM switching fabrics with multicast or broadcast capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/256Routing or path finding in ATM switching fabrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/04Selecting arrangements for multiplex systems for time-division multiplexing
    • H04Q11/0428Integrated services digital network, i.e. systems for transmission of different types of digitised signals, e.g. speech, data, telecentral, television signals
    • H04Q11/0478Provisions for broadband connections
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5619Network Node Interface, e.g. tandem connections, transit switching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5625Operations, administration and maintenance [OAM]
    • H04L2012/5626Network management, e.g. Intelligent nets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/564Connection-oriented
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5645Connectionless
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5665Interaction of ATM with other protocols

Definitions

  • This invention relates to communication networks, and more particularly to an apparatus and method for providing a high transfer rate, guaranteed quality of service, and secure internetworking of packet-based LAN and WAN segments by establishing temporary connections which are protocol- independent and transparent to the end systems.
  • this invention is directed to allocating bandwidth by multiple levels of arbitration among competing devices requesting access to a bandwidth-limited shared resource, and to a search method for making a best path determination through the network based on a number of constraints.
  • IP Internet Protocol
  • DECNET DECNET
  • AppleTALK OSI
  • SNA SNA
  • next generation networks should also have the ability to dynamically reconfigure the network so that it can guarantee a predetermined amount of bandwidth for the requested quality of service (QOS) .
  • QOS quality of service
  • the concept is to provide network managers with complete “command and control" over the entire network's infrastructure — not just tell them when a failure has occurred.
  • ATM asynchronous transfer mode
  • Text files and images can be sent over existing packet-based networks because the delivery of this information is not time critical.
  • the new traffic (voice and video) is delivery time sensitive — variable or excessive latency will degrade the quality of service and can render this information worthless.
  • the new infrastructure requirements are expected to include:
  • the present invention is a new technology referred to as secure fast packet switching (SFPS) .
  • SFPS will provide the same or better reliability and security as routers and with much greater packet switching performance, without an increase in cost. This is because the complexities and costs of providing multi-protocol routers increase greatly as performance needs go up. Also, SFPS provides the following capabilities, which routers cannot provide:
  • QOS quality of service
  • SFPS provides a transition between the packet based technologies of today and the cell based technologies of tomorrow. SFPS will enable a mixed packet and cell based network infrastructure to operate as one seamless switching fabric using the same service and configuration management system to deliver the QOS that users demand.
  • SFPS provides for high performance packet switching based on source and destination MAC IDs — the unique medium access control (MAC) address assigned to each end system by the IEEE.
  • End-to-end connections are determined by a network management application that provides security and best path routing determinations based on a number of constraints.
  • the network infrastructure can remain protocol insensitive. This allows the network to provide an equal QOS to users sending packets based on NetBIOS, LAT, IP, IPX, SNA, or any other protocol. As protocols evolve the network and its management infrastructure will not have to be reworked to support the new protocols.
  • the system uses source and destination MAC addresses which alone, or in combination with the input port on the switch, form a unique "connection identifier" for any communication exchange between end systems to be connected through an SFPS device.
  • Network infrastructures are built up around a core switching fabric.
  • the switching fabric provides the physical paths or routes that allow users to send information to each other. Access to the switching fabric is gained through an access port. Access ports provide several functions — most importantly, they provide security and accounting services. Access ports also provide the network operator with the ability to monitor and control the access into and use of the switching fabric. End point systems such as personal computers (PCs), workstations, and servers connect to the access port using one of many access technologies such as Ethernet, Token Ring, FDDI , or ATM.
  • PCs personal computers
  • workstations workstations
  • servers connect to the access port using one of many access technologies such as Ethernet, Token Ring, FDDI , or ATM.
  • the access port acts as a management agent that performs five functions for the end point system. First, it provides directory services. Second it provides network access security services. Third, it provides routing services. Fourth, it provides the ability to reserve bandwidth along a path in the switching fabric. Finally, it provides accounting services. These five services: directory, security, routing, bandwidth management and accounting are required to provide a reliable network infrastructure.
  • each packet is treated as an independent unit of data called a datagram which is individually processed by application of access and security constraints, as well as path determination.
  • this processing is done only on probe packets (common on LAN broadcast mediums) which are decoded, and through the use of a directory of end systems containing policy, call attributes, location, paths, quality of service, etc., the connection is either rejected or accepted, in which case the path is determined and switches along the path are "programmed" to allow subsequent packets on this "connection" to be switched. In either case, subsequent datagrams are either switched or discarded without having to re-apply all of the security and access control and path determination logic.
  • Another important aspect of the present invention is a method of determining a path between two nodes (end systems) on the network which has the following properties: the path is optimal for one metric and passes a set of threshold tests for a number of other metrics; and, it must do so within a given time constraint.
  • the method is a breadth first recursive search in parallel which is initiated at the source node and proceeds outwardly to discover neighboring nodes and calculate traversal paths until reaching the destination node.
  • the method includes a series of "pruning steps" to insure that the number of potential paths does not grow towards infinity and to limit the memory requirements and processing time of the search.
  • the path result may not be the mathematical (theoretical) best path, in every case, but the search will pursue those paths having a high probability of being the best path considering the constraints and in that sense the search will make a best path determination.
  • the metrics include cost, bandwidth, policy, loss, etc. While a specific embodiment of the method is useful in determining an optimal path through the network, the method has much broader applications.
  • the present invention provides a method and apparatus allowing multiple levels of arbitration among competing devices requesting access to a bandwidth-limited, shared resource.
  • the first level of arbitration is programmable.
  • the available bandwidth of the bandwidth-limited, shared resource can be equally allocated between all competing devices or some of the competing devices can be allocated more bandwidth than others. This feature of the present invention is useful when the maximum aggregate bandwidth requirements of the requesting devices are greater than the bandwidth of the shared, bandwidth-limited resource. Because it is programmable, the arbitration system of the present invention can be used to allocate the available bandwidth to prioritize those competing devices that may more urgently need the bandwidth-limited, shared resource and other competing devices will only be allocated a fraction of the bandwidth that they actually need. However, these other competing devices will be allowed to use free time segments, thus effectively being able to use more bandwidth than they are programmed for in the first level of arbitration.
  • the arbiter of the present invention is programmed with an adequate number of segments to support the bandwidth requirements of the audio communications link. These time segments are made available to the audio communications link in a periodic way that matches the bandwidth requirements of the device.
  • Additional levels of arbitration are provided to allocate unused time segments that may be available after the first level of arbitration to competing devices if the competing devices are programmed to participate in the additional levels of arbitration.
  • the second and third levels of arbitrations allow unused time segments that may be available after the first level of arbitration to be assigned to other competing devices.
  • the second level of arbitration provides a Round-Robin type of arbitration scheme that is used to allocate a free time segment to the competing device having the allocation token. If the competing device having the allocation token is not requesting use of the bandwidth-limited, shared resource, then a third level of arbitration is provided.
  • each of the competing devices participating in the third level is assigned an identification number and placed in a list and the remaining free time segment is allocated to the competing device having a predetermined rank in the list.
  • the predetermined rank may be based on the sequential order of the identification numbers.
  • the unallocated time segment might be allocated to the requesting competing device having a particular identification number, such as the lowest or highest identification number.
  • a key feature of the present invention is that arbitration is performed using a hierarchy of programmable arbitration schemes.
  • the first level of arbitration is, for example, a programmable time division multiplexing arbiter.
  • the second level of arbitration which acts only to allocate any unused time segments after the first level of arbitration is, for example, a Round-Robin type arbiter.
  • the third level of arbitration which acts to allocate any time segment that remains unallocated after the second level of arbitration is a default level of arbitration that selects one of the requesting competing devices according to a predetermined scheme.
  • Another advantage of the arbitration system of the present invention is that arbitration is performed in parallel with data transfer cycles. That is, the competing device that is to be given exclusive use of the bandwidth-limited, shared resource is decided in the time segment prior to the time segment in which a data transfer is to occur. The arbitration decision is made at the same time that a data transfer is occurring in a time segment. This pipelining of decision making effectively makes the arbitration cycles look transparent to the competing devices and does not consume any portion of the available data transfer time.
  • the arbitration system of the present invention can support devices having different bandwidth requirements (i.e., different data transfer rates) in the same system because the system is programmable.
  • the granularity (that is, the amount of bandwidth represented by a time segment) of the time segments is programmed using an allocation memory. As the number of time segments in the allocation memory is increased, the granularity of bandwidth allocation becomes finer. Therefore, the arbitration system can meet the bandwidth requirements for competing devices that have differing bandwidth requirements. For example, a competing device having a low bandwidth can be assigned only a single time segment, since the low bandwidth device requires less frequent servicing. On the other hand, a competing device having a higher bandwidth could be assigned multiple contiguous time segments, thus allowing that device to complete a data transfer.
  • Another feature of the present invention since it is a programmable arbitration system, is that the type of arbitration for each device may be programmed on a device by device basis. For example, a device may be programmed to participate only in the first level of arbitration and not in the second or third levels. In the same way, a device could be programmed to participate only in the second and/or third levels of arbitration. This makes the system more flexible depending upon the particular application and helps to guarantee quality of service for each competing device.
  • FIG. 1 is a schematic illustration of a network topology built with SFPS switches
  • Fig. 2 is a schematic illustration of the internal components of an SFPS switch in a hardware embodiment
  • Fig. 3 is a flowchart of the operation of the SFPS switch of Fig. 2;
  • Fig. 4 is a perspective view of a networking chassis with removable modules
  • Fig. 5 is a schematic diagram of a networking module with a SFPS switch
  • Fig. 6 is a schematic illustration of the networking chassis and the services it provides;
  • Fig. 7A is a schematic illustration of an SFPS switch
  • Fig. 7B is a logical view of an SFPS switch
  • Fig. 7C is a flowchart showing processing of a data packet by an SFPS switch
  • Fig. 8 is a schematic illustration of a distributed SFPS switch
  • Fig. 9 is a schematic illustration of a chassis and distributed switch and illustrates the formation of a distributed directory of port objects for the distributed switch;
  • Fig. 10 is a schematic illustration of the distributed switch on the physical and logical layers
  • Fig. 11 is a flowchart illustrating a best path determination
  • Fig. 12 is a schematic illustration of certain linked data structures used in the method of Fig. 11;
  • Fig. 13 is a sample network topology illustrating a traversal from a source node to destination node
  • Fig. 14 illustrates a networking chassis with an exemplary application of the bandwidth arbiter of the present invention
  • Fig. 15 is a schematic diagram of one embodiment of the arbiter used in the networking chassis of Fig. 14;
  • Fig. 16 illustrates a first programmed state machine that may be executed by the circuit of Fig. 14
  • Fig. 17 illustrates a second programmed state machine that may be executed by the circuit of Fig. 14;
  • Fig. 18 is a flow chart illustrating how arbitration and allocation of time segments take place simultaneously to improve system efficiency in the present invention
  • Fig. 19 is a flow chart illustrating the arbitration method of the present invention.
  • Fig. 20 is an illustration of the TDM RAM programming illustrating the arbitration method applied to an SFPS switch
  • Fig. 21 is an illustration of an SFPS software embodiment
  • Fig. 22 is an illustration of a port object for the switch of Fig. 21.
  • Example 1 - Mil transmits a packet destined for M99
  • Example 2 - Mil transmits a packet destined for M66
  • Fig. 1 shows a representative network topology built with six secure fast packet switches (SFPS) labeled SI to S6 connected by links L.
  • SFPS secure fast packet switches
  • Each SFPS switch has for example, four ports. Some ports are labeled A for Access and some are labeled N for Network. Access ports provide network access security and packet routing services. Network ports do not perform security services since this function has already been performed at the original entry access port.
  • the end systems are connected to the switches by links L and are labeled "M "; one of the end systems M10, comprises a network management server (NMS). This NMS will also contain the SFPS directory and path server.
  • NMS network management server
  • Each SFPS includes a function known as a Connection Database Look-Up Engine (CDLUE) .
  • the CDLUE's job is to check the source and destination MAC IDs of a packet received by the SFPS against its internal database, called the connection table.
  • the CDLUE will forward (route) packets out one or more ports based on the results of the connection table look-up.
  • This function is similar to a bridge except that SFPS uses both the source and the destination MAC IDs to make the forwarding decision. Bridges only use the MAC destination address. Also, if a bridge isn't sure where a destination is, it will forward the packet out all ports except the one it came in on. This "flooding" results in loss of control over network access, bandwidth, information security, network performance and reliability. Because SFPS uses both the source and destination addresses it does not have the failings of current bridges and routers.
  • Fig. l The network topology view of Fig. l will be used to illustrate how "virtual LANs" and “virtual connections" can be built to enable protocol insensitive routing and increased network security to be achieved.
  • WG1 (Mil, M22, M99)
  • WG2 (M33, M55, M77)
  • Two connections will be attempted: (Mil, M99) and (Mil, M66) .
  • Example 1 - Mil transmits a packet destined for M99.
  • Access switch SI receives this packet on inbound port Al.
  • SI looks up in its connection table to determine if a valid connection (Mil to M99) exists.
  • Si initiates a message exchange to the SFPS Server (Network Management Station) M10.
  • This message exchange is an independent exchange between the switch SI and the server M10. a) The switch sends a message asking if Mil can (is allowed) to talk to M99.
  • the server M10 will determine the path of switches to be used to provide a logical connection between Mil and M99. c) Since Mil can reach M99 by two different paths, one "best” path is selected. “Best” is constrained by, for example, cost, bandwidth, policy, loss, and other metrics. d) Let's assume the best path is chosen as traversing SI to S3 to S5. e) The server M10 will then "program" each of these switches to support this connection path.
  • SFPS Since SFPS has to be transparent in the M11-M99 interaction, it cannot modify the packets being exchanged. Typically, in traditional switches, the switch sets a connection-identifier that gets put in each packet, and is remapped at each switch, to allow the packet to be switched along the path. Since SFPS cannot touch any packet content, it has to have something in the existing packet that it can use in each switch to treat as a unique connection-identifier while preserving the Mil to M99 packet exchange. What is unique about SFPS is that it treats:
  • connection-identifier a unique "connection-identifier.” Note, that this is an implicit connection-identifier in each packet based on the arriving inbound port, but is an explicit connection-identifier in each switch's connection table.
  • Example 2 - Mil transmits a packet destined for M66.
  • Si receives the packet.
  • SI looks up in its connection table and with no match will send a message to server M10.
  • Server M10 will reject the packet as unauthorized (not within one of the two approved logical work group or "virtual" LANS) and the packet will be dropped without a connection being made. An alarm may be set to indicate that an unauthorized transmission has been attempted.
  • the SFPS switches require five management service functions to be performed at a higher layer in the network management framework.
  • the five functions are: Route Service, Access Security, Directory Service, Accounting, and Bandwidth Management.
  • Route Service e.g., Route Service
  • Access Security e.g., Access Security
  • Directory Service e.g., Directory Service
  • Accounting e.g., Accounting
  • Bandwidth Management e.g., Bandwidth Management
  • Route Services Management These services are required so the SPFS can determine the best path to route a connection. When there are many possible "paths" to a destination, the route management will determine which one should be used and pass this information to the SFPSs so that their connection databases can be configured correctly. A preferred method of making a best path determination is described in a later section.
  • Access Security Management These services are optional and can be used to limit user access to only a specified group of SFPS access ports.
  • An access group may contain from 2 to any number of users. Users can only send or receive packets from members of their access group. Access to any other access ports would be prevented by filtering out those packets.
  • Security also includes administrative policies.
  • Directory Services Management These services provide the Route Services Management with a user to access port and switch database so that packets destined for users not directly connected to the local access switch can be located and then have a path to that switch selected. This , service reduces the amount of time it takes for a connection to be established.
  • An ISO X.500 Directory Services may be used which is compatible with NIS, Novell 4.0 and others.
  • the SFPS is a multiported data communications device shown in Fig. 2 (physical layer — external ports not shown) .
  • Fig. 3 is a flow chart showing the frame processing of the SFPS switch.
  • the canonical frame format has the following structure:
  • the SFPS 10 has a common 64 bit wide packet data bus 11 that is shared by all ports, as well as by a memory array referred to as "packet ram" 12.
  • packet ram a memory array
  • the port signals to a multilevel programmable arbiter (MPA) 13 that it is ready to transfer data into the SFPS system (step 21).
  • MPA is used to allow each port a "timeslice" on the bus 11 so that data may be transferred into the SFPS and stored into packet ram.
  • the SFPS system requires ports that deliver data in to deliver an entire packet before beginning the next packet.
  • the packet data bus control system in conjunction with the MPA establishes a 10 elk (clock) cycle "timeslice" for data transfers (32 bytes of information). Transfers can be in either direction. Inbound transfers are referenced as a port delivering data into the packet ram, and outbound transfers are those in which data is sourced from the packet ram and sent out through a port towards the datalink. A transfer of the data packet in or out of the SFPS may take multiple timeslices.
  • a port When a port receives an acknowledgment from the MPA, it signals "start of frame” (SOF) on the control bus 19. This informs the lookup process that the beginning of a data packet will be traversing the bus 11 and that it should copy the DA and SA fields so that it may proceed with a lookup operation (step 23). Now, in parallel, the lookup process will be forming the results word (steps 24, 26) while the port continues to transfer the entire packet into the packet ram 12 (step 22), controlled by the DMA process. Once the end of the data packet is delivered, the port signals "end of frame” EOF which tells the DMA 16 that it is done.
  • SOF start of frame
  • the common bus 11 also indicates which port is transferring the data into the packet ram 12; this information is used by the lookup circuitry 14 so that it may associate the DA-SA data with a certain inbound port (step 24).
  • the lookup circuitry 14 is where the connection database table is maintained. This table is what is established by the SFPS connection setup application. It indicates for a particular DA-SA pair on which port(s) the data shall be sent outbound (step 25). The table also provides a field which identifies the allowable in-port for this DA-SA connection. The lookup circuitry will match the actual inbound port with the allowable in-port to ensure that the data has entered this switch from a pre-authorized location (step 24).
  • the lookup process passes an information structure to the forwarding logic, which the forwarding logic acts on.
  • the information structure known as the "results" word, contains the following:
  • In_port the allowable in_port, used by the lookup process.
  • Out_port/Index this will be a single port number, or an index into a ram which contains a port_mask to be used when the packet is intended to be delivered out more than one port. This ram is located within the forwarding logic.
  • In_port violation a single bit indicating that the in_port check passed/ failed; this is used by the forwarding logic.
  • Unknown connection a bit indicating that the connection entry was not found in the connection database. This packet will be delivered to the host for directory assistance.
  • the forwarding logic acts on this data to produce a "outmask.” This is a mask that is as wide as the number of ports in the system. This mask, for each bit set, indicates the desire to forward this data packet out the specified ports.
  • the forwarding logic 14 waits on two pieces of information to complete its task, which is to write the outmask to the transmit queue logic 15. One piece of information is the results word for a given port (from the lookup logic — step 24); the second is a data structure that is written by the DMA control logic 16 (a pointer to where data resides in packet RAM — step 22).
  • the forwarding process upon receiving this structure from the DMA checks with the lookup process for the completion of the table search and result word formation for that port. If lookup search and frame reception are both complete, the forwarding process 14 then translates the out port information into a mask which it writes to the transmit queues 15.
  • Each queue is connected to a network interface block 18 (NIB.. , ..., NIB , respectively). If an entry exists on a queue, the port that the queue is associated with is signalled so that the port may request that information.
  • a queue entry is merely a pointer to a data packet which resides in packet ram. This pointer is what the forwarding process writes onto the queue in what is called a forwarding operation.
  • the port then signals to the MPA 13 that it wishes to perform an outbound data transfer. Once granted, the DMA controller 16 will source the appropriate data from the packet ram 12 onto the packet data bus 11 (step 27).
  • the DMA When transmitting, the DMA reads the pointer entry off the appropriate queue based on the port number that is requesting the transmit operation. All along, the DMA process has been maintaining in its internal memory the length of each packet in the packet ram. When the pointer is read from the queue and the transmit operation begins, the DMA process decrements a working count value which is first loaded with the full packet length. As transmission proceeds and this counter reaches zero, the DMA process signals "end of frame" (EOF) and the port stops requesting data transfers (unless there is another entry on its transmit queues).
  • EEF end of frame
  • LAN segments Different data links (LAN segments) specify and use dissimilar formats to encapsulate and represent data.
  • each data link sub-system In order to provide an extensible system, it is advantageous for each data link sub-system to translate incoming frames, and represent them canonically.
  • the encapsulation method utilized herein is 802.2 LLC, more specifically 802.2 SubNetwork Access Protocol (SNAP) SAP. It provides mechanisms to encapsulate DIXE frames, with no loss of information content. Using this mechanism, and accounting for various datalink address formats, the canonical representation is as follows: Table 1: Canonical Frame Format
  • the "header” is a packet description provided for use by the SFPS switch.
  • the "destination address” is the physical MAC address of the destination end system.
  • the “source address” is the physical MAC address of the source end system.
  • the LLC field is the IEEE 802.2 LLC header.
  • the “information field” is the client layer data.
  • the “check sum” is a 16 bit field for confirming packet integrity.
  • Fig. 4 is an illustration of a networking chassis adapted to incorporate the SFPS technology.
  • the chassis 30 is a mechanical enclosure 31 which is used to house a plurality of networking modules 32, which may include repeater modules, bridge modules, router modules, terminal servers, file servers, etc.
  • the chassis provides slots into which the networking modules are inserted.
  • the chassis provides a backplane 33 through which the modules inserted into the chassis are provided power from the chassis' power supply 34 and networking connectivity between modules.
  • the backplane includes a system management bus (SMB) for network management functions, and a high-speed data bus known as the INB.
  • SMB system management bus
  • the chassis or hub enables the connection of diverse LAN segments, including Ethernet, Token Ring and FDDI segments, as well as to wide area networks (WANs).
  • WANs wide area networks
  • the chassis provides connection to an asynchronous transfer mode (ATM) switch across its backplane.
  • ATM asynchronous transfer mode
  • Each module 32 is microprocessor based, e.g., i960 sold by Intel Corporation.
  • Fig. 5 illustrates a module embodying an SPFS switch 40 which is linked to the module's host processor 41 by a pair of port interface links 42 for transfer of data, and a pair of status/control links 43 for transfer of status and control signals.
  • the control and status interface is viewed by the host CPU as a set of registers that control the configuration and switching policies of the SFPS, as well as allowing the host CPU access to diagnostic information and switching statistics.
  • the SPFS 40 provides packet switching services between network data interfaces 44, 47, and 50 according to the criteria set by the host CPU 41.
  • the network data interface consists of a data path and several handshaking signals.
  • Fig. 5 shows an Ethernet interface 44 with handshake and data links 45-46, FDDI interface 47 with handshake and data links 48-49, and a backplane interface 50 (to the networking chassis backplane 33) with handshake and data links 51-52.
  • the network data interfaces 44, 47 can be configured to handle, for example, up to 16 separate network ports, or one high speed port.
  • the amount of bandwidth granted each network data interface is determined by the implementation of the SPFS; a specific example of programming the MPA arbiter on the SFPS is described in a later section.
  • the SPFS handshaking signals allow the network interface block (NIB) to request use of the SPFS, as well as synchronize the transfer of data.
  • the NIB provides translation of the original frame format to the canonical format as well as protecting the data with checksum coverage.
  • Fig. 6 is a schematic illustration of the various functions provided by the networking chassis or hub 30.
  • the chassis is schematically shown in segments consisting of: . CPU; ATM; Ethernet; Token Ring; FDDI; Router; Switching.
  • the chassis architecture may be implemented in C++ OOP (object oriented programming) software.
  • the backplane connects various LAN and WAN interfaces.
  • An integrated management network service is provided, based on RISC base CPUs (UNIX) .
  • the physical media is UTP and STP sockets, and optical fiber.
  • the functionality includes: connectivity; bridging; routing; secure fast packet switching; and ATM cell switching.
  • one or more of networking modules 32 in chassis 30 may be an ATM cell switching module. Such a module would need to perform packet to ATM cell conversion (and vice versa) for transmissions between the module and the chassis backplane.
  • ATM cell switches function much like a router in that each switch receives cells from each port and then forwards them out the correct port (Unicast) or ports (Multicast). As the cell is forwarded to a switch, its header is modified with "next switch" routing information. This process continues at each cell switch until the cell is received at the end node. End nodes then strip away the cells and deliver the data to the end user or router application.
  • Cell switches include a management agent (CPU) that is used to set up the logical connection through the switch as well as monitor the operation and performance of the switch and its ports or links. All cell switches are built around the core switch fabric which determines its maximum performance or switching capacity. Usually, this is expressed in Giga-bits-per-second (Gbps). ATM switching capacity in the one to two Gbps range are now becoming available, and switching capacities in the 20-40 Gbps range are expected within the next few years.
  • CPU management agent
  • All cell switches are built around the core switch fabric which determines its maximum performance or switching capacity. Usually, this is expressed in Giga-bits-per-second (Gbps). ATM switching capacity in the one to two Gbps range are now becoming available, and switching capacities in the 20-40 Gbps range are expected within the next few years.
  • the above networking chassis is designed to distribute the network management services across the various networking modules, to provide increased throughput (prevent bottlenecks) and fault tolerance (i.e., there is no one networking module which if defective, shuts down the system) .
  • a system and method for implementing this distributed management is more fully described in a copending and commonly owned application (U.S. Serial No. 08/187,856) filed on the same date (January 28, 1994) entitled “Distributed Chassis Agent For Network Management,” filed by Brendan Fee et al., which is hereby incorporated by reference in its entirety.
  • the "secure” feature of the SFPS means that no traffic is allowed through the switch until "programmed" by the SCS (switch agent). All end-to-end system connections passing through the switch must be validated, i.e., by way of access list, virtual LAN, policy, etc.
  • the switches register with the SCS before becoming operational. The switches “discover” and report end systems on each port of the switch to the SCS. This allows the SCS to learn the SFPS topology without the SFPS switches having to run a distributed topology exchange protocol.
  • the "fast" feature of the SFPS may be accomplished on hard cards, wherein packet switching is done completely in hardware ASICS.
  • the network interface block (NIB) handles the media interface. All NIBs translate data into a common internal frame format, i.e., the canonical format.
  • the lookup engine extracts the key fields from the frame (i.e., MAC source and destination addresses) as the first burst of data is transferred from the NIB to packet ram. The extracted data is then "looked up" in the connection table.
  • the lookup engine provides the search function, as well as dynamic learning and aging of table entries.
  • the search result is a code either programmed by the host CPU or learned by hardware that indicates where the frame should be forwarded based on the key fields. When the result operation is complete, the results are delivered to the forwarding engine.
  • the "fast" feature can be provided by soft cards, wherein packet switching logic is minimized. There are no hierarchical lookups or header decoding beyond the MAC address header. There is no variable length packet headers or addresses. There is no protocol type processing.
  • the "packet" feature of SFPS means that the switch supports existing LAN packet formats, e.g., Ethernet, Token Ring and FDDI. No segmentation or reassembly of packets is required.
  • the "switching" feature in SFPS means that the switch treats data flows as connections.
  • the source port, source MAC and destination MAC become a unique tuplet which serves as a connection identifier.
  • the switch always forwards (switches) the packet out the correct output port; there is no flooding out all ports.
  • the switch uses an arbiter to share switch bandwidth and ports.
  • SFPS host agent The operation of the SFPS host agent is best illustrated in Figs. 7A-7C.
  • Fig. 7A is a schematic illustration of a SFPS switch 91 having a plurality of ports 92.
  • a host port 93 connects the switch to its host CPU 90, which may be an i960 microprocessor sold by Intel Corporation.
  • the host CPU is connected to the system management bus (SMB) for receipt and transmission of discovery and other control messages between modules in the networking chassis.
  • SMB system management bus
  • Fig. 7B-7C illustrate the internal operation of the switch.
  • the SFPS switch 86 includes in ports 80, out ports 81, connection database 82, look-up engine 83, and a multilevel programmable arbiter MPA 84. All of these components have been previously discussed with regard to the switch shown in Fig. 2.
  • the switch 86 sends and receives messages from the host agent 85, which includes a management agent 87, a discovery agent 88, and a call processing agent 89.
  • the interaction of the host agent, switch, SCS and end system will be described in the following paragraphs, and is illustrated in the flow chart of Fig. 7C.
  • the management agent 87 provides external control of the configuration and operation of the SFPS switch, through the network management system.
  • the discovery agent 88 provides a mapping of end systems to switching ports through a passive listening (snooping) capability and a registering of end system addresses and port locations of the host switch with an external directory located in the SCS. Adjacent switches are also discovered and mapped, but this may be done with an explicit switch-to-switch protocol (nonpassive) .
  • the call processor 89 provides a means for requesting connections to be established between two end systems.
  • the call processor will decode the packet to find source or destination network addresses and will use these to map back into the mapped addresses from the external directory located in the SCS. Once the end system MACs addresses are known, the call processor will then request the connection between the end systems. If the broadcast frame was a probe or address resolution packet (i.e., an implied connect request), the call processor will return a probe reply as a "proxy" which gives the destination end system MAC addresses. Subsequently, the source end system can then send packets directly to the destination based on its MAC address.
  • Fig. 7C is a flow chart illustrating what happens from the time a data packet is received on an input port of the switch, until it is sent on the correct output port.
  • step 300 the host is initialized.
  • step 301 the host programs the connection database to send any "unknown” or "broadcast” connections to the host port.
  • the switch waits for a packet to arrive.
  • step 303 a packet has arrived.
  • step 304 the switch extracts the source MAC address, destination MAC address, and identifies the inbound port on which the packet was received.
  • step 305 the look-up engine checks to see whether this source-destination pair is already located in the connection database. If it is not found in step 308, the packet is given to the host agent.
  • the call processor and the host agent determine whether it is a broadcast destination (step 309).
  • the call processor decodes the packet to find the network protocol source and destination addresses (steps 310-311).
  • a different protocol decode logic would be provided for each network protocol. For example, in the IP protocol, if an ARP request is received, the call processor would get the target IP address (step 312). It would then ask the external directory (SCS) for the MAC address of the target IP (step 313). In the next step 314, the SCS sends the MAC destination address back to the call processor. In step 315, the call processor asks the SCS to set up a connection between the source MAC and destination MAC. In step 316, the call processor forms an ARP reply packet by putting the destination MAC address inside the packet.
  • step 317 the call processor sends a reply to the source address. It should be noted that this reply allows the source end system to update its private mapping of the destination IP address to a nonbroadcast MAC address. All subsequent packets to this destination IP address will be properly framed with the source and destination MAC address for which connections will now exist.
  • step 309 If the answer in step 309 is no, then the call processor treats it as an unknown connection (step 318), asks the SCS to set up the call (step 319) and discards the packet (step 320) .
  • step 305 if the source and destination MAC pair are found in the connection database, the data packet is sent to the switch outport(s) defined in the database (step 306).
  • step 307 the management agent collects statistics regarding transmissions through the switch and sends them to the SCS.
  • the SFPS functions can be "distributed" across the networking chassis.
  • FIG. 8 is a schematic illustration of a distributed SFPS switch.
  • a network 70 is shown schematically as a "cloud" to which there is connected by data path 71 a representative end point system 72.
  • Data paths 73, 74, 75 connect the network 70 to an SFPS switch engine 76, call processor 77, and SCS (switch agent) 78.
  • the call processor may be part of a stand-alone server, part of the SCS, part of the SFPS switch, or part of the end point system.
  • the SCS may be physically a part of some other network component. The following is a more detailed description of the operations of the distributed switch according to the present embodiment.
  • end system A wishes to communicate with end system B according to address resolution protocol ARP.
  • ARP is a protocol for mapping 32-bit IP addresses to 48-bit data link layer addresses, as specified in RFC 826.
  • the SFPS switch 76 receives the broadcast and treats it as an unknown connection. It forwards the broadcast out the broadcast redirect port (programmed by SCS 78) to the call processor 77 - see bold connecting arrow 94 in Fig. 8.
  • the call processor 77 processes the ARP request REQ packet and performs SFPS protocol to UNI (User to Network Interface) translation. It looks inside the ARP for the destination IP address. It puts the ARP request on a holding queue.
  • the call processor 77 it makes a directory assistance call to the SCS 78, asking for the MAC address for the destination IP address; it may provide the SCS with the switch address and source MAC address as well.
  • the call processor 77 then tries to establish a connection from the source to the destination. It makes a CALL-REQUEST (see bold arrow 95) on behalf of the end system, but does not set up the connection from itself.
  • the SCS 78 then processes the call request from call processor 77.
  • the SCS validates the call according to, i.e., policy, access control, virtual LANs, quality of service, etc.
  • SCS 78 determines the path to connect the source and destination and then "programs" each switch in the path with a valid connection.
  • a connection is a combination of source port, source MAC, and destination MAC mapped to an outbound port.
  • the SCS 78 uses SNMP and switch MIBs 96 to do this; there is no signalling per se.
  • SCS 78 returns CALL-ACCEPTED to the call processor 77.
  • the call processor 77 removes the ARP request from the queue and fills in the destination MAC address and sends an ARP response to the source end system.
  • the source end system now has an updated ARP cache and can send packets directly to the destination end system. These packets get switched through each switch along the path as programmed by the SCS.
  • FIG. 9 illustrates generally modules 100A-C, each having a switch engine 101A-C, input ports 102A-C, and outpu ⁇ ports 103A-C, and each connected by backplane 33 of networking chassis 30.
  • a "Distributed Directory for Port Objects" 104 is shown above which includes an object name 105 and object location 106 for each output port 103.
  • each managed object of the switching engine is indexed by at least a module chassis/slot number and in the case of ports, by a key of chassis/slot/ port.
  • the key 106 is somewhat hidden by calling this a Portldentifier 105 which can be specified in decimal dot notation.
  • the MIB tree In conjunction with a MIB tree registration agent that distributes the name and location (think of it as a replicated directory of file names, but not the data) across each module, the MIB tree will automatically form a unique naming tree by redefining the name of an object to be its OID (Object Identifier) and its location information.
  • OID Object Identifier
  • This MIB tree replication is done totally transparent to the individual managed objects on each module or switch engine. What results is a replicated tree of the name and location of all switch objects and their unique instances.
  • MIB object registration and naming will be done the same as in the distributed- system except that MIB tree will not be replicated since the system itself is not a distributed system.
  • the port objects will still use a complex portldentifier to instance themselves.
  • the Switch MIB provides a distributed view of the MIB, it does not provide a single logical view of the switching system across all of the chassis modules. This may not be apparent at first, but the Switch MIB provides for a distributed collection of switch engines that can be accessed from a single MIB view (see Fig. 10 showing SCS 78 connected to three separate switch engines on the left as the "physical switching system" 110, and connected on the right to a single “logical switching system” 111). The implications are that the SCS control agent must be able to manage and program each of the individual switch engines.
  • the SCS controller would have to program the ingress module with a separate connection going over the chassis backplane to the module with the egress port on it; the egress module would then have a connection going from the chassis backplane port to the egress port.
  • this programming of each of the switches can be done through a single switch MIB and agent access point (the chassis IP/MAC address).
  • the External View In order to provide a logical switch view, the SCS controller or management module must do this by "hiding" the internals of the individual switch engines in the chassis.
  • the external view really reflects the abstraction of the switching engine. Basically a switch engine contains inbound ports, outbound ports, and a connection table (see Fig. 7B) . Note that ports are viewed as uni-directional such that a two-way connection is explicitly defined as two separate uni-directional flows — one flow from source to destination and another as destination to source.
  • the external view does not provide any concept of aggregation since the external view may describe a logical switching system abstraction and not necessarily a real device.
  • the Internal View At the individual "real" switching system, an internal view has to be provided which is different than the generalized external view. What this means is that when a real physical system (device or element) is being managed, then the MIB view can provide aggregates and other information that is not generalized for switched systems. An example is that an individual switch engine can provide aggregate counters for switched packets and for errors inside the physical switch device. It is expected that the internal view as it is called here is used when zooming in to control a very specific device or switching element.
  • One of the principal functions of the management or SCS switch agent 78 is to determine a "best" path through the switches for a given set of metrics (see for example Fig. 1 and the accompanying text). This is important to insuring "fast” transmissions, avoiding bottlenecks (excessive traffic on the backplane), and guaranteeing quality of service (QOS). Set forth below is one preferred method for determining the best path.
  • the search method can be described as a concurrent breadth first path search through a mesh of nodes and arcs — see for example the network topology or mesh of Fig. 1 wherein the switch S and end point systems M would be nodes, and the links L between nodes would be arcs.
  • the problem to be solved is to find a path between any two points in the mesh which has the following properties.
  • the path is optimal for one metric and passes a set of threshold tests for n other metrics.
  • the desired path Q _._L of all the paths QO, .... , QZ_ is the one whose value v is the best and whose values a, .... , n all pass threshold tests A, .... , N. Secondarily, it must do this within a minimum time constraint T.
  • the method assumes an initial set of values and accumulates additional values following the traversal of all nodes and arcs along a path until the path arrives at the destination or goal node.
  • the method was developed to satisfy the requirements of ATM route determination.
  • ATM asynchronous transfer mode
  • the problem is simply to find an optimal path through a mesh which satisfies a number of independent constraints.
  • the solution would be applicable in general to: any routing problem in a mesh network such as a communication network and/or in electrical and electronic circuit design; a distribution of power; a distribution via pipelines; traffic routing over streets and highways; etc.
  • (n + 1) metrics are altered in a monotonically increasing or decreasing function. This is what makes the metrics useful. Since some metrics increase or remain the same for each traversal and some decrease or remain the same, it is confusing to describe them in terms such as larger, smaller, etc. Therefore, we will use the terms best, better, worse, and worst. For example, a cost metric can be best when it is 0 and worst when it is some maximum positive value. Probability, on the other hand, is best when it is 1 and worst when it is 0. A metric which is measured in absolute value (i.e... Impulse fct) would be best at 0 or infinity depending upon your viewpoint (i.e., is the impulse desirable or undesirable) . At initiation there is a vector of metrics which is applied at the source node. At each traversal of a node or arc this vector of values is modified and produces a traversal value which accumulates from a best state to a worst state.
  • a cost metric can be best when it is 0 and worst when it is some maximum
  • the method is a breadth first recursive search in parallel. It is initiated at a source node with an initial set of values and proceeds until there are no further paths to explore. It starts with a list of all the neighbors (neighboring nodes) of the source node. It then processes that list producing another list of all the neighbors of neighbors, etc. It uses several methods of "pruning" to keep the number of potential paths explored from growing towards infinity. A significant feature of this method is the pruning steps. As each node is discovered, a traversal value vector is recorded for that node. Each time the destination node is discovered, the traversal value vector is recorded.
  • a path When a path discovers a node already within the path, it terminates itself. This prevents cycles and prevents infinite loops. If a path discovers that its traversal value vector is not best in any of the (n + 1) metrics, it terminates itself. When a path traversal value vector has no metric which is better than one of the already completed paths, it terminates itself. Any path which would traverse a disabled arc or node, terminates itself. Any paths whose traversal value vector fails the filters (threshold value) in any metric, terminates itself. Any path which encounters an end node (i.e., a node which does not forward traffic, but may be a source or sink for traffic) which is not the destination node, terminates itself.
  • an end node i.e., a node which does not forward traffic, but may be a source or sink for traffic
  • This specific method was developed for wide area networks (WAN) which have a large number of diverse and redundant paths. It is a breadth-first search, which means it proceeds in rings moving outwardly from the source node (see rings 234A, 234B, 234C, etc. in Fig. 13 moving outwardly from source node 1), in order to build a spanning tree. Based on the time-constraint and metrics chosen, the farther one goes across the mesh, i.e., the farther away from source node 1, the higher the probability that one will reach a worst case (i.e., a filter threshold). The metrics progress monotonically toward a worst case.
  • a worst case i.e., a filter threshold
  • the algorithm is designed to proceed toward multiple destination nodes at the same time, and to save more than one path in cache memory so that if a first path becomes unavailable, a second path is readily available in the cache.
  • the method utilizes a number of "pruning" steps or “chokes” for eliminating low probability paths, i.e., subpaths which are not likely to produce the best path.
  • the chokes prevent excessive use of memory space and processing delays which would be required if every possible path were saved.
  • the amount of pruning applied can be varied as follows:
  • the method provides "grouping" such that all values and paths for the next traversal are stored together and processed together as a “computational unit.” This second feature is also important in satisfying the time constraint.
  • the significance of the chokes and grouping is exemplified by the following example.
  • a source code written in "Python” i.e., an interpretive prototyping language
  • FIG. 11 A source code written in "Python” (i.e., an interpretive prototyping language) according to the flow chart of Fig. 11, but without the chokes and grouping, provided a search time of about 115 seconds. Adding the chokes reduced the search time to 40 seconds. Adding the chokes and grouping reduced the time to one second — a 115 time increase in performance.
  • the one second search time is expected to translate into a ten millisecond performance time — well within the desired time constraint.
  • Global Adjacency [N] A one-dimensional array (i.e. a vector) of lists. Each list represents the adjacencies of the corresponding node. Each adjacency is a tuple of the neighboring node and the arc between them. A node may appear in multiple adjacencies for the same neighbor but must have a different arc index for each appearance. Each arc index will appear twice in the Adjacency structure, once for each terminating end point.
  • Local PtrSpace, New PtrSpace Each is an array of records. Each record has 3 fields. The Parentfld contains the index of the parent of this family of traversals. The Pptr contains the pointer within this array of the next parent and is maintained in index order of parents. The Vptr contains the index of the first value associated with this parent in the ValueSpace or New ValueSpace arrays.
  • the Valuefld contains the metric value vector of the aggregate values to this point in the traversals.
  • the Vptr contains the index within this array of the next metric value vector for the parent family of traversals.
  • the Pathptr contains the index into the PathSpace/NewPathSpace array for the first path of this value vector.
  • a Path is a list of lists. The first list is a sequence of node indices in the order of visits during the traversal. The second list is a sequence of arc indices in the order of visits during the traversal.
  • Local Best Value is a tuple of metric values. The first is the best primary value of a complete path seen to this point in the processing. The second is the best secondary value seen to this point in the processing.
  • All Value Vectors are in the same order as defined by the objects in Object_Vector AND ARE NOT necessarily in the same order as their owning objects within Object_Vector. Their position is established when the metric objects are initialized.
  • Route Path has the following formal parameters: Source, Goal, Primary Valuelndex, Secondary Valuelndex, Initial_Values, QOS, Filters and Returns a vector: exception, path, values.
  • Source Integer The source node index of the path.
  • the destination node indices of the possible paths. It may be a single node or multiple nodes.
  • Parameter PrimaryMetricIndex Integer The index within Object_Vector of the metric object for which this path is to be optimal.
  • Parameter SecondaryMetricIndex Integer The index within Object_Vector of the metric object which is the second precedence for optimization of this path.
  • Parameter InitialValue Vector of Metric Values These are the assigned metric values for this path. If this call to the Routing Object is in isolation of all other calls, this should be a vector of best values. However, if this call is made in conjunction with other calls to establish a path across multiple domains, this value will be a value returned from a preceding call to this Routing Object or another which represents an adjacent domain.
  • Each tuple has an index for a metric object within Object_Vector and an aggregate threshold value for that metric object. For example, when cost is the metric object and it has an index of 4 within Object_Vector, (4,40) means reject all paths whose cost is equal to or exceeds 40.
  • 0 is a successful path.
  • 1 is a successful call which determined that no path from source to destination met the constraints. Any other value indicates failure, the most common value being 3 which is an incorrect or inconsistent value for a formal parameter.
  • step 200 is an initialization of the values, wherein “source” refers to the source node address, “goals” refers to the one or more destination node addresses, “pindex” refers to the primary metric, and “sindex” refers to the secondary metric which is used to select the best path if the primary metrics for two paths are equal.
  • the "initial_value” is a vector of all initial values for the metrics which may come from the management system. In a wide area network where there may be a plurality of management systems managing different areas in the network, the best path determination may proceed from one sub-area to another and the initial values may come from the best path determination of an adjacent sub-area.
  • the "QOS” defines the quality of service for the various types of transmissions, such as voice, video or data, and provides static filters which do not change over time.
  • the "filters” are dynamic filters such as call blocking probability, peak cell rate, etc., which are required to change over time.
  • step 201 the value of the data structure "Workhead" is checked.
  • the data structure's Workhead 230, Ptrspace 231, Valuespace 232 and PathSpace 233 form a chain of linked data structures, each with an array of records. PtrSpace and ValueSpace each have three fields, while in PathSpace each record has two fields.
  • the Workhead will not be "none" and we proceed to step 202 wherein we obtain the value of parent (the next node) from PtrSpace. At this time we also set the Workhead equal to the next parent pointer, to get ready for the next traversal.
  • the Parentvalues are set equal to the values for the parent from the Nodevalues. The Nodevalues are the values of the metrics of that node. Proceeding to step 204, we get the "Neighborlist" of adjacent nodes to the parent.
  • step 205 we check whether the Neighborlist is empty, and if not, we proceed to step 206 to get the next neighbor (node) and arc from the next tuple in the Neighborlist.
  • step 206 we proceed to step 206 to get the next neighbor (node) and arc from the next tuple in the Neighborlist.
  • step 207 we proceed to step 207 to check if the neighbor node is the same as the parent; if so, we do not need to check this path (it has already been traversed) and we terminate it (this is one of the chokes).
  • step 208 we check to see if the arc or neighbor is disabled or if we have reached an end node which is not one of our goals, in which case we would terminate (i.e., another choke) .
  • step 211 we get the values from the data structure ValueSpace (232 in Fig. 12) and proceed through steps 213-215 to determine if there is any metric in Values which is better than in Nodevalues, i.e, the values of the metrics up to that node. If this is not a better path in any one metric, then we terminate the path. If not, we proceed with step 216 to record the better values into Nodevalues, and proceed to step 217 to determine whether the Nodevalues pass the threshold filters for each of the metrics.
  • step 218 we proceed to step 218 and now enter the portion of the flow chart where we iterate the paths.
  • step 218 we first check to see whether we have reached the destination node. If we have, we proceed to steps 219 and 220 to check whether the primary metric is the best compared to all previous paths. If not, we terminate the path. If it is, we proceed to step 221 to output the path as the best path determination. Returning back to step 218, if we have not reached the destination node, we proceed to steps 222-223 to check whether this path has produced the best value for the primary metrics and then proceed to step 224 to proceed onto the next Workhead.
  • step 225 we initialize a new traversal. If we have reached the end of our traversals and there is no path which meets all of the constraints, we proceed through steps 226 and 229 to report that no path has been found. Alternatively, if we have a successful result we proceed to steps 226-228 and record the best path.
  • Fig. 13 illustrates a series of traversals from source node 121 to destination node 130.
  • the search proceeds in concurrent rings as illustrated by 234A, 234B, 234C, etc.
  • the various dashed and dotted lines show different paths from source node 121 to intermediate node 129.
  • the traversal of the nodes 121-129 can have six paths, and three paths have been found to arrive at node 129 with equal values.
  • This time savings is enabled by the grouping of values and paths in the linked data structures shown in Fig. 12.
  • Bandwidth-limited resources may be hardware or software resources.
  • bandwidth-limited, shared hardware resources are peripheral devices such as printers, scanners, memories, disk drives and backplane communication links. Backplane communications links are used to connect modules in a device, such as a computer, a network controller, or a network hub such as a bridge or a router.
  • bandwidth-limited, shared software resources are processes such as compression/decompression algorithms, and memory access algorithms. These resources are referred to as bandwidth-limited because their bandwidth limits the rate at which data can be transferred to, from, or by the resource.
  • bandwidth-limited, shared resource is meant to refer to a device or process having a bandwidth limit that determines the rate of transfer of data.
  • a number of modules are contained in a chassis.
  • Each of the modules has one or more ports to which may be connected users or other network segments.
  • the modules are connected together via a backplane communication link over which data is transferred from one module to another resulting in the data being transferred from one port on one module to a port on another module.
  • This backplane communication link although typically having a high bandwidth and resulting high rate of data transfer (typically from several hundred megabits per second to several gigabits per second), is the limiting factor in determining how quickly data is transferred from one port on one module to another port on another module, because the backplane communication link can serve only one port at a time.
  • TDM time division multiplexing
  • a time segment is a unit of time, typically fixed, during which a competing device would be allowed exclusive use of the bandwidth-limited, shared resource.
  • One time segment is assigned for each competing device. If there were ten competing devices, then there would be ten time segments. Each of the competing devices is then assigned to one of the available time segments. This information is then used by a state machine that increments through each time segment to allow the particular competing device assigned to that segment to use the backplane communication link for its assigned time segment. After the state machine has stepped through all ten devices, the process loops back to the first segment and begins again. This results in each competing device being able to use one-tenth of the available bandwidth of the bandwidth-limited, shared resource.
  • a TDM arbiter In a TDM arbiter, the users of each time segment are fixed. For example, the first segment is always assigned to a particular port on the network chassis and the ninth segment is assigned to another particular port on the networking chassis.
  • One of the problems with this type of arbiter is that if the port that is allocated to a time segment is not requesting use of the backplane communication link at the time the TDM arbiter allows it to do so, then that time segment will be wasted and the backplane communication link is idle during the assigned segment.
  • Another way to allocate the time segments of a bandwidth-limited, shared resource such as a backplane communications link is to use a so-called "Round-Robin" arbitration system.
  • a Round-Robin system a list of the competing devices is compiled and stored.
  • An allocation token allowing exclusive use of the backplane communications link is then passed among the list of competing devices, for example, in a sequential manner.
  • the token can be passed to a device that is not necessarily the next device in the list, thus allowing for some prioritizing of allocation among competing devices.
  • the competing device that is in possession of the allocation token is then allowed to use the backplane communication link for a particular time period.
  • One problem with this type of arbitration system is that if the device in possession of the allocation token does not require use of the backplane communication link, the backplane communication link is unused and idle for the particular time segment.
  • fixed allocation systems may be used that determine, at the beginning of a particular time segment, which competing device is to be allowed exclusive access to the backplane communication system.
  • One problem with fixed allocation systems is that the arbitration requires a portion of the time segment to determine which competing device should use that particular time segment. Therefore, the rate at which data can be transmitted across the backplane communications link is reduced because a portion of the time segment must be used to perform arbitration.
  • TDM and Round-Robin arbiters Another disadvantage of the TDM and Round-Robin arbiters is that the latency of transmission of, for example, a data packet, may be increased due to the wasted time segments. That is, although a data packet from a particular port may be waiting and ready for transmission across the backplane communication link, the data packet cannot be transmitted until the TDM arbiter allows the port access to the backplane communication link or the Round-Robin token is allocated to the port.
  • an object of the present invention is to provide a method and apparatus for arbitrating access to a bandwidth-limited, shared resource in a manner that improves latency through a bandwidth-limited resource.
  • Another object of the present invention is to provide a method and apparatus for accessing bandwidth-limited, shared resources that allows the bandwidth-limited resource to be used whenever there is a competing device requesting access to the bandwidth-limited resource.
  • Another object of the present invention is to provide a method and apparatus that allows a bandwidth-limited resource to service competing devices that have a total aggregate bandwidth greater than the bandwidth of the bandwidth-limited, shared resource.
  • Another object of the present invention is to guarantee different quality of services to different competing devices depending upon priorities of the competing devices.
  • the present invention will now be explained with reference to its use for allocating time segments of a backplane communication link (a bandwidth-limited, shared resource) in a networking chassis.
  • a backplane communication link a bandwidth-limited, shared resource
  • the present invention is generally applicable to allocation of time segments of any type of bandwidth-limited resource to a number of competing devices.
  • the present invention may be used to control access to a local bus, a switch, a disk drive, a memory bank, or a software process.
  • Fig. 14 illustrates a networking chassis 410 that may be, for example, a bridge, router, or hub.
  • the chassis contains a number of slots that can receive plug-in modules 412-1 through 412-N.
  • a backplane including a communication link 416 connects the modules together to provide data transfer and control.
  • Each of the modules 412 includes an arbitration circuit 414 that controls access to backplane communication link 416.
  • the modules contain a number of ports 1-n to which devices that require use of the backplane communication link 416 are connected.
  • the networking chassis 410 is described more fully in a copending and commonly owned application entitled Distributed Chassis Agent For Network Management, by Brendan Fee et al., filed on even date herewith, the disclosure of which is incorporated herein by reference in its entirety.
  • the backplane communications link has a bandwidth of 4 gigabits.
  • Each of the devices 1-N which may be peripherals, workstations, network segments, bridges, routers, or other hubs, compete for access to backplane communication link 416 in order to transmit data from one device to another.
  • Fig. 15 illustrates one embodiment of arbitration circuit 414 illustrated in Fig. 14.
  • one or more of the arbitration circuits 414 is chosen to act as arbiter for all of the competing devices connected to all the ports of all modules 412.
  • Arbitration circuit 414 includes a set of status and control registers 418 that are used to control access to memory 422 and arbitration engine 424 by the CPU (central processing unit, not shown) that is acting as the chassis control agent in accordance with the method and apparatus described in the copending application.
  • the data transceiver 426 provides any necessary interface between communication link 416 and memory 422 and latch 428. Communication link 416 is typically a multibit bus.
  • the latch 428 is used to transfer data from memory 422 or data transceiver 426 to the arbitration engine 424.
  • An address generator 430 which may be a counter, is used to incrementally generate addresses for reading and writing data and control information into and out of memory 422.
  • the arbitration engine 424 arbitrates between requests received from devices on bus 432 to allocate time segments of backplane communication link 416 to the competing devices using control bus 434. Lines 436 and 438 are used to provide appropriate initialization and control signals.
  • the first step in setting up the arbitration mechanism of the present invention is to program the length of the time segments and the order in which the time segments are to be allocated.
  • the time segments are typically of equal length and the length of a particular time segment is dependent upon a particular application, the architecture of the communication link 416 and its bandwidth (or the architecture and bandwidth of the particular bandwidth- limited, shared resource that arbitration circuit is to control). For example, if communication link 416 is a bus that is only a few bits wide, the time segments need to be shorter time intervals so that data can be moved quickly. In a like manner, if the communication link 416 is a bus having a relatively wide width (i.e., 32 or 64 bits), then the time segments may be longer time intervals to provide the same bandwidth.
  • the first level of arbitration performed by arbitration circuit 414 is a programmable time division multiplexing type arbitration.
  • Memory 422 is used to provide this program ability.
  • arbitration engine 424 operates basically as a state machine wherein the states determine which competing device is to be allocated a time segment as a function of the information programmed in memory 422. Each location in the memory is programmed with information indicating which competing device is to have access to the next time segment to be allocated.
  • address generator 420 increments the memory location so that when arbitration engine 424 accesses the memory during the next state of the state machine, information as to which competing device has rights to exclusive use of communication link 416 is available.
  • Figs. 16 and 17 illustrate some examples of how the state machine might be programmed and operate.
  • Fig. 16 illustrates the case where all of the competing devices are given equal bandwidth.
  • competing device 1 has been programmed in memory 422 as the competing device allocated to the first time segment.
  • competing device 2 has been programmed as the competing device allocated to the second time segment.
  • competing device 3 has been programmed as the competing device allocated to time segment 3.
  • competing device 4 has been programmed as the competing device allocated to time segment 4.
  • the state machine returns to state 1 and continues processing.
  • Fig. 17 illustrates an embodiment in which the time division multiplexing arbiter has been programmed to allocate the bandwidth unequally.
  • state 1 the time segment is allocated to competing device 1.
  • state 2 the time segment is allocated to competing device 2.
  • state 3 the time segment is allocated to competing device 1 again.
  • state 4 the time segment is allocated to competing device 3.
  • state 5 the time segment is allocated again to competing device 1.
  • state 6 the next time slice is allocated to competing device 4. From state 6, the state machine returns to state 1 and processing continues.
  • competing device 1 has been allocated 1/2 of the available bandwidth of communication link 16 and the remaining one-half bandwidth has been allocated equally among competing devices 2, 3, and 4.
  • memory 422 can be programmed to accommodate these needs.
  • the programmable time division multiplexing arbitration system provides a first level of arbitration that can be used to assign priorities for access to communication link 416 among the various competing devices.
  • Fig. 18 illustrates one of the features of the present invention in which arbitration and allocation of time •segments are performed during the data transfer cycle just prior to the cycle in which the time segment is to be used.
  • step 450 the system is initialized. Initialization includes programming memory 422. From step 450, the system proceeds to step 452 in which a first arbitration and allocation step to allocate the first available time segment is performed. This step corresponds to, for example, determining in state 1 of Figs. 16 or 17, which device is entitled to exclusive access to communication link 416.
  • step 452 the system proceeds to step 456 in which another arbitration and allocation step is performed.
  • step 456 the system also proceeds in step 454 to allow a data transfer across communication link 416 by the competing device determined in step 452.
  • step 456 the system proceeds to step 460 in which another arbitration and allocation step is performed.
  • step 450 is performed and during time interval T.
  • step 452 is performed.
  • steps 456 and 454 are performed and during time interval T 3 , steps 460 and 458 are performed.
  • Time intervals T Q - n are equal sized time intervals.
  • the system continues in this mode of arbitrating and allocating the next available time segment in parallel with a data transfer that is already occurring. Although this results in a penalty because one extra arbitration and allocation step (namely step 452) must be performed before the first data transfer can occur, once this first arbitration and allocation has been performed, the system operates with improved efficiency because allocation and arbitration and data transfer occur simultaneously.
  • the next available time segment is arbitrated and allocated during the time segment of the previous data transfer.
  • wrap register 421 is programmed to reset address generator 430 and memory 422 to their first addresses when all of the states of the state machine have been processed. For example, if memory 422 contained 2,000 locations, address generator 430 will control the memories to sequence through all 2,000 addresses until the counter reaches its upper limit and turns over. However, in the situation where there are fewer than 2,000 states in the state machine, as illustrated in Figs. 16 and 17, further improvements in efficiency can be obtained by programming wrap register 421 vith the highest state of the state machine (and/or the highest address location of the memory 422). For example, in Fig.
  • wrap register 421 would be programmed to indicate that the highest state in the state machine is state 6 and would also contain the highest programmed address in memory 422. In each state of the state machine, a check is made of wrap register 421 to determine whether or not the state machine has reached its last state. If the answer is yes, the state machine loops back to state 1 and processing continues. On the other hand, if the check indicates that the last state of the state machine or the highest address in the memory has not been reached, then the state machine and address are incremented to the next state and address, respectively.
  • the programmable arbitration system of the present invention provides a first level of arbitration and allows competing devices which require deterministic service policies such as isochronous devices to be serviced with other nondeterministic devices trying to access the communication link 416. This fixed allocation system also guarantees that the bandwidth needed to service an isochronous device is always available.
  • Fig. 19 illustrates the method of the present invention including all three levels of arbitration.
  • the second and third levels of arbitration when competing devices have been programmed to use them, allow unused time segments to be allocated to other competing devices in order to improve system performance.
  • step 500 the arbitration circuit 414 is initialized. Initialization includes assigning each competing device an identification number and assigning time segments to these identification numbers as illustrated in, for example, Fig. 17. One skilled in the art will appreciate that a competing device may be prohibited from participating in the first level of arbitration by not assigning it a time segment. In addition, a list of the competing device identification numbers is also stored in memory 422 and an allocation token is assigned to one of the competing device identification numbers. Also, initialization includes programming, into memory, which levels of arbitration a competing device may participate in. From step 500, the system proceeds to step 502.
  • step 502 the TDM state machine programmed in accordance with, for example, Fig. 16 or 17, is initialized and a first arbitration and allocation step, such as step 452 in Fig. 18, is performed.
  • step 504 the system goes to the first state of the programmed state machine.
  • step 504 the system proceeds to step 506.
  • step 506 the system determines which competing devices are requesting use of communications link 416 by monitoring request signals received on, for example, bus 432 in Fig. 15. From step 506, the system proceeds to step 508.
  • step 508 the system determines whether any requesting device identification number equals the identification number that has been programmed for the next state of the state machine. If the answer is yes in step 508, the system proceeds to step 510 in which the time segment is allocated to the requesting device identified in step 508. On the other hand, if the answer in step 508 is no, the system proceeds to step 512.
  • step 512 the system determines whether any requesting device identification number equals the identification number of the device associated with the allocation token that was assigned in initialization step 500. This provides a second level of arbitration. The system also checks if the requesting device has been programmed to participate in the second level of arbitration. If the time segment remains unallocated after the first level of arbitration in step 508, the system provides a second level of arbitration, in step 512, to attempt to assign the unused time segment to another competing device. If the answer is yes in step 512, the system proceeds to step 514 in which the system determines whether the device identified in step 512 is presently using the bandwidth-limited, shared resource, i.e., the communication link 416 illustrated in Figs. 14 and 15. The purpose of step 514 is to prevent one of the competing devices from hogging the communications link for multiple time segments. If the answer is no in step 514, the system proceeds to step 516 in which the time segment is allocated to the requesting competing device identified in step 512.
  • Step 518 provides a third level of arbitration that attempts to make use of the unallocated time segment if the first two levels of arbitration have not assigned the time segment.
  • the system determines whether there is a requesting competing device having the lowest identification number in the list of competing devices and whether that device has been programmed to participate in the third level of arbitration. If the answer is yes in step 518, the system proceeds to step 520 and allocates the time segment to the requesting competing device identified in step 518. From step 520, the system proceeds to step 522.
  • step 518 if the system determines that there is no device waiting to use communication link 416, then the time segment goes unallocated and the system proceeds to step 522.
  • the third level of arbitration is illustrated as assigning the time segment to the device having the lowest identification number, clearly other allocation schemes could be substituted for this step.
  • the time segment could be allocated to the device having the highest identification number in the list of competing devices.
  • the third level of arbitration allocates the time segment to the requesting competing device having a predetermined rank in the list of competing devices.
  • the predetermined rank may be the lowest identification number, the highest identification number, or the identification number in the middle of the list, for example.
  • step 522 the allocation token is passed to the next competing device in the list of competing devices.
  • step 522 the system proceeds to step 523 in which an enable signal is sent to the competing device selected in steps 510, 516, or 520.
  • step 524 the wrap register is checked to determine if the last state of the state machine or the last programmed memory location has been reached. If the answer is yes in step 524, the system proceeds to step 504, returning to the first state of the state machine, and processing continues as already described. On the other hand, if the answer in step 524 is no, the system proceeds to step 526. In step 526, the address of memory 422 is incremented and the state machine goes to the next sequential state. From step 526, the system proceeds to step 506 and processing continues as already described.
  • the allocation and arbitration steps proceed in parallel with data transfers occurring during a time segment. That is, the system is proceeding through steps 500-522 while the competing device that had been enabled as a result of step 523 in the prior arbitration and allocation cycle is performing a data transfer.
  • the present invention provides a number of advantages.
  • conventional TDM type arbiters are hard-coded logic implementations that are not programmable and not easily used in other applications once designed.
  • the present invention on the other hand, being a programmable memory-based device, is not only programmable, but the same hardware can be used in other applications.
  • the programmable memory also allows the present invention to be configured to allow any time segments or mix of time segments to be assigned to a bandwidth-limited, shared resource rather than having the resources assigned to the same segment in every implementation.
  • the present invention provides a system in which competing devices that require deterministic and regular service policies can be accommodated, as well as devices that can arbitrarily make use of a bandwidth-limited, shared resource.
  • the present invention allows unused time segments to be allocated to devices that can make use of them, thus improving the latency of data transmission to or through the bandwidth-limited, shared resource, if the competing devices are programmed to participate in the second
  • the present invention may be implemented in a variety of ways.
  • the invention can be implemented completely in software, completely in hardware, or in a combination of both.
  • memory 422 can be implemented as static RAM, dynamic RAM, novRAM, or proms.
  • the control circuitry of address generator 430, data transceiver 426, and latch 428 can be fabricated from standard TTL devices, CMOS devices, or incorporated into single chip implementations such as PALS, FPGAs, or ASICS.
  • the previously defined multi-level programmable arbitration is applied to module 32 plugged into networking chassis 30 (see Fig. 4).
  • the module 32 includes an SFPS switch 40, as shown in Fig. 5; the internal operation of the SFPS switch was previously described with regard to " Fig. 2.
  • the multilevel programmable arbiter (MPA) 13 (shown
  • the host gets 100k x 256, or 25.6 Mbits/sec.
  • the backplane gets 100k x 256 x 12, or approximately 307 Mbits/sec.
  • the round robin token continually circulates between all those devices enabled to use it.
  • the third level of arbitration is available to those devices enabled to use it, and awards the unused time slice to the lowest requesting device participating in the third level arbitration.
  • the ports themselves will put requirements on how often they need a slice.
  • the Ethernet ports have 32 byte pre-staged fifos that need to be filled or emptied within a certain time interval.
  • the Ethernet ports having 32-byte fifos need a data transfer of 32 bytes every 32 x 800 nsec or 25.6 usec. This means that each Ethernet port needs its port ID programmed at no less than a 25.6 usec interval in the TDM ram to insure that no overflow or underflow occur for the device.
  • the 25.6 usec translates to 64 time slices in the TDM ram. As long as the slices for a particular Ethernet port are not further apart in the ram than 64 addresses, no under or over runs of data will occur. FDDI ports would require a different bandwidth allocation.
  • a complete functional model of the SFPS may be implemented as software objects within the firmware architecture.
  • the SFPS is integrated within the generalized system architecture which allows it to be a logical application within the system and have access to the resources and communication device drivers.
  • Connection Table Object 606 InPort Objects 607
  • OutPort Objects 608 the Switch Engine Object 609.
  • Connection Table Object Provides the data and methods for maintaining the cross connect mapping of in-ports and out-ports for each connection. It is indexed, in order, by SFPS connection-identifiers. Connection-identifiers are formed by combining the source-port, the source MAC address, and the destination MAC address of the end stations for which a connection is defined. Note that multi-party connections will have a list of out-ports within the Connection Table.
  • the Connection Table is an AVL-tree (a balanced binary tree) which can grow to arbitrary size. Currently, a maximum of 16,000 connection entries are supported. In addition to providing internal access for the Switch Engine, it also provides call accounting information on each active connection as well as the managed object view for remote management.
  • Port Objects Provides the data and methods for configuring and accessing the physical media ports for in-bound and out-bound traffic.
  • these Port objects 610 are objects that allow SFPS-specific use of physical switch ports 611 within the system.
  • these objects access the physical port through a Framing Object 612 which hides the media-specific framing characteristics of the communication datalink.
  • the Framing Objects interface with the media-specific device driver 613 through a common datalink Interface Object 614 and packet memory which is described and accessed with Packet Control Structures (PCS) 615.
  • PCS Packet Control Structures
  • Switch Engine Object Provides the data and methods for the actual switching machine of the SFPS. This object implements a TDM and polling software to service in-bound and out-bound ports.
  • the Switch Engine Object is the central engine of the SFPS Switch. It provides the context under which the switching of packets is performed.
  • Threads exist for SFPS which provide functionality required for SFPS which is not in the SFPS Switch itself. These mainly deal with the access to external servers and control points which exist outside of the embedded device. Each of these threads are instantiated by the SFPS Application Object. Threads are essentially processes or software tasks. Each of the SFPS applications are described below.
  • SFPS Switch Agent This thread provides the remote management of the SFPS Switch. It implements the managed objects which are the objects that provide the SNMP-based view of the control and configuration aspects of the switch. These managed objects are also used internally to provide access from the local console.
  • the actual MIB and its managed object definition is set forth in section 11.3.
  • SFPS Call Processor This thread provides the logic and interface for translating unknown or broadcast packets into third-party call requests. This is a key element of providing access through an SFPS Switch, since the Switch itself will not provide any switching capability until it is "programmed" with connections in the connection table.
  • the Call Processor thread processes packets by decoding the protocol-specific frames, decoding either MAC addresses or network-level addresses inside the network packet to determine the end-to-end system path for the connection and making API message requests to the SFPS Connection Server.
  • the Call Processor specifically translates protocol packets into implied connection requests and asks the SFPS connection server to establish a logical path of switched connections allowing the source and destination end systems to have a uni-directional connection through the SFPS network fabric.
  • This thread provides the logic and capability to discover adjacent systems attached to the SFPS Switch. Specifically, this thread snoops on protocol packets and determines if it originated from another SFPS Switch (SFPS Adjacency) or from an end system (SFPS user). By snooping the packets it decodes and extracts any address information inside the packet. In particular, the thread extracts the source MAC address and any high-layer protocol addresses and, in turn, registers these with an external SFPS Directory Server. In addition, it maintains a discovery table which shows adjacencies and end systems for each inPort and outPort on the switch.
  • SFPS Adjacency SFPS Adjacency
  • SFPS user end system
  • This module will be extended, as required.
  • Cabletron Systems reserves the right to make changes in Specification and other information contained in this document without prior notice. The reader should consult Cabletron Systems to determine whether any such changes have been made.
  • Cabletron grants vendors, end-users, and other interested parties a non-exclusive license to use this Specification in connection with the management of Cabletron products. Copyright October 93 Cabletron Systems
  • OBJECT IDENTIFIER ⁇ enterprises 52 ⁇ mibs
  • OBJECT IDENTIFIER ⁇ Cabletron 4 ⁇ ctronExp
  • OBJECT IDENTIFIER ⁇ mibs 2 ⁇ ctronSwitch
  • OBJECT IDENTIFIER ⁇ ctronExp 4 ⁇ switchCommon
  • OBJECT IDENTIFIER ⁇ ctronSwitch 1 ⁇ switchSFPS
  • OBJECT IDENTIFIER ⁇ ctronSwitch 2 ⁇
  • OBJECT IDENTIFIER ⁇ switchSFPS 1 ⁇ sfpsSwitchAgent
  • OBJECT IDENTIFIER ⁇ switchSFPS 2 ⁇
  • OBJECT IDENTIFIER ⁇ sfpsSwitchEngine 1 ⁇ sfpsSwitchPorts
  • OBJECT IDENTIFIER ⁇ sfpsSwitchEngine 2 ⁇ sfpsSwitchConnections
  • OBJECT IDENTIFIER ⁇ sfpsSwitchEngine 3 ⁇
  • OBJECT IDENTIFIER ⁇ sfpsSwitchAgent 3 ⁇ stpsAgentDiagnostics
  • OBJECT IDENTIFIER ⁇ sfpsSwitchSystem 1 ⁇ sfpsSystemStats
  • OBJECT IDENTIFIER : « ⁇ sfpsSwitchSystem 2 ⁇
  • OBJECT IDENTIFIER : : ⁇ sfpsSwitchPorts 2 ⁇
  • OBJECT IDENTIFIER ⁇ sfpsAgentTopology l ⁇ sfpsTopologyAdjacencies
  • OBJECT IDENTIFIER ⁇ sfpsAgentTopology 2 ⁇
  • This group contains the objects that pertain to SFPS switching engines at a SFPS switch module single-instance level. This group contains two sub-groups: configuration and statistics.
  • This group contains the objects that pertain to the setup and configuration of a single instance of an SFPS.
  • SfpsSysConfigEntry SEQUENCE ⁇ sfpsSysConfigSwitchlnstance SfpsSwitchlnstance, sfpsSysConfigAdminStatus INTEGER, sfpsSysConfigAdminReset INTEGER, sfpsSysConfigOperStatus INTEGER, sfpsSysConfigOperTime TimeTicks, sfpsSysConfigLa ⁇ tChange TimeTicks, sfpsSysConfigVersion DisplayString, sfpsSysConfigMibRev DisplayString, sfpsSysConfigHostMgmtPort SfpsSwitchPort, sfpsSysConfigHostCtlPort SfpsSwitchPort, sfpsSysConfigBcastPort SfpsSwitchPort, sfpsSwitchPort
  • SYNTAX Sfp ⁇ SwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the SFPS switch port that will be forwarded all non-broadcast frames that are not part of a valid connection.” ⁇ sfpsSysConfigEntry 12 ⁇
  • Thi ⁇ group containg the object ⁇ that pertain to the performance monitoring and statistic ⁇ of a single instance of an SFPS switch.
  • SfpsSy ⁇ Stat ⁇ Entry SEQUENCE ⁇ ⁇ fpsSysStat ⁇ Switchln ⁇ tance Sfp ⁇ Switchln ⁇ tance, ⁇ fp ⁇ Sy ⁇ Stat ⁇ AdminStatu ⁇ INTEGER, ⁇ fpzSy ⁇ Stat ⁇ Re ⁇ et INTEGER, ⁇ fpsSysStat ⁇ OperTime TimeTick ⁇ , ⁇ fp ⁇ Sy ⁇ Stat ⁇ lnPkt ⁇ Counter, ⁇ fp ⁇ SysStatsOutPkt ⁇ Counter, ⁇ fp ⁇ Sy ⁇ Stat ⁇ Di ⁇ cardPkts Counter, sfpsSy ⁇ Stat ⁇ FilteredPkt ⁇ Counter, ⁇ fp ⁇ Sy ⁇ Stat ⁇ lnOctet ⁇ Counter, sfpsSysStat ⁇ OutOctet ⁇ Counter, ⁇ fp ⁇ Sy ⁇ tat ⁇ D
  • This group contains the managed objects used to setup and configure the SFPS ports for packet switching and statisic ⁇ monitoring.
  • Thi ⁇ group contain ⁇ two sub-groups: configuration and stati ⁇ tic ⁇ .
  • Thi ⁇ table contain ⁇ the managed object ⁇ used to set-up and configure each SFPS ⁇ witching port .
  • Sfp ⁇ lnPortConfigEntry : : SEQUENCE ⁇ ⁇ fp ⁇ lnPortConfigPort SfpsSwitchPort, ⁇ fp ⁇ inPortConfigAdminStatu ⁇ INTEGER,
  • STATUS mandatory DESCRIPTION "Set ⁇ the type of port access attribute for the inbound SFPS port for which the entry exi ⁇ t ⁇ . Acce ⁇ port ⁇ allow ⁇ ingle u ⁇ er or shared access and perform statistic ⁇ and control; network port ⁇ are equivalent to trunk port ⁇ with no acce ⁇ control; host management port indicates the (virtual) port to which the (internal) management agent is attached; host control port indicates the port to redirect nonmanagement packets.
  • DESCRIPTION "Sets the amount of Bandwidth that is reserved for the inbound SFPS port for which this entry exist ⁇ . Thi ⁇ bandwidth i ⁇ ⁇ et a ⁇ ide for thi ⁇ port and may be given to another port if unused.”
  • SfpsInPortConfigQLen OBJECT-TYPE SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the actual inbound queue size for this port. Size is indicated in packets (packet descriptor ⁇ ) . Thi ⁇ is a transient value that reflects the current depth of queue. "
  • Sfp ⁇ OutPortConfigEntry SEQUENCE ⁇ sfpsOutPortConfigPort SfpsSwitchPort, Sfp ⁇ OutPortConfigAdminStatu ⁇ INTEGER, ⁇ fp ⁇ OutPortConfigOperStatu ⁇ INTEGER, ⁇ fp ⁇ OutPortConfigOperTime TimeTicks, sfp ⁇ OutPortConfigType INTEGER, ⁇ fp ⁇ outPortConfigRe ⁇ ervedBW INTEGER, ⁇ fp ⁇ OutPortConfigAllocBW INTEGER, ⁇ fp ⁇ OutPortConfigQoS INTEGER, ⁇ fp ⁇ outPortConfigQSize Gauge, ⁇ fp ⁇ OutPortConfigQLen INTEGER
  • SYNTAX SfpsSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. Thi ⁇ identifie ⁇ the outbound SFPS ⁇ witch port for which the entry exi ⁇ t ⁇ .” ⁇ ⁇ fp ⁇ OutPortConfigEntry 1 ⁇
  • ACCESS read-write STATUS mandatory DESCRIPTION "Sets the type of port access attribute for the outbound SFPS port for which the entry exist ⁇ .
  • Acce ⁇ port ⁇ allow ⁇ ingle u ⁇ er or shared access and perform stati ⁇ ic ⁇ and control; network ports are equivalent to trunk port ⁇ with no acce ⁇ s control; host management port indicates the (virtual) port to which the (internal) management agent i ⁇ attached; ho ⁇ t control port indicate ⁇ the port to redirect non-management packets .
  • " : ⁇ sfpsOutPortConfigEntry 5 ⁇
  • SYNTAX INTEGER ACCESS read-write STATUS mandatory DESCRIPTION "Set ⁇ the amount of Bandwidth that is reserved for the outbound SFPS port for which this entry exists. This bandwidth is set aside for this port and may be given to another port if unused.”
  • DESCRIPTION "Sets the amount of Bandwidth that is allocated for the outbound SFPS port for which this entry exists. This bandwidth may be less than the reserved bandwidth.”
  • SYNTAX Gauge ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the maximum outbound queue size for this port. Size is indicated in packets (packet descriptors)." ⁇ Sfp ⁇ OutPortConfigEntry 9 ⁇
  • SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the actual outbound queue size for this port. Size is indicated in packet ⁇ (packet de ⁇ criptor ⁇ ) . Thi ⁇ i ⁇ a tran ⁇ ient value that reflects the current depth of queue. "
  • This table contains the object ⁇ that ⁇ pecify the packet
  • Sfp ⁇ lnPortStat ⁇ Entry SEQUENCE ⁇ sfp ⁇ lnPortStat ⁇ Port SfpsSwitchPort, sfp ⁇ lnPortStat ⁇ AdminStatu ⁇ INTEGER, ⁇ fpsinPortStatsRe ⁇ et INTEGER, ⁇ tp ⁇ fnPortStatsOperTime TimeTicks, sfp ⁇ lnPortStat ⁇ Pkt ⁇ Counter, ⁇ fp ⁇ lnPortStat ⁇ Di ⁇ cardPkt ⁇ Counter, sfpsInPortStat ⁇ Bytes Counter, sfpsInPortStat ⁇ Di ⁇ cardByte ⁇ Counter, ⁇ fp ⁇ lnPortStat ⁇ QOverflow ⁇ Counter
  • Sfp ⁇ OutPortStatsEntry SEQUENCE ⁇ sfp ⁇ OutPortStat ⁇ Port ⁇ fp ⁇ SwitchPort, ⁇ fp ⁇ OutPortStat ⁇ AdminStatu ⁇ INTEGER, ⁇ fp ⁇ OutPortStat ⁇ Re ⁇ et INTEGER, ⁇ fp ⁇ OutPortStat ⁇ OperTime TimeTick ⁇ , ⁇ fpsOutPortStatsPkt ⁇ Counter, sfpsoutPortStat ⁇ DiscardPkts Counter, sfpsOutPortStat ⁇ Byte ⁇ Counte , sfpaOutPortStatsDi ⁇ cardByte ⁇ Counter, ⁇ fpsoutPortStatsQOverflow ⁇ Counter ⁇
  • Thi ⁇ identifies the SFPS outbound switch port for which the entry exist ⁇ .”
  • Sfp ⁇ ConnectionEntry SEQUENCE ⁇ ⁇ fp ⁇ CnxInPort SfpsSwitchPort, ⁇ fp ⁇ CnxSource SfpsAddre ⁇ , ⁇ fp ⁇ CnxDe ⁇ tination Sfp ⁇ Addre ⁇ s, ⁇ fp ⁇ CnxRowStatu ⁇ INTEGER, ⁇ fp ⁇ CnxAdminStatu ⁇ INTEGER, ⁇ fp ⁇ CnxOutPort SfpsSwitchPort, ⁇ fp ⁇ cnxAge TimeTicks, ⁇ fp ⁇ CnxType INTEGER, ⁇ fp ⁇ CnxRe ⁇ ervedBW INTEGER, ⁇ fp ⁇ CnxAllocBW INTEGER, ⁇ fp ⁇ CnxCurrentBW INTEGER, , ⁇ fp ⁇ CnxQoS INTEGER, ⁇ fpeCnxPkt ⁇ Counter, ⁇ fp ⁇ CnxByte
  • Thi ⁇ table contain ⁇ the li ⁇ t of outbound port ⁇ for a connection entry. Note that a uni traffic flow can go out multiple outbound port ⁇ , which may be u ⁇ eful for virtual LAN ⁇ or multica ⁇ t group ⁇ .
  • SfpsConnectionOutPortEntry SEQUENCE ⁇ ⁇ fp ⁇ CnxOutPortInPort Sfp ⁇ SwitchPort, ⁇ fp ⁇ CnxOutPortSource Sfp ⁇ Addre ⁇ s, ⁇ fp ⁇ CnxOutPortDe ⁇ tination SfpsAddre ⁇ s, ⁇ fp ⁇ CnxOutPortID SfpsSwitchPort, ⁇ fp ⁇ CnxOutPortRowStatu ⁇ INTEGER, ⁇ fp ⁇ CnxOutPortAdminStatu ⁇ INTEGER

Abstract

Apparatus and method for establishing 'virtual connections' through a switched data communications network which provides higher speed, lower cost, integrated services, and manageability. Once the virtual connection is established, the switches can move connectionless data packets along the established path in a straight-forward manner without transformation of the data packets. The complexities associated with routing data are pushed out of the data transfer path and are instead handled at connection establishment time. This allows the switches to be simpler and therefore faster. Also, the switching decision is substantially protocol independent and transparent to the end systems. It also yields important benefits in terms of manageability because capabilities which were too costly to perform on a packet-by-packet basis can readily be performed at connection establishment time. Thus, a new level of manageability can be achieved which was not practical with datagram oriented technology. Improved allocation of bandwidth and a new best path searching method are also provided.

Description

NETWORK HAVING SECURE FAST PACKET SWITCHING AND GUARANTEED QUALITY OF SERVICE
Field of the Invention
This invention relates to communication networks, and more particularly to an apparatus and method for providing a high transfer rate, guaranteed quality of service, and secure internetworking of packet-based LAN and WAN segments by establishing temporary connections which are protocol- independent and transparent to the end systems. In addition, this invention is directed to allocating bandwidth by multiple levels of arbitration among competing devices requesting access to a bandwidth-limited shared resource, and to a search method for making a best path determination through the network based on a number of constraints.
Background of the Invention
Data networks today rely heavily on shared medium, packet-based LAN technologies for both access and backbone connections. The use of packet switching systems, such as bridges and routers, to connect these LANs into global internets is now widespread. An internet router must be capable of processing packets based on many different protocols, including IP, IPX, DECNET, AppleTALK, OSI, SNA and others. The complexities of building networks capable of switching packets around the world using these different protocols is challenging to both vendors and users.
Standards-based LAN systems work reasonably well at transfer rates up to about 100Mbps. At transfer rates above 100Mbps, providing the processing power required by a packe- switch interconnecting a group of networks becomes economically unrealistic for the performance levels desired. This inability to economically "scale up" performance is beginning to cause restrictions in some user's planned network expansions. Also, today's data networks do not provide network managers with enough control over bandwidth allocation and user access.
Tomorrow's networks are expected to support "multimedia" applications with their much greater bandwidth and real-time delivery requirements. The next generation networks should also have the ability to dynamically reconfigure the network so that it can guarantee a predetermined amount of bandwidth for the requested quality of service (QOS) . This includes providing access, performance, fault tolerance and security between any specified set of end systems as directed by the network's manager. The concept is to provide network managers with complete "command and control" over the entire network's infrastructure — not just tell them when a failure has occurred.
A new set of technologies known as asynchronous transfer mode (ATM) may provide the best, long-term solution for implementing the requirements of both private and public internets. ATM promises to provide a more economical and scalable set of technologies for implementing the ultra-high-performance information networks that will be required to provide the quality of service users will demand. Thus, over the next 20 years, the network infrastructure may change from packet-based standards to one based on ATM cell switching. While changes in the accompanying network will be dramatic, it would be desirable for users making the transition to be able to.retain their most recent equipment investment.
Another expected change in tomorrow's networks is a change in data flow. Data flow in today's network typically follows the client-server computing model. This is where many clients are all transferring data into and out of one or more network servers. Clients do not normally talk to each other; they share data by using the server. While this type of data exchange will continue, much more of the information flow in tomorrow's networks will be peer-to-peer. Since the ultimate goal is a truly distributed computing environment where all systems act as both the client and server, more of the data flow will follow a peer-to-peer model. The network will be required to provide more direct access to all peers wishing to use high-performance backbone internets connecting, for example, the desktop computers.
The bulk of information transported in the future will be of digital origin. This digital information will require a great deal more bandwidth than today's separate voice, fax, and SNA networks which operate with acceptable performance using voice grade telephone lines. Voice will shrink as a percentage of total traffic, while other forms of information including image and video will greatly increase. Even when compressing is available, the bandwidth requirements for both inside and outside building networks will need to be greatly expanded.
Text files and images can be sent over existing packet-based networks because the delivery of this information is not time critical. The new traffic (voice and video) is delivery time sensitive — variable or excessive latency will degrade the quality of service and can render this information worthless.
Thus, the new infrastructure requirements are expected to include:
• increased workstation processing power at the desktop, which is driving the need for increased network performance and capacity;
• increased numbers of network users, which is driving the need for increased network security;
• network access and bandwidth allocation must be managed;
• integrated voice, video and data applications are increasing the need to be able to guarantee improved network quality of service (QOS); • management must be able to provide a variable quality of service to each user based on their particular needs (a user's needs may change at any time);
• the ability to guarantee each user's QOS can only be achieved by tightly integrating the network and its management systems.
It is an object of the present invention to provide an apparatus and method which satisfies one or more of the above-mentioned requirements.
Summary of the Invention
In one important aspect, the present invention is a new technology referred to as secure fast packet switching (SFPS) . SFPS will provide the same or better reliability and security as routers and with much greater packet switching performance, without an increase in cost. This is because the complexities and costs of providing multi-protocol routers increase greatly as performance needs go up. Also, SFPS provides the following capabilities, which routers cannot provide:
• ability to create many separate, logical work group LANs on the same physical network
• ability to create many separate virtual connections or circuits with a specified quality of service (QOS)
• ability to guarantee a requested QOS — time sensitive delivery
• ability to account for network use (why is the phone bill so high?)
Although ATM cell switching may similarly provide many of these new capabilities, adoption of cell switching would require that all existing networks be re-engineered. SFPS provides a transition between the packet based technologies of today and the cell based technologies of tomorrow. SFPS will enable a mixed packet and cell based network infrastructure to operate as one seamless switching fabric using the same service and configuration management system to deliver the QOS that users demand.
SFPS provides for high performance packet switching based on source and destination MAC IDs — the unique medium access control (MAC) address assigned to each end system by the IEEE. End-to-end connections are determined by a network management application that provides security and best path routing determinations based on a number of constraints. By switching connectionless datagram packets based only on MAC layer information, the network infrastructure can remain protocol insensitive. This allows the network to provide an equal QOS to users sending packets based on NetBIOS, LAT, IP, IPX, SNA, or any other protocol. As protocols evolve the network and its management infrastructure will not have to be reworked to support the new protocols.
More specifically, the system uses source and destination MAC addresses which alone, or in combination with the input port on the switch, form a unique "connection identifier" for any communication exchange between end systems to be connected through an SFPS device. A specific example is as follows: input port = 2 source MAC address = 00:00:ID:01:02:03 destination MAC address = 00:00:ID:11:22:33; together, these form a "tuple" bound to a specific uni-directional flow from source address to destination address. All packets that have this tuple are automatically switched according to the operation of the SFPS.
Network infrastructures are built up around a core switching fabric. The switching fabric provides the physical paths or routes that allow users to send information to each other. Access to the switching fabric is gained through an access port. Access ports provide several functions — most importantly, they provide security and accounting services. Access ports also provide the network operator with the ability to monitor and control the access into and use of the switching fabric. End point systems such as personal computers (PCs), workstations, and servers connect to the access port using one of many access technologies such as Ethernet, Token Ring, FDDI , or ATM.
In a SFPS network, the access port acts as a management agent that performs five functions for the end point system. First, it provides directory services. Second it provides network access security services. Third, it provides routing services. Fourth, it provides the ability to reserve bandwidth along a path in the switching fabric. Finally, it provides accounting services. These five services: directory, security, routing, bandwidth management and accounting are required to provide a reliable network infrastructure.
In traditional bridge and router devices, each packet is treated as an independent unit of data called a datagram which is individually processed by application of access and security constraints, as well as path determination. In SFPS, this processing is done only on probe packets (common on LAN broadcast mediums) which are decoded, and through the use of a directory of end systems containing policy, call attributes, location, paths, quality of service, etc., the connection is either rejected or accepted, in which case the path is determined and switches along the path are "programmed" to allow subsequent packets on this "connection" to be switched. In either case, subsequent datagrams are either switched or discarded without having to re-apply all of the security and access control and path determination logic.
Another important aspect of the present invention is a method of determining a path between two nodes (end systems) on the network which has the following properties: the path is optimal for one metric and passes a set of threshold tests for a number of other metrics; and, it must do so within a given time constraint. The method is a breadth first recursive search in parallel which is initiated at the source node and proceeds outwardly to discover neighboring nodes and calculate traversal paths until reaching the destination node. The method includes a series of "pruning steps" to insure that the number of potential paths does not grow towards infinity and to limit the memory requirements and processing time of the search. Because of these real-world constraints (time, memory, processing), the path result may not be the mathematical (theoretical) best path, in every case, but the search will pursue those paths having a high probability of being the best path considering the constraints and in that sense the search will make a best path determination. Generally, the metrics include cost, bandwidth, policy, loss, etc. While a specific embodiment of the method is useful in determining an optimal path through the network, the method has much broader applications.
In another aspect, the present invention provides a method and apparatus allowing multiple levels of arbitration among competing devices requesting access to a bandwidth-limited, shared resource.
The first level of arbitration is programmable. The available bandwidth of the bandwidth-limited, shared resource can be equally allocated between all competing devices or some of the competing devices can be allocated more bandwidth than others. This feature of the present invention is useful when the maximum aggregate bandwidth requirements of the requesting devices are greater than the bandwidth of the shared, bandwidth-limited resource. Because it is programmable, the arbitration system of the present invention can be used to allocate the available bandwidth to prioritize those competing devices that may more urgently need the bandwidth-limited, shared resource and other competing devices will only be allocated a fraction of the bandwidth that they actually need. However, these other competing devices will be allowed to use free time segments, thus effectively being able to use more bandwidth than they are programmed for in the first level of arbitration.
For those competing devices requiring isochronous service (including, but not limited to voice data and video data), only the first level of programmable arbitration is used. These devices are programmed not to participate in any other levels of arbitration except the first level. This allows these competing devices to use the time segments that are programmed for them, but not any of the time segments that may become available when a device does not require its programmed time segment. For example, an audio communications link requiring a very deterministic service policy would be programmed to use only the first level of arbitration and not any free time segments. The arbiter of the present invention is programmed with an adequate number of segments to support the bandwidth requirements of the audio communications link. These time segments are made available to the audio communications link in a periodic way that matches the bandwidth requirements of the device.
Additional levels of arbitration are provided to allocate unused time segments that may be available after the first level of arbitration to competing devices if the competing devices are programmed to participate in the additional levels of arbitration. The second and third levels of arbitrations allow unused time segments that may be available after the first level of arbitration to be assigned to other competing devices. The second level of arbitration provides a Round-Robin type of arbitration scheme that is used to allocate a free time segment to the competing device having the allocation token. If the competing device having the allocation token is not requesting use of the bandwidth-limited, shared resource, then a third level of arbitration is provided. In the third level of arbitration, each of the competing devices participating in the third level is assigned an identification number and placed in a list and the remaining free time segment is allocated to the competing device having a predetermined rank in the list. For example, the predetermined rank may be based on the sequential order of the identification numbers. The unallocated time segment might be allocated to the requesting competing device having a particular identification number, such as the lowest or highest identification number.
A key feature of the present invention is that arbitration is performed using a hierarchy of programmable arbitration schemes. The first level of arbitration is, for example, a programmable time division multiplexing arbiter. The second level of arbitration, which acts only to allocate any unused time segments after the first level of arbitration is, for example, a Round-Robin type arbiter. The third level of arbitration, which acts to allocate any time segment that remains unallocated after the second level of arbitration is a default level of arbitration that selects one of the requesting competing devices according to a predetermined scheme.
Another advantage of the arbitration system of the present invention is that arbitration is performed in parallel with data transfer cycles. That is, the competing device that is to be given exclusive use of the bandwidth-limited, shared resource is decided in the time segment prior to the time segment in which a data transfer is to occur. The arbitration decision is made at the same time that a data transfer is occurring in a time segment. This pipelining of decision making effectively makes the arbitration cycles look transparent to the competing devices and does not consume any portion of the available data transfer time.
The arbitration system of the present invention can support devices having different bandwidth requirements (i.e., different data transfer rates) in the same system because the system is programmable. In one embodiment of the invention, the granularity (that is, the amount of bandwidth represented by a time segment) of the time segments is programmed using an allocation memory. As the number of time segments in the allocation memory is increased, the granularity of bandwidth allocation becomes finer. Therefore, the arbitration system can meet the bandwidth requirements for competing devices that have differing bandwidth requirements. For example, a competing device having a low bandwidth can be assigned only a single time segment, since the low bandwidth device requires less frequent servicing. On the other hand, a competing device having a higher bandwidth could be assigned multiple contiguous time segments, thus allowing that device to complete a data transfer.
Another feature of the present invention, since it is a programmable arbitration system, is that the type of arbitration for each device may be programmed on a device by device basis. For example, a device may be programmed to participate only in the first level of arbitration and not in the second or third levels. In the same way, a device could be programmed to participate only in the second and/or third levels of arbitration. This makes the system more flexible depending upon the particular application and helps to guarantee quality of service for each competing device.
Many aspects of the previously defined inventions may be constructed as: software objects which exist in embedded devices as firmware; software objects which are part of an application on a commercial computer system; or Application Specific Integrated Circuit (ASIC) or functionally equivalent hardware components.
These and other functions and benefits of the present invention will be more fully described in the following detailed description.
Brief Description of the Drawings
Fig. 1 is a schematic illustration of a network topology built with SFPS switches; Fig. 2 is a schematic illustration of the internal components of an SFPS switch in a hardware embodiment;
Fig. 3 is a flowchart of the operation of the SFPS switch of Fig. 2;
Fig. 4 is a perspective view of a networking chassis with removable modules;
Fig. 5 is a schematic diagram of a networking module with a SFPS switch;
Fig. 6 is a schematic illustration of the networking chassis and the services it provides;
Fig. 7A is a schematic illustration of an SFPS switch;
Fig. 7B is a logical view of an SFPS switch;
Fig. 7C is a flowchart showing processing of a data packet by an SFPS switch;
Fig. 8 is a schematic illustration of a distributed SFPS switch;
Fig. 9 is a schematic illustration of a chassis and distributed switch and illustrates the formation of a distributed directory of port objects for the distributed switch;
Fig. 10 is a schematic illustration of the distributed switch on the physical and logical layers;
Fig. 11 is a flowchart illustrating a best path determination;
Fig. 12 is a schematic illustration of certain linked data structures used in the method of Fig. 11;
Fig. 13 is a sample network topology illustrating a traversal from a source node to destination node;
Fig. 14 illustrates a networking chassis with an exemplary application of the bandwidth arbiter of the present invention;
Fig. 15 is a schematic diagram of one embodiment of the arbiter used in the networking chassis of Fig. 14;
Fig. 16 illustrates a first programmed state machine that may be executed by the circuit of Fig. 14; Fig. 17 illustrates a second programmed state machine that may be executed by the circuit of Fig. 14;
Fig. 18 is a flow chart illustrating how arbitration and allocation of time segments take place simultaneously to improve system efficiency in the present invention;
Fig. 19 is a flow chart illustrating the arbitration method of the present invention;
Fig. 20 is an illustration of the TDM RAM programming illustrating the arbitration method applied to an SFPS switch;
Fig. 21 is an illustration of an SFPS software embodiment; and
Fig. 22 is an illustration of a port object for the switch of Fig. 21.
Detailed Description
The detailed description is separated into the following subsections for ease of reference:
1. Establishing "Virtual LANs" and "Virtual Connections"
1.1 Example 1 - Mil transmits a packet destined for M99
1.2 Example 2 - Mil transmits a packet destined for M66
2. SFPS Management Services
2.1 Route Services Management
2.2 Access Security Management
2.3 Directory Services Management
2.4 Accounting Management
2.5 Bandwidth Management
3. SFPS Hardware Implementation
4. Canonical Frame Representation
5. Networking Chassis With SFPS Modules 6. SFPS Functions
7. SFPS Host Agent
8. SPFS Distributed Switch
8.1 Example of IP Packet Flow Through Distributed Switch
8.2 Distributed Switch MIB
9. Best Path Determination
9.1 Example of Best Path Determination
9.2 Data Structures
9.3 Flow Chart
10. Allocation of Bandwidth
10.1 Discussion of the Related Art
10.2 New Apparatus and Method for Allocating Bandwidth
10.3 Example of Bandwidth Allocation For SFPS Module
11. SFPS Software Object Model
11.1 SFPS Objects
11.2 SFPS Application Threads
11.3 MIB and its Managed Object Definition
12. Related Applications
1. Establishing "Virtual LANs" and "Virtual Connections"
Fig. 1 shows a representative network topology built with six secure fast packet switches (SFPS) labeled SI to S6 connected by links L. Each SFPS switch has for example, four ports. Some ports are labeled A for Access and some are labeled N for Network. Access ports provide network access security and packet routing services. Network ports do not perform security services since this function has already been performed at the original entry access port. The end systems are connected to the switches by links L and are labeled "M "; one of the end systems M10, comprises a network management server (NMS). This NMS will also contain the SFPS directory and path server.
Each SFPS includes a function known as a Connection Database Look-Up Engine (CDLUE) . The CDLUE's job is to check the source and destination MAC IDs of a packet received by the SFPS against its internal database, called the connection table. The CDLUE will forward (route) packets out one or more ports based on the results of the connection table look-up. This function is similar to a bridge except that SFPS uses both the source and the destination MAC IDs to make the forwarding decision. Bridges only use the MAC destination address. Also, if a bridge isn't sure where a destination is, it will forward the packet out all ports except the one it came in on. This "flooding" results in loss of control over network access, bandwidth, information security, network performance and reliability. Because SFPS uses both the source and destination addresses it does not have the failings of current bridges and routers.
The network topology view of Fig. l will be used to illustrate how "virtual LANs" and "virtual connections" can be built to enable protocol insensitive routing and increased network security to be achieved. In this case, there are two logical work group LANs: WG1 = (Mil, M22, M99), and WG2 = (M33, M55, M77) . Two connections will be attempted: (Mil, M99) and (Mil, M66) .
1.1 Example 1 - Mil transmits a packet destined for M99.
1. Access switch SI receives this packet on inbound port Al.
2. SI looks up in its connection table to determine if a valid connection (Mil to M99) exists.
3. No connection is yet defined so Si initiates a message exchange to the SFPS Server (Network Management Station) M10. This message exchange is an independent exchange between the switch SI and the server M10. a) The switch sends a message asking if Mil can (is allowed) to talk to M99.
This is where security, policy and administrative constraints are applied. b) If the two stations are allowed to have a connection, then the server M10 will determine the path of switches to be used to provide a logical connection between Mil and M99. c) Since Mil can reach M99 by two different paths, one "best" path is selected. "Best" is constrained by, for example, cost, bandwidth, policy, loss, and other metrics. d) Let's assume the best path is chosen as traversing SI to S3 to S5. e) The server M10 will then "program" each of these switches to support this connection path.
•••Important point: Since SFPS has to be transparent in the M11-M99 interaction, it cannot modify the packets being exchanged. Typically, in traditional switches, the switch sets a connection-identifier that gets put in each packet, and is remapped at each switch, to allow the packet to be switched along the path. Since SFPS cannot touch any packet content, it has to have something in the existing packet that it can use in each switch to treat as a unique connection-identifier while preserving the Mil to M99 packet exchange. What is unique about SFPS is that it treats:
- source MAC address
- destination MAC address as a unique "connection-identifier." Note, that this is an implicit connection-identifier in each packet based on the arriving inbound port, but is an explicit connection-identifier in each switch's connection table.
f) Each of the switch's connection tables will look like this:
Figure imgf000018_0001
g) So, once all these switches are programmed
(through, for example, SNMP Network Management Protocol), a packet from Mil destined for M99 would look like this:
M99 Mil Packet Data
and would be "switched" along the path as follows :
Mil →* A1-S1-N2 ->• N1-S3-N3 →- N2-S5-A2 →* M99
h) Note that once the switches have these connections defined, the packets traverse Mil to M99 without any additional call-setup or network management interaction. This provides the fast packet switching between the end systems . Note, the Mil to M99 packet exchange occurs as if they were directly connected on the same LAN segment. Thus, the "virtual LAN" is provided, as well as transparent switching. i) At each switch, the switch looks up in the packet the source and destination MAC addresses and combines them with the inbound (source) port to form the connection identifier. If this connection is in its table, the packet will be forwarded (switched) out the designated output port. All subsequent Mil to M99 packets will take the same path through the switches. Note if a valid source-destination MAC pair arrives on a port other than the defined inport, it will be considered a security violation. j) These "virtual connections" exist until they are explicitly removed by the network management system. This could be due to timeout (idle connection) or resource management. No explicit disconnect is done by Mil or M99.
1.2 Example 2 - Mil transmits a packet destined for M66.
1. If Mil also transmits data destined for M66, the same set of processing would be done:
a) Si receives the packet. b) SI looks up in its connection table and with no match will send a message to server M10. c) Server M10 will reject the packet as unauthorized (not within one of the two approved logical work group or "virtual" LANS) and the packet will be dropped without a connection being made. An alarm may be set to indicate that an unauthorized transmission has been attempted.
2. SFPS Management Services
In this particular embodiment, the SFPS switches require five management service functions to be performed at a higher layer in the network management framework. The five functions are: Route Service, Access Security, Directory Service, Accounting, and Bandwidth Management. A general review of each management function is provided below. The functions are usually performed in software and may reside on none, some, or all SFPS in a network. Since some of the management functions are required by multiple-user applications, they may be shared and would be already available.
2.1 Route Services Management: These services are required so the SPFS can determine the best path to route a connection. When there are many possible "paths" to a destination, the route management will determine which one should be used and pass this information to the SFPSs so that their connection databases can be configured correctly. A preferred method of making a best path determination is described in a later section.
2.2 Access Security Management: These services are optional and can be used to limit user access to only a specified group of SFPS access ports. An access group may contain from 2 to any number of users. Users can only send or receive packets from members of their access group. Access to any other access ports would be prevented by filtering out those packets. Security also includes administrative policies.
2.3 Directory Services Management: These services provide the Route Services Management with a user to access port and switch database so that packets destined for users not directly connected to the local access switch can be located and then have a path to that switch selected. This, service reduces the amount of time it takes for a connection to be established. An ISO X.500 Directory Services may be used which is compatible with NIS, Novell 4.0 and others.
2.4 Accounting Management: These services provide an accounting of each user ' s use of the network and provide the network manager with usage and cost reporting so that proper use of corporate network resources can be verified and traced. 2.5 Bandwidth Management: As network usage grows, congestion of the network connection will likely occur. The bandwidth management service insures that bandwidth is allocated to highest priority users first and that the network is always available for those users should congestion occur. Lower priority users would have their packets dropped when congestion occurred. A specific multi¬ level programmable arbiter for making bandwidth allocations is described in a later section.
3. SFPS Hardware Implementation
In a specific hardware embodiment, the SFPS is a multiported data communications device shown in Fig. 2 (physical layer — external ports not shown) . Fig. 3 is a flow chart showing the frame processing of the SFPS switch.
Data enters the SFPS 10 through one of its ports in a format known as the Canonical Frame Format, which is described in a later section. The canonical frame format has the following structure:
Table 1: Canonical Frame Format
Destination Source LLC Information Check
Header Address Address Field Field Sum
(64 bits) (64 bits) (64 bits) (64 bits) (0 or more bytes) (16 bits)
As shown in Fig. 2, the SFPS 10 has a common 64 bit wide packet data bus 11 that is shared by all ports, as well as by a memory array referred to as "packet ram" 12. When data arrives at a given port (step 20 in Fig. 3), the port signals to a multilevel programmable arbiter (MPA) 13 that it is ready to transfer data into the SFPS system (step 21). The MPA is used to allow each port a "timeslice" on the bus 11 so that data may be transferred into the SFPS and stored into packet ram.
The SFPS system requires ports that deliver data in to deliver an entire packet before beginning the next packet. The packet data bus control system in conjunction with the MPA establishes a 10 elk (clock) cycle "timeslice" for data transfers (32 bytes of information). Transfers can be in either direction. Inbound transfers are referenced as a port delivering data into the packet ram, and outbound transfers are those in which data is sourced from the packet ram and sent out through a port towards the datalink. A transfer of the data packet in or out of the SFPS may take multiple timeslices.
When a port receives an acknowledgment from the MPA, it signals "start of frame" (SOF) on the control bus 19. This informs the lookup process that the beginning of a data packet will be traversing the bus 11 and that it should copy the DA and SA fields so that it may proceed with a lookup operation (step 23). Now, in parallel, the lookup process will be forming the results word (steps 24, 26) while the port continues to transfer the entire packet into the packet ram 12 (step 22), controlled by the DMA process. Once the end of the data packet is delivered, the port signals "end of frame" EOF which tells the DMA 16 that it is done. This causes the DMA, who has been maintaining a byte count for the packet, to transfer this information to the forwarding process along with a pointer to the location of the data packet in packet ram. Additionally, the input port number is sent to the forwarding process (from the DMA). The forwarding process then proceeds.
The common bus 11 also indicates which port is transferring the data into the packet ram 12; this information is used by the lookup circuitry 14 so that it may associate the DA-SA data with a certain inbound port (step 24). The lookup circuitry 14 is where the connection database table is maintained. This table is what is established by the SFPS connection setup application. It indicates for a particular DA-SA pair on which port(s) the data shall be sent outbound (step 25). The table also provides a field which identifies the allowable in-port for this DA-SA connection. The lookup circuitry will match the actual inbound port with the allowable in-port to ensure that the data has entered this switch from a pre-authorized location (step 24).
The lookup process passes an information structure to the forwarding logic, which the forwarding logic acts on. The information structure, known as the "results" word, contains the following:
1) In_port — the allowable in_port, used by the lookup process.
2) Out_port/Index — this will be a single port number, or an index into a ram which contains a port_mask to be used when the packet is intended to be delivered out more than one port. This ram is located within the forwarding logic.
3) The actual in_port — to be used for statistics collection, since the lookup process has performed the in_port match against the allowable in_port field.
4) In_port violation — a single bit indicating that the in_port check passed/ failed; this is used by the forwarding logic.
5) Unknown connection — a bit indicating that the connection entry was not found in the connection database. This packet will be delivered to the host for directory assistance.
The forwarding logic acts on this data to produce a "outmask." This is a mask that is as wide as the number of ports in the system. This mask, for each bit set, indicates the desire to forward this data packet out the specified ports. The forwarding logic 14 waits on two pieces of information to complete its task, which is to write the outmask to the transmit queue logic 15. One piece of information is the results word for a given port (from the lookup logic — step 24); the second is a data structure that is written by the DMA control logic 16 (a pointer to where data resides in packet RAM — step 22).
The forwarding process upon receiving this structure from the DMA checks with the lookup process for the completion of the table search and result word formation for that port. If lookup search and frame reception are both complete, the forwarding process 14 then translates the out port information into a mask which it writes to the transmit queues 15.
There exists at least one transmit queue per port (see Q,, ..., Q in transit queue 15 of Fig. 2). Each queue is connected to a network interface block 18 (NIB.. , ..., NIB , respectively). If an entry exists on a queue, the port that the queue is associated with is signalled so that the port may request that information. A queue entry is merely a pointer to a data packet which resides in packet ram. This pointer is what the forwarding process writes onto the queue in what is called a forwarding operation. The port then signals to the MPA 13 that it wishes to perform an outbound data transfer. Once granted, the DMA controller 16 will source the appropriate data from the packet ram 12 onto the packet data bus 11 (step 27). There is a link 17 between the DMA control process and the queue process. When transmitting, the DMA reads the pointer entry off the appropriate queue based on the port number that is requesting the transmit operation. All along, the DMA process has been maintaining in its internal memory the length of each packet in the packet ram. When the pointer is read from the queue and the transmit operation begins, the DMA process decrements a working count value which is first loaded with the full packet length. As transmission proceeds and this counter reaches zero, the DMA process signals "end of frame" (EOF) and the port stops requesting data transfers (unless there is another entry on its transmit queues).
4. Canonical Frame Representation
Different data links (LAN segments) specify and use dissimilar formats to encapsulate and represent data. In order to provide an extensible system, it is advantageous for each data link sub-system to translate incoming frames, and represent them canonically. Intermediate systems, such as the networking chassis backplane, then need only understand this canonical representation in order to operate on the received frames.
To this end, it is expected that data link sub-systems will translate incoming frames from native to the canonical format, and perform the converse operation for frames to be transmitted. In the later-described embodiment entitled "Networking Chassis With SFPS Modules", a networking chassis having a common bus receives removable modules; if all external interfaces on a particular module are similar, the module may choose to translate (from native to canonical) before transmission out onto the common chassis bus. The point of translation within any module is a realization issue.
The encapsulation method utilized herein is 802.2 LLC, more specifically 802.2 SubNetwork Access Protocol (SNAP) SAP. It provides mechanisms to encapsulate DIXE frames, with no loss of information content. Using this mechanism, and accounting for various datalink address formats, the canonical representation is as follows: Table 1: Canonical Frame Format
Destination Source LLC Information Check
Header Address Address Field Field sum
(64 bits) (64 bits) (64 bits) (64 bitε) (0 or more bytes) (16 bits)
The "header" is a packet description provided for use by the SFPS switch. The "destination address" is the physical MAC address of the destination end system. The "source address" is the physical MAC address of the source end system. The LLC field is the IEEE 802.2 LLC header. The "information field" is the client layer data. The "check sum" is a 16 bit field for confirming packet integrity.
5. Networking Chassis With SFPS Modules
Fig. 4 is an illustration of a networking chassis adapted to incorporate the SFPS technology. As shown, the chassis 30 is a mechanical enclosure 31 which is used to house a plurality of networking modules 32, which may include repeater modules, bridge modules, router modules, terminal servers, file servers, etc. The chassis provides slots into which the networking modules are inserted. In addition to being a mechanical enclosure, the chassis provides a backplane 33 through which the modules inserted into the chassis are provided power from the chassis' power supply 34 and networking connectivity between modules. The backplane includes a system management bus (SMB) for network management functions, and a high-speed data bus known as the INB.
The chassis or hub enables the connection of diverse LAN segments, including Ethernet, Token Ring and FDDI segments, as well as to wide area networks (WANs). In addition, the chassis provides connection to an asynchronous transfer mode (ATM) switch across its backplane.
Each module 32 is microprocessor based, e.g., i960 sold by Intel Corporation. Fig. 5 illustrates a module embodying an SPFS switch 40 which is linked to the module's host processor 41 by a pair of port interface links 42 for transfer of data, and a pair of status/control links 43 for transfer of status and control signals. The control and status interface is viewed by the host CPU as a set of registers that control the configuration and switching policies of the SFPS, as well as allowing the host CPU access to diagnostic information and switching statistics.
The SPFS 40 provides packet switching services between network data interfaces 44, 47, and 50 according to the criteria set by the host CPU 41.
The network data interface consists of a data path and several handshaking signals. By way of example, Fig. 5 shows an Ethernet interface 44 with handshake and data links 45-46, FDDI interface 47 with handshake and data links 48-49, and a backplane interface 50 (to the networking chassis backplane 33) with handshake and data links 51-52. The network data interfaces 44, 47 can be configured to handle, for example, up to 16 separate network ports, or one high speed port. The amount of bandwidth granted each network data interface is determined by the implementation of the SPFS; a specific example of programming the MPA arbiter on the SFPS is described in a later section. The SPFS handshaking signals allow the network interface block (NIB) to request use of the SPFS, as well as synchronize the transfer of data. The NIB provides translation of the original frame format to the canonical format as well as protecting the data with checksum coverage.
Fig. 6 is a schematic illustration of the various functions provided by the networking chassis or hub 30. The chassis is schematically shown in segments consisting of: . CPU; ATM; Ethernet; Token Ring; FDDI; Router; Switching. The chassis architecture may be implemented in C++ OOP (object oriented programming) software. The backplane connects various LAN and WAN interfaces. An integrated management network service is provided, based on RISC base CPUs (UNIX) . The physical media is UTP and STP sockets, and optical fiber. The functionality includes: connectivity; bridging; routing; secure fast packet switching; and ATM cell switching.
As previously discussed, one or more of networking modules 32 in chassis 30 may be an ATM cell switching module. Such a module would need to perform packet to ATM cell conversion (and vice versa) for transmissions between the module and the chassis backplane. Within the ATM module, ATM cell switches function much like a router in that each switch receives cells from each port and then forwards them out the correct port (Unicast) or ports (Multicast). As the cell is forwarded to a switch, its header is modified with "next switch" routing information. This process continues at each cell switch until the cell is received at the end node. End nodes then strip away the cells and deliver the data to the end user or router application. Cell switches include a management agent (CPU) that is used to set up the logical connection through the switch as well as monitor the operation and performance of the switch and its ports or links. All cell switches are built around the core switch fabric which determines its maximum performance or switching capacity. Usually, this is expressed in Giga-bits-per-second (Gbps). ATM switching capacity in the one to two Gbps range are now becoming available, and switching capacities in the 20-40 Gbps range are expected within the next few years.
The above networking chassis is designed to distribute the network management services across the various networking modules, to provide increased throughput (prevent bottlenecks) and fault tolerance (i.e., there is no one networking module which if defective, shuts down the system) . A system and method for implementing this distributed management is more fully described in a copending and commonly owned application (U.S. Serial No. 08/187,856) filed on the same date (January 28, 1994) entitled "Distributed Chassis Agent For Network Management," filed by Brendan Fee et al., which is hereby incorporated by reference in its entirety.
6. SFPS Functions
The "secure" feature of the SFPS means that no traffic is allowed through the switch until "programmed" by the SCS (switch agent). All end-to-end system connections passing through the switch must be validated, i.e., by way of access list, virtual LAN, policy, etc. The switches register with the SCS before becoming operational. The switches "discover" and report end systems on each port of the switch to the SCS. This allows the SCS to learn the SFPS topology without the SFPS switches having to run a distributed topology exchange protocol.
The "fast" feature of the SFPS may be accomplished on hard cards, wherein packet switching is done completely in hardware ASICS. The network interface block (NIB) handles the media interface. All NIBs translate data into a common internal frame format, i.e., the canonical format. The lookup engine extracts the key fields from the frame (i.e., MAC source and destination addresses) as the first burst of data is transferred from the NIB to packet ram. The extracted data is then "looked up" in the connection table. The lookup engine provides the search function, as well as dynamic learning and aging of table entries. The search result is a code either programmed by the host CPU or learned by hardware that indicates where the frame should be forwarded based on the key fields. When the result operation is complete, the results are delivered to the forwarding engine.
Alternatively, the "fast" feature can be provided by soft cards, wherein packet switching logic is minimized. There are no hierarchical lookups or header decoding beyond the MAC address header. There is no variable length packet headers or addresses. There is no protocol type processing.
The "packet" feature of SFPS means that the switch supports existing LAN packet formats, e.g., Ethernet, Token Ring and FDDI. No segmentation or reassembly of packets is required.
The "switching" feature in SFPS means that the switch treats data flows as connections. The source port, source MAC and destination MAC become a unique tuplet which serves as a connection identifier. The switch always forwards (switches) the packet out the correct output port; there is no flooding out all ports. The switch uses an arbiter to share switch bandwidth and ports. When the network management service provides for distributed management of all modules in the networking chassis, it is possible to guarantee performance to designated users and provide varying levels of quality of service.
7. The SFPS Host Agent
The operation of the SFPS host agent is best illustrated in Figs. 7A-7C.
Fig. 7A is a schematic illustration of a SFPS switch 91 having a plurality of ports 92. A host port 93 connects the switch to its host CPU 90, which may be an i960 microprocessor sold by Intel Corporation. The host CPU is connected to the system management bus (SMB) for receipt and transmission of discovery and other control messages between modules in the networking chassis.
Fig. 7B-7C illustrate the internal operation of the switch. The SFPS switch 86 includes in ports 80, out ports 81, connection database 82, look-up engine 83, and a multilevel programmable arbiter MPA 84. All of these components have been previously discussed with regard to the switch shown in Fig. 2. The switch 86 sends and receives messages from the host agent 85, which includes a management agent 87, a discovery agent 88, and a call processing agent 89. The interaction of the host agent, switch, SCS and end system will be described in the following paragraphs, and is illustrated in the flow chart of Fig. 7C.
The management agent 87 provides external control of the configuration and operation of the SFPS switch, through the network management system.
The discovery agent 88 provides a mapping of end systems to switching ports through a passive listening (snooping) capability and a registering of end system addresses and port locations of the host switch with an external directory located in the SCS. Adjacent switches are also discovered and mapped, but this may be done with an explicit switch-to-switch protocol (nonpassive) .
The call processor 89 provides a means for requesting connections to be established between two end systems. In the case where the source-destination MAC addresses are not in the packet frame, i.e., usually in a frame that has a broadcast — all hosts — MAC address, the call processor will decode the packet to find source or destination network addresses and will use these to map back into the mapped addresses from the external directory located in the SCS. Once the end system MACs addresses are known, the call processor will then request the connection between the end systems. If the broadcast frame was a probe or address resolution packet (i.e., an implied connect request), the call processor will return a probe reply as a "proxy" which gives the destination end system MAC addresses. Subsequently, the source end system can then send packets directly to the destination based on its MAC address.
Fig. 7C is a flow chart illustrating what happens from the time a data packet is received on an input port of the switch, until it is sent on the correct output port.
Referring to Fig. 7C, in step 300 the host is initialized. In step 301, the host programs the connection database to send any "unknown" or "broadcast" connections to the host port. In the next step 302, the switch waits for a packet to arrive. In the next step 303, a packet has arrived. In step 304, the switch extracts the source MAC address, destination MAC address, and identifies the inbound port on which the packet was received. In step 305, the look-up engine checks to see whether this source-destination pair is already located in the connection database. If it is not found in step 308, the packet is given to the host agent. The call processor and the host agent determine whether it is a broadcast destination (step 309). If the answer is yes, the call processor decodes the packet to find the network protocol source and destination addresses (steps 310-311). A different protocol decode logic would be provided for each network protocol. For example, in the IP protocol, if an ARP request is received, the call processor would get the target IP address (step 312). It would then ask the external directory (SCS) for the MAC address of the target IP (step 313). In the next step 314, the SCS sends the MAC destination address back to the call processor. In step 315, the call processor asks the SCS to set up a connection between the source MAC and destination MAC. In step 316, the call processor forms an ARP reply packet by putting the destination MAC address inside the packet. In step 317, the call processor sends a reply to the source address. It should be noted that this reply allows the source end system to update its private mapping of the destination IP address to a nonbroadcast MAC address. All subsequent packets to this destination IP address will be properly framed with the source and destination MAC address for which connections will now exist.
If the answer in step 309 is no, then the call processor treats it as an unknown connection (step 318), asks the SCS to set up the call (step 319) and discards the packet (step 320) .
Returning to step 305, if the source and destination MAC pair are found in the connection database, the data packet is sent to the switch outport(s) defined in the database (step 306). In next step 307, the management agent collects statistics regarding transmissions through the switch and sends them to the SCS.
8. SPFS Distributed Switch
Similar to the manner in which management services may be distributed across the modules in the networking chassis, the SFPS functions can be "distributed" across the networking chassis.
Fig. 8 is a schematic illustration of a distributed SFPS switch. A network 70 is shown schematically as a "cloud" to which there is connected by data path 71 a representative end point system 72. Data paths 73, 74, 75 connect the network 70 to an SFPS switch engine 76, call processor 77, and SCS (switch agent) 78. This is just one of many ways in which the functions of the switch may be distributed; there are many other ways. For example, the call processor may be part of a stand-alone server, part of the SCS, part of the SFPS switch, or part of the end point system. Similarly, the SCS may be physically a part of some other network component. The following is a more detailed description of the operations of the distributed switch according to the present embodiment.
8.1 Example of IP Packet Flow Through Distributed Switch
The following example illustrates IP packet flow through the distributed switch. In this example, end system A wishes to communicate with end system B according to address resolution protocol ARP. ARP is a protocol for mapping 32-bit IP addresses to 48-bit data link layer addresses, as specified in RFC 826. The SFPS switch 76 receives the broadcast and treats it as an unknown connection. It forwards the broadcast out the broadcast redirect port (programmed by SCS 78) to the call processor 77 - see bold connecting arrow 94 in Fig. 8. The call processor 77 processes the ARP request REQ packet and performs SFPS protocol to UNI (User to Network Interface) translation. It looks inside the ARP for the destination IP address. It puts the ARP request on a holding queue. It makes a directory assistance call to the SCS 78, asking for the MAC address for the destination IP address; it may provide the SCS with the switch address and source MAC address as well. Once the destination MAC address is known, the call processor 77 then tries to establish a connection from the source to the destination. It makes a CALL-REQUEST (see bold arrow 95) on behalf of the end system, but does not set up the connection from itself.
The SCS 78 then processes the call request from call processor 77. The SCS validates the call according to, i.e., policy, access control, virtual LANs, quality of service, etc. SCS 78 determines the path to connect the source and destination and then "programs" each switch in the path with a valid connection. A connection is a combination of source port, source MAC, and destination MAC mapped to an outbound port. The SCS 78 uses SNMP and switch MIBs 96 to do this; there is no signalling per se. SCS 78 returns CALL-ACCEPTED to the call processor 77.
The call processor 77 removes the ARP request from the queue and fills in the destination MAC address and sends an ARP response to the source end system. The source end system now has an updated ARP cache and can send packets directly to the destination end system. These packets get switched through each switch along the path as programmed by the SCS.
8.2 Distributed Switch MIB
In the following explanation of the distributed switch MIB, Fig. 9 illustrates generally modules 100A-C, each having a switch engine 101A-C, input ports 102A-C, and outpuτ ports 103A-C, and each connected by backplane 33 of networking chassis 30. A "Distributed Directory for Port Objects" 104 is shown above which includes an object name 105 and object location 106 for each output port 103.
It is important to understand how the switch MIB becomes distributed across the networking chassis. Essentially, the MIB objects are self-distributing by design in that there are no "flat" managed objects that would need to be replicated across modules. Instead, each managed object of the switching engine is indexed by at least a module chassis/slot number and in the case of ports, by a key of chassis/slot/ port. The key 106 is somewhat hidden by calling this a Portldentifier 105 which can be specified in decimal dot notation. In conjunction with a MIB tree registration agent that distributes the name and location (think of it as a replicated directory of file names, but not the data) across each module, the MIB tree will automatically form a unique naming tree by redefining the name of an object to be its OID (Object Identifier) and its location information. This MIB tree replication is done totally transparent to the individual managed objects on each module or switch engine. What results is a replicated tree of the name and location of all switch objects and their unique instances.
In stand-alone switching systems the MIB object registration and naming will be done the same as in the distributed- system except that MIB tree will not be replicated since the system itself is not a distributed system. However, the port objects will still use a complex portldentifier to instance themselves.
8.2.1 The Switch MIB: Despite the fact that the Switch MIB provides a distributed view of the MIB, it does not provide a single logical view of the switching system across all of the chassis modules. This may not be apparent at first, but the Switch MIB provides for a distributed collection of switch engines that can be accessed from a single MIB view (see Fig. 10 showing SCS 78 connected to three separate switch engines on the left as the "physical switching system" 110, and connected on the right to a single "logical switching system" 111). The implications are that the SCS control agent must be able to manage and program each of the individual switch engines. For example, to obtain a connection path that had its ingress port on one module and its egress port on a different module, the SCS controller would have to program the ingress module with a separate connection going over the chassis backplane to the module with the egress port on it; the egress module would then have a connection going from the chassis backplane port to the egress port. However, this programming of each of the switches can be done through a single switch MIB and agent access point (the chassis IP/MAC address).
8.2.2 The External View: In order to provide a logical switch view, the SCS controller or management module must do this by "hiding" the internals of the individual switch engines in the chassis. The external view really reflects the abstraction of the switching engine. Basically a switch engine contains inbound ports, outbound ports, and a connection table (see Fig. 7B) . Note that ports are viewed as uni-directional such that a two-way connection is explicitly defined as two separate uni-directional flows — one flow from source to destination and another as destination to source.
The external view does not provide any concept of aggregation since the external view may describe a logical switching system abstraction and not necessarily a real device.
8.2.3 The Internal View: At the individual "real" switching system, an internal view has to be provided which is different than the generalized external view. What this means is that when a real physical system (device or element) is being managed, then the MIB view can provide aggregates and other information that is not generalized for switched systems. An example is that an individual switch engine can provide aggregate counters for switched packets and for errors inside the physical switch device. It is expected that the internal view as it is called here is used when zooming in to control a very specific device or switching element.
9. Best Path Determination
One of the principal functions of the management or SCS switch agent 78 (see Fig. 8) is to determine a "best" path through the switches for a given set of metrics (see for example Fig. 1 and the accompanying text). This is important to insuring "fast" transmissions, avoiding bottlenecks (excessive traffic on the backplane), and guaranteeing quality of service (QOS). Set forth below is one preferred method for determining the best path.
The search method can be described as a concurrent breadth first path search through a mesh of nodes and arcs — see for example the network topology or mesh of Fig. 1 wherein the switch S and end point systems M would be nodes, and the links L between nodes would be arcs.
The problem to be solved is to find a path between any two points in the mesh which has the following properties. The path is optimal for one metric and passes a set of threshold tests for n other metrics. Mathematically the desired path Q _._L of all the paths QO, .... , QZ_ is the one whose value v is the best and whose values a, .... , n all pass threshold tests A, .... , N. Secondarily, it must do this within a minimum time constraint T.
The method assumes an initial set of values and accumulates additional values following the traversal of all nodes and arcs along a path until the path arrives at the destination or goal node. The method was developed to satisfy the requirements of ATM route determination. ATM (asynchronous transfer mode) is a new CCITT networking technology. The problem is simply to find an optimal path through a mesh which satisfies a number of independent constraints. The solution would be applicable in general to: any routing problem in a mesh network such as a communication network and/or in electrical and electronic circuit design; a distribution of power; a distribution via pipelines; traffic routing over streets and highways; etc.
The method, which is illustrated in the flow chart, data structures and example of Figs. 11-13, will first be described generally.
As paths are expanded during a discovery process, (n + 1) metrics are altered in a monotonically increasing or decreasing function. This is what makes the metrics useful. Since some metrics increase or remain the same for each traversal and some decrease or remain the same, it is confusing to describe them in terms such as larger, smaller, etc. Therefore, we will use the terms best, better, worse, and worst. For example, a cost metric can be best when it is 0 and worst when it is some maximum positive value. Probability, on the other hand, is best when it is 1 and worst when it is 0. A metric which is measured in absolute value (i.e.. Impulse fct) would be best at 0 or infinity depending upon your viewpoint (i.e., is the impulse desirable or undesirable) . At initiation there is a vector of metrics which is applied at the source node. At each traversal of a node or arc this vector of values is modified and produces a traversal value which accumulates from a best state to a worst state.
The method is a breadth first recursive search in parallel. It is initiated at a source node with an initial set of values and proceeds until there are no further paths to explore. It starts with a list of all the neighbors (neighboring nodes) of the source node. It then processes that list producing another list of all the neighbors of neighbors, etc. It uses several methods of "pruning" to keep the number of potential paths explored from growing towards infinity. A significant feature of this method is the pruning steps. As each node is discovered, a traversal value vector is recorded for that node. Each time the destination node is discovered, the traversal value vector is recorded.
When a path discovers a node already within the path, it terminates itself. This prevents cycles and prevents infinite loops. If a path discovers that its traversal value vector is not best in any of the (n + 1) metrics, it terminates itself. When a path traversal value vector has no metric which is better than one of the already completed paths, it terminates itself. Any path which would traverse a disabled arc or node, terminates itself. Any paths whose traversal value vector fails the filters (threshold value) in any metric, terminates itself. Any path which encounters an end node (i.e., a node which does not forward traffic, but may be a source or sink for traffic) which is not the destination node, terminates itself.
For each successive traversal list, all the paths going to a single node are grouped together before processing. Any of these paths which is not better than the others in at least one metric is terminated.
With the above pruning steps, only paths which can potentially produce a best result in some metric are allowed to proceed towards the destination. If a filter should knock out a promising path, the less promising paths will not be blocked as they are in Djikstra (i.e., Djikstra's short path algorithm with filtering) . If any path can successfully pass the filters, it will get through since all paths which are best at something are allowed to continue.
Once there are no more paths to process, all the successful paths are scanned selecting the path which best fits the desired result for presentation as the final answer.
The above steps comprise the most agressive pruning; a subset of these steps may be used for less aggressive pruning. 9.1 Example of Best Path Determination
This specific method was developed for wide area networks (WAN) which have a large number of diverse and redundant paths. It is a breadth-first search, which means it proceeds in rings moving outwardly from the source node (see rings 234A, 234B, 234C, etc. in Fig. 13 moving outwardly from source node 1), in order to build a spanning tree. Based on the time-constraint and metrics chosen, the farther one goes across the mesh, i.e., the farther away from source node 1, the higher the probability that one will reach a worst case (i.e., a filter threshold). The metrics progress monotonically toward a worst case. The algorithm is designed to proceed toward multiple destination nodes at the same time, and to save more than one path in cache memory so that if a first path becomes unavailable, a second path is readily available in the cache. At the same time, the method utilizes a number of "pruning" steps or "chokes" for eliminating low probability paths, i.e., subpaths which are not likely to produce the best path. The chokes prevent excessive use of memory space and processing delays which would be required if every possible path were saved. The amount of pruning applied can be varied as follows:
• "aggressive" means a traversal value is better in at least one metric;
• "moderate" means a traversal value is better or equal in at least one metric; and
• "light" means a traversal value is better, equal or above some threshold level in at least one metric; this is used in cases where there is little redundancy in the mesh, so that one can save multiple values in cache.
In addition to providing chokes (i.e., pruning mechanisms), the method provides "grouping" such that all values and paths for the next traversal are stored together and processed together as a "computational unit." This second feature is also important in satisfying the time constraint. The significance of the chokes and grouping is exemplified by the following example. A source code written in "Python" (i.e., an interpretive prototyping language) according to the flow chart of Fig. 11, but without the chokes and grouping, provided a search time of about 115 seconds. Adding the chokes reduced the search time to 40 seconds. Adding the chokes and grouping reduced the time to one second — a 115 time increase in performance. When written in C++ language, the one second search time is expected to translate into a ten millisecond performance time — well within the desired time constraint.
9.2 Data Structures Global Object_Vector[0] . A vector of object instances which is a property of the Routing Object itself and is created when the Routing Object is first initialized. Each Object in the Object Vector is the implementation of a metric object.
Global Node Values [N][Q][V]. A two-dimensional array of metric value vectors. There is a vector for each combination of node index and qos index that are defined for the Routing Object.
Global Arc Values [A][V] . A one-dimensional array of metric value vectors. There is a vector for each arc in the Routing Object.
Global Adjacency [N] . A one-dimensional array (i.e. a vector) of lists. Each list represents the adjacencies of the corresponding node. Each adjacency is a tuple of the neighboring node and the arc between them. A node may appear in multiple adjacencies for the same neighbor but must have a different arc index for each appearance. Each arc index will appear twice in the Adjacency structure, once for each terminating end point. Local PtrSpace, New PtrSpace. Each is an array of records. Each record has 3 fields. The Parentfld contains the index of the parent of this family of traversals. The Pptr contains the pointer within this array of the next parent and is maintained in index order of parents. The Vptr contains the index of the first value associated with this parent in the ValueSpace or New ValueSpace arrays.
Local ValueSpace, New ValueSpace. Each is an array of records. Each record has 3 fields. The Valuefld contains the metric value vector of the aggregate values to this point in the traversals. The Vptr contains the index within this array of the next metric value vector for the parent family of traversals. The Pathptr contains the index into the PathSpace/NewPathSpace array for the first path of this value vector.
Local PathSpace, New PathSpace. Each is an array of records. Each record has 2 fields. The Pathfld contains the path to this point for the traversals. The Npptr contains the index within this array of the next path for this value vector. A Path is a list of lists. The first list is a sequence of node indices in the order of visits during the traversal. The second list is a sequence of arc indices in the order of visits during the traversal.
Local Workhead, New Wrkhead Integer. The index within PtrSpace NewPtrSpace of the fist parent within a ring or the next to be processed in a ring. Workhead, PtrSpace, ValueSpace, and PathSpace is the current concentric ring of traversals that is being processed and New Wrkhead, New PtrSpace, New ValueSpace, and New PathSpace are the next ring to be worked on. We build the next ring while we are processing the current ring. Local Output. Output is an array of records. The first field of each record is a completed path from source to goal. The second record is the aggregate values for that path. Thus, each .entry in Output is a completed path.
Local Best Value is a tuple of metric values. The first is the best primary value of a complete path seen to this point in the processing. The second is the best secondary value seen to this point in the processing.
All Value Vectors are in the same order as defined by the objects in Object_Vector AND ARE NOT necessarily in the same order as their owning objects within Object_Vector. Their position is established when the metric objects are initialized.
Route Path has the following formal parameters: Source, Goal, Primary Valuelndex, Secondary Valuelndex, Initial_Values, QOS, Filters and Returns a vector: exception, path, values.
Parameter Source Integer. The source node index of the path.
Parameter Goals List of Integers. The destination node indices of the possible paths. It may be a single node or multiple nodes.
Parameter PrimaryMetricIndex Integer. The index within Object_Vector of the metric object for which this path is to be optimal.
Parameter SecondaryMetricIndex Integer. The index within Object_Vector of the metric object which is the second precedence for optimization of this path. Parameter InitialValue Vector of Metric Values. These are the assigned metric values for this path. If this call to the Routing Object is in isolation of all other calls, this should be a vector of best values. However, if this call is made in conjunction with other calls to establish a path across multiple domains, this value will be a value returned from a preceding call to this Routing Object or another which represents an adjacent domain.
Parameter QOS Integer. This is the index for the QOS desired for this path.
Parameter Filters Sequence of tuples. Each tuple has an index for a metric object within Object_Vector and an aggregate threshold value for that metric object. For example, when cost is the metric object and it has an index of 4 within Object_Vector, (4,40) means reject all paths whose cost is equal to or exceeds 40.
Return Parameter Exception Enumerated Integer. 0 is a successful path. 1 is a successful call which determined that no path from source to destination met the constraints. Any other value indicates failure, the most common value being 3 which is an incorrect or inconsistent value for a formal parameter.
Return Parameter Path. A list of arc indices in order of traversal from source to goal.
Return Parameter Values. A vector of metric values which represents the aggregate of the InitialValues and all Node and Arc Traversals within the path up to but not including traversal of the goal node. 9.3 Flow Chart
Referring to Fig. 11, step 200 is an initialization of the values, wherein "source" refers to the source node address, "goals" refers to the one or more destination node addresses, "pindex" refers to the primary metric, and "sindex" refers to the secondary metric which is used to select the best path if the primary metrics for two paths are equal. The "initial_value" is a vector of all initial values for the metrics which may come from the management system. In a wide area network where there may be a plurality of management systems managing different areas in the network, the best path determination may proceed from one sub-area to another and the initial values may come from the best path determination of an adjacent sub-area. If this is the first system to determine the best path, then the initial values will be the best values of the metrics. The "QOS" defines the quality of service for the various types of transmissions, such as voice, video or data, and provides static filters which do not change over time. The "filters" are dynamic filters such as call blocking probability, peak cell rate, etc., which are required to change over time.
Following initialization, the method proceeds to step 201 wherein the value of the data structure "Workhead" is checked. As shown in Fig. 12, the data structure's Workhead 230, Ptrspace 231, Valuespace 232 and PathSpace 233 form a chain of linked data structures, each with an array of records. PtrSpace and ValueSpace each have three fields, while in PathSpace each record has two fields. These linked data structures illustrate how the values and paths for the next traversal are stored and processed together as a computational unit.
During the first traversal, the Workhead will not be "none" and we proceed to step 202 wherein we obtain the value of parent (the next node) from PtrSpace. At this time we also set the Workhead equal to the next parent pointer, to get ready for the next traversal. We proceed to step 203, wherein the Parentvalues are set equal to the values for the parent from the Nodevalues. The Nodevalues are the values of the metrics of that node. Proceeding to step 204, we get the "Neighborlist" of adjacent nodes to the parent. Proceeding to step 205, we check whether the Neighborlist is empty, and if not, we proceed to step 206 to get the next neighbor (node) and arc from the next tuple in the Neighborlist. During this next portion of the flow chart from steps 206 to 210, we are processing the values. We then proceed to step 207 to check if the neighbor node is the same as the parent; if so, we do not need to check this path (it has already been traversed) and we terminate it (this is one of the chokes). Next at step 208 we check to see if the arc or neighbor is disabled or if we have reached an end node which is not one of our goals, in which case we would terminate (i.e., another choke) . We then proceed to steps 209 and 210 to check the value of the secondary metric. We now enter a new portion of the flow chart from steps 211 to 217 where we iterate the values. At step 211, we get the values from the data structure ValueSpace (232 in Fig. 12) and proceed through steps 213-215 to determine if there is any metric in Values which is better than in Nodevalues, i.e, the values of the metrics up to that node. If this is not a better path in any one metric, then we terminate the path. If not, we proceed with step 216 to record the better values into Nodevalues, and proceed to step 217 to determine whether the Nodevalues pass the threshold filters for each of the metrics. If they do, we proceed to step 218 and now enter the portion of the flow chart where we iterate the paths. In step 218, we first check to see whether we have reached the destination node. If we have, we proceed to steps 219 and 220 to check whether the primary metric is the best compared to all previous paths. If not, we terminate the path. If it is, we proceed to step 221 to output the path as the best path determination. Returning back to step 218, if we have not reached the destination node, we proceed to steps 222-223 to check whether this path has produced the best value for the primary metrics and then proceed to step 224 to proceed onto the next Workhead.
Returning to step 225, we initialize a new traversal. If we have reached the end of our traversals and there is no path which meets all of the constraints, we proceed through steps 226 and 229 to report that no path has been found. Alternatively, if we have a successful result we proceed to steps 226-228 and record the best path.
Fig. 13 illustrates a series of traversals from source node 121 to destination node 130. The search proceeds in concurrent rings as illustrated by 234A, 234B, 234C, etc. The various dashed and dotted lines show different paths from source node 121 to intermediate node 129. In this case, the traversal of the nodes 121-129 can have six paths, and three paths have been found to arrive at node 129 with equal values. In this case, we would not need to check the individual metrics of each of the three paths with the next traversal to node 130, since they are all equal; rather, we can simply check the next traversal against the metrics of one path. This time savings is enabled by the grouping of values and paths in the linked data structures shown in Fig. 12.
10. Allocation of Bandwidth
10.1 Discussion of the Related Art
In computer networks and controllers, sharing of bandwidth-limited resources is commonly required. Bandwidth-limited resources may be hardware or software resources. Examples of bandwidth-limited, shared hardware resources are peripheral devices such as printers, scanners, memories, disk drives and backplane communication links. Backplane communications links are used to connect modules in a device, such as a computer, a network controller, or a network hub such as a bridge or a router. Examples of bandwidth-limited, shared software resources are processes such as compression/decompression algorithms, and memory access algorithms. These resources are referred to as bandwidth-limited because their bandwidth limits the rate at which data can be transferred to, from, or by the resource. Within this disclosure, the term bandwidth-limited, shared resource is meant to refer to a device or process having a bandwidth limit that determines the rate of transfer of data.
In a system such as a local area network bridge or router, a number of modules are contained in a chassis. Each of the modules has one or more ports to which may be connected users or other network segments. The modules are connected together via a backplane communication link over which data is transferred from one module to another resulting in the data being transferred from one port on one module to a port on another module. This backplane communication link, although typically having a high bandwidth and resulting high rate of data transfer (typically from several hundred megabits per second to several gigabits per second), is the limiting factor in determining how quickly data is transferred from one port on one module to another port on another module, because the backplane communication link can serve only one port at a time.
To ensure that all of the ports connected to the networking chassis have access to the backplane communication link, some type of arbitration is typically employed. Each of the ports on a module connected to the networking chassis may be considered a "competing device" that competes, along with all of the other ports connected to the networking chassis for access to the backplane communication link. Within this disclosure, the term "competing device" is meant to refer generally to any type of hardware device, software process, or firmware, or application program that is to make use of a bandwidth-limited, shared resource. One approach to arbitrate between the competing devices has been to provide what is known as time division multiplexing (TDM). In a TDM arbiter, a time segment is determined. A time segment is a unit of time, typically fixed, during which a competing device would be allowed exclusive use of the bandwidth-limited, shared resource. One time segment is assigned for each competing device. If there were ten competing devices, then there would be ten time segments. Each of the competing devices is then assigned to one of the available time segments. This information is then used by a state machine that increments through each time segment to allow the particular competing device assigned to that segment to use the backplane communication link for its assigned time segment. After the state machine has stepped through all ten devices, the process loops back to the first segment and begins again. This results in each competing device being able to use one-tenth of the available bandwidth of the bandwidth-limited, shared resource.
In a TDM arbiter, the users of each time segment are fixed. For example, the first segment is always assigned to a particular port on the network chassis and the ninth segment is assigned to another particular port on the networking chassis. One of the problems with this type of arbiter is that if the port that is allocated to a time segment is not requesting use of the backplane communication link at the time the TDM arbiter allows it to do so, then that time segment will be wasted and the backplane communication link is idle during the assigned segment.
Another way to allocate the time segments of a bandwidth-limited, shared resource such as a backplane communications link is to use a so-called "Round-Robin" arbitration system. In a Round-Robin system, a list of the competing devices is compiled and stored. An allocation token allowing exclusive use of the backplane communications link is then passed among the list of competing devices, for example, in a sequential manner. By applying sets of rules to the allocation token, the token can be passed to a device that is not necessarily the next device in the list, thus allowing for some prioritizing of allocation among competing devices. The competing device that is in possession of the allocation token is then allowed to use the backplane communication link for a particular time period. One problem with this type of arbitration system is that if the device in possession of the allocation token does not require use of the backplane communication link, the backplane communication link is unused and idle for the particular time segment.
Other types of fixed allocation systems may be used that determine, at the beginning of a particular time segment, which competing device is to be allowed exclusive access to the backplane communication system. One problem with fixed allocation systems is that the arbitration requires a portion of the time segment to determine which competing device should use that particular time segment. Therefore, the rate at which data can be transmitted across the backplane communications link is reduced because a portion of the time segment must be used to perform arbitration.
Another disadvantage of the TDM and Round-Robin arbiters is that the latency of transmission of, for example, a data packet, may be increased due to the wasted time segments. That is, although a data packet from a particular port may be waiting and ready for transmission across the backplane communication link, the data packet cannot be transmitted until the TDM arbiter allows the port access to the backplane communication link or the Round-Robin token is allocated to the port.
Therefore, an object of the present invention is to provide a method and apparatus for arbitrating access to a bandwidth-limited, shared resource in a manner that improves latency through a bandwidth-limited resource.
Another object of the present invention is to provide a method and apparatus for accessing bandwidth- limited, shared resources that allows the bandwidth-limited resource to be used whenever there is a competing device requesting access to the bandwidth-limited resource.
Another object of the present invention is to provide a method and apparatus that allows a bandwidth-limited resource to service competing devices that have a total aggregate bandwidth greater than the bandwidth of the bandwidth-limited, shared resource.
Another object of the present invention is to guarantee different quality of services to different competing devices depending upon priorities of the competing devices.
10.2 New Apparatus And Method For Allocating Bandwidth
For purposes of illustration only, and not to limit the generality, the present invention will now be explained with reference to its use for allocating time segments of a backplane communication link (a bandwidth-limited, shared resource) in a networking chassis. One skilled in the art will recognize that the present invention is generally applicable to allocation of time segments of any type of bandwidth-limited resource to a number of competing devices. For example, the present invention may be used to control access to a local bus, a switch, a disk drive, a memory bank, or a software process.
Fig. 14 illustrates a networking chassis 410 that may be, for example, a bridge, router, or hub. The chassis contains a number of slots that can receive plug-in modules 412-1 through 412-N. A backplane including a communication link 416 connects the modules together to provide data transfer and control. Each of the modules 412 includes an arbitration circuit 414 that controls access to backplane communication link 416. The modules contain a number of ports 1-n to which devices that require use of the backplane communication link 416 are connected. The networking chassis 410 is described more fully in a copending and commonly owned application entitled Distributed Chassis Agent For Network Management, by Brendan Fee et al., filed on even date herewith, the disclosure of which is incorporated herein by reference in its entirety. In the networking chassis 410, the backplane communications link has a bandwidth of 4 gigabits. Each of the devices 1-N, which may be peripherals, workstations, network segments, bridges, routers, or other hubs, compete for access to backplane communication link 416 in order to transmit data from one device to another.
Fig. 15 illustrates one embodiment of arbitration circuit 414 illustrated in Fig. 14. In accordance with the method described in the above-described copending application, one or more of the arbitration circuits 414 is chosen to act as arbiter for all of the competing devices connected to all the ports of all modules 412.
Arbitration circuit 414 includes a set of status and control registers 418 that are used to control access to memory 422 and arbitration engine 424 by the CPU (central processing unit, not shown) that is acting as the chassis control agent in accordance with the method and apparatus described in the copending application. The data transceiver 426 provides any necessary interface between communication link 416 and memory 422 and latch 428. Communication link 416 is typically a multibit bus. The latch 428 is used to transfer data from memory 422 or data transceiver 426 to the arbitration engine 424. An address generator 430, which may be a counter, is used to incrementally generate addresses for reading and writing data and control information into and out of memory 422.
The arbitration engine 424 arbitrates between requests received from devices on bus 432 to allocate time segments of backplane communication link 416 to the competing devices using control bus 434. Lines 436 and 438 are used to provide appropriate initialization and control signals.
The first step in setting up the arbitration mechanism of the present invention is to program the length of the time segments and the order in which the time segments are to be allocated. The time segments are typically of equal length and the length of a particular time segment is dependent upon a particular application, the architecture of the communication link 416 and its bandwidth (or the architecture and bandwidth of the particular bandwidth- limited, shared resource that arbitration circuit is to control). For example, if communication link 416 is a bus that is only a few bits wide, the time segments need to be shorter time intervals so that data can be moved quickly. In a like manner, if the communication link 416 is a bus having a relatively wide width (i.e., 32 or 64 bits), then the time segments may be longer time intervals to provide the same bandwidth.
The first level of arbitration performed by arbitration circuit 414 is a programmable time division multiplexing type arbitration. Memory 422 is used to provide this program ability. After memory 422 has been programmed, arbitration engine 424 operates basically as a state machine wherein the states determine which competing device is to be allocated a time segment as a function of the information programmed in memory 422. Each location in the memory is programmed with information indicating which competing device is to have access to the next time segment to be allocated. After the arbitration is performed, address generator 420 increments the memory location so that when arbitration engine 424 accesses the memory during the next state of the state machine, information as to which competing device has rights to exclusive use of communication link 416 is available.
Figs. 16 and 17 illustrate some examples of how the state machine might be programmed and operate. Fig. 16 illustrates the case where all of the competing devices are given equal bandwidth. In state 1, competing device 1 has been programmed in memory 422 as the competing device allocated to the first time segment. In state 2, competing device 2 has been programmed as the competing device allocated to the second time segment. In state 3, competing device 3 has been programmed as the competing device allocated to time segment 3. In state 4, competing device 4 has been programmed as the competing device allocated to time segment 4. From state 4, the state machine returns to state 1 and continues processing. Although only four states and four devices have been illustrated, one skilled in the art will appreciate that the state machine would have as many states as there are devices and memory 422 would have at least as many memory locations for devices as there are competing devices. As is evident from Fig. 16, each competing device has been allocated one-quarter of the available bandwidth.
Fig. 17 illustrates an embodiment in which the time division multiplexing arbiter has been programmed to allocate the bandwidth unequally. In state 1, the time segment is allocated to competing device 1. In state 2, the time segment is allocated to competing device 2. In state 3, the time segment is allocated to competing device 1 again. In state 4, the time segment is allocated to competing device 3. In state 5, the time segment is allocated again to competing device 1. In state 6, the next time slice is allocated to competing device 4. From state 6, the state machine returns to state 1 and processing continues. As is evident from the programmed time division multiplexing scheme illustrated in Fig. 17, competing device 1 has been allocated 1/2 of the available bandwidth of communication link 16 and the remaining one-half bandwidth has been allocated equally among competing devices 2, 3, and 4. Thus, if competing device 1 required more bandwidth or was a higher priority device, memory 422 can be programmed to accommodate these needs.
One skilled in the art will appreciate that other state machines can be developed along this principle to allocate the bandwidth as needed to various competing devices. As also illustrated in Fig. 17, the programmable time division multiplexing arbitration system provides a first level of arbitration that can be used to assign priorities for access to communication link 416 among the various competing devices.
Fig. 18 illustrates one of the features of the present invention in which arbitration and allocation of time •segments are performed during the data transfer cycle just prior to the cycle in which the time segment is to be used. In step 450, the system is initialized. Initialization includes programming memory 422. From step 450, the system proceeds to step 452 in which a first arbitration and allocation step to allocate the first available time segment is performed. This step corresponds to, for example, determining in state 1 of Figs. 16 or 17, which device is entitled to exclusive access to communication link 416.
From step 452, the system proceeds to step 456 in which another arbitration and allocation step is performed. During arbitration and allocation step 456, the system also proceeds in step 454 to allow a data transfer across communication link 416 by the competing device determined in step 452. From step 456, the system proceeds to step 460 in which another arbitration and allocation step is performed. At the same time that arbitration and allocation step 460 is being performed, a data transfer across communications link 416 by the device determined in step 456 is being performed. As illustrated by time scale 451, during time interval T , step 450 is performed and during time interval T.( step 452 is performed. During time interval T,, steps 456 and 454 are performed and during time interval T3, steps 460 and 458 are performed. Time intervals TQ - n are equal sized time intervals. The system continues in this mode of arbitrating and allocating the next available time segment in parallel with a data transfer that is already occurring. Although this results in a penalty because one extra arbitration and allocation step (namely step 452) must be performed before the first data transfer can occur, once this first arbitration and allocation has been performed, the system operates with improved efficiency because allocation and arbitration and data transfer occur simultaneously. In particular, the next available time segment is arbitrated and allocated during the time segment of the previous data transfer.
Referring again to Figs. 15, 16 and 17, one additional feature of the present invention is the inclusion of a "wrap" register 421 in address and control generator 420. Wrap register 421 is programmed to reset address generator 430 and memory 422 to their first addresses when all of the states of the state machine have been processed. For example, if memory 422 contained 2,000 locations, address generator 430 will control the memories to sequence through all 2,000 addresses until the counter reaches its upper limit and turns over. However, in the situation where there are fewer than 2,000 states in the state machine, as illustrated in Figs. 16 and 17, further improvements in efficiency can be obtained by programming wrap register 421 vith the highest state of the state machine (and/or the highest address location of the memory 422). For example, in Fig. 17, wrap register 421 would be programmed to indicate that the highest state in the state machine is state 6 and would also contain the highest programmed address in memory 422. In each state of the state machine, a check is made of wrap register 421 to determine whether or not the state machine has reached its last state. If the answer is yes, the state machine loops back to state 1 and processing continues. On the other hand, if the check indicates that the last state of the state machine or the highest address in the memory has not been reached, then the state machine and address are incremented to the next state and address, respectively.
The programmable arbitration system of the present invention provides a first level of arbitration and allows competing devices which require deterministic service policies such as isochronous devices to be serviced with other nondeterministic devices trying to access the communication link 416. This fixed allocation system also guarantees that the bandwidth needed to service an isochronous device is always available.
Reference is now made to Fig. 19 which illustrates the method of the present invention including all three levels of arbitration. As will be described, the second and third levels of arbitration, when competing devices have been programmed to use them, allow unused time segments to be allocated to other competing devices in order to improve system performance.
In step 500, the arbitration circuit 414 is initialized. Initialization includes assigning each competing device an identification number and assigning time segments to these identification numbers as illustrated in, for example, Fig. 17. One skilled in the art will appreciate that a competing device may be prohibited from participating in the first level of arbitration by not assigning it a time segment. In addition, a list of the competing device identification numbers is also stored in memory 422 and an allocation token is assigned to one of the competing device identification numbers. Also, initialization includes programming, into memory, which levels of arbitration a competing device may participate in. From step 500, the system proceeds to step 502.
In step 502, the TDM state machine programmed in accordance with, for example, Fig. 16 or 17, is initialized and a first arbitration and allocation step, such as step 452 in Fig. 18, is performed. From step 502, the system proceeds to step 504 in which the system goes to the first state of the programmed state machine. From step 504, the system proceeds to step 506. In step 506, the system determines which competing devices are requesting use of communications link 416 by monitoring request signals received on, for example, bus 432 in Fig. 15. From step 506, the system proceeds to step 508. In step 508, the system determines whether any requesting device identification number equals the identification number that has been programmed for the next state of the state machine. If the answer is yes in step 508, the system proceeds to step 510 in which the time segment is allocated to the requesting device identified in step 508. On the other hand, if the answer in step 508 is no, the system proceeds to step 512.
In step 512, the system determines whether any requesting device identification number equals the identification number of the device associated with the allocation token that was assigned in initialization step 500. This provides a second level of arbitration. The system also checks if the requesting device has been programmed to participate in the second level of arbitration. If the time segment remains unallocated after the first level of arbitration in step 508, the system provides a second level of arbitration, in step 512, to attempt to assign the unused time segment to another competing device. If the answer is yes in step 512, the system proceeds to step 514 in which the system determines whether the device identified in step 512 is presently using the bandwidth-limited, shared resource, i.e., the communication link 416 illustrated in Figs. 14 and 15. The purpose of step 514 is to prevent one of the competing devices from hogging the communications link for multiple time segments. If the answer is no in step 514, the system proceeds to step 516 in which the time segment is allocated to the requesting competing device identified in step 512.
Returning to steps 512 and 514, if the answer is no in step 512 or yes in step 514, the system proceeds to step 518. Step 518 provides a third level of arbitration that attempts to make use of the unallocated time segment if the first two levels of arbitration have not assigned the time segment. In step 518, the system determines whether there is a requesting competing device having the lowest identification number in the list of competing devices and whether that device has been programmed to participate in the third level of arbitration. If the answer is yes in step 518, the system proceeds to step 520 and allocates the time segment to the requesting competing device identified in step 518. From step 520, the system proceeds to step 522. Returning to step 518, if the system determines that there is no device waiting to use communication link 416, then the time segment goes unallocated and the system proceeds to step 522. One skilled in the art will appreciate that although the third level of arbitration is illustrated as assigning the time segment to the device having the lowest identification number, clearly other allocation schemes could be substituted for this step. For example, the time segment could be allocated to the device having the highest identification number in the list of competing devices. More generally, the third level of arbitration allocates the time segment to the requesting competing device having a predetermined rank in the list of competing devices. The predetermined rank may be the lowest identification number, the highest identification number, or the identification number in the middle of the list, for example.
Returning to steps 510 and 516, the system also proceeds to step 522 after these steps. In step 522, the allocation token is passed to the next competing device in the list of competing devices.
From step 522, the system proceeds to step 523 in which an enable signal is sent to the competing device selected in steps 510, 516, or 520.
From step 523, the system proceeds to step 524. In step 524, the wrap register is checked to determine if the last state of the state machine or the last programmed memory location has been reached. If the answer is yes in step 524, the system proceeds to step 504, returning to the first state of the state machine, and processing continues as already described. On the other hand, if the answer in step 524 is no, the system proceeds to step 526. In step 526, the address of memory 422 is incremented and the state machine goes to the next sequential state. From step 526, the system proceeds to step 506 and processing continues as already described.
As can be seen from an examination of Fig. 19, once the system has proceeded through a first arbitration and allocation cycle, the allocation and arbitration steps proceed in parallel with data transfers occurring during a time segment. That is, the system is proceeding through steps 500-522 while the competing device that had been enabled as a result of step 523 in the prior arbitration and allocation cycle is performing a data transfer.
The present invention provides a number of advantages. Typically, conventional TDM type arbiters are hard-coded logic implementations that are not programmable and not easily used in other applications once designed. The present invention, on the other hand, being a programmable memory-based device, is not only programmable, but the same hardware can be used in other applications. The programmable memory also allows the present invention to be configured to allow any time segments or mix of time segments to be assigned to a bandwidth-limited, shared resource rather than having the resources assigned to the same segment in every implementation.
The present invention provides a system in which competing devices that require deterministic and regular service policies can be accommodated, as well as devices that can arbitrarily make use of a bandwidth-limited, shared resource. In addition, the present invention allows unused time segments to be allocated to devices that can make use of them, thus improving the latency of data transmission to or through the bandwidth-limited, shared resource, if the competing devices are programmed to participate in the second
Figure imgf000061_0001
improving the latency through the bandwidth-limited, shared resource.
The present invention may be implemented in a variety of ways. For example, the invention can be implemented completely in software, completely in hardware, or in a combination of both. As illustrated in Fig. 15, memory 422 can be implemented as static RAM, dynamic RAM, novRAM, or proms. The control circuitry of address generator 430, data transceiver 426, and latch 428 can be fabricated from standard TTL devices, CMOS devices, or incorporated into single chip implementations such as PALS, FPGAs, or ASICS.
Having thus described one particular embodiment of the invention, various alterations, modifications, and improvements will readily occur to those skilled in the art. For example, one skilled in the art will appreciate that the present invention may be applied outside the field of computer networks to any system that requires sharing of a bandwidth-limited resource among competing devices, such as a memory bank or a disk drive in a standalone computer system. Additionally, although a hierarchy of three levels of arbitration has been discussed in detail, any number of levels of arbitration can be used depending upon the particular characteristics of the bandwidth-limited, shared resource and the environment in which it is used. Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention.
10.3 Example of Bandwidth Allocation For SFPS Module
In this example, the previously defined multi-level programmable arbitration is applied to module 32 plugged into networking chassis 30 (see Fig. 4). The module 32 includes an SFPS switch 40, as shown in Fig. 5; the internal operation of the SFPS switch was previously described with regard to " Fig. 2. The multilevel programmable arbiter (MPA) 13 (shown
Figure imgf000063_0001
The host gets 100k x 256, or 25.6 Mbits/sec. The backplane gets 100k x 256 x 12, or approximately 307 Mbits/sec. At the second level of arbitration (not shown) , the round robin token continually circulates between all those devices enabled to use it. Similarly, the third level of arbitration is available to those devices enabled to use it, and awards the unused time slice to the lowest requesting device participating in the third level arbitration.
While this example does not seem to put any stringent requirements on the number of slices given a port or how frequently the slices need to appear in the TDM ram, the ports themselves will put requirements on how often they need a slice. For example, the Ethernet ports have 32 byte pre-staged fifos that need to be filled or emptied within a certain time interval. The Ethernet ports having 32-byte fifos need a data transfer of 32 bytes every 32 x 800 nsec or 25.6 usec. This means that each Ethernet port needs its port ID programmed at no less than a 25.6 usec interval in the TDM ram to insure that no overflow or underflow occur for the device. The 25.6 usec translates to 64 time slices in the TDM ram. As long as the slices for a particular Ethernet port are not further apart in the ram than 64 addresses, no under or over runs of data will occur. FDDI ports would require a different bandwidth allocation.
11. SFPS Software Object Model
A complete functional model of the SFPS may be implemented as software objects within the firmware architecture. The SFPS is integrated within the generalized system architecture which allows it to be a logical application within the system and have access to the resources and communication device drivers.
11.1 SFPS Objects
All of the embedded SFPS is implemented within software objects. Objects are data constructs and associated
Figure imgf000065_0001
sub-objects which provide the SFPS switch functionality. These are the Connection Table Object 606, InPort Objects 607, the OutPort Objects 608, and the Switch Engine Object 609.
Connection Table Object - Provides the data and methods for maintaining the cross connect mapping of in-ports and out-ports for each connection. It is indexed, in order, by SFPS connection-identifiers. Connection-identifiers are formed by combining the source-port, the source MAC address, and the destination MAC address of the end stations for which a connection is defined. Note that multi-party connections will have a list of out-ports within the Connection Table. The Connection Table is an AVL-tree (a balanced binary tree) which can grow to arbitrary size. Currently, a maximum of 16,000 connection entries are supported. In addition to providing internal access for the Switch Engine, it also provides call accounting information on each active connection as well as the managed object view for remote management.
Port Objects - Provides the data and methods for configuring and accessing the physical media ports for in-bound and out-bound traffic. As illustrated in Fig. 22, these Port objects 610 are objects that allow SFPS-specific use of physical switch ports 611 within the system. In firmware-based systems, these objects access the physical port through a Framing Object 612 which hides the media-specific framing characteristics of the communication datalink. The Framing Objects, in turn, interface with the media-specific device driver 613 through a common datalink Interface Object 614 and packet memory which is described and accessed with Packet Control Structures (PCS) 615. To provide bandwidth control and rate limiting, these objects have transmit and receive queues 616, 617 which provide the staging of packets into and out of the switch engine. InBound and OutBound Port Objects are derived from these Port Objects. Switch Engine Object - Provides the data and methods for the actual switching machine of the SFPS. This object implements a TDM and polling software to service in-bound and out-bound ports. The Switch Engine Object is the central engine of the SFPS Switch. It provides the context under which the switching of packets is performed.
11.2 SFPS Application Threads
Several Application Threads exist for SFPS which provide functionality required for SFPS which is not in the SFPS Switch itself. These mainly deal with the access to external servers and control points which exist outside of the embedded device. Each of these threads are instantiated by the SFPS Application Object. Threads are essentially processes or software tasks. Each of the SFPS applications are described below.
SFPS Switch Agent - This thread provides the remote management of the SFPS Switch. It implements the managed objects which are the objects that provide the SNMP-based view of the control and configuration aspects of the switch. These managed objects are also used internally to provide access from the local console. The actual MIB and its managed object definition is set forth in section 11.3.
SFPS Call Processor - This thread provides the logic and interface for translating unknown or broadcast packets into third-party call requests. This is a key element of providing access through an SFPS Switch, since the Switch itself will not provide any switching capability until it is "programmed" with connections in the connection table. The Call Processor thread processes packets by decoding the protocol-specific frames, decoding either MAC addresses or network-level addresses inside the network packet to determine the end-to-end system path for the connection and making API message requests to the SFPS Connection Server. The Call Processor specifically translates protocol packets into implied connection requests and asks the SFPS connection server to establish a logical path of switched connections allowing the source and destination end systems to have a uni-directional connection through the SFPS network fabric.
SFPS Discovery Agent - This thread provides the logic and capability to discover adjacent systems attached to the SFPS Switch. Specifically, this thread snoops on protocol packets and determines if it originated from another SFPS Switch (SFPS Adjacency) or from an end system (SFPS user). By snooping the packets it decodes and extracts any address information inside the packet. In particular, the thread extracts the source MAC address and any high-layer protocol addresses and, in turn, registers these with an external SFPS Directory Server. In addition, it maintains a discovery table which shows adjacencies and end systems for each inPort and outPort on the switch.
11.3 MIB and Its Managed Object Definition
CTRON-SFPS-MIR DEFINITIONS : := BEGIN
sfps-mib.txt Revision: 0.0.03
0.0.01 initial draft
0.0.02 added outPort in connection table 0.0.03 added complete enum types for InPortConfigType 0.0.04 added a separate outPortTable for connectionTable
Part Number :
Date: October 25, 1993
Cabletron Systems, Inc.
35 Industrial Way, P.O. Box 5005 Rochester, NH 03867-5005
(603) 332-9400 support<_.ctron.com This module provides authoritative definitions for Cabletron's enterprise specific Fast Packet Switching MIB.
This module will be extended, as required.
Cabletron Systems reserves the right to make changes in Specification and other information contained in this document without prior notice. The reader should consult Cabletron Systems to determine whether any such changes have been made.
In no event shall Cabletron Systems be liable for any incidental, indirect, special, or consequential damages whatsoever (including but not limited to lost profits) arising out of or related to this document or the information contained in it, even if Cabletron Systems has been advised of, known, or should have known, the possibility of such damages.
Cabletron grants vendors, end-users, and other interested parties a non-exclusive license to use this Specification in connection with the management of Cabletron products. Copyright October 93 Cabletron Systems
IMPORTS
OBJECT-TYPE
FROM RFC-1212 DisplayString
FROM RFC1213-MIB enterprises, IpAddress, Counter, TimeTicks, Gauge
FROM RFC1155-SMI; Cabletron
OBJECT IDENTIFIER = { enterprises 52 } mibs
OBJECT IDENTIFIER = { Cabletron 4 } ctronExp
OBJECT IDENTIFIER = { mibs 2 } ctronSwitch
OBJECT IDENTIFIER = { ctronExp 4 } switchCommon
OBJECT IDENTIFIER = { ctronSwitch 1 } switchSFPS
OBJECT IDENTIFIER = { ctronSwitch 2 }
— The-SFPS Switch Groups,
sfpsSwitchEngine
OBJECT IDENTIFIER = { switchSFPS 1 } sfpsSwitchAgent
OBJECT IDENTIFIER = { switchSFPS 2 }
— The SFPS Switch Engine Groups
sfpsSwitchSystem
OBJECT IDENTIFIER = { sfpsSwitchEngine 1 } sfpsSwitchPorts
OBJECT IDENTIFIER = { sfpsSwitchEngine 2 } sfpsSwitchConnections
OBJECT IDENTIFIER = { sfpsSwitchEngine 3 }
— The SFPS Switch Agent Groups
sfpsAgentSCSDomain
OBJECT IDENTIFIER : : = { sfpsSwitchAgent 1 } sfpsAgentTopology
OBJECT IDENTIFIER : : = { sfpsSwitchAgent 2 } sfpsAgentSignalling
OBJECT IDENTIFIER = { sfpsSwitchAgent 3 } stpsAgentDiagnostics
OBJECT IDENTIFIER - { sfpsSwitchAgent 4 }
— The SFPS Switch System Group
sfpsSystemConfig
OBJECT IDENTIFIER : = { sfpsSwitchSystem 1 } sfpsSystemStats
OBJECT IDENTIFIER : : « { sfpsSwitchSystem 2 }
— The SFPS Switch Ports Group
sfpsPortConfig
OBJECT IDENTIFIER : : = { sfpsSwitchPorts 1 } sfpsPortStatε
OBJECT IDENTIFIER : : = { sfpsSwitchPorts 2 }
— The SFPS Agent SCS Domain Group
— tbd
— The SFPS Topology Group
sfpsTopologyUsers
OBJECT IDENTIFIER = { sfpsAgentTopology l } sfpsTopologyAdjacencies
OBJECT IDENTIFIER = { sfpsAgentTopology 2 }
— The SFPS Agent Call Processing Group
— tbd
— The SFPS Agent Diagnostics Group sfpsDiagEventLog
OBJECT IDENTIFIER : : = { εfpsAgentDiagnostics 1 } sfpsDiagTesting
OBJECT IDENTIFIER : : = { εfpsAgentDiagnostics 2 } — Textual Conventions
sfpsSwitchlnstance : := INTEGER
— this will map to chassis.module index value
sfpsSwitchPort : := INTEGER
— this will map to chassis.module.portgroup. portsubgroup.port index value
sfpsAddress : := OCTET STRING (SIZE (6))
— this will map to a MAC address
— SFPS Switch Engine System Group
— This group contains the objects that pertain to SFPS switching engines at a SFPS switch module single-instance level. This group contains two sub-groups: configuration and statistics.
— SFPS Switch Configuration Group
— This group contains the objects that pertain to the setup and configuration of a single instance of an SFPS.
sfpsSysConfigTable OBJECT-TYPE
SYNTAX SEQUENCE OF sfpsSysConfiqEntry
ACCESS not-accessible
STATUS mandatory
DESCRIPTION "This table contains the configuration and administrative information of each SFPS instance. Essentially, a separate SFPS instance exists for each switch module. If SFPS is not configured on a module, then an entry will not exist."
: : = { sfpsSystemConfig 1 } sfpsSysConfigEntry OBJECT-TYPE
SYNTAX SfpsSysConfigEntry ACCESS not-accessible STATUS •mandatory DESCRIPTION "Each entry specifies the SFPS configuration for the SFPS instance."
INDEX { sfpsSysConfigSwitchlnstance }
: = { sfpsSysConfigTable 1 }
SfpsSysConfigEntry : : = SEQUENCE { sfpsSysConfigSwitchlnstance SfpsSwitchlnstance, sfpsSysConfigAdminStatus INTEGER, sfpsSysConfigAdminReset INTEGER, sfpsSysConfigOperStatus INTEGER, sfpsSysConfigOperTime TimeTicks, sfpsSysConfigLaεtChange TimeTicks, sfpsSysConfigVersion DisplayString, sfpsSysConfigMibRev DisplayString, sfpsSysConfigHostMgmtPort SfpsSwitchPort, sfpsSysConfigHostCtlPort SfpsSwitchPort, sfpsSysConfigBcastPort SfpsSwitchPort, sfpsSysConfigErrorPort SfpsSwitchPort, sfpsSysConfigSwitchCapacity INTEGER, stpsSysConfigSwitchBW INTEGER, sfpsSysConfigHostBW INTEGER, sfpsSysConfigFreeBufQSize Gauge, sfpsSysConfigFreeBufQLen INTEGER
} sfpsSysConfigSwitchlnstance OBJECT-TYPE SYNTAX SfpsSwitchlnstance
ACCESS read-only
STATUS mandatory DESCRIPTION "The primary index to the SFPS switch table. This identifies the SFPS switch for which the entry exists." = { sfpsSysConfigEntry 1 }
sfpsSysConfigAdminStatus OBJECT-TYPE SYNTAX INTEGER { other(1), none of the following disabled(2) , shutdown the SFPS enabled(3) startup the SFPS }
ACCESS read-write STATUS mandatory DESCRIPTION "Sets the administrative state of the SFPS switching services for this SFPS instance. This controls the SFPS state at a module level. Regardless of the per-port state of each SFPS switching port and the state of active connections, writing the value disabled(2) will cause the SFPS to immediately shutdown. A gracefull shutdown will be attempted." = { sfpsSysConfigEntry 2 }
sfpsSysConfigAdminReset OBJECT-TYPE SYNTAX INTEGER { other(l), — none of the following reset(2) — force a reset
}
ACCESS read-write STATUS mandatory DESCRIPTION "Resets this SFPS switch instance. Writing a value of reset(2) will force a soft restart of the SFPS without any graceful shutdown. Any active connections or services will be interrupted." = { sfpsSysConfigEntry 3 } sfpsSysConfigOperStatus OBJECT-TYPE SYNTAX INTEGER { other(1) , — none of the following disabled(2) , — not running enabled(3) , — running pending-disable(4) ,— shut-down in progress pending-enable(5) , — start-up in progress invalid-config(6) — not running,invalid config
} ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the current operating condition of the SFPS instance. " : : = { sfpsSysConfigEntry 4 }
sfpsSysConfigOperTime OBJECT-TYPE
SYNTAX TimeTicks ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the amount of time (# of time ticks) that this SFPS switch instance has been in its current operational state." - { sfpsSysConfigEntry 5 }
sfpsSysConfigLastChange OBJECT-TYPE
SYNTAX TimeTicks ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the last time a change was made to the configuration entry for this SFPS switch instance." = { sfpsSysConfigEntry 6 } sfpsSysConfigVersion OBJECT-TYPE
SYNTAX DisplayString ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the current revision level of the SFPS MIB for this SFPS switch instance." = { sfpsSysConfigEntry 7 }
sfpsSysConfigMibRev OBJECT-TYPE
SYNTAX DisplayString ACCESS read-only STATUS mandatory DESCRIPTION "Indicates in textual format the current revision level of the Cabletron SFPS MIB implemented by the agent for this SFPS switch instance." = { sfpsSysConfigEntry 8 }
sfpsSysConfigHoεtMgmtPort OBJECT-TYPE
SYNTAX SfpεSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the SFPS switch port that is attached to the Hoεt Management Agent. All valid management requeεtε are forwarded to this port by default. This is done by providing a default entry in the SFPS connection table that allowε DA-only εwitching to the hoεt port. Specific programming of the SFPS connection table can override thiε default." = { εfpεSyεConfigEntry 9 }
εfpεSyεConfigHostCtlPort OBJECT-TYPE SYNTAX SfpsSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the SFPS switch port that is attached to the host for non-management packetε . This port is known as the host .control channel. "
: : = { εfpεSyεConfigEntry 10 }
sfpsSysConfigBcastPort OBJECT-TYPE SYNTAX SfpsSwitchPort
ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the SFPS switch port that will be fowarded all broadcast (non-unicaεt) frames that are not explicitly part of a connection. By default, this is the host control port. " = { sfpεSysConfigEntry 11 }
εfpεSyεConfigErrorPort OBJECT-TYPE
SYNTAX SfpεSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the SFPS switch port that will be forwarded all non-broadcast frames that are not part of a valid connection." = { sfpsSysConfigEntry 12 }
sfpsSyεConfigSwitchCapacity OBJECT-TYPE
SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the theoretical maximum bandwidth of the SFPS εwitch inεtance for which thiε entry exists."
= { εfpεSyεConfigEntry 13 } εfpεSyεConfigSwitchBW OBJECT-TYPE SYNTAX INTEGER ACCESS read-write STATUS mandatory
DESCRIPTION "Indicateε the percentage of the system bandwidth to be allocated to the switch, : : = { sfpsSyεConfigEntry 14 }
εfpεSyεConfigHoεtBW OBJECT-TYPE
SYNTAX INTEGER ACCESS read-write STATUS mandatory DESCRIPTION "Indicateε the percentage of the εyεtem bandwidth to be allocated to the hoεt management agent of the εwitch."
= { εfpεSyεConfigEntry 15 }
sfpεSysConfigFreeBufQSize OBJECT-TYPE
SYNTAX Gauge ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the maximum number of free buffers in the SFPS switch." = { εfpεSyεConfigEntry 16 }
εfpεSyεConfigFreeBufQLen OBJECT-TYPE
SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the actual number of free bufferε left in the SFPS εwitch." = { εfpεSyεConfigEntry 17 } — SFPS Switch Statisticε Group
— Thiε group containg the objectε that pertain to the performance monitoring and statisticε of a single instance of an SFPS switch.
sfpεSyεStatεTable OBJECT-TYPE SYNTAX SEQUENCE OF SfpεSyεStatεEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Thiε table containε the εtatiεtics information for each SFPS switch instance. Essentially, a separate SFPS instance exiεtε for each εwitch module. If SFPS is not configured on a module, then an entry will not exist. " = { sfpεSyεtemStatε l }
εfpεSyεStatεEntry OBJECT-TYPE SYNTAX SfpεSyεStatεEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Each entry contains the SFPS statiεticε for the SFPS inεtance." INDEX { εfpεSyεStatεSwitchlnstance } : : = { sfpsSysStatsTable 1 }
SfpsSyεStatεEntry : : = SEQUENCE { εfpsSysStatεSwitchlnεtance SfpεSwitchlnεtance, εfpεSyεStatεAdminStatuε INTEGER, εfpzSyεStatεReεet INTEGER, εfpsSysStatεOperTime TimeTickε, εfpεSyεStatεlnPktε Counter, εfpεSysStatsOutPktε Counter, εfpεSyεStatεDiεcardPkts Counter, sfpsSyεStatεFilteredPktε Counter, εfpεSyεStatεlnOctetε Counter, sfpsSysStatεOutOctetε Counter, εfpεSyεεtatεDiεcardOctetε Counter, sfpsSyεStat FilteredOctetε Counter
— Do we need to count redirect bcaεt and unknown deεt packetε/byteε?
} sfpsSyεStatεSwitchlnεtance OBJECT-TYPE SYNTAX SfpεSwitchlnεtance
ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS εwitch table. Thiε identifies the SFPS switch for which the entry existε." = { εfpεSyεStatsEntry 1 }
sfpεSyεStatsAdminStatus OBJECT-TYPE SYNTAX INTEGER { other(l) diεabled(2) , enabled(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS εwitch εtatiεticε. Writing a value of enabled(3) cauεeε theεe counterε to become active for thiε SFPS εwitch inεtance. Writing a value of diεabled(2) cauεeε theεe counterε to become inactive for thiε SFPS εwitch inεtance." = { εfpεSyεStatεEntry 2 } εfpεSysStatsReset OBJECT-TYPE SYNTAX INTEGER { other(1), reset(2)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Reεetε the SFPS εwitch counterε for thiε SFPS εwitch inεtance. Writing a value of reεet(2) reεetε the SFPS switch counters to 0 and causes sfpsSyεStatεOperTime to also be reset to 0. " = { sfpsSysStatεEntry 3 }
εfpεSysStatεOperTime OBJECT-TYPE SYNTAX TimeTickε
ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the amount of time (# of time ticks) that the SFPS switch statisticε have been active for thiε SFPS εwitch inεtance." = { εfpεSyεStatεEntry 4 }
εfpεSyεStatεlnPktε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packetε that have been received, on thiε SFPS switch instance, during the time of sfpsSyεStatεOperTime. "
: = { SfpsSyεStatεEntry 5 } εfpεSysStatsOutPkts OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packets that have been switched, on this SFPS εwitch inεtance, during the time of sfpsSyεStatSOperTime. " = { SfpsSyεStatεEntry 6 }
εfpεSyεStatεDiεcardPktε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packetε that have been diεcarded, on thiε SFPS εwitch inεtance, during the time of εfpεSyεStatεOperTime. " = { SfpsSyεStatεEntry 7 }
sfpsSysStatsFilteredPkts OBJECT-TYPE
SYNTAX counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the total number of SFPS packets that have been filtered, on this SFPS switch instance, during the time of εfpεSyεStatεOperTime. " = { εfpεSysStatsEntry 8 }
sfpsSysStatsInOctets OBJECT-TYPE SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS octetε that have been received, on thiε SFPS εwitch inεtance, during the time of sfpsSysStatsOperTime."
: : = { sfpsSysStatεEntry 9 }
sfpsSyεStatsOutOctets OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS octetε that have been εwitched, on this SFPS switch instance, during the time of sfpεSyεStatεOperTime. "
- { εfpεSyεStatεEntry 10 }
εfpsSysStatεDiεcardOctetε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS octets that have been discarded, on this SFPS switch instance, during the time of sfpsSyεStatεOperTime. "
: : = { sfpεSysStatsEntry 11 }
sfpsSysStatεFilteredOctets OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the total number of SFPS octets that have been filtered, on this SFPS switch instance, during the time of εfpεSyεStatεOperTime. "
: : = { εfpεSyεStatεEntry 12 } SFPS Switching Port Group
This group contains the managed objects used to setup and configure the SFPS ports for packet switching and statisicε monitoring. Thiε group containε two sub-groups: configuration and statiεticε.
SFPS Port Configuration Tableε
Thiε table containε the managed objectε used to set-up and configure each SFPS εwitching port . A εeperate table exiεtε for inbound portε and outbound ports.
Inbound ports .
sfpsInPortConfigTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpsInPortConfigEntry
ACCESS not-accesεible STATUS mandatory DESCRIPTION "Thiε table containε the configuration information of each configured inbound SFPS εwitch port. If SFPS iε not configured on a port, then an entry will not exiεt." = { εfpεPortConfig l }
εfpεlnPortConfigEntry OBJECT-TYPE
SYNTAX SfpεlnPortConfigEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Each entry εpecifieε the SFPS configuration for the SFPS inbound switch port for which the entry existε."
INDEX sfpsInPortConfigPort }
: = { SfpεlnPortConfigTable 1 }
SfpεlnPortConfigEntry : : = SEQUENCE { εfpεlnPortConfigPort SfpsSwitchPort, εfpεinPortConfigAdminStatuε INTEGER,
SfpεlnPortConfigOperStatus INTEGER, εfpεlnPortConfigOperTime TimeTicks, εfpεInPortconfigType INTEGER, sfpsInPortConfigReservedBW INTEGER, sfpsInPortConfigAllocBW INTEGER, εfpεInPortConfigQoS INTEGER, εfpεlnPortConfigQSize Gauge, sfpsInPortConfigQLen INTEGER
} sfpsInPortConfigPort OBJECT-TYPE SYNTAX SfpsSwitchPort
ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. This identifieε the inbound SFPS switch port for which the entry exists." = { SfpεlnPortConfigEntry 1 }
sfpsInPortConfigAdminStatuε OBJECT-TYPE
SYNTAX INTEGER { other (1) diεabled(2) , enabled(3) , loopback(4)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS inbound εwitch port for which the entry exiεtε. " = { εfpεlnPortConfigEntry 2 }
sfpsInPortConfigOperStatus OBJECT-TYPE SYNTAX INTEGER { other(1) , none of the following disabled(2) , not running enabled(3) , running pending-diεable(4) ,— εhut-down in progreεε pending-enable(5) , — εtart-up in progreεε invalid-config(6) , — not running,invalid config teεting(7) — in loopback mode }
ACCESS read-only
STAIIUS mandatory
DESCRIPTION "Indicateε the current operating condition of the SFPS on the inbound εwitch port for which thiε entry exiεts." { sfpsInPortConfigEntry 3 }
SfpεlnPortConfigOperTime OBJECT-TYPE SYNTAX TimeTickε
ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the elapεed time, in hundredths of a second, that sfpεlnPortOperStatuε has been in its current operational state on the SFPS inbound switch port for which this entry exists. " = { SfpεlnPortConfigEntry 4 }
SfpεlnPortConfigType OBJECT-TYPE
SYNTAX INTEGER { other(1) , acceεε-port(2) , network-port(3) , hoεt-mgmt-port(4) hoεt-ctl-port(5)
}
ACCESS read-write
STATUS mandatory DESCRIPTION "Setε the type of port access attribute for the inbound SFPS port for which the entry exiεtε. Acceεε portε allow εingle uεer or shared access and perform statisticε and control; network portε are equivalent to trunk portε with no acceεε control; host management port indicates the (virtual) port to which the (internal) management agent is attached; host control port indicates the port to redirect nonmanagement packets. "
: : = { sfpsInPortConfigEntry 5 }
sfpsInPortConfigReservedBW OBJECT-TYPE
SYNTAX INTEGER
ACCESS read-write
STATUS mandatory
DESCRIPTION "Sets the amount of Bandwidth that is reserved for the inbound SFPS port for which this entry existε. Thiε bandwidth iε εet aεide for thiε port and may be given to another port if unused."
— ? should this be in Mbits/sec or as a percentage of total b/w.
— Currently defined as percentage of total b/w in εwitch.
: : = { εfpεlnPortConfigEntry 6 }
sfpsInPortConfigAllocBW OBJECT-TYPE SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Sets the amount of Bandwidth that iε allocated for the inbound SFPS port for which thiε entry exiεtε. Thiε bandwidth may be leεε than the reεerved bandwidth."
— ? εhould thiε be in Mbitε/εec or as a percentage of total b/w.
— Currently defined as percentage of total b/w in switch.
: : = { sfpεlnportConfigEntry 7 }
sfpsInPortConfigQoS OBJECT-TYPE SYNTAX INTEGER ACCESS read-write STATUS mandatory
DESCRIPTION "Sets the desired QoS service claεε for the inbound SFPS port for which thiε entry exiεtε. "
— ? εhould thiε map to the ATM εervice claεεes
: : = { SfpεlnPortConfigEntry 8 }
εfpεlnPortConfigQSize OBJECT-TYPE
SYNTAX Gauge
ACCESS read-only
STATUS mandatory
DESCRIPTION "Indicateε the maximum inbound queue εize for this port. Size is indicated in packets (packet descriptorε) . "
: : = { sfpsInPortConfigEntry 9 }
SfpsInPortConfigQLen OBJECT-TYPE SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the actual inbound queue size for this port. Size is indicated in packets (packet descriptorε) . Thiε is a transient value that reflects the current depth of queue. "
: : = { sfpεlnportConfigEntry 10 }
— Outbound Portε
εfpεOutPortConfigTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpεOutPortConfigEntry
ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Thiε table containε the configuration information of each configured outbound SFPS εwitch port. If SFPS iε not configured on a port, then an entry will not exiεt." = { sfpsPortConfig 2 }
sfpsOutPortConfigEntry OBJECT-TYPE
SYNTAX SfpεOutPortConfigEntry ACCESS not-acceεsible STATUS mandatory DESCRIPTION "Each entry specifieε the SFPS configuration for the SFPS outbound εwitch port for which the entry exiεtε."
INDEX { SfpsOutPortConfigPort }
: : = { SfpεOutPortConfigTable 1 }
SfpεOutPortConfigEntry : : = SEQUENCE { sfpsOutPortConfigPort SfpsSwitchPort, SfpεOutPortConfigAdminStatuε INTEGER, εfpεOutPortConfigOperStatuε INTEGER, εfpεOutPortConfigOperTime TimeTicks, sfpεOutPortConfigType INTEGER, εfpεoutPortConfigReεervedBW INTEGER, εfpεOutPortConfigAllocBW INTEGER, εfpεOutPortConfigQoS INTEGER, εfpεoutPortConfigQSize Gauge, εfpεOutPortConfigQLen INTEGER
sfpsOutPortConfigPort OBJECT-TYPE
SYNTAX SfpsSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. Thiε identifieε the outbound SFPS εwitch port for which the entry exiεtε." { εfpεOutPortConfigEntry 1 }
sfpsOutPortConfigAdminStatuε OBJECT-TYPE
SYNTAX INTEGER { other(1) , diεabled(2) , enabled(3) , loopback(4)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS outbound εwitch port for which the entry exiεtε. " = { sfpsOutPortConfigEntry 2 }
SfpεOutPortConfigOperStatuε OBJECT-TYPE SYNTAX INTEGER { other(1) , none of the following diεabled(2), not running enabled(3), running pending-disable(4) ,— shut-down in progreεs pending-enable(5) , — εtart-up in progreεs invalid-config(6) , — not running,invalid config testing(7) — in loopback mode
}
ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the current operating condition of the SFPS on the outbound εwitch port for which thiε entry exiεts." = { SfpεOutPortConfigEntry 3 }
εfpεOutPortConfigOperTime OBJECT-TYPE
SYNTAX TimeTickε ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the elapsed time, in hundredths of a second, that sfpεOutPortOperStatus has been in its current operational state on the SFPS outbound switch port for which this entry existε." = { SfpεOutPortConfigEntry 4 }
εfpεOutPortConfigType OBJECT-TYPE SYNTAX INTEGER { other(1) , acceεε-part(2) , network-port(3) , hoεt-mgmt-port(4) , host-ct1-port(5)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Sets the type of port access attribute for the outbound SFPS port for which the entry existε. Acceεε portε allow εingle uεer or shared access and perform statiεicε and control; network ports are equivalent to trunk portε with no acceεs control; host management port indicates the (virtual) port to which the (internal) management agent iε attached; hoεt control port indicateε the port to redirect non-management packets . " : = { sfpsOutPortConfigEntry 5 }
SfpεOutPortConfigReεervedBW OBJECT-TYPE
SYNTAX INTEGER ACCESS read-write STATUS mandatory DESCRIPTION "Setε the amount of Bandwidth that is reserved for the outbound SFPS port for which this entry exists. This bandwidth is set aside for this port and may be given to another port if unused."
— ? should this be in Mbits/sec or as a percentage of total b/w.
— currently defined aε percentage of total b/w in switch.
: : = { SfpεOutPortConfigEntry 6 }
εfpεOutPortConfigAllocBW OBJECT-TYPE
SYNTAX INTEGER
ACCESS read-only
STATUS mandatory
DESCRIPTION "Sets the amount of Bandwidth that is allocated for the outbound SFPS port for which this entry exists. This bandwidth may be less than the reserved bandwidth."
— ? should this be in Mbits/εec or as a percentage of total b/w.
— Currently defined as percentage of total b/w in switch. : - { sfpsOutPortConfigEntry 7 }
sfpsOutPortConfigQos OBJECT-TYPE
SYNTAX INTEGER ACCESS read-write STATUS mandatory DESCRIPTION "Sets the desired QoS εervice claεε for the outbound SFPS port for which thiε entry existε. "
— ? should this map to the ATM service clasεes : : = { SfpεOutPortConfigEntry 8 }
sfpεOutPortConfigQSize OBJECT-TYPE
SYNTAX Gauge ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the maximum outbound queue size for this port. Size is indicated in packets (packet descriptors)." { SfpεOutPortConfigEntry 9 }
εfpsOutPortConfigQLen OBJECT-TYPE
SYNTAX INTEGER ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the actual outbound queue size for this port. Size is indicated in packetε (packet deεcriptorε) . Thiε iε a tranεient value that reflects the current depth of queue. "
: : = { SfpεOutPortConfigEntry 10 }
— SFPS Switching Port Statisticε Tables
— This table contains the objectε that εpecify the packet
— and byte counters for each configured SFPS switching port — A separate table exiεtε for inbound and outbound portε
— Inbound portε .
sfpsInPortStatεTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpεlnPortStatεEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Thiε table contains the packet and byte counterε for each inbound SFPS switch port . "
= { sfpεPortStats 1 }
SfpεlnPortStatεEntry OBJECT-TYPE
SYNTAX SfpεlnPortStatεEntry ACCESS not-acceεsible STATUS mandatory DESCRIPTION "Specifies the SFPS packet and byte counters for the inbound SFPS switch port for which this entry exiεtε."
INDEX { εfpsInPortStatsPort }
= { εfpεlnPortStatεTable 1}
SfpεlnPortStatεEntry : : = SEQUENCE { sfpεlnPortStatεPort SfpsSwitchPort, sfpεlnPortStatεAdminStatuε INTEGER, εfpsinPortStatsReεet INTEGER, εtpεfnPortStatsOperTime TimeTicks, sfpεlnPortStatεPktε Counter, εfpεlnPortStatεDiεcardPktε Counter, sfpsInPortStatεBytes Counter, sfpsInPortStatεDiεcardByteε Counter, εfpεlnPortStatεQOverflowε Counter
} εfpεlnPortStatsPort OBJECT-TYPE SYNTAX SfpsSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS port table. This identifies the SFPS inbound switch port for which the entry exists."
: : = { sfpsInPortStatsEntry 1 }
εfpεlnPortStatsAdminStatus OBJECT-TYPE
SYNTAX INTEGER { other(1) , diεabled(2) , enabled(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS packet and byte counterε on the inbound SFPS εwitch port for which this entry existε. " = { εfpεlnPortStatεEntry 2 }
εfpsinPortStatsReεet OBJECT-TYPE
SYNTAX INTEGER { other(1) , reεet(2)
}
ACCESS read-write
STATUS mandatory DESCRIPTION "Reεetε the SFPS packet and byte counterε on the inbound SFPS switch port for which this entry existε."
: : - { εfpεlnPortStatεEntry 3 }
sfpsInPortStatsOperTime OBJECT-TYPE SYNTAX TimeTicks ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the amount of time (tt of time tickε) that the port-εpecific SFPS packet and byte counterε have been active on the inbound SFPS switch port for which this entry exiεtε. "
: : = { εfpεlnPortStatsEntry 4 }
sfpεlnPortStatεPktε OBJECT-TYPE SYNTAX Counter
ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the total number of SFPS packetε that have been received, during sfpεlnPortStatεOpertime, on the inbound SFPS εwitch port for which thiε entry exiεtε. " - { εfpεlnPortStatεEntry 5 }
εfpεlnPortStatεDiεcardPktε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packetε that have been diεcarded (dropped) , during sfpsInPortStatεOpertime, on the inbound
SFPS εwitch port for which thiε entry exiεtε. "
: = { εfpεlnPortStatεEntry 6 }
εfpεlnPortStatεBytes OBJECT-TYPE SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS bytes that have been received, during sfpεlnPortStatεOperTime, on the inbound SFPS εwitch port for which the entry exiεtε."
: : = { εfpsInPortStatsEntry 7 }
sfpsInPortStatsDiscardByteε OBJECT-TYPE
SYNTAX Counter
ACCESS read-only
STATUS mandatory
DESCRIPTION "Indicateε the total number of byteε in the SFPS packetε that have been diεcarded (dropped), during εfpεlnPortStatεOperTime, on the inbound SFPS εwitch port for which the entry exiεtε."
: : = { εfpεlnPortStatεEntry 8 }
εfpεlnPortStatεQOverflowε OBJECT-TYPE
SYNTAX Counter
ACCESS read-only
STATUS mandatory
DESCRIPTION "Indicateε the total number of queue overflow conditionε have been experienced for the inbound SFPS εwitch port for which the entry exiεtε."
: : = { εfpεlnPortStatεEntry 9 }
— Outbound portε.
εfpεOutPortStatsTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpsOutPortStatεEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "This table contains the packet and byte counters for each outbound SFPS switch port."
: : = { sfpsPόrtStatε 2 }
sfpsOutPortStatsEntry OBJECT-TYPE
SYNTAX SfpsOutPortStatεEntry ACCESS not-accessible STATUS mandatory DESCRIPTION "Specifies the SFPS packet and byte counterε for the outbound SFPS εwitch port for which thiε entry exiεtε . "
INDEX { εfpεOutPortStatεPort }
: : = { εfpεOutPortStatεTable 1 }
SfpεOutPortStatsEntry : : = SEQUENCE { sfpεOutPortStatεPort εfpεSwitchPort, εfpεOutPortStatεAdminStatuε INTEGER, εfpεOutPortStatεReεet INTEGER, εfpεOutPortStatεOperTime TimeTickε, εfpsOutPortStatsPktε Counter, sfpsoutPortStatεDiscardPkts Counter, sfpsOutPortStatεByteε Counte , sfpaOutPortStatsDiεcardByteε Counter, εfpsoutPortStatsQOverflowε Counter }
εfpεOutPortStatεPort OBJECT-TYPE
SYNTAX SfpεSwitchPort ACCESS read-only STATUS mandatory DESCRIPTION "The primary index to the SFPS port table,
Thiε identifies the SFPS outbound switch port for which the entry existε."
: : = { SfpsOutPortStatεEntry 1 } εfpεOutPortStatεAd inStatuε OBJECT-TYPE
SYNTAX INTEGER { other(1) , diεabled (2) , enabled(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS packet and byte counterε on the outbound
SFPS εwitch port for which this entry existε. "
= { εfpεOutPortStatεEntry 2 }
εfpεOutPortStatεReεet OBJECT TYPE
SYNTAX INTEGER { other(l), reεet(2)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Reεetε the SFPS packet and byte counterε on the outbound SFPS εwitch port for which thiε entry exiεtε." = { εfpεOutPortStatsEntry 3 }
sfpεOutPortStatεOperTime OBJECT-TYPE SYNTAX TimeTickε
ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the amount of time (# of time ticks) that the port-specific SFPS packet and byte counters have been active on the outbound SFPS switch port for which this entry existε. " = { εfpεOutPortStatεEntry 4 } εfpεOutPortStatεPktε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packetε that have been received, during εfpεOutPortStatεOpertime, on the outbound SFPS εwitch port for which thiε entry exiεtε. " = { εfpεOutPortStatεEntry 5 }
εfpsOutPortStatsDiεcardPktε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS packets that have been diεcarded (dropped), during εfpεOutPortStatsOpertime, on the outbound SFPS switch port for which this entry exiεts. " = { sfpεOutPortStatεEntry 6 }
sfpsOutPortStatεByteε OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of SFPS byteε that have been received, during sfpsOutPortStatsOperTime, on the outbound
SFPS switch port for which the entry exiεtε . "
: = { εfpεOutPortStatεEntry 7 }
εfpεOutPortStatεDiεcardBytes OBJECT-TYPE SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of bytes in the SFPS packetε that have been diεcarded (dropped), during sfpsOutPortStatsOperTime, on the outbound SFPS switch port for which the entry existε." = { εfpεOutPortStatεEntry 8 }
εfpεOutPortStatεQOverflows OBJECT-TYPE
SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicateε the total number of queue overflow conditionε have been experienced for the outbound SFPS εwitch port for which the entry exists." : : = { sfpεOutPortStatεEntry 9 }
— SFPS Switching Connection Group
— Thiε group containε the managed objectε for maintaining
— SFPS connectionε.
— SFPS connection Table
— Thiε table containε the SFPS-εpecific connection table
— managed objectε. Note that becauεe thiε table iε indexed
— by the SfpεSwitchPort index which will map to a
— chaεεiε.module.portεubgroup.portgroup.port location, thiε
— table will εhow connectionε at the chaεsis, module,
— portgoupε, and port levelε.
εfpεConnectionTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpεConnectionEntry ACCESS not-acceεεible
STATUS mandatory DESCRIPTION "This table containε the connection information for all active connectionε on the SFPS acceεε ports."
: : = { sfpεSwitchConnectionε 1 }
sfpsConnectionEntry OBJECT-TYPE
SYNTAX SfpεConnectionEntry ACCESS not-acceεεible STATUS mandatory DESCRIPTION "Each entry εpecifies the connection information for the SFPS switch access port for which the entry existε." INDEX { sfpεCnxInPort, εfpsCnxSource, εfpεCnxDeεtination } : : = { εfpεConnectionTable 1 }
SfpεConnectionEntry : : = SEQUENCE { εfpεCnxInPort SfpsSwitchPort, εfpεCnxSource SfpsAddreεε, εfpεCnxDeεtination SfpεAddreεs, εfpεCnxRowStatuε INTEGER, εfpεCnxAdminStatuε INTEGER, εfpεCnxOutPort SfpsSwitchPort, εfpεcnxAge TimeTicks, εfpεCnxType INTEGER, εfpεCnxReεervedBW INTEGER, εfpεCnxAllocBW INTEGER, εfpεCnxCurrentBW INTEGER, , εfpεCnxQoS INTEGER, εfpeCnxPktε Counter, εfpεCnxByteε Counter
} εfpεCnxInPort OBJECT-TYPE SYNTAX SfpεSwitchPort ACCESS read-write STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. This identifies the inbound SFPS switch port for which the entry existε."
= { εfpεConnectionEntry 1 }
εfpεCnxSource OBJECT-TYPE SYNTAX SfpεAddreεε ACCESS read-write STATUS mandatory DESCRIPTION "The εource SFPS addreεε for thiε source/destination connection = { εfpεConnectionEntry 2 }
εfpεCnxDeεtination OBJECT-TYPE
SYNTAX SfpsAddresε ACCESS read-write STATUS mandatory DESCRIPTION "The destination SFPS addresε for thiε source/destination connection." = { εfpεConnectionEntry 3 }
sfpsCnxRowStatuε OBJECT-TYPE SYNTAX INTEGER { other(1) , activate(2) , delete(3) , under-creation(4)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Controlε the creation, modification, and deletion of connection entrieε." { SfpεConnectionEntry 4 }
sfpsCnxAdminStatuε OBJECT-TYPE
SYNTAX INTEGER { othe (1) , diεabled(2) , enabled(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the SFPS connection. " = { εfpεConnectionEntry 5 }
εfpεCnxOutPort OBJECT-TYPE SYNTAX SfpεSwitchPort ACCESS read-write STATUS mandatory DESCRIPTION "The primary index to the SFPS out port table. Thiε identifieε the outbound SFPS εwitch port for which the entry exists. All switched traffic for this connection will be transmitted on thiε outbound port."
•= { εfpsConnectionEntry 6 }
sfpsCnxAge OBJECT-TYPE SYNTAX TimeTicks ACCESS read-only STATUS mandatory
DESCRIPTION "Indicateε the age of the connection." : : = { εfpsConnectionEntry 7 } sfpsCnxType OBJECT-TYPE SYNTAX INTEGER { other(1) , proviεioned(2) , switched(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Sets the type of connection. Provisioned connectionε are εet up by the external agent; switched connections are εet up dynamically. " { εfpsConnectionEntry 8 }
sfpεCnxReεervedBW OBJECT-TYPE SYNTAX INTEGER
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the amount of Bandwidth that iε reεerved for thiε connection."
— ? Should thiε be in Mbitε/εec or as a percentage of total b/w.
— Currently defined as percentage of total b/w in switch.
: : = { sfpsConnectionEntry 9 }
εfpεCnxAllocBW OBJECT-TYPE SYNTAX INTEGER ACCESS read-write STATUS mandatory DESCRIPTION "Setε the amount of Bandwidth that is allocated for this connection."
— ? should this be in Mbitε/εec or aε a percentage of total b/w. — Currently defined aε percentage of total b/w in εwitch.
: : = { sfpsConnectionEntry 10 }
sfpsCnxCurrentBW OBJECT-TYPE SYNTAX INTEGER ACCESS read-write STATUS mandatory
DESCRIPTION "Indicateε the amount of Bandwidth that iε currently being uεed for thiε connection."
— ? εhould thiε be in mbitε/εec or aε a percentage of total b/w.
— Currently defined aε percentage of total b/w in εwitch.
: : = { εfpεConnectionEntry 11 }
SfpεCnxQoS OBJECT-TYPE SYNTAX INTEGER ACCESS read-write STATUS mandatory
DESCRIPTION "Setε the deεired QoS εervice claεε for thiε connection."
— Should thiε map to the ATM εervice classeε
: : = { εfpεConnectionEntry 12 }
εfpεCnxPkts OBJECT-TYPE SYNTAX Counter ACCESS read-only STATUS mandatory DESCRIPTION "Indicates the total number of packets sent on thiε connection." : : = { εfpεConnectionEntry 13 }
εfpεCnxByteε OBJECT-TYPE
SYNTAX Counter
ACCESS read-only
STATUS mandatory DESCRIPTION "Indicateε the total number of byteε εent on thiε connection." : : = { εfpεConnectionEntry 14 }
SFPS Connection OutPort Table
Thiε table containε the liεt of outbound portε for a connection entry. Note that a uni traffic flow can go out multiple outbound portε, which may be uεeful for virtual LANε or multicaεt groupε .
sfpsConnectionOutPortTable OBJECT-TYPE
SYNTAX SEQUENCE OF SfpsConnectionOutPortEntry ACCESS not-accesεible STATUS mandatory DESCRIPTION "Thiε table containε the control of the outbound port for the active connection for which thiε entry exiεtε."
= { εfpεSwitchConnectionε 2 }
SfpsConnectionOutPortEntry OBJECT-TYPE
SYNTAX SfpsConnectionOutPortEntry ACCESS not-accessible STATUS mandatory DESCRIPTION "Each entry specifies the use of the port specified by the inεtance of thiε entry. " INDEX εfpεCnxOutPortlnPort, εfpεCnxOutPortSource, { εfpsCnxOutPortDestination, εfpεCnxOutPortID
} : : = { sfpsConnectionOutPortTable 1 }
SfpsConnectionOutPortEntry : : = SEQUENCE { εfpεCnxOutPortInPort SfpεSwitchPort, εfpεCnxOutPortSource SfpεAddreεs, εfpεCnxOutPortDeεtination SfpsAddreεs, εfpεCnxOutPortID SfpsSwitchPort, εfpεCnxOutPortRowStatuε INTEGER, εfpεCnxOutPortAdminStatuε INTEGER
sfpaCnxOutPortInPort OBJECT-TYPE
SYNTAX SfpsSwitchPort ACCESS read-write STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. This identifies the inbound SFPS switch port for which the entry existε."
: : = { εfpsConnectionOutPortEntry 1 }
sfpsCnxOutPortSource OBJECT-TYPE
SYNTAX SfpsAddresε ACCESS read-write STATUS mandatory DESCRIPTION "The εource SFPS addreεε for thiε εource/deεtination connection." = { εfpsConnectionOutPortEntry 2 }
εfpεCnxOutPortDeεtination OBJECT-TYPE
SYNTAX SfpεAddreεε ACCESS read-write STATUS mandatory DESCRIPTION "The deεtination SFPS addreεε for this source/destination connection." = { SfpsConnectionOutPortEntry 3 }
sfpεCnxOutPortID OBJECT-TYPE
SYNTAX SfpsSwitchPort ACCESS read-write STATUS mandatory DESCRIPTION "The primary index to the SFPS in port table. This identifies the outbound SFPS switch port for which the entry existε." : : = { εfpεConnectionOutPortEntry 4 }
sfpsCnxOutPortRowStatus OBJECT-TYPE
SYNTAX INTEGER { other(l) , activate(2) , delete(3), under-creation(4)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Controlε the creation, modification, and deletion of connection entrieε." = { εfpεConnectionOutPortEntry 5 }
εfpεCnxOutPortAdminStatuε OBJECT-TYPE
SYNTAX INTEGER { other(l) , diεabled(2) , enabled(3)
}
ACCESS read-write STATUS mandatory DESCRIPTION "Setε the adminiεtrative εtate of the outbound port. This allows the outbound port to be logically enabled and diεabled without table addition/deletion." = { εfpεConnectionOutPortEntry 6 }
sfpsSCSAddresε OBJECT-TYPE SYNTAX IpAddreεε ACCESS read-write STATUS mandatory DESCRIPTION "Defineε the IP Addreεε of the controlling SCS Server which controlε thiε SFPS agent.'
= { sfpsConfig 1 } sfpsSCSDomain OBJECT-TYPE SYNTAX IpAddress ACCESS read-write STATUS mandatory
DESCRIPTION "Defineε the IP Addreεε of the controlling SCS Server which controls this SFPS agent." : : = { sfpεConfig 1 }
12. Related Applicationε
The subject matter of the present application may be advantageously combined with the εubject matterε of the following copending and commonly owned applicationε filed on the εame date, and which are hereby incorporated by reference in their entirety:
• U.S. Serial No. 08/187,856 entitled Diεtributed Chaεεiε Agent For Network Management, filed January 28, 1994 by Brendan fee et al.;
• U.S. Serial No. 08/188,033 entitled Fault Tolerant System Management Bus Architecture", filed January 28, 1994 by Brendan Fee et al.
While there have been shown and described several embodiments of the present invention, it will be obvious to those skilled in the art that various changes and modifications may be made therein without departing from the scope of the invention as defined by the appending claims.

Claims

1. A method of controlling εwitcheε and tranεmitting data packets in a packet switched data communications network, the network including a plurality of end εyεtemε and switches connected by links, the εwitcheε having acceεε portε connected to end εyεtemε and network ports connected to other switcheε, and each end system having a unique physical layer address, the method comprising the stepε of: prior to tranεmiεεion of a data packet compriεing a connectionleεε datagram from a firεt end εyεtem to a εecond end εyεtem, determining a path from the firεt end εyεtem to the εecond end εyεtem through a plurality of εwitcheε and baεed on the phyεical layer addreεεeε of the firεt and εecond end εyεtemε, and configuring the plurality of switches on the path to enable transmiεεion of the data packet, wherein the data packet remainε aε a connectionless datagram.
2. The method of claim 1, wherein the configuring step compriseε providing each switch in the path with a connection identifier for the data packet, the connection identifier including an input port of the respective switch, a physical εource addreεs of the first end syεtem, and a physical destination addresε of the εecond end system, and mapping the connection identifier to an output port of the respective switch.
3. The method of claim 2, wherein each switch haε a connection table and the programming εtep includes entering the connection identifier in the connection table at each respective switch on the path.
4. The method of claim 3, further including the step of deleting the connection identifier from the connection table after a predetermined time.
5. The method of claim 3, wherein multiple data packets having the same connection identifier are transmitted through the network by accesεing the connection tableε in the switches on the path, without redetermining the path.
6. The method of claim 1, wherein the determining step includes determining multiple paths for transmiεεion of a data packet from a first end syεtem to a plurality of εecond end εyεtemε, and configuring each of the εwitcheε on the multiple pathε .
7. The method of claim 1, wherein the determining εtep includeε address learning by pairing a source address within an incoming data packet with the port on which the packet arrives at the respective switch, and registering the pairs in a central directory which maintains such pairs for all of the εwitcheε in the network.
8. The method of claim l, wherein the determining step iε initiated when the data packet enterε a firεt switch adjacent to the first end syεtem, and the data packet is stored during the determining and configuring stepε.
9. The method of claim 1, wherein the determining step includes, when a first switch receives a broadcast data packet, looking inside the broadcast data packet for higher layer protocol information to determine the phyεical layer addreεε of the εecond end system for which the data packet is intended.
10. The method of claim l, wherein the determining step includes, when a first switch receives a data packet having an unknown destination addresε, looking inεide the data packet for higher layer protocol information to determine the εecond end εyεtem for which the data packet iε intended. - I l l -
11. The method of claim 10, further including the firεt switch sending a reply back to the first end syεtem with the phyεical addreεε of the εecond end εyεtem.
12. The method of claim 1, wherein the determining εtep includeε εending a connection set-up request to a connection service for determining the path and configuring the switches,
13. The method of claim 1, wherein multiple data packets are transmitted from the first end syεtem to the εecond end εyεtem on the same path without redetermining the path.
14. The method of claim 1, wherein the configuring step includeε configuring the εwitcheε for tranεmiεεion out multiple portε simultaneouεly.
15. The method of claim 1, wherein the εwitch tranεmitε data packetε received from different firεt end εystems but intended for one second end syεtem, out different portε.
16. In a packet switched data communications network, the network including a plurality of end syεtemε and εwitcheε connected by linkε, the εwitcheε having access ports connected to end systems and network ports connected to other switcheε, and each end εystem having a unique physical layer addresε, the εwitch including a connection database of valid connectionε between different portε on the εwitch and a εwitching mechaniεm for establishing temporary connections between different ports on the switch, characterized by a central connection server coupled to each switch, means for registering each switch with the εerver, and means, prior to transmiεsion of a data packet comprising a connectionless datagram from a firεt end εyεtem to a εecond end εyεtem, for determining a path of valid connectionε from the firεt end εystem to the εecond end system through one or more switches and configuring the connection table of each switch on the path with a connection identifier identified by the phyεical layer addreεεeε for the firεt and εecond end εyεtemε, wherein the data packet remainε aε a connectionleεε datagram.
17. The network of claim 16, wherein the connection identifier includeε an input port of the reεpective switch, a physical source addreεs of the first end system, and a physical destination addresε of the εecond end εyεtem, and which connection identifier iε mapped to an output port of the reεpective switch.
18. The network of claim 16, further including means for deleting the connection identifier from the connection table after a predetermined time.
19. The network of claim 16, wherein each εwitch includeε meanε for addreεε learning by pairing a εource addreεε within an incoming data packet with the port on which the packet arriveε at the reεpetive εwitch, and the meanε for regiεtering includes a central directory which maintains such pairs for all of the switcheε in the network.
20. The network of claim 16, wherein each switch includes means for storing the data packet while the path is determined and the switches are configured.
21. The network of claim 16, wherein the means for determining include means for looking inside a data packet which does not contain the physical layer addresε of the second end syεtem, for higher layer protocol information to determine the second end system for which the data packet is intended.
22. The network of claim 21, further including means for sending a reply to the first end syεtem with the physical layer address of the second end syεtem.
23. The network of claim 16, wherein each εwitch includeε meanε for sending a connection setup request to the central connection εerver.
24. The network of claim 16, wherein the central connection εerver iε external to the εwitcheε.
25. The network of claim 16, wherein the means for determining the connection identifier is exclusive to the central connection server.
26. The network of claim 16, wherein the determining means includes: means for authorizing valid connections between firεt and εecond end systemε.
27. The network of claim 26, wherein the authorizing meanε includes: a directory databaεe of valid connectionε between firεt and εecond end εyεtemε; means for acceεεing the directory databaεe to determine if there is a valid connection.
28. The network of claim 16, wherein the determining means includes: means for determining a best path for the valid connection through the switches of the network.
29. The network of claim 28, wherein: the means for determining the best path utilizes a number of constraints including one or more of: bandwidth; cost; QOS;and a maximum number of connections.
30. The network of claim 16, wherein the determining meanε includeε: meanε for determining a valid connection which varieε with time or the application of different conεtraintε.
31. The network of claim 16, further including meanε for allocating a εpecified bandwidth to a connection.
32. The network of claim 16, including a management information baεe for controlling the εwitch operation and configuration.
33. The network of claim 16, wherein the determining meanε iε part of a network management εyεtem which provideε at leaεt one of the following εerviceε: a) determination of a beεt path between firεt and εecond end εystems;
b) designation of valid connections between first and second end εyεtemε;
c) determination of the location of end εystems;
d) accounting of each end syεtem'ε uεage of the network baεed on the number of data packet tranεmissions or bytes;
e) designation of a specified bandwidth for connections between designated end εyεtems.
34. The network of claim 16, wherein the phyεical layer address is a MAC address.
35. The network of claim 16, wherein the configuring means includeε: means for setting up the temporary connection; meanε for forwarding the data packet tranεmiεεion; and meanε for terminating the temporary connection.
36. In a method of breadth-first searching to build a spanning tree, wherein a plurality of traversalε are made of different pathε moving outwardly from a starting point in a search to find a best path to a deεtination point based on a plurality of metrics, the improvement comprising: at the end of each traversal, comparing the values of the metrics and eliminating the paths which are not best or do not paεε a threεhold level in at leaεt one metric.
37. The method of claim 36, wherein the comparing εtep compriεeε eliminating a path which is not better in at least one metric.
38. The method of claim 36, wherein the comparing step compriεeε eliminating a path which iε not better or equal in at leaεt one metric.
39. The method of claim 36, wherein the comparing step compriseε eliminating a path which iε not better or equal in at leaεt one metric or which doeε not paεε a threshold level.
40. The method of claim 36, wherein all of the values and paths for a given traversal are stored and procesεed together.
41. In a method for routing data packetε through a mesh of nodes and arcs, the improvement comprising: a) selecting a plurality of (n + 1) metrics and designating a plurality of posεible values for each metric from best to worεt; b) selecting a minimum acceptable value for each metric;
c) asεuming an initial εet of valueε for the metricε;
d) εtarting at a εource node, determining a plurality of poεεible pathε by diεcovering all immediate neighboring nodeε and determining a traversal εet of metric valueε for each path;
e) repeating εtep d) for each diεcovered node and continuing until a destination node is reached; and
f) eliminating certain traversal setε of valueε during the repeating εtep e) in accordance with the following ruleε:
1) if a path diεcoverε a node already within the path, terminating the path;
2) if a path diεcoverε that its traversal value vector is not best in any of
(n + 1) metricε, terminating the path;
3) if a path has no metric which is better than one of the already completed pathε, terminating the path;
4) if a path diεcoverε a defective arc or node, terminating the path;
5) if a path haε a metric value which doeε not satisfy a threshold level, terminating the path; and
6) if a path discoverε an end node which is not the destination node, terminating the path.
42. A method of allocating a bandwidth-limited, shared resource among a plurality of competing devices, comprising the steps of: dividing an available time of the reεource into a plurality of time εegmentε; allocating one or more of the time εegments among the competing devices in a predetermined order to provide a first level of arbitration; providing a list of competing devices; allocating a token entitling one of the competing deviceε in the liεt of competing deviceε to a time εegment; allocating a time εegment to the competing device having the token if the time εegment iε unallocated after the firεt level of arbitration to provide a second level of arbitration; and allocating the time segment to the device having a predetermined rank in the list of competing devices if the time segment iε unallocated after the εecond level of arbitration to provide a third level of arbitration.
43. A εyεtem for allocating a bandwidth-limited, εhared resource among a plurality of competing devices, compriεing: meanε for dividing an available time of the reεource into a plurality of time εegmentε; meanε for allocating the time εegmentε among the competing deviceε in a predetermined order to provide a firεt level of arbitration; meanε for providing a liεt of competing deviceε; means for allocating a token entitling one of the competing devices in the list of competing devices to a time εegment; meanε for allocating a time segment to the competing device having the token if the time segment is unallocated after the first level of arbitration to provide a second level of arbitration; and meanε for allocating the time εegment to the device having a predetermined rank in the list of competing deviceε if the time segment is unallocated after the second level of arbitration to provide a third level of arbitration.
PCT/US1995/001026 1994-01-28 1995-01-26 Network having secure fast packet switching and guaranteed quality of service WO1995020850A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
DE69522666T DE69522666T2 (en) 1994-01-28 1995-01-26 NETWORK WITH SECURE, FAST PACKAGE BROKERAGE AND GUARANTEED SERVICE QUALITY
AT95908127T ATE205652T1 (en) 1994-01-28 1995-01-26 NETWORK WITH SECURE, FAST PARCEL DELIVERY AND GUARANTEED QUALITY OF SERVICE
JP7520158A JPH09508509A (en) 1994-01-28 1995-01-26 Network with secure high-speed packet switching function and guaranteed quality of service
AU16078/95A AU678687B2 (en) 1994-01-28 1995-01-26 Network having secure fast packet switching and guaranteed quality of service
EP95908127A EP0741937B1 (en) 1994-01-28 1995-01-26 Network having secure fast packet switching and guaranteed quality of service

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/188,238 US5485455A (en) 1994-01-28 1994-01-28 Network having secure fast packet switching and guaranteed quality of service
US08/188,238 1994-01-28

Publications (1)

Publication Number Publication Date
WO1995020850A1 true WO1995020850A1 (en) 1995-08-03

Family

ID=22692312

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1995/001026 WO1995020850A1 (en) 1994-01-28 1995-01-26 Network having secure fast packet switching and guaranteed quality of service

Country Status (7)

Country Link
US (4) US5485455A (en)
EP (3) EP0746176A3 (en)
JP (1) JPH09508509A (en)
AT (1) ATE205652T1 (en)
AU (3) AU678687B2 (en)
DE (1) DE69522666T2 (en)
WO (1) WO1995020850A1 (en)

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997024841A2 (en) * 1995-12-29 1997-07-10 Cisco Systems, Inc. Datagram transmission over virtual circuits
WO1998037727A2 (en) * 1997-02-18 1998-08-27 Virata Limited Proxy-controlled atm subnetwork
US5802042A (en) * 1996-06-28 1998-09-01 Cisco Systems, Inc. Autosensing LMI protocols in frame relay networks
US6147996A (en) * 1995-08-04 2000-11-14 Cisco Technology, Inc. Pipelined multiple issue packet switch
US6360109B1 (en) * 1997-04-30 2002-03-19 U.S. Philips Corporation Terminal, automatic recall procedure, and telecommunication system
JP2003508955A (en) * 1999-08-31 2003-03-04 サイエンス アプリケーションズ インターナショナル コーポレイション System and method for interconnecting multiple virtual private networks
US6771642B1 (en) 1999-01-08 2004-08-03 Cisco Technology, Inc. Method and apparatus for scheduling packets in a packet switch
US6909697B1 (en) 1997-12-22 2005-06-21 Cisco Technology, Inc. Method and apparatus for identifying a maximum frame size
US6993048B1 (en) 2000-07-31 2006-01-31 Cisco Technology, Inc. ATM permanent virtual circuit and layer 3 auto-configuration for digital subscriber line customer premises equipment
US7095741B1 (en) 2000-12-20 2006-08-22 Cisco Technology, Inc. Port isolation for restricting traffic flow on layer 2 switches
US7123620B1 (en) 2000-04-25 2006-10-17 Cisco Technology, Inc. Apparatus and method for scalable and dynamic traffic engineering in a data communication network
US7319668B2 (en) 2001-08-31 2008-01-15 Fujitsu Limited Network system capable of selecting optimal route according to type of transmitted data
US7710959B2 (en) 2006-08-29 2010-05-04 Cisco Technology, Inc. Private VLAN edge across multiple switch modules

Families Citing this family (730)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6604118B2 (en) 1998-07-31 2003-08-05 Network Appliance, Inc. File system image transfer
US5835726A (en) * 1993-12-15 1998-11-10 Check Point Software Technologies Ltd. System for securing the flow of and selectively modifying packets in a computer network
WO1997000471A2 (en) * 1993-12-15 1997-01-03 Check Point Software Technologies Ltd. A system for securing the flow of and selectively modifying packets in a computer network
KR100218624B1 (en) * 1993-12-24 1999-09-01 포만 제프리 엘 Routing bandwidth-reserved connections in information networks
US5509123A (en) * 1994-03-22 1996-04-16 Cabletron Systems, Inc. Distributed autonomous object architectures for network layer routing
US6185619B1 (en) 1996-12-09 2001-02-06 Genuity Inc. Method and apparatus for balancing the process load on network servers according to network and serve based policies
FR2718868B1 (en) * 1994-04-18 1996-05-31 Bull Sa Method for detecting deadlocks in multiprocessor systems with shared memory.
US6510465B1 (en) 1994-04-19 2003-01-21 Ibm Dual communication services interface for distributed transaction processing
US6633561B2 (en) 1994-05-05 2003-10-14 Sprint Communications Company, L.P. Method, system and apparatus for telecommunications control
US6023474A (en) 1996-11-22 2000-02-08 Sprint Communications C.O.L.P. Broadband telecommunications system interface
US5920562A (en) 1996-11-22 1999-07-06 Sprint Communications Co. L.P. Systems and methods for providing enhanced services for telecommunication call
US5926482A (en) * 1994-05-05 1999-07-20 Sprint Communications Co. L.P. Telecommunications apparatus, system, and method with an enhanced signal transfer point
US6430195B1 (en) 1994-05-05 2002-08-06 Sprint Communications Company L.P. Broadband telecommunications system interface
US5991301A (en) * 1994-05-05 1999-11-23 Sprint Communications Co. L.P. Broadband telecommunications system
US6314103B1 (en) 1994-05-05 2001-11-06 Sprint Communications Company, L.P. System and method for allocating bandwidth for a call
US6181703B1 (en) 1995-09-08 2001-01-30 Sprint Communications Company L. P. System for managing telecommunications
US6031840A (en) * 1995-12-07 2000-02-29 Sprint Communications Co. L.P. Telecommunications system
US6631133B1 (en) * 1994-05-05 2003-10-07 Sprint Communications Company L.P. Broadband telecommunications system
HU220989B1 (en) 1994-05-05 2002-07-29 Sprint Communications Company, LP Method and telecommunications system for processing telecommunication calls
US6172977B1 (en) 1994-05-05 2001-01-09 Sprint Communications Company, L. P. ATM direct access line system
JP3326292B2 (en) * 1994-05-24 2002-09-17 株式会社東芝 Communication device and communication method thereof
JP3521955B2 (en) * 1994-06-14 2004-04-26 株式会社日立製作所 Hierarchical network management system
SE503022C2 (en) * 1994-06-15 1996-03-11 Ericsson Telefon Ab L M Distributed connection control in telecommunications networks
TW252248B (en) * 1994-08-23 1995-07-21 Ibm A semiconductor memory based server for providing multimedia information on demand over wide area networks
US5680552A (en) * 1994-09-20 1997-10-21 Lucent Technologies Inc. Gateway system for interconnecting different data communication networks
US5590201A (en) * 1994-11-10 1996-12-31 Advanced Micro Devices Inc. Programmable source address locking mechanism for secure networks
JPH08223195A (en) * 1994-11-22 1996-08-30 At & T Corp Local area hub network allowing expansion of port number andmethod of expanding its port number
US5867666A (en) 1994-12-29 1999-02-02 Cisco Systems, Inc. Virtual interfaces with dynamic binding
US5627819A (en) * 1995-01-09 1997-05-06 Cabletron Systems, Inc. Use of multipoint connection services to establish call-tapping points in a switched network
JP2682494B2 (en) * 1995-02-24 1997-11-26 日本電気株式会社 Multi-access communication system
US5832503A (en) * 1995-02-24 1998-11-03 Cabletron Systems, Inc. Method and apparatus for configuration management in communications networks
US5586268A (en) * 1995-03-03 1996-12-17 Advanced System Products, Inc. Multiple peripheral adapter device driver architecture
US6083270A (en) 1995-03-24 2000-07-04 The Board Of Trustees Of The Leland Stanford Junior University Devices and methods for interfacing human users with electronic devices
US5678006A (en) * 1995-04-27 1997-10-14 Cisco Systems, Inc. Network switch having network management agent functions distributed among multiple trunk and service modules
US5674003A (en) * 1995-04-28 1997-10-07 Andersen; David B. Mechanisms for accessing unique features of telephony networks from a protocol-Independent data transport interface
US5802278A (en) * 1995-05-10 1998-09-01 3Com Corporation Bridge/router architecture for high performance scalable networking
US5592622A (en) * 1995-05-10 1997-01-07 3Com Corporation Network intermediate system with message passing architecture
JP2770782B2 (en) * 1995-05-31 1998-07-02 日本電気株式会社 LAN connection device
US5627971A (en) * 1995-06-01 1997-05-06 Northern Telecom Limited Machine method for determining the eligibility of links in a network
US5680303A (en) * 1995-06-07 1997-10-21 Compuserve Incorporated Communication device sharing on a local area network
US5710703A (en) * 1995-06-07 1998-01-20 Chrysler Corporation Method and system for sharing a hardware resource
US6393486B1 (en) 1995-06-23 2002-05-21 Cisco Technology, Inc. System and method using level three protocol information for network centric problem analysis and topology construction of actual or planned routed network
US6883034B1 (en) 1995-06-23 2005-04-19 Cisco Technology, Inc. Method of resolving conflicts in access control lists in router by comparing elements in the lists based on subsumption relations
US5710908A (en) * 1995-06-27 1998-01-20 Canon Kabushiki Kaisha Adaptive network protocol independent interface
US5796944A (en) * 1995-07-12 1998-08-18 3Com Corporation Apparatus and method for processing data frames in an internetworking device
US5734656A (en) * 1995-07-12 1998-03-31 Bay Networks, Inc. Method and apparatus for dynamically allocating bandwidth on a TDM bus
US7468977B1 (en) 1995-07-12 2008-12-23 Nortel Networks Limited LAN/ATM switch having local packet switching and an ATM core fabric
JPH11510004A (en) 1995-07-19 1999-08-31 フジツウ ネットワーク コミュニケーションズ,インコーポレイテッド Point-to-multipoint transmission using subqueues
EP0839420A4 (en) * 1995-07-19 2001-07-18 Fujitsu Network Communications Allocated and dynamic bandwidth management
US5996020A (en) * 1995-07-21 1999-11-30 National Security Agency Multiple level minimum logic network
US6097718A (en) 1996-01-02 2000-08-01 Cisco Technology, Inc. Snapshot routing with route aging
WO1997010656A1 (en) 1995-09-14 1997-03-20 Fujitsu Network Communications, Inc. Transmitter controlled flow control for buffer allocation in wide area atm networks
US5742588A (en) * 1995-09-18 1998-04-21 Telefonaktiebolaget Lm Ericsson Packet switched traffic management in a cellular telecommunications system
US5712907A (en) * 1995-09-18 1998-01-27 Open Port Technology, Inc. Pro-active message delivery system and method
US5805593A (en) * 1995-09-26 1998-09-08 At&T Corp Routing method for setting up a service between an origination node and a destination node in a connection-communications network
US6182224B1 (en) 1995-09-29 2001-01-30 Cisco Systems, Inc. Enhanced network services using a subnetwork of communicating processors
SE507482C2 (en) * 1995-10-09 1998-06-15 Ericsson Telefon Ab L M Redundancy communication management system and procedure
JP3169541B2 (en) * 1995-11-07 2001-05-28 富士通株式会社 Automatic path setting device for synchronous communication system
US5684800A (en) * 1995-11-15 1997-11-04 Cabletron Systems, Inc. Method for establishing restricted broadcast groups in a switched network
EP0873626B1 (en) * 1995-11-15 2006-05-10 Enterasys Networks, Inc. Distributed connection-oriented services for switched communications networks
CA2186795A1 (en) * 1995-11-17 1997-05-18 Cormac John Sreenan Resource management system for a broadband multipoint bridge
US5832069A (en) * 1995-11-17 1998-11-03 Sprint Communications Co L.P. Object oriented system for modeling telecommunications circuits to estimate the access cost for leasing selected circuits
US5734642A (en) * 1995-12-22 1998-03-31 Cabletron Systems, Inc. Method and apparatus for network synchronization
US6035105A (en) 1996-01-02 2000-03-07 Cisco Technology, Inc. Multiple VLAN architecture system
US5765153A (en) * 1996-01-03 1998-06-09 International Business Machines Corporation Information handling system, method, and article of manufacture including object system authorization and registration
US5764756A (en) * 1996-01-11 1998-06-09 U S West, Inc. Networked telephony central offices
US6233623B1 (en) 1996-01-11 2001-05-15 Cabletron Systems, Inc. Replicated resource management system for managing resources in a distributed application and maintaining a relativistic view of state
US5799016A (en) * 1996-01-11 1998-08-25 U S West, Inc. Network addressing scheme encoding communication channel information
AU1697697A (en) 1996-01-16 1997-08-11 Fujitsu Limited A reliable and flexible multicast mechanism for atm networks
AU2257097A (en) * 1996-02-02 1997-08-22 Sprint Communications Company, L.P. Atm gateway system
US5870550A (en) * 1996-02-26 1999-02-09 Network Engineering Software Web server employing multi-homed, moldular framework
US5826014A (en) * 1996-02-06 1998-10-20 Network Engineering Software Firewall system for protecting network elements connected to a public network
US5898830A (en) 1996-10-17 1999-04-27 Network Engineering Software Firewall providing enhanced network security and user transparency
US5781624A (en) * 1996-02-16 1998-07-14 Lucent Technologies Inc. Method for sharing network resources by virtual partitioning
US6237029B1 (en) 1996-02-26 2001-05-22 Argosystems, Inc. Method and apparatus for adaptable digital protocol processing
US8117298B1 (en) 1996-02-26 2012-02-14 Graphon Corporation Multi-homed web server
US5978364A (en) * 1996-02-29 1999-11-02 Philips Electronics North America Corporation Method for routing data packets within a wireless, packet-hopping network and a wireless network for implementing the same
US6108304A (en) * 1996-03-08 2000-08-22 Abe; Hajime Packet switching network, packet switching equipment, and network management equipment
US5612897A (en) * 1996-03-21 1997-03-18 Digital Equipment Corporation Symmetrically switched multimedia system
US5652751A (en) * 1996-03-26 1997-07-29 Hazeltine Corporation Architecture for mobile radio networks with dynamically changing topology using virtual subnets
US5740171A (en) * 1996-03-28 1998-04-14 Cisco Systems, Inc. Address translation mechanism for a high-performance network switch
US5805569A (en) * 1996-04-30 1998-09-08 Telefonaktiebolaget Lm Ericsson Packet data communications system having a malfunction list
US5917825A (en) * 1996-05-07 1999-06-29 Rad Network Devices, Ltd. LAN message routing system
JP3697317B2 (en) 1996-05-28 2005-09-21 株式会社東芝 Communication device
US6308148B1 (en) * 1996-05-28 2001-10-23 Cisco Technology, Inc. Network flow data export
US6243667B1 (en) * 1996-05-28 2001-06-05 Cisco Systems, Inc. Network flow switching and flow data export
US5940393A (en) 1996-05-28 1999-08-17 Sprint Communications Co. L.P. Telecommunications system with a connection processing system
US5878225A (en) * 1996-06-03 1999-03-02 International Business Machines Corporation Dual communication services interface for distributed transaction processing
US6151324A (en) * 1996-06-03 2000-11-21 Cabletron Systems, Inc. Aggregation of mac data flows through pre-established path between ingress and egress switch to reduce number of number connections
JPH09331332A (en) * 1996-06-10 1997-12-22 Fujitsu Ltd Negotiation method for connection identifier
US6400687B1 (en) * 1996-06-13 2002-06-04 British Telecommunications Public Limited Company ATM network management
US5850396A (en) * 1996-06-24 1998-12-15 Gateway 2000, Inc. Multicast message distribution in a polynomial expansion manner
US6212182B1 (en) 1996-06-27 2001-04-03 Cisco Technology, Inc. Combined unicast and multicast scheduling
US6434120B1 (en) 1998-08-25 2002-08-13 Cisco Technology, Inc. Autosensing LMI protocols in frame relay networks
US5777986A (en) * 1996-08-16 1998-07-07 Motorola, Inc. Method and apparatus for controlling quality of service in an ATM network
US5748905A (en) 1996-08-30 1998-05-05 Fujitsu Network Communications, Inc. Frame classification using classification keys
US6046999A (en) 1996-09-03 2000-04-04 Hitachi, Ltd. Router apparatus using ATM switch
US5822758A (en) * 1996-09-09 1998-10-13 International Business Machines Corporation Method and system for high performance dynamic and user programmable cache arbitration
US6031842A (en) 1996-09-11 2000-02-29 Mcdata Corporation Low latency shared memory switch architecture
JP2956608B2 (en) * 1996-09-17 1999-10-04 日本電気株式会社 ATM transmission equipment
US6510151B1 (en) 1996-09-19 2003-01-21 Enterasys Networks, Inc. Packet filtering in connection-based switching networks
US6275861B1 (en) * 1996-09-27 2001-08-14 Pmc-Sierra, Inc. Method and apparatus to identify flows in data systems
US6101170A (en) 1996-09-27 2000-08-08 Cabletron Systems, Inc. Secure fast packet switch having improved memory utilization
BR9711589A (en) 1996-10-04 1999-08-24 Fisher Controls Int Maintenance interface device for use in a process control system
US5970430A (en) * 1996-10-04 1999-10-19 Fisher Controls International, Inc. Local device and process diagnostics in a process control network having distributed control functions
US6044305A (en) * 1996-10-04 2000-03-28 Fisher Controls International, Inc. Method and apparatus for debugging and tuning a process control network having distributed control functions
US6047222A (en) * 1996-10-04 2000-04-04 Fisher Controls International, Inc. Process control network with redundant field devices and buses
DE69710201T3 (en) 1996-10-04 2007-07-05 Fisher Controls International Llc (N.D.Ges.D.Staates Delaware) NETWORK ACCESS INTERFACE FOR PROCESS CONTROL NETWORK
USRE39501E1 (en) * 1996-10-31 2007-03-06 Nvidia Corporation Multiple network protocol encoder/decoder and data processor
US6034963A (en) * 1996-10-31 2000-03-07 Iready Corporation Multiple network protocol encoder/decoder and data processor
US6016307A (en) 1996-10-31 2000-01-18 Connect One, Inc. Multi-protocol telecommunications routing optimization
US6157647A (en) * 1996-11-06 2000-12-05 3Com Corporation Direct addressing between VLAN subnets
US6401109B1 (en) 1996-11-18 2002-06-04 International Business Machines Corp. Virtual socket for JAVA interprocess communication
US6335927B1 (en) * 1996-11-18 2002-01-01 Mci Communications Corporation System and method for providing requested quality of service in a hybrid network
US6044080A (en) * 1996-11-19 2000-03-28 Pluris, Inc. Scalable parallel packet router
US6307853B1 (en) * 1996-11-21 2001-10-23 Net2Phone, Inc. Re-routing telephony communications traffic through a private branch exchange to a data network
US6002689A (en) 1996-11-22 1999-12-14 Sprint Communications Co. L.P. System and method for interfacing a local communication device
US6647393B1 (en) * 1996-11-22 2003-11-11 Mangosoft Corporation Dynamic directory service
NZ335503A (en) 1996-11-22 2000-05-26 Sprint Comm Company Lp Detecting a call trigger in a telecommunications network without requiring a service platform to remain connected to the call
US20060129627A1 (en) * 1996-11-22 2006-06-15 Mangosoft Corp. Internet-based shared file service with native PC client access and semantics and distributed version control
US6014378A (en) 1996-11-22 2000-01-11 Sprint Communications Company, L.P. Telecommunications tandem system for circuit-based traffic
US6115380A (en) 1996-11-22 2000-09-05 Sprint Communications Co., L.P. Broadband telecommunications system
US7058696B1 (en) 1996-11-22 2006-06-06 Mangosoft Corporation Internet-based shared file service with native PC client access and semantics
US6667982B2 (en) * 1996-11-22 2003-12-23 Sprint Communications Company, L.P. Broadband telecommunications system interface
US5893081A (en) * 1996-11-25 1999-04-06 Etak, Inc. Using multiple levels of costs for a pathfinding computation
US5916299A (en) * 1996-11-25 1999-06-29 Etak, Inc. Method for determining exits and entrances for a region in a network
JP2001500338A (en) 1996-12-06 2001-01-09 フジツウ ネットワーク コミュニケーションズ,インコーポレイテッド Method for controlling flow of ATM traffic
US5898668A (en) * 1996-12-13 1999-04-27 Siemens Information And Communication Networks, Inc. Method and system for increasing quality of service at or below a threshold cost
US5905725A (en) * 1996-12-16 1999-05-18 Juniper Networks High speed switching device
US5909440A (en) * 1996-12-16 1999-06-01 Juniper Networks High speed variable length best match look-up in a switching device
US6493347B2 (en) * 1996-12-16 2002-12-10 Juniper Networks, Inc. Memory organization in a switching device
US6304546B1 (en) 1996-12-19 2001-10-16 Cisco Technology, Inc. End-to-end bidirectional keep-alive using virtual circuits
EP0851706A1 (en) * 1996-12-24 1998-07-01 International Business Machines Corporation Flow control for very bursty connections in high speed cell switching networks
US6098109A (en) * 1996-12-30 2000-08-01 Compaq Computer Corporation Programmable arbitration system for determining priority of the ports of a network switch
US6282195B1 (en) * 1997-01-09 2001-08-28 Silicon Graphics, Inc. Packetized data transmissions in a switched router architecture
FR2758426B1 (en) * 1997-01-16 2001-10-05 Alcatel Data Networks Inc DATA FRAME SWITCH
US5940376A (en) * 1997-01-29 1999-08-17 Cabletron Systems, Inc. Method and apparatus to establish a tap-point in a switched network using self-configuring switches having distributed configuration capabilities
US6084858A (en) * 1997-01-29 2000-07-04 Cabletron Systems, Inc. Distribution of communication load over multiple paths based upon link utilization
US5889776A (en) * 1997-01-31 1999-03-30 Alpnet Corporation Physical layer switch system for ethernet local area network communication system
US5933427A (en) * 1997-01-31 1999-08-03 Edgepoint Networks, Inc. Switch system employing a N:M switch circuit for routing packets among devices in a data communication network
US5991305A (en) * 1997-02-14 1999-11-23 Advanced Micro Devices, Inc. Integrated multiport switch having independently resettable management information base (MIB)
US5978730A (en) * 1997-02-20 1999-11-02 Sony Corporation Caching for pathfinding computation
US5999541A (en) * 1997-02-28 1999-12-07 3Com Corporation Transmission of token-ring packets over ethernet by tunneling
IL131553A0 (en) * 1997-03-06 2001-01-28 Software And Systems Engineeri System and method for gaining access to information in a distributed computer system
US6006267A (en) * 1997-03-06 1999-12-21 International Business Machines Corp. Method and system for connecting network hosts having different communication protocols
US6229808B1 (en) * 1997-03-07 2001-05-08 Advanced Micro Devices, Inc. Method of communication for a computer using packet switches for internal data transfer
JP3579208B2 (en) * 1997-03-11 2004-10-20 株式会社東芝 Node device and message exchange method
US5889774A (en) * 1997-03-14 1999-03-30 Efusion, Inc. Method and apparatus for selecting an internet/PSTN changeover server for a packet based phone call
US6035340A (en) * 1997-03-19 2000-03-07 Nortel Networks Corporation Method and apparatus for providing a multiple-ring token ring hub expansion
US6532491B1 (en) 1997-03-24 2003-03-11 Novell, Inc. Processes and apparatuses for managing network devices
US6757286B1 (en) * 1997-03-24 2004-06-29 Alcatel Self-configuring communication network
US5848404A (en) * 1997-03-24 1998-12-08 International Business Machines Corporation Fast query search in large dimension database
US5948065A (en) * 1997-03-28 1999-09-07 International Business Machines Corporation System for managing processor resources in a multisystem environment in order to provide smooth real-time data streams while enabling other types of applications to be processed concurrently
US6654780B1 (en) 1997-03-28 2003-11-25 International Business Machines Corporation System of managing processor resources in a non-dedicated computer system
US5925102A (en) * 1997-03-28 1999-07-20 International Business Machines Corporation Managing processor resources in a multisystem environment in order to provide smooth real-time data streams, while enabling other types of applications to be processed concurrently
US6282560B1 (en) 1997-03-28 2001-08-28 International Business Machines Corporation Managing processor resources in a non-dedicated computer system
US5949753A (en) * 1997-04-11 1999-09-07 International Business Machines Corporation Redundant internet protocol gateways using local area network emulation
DE19715396A1 (en) * 1997-04-14 1998-10-15 Philips Patentverwaltung Transmission system with several network elements
US6067299A (en) 1997-04-16 2000-05-23 Sprint Communications Company, L.P. Communications system for providing ATM connections and echo cancellation
JP3865454B2 (en) * 1997-04-17 2007-01-10 富士通株式会社 Communication device
US5949784A (en) * 1997-05-01 1999-09-07 3Com Corporation Forwarding mechanism for multi-destination packets to minimize per packet scheduling overhead in a network forwarding engine
US7039008B1 (en) * 1997-05-02 2006-05-02 Cisco Technology, Inc. Method and apparatus for maintaining connection state between a connection manager and a failover device
US6144992A (en) * 1997-05-09 2000-11-07 Altiris, Inc. Method and system for client/server and peer-to-peer disk imaging
US6137800A (en) 1997-05-09 2000-10-24 Sprint Communications Company, L. P. System and method for connecting a call
US6704327B1 (en) 1997-05-09 2004-03-09 Sprint Communications Company, L.P. System and method for connecting a call
US6208616B1 (en) * 1997-05-13 2001-03-27 3Com Corporation System for detecting errors in a network
US6314525B1 (en) 1997-05-13 2001-11-06 3Com Corporation Means for allowing two or more network interface controller cards to appear as one card to an operating system
US6178170B1 (en) 1997-05-13 2001-01-23 Sprint Communications Company, L. P. System and method for transporting a call
US5805803A (en) * 1997-05-13 1998-09-08 Digital Equipment Corporation Secure web tunnel
US6134678A (en) * 1997-05-13 2000-10-17 3Com Corporation Method of detecting network errors
US6105151A (en) * 1997-05-13 2000-08-15 3Com Corporation System for detecting network errors
NO304570B1 (en) * 1997-05-20 1999-01-11 Ericsson Telefon Ab L M Procedure related to GPRS (General Packet Radio Service) system with packet switched connections
US6122272A (en) 1997-05-23 2000-09-19 Cisco Technology, Inc. Call size feedback on PNNI operation
US6356530B1 (en) 1997-05-23 2002-03-12 Cisco Technology, Inc. Next hop selection in ATM networks
US6011780A (en) * 1997-05-23 2000-01-04 Stevens Institute Of Technology Transparant non-disruptable ATM network
US6041042A (en) * 1997-05-27 2000-03-21 Cabletron Systems, Inc. Remote port mirroring system and method thereof
US5982753A (en) * 1997-06-09 1999-11-09 Fluke Corporation Method of testing a switched local area network
US6134589A (en) * 1997-06-16 2000-10-17 Telefonaktiebolaget Lm Ericsson Dynamic quality control network routing
US5974460A (en) * 1997-06-16 1999-10-26 International Business Machines Corporation Apparatus and method for selecting an optimum telecommunications link
US6862284B1 (en) 1997-06-17 2005-03-01 Cisco Technology, Inc. Format for automatic generation of unique ATM addresses used for PNNI
US5963448A (en) * 1997-06-18 1999-10-05 Allen-Bradley Company, Llc Industrial controller having redundancy and using connected messaging and connection identifiers to enable rapid switchover without requiring new connections to be opened or closed at switchover
US5966534A (en) * 1997-06-27 1999-10-12 Cooke; Laurence H. Method for compiling high level programming languages into an integrated processor with reconfigurable logic
US6016310A (en) * 1997-06-30 2000-01-18 Sun Microsystems, Inc. Trunking support in a high performance network device
US5938736A (en) * 1997-06-30 1999-08-17 Sun Microsystems, Inc. Search engine architecture for a high performance multi-layer switch element
US6049528A (en) * 1997-06-30 2000-04-11 Sun Microsystems, Inc. Trunking ethernet-compatible networks
US6088356A (en) * 1997-06-30 2000-07-11 Sun Microsystems, Inc. System and method for a multi-layer network element
US5909686A (en) * 1997-06-30 1999-06-01 Sun Microsystems, Inc. Hardware-assisted central processing unit access to a forwarding database
US6128666A (en) * 1997-06-30 2000-10-03 Sun Microsystems, Inc. Distributed VLAN mechanism for packet field replacement in a multi-layered switched network element using a control field/signal for indicating modification of a packet with a database search engine
US6081512A (en) * 1997-06-30 2000-06-27 Sun Microsystems, Inc. Spanning tree support in a high performance network device
US6119196A (en) * 1997-06-30 2000-09-12 Sun Microsystems, Inc. System having multiple arbitrating levels for arbitrating access to a shared memory by network ports operating at different data rates
US6081522A (en) * 1997-06-30 2000-06-27 Sun Microsystems, Inc. System and method for a multi-layer network element
US6014380A (en) * 1997-06-30 2000-01-11 Sun Microsystems, Inc. Mechanism for packet field replacement in a multi-layer distributed network element
US6044087A (en) * 1997-06-30 2000-03-28 Sun Microsystems, Inc. Interface for a highly integrated ethernet network element
US5920566A (en) * 1997-06-30 1999-07-06 Sun Microsystems, Inc. Routing in a multi-layer distributed network element
US6044418A (en) * 1997-06-30 2000-03-28 Sun Microsystems, Inc. Method and apparatus for dynamically resizing queues utilizing programmable partition pointers
US6151327A (en) * 1997-06-30 2000-11-21 Mci Communications Corporation Method of routing and bundling demands with low utilization in a telecommunications network
US6246680B1 (en) 1997-06-30 2001-06-12 Sun Microsystems, Inc. Highly integrated multi-layer switch element architecture
US6094435A (en) * 1997-06-30 2000-07-25 Sun Microsystems, Inc. System and method for a quality of service in a multi-layer network element
US6052738A (en) * 1997-06-30 2000-04-18 Sun Microsystems, Inc. Method and apparatus in a packet routing switch for controlling access at different data rates to a shared memory
US6118760A (en) * 1997-06-30 2000-09-12 Sun Microsystems, Inc. Management of entries in a network element forwarding memory
US6081524A (en) 1997-07-03 2000-06-27 At&T Corp. Frame relay switched data service
US6181698B1 (en) 1997-07-09 2001-01-30 Yoichi Hariguchi Network routing table using content addressable memory
GB2327317B (en) 1997-07-11 2002-02-13 Ericsson Telefon Ab L M Access control and resourse reservation in a communications network
US6078590A (en) 1997-07-14 2000-06-20 Cisco Technology, Inc. Hierarchical routing knowledge for multicast packet routing
US6304912B1 (en) * 1997-07-24 2001-10-16 Fujitsu Limited Process and apparatus for speeding-up layer-2 and layer-3 routing, and for determining layer-2 reachability, through a plurality of subnetworks
AU8576798A (en) * 1997-07-25 1999-02-16 Starvox, Inc. Apparatus and method for integrated voice gateway
US6330599B1 (en) 1997-08-05 2001-12-11 Cisco Technology, Inc. Virtual interfaces with dynamic binding
US6512766B2 (en) * 1997-08-22 2003-01-28 Cisco Systems, Inc. Enhanced internet packet routing lookup
US6212183B1 (en) 1997-08-22 2001-04-03 Cisco Technology, Inc. Multiple parallel packet routing lookup
US6157641A (en) 1997-08-22 2000-12-05 Cisco Technology, Inc. Multiprotocol packet recognition and switching
US6751196B1 (en) * 1997-08-27 2004-06-15 Philips Electronics North America Corp. Apparatus and method for peer-to-peer link monitoring of a wireless network with centralized control
US6192046B1 (en) * 1997-08-28 2001-02-20 Ascend Communications, Inc. Apparatus and method for efficiently transferring ATM cells across a backplane in a network switch
US5974467A (en) * 1997-08-29 1999-10-26 Extreme Networks Protocol for communicating data between packet forwarding devices via an intermediate network interconnect device
US6052724A (en) * 1997-09-02 2000-04-18 Novell Inc Method and system for managing a directory service
US6006206A (en) 1997-09-08 1999-12-21 Reuters Limited Data health monitor for financial information communications networks
US6308207B1 (en) * 1997-09-09 2001-10-23 Ncr Corporation Distributed service subsystem architecture for distributed network management
US6205149B1 (en) * 1997-09-11 2001-03-20 3Com Corporation Quality of service control mechanism and apparatus
US6366876B1 (en) * 1997-09-29 2002-04-02 Sun Microsystems, Inc. Method and apparatus for assessing compatibility between platforms and applications
US6343072B1 (en) 1997-10-01 2002-01-29 Cisco Technology, Inc. Single-chip architecture for shared-memory router
US6014612A (en) * 1997-10-02 2000-01-11 Fisher Controls International, Inc. Remote diagnostics in a process control network having distributed control functions
CA2217315A1 (en) * 1997-10-03 1999-04-03 Newbridge Networks Corporation Service management of multiple independent forwarding realms
US6134581A (en) * 1997-10-06 2000-10-17 Sun Microsystems, Inc. Method and system for remotely browsing objects
SE512176C2 (en) * 1997-10-06 2000-02-07 Ericsson Telefon Ab L M Method and apparatus of telecommunication systems
US6023471A (en) * 1997-10-07 2000-02-08 Extreme Networks Network interconnect device and protocol for communicating data among packet forwarding devices
US6389453B1 (en) * 1997-10-09 2002-05-14 Mci Communications Corporation Method and system for routing undirectional multicast data
US7185266B2 (en) * 2003-02-12 2007-02-27 Alacritech, Inc. Network interface device for error detection using partial CRCS of variable length message portions
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
US6226680B1 (en) 1997-10-14 2001-05-01 Alacritech, Inc. Intelligent network interface system method for protocol processing
US6434620B1 (en) * 1998-08-27 2002-08-13 Alacritech, Inc. TCP/IP offload network interface device
US8782199B2 (en) * 1997-10-14 2014-07-15 A-Tech Llc Parsing a packet header
US6697868B2 (en) * 2000-02-28 2004-02-24 Alacritech, Inc. Protocol processing stack for use with intelligent network interface device
US8621101B1 (en) 2000-09-29 2013-12-31 Alacritech, Inc. Intelligent network storage interface device
US7167927B2 (en) * 1997-10-14 2007-01-23 Alacritech, Inc. TCP/IP offload device with fast-path TCP ACK generating and transmitting mechanism
US8539112B2 (en) 1997-10-14 2013-09-17 Alacritech, Inc. TCP/IP offload device
US6456624B1 (en) * 1997-10-29 2002-09-24 Enterasys Networks, Inc. Network address resolve blocker
US6343289B1 (en) * 1997-10-31 2002-01-29 Nortel Networks Limited Efficient search and organization of a forwarding database or the like
US6088665A (en) * 1997-11-03 2000-07-11 Fisher Controls International, Inc. Schematic generator for use in a process control network having distributed control functions
US6308216B1 (en) * 1997-11-14 2001-10-23 International Business Machines Corporation Service request routing using quality-of-service data and network resource information
US6081530A (en) * 1997-11-24 2000-06-27 Nokia High Speed Access Products Inc. Transmission of ATM cells
US6081589A (en) * 1997-12-01 2000-06-27 Nortel Networks Corporation Method and apparatus for identifying and handling on-line access calls within a switch
US7570583B2 (en) * 1997-12-05 2009-08-04 Cisco Technology, Inc. Extending SONET/SDH automatic protection switching
WO1999030450A1 (en) 1997-12-08 1999-06-17 Packeteer, Inc. Method for data rate control for heterogenous or peer internetworking
US6002670A (en) * 1997-12-12 1999-12-14 Nortel Networks Corporation Optimization and recovery techniques in IMA networks
US6154449A (en) * 1997-12-23 2000-11-28 Northern Telecom Limited Switchless network
US6597684B1 (en) * 1997-12-24 2003-07-22 Nortel Networks Ltd. Distributed architecture and associated protocols for efficient quality of service-based route computation
US6111877A (en) 1997-12-31 2000-08-29 Cisco Technology, Inc. Load sharing across flows
JP3692757B2 (en) * 1998-01-09 2005-09-07 富士ゼロックス株式会社 Image forming apparatus and control method thereof
US6628616B2 (en) 1998-01-30 2003-09-30 Alcatel Frame relay network featuring frame relay nodes with controlled oversubscribed bandwidth trunks
US6512772B1 (en) * 1998-02-12 2003-01-28 Hitachi, Ltd. ATM-address resolving transmission apparatus
US6016485A (en) * 1998-02-13 2000-01-18 Etak, Inc. System for pathfinding
US6483837B1 (en) 1998-02-20 2002-11-19 Sprint Communications Company L.P. System and method for connecting a call with an interworking system
US6563918B1 (en) 1998-02-20 2003-05-13 Sprint Communications Company, LP Telecommunications system architecture for connecting a call
US6470019B1 (en) 1998-02-20 2002-10-22 Sprint Communications Company L.P. System and method for treating a call for call processing
US6457130B2 (en) 1998-03-03 2002-09-24 Network Appliance, Inc. File access control in a multi-protocol file server
US6317844B1 (en) 1998-03-10 2001-11-13 Network Appliance, Inc. File server storage arrangement
US5999517A (en) * 1998-03-13 1999-12-07 3Com Corporation Summarization of routing information in a hierarchical network
US6212165B1 (en) * 1998-03-24 2001-04-03 3Com Corporation Apparatus for and method of allocating a shared resource among multiple ports
US6853638B2 (en) * 1998-04-01 2005-02-08 Cisco Technology, Inc. Route/service processor scalability via flow-based distribution of traffic
US20090059818A1 (en) * 1998-04-03 2009-03-05 Pickett Scott K Systems and methods for providing configurable caller id iformation
US6389009B1 (en) * 2000-12-28 2002-05-14 Vertical Networks, Inc. Systems and methods for multiple mode voice and data communications using intelligently bridged TDM and packet buses
US7072330B2 (en) * 1998-04-03 2006-07-04 Consolidated Ip Holdings, Inc. Systems for voice and data communications having TDM and packet buses and telephony station cards including voltage generators
US6181694B1 (en) 1998-04-03 2001-01-30 Vertical Networks, Inc. Systems and methods for multiple mode voice and data communciations using intelligently bridged TDM and packet buses
US6498791B2 (en) * 1998-04-03 2002-12-24 Vertical Networks, Inc. Systems and methods for multiple mode voice and data communications using intelligently bridged TDM and packet buses and methods for performing telephony and data functions using the same
US6160871A (en) 1998-04-10 2000-12-12 Sprint Communications Company, L.P. Communications test system
US6356564B1 (en) * 1998-04-22 2002-03-12 Alcatel Canada Inc. Use of booking factors to redefine available bandwidth
US6157955A (en) 1998-06-15 2000-12-05 Intel Corporation Packet processing system including a policy engine having a classification unit
US6370121B1 (en) 1998-06-29 2002-04-09 Cisco Technology, Inc. Method and system for shortcut trunking of LAN bridges
US6304349B1 (en) * 1998-06-30 2001-10-16 Lucent Technologies Inc. WDM optical communications networks and methods for provisioning
US6745243B2 (en) * 1998-06-30 2004-06-01 Nortel Networks Limited Method and apparatus for network caching and load balancing
US6377577B1 (en) 1998-06-30 2002-04-23 Cisco Technology, Inc. Access control list processing in hardware
DE19829821C2 (en) * 1998-07-03 2001-08-02 Siemens Ag Method for setting up a route via a communication network
US6182147B1 (en) 1998-07-31 2001-01-30 Cisco Technology, Inc. Multicast group routing using unidirectional links
US6308219B1 (en) 1998-07-31 2001-10-23 Cisco Technology, Inc. Routing table lookup implemented using M-trie having nodes duplicated in multiple memory banks
US6389506B1 (en) 1998-08-07 2002-05-14 Cisco Technology, Inc. Block mask ternary cam
US6101115A (en) 1998-08-07 2000-08-08 Cisco Technology, Inc. CAM match line precharge
US6496519B1 (en) 1998-08-27 2002-12-17 Nortel Networks Limited Frame based data transmission over synchronous digital hierarchy network
US6256322B1 (en) 1998-10-02 2001-07-03 Canon Kabushiki Kaisha Bundling multiple network management packets
US6397345B1 (en) * 1998-10-09 2002-05-28 Openwave Systems Inc. Fault tolerant bus for clustered system
US6412079B1 (en) * 1998-10-09 2002-06-25 Openwave Systems Inc. Server pool for clustered system
DE19848359A1 (en) * 1998-10-21 2000-04-27 Bosch Gmbh Robert Computer network has proxy agent for regulating connection setup and connection clearing between terminals and configuration and monitoring of interface
CA2349010A1 (en) 1998-10-27 2000-05-04 Fujitsu Network Communications, Inc. Event based rate policing with a jumping window
US6349306B1 (en) * 1998-10-30 2002-02-19 Aprisma Management Technologies, Inc. Method and apparatus for configuration management in communications networks
US6304913B1 (en) 1998-11-09 2001-10-16 Telefonaktiebolaget L M Ericsson (Publ) Internet system and method for selecting a closest server from a plurality of alternative servers
US6714517B1 (en) 1998-11-10 2004-03-30 Extreme Networks Method and apparatus for interconnection of packet switches with guaranteed bandwidth
US6654374B1 (en) 1998-11-10 2003-11-25 Extreme Networks Method and apparatus to reduce Jitter in packet switched networks
US6970424B2 (en) 1998-11-10 2005-11-29 Extreme Networks Method and apparatus to minimize congestion in a packet switched network
US6470410B1 (en) * 1998-11-23 2002-10-22 Advanced Micro Devices, Inc. Target side concentrator mechanism for connecting multiple logical pipes to a single function utilizing a computer interconnection bus
US6611891B1 (en) 1998-11-23 2003-08-26 Advanced Micro Devices, Inc. Computer resource configuration mechanism across a multi-pipe communication link
US6457084B1 (en) * 1998-11-23 2002-09-24 Advanced Micro Devices, Inc. Target side distributor mechanism for connecting multiple functions to a single logical pipe of a computer interconnection bus
US6618782B1 (en) 1998-11-23 2003-09-09 Advanced Micro Devices, Inc. Computer interconnection bus link layer
US6499079B1 (en) 1998-11-23 2002-12-24 Advanced Micro Devices, Inc. Subordinate bridge structure for a point-to-point computer interconnection bus
US6457081B1 (en) 1998-11-23 2002-09-24 Advanced Micro Devices, Inc. Packet protocol for reading an indeterminate number of data bytes across a computer interconnection bus
US6343984B1 (en) 1998-11-30 2002-02-05 Network Appliance, Inc. Laminar flow duct cooling system
US6212195B1 (en) * 1998-12-01 2001-04-03 3Com Corporation Telecommunication apparatus and method for forwarding packets using separate collision domains
US6108702A (en) 1998-12-02 2000-08-22 Micromuse, Inc. Method and apparatus for determining accurate topology features of a network
JP3996288B2 (en) * 1998-12-07 2007-10-24 株式会社日立製作所 Communication network system management method and information relay apparatus
US6324185B1 (en) 1998-12-08 2001-11-27 Cisco Technology, Inc. Method and apparatus for switching and managing bandwidth in an ATM/TDM network cross-connection
DE19858059A1 (en) * 1998-12-16 2000-06-21 Bosch Gmbh Robert Network of multiple devices and method for operating a network of multiple devices
US6917617B2 (en) * 1998-12-16 2005-07-12 Cisco Technology, Inc. Use of precedence bits for quality of service
US6643260B1 (en) 1998-12-18 2003-11-04 Cisco Technology, Inc. Method and apparatus for implementing a quality of service policy in a data communications network
US6714217B2 (en) 1998-12-18 2004-03-30 Sprint Communication Company, L.P. System and method for providing a graphical user interface to, for building, and/or for monitoring a telecommunication network
US20020188720A1 (en) * 1998-12-28 2002-12-12 William F. Terrell Method and apparatus for dynamically controlling the provision of differentiated services
US6351784B1 (en) 1998-12-28 2002-02-26 International Business Machines Corp. System for determining whether a subsequent transaction may be allowed or must be allowed or must not be allowed to bypass a preceding transaction
US6347349B1 (en) * 1998-12-28 2002-02-12 International Business Machines Corp. System for determining whether a subsequent transaction may be allowed or must be allowed or must not be allowed to bypass a preceding transaction
US6532235B1 (en) * 1998-12-29 2003-03-11 Qwest Communication Int'l., Inc. Method and tool for calculating impact of voice traffic on fast packet networks
US6549538B1 (en) 1998-12-31 2003-04-15 Compaq Information Technologies Group, L.P. Computer method and apparatus for managing network ports cluster-wide using a lookaside list
US6665304B2 (en) * 1998-12-31 2003-12-16 Hewlett-Packard Development Company, L.P. Method and apparatus for providing an integrated cluster alias address
US6671273B1 (en) * 1998-12-31 2003-12-30 Compaq Information Technologies Group L.P. Method for using outgoing TCP/IP sequence number fields to provide a desired cluster node
US6483812B1 (en) * 1999-01-06 2002-11-19 International Business Machines Corporation Token ring network topology discovery and display
US7079530B1 (en) * 1999-02-25 2006-07-18 Sprint Communications Company L.P. System and method for caching toll free number information
US6853623B2 (en) 1999-03-05 2005-02-08 Cisco Technology, Inc. Remote monitoring of switch network
US6590869B1 (en) 1999-03-11 2003-07-08 Siemens Information & Communication Networks, Inc. Method and apparatus for selecting whether to place a call over the internet or the PSTN using a two tiered process
US6510351B1 (en) 1999-03-15 2003-01-21 Fisher-Rosemount Systems, Inc. Modifier function blocks in a process control system
US6757791B1 (en) 1999-03-30 2004-06-29 Cisco Technology, Inc. Method and apparatus for reordering packet data units in storage queues for reading and writing memory
US6760331B1 (en) 1999-03-31 2004-07-06 Cisco Technology, Inc. Multicast routing with nearest queue first allocation and dynamic and static vector quantization
US6603772B1 (en) 1999-03-31 2003-08-05 Cisco Technology, Inc. Multicast routing with multicast virtual output queues and shortest queue first allocation
US6795860B1 (en) * 1999-04-05 2004-09-21 Cisco Technology, Inc. System and method for selecting a service with dynamically changing information
US7103068B1 (en) * 1999-05-04 2006-09-05 Sprint Communication Company L.P. System and method for configuring bandwidth transmission rates for call connections
US6636509B1 (en) * 1999-05-11 2003-10-21 Cisco Technology, Inc. Hardware TOS remapping based on source autonomous system identifier
US6754214B1 (en) 1999-07-19 2004-06-22 Dunti, Llc Communication network having packetized security codes and a system for detecting security breach locations within the network
US6788701B1 (en) 1999-05-14 2004-09-07 Dunti Llc Communication network having modular switches that enhance data throughput
US7778259B1 (en) 1999-05-14 2010-08-17 Dunti Llc Network packet transmission mechanism
US6654346B1 (en) 1999-07-19 2003-11-25 Dunti Corporation Communication network across which packets of data are transmitted according to a priority scheme
US6643286B1 (en) 1999-05-14 2003-11-04 Dunti Corporation Modular switches interconnected across a communication network to achieve minimal address mapping or translation between termination devices
US6587462B2 (en) 2001-02-16 2003-07-01 Dunti Corporation Address mapping mechanism enabling multi-domain addressing in communication networks
US7970929B1 (en) 2002-03-19 2011-06-28 Dunti Llc Apparatus, system, and method for routing data to and from a host that is moved from one location on a communication system to another location on the communication system
US6895088B1 (en) * 1999-05-21 2005-05-17 Sprint Communications Company L.P. System and method for controlling a call processing system
AUPQ070599A0 (en) * 1999-06-02 1999-06-24 Canon Kabushiki Kaisha Reconfigurable vliw processor
US6591301B1 (en) * 1999-06-07 2003-07-08 Nortel Networks Limited Methods and systems for controlling network gatekeeper message processing
US6678264B1 (en) * 1999-06-30 2004-01-13 Nortel Networks Limited Establishing connections with a pre-specified quality of service across a communication network
JP3623697B2 (en) * 1999-07-29 2005-02-23 富士通株式会社 Disc time sharing apparatus and method
US6711125B1 (en) 1999-08-02 2004-03-23 Extreme Networks Provisioning networks for reliable quality of service
US8135842B1 (en) 1999-08-16 2012-03-13 Nvidia Corporation Internet jack
US8179809B1 (en) 1999-08-23 2012-05-15 Oracle America, Inc. Approach for allocating resources to an apparatus based on suspendable resource requirements
US7463648B1 (en) * 1999-08-23 2008-12-09 Sun Microsystems, Inc. Approach for allocating resources to an apparatus based on optional resource requirements
US7703102B1 (en) 1999-08-23 2010-04-20 Oracle America, Inc. Approach for allocating resources to an apparatus based on preemptable resource requirements
US8032634B1 (en) 1999-08-23 2011-10-04 Oracle America, Inc. Approach for allocating resources to an apparatus based on resource requirements
US8019870B1 (en) 1999-08-23 2011-09-13 Oracle America, Inc. Approach for allocating resources to an apparatus based on alternative resource requirements
US8234650B1 (en) 1999-08-23 2012-07-31 Oracle America, Inc. Approach for allocating resources to an apparatus
US6606704B1 (en) * 1999-08-31 2003-08-12 Intel Corporation Parallel multithreaded processor with plural microengines executing multiple threads each microengine having loadable microcode
US6983350B1 (en) * 1999-08-31 2006-01-03 Intel Corporation SDRAM controller for parallel processor architecture
US6668317B1 (en) * 1999-08-31 2003-12-23 Intel Corporation Microengine for parallel processor architecture
US6618745B2 (en) 1999-09-10 2003-09-09 Fisher Rosemount Systems, Inc. Linking device in a process control system that allows the formation of a control loop having function blocks in a controller and in field devices
US6674760B1 (en) 1999-09-28 2004-01-06 Extreme Networks, Inc. Method and system for implementing end-to-end QoS in packet-switched networks
US6704752B1 (en) * 1999-10-12 2004-03-09 Cisco Technology, Inc. Method and system for executing, tracking and restoring temporary router configuration change using a centralized database
US6952703B1 (en) 1999-10-12 2005-10-04 Cisco Technology, Inc. Subsystem application notification method in a centralized router database
US6728723B1 (en) * 1999-10-12 2004-04-27 Cisco Technology, Inc. Method and system for verifying configuration transactions managed by a centralized database
AU5441901A (en) * 1999-10-21 2001-07-03 Sony Electronics Inc. A method and system for providing support between multiple applications and serial bus devices
WO2001031857A1 (en) * 1999-10-26 2001-05-03 Astracon, Inc. Method of implementing ip virtual private networks to ensure quality of service
US7046665B1 (en) 1999-10-26 2006-05-16 Extreme Networks, Inc. Provisional IP-aware virtual paths over networks
US6816497B1 (en) 1999-11-05 2004-11-09 Sprint Communications Company, L.P. System and method for processing a call
US6901051B1 (en) * 1999-11-15 2005-05-31 Fujitsu Limited Server-based network performance metrics generation system and method
US7130807B1 (en) 1999-11-22 2006-10-31 Accenture Llp Technology sharing during demand and supply planning in a network-based supply chain environment
US8032409B1 (en) 1999-11-22 2011-10-04 Accenture Global Services Limited Enhanced visibility during installation management in a network-based supply chain environment
US8271336B2 (en) 1999-11-22 2012-09-18 Accenture Global Services Gmbh Increased visibility during order management in a network-based supply chain environment
KR100450942B1 (en) 1999-11-22 2004-10-02 삼성전자주식회사 Address search apparatus and method in ethernet switch
US7716077B1 (en) 1999-11-22 2010-05-11 Accenture Global Services Gmbh Scheduling and planning maintenance and service in a network-based supply chain environment
EP1275052A2 (en) * 1999-11-22 2003-01-15 Accenture LLP Network and life cycle asset management in an e-commerce environment and method thereof
AU1928701A (en) * 1999-11-22 2001-06-04 Accenture Llp Technology sharing during asset management and asset tracking in a network-basedsupply chain environment and method thereof
US6665297B1 (en) 1999-12-09 2003-12-16 Mayan Networks Corporation Network routing table
US6857026B1 (en) * 1999-12-14 2005-02-15 Nortel Networks Limited Using alternate routes for fail-over in a communication network
US6704314B1 (en) * 1999-12-15 2004-03-09 Sprint Communications Company, L.P. Method and apparatus to control cell substitution
US6467084B1 (en) * 1999-12-16 2002-10-15 Emware, Inc. Systems and methods for reprogramming an embedded device with program code using relocatable program code
US6798746B1 (en) 1999-12-18 2004-09-28 Cisco Technology, Inc. Method and apparatus for implementing a quality of service policy in a data communications network
US6532509B1 (en) 1999-12-22 2003-03-11 Intel Corporation Arbitrating command requests in a parallel multi-threaded processing system
US6785738B1 (en) * 1999-12-23 2004-08-31 Cisco Technology, Inc. ARP packet to preserve canonical form of addresses
US6694380B1 (en) 1999-12-27 2004-02-17 Intel Corporation Mapping requests from a processing unit that uses memory-mapped input-output space
US7620702B1 (en) 1999-12-28 2009-11-17 Intel Corporation Providing real-time control data for a network processor
US6826195B1 (en) * 1999-12-28 2004-11-30 Bigband Networks Bas, Inc. System and process for high-availability, direct, flexible and scalable switching of data packets in broadband networks
US6661794B1 (en) * 1999-12-29 2003-12-09 Intel Corporation Method and apparatus for gigabit packet assignment for multithreaded packet processing
US6952824B1 (en) 1999-12-30 2005-10-04 Intel Corporation Multi-threaded sequenced receive for fast network port stream of packets
US7480706B1 (en) 1999-12-30 2009-01-20 Intel Corporation Multi-threaded round-robin receive for fast network port
US6584522B1 (en) 1999-12-30 2003-06-24 Intel Corporation Communication between processors
US6694362B1 (en) * 2000-01-03 2004-02-17 Micromuse Inc. Method and system for network event impact analysis and correlation with network administrators, management policies and procedures
JP3522619B2 (en) * 2000-01-05 2004-04-26 株式会社エヌ・ティ・ティ・ドコモ Transmitter in multi-carrier CDMA transmission system
US6810422B1 (en) 2000-01-14 2004-10-26 Lockheed Martin Tactical Defense Systems System and method for probabilistic quality of communication service determination
IL134047A (en) * 2000-01-14 2004-02-08 Lightscape Networks Ltd Method for selecting the type of communication channels in a multi-layered network and system using same
US6785377B1 (en) * 2000-01-19 2004-08-31 Sprint Communications Company L.P. Data calls using both constant bit rate and variable bit rate connections
US6850530B1 (en) * 2000-02-04 2005-02-01 Cisco Technology, Inc. Methods and apparatus for providing and obtaining resource usage information
US20080281963A1 (en) * 2000-03-02 2008-11-13 Rick Fletcher Distributed remote management (drmon) for networks
US7545755B2 (en) * 2000-03-03 2009-06-09 Adtran Inc. Routing switch detecting change in session identifier before reconfiguring routing table
US6643269B1 (en) * 2000-03-03 2003-11-04 Luminous Networks, Inc. Routing switch automatically identifying network topology
JP4693328B2 (en) * 2000-03-15 2011-06-01 インフォジム インフォルマティオンステヒニク ゲゼルシャフト ミット ベシュレンクテル ハフツング Method and system for communicating data over an optimal data path in a network
US6762997B1 (en) * 2000-03-29 2004-07-13 Lucent Technologies Inc. Method for finding shortest network routing paths subject to system constraints
WO2001075679A1 (en) * 2000-04-04 2001-10-11 Metamatrix, Inc. A system and method for accessing data in disparate information sources
US6738376B1 (en) 2000-04-07 2004-05-18 International Business Machines Corporation Method and system for managing multicast traffic
AU2001261258A1 (en) * 2000-05-05 2001-11-20 Aprisma Management Technologies, Inc. Help desk systems and methods for use with communications networks
AU2001261275A1 (en) * 2000-05-05 2001-11-20 Aprisma Management Technologies, Inc. Systems and methods for isolating faults in computer networks
US7237138B2 (en) * 2000-05-05 2007-06-26 Computer Associates Think, Inc. Systems and methods for diagnosing faults in computer networks
US7500143B2 (en) * 2000-05-05 2009-03-03 Computer Associates Think, Inc. Systems and methods for managing and analyzing faults in computer networks
US7752024B2 (en) * 2000-05-05 2010-07-06 Computer Associates Think, Inc. Systems and methods for constructing multi-layer topological models of computer networks
US6611526B1 (en) 2000-05-08 2003-08-26 Adc Broadband Access Systems, Inc. System having a meshed backplane and process for transferring data therethrough
US6853680B1 (en) 2000-05-10 2005-02-08 Bigband Networks Bas, Inc. System and process for embedded cable modem in a cable modem termination system to enable diagnostics and monitoring
AU2001240077A1 (en) * 2000-05-19 2001-12-03 Channelogics, Inc. Allocating access across shared communications medium
US7499453B2 (en) * 2000-05-19 2009-03-03 Cisco Technology, Inc. Apparatus and methods for incorporating bandwidth forecasting and dynamic bandwidth allocation into a broadband communication system
US7502366B1 (en) * 2000-05-23 2009-03-10 Advanced Micro Devices, Inc. Arrangement in a network switch for prioritizing data frames based on user-defined frame attributes
DE10026730A1 (en) * 2000-05-30 2001-12-06 Bayerische Motoren Werke Ag Resources management method for distributed system of subscribers, involves controlling the inter-communicating subscribers/resources, by means of several controllers
US6944130B1 (en) * 2000-05-31 2005-09-13 Cisco Technology, Inc. Method and apparatus for determining a layer 2 path in a switched network
TW480858B (en) * 2000-06-15 2002-03-21 Nat Science Council Expandability design of QoS route and transfer
US6850980B1 (en) 2000-06-16 2005-02-01 Cisco Technology, Inc. Content routing service protocol
US20040073617A1 (en) * 2000-06-19 2004-04-15 Milliken Walter Clark Hash-based systems and methods for detecting and preventing transmission of unwanted e-mail
US20020064218A1 (en) * 2000-06-29 2002-05-30 Phonex Broadband Corporation Data link for multi protocol facility distributed communication hub
US7111163B1 (en) 2000-07-10 2006-09-19 Alterwan, Inc. Wide area network using internet with quality of service
JP2002044138A (en) * 2000-07-25 2002-02-08 Nec Corp Network system, cache server, relay server, router, cache server control method and recording medium
US7388831B2 (en) * 2000-07-26 2008-06-17 Pluris, Inc. Method and apparatus for bond management according to hierarchy
US6553005B1 (en) * 2000-07-26 2003-04-22 Pluris, Inc. Method and apparatus for load apportionment among physical interfaces in data routers
US6781959B1 (en) 2000-07-31 2004-08-24 Cisco Technology, Inc. Method and apparatus for determining troubleshooting information for completed calls in a telecommunications network
US7224693B1 (en) * 2000-08-11 2007-05-29 Ericsson Ab Long packet handling
US6363071B1 (en) * 2000-08-28 2002-03-26 Bbnt Solutions Llc Hardware address adaptation
US7411981B1 (en) 2000-08-31 2008-08-12 Cisco Technology, Inc. Matching of radius request and response packets during high traffic volume
US6771665B1 (en) 2000-08-31 2004-08-03 Cisco Technology, Inc. Matching of RADIUS request and response packets during high traffic volume
US6920498B1 (en) 2000-08-31 2005-07-19 Cisco Technology, Inc. Phased learning approach to determining closest content serving sites
US6606482B1 (en) * 2000-09-22 2003-08-12 Mobilnet Corporation Adaptive personal routing in a wireless communication network
US7061907B1 (en) * 2000-09-26 2006-06-13 Dell Products L.P. System and method for field upgradeable switches built from routing components
US7630398B2 (en) * 2000-09-27 2009-12-08 Intel Corporation Subnet independent transparent bridge
US6820123B1 (en) 2000-09-28 2004-11-16 Cisco Technology, Inc. Method and apparatus for assigning hot objects to server load balancer
US8019901B2 (en) 2000-09-29 2011-09-13 Alacritech, Inc. Intelligent network storage interface system
US20050157654A1 (en) * 2000-10-12 2005-07-21 Farrell Craig A. Apparatus and method for automated discovery and monitoring of relationships between network elements
US6738829B1 (en) * 2000-10-16 2004-05-18 Wind River Systems, Inc. System and method for implementing a generic enhanced network driver
US7003559B1 (en) * 2000-10-23 2006-02-21 Hewlett-Packard Development Company, L.P. System and method for determining probable network paths between nodes in a network topology
US7039717B2 (en) 2000-11-10 2006-05-02 Nvidia Corporation Internet modem streaming socket method
US6868071B1 (en) * 2000-11-15 2005-03-15 Intel Corporation System and method of transmitting data frames in a mesh of data switches
US7383191B1 (en) 2000-11-28 2008-06-03 International Business Machines Corporation Method and system for predicting causes of network service outages using time domain correlation
US6529481B2 (en) * 2000-11-30 2003-03-04 Pluris, Inc. Scalable and fault-tolerant link state routing protocol for packet-switched networks
CA2327896A1 (en) * 2000-12-08 2002-06-08 Alcatel Canada Inc. An mpls implementation on an atm platform
US7181162B2 (en) 2000-12-12 2007-02-20 The Directv Group, Inc. Communication system using multiple link terminals
US7103317B2 (en) * 2000-12-12 2006-09-05 The Directv Group, Inc. Communication system using multiple link terminals for aircraft
US6952580B2 (en) 2000-12-12 2005-10-04 The Directv Group, Inc. Multiple link internet protocol mobile communications system and method therefor
US7400857B2 (en) 2000-12-12 2008-07-15 The Directv Group, Inc. Communication system using multiple link terminals
US20020075901A1 (en) * 2000-12-19 2002-06-20 Bruce Perlmutter Bandwidth management for tunneling servers
GB0031157D0 (en) * 2000-12-20 2001-01-31 Ncr Int Inc Streaming of data
US20020083344A1 (en) * 2000-12-21 2002-06-27 Vairavan Kannan P. Integrated intelligent inter/intra networking device
US20050237949A1 (en) * 2000-12-21 2005-10-27 Addessi Vincent M Dynamic connection structure for file transfer
US6618388B2 (en) 2001-01-05 2003-09-09 Extreme Networks Method and system for VMAN protocol
US20050207444A1 (en) * 2001-01-12 2005-09-22 Eci Telecom Ltd. Hybrid network element for a multi-protocol layered transmissions network and a graphical representation of the network
US7809403B2 (en) * 2001-01-19 2010-10-05 The Directv Group, Inc. Stratospheric platforms communication system using adaptive antennas
US8396513B2 (en) 2001-01-19 2013-03-12 The Directv Group, Inc. Communication system for mobile users using adaptive antenna
US7187949B2 (en) 2001-01-19 2007-03-06 The Directv Group, Inc. Multiple basestation communication system having adaptive antennas
US7379475B2 (en) 2002-01-25 2008-05-27 Nvidia Corporation Communications processor
US6868083B2 (en) * 2001-02-16 2005-03-15 Hewlett-Packard Development Company, L.P. Method and system for packet communication employing path diversity
US7286532B1 (en) * 2001-02-22 2007-10-23 Cisco Technology, Inc. High performance interface logic architecture of an intermediate network node
US7003572B1 (en) * 2001-02-28 2006-02-21 Packeteer, Inc. System and method for efficiently forwarding client requests from a proxy server in a TCP/IP computing environment
US20020126659A1 (en) * 2001-03-07 2002-09-12 Ling-Zhong Liu Unified software architecture for switch connection management
GB2373116A (en) * 2001-03-09 2002-09-11 Marconi Comm Ltd Optical cross-connect with dynamic bandwidth allocation
US6966015B2 (en) * 2001-03-22 2005-11-15 Micromuse, Ltd. Method and system for reducing false alarms in network fault management systems
US7676567B2 (en) * 2001-03-23 2010-03-09 International Business Machines Corporation System and method for mapping a network
US7009974B1 (en) * 2001-04-18 2006-03-07 Force10 Networks, Inc. Method and apparatus for updating addresses in network processing device
US8218555B2 (en) 2001-04-24 2012-07-10 Nvidia Corporation Gigabit ethernet adapter
US20040004966A1 (en) * 2001-04-27 2004-01-08 Foster Michael S. Using virtual identifiers to route transmitted data through a network
JP2004537881A (en) * 2001-04-27 2004-12-16 ザ ボーイング カンパニー Methods and systems for network management
US7039642B1 (en) * 2001-05-04 2006-05-02 Microsoft Corporation Decision-theoretic methods for identifying relevant substructures of a hierarchical file structure to enhance the efficiency of document access, browsing, and storage
US7243160B2 (en) * 2001-05-10 2007-07-10 Intel Corporation Method for determining multiple paths between ports in a switched fabric
US7164684B2 (en) * 2001-05-18 2007-01-16 Ge Fanuc Automation North America, Inc. Ethernet node having hub, switch and/or repeater characteristics
US6744739B2 (en) * 2001-05-18 2004-06-01 Micromuse Inc. Method and system for determining network characteristics using routing protocols
US7043727B2 (en) * 2001-06-08 2006-05-09 Micromuse Ltd. Method and system for efficient distribution of network event data
US8086738B2 (en) * 2007-05-24 2011-12-27 Russell Fish Distributed means of organizing an arbitrarily large number of computers
US7516208B1 (en) 2001-07-20 2009-04-07 International Business Machines Corporation Event database management method and system for network event reporting system
US6985483B2 (en) * 2001-07-31 2006-01-10 North Carolina State University Methods and systems for fast packet forwarding
US20050286685A1 (en) * 2001-08-10 2005-12-29 Nikola Vukovljak System and method for testing multiple dial-up points in a communications network
TW576061B (en) * 2001-08-13 2004-02-11 Via Tech Inc Device and method for load balancing of packet switching
US9836424B2 (en) 2001-08-24 2017-12-05 Intel Corporation General input/output architecture, protocol and related methods to implement flow control
DE60213616T2 (en) * 2001-08-24 2007-08-09 Intel Corporation, Santa Clara A GENERAL INPUT / OUTPUT ARCHITECTURE, PROTOCOL AND CORRESPONDING METHODS FOR IMPLEMENTING RIVER CONTROL
US7177971B2 (en) * 2001-08-24 2007-02-13 Intel Corporation General input/output architecture, protocol and related methods to provide isochronous channels
KR100903905B1 (en) * 2001-09-19 2009-06-19 톰슨 라이센싱 Apparatus and process for limiting a data transfer bandwidth through handshake suppression
US7155463B1 (en) 2001-09-20 2006-12-26 Emc Corporation System and method for replication of one or more databases
US7827136B1 (en) 2001-09-20 2010-11-02 Emc Corporation Management for replication of data stored in a data storage environment including a system and method for failover protection of software agents operating in the environment
US7539745B1 (en) * 2001-12-11 2009-05-26 Emc Corporation Network management for replication of data stored in a data storage environment
AU2002340023A1 (en) * 2001-09-24 2003-04-07 Rumi Sheryar Gonda Method for supporting ethernet mac circuits
US7126952B2 (en) * 2001-09-28 2006-10-24 Intel Corporation Multiprotocol decapsulation/encapsulation control structure and packet protocol conversion method
US7302700B2 (en) 2001-09-28 2007-11-27 Juniper Networks, Inc. Method and apparatus for implementing a layer 3/layer 7 firewall in an L2 device
US7447197B2 (en) * 2001-10-18 2008-11-04 Qlogic, Corporation System and method of providing network node services
US7200144B2 (en) * 2001-10-18 2007-04-03 Qlogic, Corp. Router and methods using network addresses for virtualization
US7389359B2 (en) 2001-10-19 2008-06-17 Foundry Networks, Inc. Method and system for intelligently forwarding multicast packets
US7647422B2 (en) * 2001-11-06 2010-01-12 Enterasys Networks, Inc. VPN failure recovery
US20030107590A1 (en) * 2001-11-07 2003-06-12 Phillippe Levillain Policy rule management for QoS provisioning
US7529225B2 (en) * 2001-11-16 2009-05-05 Ibasis, Inc. System and method for voice over internet protocol (VoIP) and facsimile over internet protocol (FoIP) calling over the internet
US7843835B2 (en) * 2001-11-16 2010-11-30 Ibasis, Inc. System and method of monitoring an internet based telephone call routing system
US7391731B1 (en) 2002-03-07 2008-06-24 Ibasis, Inc. Method for determining best path
US7110389B2 (en) * 2001-11-19 2006-09-19 International Business Machines Corporation Fanning route generation technique for multi-path networks
US7046666B1 (en) 2001-12-06 2006-05-16 The Directv Group, Inc. Method and apparatus for communicating between divergent networks using media access control communications
EP1331766A1 (en) * 2001-12-20 2003-07-30 Alcatel A telecommunications system employing virtual service network architecture
US6999418B2 (en) * 2001-12-21 2006-02-14 Fujitsu Limited System and method for reduced frame flooding
US7363368B2 (en) 2001-12-24 2008-04-22 International Business Machines Corporation System and method for transaction recording and playback
US7145904B2 (en) * 2002-01-03 2006-12-05 Integrated Device Technology, Inc. Switch queue predictive protocol (SQPP) based packet switching technique
US7020133B2 (en) * 2002-01-03 2006-03-28 Integrated Device Technology Switch queue predictive protocol (SQPP) based packet switching method
US20030128668A1 (en) * 2002-01-04 2003-07-10 Yavatkar Rajendra S. Distributed implementation of control protocols in routers and switches
US7117264B2 (en) * 2002-01-10 2006-10-03 International Business Machines Corporation Method and system for peer to peer communication in a network environment
US7420987B1 (en) 2002-01-17 2008-09-02 Juniper Networks, Inc. Arbiter for multiple mutually exclusive vectors
KR20040103917A (en) * 2002-01-22 2004-12-09 코네샌트 시스템즈, 인코포레이티드 Low-processor-load aggregation
US7414985B1 (en) * 2002-02-01 2008-08-19 Ciena Corporation Link aggregation
US7352741B2 (en) * 2002-02-21 2008-04-01 Sun Microsystems, Inc. Method and apparatus for speculative arbitration
US20030159143A1 (en) * 2002-02-21 2003-08-21 Peter Chan Systems and methods for generating a real-time video program guide through video access of multiple channels
US7072304B2 (en) * 2002-02-27 2006-07-04 Nortel Networks Limited Network path selection based on bandwidth
JP2005539409A (en) * 2002-03-01 2005-12-22 エンテラシス ネットワークス インコーポレイテッド Position recognition data network
US7535913B2 (en) 2002-03-06 2009-05-19 Nvidia Corporation Gigabit ethernet adapter supporting the iSCSI and IPSEC protocols
US7406038B1 (en) * 2002-04-05 2008-07-29 Ciphermax, Incorporated System and method for expansion of computer network switching system without disruption thereof
US20030196211A1 (en) * 2002-04-10 2003-10-16 Peter Chan Systems, methods and apparatuses for simulated rapid tuning of digital video channels
US7543087B2 (en) * 2002-04-22 2009-06-02 Alacritech, Inc. Freeing transmit memory on a network interface device prior to receiving an acknowledgement that transmit data has been received by a remote device
US7496689B2 (en) * 2002-04-22 2009-02-24 Alacritech, Inc. TCP/IP offload device
US7730208B2 (en) * 2002-05-09 2010-06-01 Hughes Network Systems, Inc. Method and system for centrally exchanging terminal information over a meshed network
US6625169B1 (en) * 2002-06-14 2003-09-23 Telesys Technologies, Inc. Integrated communication systems for exchanging data and information between networks
US7471688B2 (en) * 2002-06-18 2008-12-30 Intel Corporation Scheduling system for transmission of cells to ATM virtual circuits and DSL ports
US7119713B2 (en) * 2002-06-27 2006-10-10 Elster Electricity, Llc Dynamic self-configuring metering network
US20040113810A1 (en) * 2002-06-28 2004-06-17 Mason Robert T. Data collector for an automated meter reading system
US7869424B2 (en) * 2002-07-01 2011-01-11 Converged Data Solutions Inc. Systems and methods for voice and data communications including a scalable TDM switch/multiplexer
US7706359B2 (en) * 2002-07-01 2010-04-27 Converged Data Solutions, Inc. Systems and methods for voice and data communications including a network drop and insert interface for an external data routing resource
JP3973986B2 (en) * 2002-07-12 2007-09-12 株式会社エヌ・ティ・ティ・ドコモ Node search method, node, communication system, and node search program
US7480256B2 (en) * 2002-08-14 2009-01-20 Pluris, Inc. Scalable and fault-tolerant link state routing protocol for packet-switched networks
US7352769B2 (en) 2002-09-12 2008-04-01 Intel Corporation Multiple calendar schedule reservation structure and method
US9014196B2 (en) * 2002-09-17 2015-04-21 Broadcom Corporation System and method for providing a super channel in a multi-band multi-protocol hybrid wired/wireless network
US7337241B2 (en) * 2002-09-27 2008-02-26 Alacritech, Inc. Fast-path apparatus for receiving data corresponding to a TCP connection
US7139837B1 (en) * 2002-10-04 2006-11-21 Ipolicy Networks, Inc. Rule engine
FR2846839B1 (en) * 2002-10-31 2005-01-21 Thales Sa METHOD FOR ALLOCATING ACCESS IN A PARTIALLY CONNECTED NETWORK
US7433307B2 (en) * 2002-11-05 2008-10-07 Intel Corporation Flow control in a network environment
GB0227048D0 (en) * 2002-11-20 2002-12-24 3Com Corp Network units for use in and organisation of cascade systems
US7355974B2 (en) * 2003-01-27 2008-04-08 International Business Machines Corporation Method for forwarding data packets by a router
US20040223497A1 (en) * 2003-05-08 2004-11-11 Onvoy Inc. Communications network with converged services
US7443836B2 (en) 2003-06-16 2008-10-28 Intel Corporation Processing a data packet
US20050063379A1 (en) * 2003-09-18 2005-03-24 Samsung Electronics Co., Ltd Apparatus and method for traffic profiling in a massively parallel router
US6996070B2 (en) * 2003-12-05 2006-02-07 Alacritech, Inc. TCP/IP offload device with reduced sequential processing
US8176545B1 (en) 2003-12-19 2012-05-08 Nvidia Corporation Integrated policy checking system and method
US8065439B1 (en) 2003-12-19 2011-11-22 Nvidia Corporation System and method for using metadata in the context of a transport offload engine
US7899913B2 (en) 2003-12-19 2011-03-01 Nvidia Corporation Connection management system and method for a transport offload engine
US8549170B2 (en) 2003-12-19 2013-10-01 Nvidia Corporation Retransmission system and method for a transport offload engine
US7260631B1 (en) 2003-12-19 2007-08-21 Nvidia Corporation System and method for receiving iSCSI protocol data units
US7624198B1 (en) 2003-12-19 2009-11-24 Nvidia Corporation Sequence tagging system and method for transport offload engine data lists
CN1555164B (en) * 2003-12-25 2010-09-29 中兴通讯股份有限公司 Route service device and method and system for realizing calling route using said device
US7573898B2 (en) * 2003-12-29 2009-08-11 Fujitsu Limited Method and apparatus to double LAN service unit bandwidth
US7277876B2 (en) * 2004-01-23 2007-10-02 Solomon Research Llc Dynamic adaptive distributed computer system
US7206872B2 (en) 2004-02-20 2007-04-17 Nvidia Corporation System and method for insertion of markers into a data stream
US7249306B2 (en) 2004-02-20 2007-07-24 Nvidia Corporation System and method for generating 128-bit cyclic redundancy check values with 32-bit granularity
US20050195756A1 (en) * 2004-02-26 2005-09-08 Frattura David E. Status announcement system and method
US7580403B2 (en) * 2004-02-26 2009-08-25 Enterasys Networks, Inc. Status transmission system and method
TWI250753B (en) * 2004-02-27 2006-03-01 Accton Technology Corp Locate the incoming port of a MAC address in ethernet switch network
US7690040B2 (en) 2004-03-10 2010-03-30 Enterasys Networks, Inc. Method for network traffic mirroring with data privacy
WO2005091901A2 (en) * 2004-03-10 2005-10-06 Enterasys Networks, Inc. Dynamic network detection system and method
US7356694B2 (en) * 2004-03-10 2008-04-08 American Express Travel Related Services Company, Inc. Security session authentication system and method
US7474661B2 (en) * 2004-03-26 2009-01-06 Samsung Electronics Co., Ltd. Apparatus and method for distributing forwarding table lookup operations among a plurality of microengines in a high-speed routing node
US20050220096A1 (en) 2004-04-06 2005-10-06 Robert Friskney Traffic engineering in frame-based carrier networks
US8923292B2 (en) 2004-04-06 2014-12-30 Rockstar Consortium Us Lp Differential forwarding in address-based carrier networks
US7698413B1 (en) 2004-04-12 2010-04-13 Nvidia Corporation Method and apparatus for accessing and maintaining socket control information for high speed network connections
US7181358B2 (en) * 2004-05-05 2007-02-20 Verigy Pte. Ltd. Method, apparatus and database using a map of linked data nodes for storing test numbers
US8458453B1 (en) 2004-06-11 2013-06-04 Dunti Llc Method and apparatus for securing communication over public network
US7684322B2 (en) * 2004-07-01 2010-03-23 Nortel Networks Limited Flow admission control in an IP network
US8422500B2 (en) 2004-07-02 2013-04-16 Rockstar Consortium Us Lp VLAN support of differentiated services
EP1617355A1 (en) 2004-07-14 2006-01-18 Sap Ag Technique for flexible path optimization
EP1617326A1 (en) * 2004-07-14 2006-01-18 Sap Ag Technique for handling hierarchical application data
US7945945B2 (en) * 2004-08-06 2011-05-17 Enterasys Networks, Inc. System and method for address block enhanced dynamic network policy management
US7729261B2 (en) * 2004-08-10 2010-06-01 Alcatel Lucent Forwarding of network traffic in respect of differentiated restricted transit network nodes
US8819213B2 (en) * 2004-08-20 2014-08-26 Extreme Networks, Inc. System, method and apparatus for traffic mirror setup, service and security in communication networks
KR100898681B1 (en) * 2004-09-07 2009-05-22 메시네트웍스, 인코포레이티드 System and method for routing data between different types of nodes in a wireless network
US7702594B2 (en) 2004-09-24 2010-04-20 Elster Electricity, Llc System and method for automated configuration of meters
US7742430B2 (en) 2004-09-24 2010-06-22 Elster Electricity, Llc System for automated management of spontaneous node migration in a distributed fixed wireless network
US8248939B1 (en) 2004-10-08 2012-08-21 Alacritech, Inc. Transferring control of TCP connections between hierarchy of processing mechanisms
US7957379B2 (en) 2004-10-19 2011-06-07 Nvidia Corporation System and method for processing RX packets in high speed network applications using an RX FIFO buffer
US7347628B2 (en) 2004-11-08 2008-03-25 Enterasys Networks, Inc. Optical interface identification system
KR100703726B1 (en) * 2004-12-11 2007-04-05 삼성전자주식회사 Method for managing neighbor node and determining routing path in mobile ad hoc network, and network apparatus thereof
US7689575B2 (en) * 2004-12-29 2010-03-30 Yahoo! Inc. Bitmask access for managing blog content
US7463587B2 (en) * 2005-01-11 2008-12-09 Alcatel Lucent System and method for identifying pre-computed paths in a policy-based routing network
DE102005002358A1 (en) * 2005-01-18 2006-08-24 Siemens Ag Method for determining the forwarding direction of Ethernet frames
US9497109B2 (en) * 2005-02-11 2016-11-15 Hewlett Packard Enterprise Development Lp Switching mesh with user-configurable paths
WO2006095508A1 (en) * 2005-03-08 2006-09-14 Nippon Telegraph And Telephone Corporation Flooding suppression method
US8107370B2 (en) * 2005-04-06 2012-01-31 Cisco Technology, Inc. Network access device with restricted and unrestricted input ports
KR100703780B1 (en) * 2005-05-11 2007-04-06 삼성전자주식회사 Method and apparatus for supporting consistency of routing table's data in wireless network
DE102005022689B4 (en) * 2005-05-18 2007-09-20 Adc Gmbh Active distribution device in the subscriber access area
DE102005022547B4 (en) * 2005-05-18 2008-07-03 Adc Gmbh Distribution device in the subscriber connection area
US7936668B2 (en) * 2005-05-26 2011-05-03 Cisco Technology, Inc. Methods and apparatus for distributing label information
US20060268691A1 (en) * 2005-05-31 2006-11-30 International Business Machines Corporation Divide and conquer route generation technique for distributed selection of routes within a multi-path network
US7978719B2 (en) * 2005-06-10 2011-07-12 International Business Machines Corporation Dynamically assigning endpoint identifiers to network interfaces of communications networks
US8086232B2 (en) * 2005-06-28 2011-12-27 Enterasys Networks, Inc. Time synchronized wireless method and operations
US7774402B2 (en) * 2005-06-29 2010-08-10 Visa U.S.A. Adaptive gateway for switching transactions and data on unreliable networks using context-based rules
US7694287B2 (en) * 2005-06-29 2010-04-06 Visa U.S.A. Schema-based dynamic parse/build engine for parsing multi-format messages
US8457017B2 (en) * 2005-06-30 2013-06-04 Infinera Corporation Multi-chassis interconnect
CN100452892C (en) * 2005-07-11 2009-01-14 华为技术有限公司 Method for carrying out playback on conversation
EP1744497B1 (en) * 2005-07-14 2008-01-23 Interuniversitair Microelektronica Centrum Vzw Method for managing a plurality of virtual links shared on a communication line and network implementing said method
US20070041374A1 (en) * 2005-08-17 2007-02-22 Randeep Kapoor Reset to a default state on a switch fabric
US7978611B2 (en) * 2005-09-06 2011-07-12 At&T Intellectual Property I, L.P. Systems and methods to determine network routes based on transmission medium length
US20070064612A1 (en) * 2005-09-19 2007-03-22 Sbc Knowledge Ventures L.P. Method and apparatus for selecting an optimal path from a path-starting node of a network to a path-ending node of the network
US8099756B2 (en) * 2005-11-10 2012-01-17 Versteeg William C Channel changes between services with differing bandwidth in a switched digital video system
US7742407B2 (en) 2005-11-10 2010-06-22 Scientific-Atlanta, Llc Quality of service management in a switched digital video environment
US20070106782A1 (en) * 2005-11-10 2007-05-10 Scientific-Atlanta, Inc. Bandwidth management in each network device in a switched digital video environment
US20070107024A1 (en) * 2005-11-10 2007-05-10 Scientific-Atlanta, Inc. Atomic channel changes in a switched digital video system
US7873760B2 (en) * 2005-11-11 2011-01-18 Versteeg William C Expedited digital signal decoding
US20070110035A1 (en) * 2005-11-14 2007-05-17 Broadcom Corporation, A California Corporation Network nodes cooperatively routing traffic flow amongst wired and wireless networks
EP1816799A1 (en) * 2006-02-01 2007-08-08 Siemens AG Method for creating a path for data transmission in a network based on network element reliability.
US20070211882A1 (en) * 2006-03-07 2007-09-13 Francois Hatte Control method for a telecommunication distribution system
US20070211883A1 (en) * 2006-03-07 2007-09-13 Jorg Franzke Telecommunications device having distribution units arranged in block configuration
US8437344B2 (en) * 2006-03-07 2013-05-07 Adc Telecommunications, Inc. Telecommunication distribution device with multi-circuit board arrangement
US20070211740A1 (en) * 2006-03-07 2007-09-13 Jorg Franzke Telecommunications distribution system with line sharing
US20070226549A1 (en) * 2006-03-17 2007-09-27 Alcatel Apparatus for detecting errors in a communication system
US20090299493A1 (en) * 2006-05-02 2009-12-03 Allan Bo Joergensen System for operating a plant
US20070280240A1 (en) * 2006-05-31 2007-12-06 Robert Beach System and method for internet protocol mobility
ATE519301T1 (en) * 2006-06-27 2011-08-15 Ericsson Telefon Ab L M FORCED MEDIA ACCESS CONTROL (MAC) LEARNING IN BRIDGED ETHERNET NETWORKS
KR100819271B1 (en) * 2006-06-30 2008-04-03 삼성전자주식회사 Packet switch device and bandwidth control method thereof
US8194643B2 (en) 2006-10-19 2012-06-05 Embarq Holdings Company, Llc System and method for monitoring the connection of an end-user to a remote network
US20080022320A1 (en) * 2006-06-30 2008-01-24 Scientific-Atlanta, Inc. Systems and Methods of Synchronizing Media Streams
US7948909B2 (en) 2006-06-30 2011-05-24 Embarq Holdings Company, Llc System and method for resetting counters counting network performance information at network communications devices on a packet network
US8488447B2 (en) 2006-06-30 2013-07-16 Centurylink Intellectual Property Llc System and method for adjusting code speed in a transmission path during call set-up due to reduced transmission performance
US9094257B2 (en) 2006-06-30 2015-07-28 Centurylink Intellectual Property Llc System and method for selecting a content delivery network
US8000318B2 (en) * 2006-06-30 2011-08-16 Embarq Holdings Company, Llc System and method for call routing based on transmission performance of a packet network
US8477614B2 (en) 2006-06-30 2013-07-02 Centurylink Intellectual Property Llc System and method for routing calls if potential call paths are impaired or congested
US8717911B2 (en) 2006-06-30 2014-05-06 Centurylink Intellectual Property Llc System and method for collecting network performance information
US8289965B2 (en) 2006-10-19 2012-10-16 Embarq Holdings Company, Llc System and method for establishing a communications session with an end-user based on the state of a network connection
US7899046B2 (en) * 2006-07-07 2011-03-01 Ver Steeg William C Determining strategy for multicast and/or unicast transmission to correct forward errors
US7774672B2 (en) 2006-07-07 2010-08-10 Scientific-Atlanta, Llc Requesting additional forward error correction
US7725797B2 (en) 2006-07-07 2010-05-25 Scientific-Atlanta, Llc Buffer for storing data and forward error correction (FEC)
US7877660B2 (en) * 2006-07-07 2011-01-25 Ver Steeg William C Transmitting additional forward error correction (FEC) upon request
US8576722B2 (en) 2006-08-22 2013-11-05 Centurylink Intellectual Property Llc System and method for modifying connectivity fault management packets
US8238253B2 (en) 2006-08-22 2012-08-07 Embarq Holdings Company, Llc System and method for monitoring interlayer devices and optimizing network performance
US8102770B2 (en) * 2006-08-22 2012-01-24 Embarq Holdings Company, LP System and method for monitoring and optimizing network performance with vector performance tables and engines
US8531954B2 (en) 2006-08-22 2013-09-10 Centurylink Intellectual Property Llc System and method for handling reservation requests with a connection admission control engine
US8750158B2 (en) 2006-08-22 2014-06-10 Centurylink Intellectual Property Llc System and method for differentiated billing
US8537695B2 (en) 2006-08-22 2013-09-17 Centurylink Intellectual Property Llc System and method for establishing a call being received by a trunk on a packet network
US7940735B2 (en) 2006-08-22 2011-05-10 Embarq Holdings Company, Llc System and method for selecting an access point
US8144587B2 (en) 2006-08-22 2012-03-27 Embarq Holdings Company, Llc System and method for load balancing network resources using a connection admission control engine
US8224255B2 (en) 2006-08-22 2012-07-17 Embarq Holdings Company, Llc System and method for managing radio frequency windows
US8307065B2 (en) 2006-08-22 2012-11-06 Centurylink Intellectual Property Llc System and method for remotely controlling network operators
WO2008024387A2 (en) 2006-08-22 2008-02-28 Embarq Holdings Company Llc System and method for synchronizing counters on an asynchronous packet communications network
US8223655B2 (en) 2006-08-22 2012-07-17 Embarq Holdings Company, Llc System and method for provisioning resources of a packet network based on collected network performance information
US9479341B2 (en) 2006-08-22 2016-10-25 Centurylink Intellectual Property Llc System and method for initiating diagnostics on a packet network node
US8228791B2 (en) 2006-08-22 2012-07-24 Embarq Holdings Company, Llc System and method for routing communications between packet networks based on intercarrier agreements
US7808918B2 (en) 2006-08-22 2010-10-05 Embarq Holdings Company, Llc System and method for dynamically shaping network traffic
US20080049629A1 (en) * 2006-08-22 2008-02-28 Morrill Robert J System and method for monitoring data link layer devices and optimizing interlayer network performance
US8619600B2 (en) 2006-08-22 2013-12-31 Centurylink Intellectual Property Llc System and method for establishing calls over a call path having best path metrics
US8130793B2 (en) 2006-08-22 2012-03-06 Embarq Holdings Company, Llc System and method for enabling reciprocal billing for different types of communications over a packet network
US8125897B2 (en) 2006-08-22 2012-02-28 Embarq Holdings Company Lp System and method for monitoring and optimizing network performance with user datagram protocol network performance information packets
US8274905B2 (en) 2006-08-22 2012-09-25 Embarq Holdings Company, Llc System and method for displaying a graph representative of network performance over a time period
US8098579B2 (en) 2006-08-22 2012-01-17 Embarq Holdings Company, LP System and method for adjusting the window size of a TCP packet through remote network elements
US7684332B2 (en) 2006-08-22 2010-03-23 Embarq Holdings Company, Llc System and method for adjusting the window size of a TCP packet through network elements
US8407765B2 (en) 2006-08-22 2013-03-26 Centurylink Intellectual Property Llc System and method for restricting access to network performance information tables
US8194555B2 (en) 2006-08-22 2012-06-05 Embarq Holdings Company, Llc System and method for using distributed network performance information tables to manage network communications
US8199653B2 (en) 2006-08-22 2012-06-12 Embarq Holdings Company, Llc System and method for communicating network performance information over a packet network
US8743703B2 (en) 2006-08-22 2014-06-03 Centurylink Intellectual Property Llc System and method for tracking application resource usage
US8015294B2 (en) 2006-08-22 2011-09-06 Embarq Holdings Company, LP Pin-hole firewall for communicating data packets on a packet network
US8064391B2 (en) 2006-08-22 2011-11-22 Embarq Holdings Company, Llc System and method for monitoring and optimizing network performance to a wireless device
US7843831B2 (en) 2006-08-22 2010-11-30 Embarq Holdings Company Llc System and method for routing data on a packet network
US8107366B2 (en) * 2006-08-22 2012-01-31 Embarq Holdings Company, LP System and method for using centralized network performance tables to manage network communications
US8040811B2 (en) 2006-08-22 2011-10-18 Embarq Holdings Company, Llc System and method for collecting and managing network performance information
US8189468B2 (en) 2006-10-25 2012-05-29 Embarq Holdings, Company, LLC System and method for regulating messages between networks
US8549405B2 (en) 2006-08-22 2013-10-01 Centurylink Intellectual Property Llc System and method for displaying a graphical representation of a network to identify nodes and node segments on the network that are not operating normally
US8144586B2 (en) 2006-08-22 2012-03-27 Embarq Holdings Company, Llc System and method for controlling network bandwidth with a connection admission control engine
US20080059424A1 (en) * 2006-08-28 2008-03-06 Assimakis Tzamaloukas System and method for locating-based searches and advertising
US7987260B2 (en) * 2006-08-28 2011-07-26 Dash Navigation, Inc. System and method for updating information using limited bandwidth
US8612437B2 (en) * 2006-08-28 2013-12-17 Blackberry Limited System and method for location-based searches and advertising
US8280395B2 (en) * 2006-08-28 2012-10-02 Dash Navigation, Inc. System and method for updating information using limited bandwidth
US7822802B2 (en) * 2006-09-29 2010-10-26 Fisher-Rosemount Systems, Inc. Apparatus and method for merging wireless data into an established process control system
US7870465B2 (en) * 2006-10-18 2011-01-11 Versteeg William C Reducing channel-change time
US8073384B2 (en) 2006-12-14 2011-12-06 Elster Electricity, Llc Optimization of redundancy and throughput in an automated meter data collection system using a wireless network
US8654638B2 (en) * 2006-12-19 2014-02-18 Marcin Godlewski Dynamically adjusting bandwidth usage among subscriber streams
US8144697B2 (en) * 2007-01-12 2012-03-27 Raytheon Company System and method for networking computing clusters
US8040916B2 (en) * 2007-03-14 2011-10-18 Cisco Technology, Inc. Admission control for virtualized services in routers
US20080244667A1 (en) * 2007-03-27 2008-10-02 Osborne Jason C Bandwidth sensitive switched digital video content delivery
US8370889B2 (en) * 2007-03-28 2013-02-05 Kanthimathi Gayatri Sukumar Switched digital video client reverse channel traffic reduction
US20080263171A1 (en) * 2007-04-19 2008-10-23 Alacritech, Inc. Peripheral device that DMAS the same data to different locations in a computer
WO2008130410A1 (en) * 2007-04-20 2008-10-30 University Of Florida Research Foundation, Inc. Method and systems for bandwidth scheduling and path computation for connection-oriented networks
US8320302B2 (en) 2007-04-20 2012-11-27 Elster Electricity, Llc Over the air microcontroller flash memory updates
US8391354B2 (en) * 2007-05-14 2013-03-05 Broadcom Corporation Method and system for transforming uncompressed video traffic to network-aware ethernet traffic with A/V bridging capabilities and A/V bridging extensions
US20080298345A1 (en) * 2007-05-30 2008-12-04 Llija Hadzic Cross-connect for emulated circuit-base communications
US8111692B2 (en) 2007-05-31 2012-02-07 Embarq Holdings Company Llc System and method for modifying network traffic
US7818785B2 (en) * 2007-07-25 2010-10-19 Dell Products L.P. System and method for secure information handling system memory
US8116337B2 (en) * 2007-07-27 2012-02-14 Marcin Godlewski Bandwidth requests transmitted according to priority in a centrally managed network
US8832766B2 (en) * 2007-07-27 2014-09-09 William C. Versteeg Systems and methods of differentiated channel change behavior
US8776160B2 (en) * 2007-07-27 2014-07-08 William C. Versteeg Systems and methods of differentiated requests for network access
US8208403B2 (en) * 2007-12-26 2012-06-26 Verizon Patent And Licensing Inc. Defining an end-to-end path for a network service
WO2009082761A1 (en) 2007-12-26 2009-07-02 Elster Electricity, Llc. Optimized data collection in a wireless fixed network metering system
US8683572B1 (en) 2008-01-24 2014-03-25 Dunti Llc Method and apparatus for providing continuous user verification in a packet-based network
US8335780B2 (en) * 2008-03-11 2012-12-18 James Madison Kelley Scalable high speed relational processor for databases and networks
US8539513B1 (en) 2008-04-01 2013-09-17 Alacritech, Inc. Accelerating data transfer in a virtual computer system with tightly coupled TCP connections
US8068425B2 (en) 2008-04-09 2011-11-29 Embarq Holdings Company, Llc System and method for using network performance information to determine improved measures of path states
US8525692B2 (en) 2008-06-13 2013-09-03 Elster Solutions, Llc Techniques for limiting demand from an electricity meter with an installed relay
CN101616169B (en) 2008-06-23 2013-03-13 华为技术有限公司 Method for selecting service providing entities, system, service selecting entity and service managing entity
US8341286B1 (en) 2008-07-31 2012-12-25 Alacritech, Inc. TCP offload send optimization
US7886073B2 (en) * 2008-08-08 2011-02-08 Cisco Technology, Inc. Systems and methods of reducing media stream delay
US8015310B2 (en) * 2008-08-08 2011-09-06 Cisco Technology, Inc. Systems and methods of adaptive playout of delayed media streams
US9306793B1 (en) 2008-10-22 2016-04-05 Alacritech, Inc. TCP offload device that batches session layer headers to reduce interrupts as well as CPU copies
US8959245B2 (en) * 2008-11-25 2015-02-17 Broadcom Corporation Multiple pathway session setup to support QoS services
US8239739B2 (en) * 2009-02-03 2012-08-07 Cisco Technology, Inc. Systems and methods of deferred error recovery
US8203463B2 (en) 2009-02-13 2012-06-19 Elster Electricity Llc Wakeup and interrogation of meter-reading devices using licensed narrowband and unlicensed wideband radio communication
US8971335B2 (en) * 2009-07-02 2015-03-03 Exafer Ltd System and method for creating a transitive optimized flow path
US8325733B2 (en) * 2009-09-09 2012-12-04 Exafer Ltd Method and system for layer 2 manipulator and forwarder
US8095684B2 (en) * 2009-09-15 2012-01-10 Symantec Corporation Intelligent device and media server selection for optimized backup image duplication
RU2732585C2 (en) 2010-07-09 2020-09-22 Виза Интернэшнл Сервис Ассосиэйшн Gateway level of abstraction
WO2012038722A1 (en) * 2010-09-24 2012-03-29 Bae Systems Plc Admission control in a self aware network
US9344335B2 (en) 2011-09-09 2016-05-17 Microsoft Technology Licensing, Llc Network communication and cost awareness
US9015555B2 (en) 2011-11-18 2015-04-21 Cisco Technology, Inc. System and method for multicast error recovery using sampled feedback
US8897301B2 (en) 2012-03-14 2014-11-25 International Business Machines Corporation Multicast bandwidth multiplication for a unified distributed switch
US8953619B2 (en) * 2012-03-14 2015-02-10 International Business Machines Corporation Dynamic optimization of a multicast tree hierarchy for a distributed switch
US8811406B2 (en) 2012-03-14 2014-08-19 International Business Machines Corporation Delivering multicast frames to aggregated link trunks in a distributed switch
US8913620B2 (en) * 2012-03-14 2014-12-16 International Business Machines Corporation Multicast traffic generation using hierarchical replication mechanisms for distributed switches
CN103582085B (en) * 2012-08-10 2017-02-22 华为技术有限公司 Access method and device in heterogeneous network
US9170768B2 (en) 2012-12-24 2015-10-27 Apple Inc. Managing fast to slow links in a bus fabric
US9112796B2 (en) 2013-03-14 2015-08-18 Lenovo Enterprise Solutions (Singapore) Pte. Ltd. System guided surrogating control in broadcast and multicast
US9998536B2 (en) 2013-05-29 2018-06-12 Microsoft Technology Licensing, Llc Metered network synchronization
CN104243536B (en) * 2013-06-24 2017-09-15 中国科学院软件研究所 A kind of bullet train controls network semi-matter simulating system
US10003536B2 (en) 2013-07-25 2018-06-19 Grigore Raileanu System and method for managing bandwidth usage rates in a packet-switched network
US9525638B2 (en) 2013-10-15 2016-12-20 Internap Corporation Routing system for internet traffic
US9389630B2 (en) * 2014-02-21 2016-07-12 International Business Machines Corporation Predictive smart grid re-structuring based on expected load and power generation
US9450916B2 (en) * 2014-08-22 2016-09-20 Honeywell International Inc. Hardware assist for redundant ethernet network
US10067800B2 (en) * 2014-11-06 2018-09-04 Vmware, Inc. Peripheral device sharing across virtual machines running on different host computing systems
US10924408B2 (en) 2014-11-07 2021-02-16 Noction, Inc. System and method for optimizing traffic in packet-switched networks with internet exchanges
US9769070B2 (en) 2015-01-28 2017-09-19 Maxim Basunov System and method of providing a platform for optimizing traffic through a computer network with distributed routing domains interconnected through data center interconnect links
US10079779B2 (en) 2015-01-30 2018-09-18 Nicira, Inc. Implementing logical router uplinks
US10235176B2 (en) 2015-12-17 2019-03-19 The Charles Stark Draper Laboratory, Inc. Techniques for metadata processing
CN109314676B (en) 2016-04-28 2022-07-01 费尔弗洛技术控股私人有限公司 Method for distributing and aggregating resource data in network domain
US10972437B2 (en) * 2016-08-08 2021-04-06 Talari Networks Incorporated Applications and integrated firewall design in an adaptive private network (APN)
US10091784B1 (en) 2016-12-31 2018-10-02 Sprint Communications Company L.P. Device-to-device (D2D) scheduling control in orthogonal frequency division multiplexing (OFDM) wireless system
US10409995B1 (en) * 2017-05-08 2019-09-10 Amazon Technologies, Inc. End-to-end change tracking for triggering website security review
TWI794405B (en) 2018-02-02 2023-03-01 美商查爾斯塔克德拉普實驗室公司 Systems and methods for policy execution processing
US20210026934A1 (en) 2018-02-02 2021-01-28 Dover Microsystems, Inc. Systems and methods for policy linking and/or loading for secure initialization
WO2019213061A1 (en) 2018-04-30 2019-11-07 Dover Microsystems, Inc. Systems and methods for checking safety properties
EP3877874A1 (en) 2018-11-06 2021-09-15 Dover Microsystems, Inc. Systems and methods for stalling host processor
US11277432B2 (en) * 2018-12-03 2022-03-15 Accenture Global Solutions Limited Generating attack graphs in agile security platforms
US11283825B2 (en) 2018-12-03 2022-03-22 Accenture Global Solutions Limited Leveraging attack graphs of agile security platform
US11184385B2 (en) 2018-12-03 2021-11-23 Accenture Global Solutions Limited Generating attack graphs in agile security platforms
US11159555B2 (en) 2018-12-03 2021-10-26 Accenture Global Solutions Limited Generating attack graphs in agile security platforms
US11281806B2 (en) 2018-12-03 2022-03-22 Accenture Global Solutions Limited Generating attack graphs in agile security platforms
US11841956B2 (en) 2018-12-18 2023-12-12 Dover Microsystems, Inc. Systems and methods for data lifecycle protection
EP3764263A1 (en) 2019-07-12 2021-01-13 Accenture Global Solutions Limited Evaluating efficacy of security controls in enterprise networks using graph values
JP2022552941A (en) * 2019-09-26 2022-12-21 コムスコープ テクノロジーズ リミティド ライアビリティ カンパニー Passive Backplane Architecture for Master Unit of Distributed Antenna System
EP3872665A1 (en) 2020-02-28 2021-09-01 Accenture Global Solutions Limited Cyber digital twin simulator for security controls requirements
US11533332B2 (en) 2020-06-25 2022-12-20 Accenture Global Solutions Limited Executing enterprise process abstraction using process aware analytical attack graphs
US11483213B2 (en) 2020-07-09 2022-10-25 Accenture Global Solutions Limited Enterprise process discovery through network traffic patterns
US11411976B2 (en) 2020-07-09 2022-08-09 Accenture Global Solutions Limited Resource-efficient generation of analytical attack graphs
US11831675B2 (en) 2020-10-26 2023-11-28 Accenture Global Solutions Limited Process risk calculation based on hardness of attack paths
TWI744093B (en) * 2020-11-13 2021-10-21 國立清華大學 Binary-addition tree algorithm-based network assessment method and system thereof
CN112947467B (en) * 2021-03-11 2021-11-02 东莞职业技术学院 Vehicle path planning method for traversing multi-point homing
US11880250B2 (en) 2021-07-21 2024-01-23 Accenture Global Solutions Limited Optimizing energy consumption of production lines using intelligent digital twins
US11895150B2 (en) 2021-07-28 2024-02-06 Accenture Global Solutions Limited Discovering cyber-attack process model based on analytical attack graphs
KR20230084959A (en) * 2021-12-06 2023-06-13 현대자동차주식회사 Gateway and method for processing can message thereof
US20240037550A1 (en) * 2022-07-29 2024-02-01 Ncr Corporation Information encoding and transmission techniques

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4987536A (en) * 1988-05-12 1991-01-22 Codex Corporation Communication system for sending an identical routing tree to all connected nodes to establish a shortest route and transmitting messages thereafter
EP0413488A2 (en) * 1989-08-15 1991-02-20 AT&T Corp. Arrangement for regulating traffic in a high speed data network
US5001707A (en) * 1989-11-02 1991-03-19 Northern Telecom Limited Method of providing reserved bandwidth in a dual bus system
EP0473066A1 (en) * 1990-08-27 1992-03-04 Mitsubishi Denki Kabushiki Kaisha Inter-local area network connecting system
EP0524316A1 (en) * 1991-01-31 1993-01-27 Fujitsu Limited Connectionless communication system
EP0568477A2 (en) * 1992-04-28 1993-11-03 International Business Machines Corporation Method and apparatus for optinum path selection in packet transmission networks

Family Cites Families (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4445116A (en) * 1982-03-05 1984-04-24 Burroughs Corporation Method for allocating bandwidth between stations in a local area network
US4536874A (en) * 1983-07-21 1985-08-20 Stoffel James C Bandwidth efficient multipoint data communication system
US5008882A (en) * 1987-08-17 1991-04-16 California Institute Of Technology Method and apparatus for eliminating unsuccessful tries in a search tree
US4905233A (en) * 1987-11-23 1990-02-27 Harris Corporation Multiple path routing mechanism for packet communications network
US4894822A (en) * 1987-11-24 1990-01-16 AT&T Information Systems American Telephone and Telegraph Company Fast packetized data delivery for digital networks
US5088032A (en) * 1988-01-29 1992-02-11 Cisco Systems, Inc. Method and apparatus for routing communications among computer networks
US4873517A (en) * 1988-06-23 1989-10-10 International Business Machines Corporation Method for selecting least weight end node to end node route in a data communications network
EP0364638B1 (en) * 1988-10-20 1994-04-20 International Business Machines Corporation Communication network
US5113499A (en) * 1989-04-28 1992-05-12 Sprint International Communications Corp. Telecommunication access management system for a packet switching network
GB8911395D0 (en) * 1989-05-18 1989-07-05 British Telecomm Data communications network
US4991171A (en) * 1989-09-26 1991-02-05 At&T Bell Laboratories Broadcast packet switch network
GB8927623D0 (en) * 1989-12-06 1990-02-07 Bicc Plc Repeaters for secure local area networks
US5301303A (en) * 1990-04-23 1994-04-05 Chipcom Corporation Communication system concentrator configurable to different access methods
US5136580A (en) * 1990-05-16 1992-08-04 Microcom Systems, Inc. Apparatus and method for learning and filtering destination and source addresses in a local area network system
US5226120A (en) * 1990-05-21 1993-07-06 Synoptics Communications, Inc. Apparatus and method of monitoring the status of a local area network
US5261044A (en) * 1990-09-17 1993-11-09 Cabletron Systems, Inc. Network management system using multifunction icons for information display
WO1992016066A1 (en) * 1991-02-28 1992-09-17 Stratacom, Inc. Method and apparatus for routing cell messages using delay
US5274631A (en) * 1991-03-11 1993-12-28 Kalpana, Inc. Computer network switching system
US5268900A (en) * 1991-07-05 1993-12-07 Codex Corporation Device and method for implementing queueing disciplines at high speeds
EP0552385B1 (en) * 1991-08-21 2001-02-14 International Business Machines Corporation Connectionless ATM data services
DE69220564T2 (en) * 1992-04-27 1998-01-15 Ibm Support of connectionless services in the ATM network using partial connections
US5313466A (en) * 1992-09-22 1994-05-17 The Texas A&M University System Local synchronous bandwidth allocation in a token ring network
US5317566A (en) * 1993-08-18 1994-05-31 Ascom Timeplex Trading Ag Least cost route selection in distributed digital communication networks

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4987536A (en) * 1988-05-12 1991-01-22 Codex Corporation Communication system for sending an identical routing tree to all connected nodes to establish a shortest route and transmitting messages thereafter
EP0413488A2 (en) * 1989-08-15 1991-02-20 AT&T Corp. Arrangement for regulating traffic in a high speed data network
US5001707A (en) * 1989-11-02 1991-03-19 Northern Telecom Limited Method of providing reserved bandwidth in a dual bus system
EP0473066A1 (en) * 1990-08-27 1992-03-04 Mitsubishi Denki Kabushiki Kaisha Inter-local area network connecting system
EP0524316A1 (en) * 1991-01-31 1993-01-27 Fujitsu Limited Connectionless communication system
EP0568477A2 (en) * 1992-04-28 1993-11-03 International Business Machines Corporation Method and apparatus for optinum path selection in packet transmission networks

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6147996A (en) * 1995-08-04 2000-11-14 Cisco Technology, Inc. Pipelined multiple issue packet switch
WO1997024841A2 (en) * 1995-12-29 1997-07-10 Cisco Systems, Inc. Datagram transmission over virtual circuits
WO1997024841A3 (en) * 1995-12-29 1997-09-12 Cisco Systems Inc Datagram transmission over virtual circuits
US5802042A (en) * 1996-06-28 1998-09-01 Cisco Systems, Inc. Autosensing LMI protocols in frame relay networks
WO1998037727A2 (en) * 1997-02-18 1998-08-27 Virata Limited Proxy-controlled atm subnetwork
WO1998037727A3 (en) * 1997-02-18 1998-12-23 Advanced Telecommunications Mo Proxy-controlled atm subnetwork
US6111858A (en) * 1997-02-18 2000-08-29 Virata Limited Proxy-controlled ATM subnetwork
US6360109B1 (en) * 1997-04-30 2002-03-19 U.S. Philips Corporation Terminal, automatic recall procedure, and telecommunication system
US6909697B1 (en) 1997-12-22 2005-06-21 Cisco Technology, Inc. Method and apparatus for identifying a maximum frame size
US6771642B1 (en) 1999-01-08 2004-08-03 Cisco Technology, Inc. Method and apparatus for scheduling packets in a packet switch
JP2003508955A (en) * 1999-08-31 2003-03-04 サイエンス アプリケーションズ インターナショナル コーポレイション System and method for interconnecting multiple virtual private networks
US7123620B1 (en) 2000-04-25 2006-10-17 Cisco Technology, Inc. Apparatus and method for scalable and dynamic traffic engineering in a data communication network
US7453884B2 (en) 2000-04-25 2008-11-18 Cisco Technology, Inc. Apparatus and method for scalable and dynamic traffic engineering in a data communication network
US6993048B1 (en) 2000-07-31 2006-01-31 Cisco Technology, Inc. ATM permanent virtual circuit and layer 3 auto-configuration for digital subscriber line customer premises equipment
US7620051B2 (en) 2000-07-31 2009-11-17 Cisco Technology, Inc. ATM permanent virtual circuit and layer 3 auto-configuration for digital subscriber line customer premises equipment
US7864773B2 (en) 2000-07-31 2011-01-04 Cisco Technology, Inc. Virtual circuit auto-configuration for customer premises equipment
US7095741B1 (en) 2000-12-20 2006-08-22 Cisco Technology, Inc. Port isolation for restricting traffic flow on layer 2 switches
US7881296B2 (en) 2000-12-20 2011-02-01 Cisco Technology, Inc. Port isolation for restricting traffic flow on layer 2 switches
US7319668B2 (en) 2001-08-31 2008-01-15 Fujitsu Limited Network system capable of selecting optimal route according to type of transmitted data
US7710959B2 (en) 2006-08-29 2010-05-04 Cisco Technology, Inc. Private VLAN edge across multiple switch modules

Also Published As

Publication number Publication date
US5790546A (en) 1998-08-04
US5485455A (en) 1996-01-16
US5521910A (en) 1996-05-28
EP0746175A3 (en) 1998-02-04
ATE205652T1 (en) 2001-09-15
AU1607895A (en) 1995-08-15
EP0741937B1 (en) 2001-09-12
EP0746176A2 (en) 1996-12-04
AU6190296A (en) 1996-10-03
AU678687B2 (en) 1997-06-05
AU6190396A (en) 1996-10-03
AU681063B2 (en) 1997-08-14
EP0741937A1 (en) 1996-11-13
DE69522666T2 (en) 2002-06-20
US5491694A (en) 1996-02-13
DE69522666D1 (en) 2001-10-18
EP0746175A2 (en) 1996-12-04
AU681062B2 (en) 1997-08-14
EP0746176A3 (en) 1998-02-04
JPH09508509A (en) 1997-08-26

Similar Documents

Publication Publication Date Title
US5521910A (en) Method for determining a best path between two nodes
US6650639B2 (en) Secure fast packet switch having improved memory utilization
Keshav et al. Issues and trends in router design
US6745246B1 (en) Apparatus and method in a network switch for modifying a bandwidth request between a requestor and a router
US5818842A (en) Transparent interconnector of LANs by an ATM network
AU670126B2 (en) Virtual network using asynchronous transfer mode
US5920705A (en) Method and apparatus for dynamically shifting between routing and switching packets in a transmission network
US5892924A (en) Method and apparatus for dynamically shifting between routing and switching packets in a transmission network
McAuley Protocol design for high speed networks
US5754532A (en) Use of multipoint connection services to establish call-tapping points in a switched network
US7327688B2 (en) Digital communications system
US20010012271A1 (en) Improved acknowledgement of bandwidth requests for the block transfer of data
US6289017B1 (en) Method of providing redundancy and load sharing among multiple LECs in an asynchronous mode network
Cisco M
Cisco M
Cisco M
Cisco M
Cisco M
Cisco M
Cisco Troubleshooting Layer 3 Network Connections
EP1216529A1 (en) System and method of scheduling data cells over a variable bandwidth channel
Cisco Troubleshooting Layer 3 Network Connections
Kuhn et al. Current and advanced protocols over ATM: evaluation, implementation and experiences
Taniguchi et al. Architecture and Performance Evaluation for High Speed LAN Internetworking Processors
O'Donohoe A performance analysis of the IEEE 802.6 DQDB metropolitan area network protocol

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AU JP

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 1995908127

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1995908127

Country of ref document: EP

WWG Wipo information: grant in national office

Ref document number: 1995908127

Country of ref document: EP