Senior Fitness - Exercise and Nutrition for Aging Men and Women
FREE Article Feed for your website.
Home Ownership Magazine
Party Planning Information
Article Marketing Resources
Bio-Medical Research Article Database
Informative Articles on Life, Love and Happiness
Tutorials on Business to Writing
Famous Quotes from Famous People
Song Lyric Information
New US Patent Information
Comprehensive List of Content by Category
Online Auctions and Shopping Related Articles
Article Search
Most Recent Articles
Title: Electric double layer capacitor and electrolytic solution therefor
Patent Number: 7,436,651 Issued on 10/14/2008 to Takeda,   et al.

Title: Laminated ceramic capacitor
Patent Number: 7,436,650 Issued on 10/14/2008 to Oguni,   et al.

Title: Ceramic electronic component and method for manufacturing the same
Patent Number: 7,436,649 Issued on 10/14/2008 to Omura

Title: Multilayer capacitor and mounted structure thereof
Patent Number: 7,436,648 Issued on 10/14/2008 to Togashi

Title: Thin-film capacitor including an opening therein
Patent Number: 7,436,647 Issued on 10/14/2008 to Koiwa,   et al.

Title: Protection element for a capacitor with self-healing properties
Patent Number: 7,436,646 Issued on 10/14/2008 to Delince,   et al.

Title: Method and apparatus for controlling temperature of a substrate
Patent Number: 7,436,645 Issued on 10/14/2008 to Holland,   et al.

Title: Switching circuit, switching method, protective device and battery pack
Patent Number: 7,436,644 Issued on 10/14/2008 to Nagai,   et al.

Title: Protection circuit
Patent Number: 7,436,643 Issued on 10/14/2008 to van den Berg,   et al.

Title: Solid state AC switch
Patent Number: 7,436,642 Issued on 10/14/2008 to Grisoni

Title: Magnetoresistive sensor having an improved pinning structure
Patent Number: 7,436,637 Issued on 10/14/2008 to Pinarbasi

Title: Dual CPP GMR sensor with in-stack bias structure
Patent Number: 7,436,636 Issued on 10/14/2008 to Gill

Title: Current perpendicular to plane (CPP) magnetoresistive sensor having a highly conductive lead structure
Patent Number: 7,436,635 Issued on 10/14/2008 to Pinarbasi

Title: Magnetically anisotropic shield for use in magnetic data recording
Patent Number: 7,436,634 Issued on 10/14/2008 to Carey,   et al.

Title: Thin-film magnetic head, head gimbal assembly and hard disk system
Patent Number: 7,436,633 Issued on 10/14/2008 to Kiyono,   et al.

Title: Differential/dual CPP recording head
Patent Number: 7,436,632 Issued on 10/14/2008 to Li,   et al.

Title: Heated gimbal for magnetic head to disk clearance adjustment
Patent Number: 7,436,631 Issued on 10/14/2008 to Fanslau, Jr.,   et al.

Title: System and method for reducing micro-discharge events in a data storage device
Patent Number: 7,436,630 Issued on 10/14/2008 to Watson,   et al.

Title: Laminated magnetic structure for use in a perpendicular magnetic write head
Patent Number: 7,436,629 Issued on 10/14/2008 to Freitag,   et al.

Title: Perpendicular magnetic recording head for reducing the width of magnetization reversal between recording patterns on a recording medium and method of manufacturing the same
Patent Number: 7,436,628 Issued on 10/14/2008 to Kameda,   et al.

Title: Magnetic head for perpendicular magnetic recording and method of manufacturing same
Patent Number: 7,436,627 Issued on 10/14/2008 to Sasaki,   et al.

Title: Clamp assembly for a data storage device with a lubricant trap to prevent lubricant migration from mounting screws
Patent Number: 7,436,626 Issued on 10/14/2008 to Burns,   et al.

Title: Disk drive spindle motor having a cavity defined by one of an upper surface of a stator support structure and a lower surface of a stator tooth
Patent Number: 7,436,625 Issued on 10/14/2008 to Chiou,   et al.

Title: Pole base loading apparatus and main chassis for magnetic recording/reading device
Patent Number: 7,436,624 Issued on 10/14/2008 to Oh,   et al.

Title: Concurrent servo and data track writing
Patent Number: 7,436,622 Issued on 10/14/2008 to Johnson,   et al.

Title: Azimuth compensation using combination bump pes detection
Patent Number: 7,436,621 Issued on 10/14/2008 to Goker,   et al.

Title: Method for selecting an electrical power to be applied to a head-based flying height actuator
Patent Number: 7,436,620 Issued on 10/14/2008 to Kang,   et al.

Title: Head floating amount control method and unit, storage apparatus and computer-readable program
Patent Number: 7,436,619 Issued on 10/14/2008 to Takahashi

Title: Circuit and method for protecting emergency head-retract capacitor in a hard disk drive
Patent Number: 7,436,618 Issued on 10/14/2008 to Rana,   et al.

Title: Controller, state estimator and methods for use therewith
Patent Number: 7,436,617 Issued on 10/14/2008 to Chang

Title: Current pulsing for unloading
Patent Number: 7,436,616 Issued on 10/14/2008 to Hansen,   et al.

Title: Using a measured error to determine coefficients to provide to an equalizer to use to equalize an input signal
Patent Number: 7,436,615 Issued on 10/14/2008 to Eleftheriou,   et al.

Title: Data storage device and data storage device control
Patent Number: 7,436,614 Issued on 10/14/2008 to Uchida

Title: Magnetic recording device
Patent Number: 7,436,613 Issued on 10/14/2008 to Takahashi,   et al.

Title: Storage apparatus, storage apparatus control method, and computer product
Patent Number: 7,436,612 Issued on 10/14/2008 to Obara,   et al.

Title: Method of servo writing for magnetic recording system, magnetic recording system
Patent Number: 7,436,611 Issued on 10/14/2008 to Nishida,   et al.

Title: Disk drive employing different zone boundaries across disk surfaces
Patent Number: 7,436,610 Issued on 10/14/2008 to Thelin

Title: Apparatus method and system for concurrent gain control in a magnetic read channel
Patent Number: 7,436,609 Issued on 10/14/2008 to Hutchins

Title: Focusing module
Patent Number: 7,436,608 Issued on 10/14/2008 to Chuang,   et al.

Title: Lens module
Patent Number: 7,436,607 Issued on 10/14/2008 to Gao

Title: Optical scanner and scanning type projector
Patent Number: 7,436,567 Issued on 10/14/2008 to Ueyama

Title: Scene graph based display for desktop applications
Patent Number: 7,436,406 Issued on 10/14/2008 to Dautelle

Title: Method and apparatus for analyzing surveillance systems using a total surveillance time metric
Patent Number: 7,436,295 Issued on 10/14/2008 to Collipi,   et al.

Title: Protection of devices in a redundant configuration
Patent Number: 7,436,291 Issued on 10/14/2008 to Sellars,   et al.

Title: Sensor discrimination apparatus, system, and method
Patent Number: 7,436,290 Issued on 10/14/2008 to Williams,   et al.

Title: Remote keyless entry system with two modes of demodulation
Patent Number: 7,436,289 Issued on 10/14/2008 to Desai,   et al.

Title: Remote control equipment and a control method thereof
Patent Number: 7,436,288 Issued on 10/14/2008 to Shin

Title: Auxiliary generator self-test verification device
Patent Number: 7,436,287 Issued on 10/14/2008 to Bollin

Title: Circuit arrangement and method for increasing the functional range of a transponder
Patent Number: 7,436,286 Issued on 10/14/2008 to Fischer,   et al.

Title: Dual-communication electronic shelf label system and method
Patent Number: 7,436,285 Issued on 10/14/2008 to Roquemore, III

Title: Low resistance polymer matrix fuse apparatus and method
Patent Number: 7,436,284 Issued on 10/14/2008 to Bender,   et al.

Title: Mechanical reinforcement structure for fuses
Patent Number: 7,436,283 Issued on 10/14/2008 to Babic,   et al.

Title: Miniature circuitry and inductive components and methods for manufacturing same
Patent Number: 7,436,282 Issued on 10/14/2008 to Whittaker,   et al.

Title: High-voltage transformer winding and method of making
Patent Number: 7,436,280 Issued on 10/14/2008 to Jedlitschka

Title: High voltage transformer
Patent Number: 7,436,279 Issued on 10/14/2008 to Weger

Title: Electrical contacting of thin enameled wires of secondary windings of ignition coils having a contact crown and contact element
Patent Number: 7,436,278 Issued on 10/14/2008 to Fischer,   et al.

Title: Power transformer
Patent Number: 7,436,277 Issued on 10/14/2008 to Hazucha,   et al.

Title: Tuning circuit preventing a deterioration of Q value
Patent Number: 7,436,276 Issued on 10/14/2008 to Suzuki,   et al.

Title: Waveguide quick disconnect clamp
Patent Number: 7,436,275 Issued on 10/14/2008 to Dale

Title: Band-pass filter
Patent Number: 7,436,274 Issued on 10/14/2008 to Shih

Title: Surface acoustic wave device and method for manufacturing the same
Patent Number: 7,436,273 Issued on 10/14/2008 to Onozawa

Title: Piezoelectric device
Patent Number: 7,436,272 Issued on 10/14/2008 to Fujii,   et al.

Title: Dielectrically transduced single-ended to differential MEMS filter
Patent Number: 7,436,271 Issued on 10/14/2008 to Weinstein,   et al.

Title: Structure and method for improving the reliability of surface mounted ceramic duplexers
Patent Number: 7,436,270 Issued on 10/14/2008 to Ratell, Jr.,   et al.

Title: Acoustically coupled resonators and method of making the same
Patent Number: 7,436,269 Issued on 10/14/2008 to Wang,   et al.

Title: Signal transmission structure, circuit board and connector assembly structure
Patent Number: 7,436,268 Issued on 10/14/2008 to Jiang,   et al.

Title: Microstrip line dielectric overlay
Patent Number: 7,436,267 Issued on 10/14/2008 to Greeff

Title: LC quadrature VCO having startup circuit
Patent Number: 7,436,266 Issued on 10/14/2008 to Byun,   et al.

Title: Clock generator and clock generating method using delay locked loop
Patent Number: 7,436,265 Issued on 10/14/2008 to Park,   et al.

Title: Charge supply apparatus and method in frequency synthesizer
Patent Number: 7,436,264 Issued on 10/14/2008 to Yu

Title: Apparatus and method for presenting a modulated output signal at an output locus
Patent Number: 7,436,263 Issued on 10/14/2008 to Nguyen

Title: Highly linear variable gain amplifier
Patent Number: 7,436,262 Issued on 10/14/2008 to Ashby,   et al.

Title: Operational amplifier
Patent Number: 7,436,261 Issued on 10/14/2008 to Kazuyoshi

Title: Controlling the ratio of amplification factors between linear amplifiers
Patent Number: 7,436,260 Issued on 10/14/2008 to Chamla,   et al.

Title: Amplification apparatus
Patent Number: 7,436,259 Issued on 10/14/2008 to Haramoto,   et al.

Packet communication scheduling with hierarchical tunnels Number:6,765,915 from the United States Patent and Trademark Office (PTO) owispatent

Home    Author Login    Submit Article    Article Search    Add Your Link    Edit Your Link    Contact Us    Advertising    Disclaimer

   

 
Web LinkGrinder.com

Top Breaking News
     Greek, Cypriot Leaders Resume Unification Talks in Nicosia by Nathan Morley
     Indonesia Tobacco Sales Grow, Raising Health Fears
     South Korea Allows Top Defector to Travel Overseas by VOA News

Title: Packet communication scheduling with hierarchical tunnels

Abstract: A packet communication scheduling system comprises tunnel schedulers, a packet scheduler, and a rate controller. The packet scheduler generates a packet schedule and first-set information in response to packet information. The first tunnel scheduler generates a first schedule for a first set of tunnels in response to the first-set information. The first tunnel scheduler also generates second-set information in response to the first-set information. The second tunnel scheduler generates a second schedule for a second set of tunnels in response to the second-set information. The second tunnel scheduler also generates third-set information in response to the second-set information. The third tunnel scheduler generates a third schedule for a third set of tunnels in response to the third-set information. The third tunnel scheduler selects a next third-set tunnel identifier based on the third schedule. The second tunnel scheduler selects a next second-set tunnel identifier based on the second schedule and the next third-set tunnel identifier. The first tunnel scheduler selects a next first-set tunnel identifier based on the first schedule and the next second-set tunnel identifier. The packet scheduler selects a next packet identifier for a next packet transmission based on the next first-set tunnel identifier and the packet schedule.

Patent Number: 6,765,915 Issued on 07/20/2004 to Metzger,   et al.


Inventors: Metzger; Michael M. (Boulder, CO), Gemar; Jeffrey R. (Superior, CO), Rick; Uve W. (Broomfield, CO)
Assignee: Conexant Systems, Inc. (Newport Beach, CA)
Appl. No.: 09/578,967
Filed: May 25, 2000


Current U.S. Class: 370/395.43
Current International Class: H04L 12/46 (20060101); H04L 12/56 (20060101)
Field of Search: 370/229,230,230.1,231,235,236,236.1,395.1,395.4,395.41,395.42,395.43,468,474


References Cited [Referenced By]

U.S. Patent Documents
5689499 November 1997 Hullett et al.
5987031 November 1999 Miller et al.
6262989 July 2001 Gemar et al.
6272109 August 2001 Pei et al.
6359891 March 2002 Bergantino et al.
6430156 August 2002 Park et al.
6459681 October 2002 Oliva
6507577 January 2003 Mauger et al.
6532213 March 2003 Chiussi et al.
Primary Examiner: Yao; Kwang Bin
Attorney, Agent or Firm: Kind; Keith

Claims



What is claimed is:

1. A packet communication scheduling system: a first tunnel scheduler configured to generate a first schedule for a first set of tunnels in response to first-set tunnel information, to select a next first-set tunnel identifier based on the first schedule, and to generate the first schedule for the first set of tunnels in response to the packet system feedback information wherein the first-set tunnel information indicates new first-set tunnels and first-set transmission results, and wherein the first set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, an available bit rate tunnel, an unspecified bit-rate tunnel, and a guaranteed flat rate tunnel; a second tunnel scheduler configured to generate a second schedule for a second set of tunnels in response to second-set information and to select a next second-set tunnel identifier based on the second schedule, wherein the second-set information indicates new second-set tunnels and second-set transmission results, and wherein the second set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, an available bit rate tunnel, an unspecified bit-rate tunnel, and a guaranteed flat rate tunnel; a packet scheduler configured to generate a packet schedule and the first-set tunnel information in response to packet information, to select a next packet identifier for a next packet transmission based on the next first-set tunnel identifier and the packet schedule, and to generate the packet schedule in response to the packet system feedback information; a feedback loop rate controller configured to receive and distribute packet system feedback information, wherein the feedback loop rate controller is configured to process tunnel resource management cells for ABR tunnels and wherein the packet system feedback information is for available bit rate traffic; and wherein the first tunnel scheduler is further configured to generate the second-set information in response to the first-set information and to select the next first-set tunnel identifier based on the next second-set tunnel identifier. the second tunnel scheduler is further configured to generate the second schedule for the second set of tunnels in response to the packet system feedback information; the first tunnel scheduler is further configured to generate the first schedule for the first set of tunnels in response to the packet system feedback information; and the packet scheduler is further configured to generate the packet schedule in response to the packet system feedback information.

2. The packet communication scheduling system of claim 1 wherein the packet system feedback information is for available bit rate traffic.

3. The packet communication scheduling system of claim 2 wherein the feedback loop rate controller is configured to process tunnel resource management cells for ABR tunnels.

4. The packet communication scheduling system of claim 1 further comprising: a third tunnel scheduler configured to generate a third schedule for a third set of tunnels in response to third-set information and to select a next third-set tunnel identifier based on the third schedule; and wherein the second tunnel scheduler is further configured to generate the third-set information in response to the second-set information and to select the next second-set tunnel identifier based on the next third-set tunnel identifier.

5. The packet communication scheduling system of claim 4 wherein the third-set information indicates new third-set tunnels and third-set transmission results.

6. The packet communication scheduling system of claim 4 wherein the third set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, and an available bit rate tunnel.

7. The packet communication scheduling system of claim 6 wherein the third set of tunnels includes an unspecified bit-rate tunnel and a guaranteed flat rate tunnel.

8. The packet communication scheduling system of claim 4 further comprising: the feedback loop rate controller is configured to receive and distribute packet system feedback information; and wherein the third tunnel scheduler is further configured to generate the third schedule for the third set of tunnels in response to the packet system feedback information; the second tunnel scheduler is further configured to generate the second schedule for the second set of tunnels in response to the packet system feedback information; the first tunnel scheduler is further configured to generate the first schedule for the first set of tunnels in response to the packet system feedback information; and the packet scheduler is further configured to generate the packet schedule in response to the packet system feedback information.

9. The packet communication scheduling system of claim 8 wherein the packet system feedback information is for available bit rate traffic.

10. The packet communication scheduling system of claim 9 wherein the feedback loop rate controller is configured to process tunnel resource management cells for ABR tunnels.

11. A method of operating a packet communication scheduling system, the method comprising: generating a packet schedule and first-set tunnel information in response to packet information; generating a first schedule for a first set of tunnels in response to the first-set tunnel information, wherein the first set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, an available bit rate tunnel, an unspecified bit-rate tunnel, and a guaranteed flat rate tunnel; selecting a next first-set tunnel identifier based on the first schedule; selecting a next packet identifier for a next packet transmission based on the next first-set tunnel identifier and the packet schedule; generating second-set information in response to the first-set information, wherein the second-set information indicates new second-set tunnels and second-set transmission results; generating a second schedule for a second set of tunnels in response to the second-set information, wherein the second set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, an available bit rate tunnel, an unspecified bit-rate tunnel, and a guaranteed flat rate tunnel; selecting a next second-set tunnel identifier based on the second schedule; receiving and distributing packet system feedback information, wherein the packet system feedback information is for available bit rate traffic; and wherein generating the first schedule comprises generating the first schedule in response to the packet system feedback information; generating the packet schedule comprises generating the packet schedule in response to the packet system feedback information; selecting the next first-set tunnel identifier comprises selecting the next first-set tunnel identifier based on the next second-set tunnel identifier; wherein the first-set tunnel information indicates new first-set tunnels and first-set transmission results; wherein the packet system feedback information is for available bit rate traffic; wherein receiving and distributing the packet system feedback information comprises processing tunnel resource management cells for ABR tunnels; generating the second schedule comprises generating the second schedule in response to the packet system feedback information; generating the first schedule comprises generating the first schedule in response to the packet system feedback information; and generating the packet schedule comprises generating the packet schedule in response to the packet system feedback information.

12. The method of claim 11 wherein the packet system feedback information is for available bit rate traffic.

13. The method of claim 12 wherein receiving and distributing the packet system feedback information comprises processing tunnel resource management cells for ABR tunnels.

14. The method of claim 11 further comprising: generating third-set information in response to the second-set information; generating a third schedule for a third set of tunnels in response to the third-set information; selecting a next third-set tunnel identifier based on the third schedule; and wherein selecting the next second-set tunnel identifier comprises selecting the next second-set tunnel identifier based on the next third-set tunnel identifier.

15. The method of claim 14 wherein the third-set information indicates new third-set tunnels and third-set transmission results.

16.The method of claim 14 wherein the third set of tunnels includes a constant bit-rate tunnel, a variable bit rate tunnel, and an available bit rate tunnel.

17. The method of claim 16 wherein the first set of tunnels includes an unspecified bit-rate tunnel and a guaranteed flat rate tunnel.

18. The method of claim 14 further comprising: receiving and distributing the packet system feedback information; and wherein generating the third schedule comprises generating the third schedule in response to the packet system feedback information; generating the second schedule comprises generating the second schedule in response to the packet system feedback information; generating the first schedule comprises generating the first schedule in response to the packet system feedback information; and generating the packet schedule comprises generating the packet schedule in response to the packet system feedback information.

19. The method of claim 18 wherein the packet system feedback information is for available bit rate traffic.

20. The method of claim 19 wherein receiving and distributing the packet system feedback information comprises processing tunnel resource management cells for ABR tunnels.
Description



BACKGROUND OF THE INVENTION

1. Field of the Invention

The invention is related to the field of communication systems, and in particular, to a packet scheduling system that schedules packet transmission according to a hierarchy of tunnels.

2. Statement of the Problem

A packet communication system transfers packets within data streams between customer sites. The packets contain information, such as voice, video, and data. The data streams are often grouped into data tunnels to simplify management. Thus, a data tunnel is a group of data streams that flow between two customer sites. For example, a business with offices in San Francisco and New York may have a data tunnel between San Francisco and New York that includes a group of data streams. The data streams are distinguished from one another by identifiers in the packets.

The packet communication system uses various service classes to define the data streams within the tunnel. For Asynchronous Transfer Mode (ATM) communications, service classes have been defined for Constant Bit Rate (CBR), Variable Bit Rate (VBR), Available Bit Rate (ABR), Unspecified Bit Rate (UBR), and Guaranteed Flat Rate (GFR). The service class for a data stream is typically selected based on the type of data being transferred.

The packet communication system uses a scheduling system to determine when to transfer packets for the respective data streams within the tunnel. Packet scheduling is primarily based on service class. For example, a CBR data stream typically gets priority scheduling over an ABR bit stream.

Currently, CBR tunnels are available that carry CBR, VBR, ABR, GFR, and UBR data streams. Unfortunately, CBR tunnels can be inefficient or costly because constant bandwidth is allocated to the tunnel and may go unused. In addition, multiple tunnels with different service classes require a scheduling system for the tunnels in addition to the data streams. Current tunnel scheduling systems combine tunnel and data stream scheduling into a single scheduling table. The single scheduling table precludes complex scheduling and is not scalable.

A scheduling system is needed that supports tunnels that comprise multiple service classes. The scheduling system should allow for complex and hierarchical scheduling. The scheduling system should be scalable.

SUMMARY OF THE SOLUTION

The invention solves the above problems with a packet scheduling system for a packet communication network. The packet scheduling system supports tunnels that use multiple service classes, such as CBR, VBR, ABR, GFR, and UBR. Advantageously, the bit rate of the tunnels may vary dynamically to optimize bandwidth utilization. The packet scheduling-system allows for a hierarchical scheduling arrangement among multiple tunnels.

In some embodiments of the invention, a packet communication scheduling system comprises three tunnel schedulers, a packet scheduler, and a rate controller. The packet scheduler generates a packet schedule and first-set information in response to packet information. The first tunnel scheduler generates a first schedule for a first set of tunnels in response to the first-set information. The first tunnel scheduler also generates second-set information in response to the first-set information. The second tunnel scheduler generates a second schedule for a second set of tunnels in response to the second-set information. The second tunnel scheduler also generates third-set information in response to the second-set information. The third tunnel scheduler generates a third schedule for a third set of tunnels in response to the third-set information. The feedback loop rate controller receives and distributes packet system feedback information. The tunnel schedulers also generate their respective schedules in response to the packet system feedback information.

The third tunnel scheduler selects a next third-set tunnel identifier based on the third schedule. The second tunnel scheduler selects a next second-set tunnel identifier based on the second schedule and the next third-set tunnel identifier. The first tunnel scheduler selects a next first-set tunnel identifier based on the first schedule and the next second-set tunnel identifier. The packet scheduler selects a next packet identifier for a next packet transmission based on the next first-set tunnel identifier and the packet schedule.

DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram that illustrates a packet processing system in an example of the invention.

FIG. 2 is a block diagram that illustrates an ATM cell scheduling system in an example of the invention.

FIG. 3 is a block diagram that illustrates pointer queues in an example of the invention.

FIG. 4 is a block diagram that illustrates schedule tables in an example of the invention.

FIG. 5 is a block diagram that illustrates an ATM cell scheduling system with an ABR feedback loop in an example of the invention.

DETAILED DESCRIPTION OF THE INVENTION

Packet Processing System--FIG. 1

FIG. 1 depicts a specific example of a packet processing system in accord with the present invention. Those skilled in the art will appreciate numerous variations from this example that do not depart from the scope of the invention. Those skilled in the art will appreciate that various features described below could be combined with other embodiments to form multiple variations of the invention. Those skilled in the art will also appreciate that some conventional aspects of FIG. 1 have been simplified or omitted for clarity.

FIG. 1 is a block diagram that illustrates packet processing system 100 in an example of the invention. Packet processing system 100 transfers packets 131 to packet network 190 and receives packet network feedback 151 from packet network 190. Packet processing system 100 is configured to schedule packet transmission for tunnels. The tunnels could be CBR, VBR, UBR, ABR, GFR, or some other type of tunnel. The tunnel scheduling can be based on a tunnel scheduling hierarchy.

Packet processing system 100 is comprised of network interface 101, segmentation circuitry 102, rate controller 103, and packet scheduling system 104. Packet scheduling system 104 is comprised of packet scheduler 110 with packet schedule 120 and tunnel schedulers 111-113 with respective tunnel schedules 121-123. The above components of packet processing system 100 are comprised of integrated circuitry and processing instructions. The packets could be ATM cells, ATM AAL CPS packets, Internet packets, or some other packet format.

Packet scheduling system 104 transfers next packet identifiers (IDs) 132 to segmentation circuitry 102. Segmentation circuitry 102 transfers packets 131 to packet network 190 based on next packet identifiers 132. Segmentation circuitry 102 transfers packet information 141 to packet scheduler 110. Packet information 141 indicates new packet IDs, new tunnel IDs, and packet transfer results. In some examples of the invention, packet and tunnel IDs are ATM virtual connection IDs.

Packet scheduler 110 generates packet schedule 120 in response to packet information 141. Packet scheduler 110 selects next packet IDs 132 based on packet schedule 120 and next tunnel IDs 133 from tunnel scheduler 111. Packet scheduler 110 also transfers tunnel information 142 to tunnel scheduler 111. Tunnel information 142 includes new tunnel IDs and packet transfer results.

Tunnel scheduler 111 generates tunnel schedule 121 for a first set of tunnels in response to tunnel information 142. Tunnel scheduler 111 selects next tunnel IDs 133 based on tunnel schedule 121 and next tunnel IDs 134 from tunnel scheduler 112. Tunnel scheduler 111 also transfers tunnel information 143 to tunnel scheduler 112. Tunnel information 143 includes new tunnel IDs and packet transfer results.

Tunnel scheduler 112 generates tunnel schedule 122 for a second set of tunnels in response to tunnel information 143. Tunnel scheduler 112 selects next tunnel IDs 134 based on tunnel schedule 122 and next tunnel IDs 135. Tunnel scheduler 112 also transfers tunnel information 144. Tunnel information 144 includes new tunnel IDs and packet transfer results.

The ellipses signify that additional tunnel schedulers may be positioned between tunnel schedulers 112-113 if desired, but the following description assumes that no additional tunnel schedulers have been inserted. Tunnel scheduler 113 generates tunnel schedule 123 for a third set of tunnels in response to tunnel information 144. Tunnel scheduler 113 selects next tunnel IDs 135 based on tunnel schedule 123. Tunnel scheduler 113 affects tunnel scheduling for tunnel scheduler 112. Tunnel scheduler 112 affects tunnel scheduling for tunnel scheduler 111. Tunnel scheduler 111 affects packet scheduling for packet scheduler 110. Thus, tunnel scheduler 113 is at the top of a tunnel scheduling hierarchy that controls the next packet IDs 132, and that ultimately controls packets 131 that are transferred to packet network 190.

Although rate controller 103 may be omitted in some examples of the invention, it is desirable if packet network 190 provides feedback 151. Feedback 151 indicates current network status, such as congestion levels and delays. One example of feedback 151 is resource management cells for ATM ABR traffic. Rate controller 103 receives and distributes feedback 151 in the form of feedback 152-155 to respective schedulers 110-113. Schedulers 110-113 generate their respective schedules 120-123 in response to feedback 152-155.

ATM Cell Scheduling System--FIGS. 2-3

FIGS. 2-5 depict a specific example of an ATM cell scheduling system in accord with the present invention. Those skilled in the art will appreciate numerous variations from this example that do not depart from the scope of the invention. Those skilled in the art will appreciate that various features described below could be combined with other embodiments to form multiple variations of the invention. Those skilled in the art will also appreciate that some conventional aspects of FIGS. 2-3 have been simplified or omitted for clarity.

FIG. 2 is a block diagram that illustrates ATM cell scheduling system 204 in an example of the invention. ATM cell scheduling system 204 comprises VCC scheduling system 210 and tunnel scheduling system 220. VCC scheduling system 210 comprises VCC scheduler 251, VCC pointer queue 253, VCC start First-In First-Out Memory (FIFO), and VCC select FIFO. Tunnel scheduling system 220 comprises tunnel scheduler 252, tunnel pointer queue 254, tunnel start FIFO, CBR tunnel FIFO, tunnel ID FIFO, and command FIFO. Schedulers 251-252 process respective schedule tables 255-256 that are stored in control memory 250.

FIG. 3 is a block diagram that illustrates pointer queues 253-254 in an example of the invention. VCC pointer queue 253 has multiple priority levels. Each priority level is associated with one or more types of VCCs, such as CBR, VBR, ABR, UBR, and GFR. Each priority level has a bit to indicate if the priority level is active or inactive. Each priority level has a head pointer and a tail pointer. The head pointer and tail pointer define a linked list representing the Virtual Channel Connections (VCCs) that are active at the given priority level. The head pointer points to state space in control memory 250 for the first VCC in the linked list. The tail pointer points to state space in control memory 250 for the last VCC in the linked list. The linked list is circular for some priority levels, such as priority levels that contain UBR VCCs.

Tunnel pointer queue 254 also has multiple priority levels. Each priority level is associated with one or more types of tunnels, such as CBR, VBR, ABR, UBR, and GFR. A null tunnel may also be used for VCCs that are not assigned to a tunnel. Each priority level has a bit to indicate if the priority level is active or inactive. Each priority level has a head pointer and a tail pointer. The head pointer and tail pointer define a linked list representing the tunnels that are active at the given priority level. The head pointer points to state space in control memory 250 for the first tunnel in the linked list. The tail pointer points to state space in control memory 250 for the last tunnel in the linked list. Each tunnel is associated with a corresponding set of VCC pointer queue 253 priority levels, and the state space for each tunnel indicates the association. The linked list is circular for some priority levels, such as priority levels that contain UBR tunnels.

FIG. 4 is a block diagram that illustrates schedule tables 255-256 in an example of the invention. VCC schedule table 255 has time slot entries that are processed chronologically by VCC scheduler 251. Each time slot entry has fields for each of the priority levels in VCC pointer queue 253. The fields contain VCC tail pointers for the VCCs that are active for the respective priority level. For example, CBR VCCs are identified in a time slot field that is associated with the top priority level in VCC pointer queue 253. For more efficient memory utilization when VCC schedule table 255 becomes too large, VCC schedule table 255 may be separated into sub-tables with a sub-table for each priority level in VCC pointer queue 253.

Tunnel schedule table 256 has time slot entries that are processed chronologically by tunnel scheduler 252. Each time slot entry has fields for each of the priority levels in tunnel pointer queue 254. The fields contain tunnel tail pointers for the tunnels that are active for the respective priority level. Each time slot entry also contains a field for CBR tunnels.

In operation, SAR circuitry 202 notifies VCC scheduler 251 through the VCC start FIFO when a new VCC or a new tunnel is activated. If a new tunnel is activated, VCC scheduler 251 notifies tunnel scheduler 252 through the tunnel start FIFO. VCC scheduler 251 schedules any new VCCs in VCC schedule table 255, and tunnel <scheduler 252 schedules any new tunnels in tunnel schedule table 256.

VCC scheduler 251 counts the number of active VCCs in each tunnel, and when a tunnel no longer has any active VCCs, VCC scheduler 251 transfers a tunnel ID and a deactivate command respectively to the tunnel ID and command FIFOs. Tunnel scheduler 252 then deactivates the corresponding tunnel.

Tunnel scheduler 252 processes tunnel schedule table 256 to determine which tunnels are active at each priority level for the time slot. Tunnel scheduler 252 adds the tail pointers for active tunnels to pointer queue 254 and adds the CBR VCCs directly to the CBR tunnel FIFO.

VCC scheduler 251 processes the CBR tunnel FIFO to select a tunnel for the next cell transmission. If the CBR tunnel FIFO is empty, then VCC scheduler 251 processes the tunnel pointer queue 254 to select a tunnel from an active priority level for the next cell transmission. Various tunnel queue selection techniques could be used including round robin, pure priority, or a weighted scheme. Since both schedulers 251-252 access tunnel pointer queue 254, an arbitration arrangement is implemented between schedulers 251-252 to control queue access.

VCC scheduler 251 checks the state space for the selected tunnel to determine which priority levels in VCC pointer queue 253 are associated with the selected tunnel. VCC scheduler 251 activates the associated priority levels in VCC pointer queue 253. VCC scheduler 251 then processes VCC pointer queue 253 to select a VCC from an active priority level for the next cell transmission. Various VCC queue selection techniques could be used including round robin, pure priority, or a weighted scheme. VCC scheduler 251 places the selected VCC in the VCC select FIFO. SAR circuitry 202 transfers data over the VCC identified in the VCC select FIFO.

After placing the selected VCC in the VCC select FIFO, VCC scheduler 251 re-schedules the selected VCC in the VCC schedule table 255. VCC scheduler 251 also transfers the tunnel ID for the VCC and a sent command respectively to the tunnel ID FIFO and the command FIFO. Tunnel scheduler 252 re-schedules the tunnel in response to the tunnel ID and sent command in the FIFOs.

If the selected tunnel does not have any VCC pointers in VCC pointer queue 253, then VCC scheduler 251 transfers the tunnel ID and a not-sent command respectively to the tunnel ID FIFO and the command FIFO. Tunnel scheduler 252 re-schedules the tunnel in response to the tunnel ID and not-sent command in the FIFOs.

FIG. 5 is a block diagram that illustrates ATM cell scheduling system 204 with an ABR feedback loop in an example of the invention. ABR manager 560 receives ABR resource management cells from ATM network 590. ABR systems using ABR resource management cells to control ABR traffic are well known. ABR resource management for tunnels operates in a similar manner to ABR resource management for VCCs--resource management cells for tunnels would be required. Resource management cells for tunnels would include the associated tunnel ID, which could take the form of a VCC. ABR manager routes 560 the ABR resource management cells to either VCC scheduler 251 or to tunnel scheduler 252 based on whether the given ABR resource management cell relates to an ABR VCC or an ABR tunnel. No ABR tunnel forward resource management cells are generated for a tunnel if no connections are active within the tunnel.

ATM cell scheduling system 204 supports CBR, VBR, UBR, ABR, and GFR tunnels. Advantageously, ATM customers are not restricted to using variable bandwidth data streams within an inefficient CBR tunnel. In addition, a hierarchy of tunnel scheduling is available. Additional tunnel scheduling stages can be established by using the principles described above.

Additional details regarding ATM cell scheduling can be found in U.S. patent application Ser. No. 09/087,238, entitled "Apparatus and Method For Providing Multiple and Simultaneous Quality of Service Connects in a Tunnel Mode", filed on May 29, 1998, and which is hereby incorporated by reference into this patent application. Those skilled in the art will appreciate variations of the above-described embodiments that fall within the scope of the invention. As a result, the invention is not limited to the specific examples and illustrations discussed above, but only by the following claims and their equivalents.

*


Free Web Sudoku Puzzles.
Solve with your browser.
  5           8  
6               3
  1   4 9 3 6    
7     8 6        
    4       5    
        7 4     8
    3 2 8 7   6  
4               7
  7           1  
What is it?



Add Your Site · Terms Of Service · Privacy Policy


DISCLAIMER
Linkgrinder is a free service that searches the Internet and indexes all files found so that you may search quickly and easily for shared files. These files are created and made available individually by users whose identity we are not aware of and who we have no control over. In essence we function like a search engine tool; these files ARE NOT STORED OR SERVED BY OUR NETWORK. We are not responsible for any materials obtained by using our service. We do not monitor any of the contents of these files. These files may contain viruses, illegal materials, materials inappropriate for minors, offensive files and the like. BY USING OUR SERVICE, YOU ASSUME FULL RESPONSIBILITY FOR DOWNLOADING THESE MATERIALS AND WILL INDEMNIFY US FOR ANY DAMAGES THAT MAY BE INCURRED.

For More Specific Information VIEW OUR TERMS OF SERVICE.

Thank you and Enjoy!