CA2332116A1 - Explicit rate marking for flow control in atm networks - Google Patents

Explicit rate marking for flow control in atm networks Download PDF

Info

Publication number
CA2332116A1
CA2332116A1 CA002332116A CA2332116A CA2332116A1 CA 2332116 A1 CA2332116 A1 CA 2332116A1 CA 002332116 A CA002332116 A CA 002332116A CA 2332116 A CA2332116 A CA 2332116A CA 2332116 A1 CA2332116 A1 CA 2332116A1
Authority
CA
Canada
Prior art keywords
value
virtual
explicit rate
explicit
bandwidth
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA002332116A
Other languages
French (fr)
Inventor
Tao Yang
Wengang Zhai
Ping Wang
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Ascend Communications Inc
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Publication of CA2332116A1 publication Critical patent/CA2332116A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • 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/26Flow control; Congestion control using explicit feedback to the source, e.g. choke packets
    • H04L47/263Rate modification at the source after receiving feedback
    • 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/04Selecting arrangements for multiplex systems for time-division multiplexing
    • H04Q11/0428Integrated services digital network, i.e. systems for transmission of different types of digitised signals, e.g. speech, data, telecentral, television signals
    • H04Q11/0478Provisions for broadband connections
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • H04L2012/5632Bandwidth allocation
    • H04L2012/5635Backpressure, e.g. for ABR
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • H04L2012/5636Monitoring or policing, e.g. compliance with allocated rate, corrective actions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5681Buffer or queue management
    • H04L2012/5682Threshold; Watermark

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

An explicit rate marking system comprises virtual bandwidth value generator module and an explicit rate value generator module. The virtual bandwidth value generator module generates a virtual bandwidth value reflecting an available bandwidth capacity value, an explicit rate value associated with each bottlenecked virtual circuit for which the switching node (12) forms part of a path (13) and a minimum cell rate value associated with each unbottlenecked virtual circuit for which the switching node (12) forms part of a path (13). The explicit rate value generator module generates the explicit rate value in relation to the virtual bandwidth value and the minimum cell rate value associated with the virtual circuit and other virtual circuits for which the switching node (12) forms part of the path (13).

Description

EXPLICIT RATE MARKING FOR FLOW CONTROL IN ATM NETWORKS
FIELD OF THE INVENTION
The invention relates generally to the field of digital communications systems and more particularly to digital networks for facilitating communication of digital data in, for example, digital image, audio and video distribution systems and among digital computer systems. The invention is more particularly directed to a digital network in which message transfer paths may be provided with various classes of transfer service, including an unregulated available bit rate service and provides a mechanism for allowing the network to control the rate at which devices transmit messages over the network based on congestion along the path between source devices and destination devices.
BACKGROUND OF THE INVENTION
Digital networks have been developed to facilitate the transfer of information, including data and programs, among digital computer systems and other digital devices. A
variety of types of networks have been developed and implemented using diverse information transfer methodologies.
In networks in which information is transferred using the well-known "ATM"
("Asynchronous Transfer Mode") transfer methodology, communications are handled through a mesh of switching nodes. In an ATM network, the computer systems and other devices are connected to various ones of the switching nodes to, as information sources, provide information for transfer over the network and/or, as destinations, receive information from the network, with the information being transferred over paths, termed "virtual paths" and "virtual circuits," established through switching nodes comprising the network. The virtual circuits through an ATM network can be assigned to various types of service classes, which serve to govern the rate at which information, in the form of "cells,"
is transferred thereover. In some service classes, virtual circuits are guaranteed maximum rates at which information can be transferred thereover. Other service classes, on the other hand, provide "available bit rate" ("ABR") services, for which virtual circuits are each guaranteed a minimum information transfer rate, referred to as a "minimum cell rate" ("MCR") and can also make use of the bandwidth which has not been assigned to the virtual circuits which have the guaranteed maximum rates. For virtual circuits for which guaranteed maximum rates are provided, the sources already know the rates at which they can transmit information.
However, for virtual circuits which are associated with ABR service classes, the rate at which the sources can transmit may vary based on a number of factors, including, but not limited to, congestion conditions at the destination as well as congestion conditions at each switching node along the respective path from the source to the destination. To facilitate notifying each source of a virtual circuit which makes use of the ABR service class of the maximum rate at which it can transfer over the virtual circuit, the source periodically transmits a "resource management" ("RM") cell over the virtual circuit, the RM cell including the MCR assigned to the virtual circuit. When the destination receives the RM cell, it transmits the RM cell back to the source in the reverse direction along the virtual circuit. The destination can include an explicit rate value in the backward RM cell which indicates the maximum rate at which the source can trnsmit information.
Each switching node along the path can also determine the maximum rate at which it can allow the source to transmit information and, if that rate is lower than the explicit rate contained in the backward RM cell, it can substitute its rate as the explicit rate value in the backward RM cell. Thus, when the source receives the backward RM cell, the explicit rate contained therein will be the minimum value generated by the destination and all of the switching nodes along the path defined by the virtual circuit.
SUMMARY OF THE INVENTION
The invention provides a new and improved system and method, referred to herein as a virtual bandwidth explicit rate marking system, for performing explicit rate marking of resource management (RM) cells in an ATM network.
In brief summary, the invention provides an explicit rate marking system for use in connection with a switching node to generate an explicit rate value for use in a resource management cell associated with a virtual circuit in an ATM network. The explicit rate marking system comprises a virtual bandwidth value generator module and an explicit rate value generator module. The virtual bandwidth value generator module generate a virtual bandwidth value reflecting an available bandwidth capacity value, an explicit rate value associated with each bottlenecked virtual circuit for which the switching node forms part of a path, and a minimum cell rate value associated with each unbottlenecked virtual circuit for which the switching node forms part of a path. The explicit rate value generator module generates the explicit rate value in relation to the virtual bandwidth value and the minimum cell rate value associated with the virtual circuit and other virtual circuits for which the switching node forms part of a path.
BRIEF DESCRIPTION OF THE DRAWINGS
This invention is pointed out with particularity in the appended claims. The above and further advantages of this invention may be better understood by refernng to the following description taken in conjunction with the accompanying drawings, in which:
FIG.1 schematically depicts an ATM network including a system forperforming explicit rate marking for flow control in ATM networks using a virtual bandwidth-based methodology, constructed in accordance with the invention;
FIG. 2 schematically illustrates the structure of message packets and constituent message cells transferred over the network depicted in FIG. 1;
FIG. 3 schematically depicts a switching node, constructed in accordance with the invention, which is used in the computer network depicted in FIG. 1;
FIG. 4 is a flow chart depicting general operations performed by an explicit rate marking system constructed in accordance with the invention; and FIGS. 5 and 6 are flow charts depicting details of operations performed by the explicit rate marking system.
DETAILED DESCRIPTION OF AN ILLUSTRATIVE EMBODIMENT
FIG. 1 schematically depicts an illustrative ATM network 10 including a system for performing explicit rate marking for flow control in ATM networks using a virtual bandwidth-based methodology, constructed in accordance with the invention. With reference to FIG. 1 network 10 includes a plurality of switching nodes 11(1) through 11(5) (generally identified by reference numeral 11 (n)) for transferring signals representing data among a number of devices 12( 1 ) through 12(10) (generally identified by reference numeral 12(m)). The devices 12(m) may comprise any of a number of types of devices, including, for example, digital computer systems, other networks, customer premises equipment, and the like. In their operations, certain devices 12(ms ) (subscript "S" referencing "source") may, as a source device, need to transfer data to another, destination, device 12(mD) (subscript "D" referencing "destination"), which may need to use the transferred information in its operations. Each device 12(m) is connected over a communication link, generally identified by reference numeral 13(j), to a switching node 11 (n) to facilitate transmission of data thereto or the reception of data therefrom. The switching nodes 11 (n) are interconnected by communication links, also generally identified by reference numeral 13(j) to facilitate the transfer of data thereamong. The communication links 13(j) may utilize any convenient data transmission medium; in one embodiment, the transmission medium of each communication link 13{j ) is selected to comprise one or more fiber optic links. Each communication link 13(j) is preferably bi-directional, allowing the switching nodes 11 (n) to transmit and receive signals among each other and with devices 12(m) connected thereto over the same link; in the embodiment in which the communication links 13(j) are fiber optic links, two optical fibers will be provided for each communication link 13(j), each of which facilitates unidirectional transfer of optical signals.
In one embodiment, the network 10 transfers data using the well-known "ATM"
("Asynchronous Transfer Mode") transfer methodology. That methodology is described in detail in C. Partridge, Gigabit Networking, (Reading MA: Addison Wesley Publishing Company, 1994), primarily in chapters 3 and 4, and D. McDysan, et al., ATM Theory And Application (McGraw Hill, 1995) and will not be described in detail. Generally, with reference to FIG.
2, in the ATM
methodology, the devices 12(m} and the switching nodes 11(n) transmit data in the form of fixed-length "cells." In the ATM data transfer methodology, for a packet 20 to be transmitted from a source device 12(ms) to a destination device 12(mp), the source device 12(ms) allocates the data packet 20 to a plurality of "cells," identified CELL(1) through CELL(I) (generally identified "CELL(i)"), for transmission serially over the communication link 13(j) to initiate transfer thereof over the network 10. Each cell includes a header portion HEADER(i) and a data portion DATA(i), with the header portion HEADER(i) including circuit" information which controls the transfer of the cell through the network 10, and the data portion DATA(i) containing data from the packet 20. The data portion DATA(i) of each cell is of fixed, predetermined length (in one embodiment forty-eight bytes) and so the source device 12(rns) will pad the data in the last data portion DATA(i) if the amount of data in the packet 20 is not an integral multiple of the size of the data portion DATA(i) of each cell to ensure that the last data portion DATA(i) has the required length.
As noted above, the source device 12(ms) transmits the series of cells CELL( 1 ) through CELL(i) generated from a data packet 20 in order, and the network 10 is to deliver the cells to the destination device 12(mp) in the order in which they are transmitted. The destination device 12(mD) must receive all of the cells transmitted by the source device 12(ms) in order to reconstruct the packet 20. In the aforementioned ATM transfer methodology, the cells do not contain ordering information;
and so the destination device 12(mD) determines the proper order to reconstitute the packet 20 from the order in which it receives the cells. The last cell CELL(i) includes a set end of packet flag, designated EOP in FIG. 2, to indicate that it is the last cell for the packet.
As further noted above, header portion HEADER(i) includes "virtual circuit"
information which controls the transfer of the cell over the network 10. Each switching node 11 (n) uses the virtual circuit information for a cell CELL(j) that it receives over an input communication link to identify an output communication link over which it is to transmit the cell to the next switching node or the destination device 12(mp). The virtual circuit information in the headers HEADER(i) of the cells CELL(i) associated with a packet 20 will be the same, but it will differ for cells associated with different packets. Although a destination device 12(mD) will be receiving cells generated for a specific packet 20 in the order of the data in the packet, it may be contemporaneously receiving cells from the network 10 which originated at several source devices 12(ms), which cells may be received in an interleaved manner. The virtual circuit information in each cell CELL(i) will enable the destination device 12(mD) to determine the packet 20 with which the cell is associated.
For virtual circuits over which cells are transferred using the ATM's ABR
(available hit rate) service, in addition to cells, such as those described above in connection with FIG. 2, for transferring data, the network 10 also transfers resource management ("RM") cells which carry flow control information used by the respective source devices 12(mS) to regulate the rate at which they transmit cells over each virtual circuit. Generally, for each virtual circuit for which a device 12(m) is the source device 12(mS), the device 12(mS) periodically transmits an RM cell thereover to the virtual circuit's destination device 12(mD). When the destination device 12(mD) receives the RM cell, it transmits it (that is, the RM cell) back to the source device 12(mS) over the virtual circuit in a reverse direction. The RM cell, when traversing the path from the source device 12(mS) to the destination device 12(mD), is referred to as a "forward" RM ("FRM") cell, and, when traversing the path from the destination device 12(mD) to the source device 12(mS), is referred to as a "backward" RM
("BRM") cell. The destination device 12(mD) and each switching node 11 (n) along the path of the virtual circuit from the destination device 12(mD) to the source device 12(mS) can provide flow control information in the BRM cell. The flow control information provided by the destination device 12(mD) or a switching node 11 (n) may, for example, be reflective of the degree of congestion at the respective destination device 12(mD) or switching node 11 (n), or the like. The flow control information serves to limit the rate at which the source device 12(mS) will transmit cells, above a minimum cell rate ("MCR") which has been assigned to the virtual circuit, and which the source device 12(mS) includes in the FRM cell when it (that is, the source device 12(mS)) transmits the FRM cell.
Typically, when a switching node 11 (n) receives an BRM cell for a virtual circuit, it can generate flow control information and determine whether the flow control information indicates a lower cell transmission rate than indicated in the received BRM cell. If not, the switching node 11 (n) will transmit the BRM cell with the same flow control information as received.
On the other hand, if the switching node 11 (n) determines that the flow control information which it generates does indicate a lower cell transmission rate than indicated in the received BRM
cell, it will substitute the flow control information which it generated for the received flow control information in the BRM
cell before transmitting the BRM cell. Thus, when the source device 12(mS) receives the BRM cell, the flow control information will reflect the minimum of the flow control information as among the destination device 12(mD) and the switching nodes 11 (n) which received the BRM cell, which, in turn, is the minimum for the virtual circuit. The invention provides an explicit rate marking system for generating an explicit rate marking system used by the switching nodes 11 (n) to generate the flow control information for inclusion in the BRM cells.
The switching nodes 11(n) comprising network 10 all have generally the same structure, which will be described in connection with FIG. 3. With reference to FIG. 3, each switching node 11 (n) includes an input interface 30, a buffer 32, and an output interface 34, all under control of a control element 35. To facilitate bi-directional communications, the input interface 30 and output interface 34 will be connected to all of the communication links 13(p) to which the switching node 11 (n) is connected to facilitate reception of signals from, and transmission of signals to, others of the switching nodes in the network 10 or ones of the devices 12(m) to which the switching node 11 (n) is connected. In the case of the above-described embodiment in which the communication links 13(p) are in the form of optical fibers, the input interface 30 is connected to particular ones of the communication links, namely, input communication links 13(p)(i), over which the switching node 11 (n) receives the optical signals, and the output interface 34 is connected to others of the communication links, namely, output communication links 13(p)(o), over which the switching node transmits the optical signals. It will be appreciated that each input communication link 13(p)(i) will constitute an output communication link over which a device 12(m) or another switching node in the network 11 transmits signals, and each output communication link 13(p)(o) will constitute an input communication link over which a device 12(m) or another switching node in the network 11 receives signals.
As noted above, the invention provides an explicit rate marking system 36, which is included in and forms part of the control element 35 of the respective switching node 11 (n), for generating flow control information for inclusion in the BRM cells received thereby. The explicit rate marking system 36 will be described in connection with the illustrative network 10, in which five illustrative virtual circuits are established between respective source and destination devices as follows:
(i) virtual circuit ( 1 ) between source device 12( I ) and destination device 12(6) through switching nodes 11(1) through 11(4) and over communication links 13(1) through 13(4), 13(5) and 13( 1 ), with an MCR of 10 (in arbitrary units), (ii) virtual circuit (2) between source device 12(2) and destination device 12(7) through switching nodes 11 ( I ) and 11 (2) and over communication links 13( 1 ), I
3(6) and 13(1 I ), with an MCR of 2, (iii) virtual circuit (3) between source device 12(3) and destination device 12(3) through switching nodes 11 ( 1 ), I 1 (2) and 11 (3) and over communication links 13( I ),13(2),13 (7) and 13( 12), with an MCR of 3, (iv) virtual circuit (4) between source device 12(4) and destination device 12(9) through switching nodes 11(2),11(3) and l l(4) and over communication links 13(2),13(3),13(8) and 13(13), with an MCR of 10, and (v) virtual circuit (5) between source device 12(5) and destination device 12(10) through switching nodes 11(4) and 11(5) and over communication links 13(4), 13(9) and 13(14), with an MCR of 50.
In addition, each communication link 13(1) through 13(4) interconnecting the respective switching nodes 11 (n) has a maximum bandwidth capacity C~ available for the ABR
service; in the illustrative network 10, communication link 13(1) has a capacity C,=150 (in arbitrary units), communication links 13(2) and 13(3) have respective capacities CZ=C3=100, and communication link 13(4) has a capacity C4 60. It will be appreciated that the explicit rate R; for the "i-th" virtual circuit (i=1,...,5) will be the minimum of the link explicit rates R;~ over the communication links 13(j) which form the path for the virtual circuit, that is, R; = min~R;,~ ~ j E J(i)}

_g_ where "J(i)" corresponds to the set of communication links which form the path for the "i-th" virtual circuit.
As is clear, communication links 13(1) through 13(4) interconnecting the switching nodes 11 (n) can form paths for multiple virtual circuits. Generally, in determining the link explicit rate R;,~
for each virtual circuit, it is desired to be "fair" to each virtual circuit and to maximize the utilization of the respective communication link 13(j). There are two general methodologies for determining fairness, namely, an equal share methodology and a proportional methodology.
In the equal share methodology, the portion of the bandwidth for a communication link 13(j) above the MCR's for all of the virtual circuits for which the communication link 13(j) forms part of the path (which will be referred to as the "excess bandwidth"), is divided among the virtual circuits on an equal basis, and the link explicit rate R;~ for the "i-th" virtual circuit will be the sum of that and the virtual circuit's MCR, that is CJ - ~ MCRi iEl(j) (2y R;,~ = MCRi +
1 ~.I )~
where "~I(j)~" represents the number of virtual circuits for which the communication link 13(j) forms part of the path. On the other hand, in the proportional share methodology, the entire bandwidth is divided among the virtual circuits on a basis in proportion to their MCR's, that is It will be appreciated that, under the equal share methodology, virtual circuits (1), (2) and (3) will have link explicit rates R;~ of 55, 47 and 48, respectively, and under the proportional share MCRi ~.i = Ci ~ MCRi ( iel(J) methodology, they will have link explicit rates R;~ of 100, 20, and 30, respectively, A similar operation can be performed at every communication link 13 (j ) to determine the link explicit rate R;~ for the respective link and virtual circuit, and, as noted above, the explicit rate R; for each virtual circuit will be the minimum of the link explicit rates R;,~ for the respective virtual circuit.
In that connection, since the sum of the MCR's for the virtual circuit's (1) and (5) for which communication link 13(4) forms part of their respective paths, equals the capacity C4 60, it is apparent that, even though virtual circuit ( 1 ) could, over communication link 13( 1 ) be allocated an explicit rate higher than 10, because the virtual circuit is bottlenecked by the communication link 13(4), it (that is, virtual circuit(1)) can only be allocated an explicit rate R; of 10 at communication link I 3( 1 ). Accordingly, since the explicit rate for virtual circuit ( 1 ) at communication link 13 ( 1 ) will be far below that that could be assigned to the virtual circuit for communication link 13(1) as described above, there will be additional bandwidth capacity over communication link 13(1) which can be assigned to virtual circuits (2) and (3), in which case they will be assigned link explicit rates of, for example, 56 and 84, respectively, using the proportional share methodology.
The explicit rate marking system 36 provided by the invention determines the explicit rate using a virtual bandwidth methodology, in which for a communication link 13(j), if a virtual circuit for which the communication link 13(j) forms part of the path is bottlenecked over another virtual circuit, the explicit rate marking system 36 determines the link explicit rates) of other virtual circuits which use it (that is, communication link 13(j)) as part of the path, by generating a virtual bandwidth value C'~ available for the ABR service, and determining link explicit rates as described above in connection with equations (2) and (3) using the virtual bandwidth value C'~ as well as the actual bandwidth capacity C~ available for the ABR service. For the virtual circuits which are not bottlenecked, the link explicit rate R;~ will be the link explicit rate so determined, whereas for the virtual circuits which are bottlenecked. The explicit rate marking system 36 determines the virtual bandwidth value C'~ according to N.
C' j = Cj - ~ MCR. - ~ R; ' + ~ MCR (4)~
( i iE/pU) iEIB~J) I ~U~,~~ iel(l) for the equal share methodology, and MCRi iEl(j) C~j Cj ~ R' ~ MCR. (5)~
IEIq~J) I
iEI~CJ) for the proportional share methodology, where IB(j) corresponds to the set of virtual circuits which are bottlenecked elsewhere, IU(j) corresponds to the set of virtual circuits which are not bottlenecked elsewhere, and N~ represents the number of virtual circuits for which the communication link 13(j) forms part of the path (which, in turn, corresponds to ~I(j)~ in equation (2)).
It will be appreciated that, for the proportional share methodology (reference equation (5)), the virtual bandwidth C'~ for communication link 13(j) corresponds to the bandwidth capacity available for virtual circuits which are not bottlenecked, which corresponds to Cj - ~ R; , iEIB(j) multiplied by the ratio of the MCR's for all virtual circuits for which the communication link 13(j) forms part of the path, to the MCR's for the unblocked virtual circuits for which the communication link 13(j) forms part of the path. It will be appreciated that, if the virtual bandwidth C'~ is used instead ofbandwidth capacity C~ in equation (3), R;,j = J ~ ~ MCR.R , C - R ' that is, the iEIB(j) ~ MC , iEl~(J) link explicit rate for an unbottlenecked virtual circuit corresponds to the bandwidth capacity available for virtual circuits which are not bottlenecked multiplied by the ratio of the MCR of the respective virtual circuit to the sum of the MCR's of the virtual circuits which are not bottlenecked.
The virtual bandwidth C'~ for the equal share methodology is somewhat more complex. The factor Cj - ~ MCRi - ~ Ri corresponds to the amount of bandwidth capacity for iel~(j) iEIB(J) communication link 13(j) which is available for distribution to unbottlenecked virtual circuits, that is, the total bandwidth capacity C(j), minus the bandwidth capacity taken up by the bottlenecked virtual circuits ~ Ri , and minus the bandwidth capacity required to provide the MCR's for the iel~(j) unbottlenecked virtual circuits ~ MCRi . The factor N~ , when the virtual bandwidth C'~
7 E I tl (.I ) U
(equation (4)) is used to determine the link explicit rate for a virtual circuit (equation (2)) will provide a factor of ( , effectively dividing the bandwidth capacity available for distribution Iu~J) to unbottlenecked virtual circuits by the number of unbottlenecked virtual circuits. When the equal share methodology virtual bandwidth (equation (4)) is used in determining the link explicit rate R;~, the addend ~ MCR; in equation (4) will cancel the same value in the quotient, so that the link iEl(j) explicit rate R;,~ in the equal share methodology will correspond to R;,j = MCRi + 1 Cj - ~ MCR; - ~ R;
.lU .~y iel~(j) ielA(l) The general operations performed by the explicit rate marking systems 36 of the switching nodes 11 (n) to determine the explicit rate R; for each virtual circuit will be described in connection with the flowchart depicted in FIG. 4. With reference to FIG. 4, each explicit rate marking system 36, for each virtual circuit and each connection, initially determines the link explicit rate R;,~ for each communication link 13(j) using equation (2) or (3) for the selected methodology using the actual bandwidth capacity C~ of the respective communication link 13(j) available for the ABR service (step 100). Thereafter, the explicit rate marking system 36 marks each bottlenecked virtual circuit and assigns it its explicit rate R; in accordance with equation ( 1 ) (step 1 O 1 ). The explicit rate marking system 36 then determines if there are any virtual circuits which have not been marked (step 102).
If the explicit rate marking system 36 makes a positive determination in step 102, it has not determined the explicit rate R; for all of the virtual circuits, and in that case it will sequence to step 103 in which it identifies each communication link 13(j) which forms part of the path for at least one non-bottlenecked virtual circuit, and thereafter determine the virtual bandwidth value therefor in accordance with equation (4) or (5) (step 104). The explicit rate marking system 36 then determines the link explicit rate R;~ for each of the unmarked virtual circuits using equation (2) or (3) using the virtual bandwidth values C'~ instead of the actual bandwidth capacities C~
(step 105) and returns to step 101 to identify and mark virtual circuits which are determined to be bottlenecked using the new link explicit rates. The explicit rate marking system 36 repeats steps 101 through 105 until it determines in step 102 that all of the virtual circuits have been marked, at which point it will exit (step 106). It will be appreciated that, by the point at which the explicit rate marking system 36 determines that all virtual circuits have been marked, explicit rates R; will have been determined for all of the virtual circuits.

In one embodiment, instead of updating the virtual bandwidth value C'~
available to the ABR
service explicitly as described above in connection with equations (4) or (5), the explicit rate marking system 36 maintained by each switching node 11(n), after generating the virtual bandwidth value once, can make use of a virtual bandwidth factor "vbf," which it periodically updates as ATM cells are received and transmitted. The virtual bandwidth factor relates the bandwidth capacity C~
available for the ABR service to the virtual bandwidth C'~ according to C'~=vbf*C~ (where "*" is the multiplication operation). In that embodiment, operations performed by the explicit rate marking system 36 when an ATM cell arrives at a switching node 11(n) over communication link 13(j) will be described in connection with the flow chart depicted in FIG. 5. With reference to FIG. 5, when the switching node 11 (n) receives an ATM cell (step 120), initially the explicit rate marking system 36 updates several counters which are used for monitoring cell traffic load and capacity. In particular, the explicit rate marking system 36 will increment a total counter which identifies the total number of cells received since the beginning of an interval (step 121). The explicit rate marking system 36 will also determine whether the ATM cell is for a virtual circuit using the ABR service (step 122), and, if so, increment an interval ABR cell counter and a buffered ABR cell counter (step 123). The interval ABR cell counter identifies the number of ATM cells which have been received since the beginning of the same interval. The buffered ABR cell counter identifies the number of cells for virtual circuits which utilize the ABR service currently in the switching node's buffer 32.
Thereafter, the explicit rate marking system 36 determines whether the total counter's value corresponds to a predetermined update interval value (step 124). If the explicit rate marking system 36 makes a negative determination in step 124, it will return to step 120 to wait for the arnval of the next ATM cell.
On the other hand, if the explicit rate marking system 36 makes a positive determination in step 124, it will sequence to a series of steps to update the variable bandwidth factor vbf. Initially, the explicit rate marking system 36 determines an update time interval value corresponding to the actual time interval over which the number of cells corresponding to the update interval value was received (step 125). Using the update time interval value, the explicit rate marking system 36 will determine an ABR rate value and a non-ABR rate value (step 126), the ABR rate value corresponding to the value provided by the interval ABR cell counter divided by the update time interval value and the non-ABR rate value corresponding to the difference between the value provided by the total counter and the interval ABR cell counter divided by the update time interval value. Thereafter, the explicit rate marking system 36 can reset the total counter and the interval ABR cell counter (step 127) for use during the next cell reception interval.
After the counters have been reset in step 127, the explicit rate marking system 36 updates an ABR bandwidth capacity value (which corresponds to C~ above) and an ABR
utilization value (step 128). The ABR bandwidth capacity value reflects the bandwidth that is currently available for the ABR service. The explicit rate marking system 36 updates the ABR bandwidth capacity value in relation to a smoothing value, the previously generated ABR bandwidth capacity value and the difference between the a target bandwidth utilization capacity for the respective communication link 13 (j ) and the non-ABR rate value as determined in step 126. It will be appreciated that the difference will generally correspond to the bandwidth capacity that is then available for the ABR service over the respective communication link. Generally, the smoothing value is selected to be between zero and one, and the explicit rate marking system 36 generates the updated ABR
bandwidth capacity value as the smoothing value multiplied by the difference between the target bandwidth utilization capacity for the respective communication link 13(j) and the non-ABR rate value, plus one minus the smoothing value multiplied by the current ABR bandwidth capacity value.
The smoothing value is used to smooth changes which may occur between vbf updates, and in one embodiment is selected to be on the order of one-eighth.
The ABR utilization value updated in step 128 reflects the portion of ABR
bandwidth capacity that is currently being utilized. The explicit rate marking system 36 updates the ABR
utilization value in relation to the smoothing value, the ABR rate value generated in step 126, the just-generated ABR bandwidth capacity value and the current ABR utilization value. Generally, the ABR rate divided by the ABR bandwidth capacity value reflects the portion of the ABR bandwidth capacity that is currently being utilized. Accordingly, the explicit rate marking system 36 generates the updated ABR utilization value as the smoothing value multiplied by the ABR
rate and divided by the ABR capacity value, plus one minus the smoothing value multiplied by the current ABR
utilization value.
Following step 128, the explicit rate marking system 36 generates the value of a vbf utilization factor, in relation to the current ABR cell occupancy of the buffer 32 as determined by the buffered ABR cell counter and three predetermined utilization factor values, namely, an maximum utilization factor value, an intermediate utilization factor value and a minimum utilization factor value. In that operation, the explicit rate marking system 36 initially determines whether the current ABR cell occupancy is below a low threshold value (step 129). If the explicit rate marking system 36 makes a positive determination in step 129, the number of cells for virtual circuits utilizing the ABR service is relatively low. In that case, the explicit rate marking system 36 initially generates a proportionality value as the difference between the maximum and intermediate utilization factors divided by the low threshold value (step 130), and the vbf utilization factor value as the maximum utilization factor value minus a value corresponding to the proportionality value times the value provided by the buffered ABR cell counter (step 131 ).
If the explicit rate marking system 36 makes a negative determination in step 129, it sequences to step 132, in which it determines whether the current ABR cell occupancy is between the low threshold value and a high threshold value. If the explicit rate marking system 36 makes a positive determination in step 132, it will determine the proportionality value as the difference between the intermediate and low utilization factor values divided by the difference between the high and low threshold values (step 133) and the vbf utilization factor as the intermediate utilization factor minus a value corresponding to the proportionality value determined in step 133 multiplied by the difference between the value provided by the buffered ABR cell counter and the minimum threshold value (step 134).
Finally, if the explicit rate marking system 36 makes a negative determination in step 132, it will be appreciated that the current ABR cell occupancy is above the high threshold value. In that case, the explicit rate marking system 36 determines the vbf utilization factor as the low utilization factor (step 135).
Preferably, the high and low threshold values, and the values for the maximum, intermediate and minimum utilization factor will be selected so that, (i) if the buffered ABR cell occupancy is zero, the vbf utilization factor value will correspond to the maximum utilization factor;
(ii) as the buffered ABR cell occupancy increases and approaches the low threshold value, the vbf utilization factor value will decrease from the high utilization factor and approach the intermediate utilization factor;
(iii) as the buffered ABR cell occupancy further increases an approaches the high threshold value, the vbf utilization factor value will continue decreasing from the intermediate utilization factor and approach the minimum utilization factor, and (iv) if the buffered ABR cell occupancy is above the high threshold value, the vbf utilization factor value will correspond to the minimum utilization factor.
In one embodiment, the maximum utilization factor is selected to have a value of on the order of 1.2, the intermediate utilization factor is selected to have a value of on the order of 0.9 and the minimum utilization factor is selected to have a value of on the order of 0.8.
After the explicit rate marking system 36 has determined the vbf utilization factor in step 131, 134 or 135, it proceeds to a series of steps in which it actually generates the value for the virtual bandwidth factor (vbf). Initially, the explicit rate marking system 36 will save the current vbf (step 136). Thereafter, the explicit rate marking system 36 determines whether (i) the ABR utilization rate updated in step 128 is less than predetermined target utilization rate and the vbf utilization factor is greater than one, or (ii) the ABR utilization rate updated in step 128 is greater than predetermined target utilization rate and the vbf utilization factor is less than one (step 137), and, if so multiplies the current vbf by the vbf utilization factor to generate a new current vbf (step 138). Following step 138, the explicit rate marking system 36 generates a new vbf as the sum of the current vbf multiplied by the smoothing factor, and the saved current vbf multiplied by one minus the smoothing factor (step 139). Thereafter, the explicit rate marking system 36 can determine whether the vbf is within a predetermined range and, if not, adjust the vbf to be within the range (step 140).
Operations performed by the explicit rate marking system 36 when an ATM cell is transmitted will be described in connection with FIG. 6. With reference to FIG. 6, when a cell is in condition to be transmitted (step 160), the explicit rate marking system 36 determines whether the cell is associated with a virtual circuit that makes use of the ABR service (step 161 ). If the explicit rate marking system 36 makes a negative determination in step 161, the control element will perform conventional operations to transmit the cell over the appropriate communication link 13(j ) (step 162).
On the other hand, ifthe explicit rate marking system 36 makes apositive determination in step 161, it will initially decrement the buffered ABR cell counter (step 163).
Thereafter, the explicit rate marking system 36 will determine whether the cell is a BRM (backward RM) cell (step 164). If the explicit rate marking system 36 makes a positive determination in step 164, it proceeds to generate a link explicit rate R;~ for the virtual circuit associated with the cell (step 165). If the explicit rate marking system 36 makes use of the equal shares methodology it will make use of equation (2), and if it makes use of the proportional share methodology it will make use of equation (3). In both cases, the explicit rate marking system 36 uses the virtual bandwidth value C'~
instead of the bandwidth value C~ available for the ABR service, and determines the virtual bandwidth value C'~ as the ABR
capacity multiplied by the most recently determined vbf value. The explicit rate marking system 36 then determines whether the link explicit rate R;~ determined in step 165 is less than the explicit rate value contained in the BRM cell (step 166) and, if so, substitutes the link explicit rate value determined in step 165 for the explicit rate value in the BRM cell (step 167).
Following step 167, step 166 if a negative determination is made in that step, or step 164 if a negative determination is made in that step, the control element 35 will enable the cell to be transmitted over the communication link 13(j) (step 168).
The invention provides a number of advantages. In particular, the invention provides an explicit rate marking system 36 which can, for each switching node 11 (n), generate explicit rates for virtual circuits which use the respective switching node, generally only in relation to their respective MCR's, the number ofbottlenecked and unbottlenecked virtual circuits, and the amount of bandwidth capacity available for the ABR service, which simplifies assignment of ABR
bandwidth capacity to each virtual circuit even if one or more of the virtual circuits is bottlenecked.
It will be appreciated that a system in accordance with the invention can be constructed in whole or in part from special purpose hardware or a general purpose computer system, or any combination thereof, any portion of which may be controlled by a suitable program. Any program may in whole or in part comprise part of or be stored on the system in a conventional manner, or it may in whole or in part be provided in to the system over a network or other mechanism for transferring information in a conventional manner. In addition, it will be appreciated that the system may be operated and/or otherwise controlled by means of information provided by an operator using operator input elements (not shown) which may be connected directly to the system or which may transfer the information to the system over a network or other mechanism for transferring information in a conventional manner.
The foregoing description has been limited to a specific embodiment of this invention. It will be apparent, however, that various variations and modifications may be made to the invention, with the attainment of some or all of the advantages of the invention. It is the object of the appended claims to cover these and such other variations and modifications as come within the true spirit and scope of the invention.
What is claimed as new and desired to be secured by Letters Patent of the United States is:

Claims (10)

1. An explicit rate marking system for use in connection with a switching node to generate an explicit rate value for use in a resource management cell associated with a virtual circuit in an ATM network, the explicit rate marking system comprising:
A. a virtual bandwidth value generator module configured to generate a virtual bandwidth value reflecting an available bandwidth capacity value, an explicit rate value associated with each bottlenecked virtual circuit for which said switching node forms part of a path, and a minimum cell rate value associated with each unbottlenecked virtual circuit for which said switching node forms part of a path, and B. an explicit rate value generator module configured to generate the explicit rate value in relation to the virtual bandwidth value and the minimum cell rate value associated with the virtual circuit and other virtual circuits for which said switching node forms part of a path.
2. An explicit rate marking system as defined in claim 1, the explicit rate marking system generating said explicit rate value in accordance with an equal share methodology, and in which said virtual bandwidth value generator module is configured to generate said virtual bandwidth value C'j in accordance with where C j represents the available bandwidth capacity value, MCR i represents the minimum cell rate for the "i-th" virtual circuit, I B(j) corresponds to the set of virtual circuits which are bottlenecked, I U(j) corresponds to the set of virtual circuits which are not bottlenecked, and N j is related to the number of virtual circuits for which the switching node part of the path.
3. An explicit rate marking system as defined in claim 2 in which said explicit rate value generator module is configured to generate said explicit rate value R ij in accordance with
4. An explicit rate marking system as defined in claim 1, the explicit rate marking system generating said explicit rate value in accordance with a proportional share methodology, and in which said virtual bandwidth value generator module is configured to generate said virtual bandwidth value C'j in accordance with where C j represents the available bandwidth capacity value, MCR i represents the minimum cell rate for the "i-th" virtual circuit, I B(j) corresponds to the set of virtual circuits which are bottlenecked, I U(j) corresponds to the set of virtual circuits which are not bottlenecked.
5. An explicit rate marking system as defined in claim 4 in which said explicit rate value generator module is configured to generate said explicit rate value R ij in accordance with
6. An explicit rate marking method for use in connection with a switching node to generate an explicit rate value for use in a resource management cell associated with a virtual circuit in an ATM
network, the explicit rate marking method comprising:
A. a virtual bandwidth value generator step including the step of generating a virtual bandwidth value reflecting an available bandwidth capacity value, an explicit rate value associated with each bottlenecked virtual circuit for which said switching node forms part of a path, and a minimum cell rate value associated with each unbottlenecked virtual circuit for which said switching node forms part of a path, and B. an explicit rate value generating step including the step of generating the explicit rate value in relation to the virtual bandwidth value and the minimum cell rate value associated with the virtual circuit and other virtual circuits for which said switching node forms part of a path.
7. An explicit rate marking method as defined in claim 6, the explicit rate marking method facilitating the generation of said explicit rate value in accordance with an equal share methodology, and said virtual bandwidth value generating step including the step of generating generate said virtual bandwidth value C'j in accordance with where C j represents the available bandwidth capacity value, MCR i represents the minimum cell rate for the "i-th" virtual circuit, I B(j) corresponds to the set of virtual circuits which are bottlenecked, I U(j) corresponds to the set of virtual circuits which are not bottlenecked, and N j is related to the number of virtual circuits for which the switching node part of the path.
8. An explicit rate marking method as defined in claim 7, said explicit rate value generating step including the step of generating said explicit rate value R ij in accordance with
9. An explicit rate marking system as defined in claim 6, the explicit rate marking method facilitating generation of said explicit rate value in accordance with a proportional share methodology, and in which said virtual bandwidth value generating step including the step of generating said virtual bandwidth value C'j in accordance with where C j represents the available bandwidth capacity value, MCR i represents the minimum cell rate for the "i-th" virtual circuit, I B(j) corresponds to the set of virtual circuits which are bottlenecked, I U(j) corresponds to the set of virtual circuits which are not bottlenecked.
10. An explicit rate marking method as defined in claim 9 in which said explicit rate value generating step includes the step of generating said explicit rate value R ij in accordance with
CA002332116A 1998-05-15 1999-05-17 Explicit rate marking for flow control in atm networks Abandoned CA2332116A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US8558998P 1998-05-15 1998-05-15
US60/085,589 1998-05-15
PCT/US1999/010807 WO1999060758A1 (en) 1998-05-15 1999-05-17 Explicit rate marking for flow control in atm networks

Publications (1)

Publication Number Publication Date
CA2332116A1 true CA2332116A1 (en) 1999-11-25

Family

ID=22192647

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002332116A Abandoned CA2332116A1 (en) 1998-05-15 1999-05-17 Explicit rate marking for flow control in atm networks

Country Status (5)

Country Link
EP (1) EP1110353A4 (en)
JP (1) JP2002516525A (en)
AU (1) AU750013B2 (en)
CA (1) CA2332116A1 (en)
WO (1) WO1999060758A1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100459770C (en) * 2006-04-12 2009-02-04 华为技术有限公司 Method for improving interface bandwidth utilization rate between wireless network controller and base-station

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997002685A1 (en) * 1995-07-03 1997-01-23 Nippon Telegraph And Telephone Corporation Variable band communication network
US5898669A (en) * 1996-03-22 1999-04-27 Shimony; Ilan ATM traffic management device
US5864539A (en) * 1996-05-06 1999-01-26 Bay Networks, Inc. Method and apparatus for a rate-based congestion control in a shared memory switch
US5909443A (en) * 1997-01-03 1999-06-01 International Business Machines Corporation ATM network congestion control system using explicit rate cell marking

Also Published As

Publication number Publication date
JP2002516525A (en) 2002-06-04
AU4081499A (en) 1999-12-06
EP1110353A4 (en) 2005-08-17
AU750013B2 (en) 2002-07-11
EP1110353A1 (en) 2001-06-27
WO1999060758A1 (en) 1999-11-25

Similar Documents

Publication Publication Date Title
EP0800296B1 (en) Digital network including mechanism for grouping virtual message transfer paths having similar transfer service rates to facilitate efficient scheduling of transfers thereover
US5935213A (en) System and method for generating explicit rate value information for flow control in ATAM network
JP5206765B2 (en) Transmission terminal device, network node, and relay switch
US5936939A (en) Digital network including early packet discard mechanism with adjustable threshold
EP0868058B1 (en) Apparatus and method for template-based scheduling in communication networks using regularity measure lower bounds
US6442164B1 (en) Method and system for allocating bandwidth and buffer resources to constant bit rate (CBR) traffic
EP0473188A1 (en) Method of controlling data transmission in ATM network with cell loss priority level
US6477167B1 (en) Method and system for allocating bandwith to real-time variable bit rate (rt-VBR) traffic
JPH11340983A (en) Scheduling circuit and method
WO1998025378A1 (en) Method for flow controlling atm traffic
JP3220112B2 (en) Congestion control method for ATM exchange
US6570854B1 (en) System and method for performing explicit rate marking for flow control in ATM networks using a virtual bandwidth-based methodology
US6307866B1 (en) Broadband telecommunications system
AU750013B2 (en) Explicit rate marking for flow control in ATM networks
EP0481447A2 (en) Method of controlling communication network incorporating virtual channels exchange nodes and virtual paths exchange nodes
US7130267B1 (en) System and method for allocating bandwidth in a network node
US7330475B2 (en) Method for sharing the bandwidth available for unicast and multicast flows in an asynchronous switching node
CA2295621C (en) Method for optimizing the workload on connection sections given abr traffic
EP0868056B1 (en) Apparatus and method for template-based scheduling in communication networks using regularity measures
KR100281411B1 (en) Integration Method of Reverse Resource Management Cell for Point-to-Multipoint Available Bit Rate Service
KR100257933B1 (en) Traffic Shaping Method for Compliance with Maximum Cell Rate in Asynchronous Transmission Mode Networks
Panken et al. A MAC protocol for an ATM PON supporting explicit rate congestion control for ABR traffic
JP2000324124A (en) Atm exchange
JP2003283551A (en) Communication device
Shahrier et al. A distributed access generic optical network interface for SMDS networks

Legal Events

Date Code Title Description
EEER Examination request
FZDE Discontinued