WO2000001167A2 - Systems and methods for implementing abr with guaranteed mcr - Google Patents

Systems and methods for implementing abr with guaranteed mcr Download PDF

Info

Publication number
WO2000001167A2
WO2000001167A2 PCT/US1999/014500 US9914500W WO0001167A2 WO 2000001167 A2 WO2000001167 A2 WO 2000001167A2 US 9914500 W US9914500 W US 9914500W WO 0001167 A2 WO0001167 A2 WO 0001167A2
Authority
WO
WIPO (PCT)
Prior art keywords
entry
mcr
bitmap
schedule table
cell
Prior art date
Application number
PCT/US1999/014500
Other languages
French (fr)
Other versions
WO2000001167A3 (en
Inventor
Simon Chong
Ryszard Bleszynski
Original Assignee
Softcom Microsystems
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 Softcom Microsystems filed Critical Softcom Microsystems
Priority to AU49613/99A priority Critical patent/AU4961399A/en
Publication of WO2000001167A2 publication Critical patent/WO2000001167A2/en
Publication of WO2000001167A3 publication Critical patent/WO2000001167A3/en

Links

Classifications

    • 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/46Interconnection of networks
    • H04L12/4604LAN interconnection over a backbone network, e.g. Internet, Frame Relay
    • H04L12/4608LAN interconnection over ATM networks
    • 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
    • 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
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/745Address table lookup; Address filtering
    • H04L45/7453Address table lookup; Address filtering using hashing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/24Traffic characterised by specific attributes, e.g. priority or QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/52Queue scheduling by attributing bandwidth to queues
    • H04L47/522Dynamic queue service slot or variable bandwidth allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/52Queue scheduling by attributing bandwidth to queues
    • H04L47/525Queue scheduling by attributing bandwidth to queues by redistribution of residual bandwidth
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/62Queue scheduling characterised by scheduling criteria
    • H04L47/6285Provisions for avoiding starvation of low priority queues
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • H04L49/3081ATM peripheral units, e.g. policing, insertion or extraction
    • H04L49/309Header conversion, routing tables or routing tags
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/90Buffering arrangements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/90Buffering arrangements
    • H04L49/901Buffering arrangements using storage descriptor, e.g. read or write pointers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/90Buffering arrangements
    • H04L49/9084Reactions to storage capacity overflow
    • H04L49/9089Reactions to storage capacity overflow replacing packets in a storage arrangement, e.g. pushout
    • H04L49/9094Arrangements for simultaneous transmit and receive, e.g. simultaneous reading/writing from/to the storage element
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/09Mapping addresses
    • H04L61/10Mapping addresses of different types
    • 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/5614User Network Interface
    • H04L2012/5617Virtual LANs; Emulation of LANs
    • 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
    • H04L2012/5667IP over ATM
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5679Arbitration or scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/08Protocols for interworking; Protocol conversion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/12Protocol engines
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level

Abstract

Systems and methods for maintaining cell transmissions at or above the minimum cell transfer rate for ABR-category VCs. An ABR schedule table (AST) (200) in a memory stores ABR VCs scheduled for transmissions. A pointer (225) to the AST indicates that the ABR VC currently addresses is ready to transmit a cell. The schedule pointer is incremented every cell transmission time. When a cell of a particular VC is sent, the VC is rescheduled in another time slot (100) such that the next cell for that VC is transmitted at close to or equal to that VC's allowed cell transfer rate (ACR) while maintaining its minimum cell transfer rate (MCR). To determine the next time slot in which to reschedule the VC, the system uses an ACR bitmap (250) that compresses the AST and which identifies entries that are not occupied by a VC scheduled for a transmission.

Description

SYSTEMS AND METHODS FOR IMPLEMENTING ABR WITH
GUARANTEED MCR
CROSS-REFERENCES TO RELATED APPLICATIONS This application is related to U.S. Provisional Patent Application Serial No. 60/090, 939, filed June 27, 1998, entitled "Network Accelerator Subsystem Based on Single-Chip Network Processor and Interface Protocol," the disclosure of which is hereby incorporated by reference in its entirety.
BACKGROUND OF THE INVENTION The present invention relates in general to traffic scheduling in networking systems, and more particularly to supporting the Available Bit Rate (ABR) service category with guaranteed Minimum Cell Rate (MCR) transmissions in an Asynchronous Transfer Mode (ATM) networking system.
The need for faster communication among computers and other systems requires ever faster and more efficient networks. Today, networks typically use an amalgam of various software and hardware to implement a variety of network functions and standards. Network devices such as client computer systems, servers, hubs, routers, switches, network backbones, etc., are each complex devices that require digital processing in hardware and software to facilitate network communication. Some tasks performed in a network device include translation between different network standards such as Ethernet and ATM, reformatting data, traffic scheduling, routing data cells, packets messages, etc. Depending on the particular protocol being implemented, some tasks may be performed at different points in the network.
In conventional networking systems that implement ATM, data traffic is handled by a Virtual Channel, or Virtual Connection (VC). There are typically many VCs in each system and each VC has its own characteristics, such as packet type, packet size and protocols. For each VC, a descriptor which identifies the particular VC and its characteristics and requirements is stored in a memory. When a scheduler determines that a particular VC is ready for transmission, the VC descriptor is accessed and processed.
When scheduling transmissions for many VCs, several service categories are typically available, including Constant Bit Rate (CBR), Variable Bit Rate (VBR) and Available Bit Rate (ABR). The ABR category typically has the lowest priority, meaning that one or more CBR or VBR VCs may be transmitted before an ABR VC that is scheduled for transmission. In the ABR service category, a source may send cells at any rate between the Minimum Cell Rate (MCR) and the Allowed cell rate (ACR). Thus, for the ABR service category, it is desirable to transmit cells at rates close to or equal to the ACR for each VC while guaranteeing transmissions at the MCR lower bound rate for each VC.
SUMMARY OF THE INVENTION The present invention provides novel techniques for guaranteeing MCR transmissions for ABR-category VCs. In particular, the techniques of the present invention provide for enhanced scheduling capabilities and increased throughput. According to the invention, systems and methods are provided for maintaining cell transmissions at or above the minimum cell transfer rate for ABR- category VCs. An ABR schedule table (AST) in a memory stores ABR VCs scheduled for transmissions. A pointer to the AST indicates that the ABR VC currently addresses is ready to transmit a cell. The schedule pointer is incremented every cell transmission time. When a cell of a particular VC is sent, the VC is rescheduled in another time slot in the AST such that the next cell for that VC is transmitted at close to or equal to that VCs allowed cell transfer rate (ACR) while maintaining its minimum cell transfer rate (MCR). To determine the next time slot in which to reschedule the VC, the system uses an ACR bitmap that compresses the AST and which identifies entries that are not occupied by a VC scheduled for a transmission. The system determines the time slot in the AST that would allow the VC to be transmitted at its ACR. The system then checks the ACR bitmap to determine whether that ACR slot is unoccupied. If occupied, the system searches the ACR bitmap to locate the next empty slot in the AST. If all slots between the ACR slot and the slot which provides for an MCR transmission for that VC are occupied, the system searches an MCR bitmap, which compresses the AST, to determine which VC occupying the AST between the ACR slot and the MCR slot is to be replaced by the VC being rescheduled. The VC that is replaced is itself rescheduled. In this manner MCR is guaranteed for a VC being rescheduled.
According to an aspect of the invention, a method is provided for maintaining a transmission of cells at a minimum rate or above for each of a plurality of virtual connections (VCs) in a networking system device having a transmitting engine and a transmission schedule table for the plurality of VCs. The schedule table includes a plurality of entries, wherein each entry represents a time interval for transmission of a cell for a VC, and wherein the entries are continuously read in a sequential order to determine which VC is scheduled for a cell transmission during each time interval. The method typically comprises the steps of reading a first entry in the schedule table so as to identify a first VC scheduled for a cell transmission, and transmitting a cell for the first VC. The method also typically includes the step of rescheduling another cell transmission for the first VC based on an available cell rate (ACR) and a minimum cell rate (MCR) allowable for the first VC so as to maintain transmission of cells for the first VC at the MCR rate or above for the first VC.
According to another aspect of the invention, a networking system device coupled to one or more networks is provided. The device typically comprises a local memory for storing a schedule table having a plurality of entries, wherein each entry represents a time interval for transmission of a cell for a VC, and a network processor. The network processor typically includes a first and a second bitmap, each including a plurality of entries, wherein each first and second bitmap entry corresponds to an entry in the schedule table, wherein each first bitmap entry identifies whether the corresponding entry in the schedule table is occupied by a VC, and wherein each second bitmap entry identifies whether any VC occupying the corresponding entry in the schedule table has a minimum cell rate. (MCR). The network processor also typically includes a transmit processor, coupled to the local memory and the first and second bitmaps, wherein the transmit processor reads a first entry in the schedule table to identify a first VC scheduled for a cell transmission, wherein the transmit processor transmits a cell for the first VC, and wherein the transmit processor reschedules another cell transmission for the first VC in the schedule table based on an available cell rate (ACR) and an MCR allowable for the first VC so as to maintain transmission of cells for the first VC at the MCR or above for the first VC. Reference to the remaining portions of the specification, including the drawings and claims, will realize other features and advantages of the present invention. Further features and advantages of the present invention, as well as the structure and operation of various embodiments of the present invention, are described in detail below with respect to the accompanying drawings. In the drawings, like reference numbers indicate identical or functionally similar elements.
BRIEF DESCRIPTION OF THE DRAWINGS Figure 1 is a block diagram of the architecture of a network processing engine according to an embodiment of the present invention;
Figure 2 is a simplified diagram of a timing wheel representative of a traffic scheduling technique according to an embodiment of the present invention;
Figure 3 a shows an ABR schedule table and an associated ACR bitmap according to an embodiment of the present invention; Figure 3b shows the ABR schedule table and an associated MCR bitmap according to an embodiment of the present invention;
Figure 4 shows an example of a VC being rescheduled when the MCR for the VC being rescheduled is not equal to 0 according to an embodiment of the present invention; and Figure 5 shows an example of a VC being rescheduled when the MCR for the VC being rescheduled is equal to 0 according to an embodiment of the present invention.
DESCRIPTION OF THE SPECIFIC EMBODIMENTS Figμre 1 is a block diagram of the architecture of a network processing engine 10 according to an embodiment of the present invention. In preferred aspects, the network processing engine of the present invention is useful for a variety of network communications applications including implementation in multi-protocol network interface cards (NICs), server NICs, workgroup, IP and ATM switches, multi-protocol and IP routers, ATM backbone switch applications, multi-protocol and multi-protocol
/ATM adapters and the like. In preferred aspects, all components of processing engine 10 reside on a single chip (e.g., a single silicon chip), but all components may be spread across many chips such that processing engine 10 is implemented using many chips. Processing engine 10 includes a local memory interface block 15, UTOPIA interface 20, Direct Memory Access Controller (DMAC) 25, PCI interface 30, first internal bus 40, second internal bus 45, third internal bus 50, and cell bus 55. Processing engine 10 also includes an internal memory 80 and a receiver block 60 and a transmitter block 70 for processing incoming and outgoing data transmissions, respectively, over a communications interface, such as UTOPIA interface 20. Local memory interface block 15 provides a connection to a local, off-chip system memory, such as DRAM, SRAM, SDRAM, SSRAM or any combination thereof. DMAC 25 provides control of data transfers between external memories (PCI), internal memory 80 and the local memory. Internal memory 80 is used in one embodiment to store VC descriptors on-chip for fast access of the VC descriptors. Additionally, in one embodiment, internal memory 80 stores ACR and MCR bitmaps to provide enhanced traffic scheduling capabilities as will be described below in more detail.
PCI interface 30 provides a connection to external intelligence, such as a host computer system, and external packet memories. First and second internal buses 40 and 45 in one embodiment are non-multiplexed 32 bit address and 64 bit data buses. Depending on the desired line rate, PCI interface 30 is configured to run at frequencies up to 33MHz over a 32 bit PCI bus, or at frequencies up to 66MHz over a 64 bit PCI bus. For example, to achieve a 622 Mbps line rate, a 64 bit interface is used with frequencies up to 66MHz. UTOPIA interface 20 supports connections to a broad range of layer 1 physical interfaces, including, for example, OC-1, OC-3, OC-12, OC-48, OC-192 and DS-3 interfaces and the like. To support a 622Mbps line rate, the UTOPIA data bus is 16 bits, whereas for a 155Mbps line rate the UTOPIA bus is 8 bits. Third internal data bus 50 is an 8 or 16 bit UTOPIA compatible interface. Cell bus 55 is a 64 bit data path and is used to transfer cells or frames between internal cell frame buffers of receiver block 60 and transmitter block 70 and the PCI memory space through DMAC 25. Cell bus 55 allows several transactions to occur in parallel. For example, data payload transfers and descriptor data movement may occur simultaneously. Additionally, for a 622 Mbps line rate, cell bus 55 is capable of off-loading up to 160MBps of bandwidth from local memory.
Figure 2 is a simplified diagram of a timing wheel 100 representative of a traffic scheduling technique according to an embodiment of the present invention. In preferred aspects, timing wheel 100 is physically represented as a table of ABR VCs in local memory 80 as will be described in more detail below. In this implementation, a schedule pointer (not shown) pointing to the table indicates that the VC identified in the table entry currently addressed is ready to transmit a cell. In one embodiment, the " schedule pointer is implemented in a separate scheduler module (not shown) connected to transmit engine 70. Alternately, the schedule pointer and scheduler are implemented as part of transmitter engine 70. Each entry, t - ts, represents a time interval for transmission of a cell by transmitter engine 70. Referring to Figure 2, assume that the schedule pointer points to the entry to, which identifies VC0. Information about VCo is communicated to transmitter engine 70 and transmitter engine proceeds to transmit a cell for VC0. Additionally, the schedule pointer is incremented to point to the next entry, in this case entry tls which identifies VC\. The schedule pointer is incremented every time interval to point to the next entry in the table. When the last entry, ts, is reached, the schedule pointer is incremented to point to the beginning entry, i.e., the process is repeated beginning at the first entry, t0. Depending on the line rates used, the time interval will vary accordingly. For example, for an OC-12 line rate, the schedule pointer will be incremented every 675ns, and for an OC-3 line rate, the schedule pointer is incremented every 2.7μs.
After a cell for a particular VC has been transmitted by transmitter engine 70, that particular VC is rescheduled for another transmission. The next time slot (i.e., time that a cell may be sent) for that particular VC is scheduled by computing how far down the schedule table (i.e., where on the timing wheel) the particular VC should be written. The computation is based on the ACR and the MCR for that particular VC and on the line rate, for example a 2.7μs or a 675ns time interval per entry, such that cells are sent at rates close to or equal to the ACR while maintaining the MCR lower bound. The MCR and ACR for each VC are generally negotiated between the end- systems and the network(s). The ACR is a rate negotiated such that the actual cell rate sent by the end-system on the ABR connection need never exceed the ACR. The MCR is a rate negotiated such that the actual cell rate sent by the end-system on the ABR connection is not less than the MCR. The MCR agreed to between the end-systems and the network(s) carrying the connection may range from 0 to the maximum value supported by the network(s). However, it is preferred that the actual cell rate is not less than about 1 cell per second when the MCR is equal to 0. In one embodiment, the ACR and MCR information is received by the network processor 10 in a resource management (RM) cell as is well known. Each time a backward RM cell arrives, the receiver engine 60 buffers the RM cell in local memory or in internal memory 80. The RM cells are processed to determine if a rate change is necessary. Rate change information is provided in the RM cells.
Figures 3a and 3b show an ABR schedule table 200 and an associated ACR bitmap 250 and an associated MCR bitmap 260, respectively, according to an embodiment of the present invention. As shown, each entry 202 in the schedule table preferably includes a Val field 205, an MCR field 210, a Kick field 215, a Skip field 220 and a VC Descriptor Pointer (VCD#) field 225. Val field 205 includes a valid bit that indicates whether the entry is valid; e.g., if a VC is scheduled in the entry, the valid bit is set to 1, and if there is no VC scheduled in the entry, the valid bit is set to 0. VCD# field 225 includes the transmit descriptor pointer, which identifies the particular VC that is scheduled for a transmission in the time slot. The transmit descriptor pointer is used by transmitter engine 70 to access and process the identified VC descriptor from internal memory 80 or local memory. Skip field 220 indicates the number of rotations in the time wheel that the identified VC is to be skipped before the identified VC is ready for transmission. Kick field 215 indicates whether the identified VC is able to be kicked out of the time slot. MCR field 210 is used to indicate whether the identified VC has an MCR. MCR field 210 includes an MCR bit which is set to 0 if the MCR for the identified VC is 0. Otherwise, the MCR bit is set to 1 if the identified VC has an MCR different from O.
With reference to Figure 3a, each of the entries, 202ι to 202j, in schedule table 200 has a corresponding entry in ACR bitmap 250. For each entry 202 in ABR schedule table 20Q, the corresponding bit in ACR bitmap 250 indicates whether the entry (i.e., slot on time wheel 100) is empty or not. If an entry is empty, which means that there is no VC scheduled in that slot, the corresponding value in ACR bitmap is 0. If an entry is occupied, indicating that a VC is scheduled for a transmission in that slot, the corresponding value in the ACR bitmap is 1. With reference to Figure 3b, each of the entries, 202] to 202;, in schedule table 200 also has a corresponding entry in MCR bitmap 260. The corresponding bit in MCR bitmap 260 indicates whether the associated VC is kickable. Generally, if the MCR bit is 0, the VC can be kicked out of the schedule table slot, and if the MCR bit is 1, the VC cannot be kicked out. In preferred aspects, a VC can be kicked out of the time slot only when the associated Skip value is not equal to 0.
In preferred aspects, ACR bitmap 250 and MCR bitmap 260 are implemented in internal memory 80 for fast access and processing. The memory space required for each bitmap is relatively small, as each entry in the schedule table requires only 1 bit in each bitmap.
In operation, every time the schedule pointer is incremented to point to the next entry in ABR schedule table 200, the corresponding bit in ACR bitmap 250 is read. If the bit in ACR bitmap 250 is set to 1, the system reads the ABR schedule table entry from local memory and checks the Skip field. If the Skip field is not equal to 0, indicating that the identified VC is not ready for a cell transmission, the Skip value is subtracted by 1 and the ABR schedule table entry is written back to local memory. If the value of the Skip field is 0, it is time for a transmission for the identified VC. Transmitter engine 70 proceeds to transmit a cell for the identified VC. After a cell transmission has occurred for the identified VC, the system reschedules the VC according to the ACR and MCR for that particular VC.
After the transmission of a cell for a VC, transmitter engine 70 reschedules the VC based on the ACR and the MCR for that VC. It is desirable that the actual cell transfer rate (ACTR) is as close to the ACR as possible. For each VC, the system (e.g., a processor portion of transmitter engine 70 or a local host processor) determines a number, S, of time slots required to place the VC for its next transmission time, where S is defined by the equation ts+i - ts = ACR * line rate. For example, for an OC-12 line rate, ts+i - ts = ACR * 675ns. Once S is computed, transmitter engine 70 checks ACR bitmap 250 to determine if the identified time slot is available. Generally, S is equal to the number of time slots that proyides transmissions at the ACR. The time slot is not available if another VC occupies the time slot.
According to the invention, the system checks ACR bitmap 250 to determine if the time slot identified by S is available. If the slot is not available, ACR bitmap 250 is searched for the next available time slot. In general, if there is at least one available time slot between the ACR value and the MCR value, the VC is scheduled in that time slot. The original ACR bitmap and MCR bitmap bit locations associated with the VC being rescheduled are cleared and the new bit location in ACR bitmap 250 corresponding to the slot filled by the VC being rescheduled is set to 1. The new location in MCR bitmap 260 corresponding to the slot filled by the VC being rescheduled is set only if that VC is kickable. Also, the entry for the VC being rescheduled in schedule table 200 is moved to the new position and updated accordingly.
When the time slot identified by S in the time wheel is not available, the search algorithm finds the next available slot. Suppose, however, that the next available slot is 100 positions away from the slot identified by S. If the next cell sent out 6.75μ (100 * 675ns, with an OC-12 line rate) later than the current ACTR rate, the MCR may be violated. According to an embodiment of the present invention, when the MCR field 210 in schedule table 200 is not equal to 0 for the VC being rescheduled, a second parameter, SM, is computed by substituting the MCR value into the rate equation: tsM+i - sM = MCR * cell rate. The MCR bitmap row and column values are written by the processor into the row and column values. During the search for the next available slot, a condition is provided that the search does not go beyond the limitation of the MCR. If the ACR row and column numbers are not equal to the MCR row and column numbers, the search continues. However, if the ACR row and column numbers are equal to the MCR row and column numbers, the search stops and the processor is interrupted with an error condition that the MCR guarantee has been violated. An example of pseudocode for this condition is as follows: if ACTR[Rx,Cy] ≠ MCTR[Rx,Cy] Then search continues
Else, if ACR[Rx,Cy] = MCR[Rx,Cy]
Then search ends and interrupt generated.
The use of Kick field 215 now becomes apparent. Kick field 215 guards against the case where the same VC is repeatedly kicked out. When a VC is kicked out of a slot, the VC is placed in another slot with its Kick field value incremented by 1. When the kick field reaches a predefined value, this VC cannot be kicked out again. In one embodiment, the predefined value is programmable based on the number of times around the timing wheel, which is determined based on the rate of the physical layer interface (e.g., OC-3, OC-12, OC-48 and OC-192) and the size of the timing wheel RAM. Figures 4 and 5 show examples of a VC being rescheduled (VCw in the
Figures) when the VC being rescheduled is not equal to 0, and equal to 0, respectively. With reference to Figure 4, if all slots between the ACR value and the MCR value for the VC being rescheduled are occupied, and if the MCR field 210 for this VC is equal to 1 (indicating that the VC being rescheduled has an MCR requirement and cannot be kicked), the system searches MCR bitmap 260 to determine if any of the VCs occupying the slots between the ACR value and the MCR value are able to be kicked out. Preferably the first entry found that is equal to 0 in MCR bitmap 260 between the ACR value and MCR value is kicked. Preferably, as shown in Figure 4, the VC being rescheduled (VCw) swaps positions with the kickable VC (VCA) identified in MCR bitmap 260. Because both slots are occupied, no change is necessary in ACR bitmap 250. However, the two corresponding slots in MCR bitmap 260 must be recalculated to guarantee that any VC with an MCR not equal to 0 will not have its lower bound cell transfer rate violated. With reference to Figure 5, if all slots between the ACR value and the
MCR value for the VC being rescheduled are occupied, and if the MCR field 210 for this VC is equal to 0 (indicating that the VC being rescheduled has no MCR requirement and can be kicked), the system searches MCR bitmap 260 to determine if any of the slots beyond the MCR value are empty. As shown in Figure 5, the VC being rescheduled (VCw) is rescheduled in the first available slot. In this case, the original ACR bitmap and MCR bitmap bit locations associated with VCw are cleared and the new bit location in ACR bitmap 250 corresponding to the slot filled by VCw is set to 1. In the worst case scenario, VCw stays in the same time slot.
While the invention has been described by way of example and in terms of the specific embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. To the contrary, it is intended to cover various modifications and similar arrangements as would be apparent to those skilled in the art. Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.

Claims

WHAT IS CLAIMED IS: 1. A method of maintaining a transmission of cells at a minimum rate or above for each of a plurality of virtual connections (VCs) in a networking system ~ " device having a transmitting engine and a transmission schedule table for the plurality of VCs, the schedule table including a plurality of entries, wherein each entry represents a time interval for transmission of a cell for a VC, and wherein the entries are continuously read in a sequential order to determine which VC is scheduled for a cell transmission during each time interval, the method comprising the steps of: reading a first entry in the schedule table so as to identify a first VC scheduled for a cell transmission; transmitting a cell for the first VC; and rescheduling another cell transmission for the first VC based on an available cell rate (ACR) and a minimum cell rate (MCR) allowable for the first VC so as to maintain transmission of cells for the first VC at said (MCR) rate or above.
2. The method of claim 1, further comprising the steps of: pointing to the first entry in the schedule table with a schedule pointer; and continuously updating the schedule pointer to point to the next sequential entry after each time interval has elapsed.
3. The method of claim 1, wherein said step of rescheduling includes the step of determining a second entry in the schedule table in which to write the first VC based on the ACR and the MCR allowable for the first VC.
4. .. The method of claim 3, wherein said step of determining a second entry includes computing a parameter S, wherein S defines a number of entries from the first entry to the second entry.
1 5. The method of claim 4, wherein the first VC has a line rate, and wherein S is computed using the equation ts+i - ts = ACR * line rate.
6. The method of claim 3, wherein said step of rescheduling includes the step of writing the first VC to the second entry so as to maintain transmission of cells for the first VC at said MCR or above.
7. The method of claim 3, wherein said step of determining a second entry includes accessing an ACR bitmap to determine whether the second entry is occupied by a second VC, wherein each ACR bitmap entry corresponds to an entry in the schedule table.
8. The method of claim 7, wherein if the second entry is occupied by a second VC, the method further includes the step of searching the ACR bitmap beyond the second entry to locate an unoccupied entry.
9. The method of claim 8, further comprising the step of rescheduling the first VC to the schedule table entry corresponding to the first unoccupied entry found in the ACR bitmap.
10. The method of claim 8, wherein if all entries between the second entry and an MCR entry are full, the method further includes the step of searching an MCR bitmap in sequence from the second entry to the MCR entry to determine whether an entry includes a VC that is kickable, wherein each MCR bitmap entry corresponds to an entry in the schedule table.
11. The method of claim 10, further including the steps of rescheduling the first VC in the schedule table entry corresponding to the first identified entry in the MCR bitmap thatjncludes a VC that is kickable, and rescheduling the identified VC to another entry.
12. A networking system device coupled to one or more networks, the device comprising: a local memory for storing a schedule table having a plurality of entries, wherein each entry represents a time interval for transmission of a cell for a VC; and a first bitmap including a plurality of entries, wherein each first bitmap entry corresponds to an entry in the schedule table, and wherein each first bitmap entry identifies whether the corresponding entry in the schedule table is occupied by a VC; a second bitmap including a plurality of entries, wherein each second " bitmap entry corresponds to an entry in the schedule table, and wherein each second bitmap entry identifies whether any VC occupying the corresponding entry in the schedule table has a minimum cell rate (MCR); and a transmit processor, coupled to the local memory and the first and second bitmaps, wherein the transmit processor reads a first entry in the schedule table to identify a first VC scheduled for a cell transmission, wherein the transmit processor transmits a - cell for the first VC, and wherein the transmit processor reschedules another cell transmission for the first VC in the schedule table based on an available cell rate (ACR) and an MCR allowable for the first VC so as to maintain transmission of cells for the first VC at said MCR or above for the first VC.
13. The device of claim 12, wherein the first and second bitmaps and the transmit processor are implemented together on a single chip.
14. The device of claim 12, wherein the first and second bitmaps are implemented in a random access memory (RAM).
15. The device of claim 12, further including a scheduler having a pointer that points to an entry in the schedule table, wherein the scheduler continuously updates the pointer to point to the next sequential entry after each time interval has elapsed, and wherein the scheduler communicates to which entry the pointer is pointing to the transmit processor.
16. The device of claim 12, wherein the transmit processor includes a means for determining a second entry in the schedule table in which to write the first VC based on the ACR and the MCR allowable for the first VC.
17. The device of claim 16, wherein the determining means includes means for computing a parameter S, wherein S defines a number of entries from the first entry to the second entry.
18. The device of claim 17, wherein the first VC has a line rate, and wherein S is computed using the equation ts+i - ts = ACR * line rate.
19. The device of claim 16, wherein the determining means includes means for searching the first bitmap to determine whether the second entry is occupied by a second VC.
20. The device of claim 19, wherein if the second entry is occupied by a second VC, the transmit processor searches the first bitmap beyond the second entry to locate an unoccupied entry.
21. The device of claim 20, wherein the transmit processor reschedules the first VC to the schedule table entry corresponding to the first unoccupied entry found in the first bitmap.
22. The device of claim 20, wherein the transmit processor searches the second bitmap in sequence from the second entry to the MCR entry if all entries in the schedule table between the second entry and an MCR entry are occupied so as to determine whether an entry includes a VC that is kickable.
23. The device of claim 22, wherein the transmit processor reschedules the first VC in the schedule table entry corresponding to the first identified entry in the second bitmap that includes a VC that is kickable, and wherein the transmit processor reschedules the kickable VC to another entry.
PCT/US1999/014500 1998-06-27 1999-06-25 Systems and methods for implementing abr with guaranteed mcr WO2000001167A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU49613/99A AU4961399A (en) 1998-06-27 1999-06-25 Systems and methods for implementing abr with guaranteed mcr

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US9093998P 1998-06-27 1998-06-27
US60/090,939 1998-06-27
US09/335,223 US6657959B1 (en) 1998-06-27 1999-06-17 Systems and methods for implementing ABR with guaranteed MCR
US09/335,223 1999-06-17

Publications (2)

Publication Number Publication Date
WO2000001167A2 true WO2000001167A2 (en) 2000-01-06
WO2000001167A3 WO2000001167A3 (en) 2000-02-24

Family

ID=26782805

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/014500 WO2000001167A2 (en) 1998-06-27 1999-06-25 Systems and methods for implementing abr with guaranteed mcr

Country Status (3)

Country Link
US (1) US6657959B1 (en)
AU (1) AU4961399A (en)
WO (1) WO2000001167A2 (en)

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7006514B2 (en) * 2001-05-31 2006-02-28 Polytechnic University Pipelined maximal-sized matching cell dispatch scheduling
USRE42600E1 (en) * 2000-11-20 2011-08-09 Polytechnic University Scheduling the dispatch of cells in non-empty virtual output queues of multistage switches using a pipelined arbitration scheme
US7103056B2 (en) * 2000-11-20 2006-09-05 Polytechnic University Scheduling the dispatch of cells in multistage switches using a hierarchical arbitration scheme for matching non-empty virtual output queues of a module with outgoing links of the module
US20050010676A1 (en) * 2003-06-30 2005-01-13 Muthaiah Venkatachalam Time-based transmission queue for traffic management of asynchronous transfer mode virtual circuits on a multi-threaded, multi-processor system
US7339923B2 (en) * 2003-10-31 2008-03-04 Rivulet Communications, Inc. Endpoint packet scheduling system
US7453885B2 (en) * 2004-10-13 2008-11-18 Rivulet Communications, Inc. Network connection device
CN100449504C (en) * 2005-01-05 2009-01-07 华为技术有限公司 Buffer management based on bitmap list
US8687628B2 (en) * 2006-03-16 2014-04-01 Rockstar Consortium USLP Scalable balanced switches
US9021095B2 (en) 2011-05-27 2015-04-28 Oracle International Corporation Method and system for implementing an on-demand scheduler in a mobile device
US8700656B2 (en) * 2011-05-27 2014-04-15 Oracle International Corporation Method and system for implementing an on-demand scheduler
US9165011B2 (en) 2011-09-30 2015-10-20 Oracle International Corporation Concurrent calculation of resource qualification and availability using text search

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5555256A (en) * 1994-04-28 1996-09-10 Hewlett-Packard Company Channel identifier generation
US5754530A (en) * 1996-04-18 1998-05-19 Northern Telecom Limited Flow control of ABR traffic in ATM networks

Family Cites Families (95)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB1499184A (en) 1974-04-13 1978-01-25 Mathematik & Datenverarbeitung Circuit arrangement for monitoring the state of memory segments
US4700294A (en) 1982-10-15 1987-10-13 Becton Dickinson And Company Data storage system having means for compressing input data from sets of correlated parameters
SE448919B (en) 1983-03-04 1987-03-23 Ibm Svenska Ab METHOD FOR TRANSFERING INFORMATION DEVICES IN A COMPUTER NETWORK, AND COMPUTER NETWORK FOR IMPLEMENTATION OF THE METHOD
US5287537A (en) 1985-11-15 1994-02-15 Data General Corporation Distributed processing system having plural computers each using identical retaining information to identify another computer for executing a received command
FR2645986B1 (en) 1989-04-13 1994-06-17 Bull Sa METHOD FOR ACCELERATING MEMORY ACCESS OF A COMPUTER SYSTEM AND SYSTEM FOR IMPLEMENTING THE METHOD
US5473772A (en) 1991-04-02 1995-12-05 International Business Machines Corporation Automatic update of static and dynamic files at a remote network node in response to calls issued by or for application programs
DE59108304D1 (en) 1991-08-27 1996-11-28 Siemens Ag Arrangement for bit rate monitoring in ATM networks
US5379297A (en) 1992-04-09 1995-01-03 Network Equipment Technologies, Inc. Concurrent multi-channel segmentation and reassembly processors for asynchronous transfer mode
DE69226088T2 (en) 1991-11-08 1999-02-11 Teledesic Llc A Delaware Limit MEDIATION METHOD AND DEVICE FOR A SATELLITE COMMUNICATION SYSTEM
GB9205551D0 (en) 1992-03-13 1992-04-29 Inmos Ltd Cache memory
US5825765A (en) 1992-03-31 1998-10-20 Fore Systems, Inc. Communication network based on ATM for general purpose computers
JPH066362A (en) 1992-06-23 1994-01-14 Hitachi Ltd Message processing load distribution system for host system in lan
US6233702B1 (en) 1992-12-17 2001-05-15 Compaq Computer Corporation Self-checked, lock step processor pairs
US5619650A (en) 1992-12-31 1997-04-08 International Business Machines Corporation Network processor for transforming a message transported from an I/O channel to a network by adding a message identifier and then converting the message
US5684954A (en) 1993-03-20 1997-11-04 International Business Machine Corp. Method and apparatus for providing connection identifier by concatenating CAM's addresses at which containing matched protocol information extracted from multiple protocol header
US5867712A (en) 1993-04-05 1999-02-02 Shaw; Venson M. Single chip integrated circuit system architecture for document instruction set computing
US5394402A (en) 1993-06-17 1995-02-28 Ascom Timeplex Trading Ag Hub for segmented virtual local area network with shared media access
US5802287A (en) 1993-10-20 1998-09-01 Lsi Logic Corporation Single chip universal protocol multi-function ATM network interface
US5640399A (en) 1993-10-20 1997-06-17 Lsi Logic Corporation Single chip network router
US5481536A (en) 1993-10-29 1996-01-02 Siemens Aktiengesellschaft Method for restoring a prescribed sequence for unordered cell streams in ATM switching technology
US5524110A (en) 1993-11-24 1996-06-04 Intel Corporation Conferencing over multiple transports
US5414707A (en) 1993-12-01 1995-05-09 Bell Communications Research, Inc. Broadband ISDN processing method and system
JP3169155B2 (en) 1993-12-22 2001-05-21 インターナショナル・ビジネス・マシーンズ・コーポレ−ション Circuit for caching information
US5974457A (en) 1993-12-23 1999-10-26 International Business Machines Corporation Intelligent realtime monitoring of data traffic
JP3354689B2 (en) 1994-02-28 2002-12-09 富士通株式会社 ATM exchange, exchange and switching path setting method thereof
US5652872A (en) 1994-03-08 1997-07-29 Exponential Technology, Inc. Translator having segment bounds encoding for storage in a TLB
US5515370A (en) 1994-03-31 1996-05-07 Siemens Aktiengesellschaft Circuit arrangement for line units of an ATM switching equipment
JP3740195B2 (en) 1994-09-09 2006-02-01 株式会社ルネサステクノロジ Data processing device
US5539729A (en) 1994-12-09 1996-07-23 At&T Corp. Method for overload control in a packet switch that processes packet streams having different priority levels
KR0132959B1 (en) 1994-12-22 1998-04-21 양승택 No-connection type server for service thereof in atm network
JPH08186585A (en) 1995-01-05 1996-07-16 Fujitsu Ltd Atm switchboard
US5857075A (en) 1995-01-11 1999-01-05 Sony Corporation Method and integrated circuit for high-bandwidth network server interfacing to a local area network
US5764895A (en) 1995-01-11 1998-06-09 Sony Corporation Method and apparatus for directing data packets in a local area network device having a plurality of ports interconnected by a high-speed communication bus
US5943693A (en) 1995-03-29 1999-08-24 Intel Corporation Algorithmic array mapping to decrease defect sensitivity of memory devices
US5659794A (en) 1995-03-31 1997-08-19 Unisys Corporation System architecture for improved network input/output processing
US5684797A (en) 1995-04-05 1997-11-04 International Business Machines Corporation ATM cell multicasting method and apparatus
US5535201A (en) 1995-05-10 1996-07-09 Mitsubishi Electric Research Laboratories, Inc. Traffic shaping system using two dimensional timing chains
EP1686742B1 (en) * 1995-06-05 2008-10-01 NEC Electronics Corporation Communiction control device and method for an ATM system applicable to an ABR mode
US5638371A (en) 1995-06-27 1997-06-10 Nec Usa, Inc. Multiservices medium access control protocol for wireless ATM system
EP0752664A3 (en) 1995-07-07 2006-04-05 Sun Microsystems, Inc. Method and apparatus for reporting data transfer between hardware and software
US5664116A (en) 1995-07-07 1997-09-02 Sun Microsystems, Inc. Buffering of data for transmission in a computer communication system interface
US5805805A (en) 1995-08-04 1998-09-08 At&T Corp. Symmetric method and apparatus for interconnecting emulated lans
US5751951A (en) 1995-10-30 1998-05-12 Mitsubishi Electric Information Technology Center America, Inc. Network interface
CA2186795A1 (en) 1995-11-17 1997-05-18 Cormac John Sreenan Resource management system for a broadband multipoint bridge
US5826030A (en) 1995-11-30 1998-10-20 Excel Switching Corporation Telecommunication switch having a universal API with a single call processing message including user-definable data and response message each having a generic format
KR0157152B1 (en) 1995-12-23 1998-11-16 양승택 Apparatus with expansibility for processing atm layer function
US5751709A (en) * 1995-12-28 1998-05-12 Lucent Technologies Inc. Adaptive time slot scheduling apparatus and method for end-points in an ATM network
US5745477A (en) * 1996-01-25 1998-04-28 Mitsubishi Electric Information Technology Center America, Inc. Traffic shaping and ABR flow control
US5696930A (en) 1996-02-09 1997-12-09 Advanced Micro Devices, Inc. CAM accelerated buffer management
US6021263A (en) 1996-02-16 2000-02-01 Lucent Technologies, Inc. Management of ATM virtual circuits with resources reservation protocol
US5841772A (en) 1996-03-07 1998-11-24 Lsi Logic Corporation ATM communication system interconnect/termination unit
US5848068A (en) 1996-03-07 1998-12-08 Lsi Logic Corporation ATM communication system interconnect/termination unit
US5870561A (en) 1996-03-15 1999-02-09 Novell, Inc. Network traffic manager server for providing policy-based recommendations to clients
US5740171A (en) 1996-03-28 1998-04-14 Cisco Systems, Inc. Address translation mechanism for a high-performance network switch
US5768527A (en) 1996-04-23 1998-06-16 Motorola, Inc. Device, system and method of real-time multimedia streaming
US5748630A (en) 1996-05-09 1998-05-05 Maker Communications, Inc. Asynchronous transfer mode cell processing system with load multiple instruction and memory write-back
US5764896A (en) 1996-06-28 1998-06-09 Compaq Computer Corporation Method and system for reducing transfer latency when transferring data from a network to a computer system
US5991854A (en) 1996-07-01 1999-11-23 Sun Microsystems, Inc. Circuit and method for address translation, using update and flush control circuits
US5983332A (en) 1996-07-01 1999-11-09 Sun Microsystems, Inc. Asynchronous transfer mode (ATM) segmentation and reassembly unit virtual address translation unit architecture
US5912892A (en) 1996-08-30 1999-06-15 Hughes Electronics Corporation Method of providing fractional path service on an ATM network
US5956336A (en) 1996-09-27 1999-09-21 Motorola, Inc. Apparatus and method for concurrent search content addressable memory circuit
US6005943A (en) 1996-10-29 1999-12-21 Lucent Technologies Inc. Electronic identifiers for network terminal devices
JPH10136439A (en) 1996-10-30 1998-05-22 Fujitsu Ltd Mobile communication system, mobile terminal, base station, mobile exchange and mobile communication controlling method
US5878232A (en) 1996-12-27 1999-03-02 Compaq Computer Corporation Dynamic reconfiguration of network device's virtual LANs using the root identifiers and root ports determined by a spanning tree procedure
GB2324000B (en) 1997-01-17 1999-03-24 Dipak Mohan Lal Soni A hybrid distributed broadcast and unknown server for emulated local area networks
GB2322761B (en) 1997-01-17 1999-02-10 Donal Casey Method for selecting virtual channels based on address p;riority in an asynchronous transfer mode device
US6337863B1 (en) 1997-01-17 2002-01-08 Alcatel Interworking, Inc. Seamless communication service with intelligent edge devices
EP0866630A1 (en) 1997-02-14 1998-09-23 Nec Corporation ATM network with a filtering table for securing communication
US5935249A (en) 1997-02-26 1999-08-10 Sun Microsystems, Inc. Mechanism for embedding network based control systems in a local network interface device
JPH10242990A (en) 1997-02-28 1998-09-11 Nec Commun Syst Ltd Communication system for lec bridge device
JP3545570B2 (en) 1997-03-18 2004-07-21 富士通株式会社 Switching hub
US5974462A (en) 1997-03-28 1999-10-26 International Business Machines Corporation Method and apparatus for controlling the number of servers in a client/server system
US5909441A (en) 1997-04-11 1999-06-01 International Business Machines Corporation Apparatus and method for reducing frame loss in route switched networks
US6041059A (en) * 1997-04-25 2000-03-21 Mmc Networks, Inc. Time-wheel ATM cell scheduling
US6052383A (en) 1997-05-29 2000-04-18 3Com Corporation LAN to ATM backbone switch module
US6223292B1 (en) 1997-07-15 2001-04-24 Microsoft Corporation Authorization systems, methods, and computer program products
US6104700A (en) 1997-08-29 2000-08-15 Extreme Networks Policy based quality of service
US5978951A (en) 1997-09-11 1999-11-02 3Com Corporation High speed cache management unit for use in a bridge/router
US6167049A (en) * 1997-11-18 2000-12-26 Cabletron Systems, Inc. Non-zero minimum cell rate for available bit rate ATM service
US6198751B1 (en) 1997-11-19 2001-03-06 Cabletron Systems, Inc. Multi-protocol packet translator
US6003027A (en) 1997-11-21 1999-12-14 International Business Machines Corporation System and method for determining confidence levels for the results of a categorization system
US6058434A (en) 1997-11-26 2000-05-02 Acuity Imaging, Llc Apparent network interface for and between embedded and host processors
CN1157960C (en) 1997-12-12 2004-07-14 美国阿尔卡塔尔资源有限合伙公司 Telecommunication platform system and method
US6119170A (en) 1997-12-29 2000-09-12 Bull Hn Information Systems Inc. Method and apparatus for TCP/IP multihoming on a host system configured with multiple independent transport provider systems
US6154776A (en) 1998-03-20 2000-11-28 Sun Microsystems, Inc. Quality of service allocation on a network
US6201971B1 (en) 1998-03-26 2001-03-13 Nokia Mobile Phones Ltd. Apparatus, and associated method for controlling service degradation performance of communications in a radio communication system
US6073175A (en) 1998-04-27 2000-06-06 International Business Machines Corporation Method for supporting different service levels in a network using web page content information
US6144996A (en) 1998-05-13 2000-11-07 Compaq Computer Corporation Method and apparatus for providing a guaranteed minimum level of performance for content delivery over a network
US6311212B1 (en) 1998-06-27 2001-10-30 Intel Corporation Systems and methods for on-chip storage of virtual connection descriptors
US6425067B1 (en) 1998-06-27 2002-07-23 Intel Corporation Systems and methods for implementing pointer management
US6272544B1 (en) 1998-09-08 2001-08-07 Avaya Technology Corp Dynamically assigning priorities for the allocation of server resources to completing classes of work based upon achievement of server level goals
US6452923B1 (en) 1998-12-31 2002-09-17 At&T Corp Cable connected wan interconnectivity services for corporate telecommuters
US6195697B1 (en) 1999-06-02 2001-02-27 Ac Properties B.V. System, method and article of manufacture for providing a customer interface in a hybrid network
US6147975A (en) 1999-06-02 2000-11-14 Ac Properties B.V. System, method and article of manufacture of a proactive threhold manager in a hybrid communication system architecture
US6343078B1 (en) 2000-05-12 2002-01-29 3Com Corporation Compression of forwarding decisions in a network device

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5555256A (en) * 1994-04-28 1996-09-10 Hewlett-Packard Company Channel identifier generation
US5754530A (en) * 1996-04-18 1998-05-19 Northern Telecom Limited Flow control of ABR traffic in ATM networks

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
BENMOHAMED L. ET AL: 'A Control-theoretic ABR Explicit Rate Algorithm for ATM Switches with per-VC Queueing' INFOCOMM '98 IEEE vol. 1, April 1998, pages 183 - 191, XP002924502 *
CHIUSSI F. ET AL: 'Virtual Queueing Techniques for ABR Service: Improving ABR/V BR Interaction' INFOCOMM '97 IEEE vol. 2, April 1997, pages 406 - 418, XP002924503 *
GHANI N. ET AL: 'Hierarchial Scheduling for Integrated ABR/VBR Services in ATM Networks' GLOBECOMM '97 IEEE vol. 2, November 1997, pages 779 - 784, XP002924504 *
LIN D.: 'Constant-time Dynamic ATM Bandwidth Scheduling for Quaranteed and Best Effort Services with Overbooking' INFOCOMM '97 IEEE vol. 2, April 1997, pages 398 - 405, XP002924501 *

Also Published As

Publication number Publication date
WO2000001167A3 (en) 2000-02-24
US6657959B1 (en) 2003-12-02
AU4961399A (en) 2000-01-17

Similar Documents

Publication Publication Date Title
EP1095325B1 (en) Systems and methods for on-chip storage of virtual connection descriptors
US6272109B1 (en) Hierarchical schedules for different ATM traffic
WO2000000892A1 (en) Systems and methods for implementing pointer management
EP0939573B1 (en) ATM cell transmission scheduling
EP0924954B1 (en) ATM cell transmissions
CA2159459C (en) Method and system for managing memory in a high speed network
US6167049A (en) Non-zero minimum cell rate for available bit rate ATM service
US6466997B1 (en) Method and apparatus for performing TX raw cell status report frequency and interrupt frequency mitigation in a network node
EP0772131A2 (en) Method and apparatus for support of virtual channels for the transfer of data
US6501731B1 (en) CBR/VBR traffic scheduler
US6657959B1 (en) Systems and methods for implementing ABR with guaranteed MCR
US6425067B1 (en) Systems and methods for implementing pointer management
AU732962B2 (en) Hierarchical schedules for different ATM traffic
US6603768B1 (en) Multi-protocol conversion assistance method and system for a network accelerator
US7114000B1 (en) Scheduling network traffic using multiple logical schedule tables

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

AK Designated states

Kind code of ref document: A3

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

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

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase