WO2001063856A1 - Flow control between transmitter and receiver entities in a communications system - Google Patents

Flow control between transmitter and receiver entities in a communications system Download PDF

Info

Publication number
WO2001063856A1
WO2001063856A1 PCT/SE2001/000407 SE0100407W WO0163856A1 WO 2001063856 A1 WO2001063856 A1 WO 2001063856A1 SE 0100407 W SE0100407 W SE 0100407W WO 0163856 A1 WO0163856 A1 WO 0163856A1
Authority
WO
WIPO (PCT)
Prior art keywords
entity
transmitter
mac
buffer
credit
Prior art date
Application number
PCT/SE2001/000407
Other languages
French (fr)
Inventor
Göran SCHULTZ
Janne Peisa
Toomas Wigell
Reijo Matinmikko
Original Assignee
Telefonaktiebolaget Lm Ericsson (Publ)
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 Telefonaktiebolaget Lm Ericsson (Publ) filed Critical Telefonaktiebolaget Lm Ericsson (Publ)
Priority to EP01908561A priority Critical patent/EP1264446A1/en
Priority to AU2001236303A priority patent/AU2001236303A1/en
Publication of WO2001063856A1 publication Critical patent/WO2001063856A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/10Flow control between communication endpoints
    • 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/30Flow control; Congestion control in combination with information about buffer occupancy at either end or at transit nodes
    • 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/39Credit based
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/0278Traffic management, e.g. flow control or congestion control using buffer status reports
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/10Flow control between communication endpoints
    • H04W28/14Flow control between communication endpoints using intermediate storage
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W80/00Wireless network protocols or protocol adaptations to wireless operation
    • H04W80/02Data link layer protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W88/00Devices specially adapted for wireless communication networks, e.g. terminals, base stations or access point devices
    • H04W88/12Access point controller devices

Definitions

  • the present invention relates in general to the field of communications systems, and in particular, by way of example but not limitation, to handling potential buffer overflows resulting from users overloading a communications system.
  • wireless networks Access to and use of wireless networks is becoming increasingly important and popular for business, social, and recreational purposes. Users of wireless networks now rely on them for both voice and data communications. Furthermore, an ever increasing number of users demand both an increasing array of services and capabilities as well as greater bandwidth for activities such as Internet surfing. To address and meet the demands for new services and greater bandwidth, the wireless communications industry constantly strives to improve the number of services and the throughput of their wireless networks. Expanding and improving the infrastructure necessary to provide additional services and higher bandwidth is an expensive and manpower-intensive undertaking. Moreover, high-bandwidth data streams will eventually be demanded by consumers to support features such as real-time audiovisual downloads and live audio-visual communication between two or more people. In the future, it will therefore become necessary and/or more cost-effective to introduce next generation wireless system(s) instead of attempting to upgrade existing system(s).
  • the wireless communications industry intends to continue to improve the capabilities of the technology upon which it relies and that it makes available to its customers by deploying next generation system(s).
  • Protocols for a next-generation standard that is designed to meet the developing needs of wireless customers is being standardized by the 3 rd Generation Partnership Project (3GPP).
  • 3GPP 3 rd Generation Partnership Project
  • the set of protocols is known collectively as the Universal Mobile Telecommunications System (UMTS).
  • UMTS Universal Mobile Telecommunications System
  • the network 100 includes a core network 120 and a packet data convergence protocol (GSM) network.
  • UMTS Universal Mobile Telecommunications
  • the network 100 includes a core network 120 and a packet data convergence protocol (GSM) network.
  • the UTRAN 130 is composed of, at least partially, a number of Radio Network Controllers (RNCs) 140, each of which may be coupled to one or more neighboring Node Bs 150.
  • RNCs Radio Network Controllers
  • Each Node B 150 is responsible for a given geographical cell and the controlling RNC 140 is responsible for routing user and signaling data between that Node B 150 and the core network 120. All of the RNCs 140 may be directly or indirectly coupled to one another.
  • a general outline of the UTRAN 130 is given in Technical Specification TS 25.401 V2.0.0 (1999-09) of the 3rd Generation Partnership Project, 3GPP, which is hereby incorporated by reference in its entirety herein.
  • the UMTS network 100 also includes multiple user equipments (UEs) 110.
  • UE may include, for example, mobile stations, mobile terminals, laptops/personal digital assistants (PDAs) with wireless links, etc.
  • a set of Radio Access Bearers is provided to make radio resources and services available to user applications.
  • RABs Radio Access Bearers
  • RABs Radio Link Control
  • RLC Radio Link Control
  • the RLC entities buffer the received data segments and map the RABs onto respective logical channels.
  • a Medium Access Control (MAC) entity receives data transmitted in the logical channels, and further maps the data from the logical channels onto a set of transport channels.
  • the transport channels are, in turn, mapped to a single physical transport channel having a specified total band width allocated to it by the associated network.
  • a MAC entity connected to a dedicated transport channel is known as MAC-d
  • MAC-c a MAC entity connected to a common transport channel
  • GPS Generalized Processor Sharing
  • an arrangement is made available which provides data flow from a number of different MAC-d entities, respectfully associated with different logical channels, with a fair share of the data rate between the Mac-d entities and a common MAC-c entity, and which also maintains the MAC-c buffer at or close to a desired fill level. This is achieved by sharing MAC-c buffer free space between active data flows of Mac-d entities according to a sequential, round robin or flow activity principle and using available information pertaining to the buffer fill levels of the respective RLC/MAC-d entities.
  • the invention is directed to a method for providing flow control in a wireless communications system which comprises the steps of providing a receiver entity and one or more transmitter entities, a given transmitter entity transmitting when it receives credit from the receiver entity.
  • the method further comprises the step of determining whether to give credit to respective transmitter entities.
  • the method comprises transmitting packets of data from respective transmitter entities to the receiver entity in a sequential or round robin fashion.
  • the receiver entity comprises a common Medium Access Control Entity (MAC-c) having a receiver buffer
  • each of the transmitter entities comprises a dedicated Medium Access Control (Mac-d) entity, each transmitter entity bearing associated with another buffer.
  • MAC-c Medium Access Control Entity
  • Mac-d Medium Access Control
  • the determination of the determining step is based, at least in part, on the fill level of the receiver buffer, and also on the fill levels of one or more buffers associated with respective transmitter entities.
  • determination is based, at least in part, on the fill level of the receiver buffer, but not on the fill levels of any of the buffers associated with transmitter entities.
  • Another embodiment of the invention includes the steps of ascertaining if a first active transmitter entity has a current credit which is less than the buffer fill level of an associated buffer, and if so, increasing the current credit of the first active transmitter entity by one and decreasing the available credit amount by one.
  • Such ascertaining step is repeated for each active transmitter entity until either the available credit amount is exhausted, or all active transmitter entities have their corresponding current credits to their corresponding buffer fill levels.
  • Such embodiment further includes the step of recording the last active transmitter entity to receive a credit, and making another active transmitter entity immediately following the last active transmitter in a sequence to be the first active transmitter entity to receive a credit on the next occasion when credits are distributed.
  • FIG. 1 illustrates an exemplary wireless communications system with which the present invention may be advantageously employed
  • FIG. 2 illustrates a protocol model for an exemplary next-generation system with which the present invention may be advantageously employed
  • FIG. 3 illustrates a view of an exemplary second layer architecture of an exemplary next-generation system in accordance with the present invention
  • FIG. 4 illustrates an exemplary method in flowchart form for allocating bandwidth resources to data flow streams between entities in the exemplary second layer architecture of FIG. 3;
  • FIG. 5 illustrates a flow control comprising an embodiment of the invention interconnected between transmit and receive entities.
  • FIG. 6 shows a portion of the embodiment of Figure 5 in greater detail.
  • FIG. 7 illustrates a buffer for the embodiment of Figure 5.
  • FIG. 8 illustrates operation of the flow control of the embodiment shown in
  • FIG 9 shows a buffer for a second embodiment of the invention.
  • FIG. 10 is a schematic diagram illustrating operation of the second embodiment.
  • FIG. 11 is a graph depicting the relationship between buffer fill level and credits for the second embodiment.
  • FIGs. 12 and 13 are schematic diagrams for illustrating a third embodiment of the invention.
  • FIGS. 1-13 of the drawings like numerals being used for like and corresponding parts of the various drawings.
  • Aspects of the UMTS are used to describe a preferred embodiment of the present invention. However, it should be understood that the principles of the present invention are applicable to other wireless communication standards (or systems), especially those in which communication is packet-based.
  • a protocol model for an exemplary next-generation system with which the present invention may be advantageously employed is illustrated generally at 200.
  • the "Uu” indicates the interface between UTRAN 130 and the UE 110
  • ' ub" indicates the interface between the RNC 140 and a Node B 150 (where "Node B” is a generalization of, for example, a Base Transceiver Station (BTS)).
  • BTS Base Transceiver Station
  • User and signaling data maybe carried between an RNC 140 and a UE 110 using Radio Access Bearers (RABs) (as illustrated hereinbelow with reference to FIG. 3).
  • RABs Radio Access Bearers
  • a UE 110 is allocated one or more RABs, each of which is capable of carrying a flow of user or signaling data.
  • RABs are mapped onto respective logical channels.
  • MAC Media Access Control
  • a set of logical channels is mapped in turn onto a transport Channel, of which there are two types: a "common” transport Channel which is shared by different UEs 110 and a "dedicated” transport Channel which is allocated to a single UE 110 (thus leading to the terms “MAC-c" and "MAC-d”).
  • One type of common Channel is the FACH.
  • a basic characteristic of a FACH is that it is possible to send one or more fixed size packets per transmission time interval (e.g., 10, 20, 40, or 80 ms).
  • transport channels e.g., FACHs
  • S-CCPCH Secondary Common Control Physical CHANNEL
  • the serving RNC 140 may subsequently differ from the controlling RNC 140 in a UMTS network 100, but the presence or absence of this condition is not particularly relevant here.
  • the RNC 140 both controls the air interface radio resources and terminates the layer 3 intelligence (e.g., the Radio Resource Control (RRC) protocol), thus routing data associated with the UE 110 directly to and from the core network 120.
  • RRC Radio Resource Control
  • the MAC-c entity in the RNC 140 transfers M AC- c Packet Data Units (PDUs) to the peer MAC-c entity at the UE 110 using the services of the FACH Frame Protocol (FACH FP) entity between the RNC 140 and the Node
  • the FACH FP entity adds header information to the MAC-c PDUs to form FACH FP PDUs which are transported to the Node B 150 over an AAL2 (or other transport mechanism) connection.
  • An interworking function at the Node B 150 interworks the FACH frame received by the FACH FP entity into the PHY entity.
  • an important task of the MAC-c entity is the scheduling of packets (MAC PDUs) for transmission over the air interface.
  • UMTS defines a framework in which different Quality of Services (QoSs) maybe assigned to different RABs. Packets corresponding to a RAB that has been allocated a high QoS should be transmitted over the air interface at a high priority whilst packets corresponding to a RAB that has been allocated a low QoS should be transmitted over the air interface at a lower priority. Priorities maybe determined at the MAC entity (e.g., MAC-c or MAC-d) on the basis of RAB parameters .
  • QoSs Quality of Services
  • UMTS deals with the question of priority by providing at the controlling RNC 140 a set of queues for each FACH.
  • the queues may be associated with respective priority levels.
  • An algorithm which is defined for selecting packets from the queues in such a way that packets in the higher priority queues are (on average) dealt with more quickly than packets in the lower priority queues, is implemented. The nature of this algorithm is complicated by the fact that the FACHs that are sent on the same physical Channel are not independent of one another. More particularly, a set of Transport Format Combinations (TFCs) is defined for each S-CCPCH, where each TFC includes a transmission time interval, a packet size, and a total transmission size (indicating the number of packets in the transmission) for each FACH. The algorithm should select for the FACHs a TFC which matches one of those present in the TFC set in accordance with UMTS protocols.
  • TFCs Transport Format Combinations
  • a packet received at the controlling RNC 140 is placed in a queue (for transmission on a FACH), where the queue corresponds to the priority level attached to the packet as well as to the size of the packet.
  • the FACH is mapped onto a S-CCPCH at a Node B 150 or other corresponding node of the UTRAN 130.
  • the packets for transmission on the FACH are associated with either a Dedicated Control CHANNEL (DCCH) or to a Dedicated Traffic CHANNEL (DTCH).
  • DCCH Dedicated Control CHANNEL
  • DTCH Dedicated Traffic CHANNEL
  • each FACH is arranged to carry only one size of packets. However, this is not necessary, and it may be that the packet size that can be carried by a given FACH varies from one transmission time interval to another.
  • the UE 110 may communicate with the core network 120 of the UMTS system 100 via separate serving and controlling (or drift) RNCs 140 within the UTRAN 130 (e.g., when the UE 110 moves from an area covered by the original serving RNC 140 into a new area covered by a controlling/drift RNC 140) (not specifically shown).
  • RNCs 140 within the UTRAN 130 (e.g., when the UE 110 moves from an area covered by the original serving RNC 140 into a new area covered by a controlling/drift RNC 140) (not specifically shown).
  • the UE 110 are received at the MAC-d entity of the serving RNC 140 from the core network 120 and are "mapped" onto logical channels, namely a Dedicated Control Channel (DCCH) and a Dedicated traffic CHANNEL (DTCH), for example.
  • the MAC-d entity constructs MAC Service Data Units (SDUs), which include a payload section containing logical channel data and a MAC header containing, inter alia, a logical channel identifier.
  • the MAC-d entity passes the MAC SDUs to the FACH FP entity.
  • This FACH FP entity adds a further FACH FP header to each MAC SDU, where the FACH FP header includes a priority level that has been allocated to the MAC SDU by an RRC entity.
  • the RRC is notified of available priority levels, together with an identification of one or more accepted packet sizes for each priority level, following the entry of a UE 110 into the coverage area of the drift RNC 140.
  • the FACH FP packets are sent to a peer FACH FP entity at the drift RNC 140 over an AAL2 (or other) connection.
  • the peer FACH FP entity decapsulates the MAC-d SDU and identifies the priority contained in the FRAME FP header.
  • the SDU and associated priority are passed to the MAC-c entity at the controlling RNC
  • the MAC-c layer is responsible for scheduling SDUs for transmission on the FACHs. More particularly, each SDU is placed in a queue corresponding to its priority and size. For example, if there are 16 priority levels, there will be 16 queue sets for each FACH, with the number of queues in each of the 16 queue sets depending upon the number of packet sizes accepted for the associated priority. As described hereinabove, SDUs are selected from the queues for a given FACH in accordance with some predefined algorithm (e.g., so as to satisfy the TFC requirements of the physical channel).
  • the scheme described hereinbelow with reference to FIGS. 3 and 4 relates to data transmission in a telecommunications network and in particular, though not necessarily, to data transmission in a UMTS.
  • the 3 GPP is currently in the process of standardizing a new set of protocols for mobile telecommunications systems.
  • the set of protocols is known collectively as the UMTS.
  • FIG. 3 a view of an exemplary second layer architecture of an exemplary next-generation system in accordance with the present invention is illustrated generally at 300.
  • the exemplary second layer architecture 300 illustrates a simplified UMTS layer 2 protocol structure which is involved in the communication between mobile stations (e.g.
  • the RNCs 140 are analogous to the Base Station Controllers (BSCs) of existing GSM mobile telecommunications networks, communicating with the mobile stations via Node Bs 150.
  • BSCs Base Station Controllers
  • the layer 2 structure of the exemplary second layer architecture 300 includes a set of Radio Access Bearers (RABs) 305 that make available radio resources (and services) to user applications.
  • RABs Radio Access Bearers
  • Data flows (e.g., in the form of segments) from the RABs 305 are passed to respective Radio Link Control (RLC) entities 310, which amongst other tasks buffer the received data segments.
  • RLC Radio Link Control
  • RABs 305 are mapped onto respective logical channels 315.
  • a Medium Access Control (MAC) entity 320 receives data transmitted in the logical channels 315 and further maps the data from the logical channels 315 onto a set of transport channels 325.
  • MAC Medium Access Control
  • the transport channels 325 are finally mapped to a single physical transport channel 330, which has a total bandwidth (e.g., of ⁇ 2Mbits/sec) allocated to it by the network.
  • a physical channel is used exclusively by one mobile station or is shared between many mobile stations, it is referred to as either a "dedicated physical channel” or a "common channel”.
  • a MAC entity connected to a dedicated physical channel is known as MAC-d; there is preferably one MAC-d entity for each mobile station.
  • a MAC entity connected to a common channel is known as MAC-c; there is preferably one MAC-c entity for each cell.
  • the bandwidth of a transport channel 325 is not directly restricted by the capabilities of the physical layer 330, but is rather configured by a Radio Resource
  • RRC Radio Resource Controller
  • TFs Transport Formats
  • Transport Blocks For each transport channel 325, the RRC entity 335 defines one or several Transport Block (TB) sizes. Each Transport Block size directly corresponds to an allowed MAC Protocol Data Unit (PDU) and tells the MAC entity what packet sizes it can use to transmit data to the physical layer.
  • PDU Protocol Data Unit
  • TBS Transport Block Set
  • MAC entity can transmit to the physical layer in a single transmission time interval (TTI).
  • TTI transmission time interval
  • TFC Transport Format Combination
  • ⁇ TF1 (80, 80)
  • the MAC entity can choose to transmit one or two PDUs in one TTI on the particular transport channel in question; in both cases, the PDUs have a size of 80 bits.
  • the MAC entity 320 In each TTI, the MAC entity 320 has to decide how much data to transmit on each transport channel 325 connected to it. These transport channels 325 are not independent of one another, and are later multiplexed onto a single physical channel 330 at the physical layer 330 (as discussed hereinabove).
  • the RRC entity 335 has to ensure that the total transmission capability on all transport channels 325 does not exceed the transmission capability of the underlying physical channel 330. This is accomplished by giving the MAC entity 320 a Transport Format Combination Set (TFCS), which contains the allowed Transport Format Combinations for all transport channels.
  • TFCS Transport Format Combination Set
  • MAC entity 320 which has two transport channels 325 that are further multiplexed onto a single physical channel 330, which has a transport capacity of 160 bits per transmission time interval (It should be understood that, in practice, the capacity will be much greater than 160).
  • TF2 (80, 80)
  • TF3 (80, 160)
  • the RRC entity 335 has to restrict the total transmission rate by not allowing all combinations of the TFs.
  • TFCI Transport Format Combination Indicator
  • TFCI Transport Format Combination Indicator
  • IP Internet Protocol
  • ATM Asynchronous Transfer Mode
  • GPS Generalized Processor Sharing
  • WFQ Weighted Fair Queuing
  • the weights calculated for all of the input flows are added together, and the total available output bandwidth is divided amongst the input flows depending upon the weight of each flow as a fraction of the total weight.
  • GPS could be applied to the MAC entity in UMTS, with the weighting for each input flow being determined (by the RRC entity) on the basis of certain RAB parameters, which are allocated to the corresponding RAB by the network.
  • RAB parameter may equate to a Quality of Service (QoS) or Guaranteed rate allocated to a user for a particular network service.
  • MAC entity logical channels in infinitely small blocks. This is not possible in UMTS, as UMTS relies upon Transport Format Combinations Sets (TFCSs) as the basic mechanism defining how much data can be sent in each TTI.
  • TFCSs Transport Format Combinations Sets
  • GPS is to be employed in UMTS, it is necessary to select the TFC (from the TFCS) which most closely matches the bandwidth allocated to an input flow by GPS.
  • the result of this approach is that the actual amount of data sent for an input stream in a given frame either may fall below the optimized rate or may exceed that optimized rate. In the former case, a backlog of unsent data may build up for the input flow.
  • MAC Media Access Control
  • UMTS UMTS
  • the method including the following steps for each frame of an output data flow: computing for each input flow to the MAC entity a fair share of the available output bandwidth of the MAC entity; selecting a Transport Format Combination (TFC) from a TFC Set (TFCS) on the basis of the bandwidth share computed for the input flows, where the TFC includes a Transport Format allocated to each input flow; and for each input flow, if the allocated TF results in a data transmission rate which is less than the determined fair distribution, adding the difference to a backlog counter for the input flow, where the value of the backlog counter(s) is taken into account when selecting a TFC for the subsequent frame of the output data flow.
  • TFC Transport Format Combination
  • TFCS TFC Set
  • Embodiments of this scheme allow the TFC selection process for a subsequent frame to take into account any backlogs which exists for the input flows. The tendency is to adjust the selected TFC to reduce the backlogs. Such a backlog may exist due to the finite number of data transmission possibilities provided for by the TFCS.
  • Nodes at which the method of this scheme may be employed include mobile stations (such as mobile telephones and communicator type devices) (or more generally UEs) and Radio
  • RNCs Network Controllers
  • the input flows to the MAC entity are provided by respective Radio Link Control (RLC) entities.
  • RLC Radio Link Control
  • each RLC entity provides buffering for the associated data flow.
  • RRC Radio Resource Control
  • the step of computing a fair share of resources for an input flow is carried out by a Radio Resource Control (RRC) entity.
  • RRC Radio Resource Control
  • the step of computing a fair share of resources for an input flow includes the step of determining the weighting given to that flow as a fraction of the sum of the weights given to all of the input flows.
  • the fair share may then be determined by multiplying the total output bandwidth by the determined fraction.
  • this step may involve using the Generalized Processor Sharing (GPS) mechanism.
  • the weighting for a data flow may be defined by one or more Radio Access Bearer (RAB) parameters allocated to a RAB by the UMTS network, where the RAB is associated with each MAC input flow.
  • RAB Radio Access Bearer
  • the method further includes the step of adding the value of the backlog counter to the computed fair share for that flow and selecting a TFC on the basis of the resulting sums for all of the input flows.
  • a node of a Universal Mobile Telecommunications System including: a Media Access Control (MAC) entity for receiving a plurality of input data flows; first processor means for computing for each input flow to the MAC entity a fair share of the available output bandwidth of the MAC entity and for selecting a Transport Format Combination (TFC), from a TFC Set (TFCS), on the basis of the bandwidth share computed for the input flows, where the TFC includes a Transport Format allocated to each input flow; second processor means for adding to a backlog counter associated with each input flow the difference between the data transmission rate for the flow resulting from the selected TFC and the determined fair share, if the data transmission rate is less than the determined fair share, where the first processor means is arranged to take into account the value of the backlog counters when selecting a TFC for the subsequent frame of the output data flow.
  • MAC Media Access Control
  • TFC Transport Format Combination
  • TFCS TFC Set
  • the first and second processor means are provided by a Radio Resource Control (RRC) entity.
  • RRC Radio Resource Control
  • a simplified UMTS layer 2 includes one Radio Resource Control (RRC) entity, a Medium Access Control (MAC) entity for each mobile station, and a Radio Link Control (RLC) entity for each Radio Access Bearer (RAB).
  • RRC Radio Resource Control
  • MAC Medium Access Control
  • RLC Radio Link Control
  • the MAC entity performs scheduling of outgoing data packets, while the RLC entities provide buffers for respective input flows.
  • the RRC entity sets a limit on the maximum amount of data that can be transmitted from each flow by assigning a set of allowed Transport Format Combinations (TFC) to each MAC (referred to as a TFC Set or TFCS), but each MAC must independently decide how much data is transmitted from each flow by choosing the best available Transport Format Combination (TFC) from the TFCS.
  • TFC Transport Format Combinations
  • the flowchart 400 is a flow diagram of a method of allocating bandwidth resources to, for example, the input flow streams ofa MAC entity of the layer 2 of FIG 3.
  • an exemplary method in accordance with the flowchart 400 may follow the following steps. First, input flows are received at RLCs and the data is buffered (step 405). Information on buffer fill levels is passed to the MAC entity (step 410). After the information on buffer fill levels is passed, the fair MAC bandwidth share for each input flow is computed (step 415). The computed fair share of each is then adjusted by adding the contents of an associated backlog counter to the respective computed fair share (step 420). Once the computed fair shares have been adjusted, a TFC is selected from the
  • the RLC is next instructed to deliver packets to the MAC entity according to the selected TFC (step 430).
  • the MAC entity may also schedule packets in accordance with the selected TFC (step 435).
  • the traffic channels may be transported on the physical Channel(s) (step 440) .
  • the backlog counters should be updated (step 445). The process may continue (via arrow 450) when new input flows are received at the RLCs, which buffer the data (at step 405).
  • the MAC entity on a per Transmission Time Interval (TTI) basis, the optimal distribution of available bandwidth using the Generalized Processor Sharing (GPS) approach (See, e.g., the article by A. K. Parekh et al. referenced hereinabove.) and by keeping track of how far behind each flow is from the optimal bandwidth allocation using respective backlog counters.
  • the available bandwidth is distributed to flows by using the standard GPS weights, which may be calculated by the RRC using the RAB parameters.
  • the method may first calculate the GPS distribution for the input flows and add to the GPS values the current respective backlogs. This is performed once for each 10ms TTI and results in a fair transmission rate for each flow.
  • this rate may not be optimal as it may happen that there is not enough data to be sent in all buffers.
  • the fair GPS distribution is reduced so as to not exceed the current buffer fill level or the maximum allowed rate for any logical Channel.
  • a two step rating process is then carried out.
  • the set of fair rates computed for all of the input flows is compared against possible Transport Format Combinations (TFCs) in turn, with each TFC being scored according to how close it comes to sending out the optimal rate. In practice this is done by simply counting how much of the fair configuration a TFC fails to send (if a given TFC can send all packets at the fair rate, it is given a score of zero) and then considering only the TFCs which have the lowest scores. The closest match is chosen and used to determine the amount of packets sent from each queue. TFCs having an equal score are given a bonus score according to how many extra bits they can send
  • the final selection is based on a two-level scoring: the TFC with the lowest score is taken. If there are several TFCs with an equal score, the one with the highest bonus score is chosen. This ensures that the rate for each TTI is maximized. Fairness is achieved by checking that if the chosen TFC does not give all flows at least their determined fair rate, the missing bits are added to a backlog counter of the corresponding flow and the selection is repeated for the next TTI. If any of the flows has nothing to transmit, the backlog is set to zero. This algorithm can be shown to provide bandwidth (and, under certain assumptions, delay bounds) that is close to that of GPS.
  • int maxrate int i ; int tfc, tfci, qf, rate, trch; int tfc_to_use;
  • FIG. 5 there is shown a portion of the second layer architecture depicted in Figure 3. More particularly, there is shown the MAC entity 320 of Figure 3 comprising a MAC-c entity 500, as described above, connected to a dedicated MAC-d entity 510, as likewise described above.
  • Figure 5 further shows RLC entities 515, which receive data in the form of segments from respective RAB's and map the data onto corresponding logical channels 315. Each of the RLC ' s 515 is provided with a buffer 520 for buffering received data segments comprising PDU's.
  • MAC-d entity 510 serves a single mobile station (not shown) and data transmitted by the MAC-d entity is directed through transport channel 325 to a dedicated physical Channel DPCH.
  • the common MAC-c entity 500 provided with buffers 525 and connected to receive data, or more specifically PDU' s, from MAC-d entity 510 as well as from other MAC-d entities which are not shown, h accordance with the invention, it is desired to provide a flow control mechanism 530 between each of the dedicated MAC-d entities and the common MAC-c entity 500.
  • the flow control 530 enables a number of different MAC-d entities which are respectively in an active data flow mode to share the available free space of MAC-c buffer 525.
  • the flow control is designed to provide each of the active MAC-d entities with a "fair share" of the additional data flow capacity provided by the MAC-d buffer free space, that is to ensure that all active MAC-d entities are given a reasonable opportunity to use such buffer capacity to enhance their respective data flow rates.
  • the available common transfer channel data rate is shared among all the active dedicated logical channels.
  • the flow control is further designed to maintain the fill level of the MAC-c entity buffer at or close to a desired optimum fill level.
  • data transmitted by MAC-c entity 500 is directed to a transport Channel FACH.
  • flow control 530 coupled to regulate data flow into the MAC-c PDU buffers 525 from each of a number RLCs 515, each coupled to a different mobile station or other User Equipment 1-n.
  • the flow control operates in accordance with a "round robin" or some other principle, that is, each of the MAC-d entities connected to a given MAC-c entity are enabled to transfer data thereto sequentially, or in turn, or by flow activity (greedy manner), hi this embodiment, credits are assigned to the respective MAC-d entities, in accordance with criteria described hereinafter in further detail.
  • a MAC-d entity Upon receiving a credit, a MAC-d entity is entitled to transmit one packet data unit to the MAC-c buffer 525.
  • MAC-c buffer 525 which is available for use by dedicated channels associated with MAC-d entities.
  • the MAC-c buffer has an optimum level Q copt , which is related to delay and throughput requirements in buffer operation.
  • the flow control 530 endeavors to maintain such level, using feedback information received from the MAC-d entities.
  • the flow control also functions to keep the MAC-c buffer as low as possible, so that delays related to use of a common channel will be equally distributed among different MAC-d users. If the level of buffer 525 at a particular time is Q c , the available buffer space Q cdiff is equal to Q copt -
  • the flow control 530 operates to share this space amongst MAC-d users by assigning equal numbers of credits to them, provided they have PDU's available for transmission.
  • the flow control calculates the credit for each MAC-d entity from both
  • the flow control establishes credit assignment criteria which is related to buffer level Q copt , as well to levels Q cmax and Q cun , also shown in Figure 7. These criteria are as follows: (1) If Q c , MAC-c buffer fill level, is less than Q cun , an infinite or unlimited credit is given to MAC-d entities. (2) If the current MAC-c buffer fill level Q c is greater than Q cun but less than Q copt , the difference (Q COpt -Q cun ) * s divided among active MAC-d entities. (3) If the current MAC-c buffer fill level Q c is greater than Q copt , no new credits are granted except initial credits. If the credits were previously set to 'unlimited' then they are cleared by sending ofa 'zero' credits to appropriate MAC-d entities.
  • an active user is a dedicated channel service that is connected to a common channel, and has data in its RLC-d buffer.
  • An active user changes to a passive user when its RLC-d buffer becomes empty.
  • the algorithm provides fair sharing of the total available band width between active users which have available band widths.
  • the algorithm also minimizes packet delay, which is of particular importance for users operating with small packets in situations when other users have packets of large size.
  • hi overload situations the flow control algorithm isolates different data from each other and increases RLC buffer fill level only for dedicated channels with the highest rates. The RLC buffer fill levels of other channels with unchanged rates will not be increased.
  • the algorithm supports working of a channel switching function that can identify and switch the overloaded channels toward dedicated transport channels.
  • the algorithm stores the user identification where it stops with the calculations, and continues with the next user identification when the flow control algorithm is used again.
  • Figure 8 shows steps 600, respectively numbered 1-18, which depict the sequential assignment of credits and corresponding transfer of data about with respect to several dedicated channels, respectively incorporating radio link controls RLC-1, RLC-2, and RLC-3.
  • steps 1-12 displays a notation indicating the step number, and also certain count information in parentheses.
  • the count information comprises the MAC-c buffer fill level Q c , the fill level Q d of a corresponding one of the dedicated channel buffers, and the available credit count at the conclusion of the step.
  • Item 620 shows the notation for step 2, by way of illustration.
  • the available data space Q cdiff in MAC-c buffer 525 is equivalent to 12 credits.
  • assigning a credit to a dedicated channel enables the channel to transfer a specified amount of data, such as one PDU, to the MAC-c buffer.
  • the channel of RLC-1 receives one credit.
  • the available space in the MAC-c buffer decreases from 12 to 11, and one PDU, corresponding to the 1 credit, can be transferred from the RLC-1 buffer to the MAC-c buffer. Accordingly, the data contents of the RLC-1 buffer which initially equivalent to 2 credits, diminishes to a Q d count of 1.
  • step 2 the RLC-2 channel has received 1 credit, the available Q c count has decreased to 10, and the count Q d of buffer RLC-2 has decreased to 3 from an initial count of 4.
  • step 3 associated with the RLC-3 buffer.
  • step 4 shows the next-following credit again assigned to the RLC-1 channel.
  • the Q d count of the RLC-1 count goes to zero, indicating that the channel has no more PDU's available.
  • step 5 directed to the RLC-2 channel, the next credit is assigned to the RLC-2 channel, as indicated in step 7. This is in accordance with criterion (2), set forth above.
  • flow control 530 again operates in accordance with a round robin or with flow activity (greedy manner) credit based algorithm.
  • MAC-c buffer 525 again used by dedicated channels.
  • the Q optimum (Q copt ) dashed line in figure 9 represents the optimum level in regard to unwanted buffer overflow, delay variance and good throughput.
  • the flow control endeavors to maintain the buffer at the Q cop , level by means of current buffer queue fill level (Q c) and queue maximum (Q cmax) threshold values, as well as by means of information pertaining to the active users routed to the MAC-c buffer.
  • Q c current buffer queue fill level
  • Q cmax queue maximum
  • an active user is a dedicated channel service that is connected to a common channel and has data in its RLC-d buffer.
  • An active user changes to a passive user when its RLC-d buffer becomes empty.
  • T h is processing delay/handling delay
  • T d is transmission delay
  • R cmax is FACH transport channel maximum rate for this buffer.
  • N mac . d is the number of active MAC-d entities and Q cmax is a buffer high level. Default value for Q cmax could be 2 * Q copJ .
  • the flow control has an associated preprocessing function which can be triggered to run from an incoming PDU, a timer, or both.
  • the preprocessor checks the credit status of users, the value of Q c and the number of active users of buffers. The flow control algorithm is not started if the Credit is greater than 0 or other predefined value.
  • Figure 11 shows the relationship between Q c and Credits, in accordance with
  • Equations (1) - (3) Dashed lines indicate an adjustment which is made to limit C to a maximum value.
  • Packets from RLC-d buffers through MAC-d are first transmitted to MAC-c appropriate buffers and then to FACH transport channels.
  • the MAC-d packets are transferred with Data Frames that also include RLC-d buffer fill level information, as indicated by path 700 in Figure 12.
  • the MAC-c controls user data flow from MAC-d using Control Frames that include credits, i.e., the number of packets the user may transmit, represented in Figure 12 by path 710.
  • the credits for the MAC-d user will be set to initial value by the MAC-c entity.
  • MAC-c will send a Control Frame message with an Initial Credits parameter to the MAC-d user, shown by path 730.
  • sending such message after receiving the last packet from a user increases transmission delay of the next-arriving packets, and also increases the number of Control Frame messages, as shown by Figure 12. hi order to achieve a smaller delay for the next packet from a user after the buffer thereof has become temporarily empty, as well to decrease the number of control messages, an Early Initial Credit granting arrangement is used.
  • the flow control algorithm in the MAC-c shall add Initial credit to the calculated credit.
  • an initial credit will be sent to the MAC-d in advance, and there will be no need to send any new credit parameter thereto after receiving the last packet.
  • Figure 13 shows that by using the Control Frame of path 740 (Credits and Initial Credits) the additional Control Frame of path 730 in Figure 12 is eliminated.

Abstract

In certain wireless communication systems, a common channel MAC-c layer (500), a dedicated channel MAC-d layer (510), and a Radio Link Controller are respectively located in a Radio Network Control. The MAC-c layer (500) is provided with a flow control mechanism (530) for managing a number of MAC-d entity data traffic flows directed to the MAC-c buffer (525), so that buffer fill level and the MAC-c entity (500) will remain at a desired level, and all respective data flows each gets a fair share of the data rate between the MAC-c (500) and MAC-d (510) entities. The flow control operates to share MAC-c buffer space with each MAC-d entity (510) providing an active data flow in a sequential, round robin fashion or based on flow activity (greedy manner). Buffer space is assigned or allocated on the basis of MAC-c upper fill level, and is some embodiments also on the basis of active MAC-d buffer fill levels.

Description

FLOW CONTROL BETWEEN TRANSMITTER AND RECEIVER
ENTITIES IN A COMMUNICATIONS SYSTEM
CROSS-REFERENCES TO RELATED APPLICATIONS
This Non-provisional Application for Patent claims the benefit of priority from, and hereby incorporates by reference the entire disclosure of, co-pending U.S. Provisional Application for Patent Serial No. 60/184,975, (Attorney Docket No. 34646-00458USPL) filed February 25, 2000. Co-pending U.S. Provisional Applications for Patent Serial Nos. 60/185,005 (Attorney Docket No. 34646-
00459USPL) and 60/185,003 (Attorney Docket No. 34646-00460USPL), both filed on February 25, 2000, are also hereby incorporated by reference in their entirety herein.
This Non-provisional Application for Patent is related by subj ect matter to U. S . Non-provisional Applications for PatentNos.09/698785 (Attorney DocketNo.34646-
00459USPT) and 09/698672 (Attorney Docket No. 34646-00460USPT), both of which are filed on even date herewith. These two U.S. Non-provisional Applications for Patent are also hereby incorporated by reference in their entirety herein.
BACKGROUND OF THE INVENTION
Technical Field of the Invention
The present invention relates in general to the field of communications systems, and in particular, by way of example but not limitation, to handling potential buffer overflows resulting from users overloading a communications system. Description of Related Art
Access to and use of wireless networks is becoming increasingly important and popular for business, social, and recreational purposes. Users of wireless networks now rely on them for both voice and data communications. Furthermore, an ever increasing number of users demand both an increasing array of services and capabilities as well as greater bandwidth for activities such as Internet surfing. To address and meet the demands for new services and greater bandwidth, the wireless communications industry constantly strives to improve the number of services and the throughput of their wireless networks. Expanding and improving the infrastructure necessary to provide additional services and higher bandwidth is an expensive and manpower-intensive undertaking. Moreover, high-bandwidth data streams will eventually be demanded by consumers to support features such as real-time audiovisual downloads and live audio-visual communication between two or more people. In the future, it will therefore become necessary and/or more cost-effective to introduce next generation wireless system(s) instead of attempting to upgrade existing system(s).
To that end, the wireless communications industry intends to continue to improve the capabilities of the technology upon which it relies and that it makes available to its customers by deploying next generation system(s). Protocols for a next-generation standard that is designed to meet the developing needs of wireless customers is being standardized by the 3rd Generation Partnership Project (3GPP). The set of protocols is known collectively as the Universal Mobile Telecommunications System (UMTS).
Referring now to FIG. 1, an exemplary wireless communications system with which the present invention may be advantageously employed is illustrated generally at 100. In a UMTS network 100, the network 100 includes a core network 120 and a
UMTS Terrestrial Radio Access Network (UTRAN) 130. The UTRAN 130 is composed of, at least partially, a number of Radio Network Controllers (RNCs) 140, each of which may be coupled to one or more neighboring Node Bs 150. Each Node B 150 is responsible for a given geographical cell and the controlling RNC 140 is responsible for routing user and signaling data between that Node B 150 and the core network 120. All of the RNCs 140 may be directly or indirectly coupled to one another. A general outline of the UTRAN 130 is given in Technical Specification TS 25.401 V2.0.0 (1999-09) of the 3rd Generation Partnership Project, 3GPP, which is hereby incorporated by reference in its entirety herein. The UMTS network 100 also includes multiple user equipments (UEs) 110. UE may include, for example, mobile stations, mobile terminals, laptops/personal digital assistants (PDAs) with wireless links, etc.
In an exemplary second layer of the architectural structure of the UMTS, a set of Radio Access Bearers (RABs) is provided to make radio resources and services available to user applications. For each mobile station, there may be one or several
RABs, and data flows from the RABs to respective Radio Link Control (RLC) entities in the form of segments. The RLC entities buffer the received data segments and map the RABs onto respective logical channels. A Medium Access Control (MAC) entity receives data transmitted in the logical channels, and further maps the data from the logical channels onto a set of transport channels. The transport channels are, in turn, mapped to a single physical transport channel having a specified total band width allocated to it by the associated network. A MAC entity connected to a dedicated transport channel is known as MAC-d, and a MAC entity connected to a common transport channel is known as MAC-c. Preferably, there is one MAC-d entity for each mobile station in the UMTS, and one MAC-c entity for each cell.
During each transmission time interval of the system, the MAC entity has to decide how much data to transmit on each transport channel connected to it. In making this decision, it is necessary to share the total available band width between the logical channels receiving information from different RABs and their respective RLCs coupled to different mobile stations, hi the past, sharing resources between multiple input data flows has been referred to as Generalized Processor Sharing (GPS). However, it has been recognized that there are difficulties involved in applying GPS directly to bandwidth allocations in a UMTS network. More specifically, GPS assumes that data can be sent on the MAC entity logical channels in infinitely small blocks. This is not possible in UMTS. Accordingly, it is necessary to provide an alternative arrangement for managing or controlling data flow in the UMTS, in order to share the total available bandwidth among different logical channels receiving information from different RAB's. SUMMARY OF THE INVENTION
The above-identified deficiencies, as well as others that are associated with existing schemes, are remedied by the methods, systems and arrangements of the present invention. More particularly, an arrangement is made available which provides data flow from a number of different MAC-d entities, respectfully associated with different logical channels, with a fair share of the data rate between the Mac-d entities and a common MAC-c entity, and which also maintains the MAC-c buffer at or close to a desired fill level. This is achieved by sharing MAC-c buffer free space between active data flows of Mac-d entities according to a sequential, round robin or flow activity principle and using available information pertaining to the buffer fill levels of the respective RLC/MAC-d entities.
Generally, the invention is directed to a method for providing flow control in a wireless communications system which comprises the steps of providing a receiver entity and one or more transmitter entities, a given transmitter entity transmitting when it receives credit from the receiver entity. The method further comprises the step of determining whether to give credit to respective transmitter entities.
In a preferred embodiment of the invention, the method comprises transmitting packets of data from respective transmitter entities to the receiver entity in a sequential or round robin fashion. The receiver entity comprises a common Medium Access Control Entity (MAC-c) having a receiver buffer, and each of the transmitter entities comprises a dedicated Medium Access Control (Mac-d) entity, each transmitter entity bearing associated with another buffer. In one useful embodiment, the determination of the determining step is based, at least in part, on the fill level of the receiver buffer, and also on the fill levels of one or more buffers associated with respective transmitter entities. In another useful embodiment, determination is based, at least in part, on the fill level of the receiver buffer, but not on the fill levels of any of the buffers associated with transmitter entities. Another embodiment of the invention includes the steps of ascertaining if a first active transmitter entity has a current credit which is less than the buffer fill level of an associated buffer, and if so, increasing the current credit of the first active transmitter entity by one and decreasing the available credit amount by one.
Such ascertaining step is repeated for each active transmitter entity until either the available credit amount is exhausted, or all active transmitter entities have their corresponding current credits to their corresponding buffer fill levels. Such embodiment further includes the step of recording the last active transmitter entity to receive a credit, and making another active transmitter entity immediately following the last active transmitter in a sequence to be the first active transmitter entity to receive a credit on the next occasion when credits are distributed.
The above-described and other features of the present invention are explained in detail hereinafter with reference to the illustrative examples shown in the accompanying drawings. Those skilled in the art will appreciate that the described embodiments are provided for purposes of illustration and understanding and that numerous equivalent embodiments are contemplated herein.
BRIEF DESCRIPTION OF THE DRAWINGS
A more complete understanding of the methods, systems, and arrangements of the present invention may be had by reference to the following detailed description when taken in conjunction with the accompanying drawings wherein:
FIG. 1 illustrates an exemplary wireless communications system with which the present invention may be advantageously employed;
FIG. 2 illustrates a protocol model for an exemplary next-generation system with which the present invention may be advantageously employed;
FIG. 3 illustrates a view of an exemplary second layer architecture of an exemplary next-generation system in accordance with the present invention;
FIG. 4 illustrates an exemplary method in flowchart form for allocating bandwidth resources to data flow streams between entities in the exemplary second layer architecture of FIG. 3;
FIG. 5 illustrates a flow control comprising an embodiment of the invention interconnected between transmit and receive entities.
FIG. 6 shows a portion of the embodiment of Figure 5 in greater detail. FIG. 7 illustrates a buffer for the embodiment of Figure 5. FIG. 8 illustrates operation of the flow control of the embodiment shown in
Figure 5. FIG 9 shows a buffer for a second embodiment of the invention. FIG. 10 is a schematic diagram illustrating operation of the second embodiment.
FIG. 11 is a graph depicting the relationship between buffer fill level and credits for the second embodiment.
FIGs. 12 and 13 are schematic diagrams for illustrating a third embodiment of the invention.
DETAILED DESCRIPTION OF THE DRAWINGS the following description, for purposes of explanation and not limitation, specific details are set forth, such as particular circuits, logic modules (implemented in, for example, software, hardware, firmware, some combination thereof, etc.), techniques, etc. in order to provide a thorough understanding of the invention. However, it will be apparent to one of ordinary skill in the art that the present invention may be practiced in other embodiments that depart from these specific details. In other instances, detailed descriptions of well-known methods, devices, logical code (e.g., hardware, software, firmware, etc.), etc. are omitted so as not to obscure the description of the present invention with unnecessary detail.
A preferred embodiment of the present invention and its advantages are best understood by referring to FIGS. 1-13 of the drawings, like numerals being used for like and corresponding parts of the various drawings. Aspects of the UMTS are used to describe a preferred embodiment of the present invention. However, it should be understood that the principles of the present invention are applicable to other wireless communication standards (or systems), especially those in which communication is packet-based.
Referring now to FIG. 2, a protocol model for an exemplary next-generation system with which the present invention may be advantageously employed is illustrated generally at 200. In the protocol model 200 (e.g., for a Forward Access Channel (FACH) transport Channel type), the "Uu" indicates the interface between UTRAN 130 and the UE 110, and ' ub" indicates the interface between the RNC 140 and a Node B 150 (where "Node B" is a generalization of, for example, a Base Transceiver Station (BTS)). User and signaling data maybe carried between an RNC 140 and a UE 110 using Radio Access Bearers (RABs) (as illustrated hereinbelow with reference to FIG. 3). Typically, a UE 110 is allocated one or more RABs, each of which is capable of carrying a flow of user or signaling data. RABs are mapped onto respective logical channels. At the Media Access Control (MAC) layer, a set of logical channels is mapped in turn onto a transport Channel, of which there are two types: a "common" transport Channel which is shared by different UEs 110 and a "dedicated" transport Channel which is allocated to a single UE 110 (thus leading to the terms "MAC-c" and "MAC-d"). One type of common Channel is the FACH. A basic characteristic of a FACH is that it is possible to send one or more fixed size packets per transmission time interval (e.g., 10, 20, 40, or 80 ms). Several transport channels (e.g., FACHs) are in turn mapped at the physical layer onto a Secondary Common Control Physical CHANNEL (S-CCPCH) for transmission over the air interface between a Node B 150 and a UE 110. When a UE 110 registers with an RNC 140 via a Node B 150, that RNC 140 acts at least initially as both the serving and the controlling RNC 140 for the UE 110. (The serving RNC 140 may subsequently differ from the controlling RNC 140 in a UMTS network 100, but the presence or absence of this condition is not particularly relevant here.) The RNC 140 both controls the air interface radio resources and terminates the layer 3 intelligence (e.g., the Radio Resource Control (RRC) protocol), thus routing data associated with the UE 110 directly to and from the core network 120.
It should be understood that the MAC-c entity in the RNC 140 transfers M AC- c Packet Data Units (PDUs) to the peer MAC-c entity at the UE 110 using the services of the FACH Frame Protocol (FACH FP) entity between the RNC 140 and the Node
B 150. The FACH FP entity adds header information to the MAC-c PDUs to form FACH FP PDUs which are transported to the Node B 150 over an AAL2 (or other transport mechanism) connection. An interworking function at the Node B 150 interworks the FACH frame received by the FACH FP entity into the PHY entity. In an exemplary aspect of the scenario illustrated in FIG. 2, an important task of the MAC-c entity is the scheduling of packets (MAC PDUs) for transmission over the air interface. If it were the case that all packets received by the MAC-c entity were of equal priority (and of the same size), then scheduling would be a simple matter of queuing the received packets and sending them on a first come first served basis (e.g., first-in, first-out (FIFO)). However, UMTS defines a framework in which different Quality of Services (QoSs) maybe assigned to different RABs. Packets corresponding to a RAB that has been allocated a high QoS should be transmitted over the air interface at a high priority whilst packets corresponding to a RAB that has been allocated a low QoS should be transmitted over the air interface at a lower priority. Priorities maybe determined at the MAC entity (e.g., MAC-c or MAC-d) on the basis of RAB parameters .
UMTS deals with the question of priority by providing at the controlling RNC 140 a set of queues for each FACH. The queues may be associated with respective priority levels. An algorithm, which is defined for selecting packets from the queues in such a way that packets in the higher priority queues are (on average) dealt with more quickly than packets in the lower priority queues, is implemented. The nature of this algorithm is complicated by the fact that the FACHs that are sent on the same physical Channel are not independent of one another. More particularly, a set of Transport Format Combinations (TFCs) is defined for each S-CCPCH, where each TFC includes a transmission time interval, a packet size, and a total transmission size (indicating the number of packets in the transmission) for each FACH. The algorithm should select for the FACHs a TFC which matches one of those present in the TFC set in accordance with UMTS protocols.
Preferably, a packet received at the controlling RNC 140 is placed in a queue (for transmission on a FACH), where the queue corresponds to the priority level attached to the packet as well as to the size of the packet. The FACH is mapped onto a S-CCPCH at a Node B 150 or other corresponding node of the UTRAN 130. In an alternative preference, the packets for transmission on the FACH are associated with either a Dedicated Control CHANNEL (DCCH) or to a Dedicated Traffic CHANNEL (DTCH). It should be noted that, preferably, each FACH is arranged to carry only one size of packets. However, this is not necessary, and it may be that the packet size that can be carried by a given FACH varies from one transmission time interval to another. As alluded to hereinabove, the UE 110 may communicate with the core network 120 of the UMTS system 100 via separate serving and controlling (or drift) RNCs 140 within the UTRAN 130 (e.g., when the UE 110 moves from an area covered by the original serving RNC 140 into a new area covered by a controlling/drift RNC 140) (not specifically shown). Signaling and user data packets destined for the
UE 110 are received at the MAC-d entity of the serving RNC 140 from the core network 120 and are "mapped" onto logical channels, namely a Dedicated Control Channel (DCCH) and a Dedicated traffic CHANNEL (DTCH), for example. The MAC-d entity constructs MAC Service Data Units (SDUs), which include a payload section containing logical channel data and a MAC header containing, inter alia, a logical channel identifier. The MAC-d entity passes the MAC SDUs to the FACH FP entity. This FACH FP entity adds a further FACH FP header to each MAC SDU, where the FACH FP header includes a priority level that has been allocated to the MAC SDU by an RRC entity. The RRC is notified of available priority levels, together with an identification of one or more accepted packet sizes for each priority level, following the entry of a UE 110 into the coverage area of the drift RNC 140.
The FACH FP packets are sent to a peer FACH FP entity at the drift RNC 140 over an AAL2 (or other) connection. The peer FACH FP entity decapsulates the MAC-d SDU and identifies the priority contained in the FRAME FP header. The SDU and associated priority are passed to the MAC-c entity at the controlling RNC
140. The MAC-c layer is responsible for scheduling SDUs for transmission on the FACHs. More particularly, each SDU is placed in a queue corresponding to its priority and size. For example, if there are 16 priority levels, there will be 16 queue sets for each FACH, with the number of queues in each of the 16 queue sets depending upon the number of packet sizes accepted for the associated priority. As described hereinabove, SDUs are selected from the queues for a given FACH in accordance with some predefined algorithm (e.g., so as to satisfy the TFC requirements of the physical channel).
The scheme described hereinbelow with reference to FIGS. 3 and 4 relates to data transmission in a telecommunications network and in particular, though not necessarily, to data transmission in a UMTS. As noted hereinabove, the 3 GPP is currently in the process of standardizing a new set of protocols for mobile telecommunications systems. The set of protocols is known collectively as the UMTS. With reference to FIG. 3, a view of an exemplary second layer architecture of an exemplary next-generation system in accordance with the present invention is illustrated generally at 300. Specifically, by way of example only, the exemplary second layer architecture 300 illustrates a simplified UMTS layer 2 protocol structure which is involved in the communication between mobile stations (e.g. mobile telephones), or more broadly UEs 110, and Radio Network Controllers (RNCs) 140 of a UMTS network 100. The RNCs 140 are analogous to the Base Station Controllers (BSCs) of existing GSM mobile telecommunications networks, communicating with the mobile stations via Node Bs 150.
The layer 2 structure of the exemplary second layer architecture 300 includes a set of Radio Access Bearers (RABs) 305 that make available radio resources (and services) to user applications. For each mobile station there may be one or several RABs 305. Data flows (e.g., in the form of segments) from the RABs 305 are passed to respective Radio Link Control (RLC) entities 310, which amongst other tasks buffer the received data segments. There is one RLC entity 310 for each RAB 305. In the RLC layer, RABs 305 are mapped onto respective logical channels 315. A Medium Access Control (MAC) entity 320 receives data transmitted in the logical channels 315 and further maps the data from the logical channels 315 onto a set of transport channels 325. The transport channels 325 are finally mapped to a single physical transport channel 330, which has a total bandwidth (e.g., of <2Mbits/sec) allocated to it by the network. Depending whether a physical channel is used exclusively by one mobile station or is shared between many mobile stations, it is referred to as either a "dedicated physical channel" or a "common channel". A MAC entity connected to a dedicated physical channel is known as MAC-d; there is preferably one MAC-d entity for each mobile station. A MAC entity connected to a common channel is known as MAC-c; there is preferably one MAC-c entity for each cell.
The bandwidth of a transport channel 325 is not directly restricted by the capabilities of the physical layer 330, but is rather configured by a Radio Resource
Controller (RRC) entity 335 using Transport Formats (TFs). For each transport channel 325, the RRC entity 335 defines one or several Transport Block (TB) sizes. Each Transport Block size directly corresponds to an allowed MAC Protocol Data Unit (PDU) and tells the MAC entity what packet sizes it can use to transmit data to the physical layer. In addition to block size, the RRC entity 335 informs the MAC entity 320 of a Transport Block Set (TBS) size, which is the total number of bits the
MAC entity can transmit to the physical layer in a single transmission time interval (TTI). The TB size and TBS size, together with some additional information relating to the allowed physical layer configuration, form a TF. An example ofa TF is (TB=80 bits, TBS=160 bits), which means that the MAC entity 320 can transmit two 80 bit packets in a single TTI. Thus, this TF can be written as TF=(80, 160). The RRC entity
335 also informs the MAC entity of all possible TFs for a given transport channel. This combination of TFs is called a Transport Format Combination (TFC). An example ofa TFC is {TF1=(80, 80), TF2=(80, 160)}. In this example, the MAC entity can choose to transmit one or two PDUs in one TTI on the particular transport channel in question; in both cases, the PDUs have a size of 80 bits.
In each TTI, the MAC entity 320 has to decide how much data to transmit on each transport channel 325 connected to it. These transport channels 325 are not independent of one another, and are later multiplexed onto a single physical channel 330 at the physical layer 330 (as discussed hereinabove). The RRC entity 335 has to ensure that the total transmission capability on all transport channels 325 does not exceed the transmission capability of the underlying physical channel 330. This is accomplished by giving the MAC entity 320 a Transport Format Combination Set (TFCS), which contains the allowed Transport Format Combinations for all transport channels. By way of example, consider a MAC entity 320 which has two transport channels 325 that are further multiplexed onto a single physical channel 330, which has a transport capacity of 160 bits per transmission time interval (It should be understood that, in practice, the capacity will be much greater than 160). The RRC entity 335 could decide to assign three transport formats TF1=(80, 0), TF2=(80, 80) and TF3=(80, 160) to both transport channels 325. Clearly however, the MAC entity
320 cannot choose to transmit on both transport channels 325 at the same time using TF3 as this would result in the need to transmit 320 bits on the physical channel 330, which has only a capability to transmit 160 bits. The RRC entity 335 has to restrict the total transmission rate by not allowing all combinations of the TFs. An example of this would be a TFCS as follows [{(80, 0), (80, 0)}, {(80, 0), (80, 80)}, {(80, 0), (80, 160)}, {(80, 80), (80, 0)}, {(80, 80), (80, 80)}, {(80, 160), (80, 0)}], where the transport format of transport channel "1" is given as the first element of each element pair, and the transport format of transport channel "2" is given as the second element. As the MAC entity 320 can only choose one of these allowed transport format combinations from the transport format combination set, it is not possible to exceed the capability of the physical channel 330.
An element of the TFCS is pointed out by a Transport Format Combination Indicator (TFCI), which is the index of the corresponding TFC. For example, in the previous example there are 6 different TFCs, meaning that the TFCI can take any value between 1 and 6. The TFCI=2 would correspond to the second TFC, which is {(80, 0), (80, 80)}, meaning that nothing is transmitted from the first transport channel and a single packet of 80 bits is transmitted from the second transport channel.
It is of course necessary to share the total available bandwidth between the logical channels 315. The decision to distribute the bandwidth to different transport channels is made by the MAC entity 320 for each transmission time interval by choosing a suitable TFCI. This sharing of bandwidth can be done in several ways, for example by giving an absolute preference to flows which are considered to be more important than others. This would be the easiest method to implement, but can result in a very unfair distribution of the bandwidth. Specifically, it is possible that flows that have lower priorities are not allowed to transmit for prolonged periods of time. This can result in extremely poor performance if the flow control mechanism of a lower priority flow reacts to this. A typical example of such a flow control mechanism can be found in the present day Transmission Control Protocol (TCP) protocol used in the Internet. In existing technologies, such as Internet Protocol (IP) and Asynchronous Transfer Mode (ATM) networks, provision is made for allocating resources on a single output channel to multiple input flows . However, the algorithms used to share out the resources in such systems are not directly applicable to UMTS where multiple input flows are transmitted on respective logical output channels.
Sharing resources between multiple input data flows is referred to as Generalized Processor Sharing (GPS). This GPS, when employed in systems having only a single output channel, is known as Weighted Fair Queuing (WFQ) and is described in a paper entitled "A Generalized Processor Sharing Approach to Flow Control in Integrated Services Networks: The Single Node Case", A. K. Parekh, R. G. Gallager, published in IEEE/ ACM Transactions On Networking, Vol. 1, No. 3, June 1993, Pp. 344-357. Stated simply, GPS involves calculating a GPS weight for each input flow on the basis of certain parameters associated with the flow. The weights calculated for all of the input flows are added together, and the total available output bandwidth is divided amongst the input flows depending upon the weight of each flow as a fraction of the total weight. GPS could be applied to the MAC entity in UMTS, with the weighting for each input flow being determined (by the RRC entity) on the basis of certain RAB parameters, which are allocated to the corresponding RAB by the network. In particular, an RAB parameter may equate to a Quality of Service (QoS) or Guaranteed rate allocated to a user for a particular network service.
Continuing now with the scheme described herein with reference to FIGS. 3 and 4, it was realized that there are difficulties involved in applying GPS directly to bandwidth allocation in a UMTS network, as GPS assumes that data can be sent on the
MAC entity logical channels in infinitely small blocks. This is not possible in UMTS, as UMTS relies upon Transport Format Combinations Sets (TFCSs) as the basic mechanism defining how much data can be sent in each TTI. If GPS is to be employed in UMTS, it is necessary to select the TFC (from the TFCS) which most closely matches the bandwidth allocated to an input flow by GPS. The result of this approach is that the actual amount of data sent for an input stream in a given frame either may fall below the optimized rate or may exceed that optimized rate. In the former case, a backlog of unsent data may build up for the input flow.
It is an object of the scheme described herein with reference to FIGS. 3 and 4 to overcome, or at least mitigate, the disadvantage noted in the preceding paragraph.
This and other objects are achieved at least in part by maintaining a backlog counter which keeps track of the backlog of unsent data for a given input flow to the MAC entity. The backlog is taken into account when determining an appropriate TFC for that input flow for a subsequent frame. According to a first aspect of this scheme, there is provided a method of allocating transmission resources at a Media Access Control (MAC) entity of a node of a Universal Mobile Telecommunications System
(UMTS), the method including the following steps for each frame of an output data flow: computing for each input flow to the MAC entity a fair share of the available output bandwidth of the MAC entity; selecting a Transport Format Combination (TFC) from a TFC Set (TFCS) on the basis of the bandwidth share computed for the input flows, where the TFC includes a Transport Format allocated to each input flow; and for each input flow, if the allocated TF results in a data transmission rate which is less than the determined fair distribution, adding the difference to a backlog counter for the input flow, where the value of the backlog counter(s) is taken into account when selecting a TFC for the subsequent frame of the output data flow. Embodiments of this scheme allow the TFC selection process for a subsequent frame to take into account any backlogs which exists for the input flows. The tendency is to adjust the selected TFC to reduce the backlogs. Such a backlog may exist due to the finite number of data transmission possibilities provided for by the TFCS. Nodes at which the method of this scheme may be employed include mobile stations (such as mobile telephones and communicator type devices) (or more generally UEs) and Radio
Network Controllers (RNCs).
Preferably, the input flows to the MAC entity are provided by respective Radio Link Control (RLC) entities. Also preferably, each RLC entity provides buffering for the associated data flow. Also preferably, the step of computing a fair share of resources for an input flow is carried out by a Radio Resource Control (RRC) entity.
Also preferably, the step of computing a fair share of resources for an input flow includes the step of determining the weighting given to that flow as a fraction of the sum of the weights given to all of the input flows. The fair share may then be determined by multiplying the total output bandwidth by the determined fraction. Also preferably, this step may involve using the Generalized Processor Sharing (GPS) mechanism. The weighting for a data flow may be defined by one or more Radio Access Bearer (RAB) parameters allocated to a RAB by the UMTS network, where the RAB is associated with each MAC input flow. Also preferably, in the event that the backlog counter for a given input flow has a positive value, the method further includes the step of adding the value of the backlog counter to the computed fair share for that flow and selecting a TFC on the basis of the resulting sums for all of the input flows. hi certain embodiments of the scheme described herein with reference to FIGS . 3 and 4, where, for a given input flow, the allocated TF results in a data transmission rate that is more than the determined fair distribution, the difference maybe subtracted from the backlog counter for the input flow. According to a second aspect of this scheme, there is provided a node of a Universal Mobile Telecommunications System (UMTS), the node including: a Media Access Control (MAC) entity for receiving a plurality of input data flows; first processor means for computing for each input flow to the MAC entity a fair share of the available output bandwidth of the MAC entity and for selecting a Transport Format Combination (TFC), from a TFC Set (TFCS), on the basis of the bandwidth share computed for the input flows, where the TFC includes a Transport Format allocated to each input flow; second processor means for adding to a backlog counter associated with each input flow the difference between the data transmission rate for the flow resulting from the selected TFC and the determined fair share, if the data transmission rate is less than the determined fair share, where the first processor means is arranged to take into account the value of the backlog counters when selecting a TFC for the subsequent frame of the output data flow. Preferably, the first and second processor means are provided by a Radio Resource Control (RRC) entity. As is described herein with reference to FIG. 3, a simplified UMTS layer 2 includes one Radio Resource Control (RRC) entity, a Medium Access Control (MAC) entity for each mobile station, and a Radio Link Control (RLC) entity for each Radio Access Bearer (RAB). The MAC entityperforms scheduling of outgoing data packets, while the RLC entities provide buffers for respective input flows. The RRC entity sets a limit on the maximum amount of data that can be transmitted from each flow by assigning a set of allowed Transport Format Combinations (TFC) to each MAC (referred to as a TFC Set or TFCS), but each MAC must independently decide how much data is transmitted from each flow by choosing the best available Transport Format Combination (TFC) from the TFCS.
With reference now to FIG. 4, an exemplary method in flowchart form for allocating bandwidth resources to data flow streams between entities in the exemplary second layer architecture of FIG. 3 is illustrated generally at 400. The flowchart 400 is a flow diagram ofa method of allocating bandwidth resources to, for example, the input flow streams ofa MAC entity of the layer 2 of FIG 3. Generally, an exemplary method in accordance with the flowchart 400 may follow the following steps. First, input flows are received at RLCs and the data is buffered (step 405). Information on buffer fill levels is passed to the MAC entity (step 410). After the information on buffer fill levels is passed, the fair MAC bandwidth share for each input flow is computed (step 415). The computed fair share of each is then adjusted by adding the contents of an associated backlog counter to the respective computed fair share (step 420). Once the computed fair shares have been adjusted, a TFC is selected from the
TFC set to most closely match the adjusted fair shares (step 425). The RLC is next instructed to deliver packets to the MAC entity according to the selected TFC (step 430). The MAC entity may also schedule packets in accordance with the selected TFC (step 435). After packet scheduling, the traffic channels may be transported on the physical Channel(s) (step 440) . Once packet traffic has been transported, the backlog counters should be updated (step 445). The process may continue (via arrow 450) when new input flows are received at the RLCs, which buffer the data (at step 405).
Furthermore, certain embodiment(s) of the scheme operate by calculating at the
MAC entity, on a per Transmission Time Interval (TTI) basis, the optimal distribution of available bandwidth using the Generalized Processor Sharing (GPS) approach (See, e.g., the article by A. K. Parekh et al. referenced hereinabove.) and by keeping track of how far behind each flow is from the optimal bandwidth allocation using respective backlog counters. The available bandwidth is distributed to flows by using the standard GPS weights, which may be calculated by the RRC using the RAB parameters. The method may first calculate the GPS distribution for the input flows and add to the GPS values the current respective backlogs. This is performed once for each 10ms TTI and results in a fair transmission rate for each flow. However, this rate may not be optimal as it may happen that there is not enough data to be sent in all buffers. In order to achieve optimal throughput as well as fairness, the fair GPS distribution is reduced so as to not exceed the current buffer fill level or the maximum allowed rate for any logical Channel. A two step rating process is then carried out. First, the set of fair rates computed for all of the input flows is compared against possible Transport Format Combinations (TFCs) in turn, with each TFC being scored according to how close it comes to sending out the optimal rate. In practice this is done by simply counting how much of the fair configuration a TFC fails to send (if a given TFC can send all packets at the fair rate, it is given a score of zero) and then considering only the TFCs which have the lowest scores. The closest match is chosen and used to determine the amount of packets sent from each queue. TFCs having an equal score are given a bonus score according to how many extra bits they can send
(this can be further weighted by a Quality of Service rating in order to ensure that the excess capacity goes to the bearer with the highest quality class). The final selection is based on a two-level scoring: the TFC with the lowest score is taken. If there are several TFCs with an equal score, the one with the highest bonus score is chosen. This ensures that the rate for each TTI is maximized. Fairness is achieved by checking that if the chosen TFC does not give all flows at least their determined fair rate, the missing bits are added to a backlog counter of the corresponding flow and the selection is repeated for the next TTI. If any of the flows has nothing to transmit, the backlog is set to zero. This algorithm can be shown to provide bandwidth (and, under certain assumptions, delay bounds) that is close to that of GPS. However, it remains fair and maintains isolation between all flows. It is also computationally simpler than Weighted Fair Queuing algorithms because it utilizes the fact that the MAC layer ran transmit on several transport channels at the same time. This results in optimal or close to optimal utilization of the radio interface in the UMTS radio link. The following pseudo-code is an outline of an exemplary algorithm for implementing the scheme described hereinabove with reference to FIGS. 3 and 4:
/* * GPS based TFC selection. Schedules packets by optimizing the throughput
* while still keeping the fairness (i.e. guaranteed rates).
int sched_gps() {
double weight, weight_sum; double score, bonus_score; double min_score = HUGE_NUMBER; double max_bonus_score = 0;
int maxrate; int i ; int tfc, tfci, qf, rate, trch; int tfc_to_use;
double backlog[MAX_TRCH]; double gps_req[MAX_TRCH]; double gps_req_comp[MAX_TRCH];
/* First calculate the sum of the weights of all active queues */
weight_sum=0; for (trch = 0; trch < MAX TRCH; trch++) { if (queue_fill_state[trch] > 0) { weight sum. += weight_vector[trch]; }
} /* Then calculate the fair distribution of available bandwidth
* using GPS. Modify the GPS scheduling reducing the rate if there
* is not enough data in the buffers or if the scheduled rate is
* higher that the maximum rate for a given logical channel */
int gps_rate=0; for(trch = 0; trch < MAX RCH; trch++) {
if (queue_f ill_state [trch] = 0) { backlog'[trch] = 0;
}
// here we calculate how many bits we should send on each channel // by GPS
gps_req[trch] = 0; gps_req_comp[trch] = 0; if(queue_fill_state[trch) > 0) { weight = weight_vector[trch]; gps_req[trch] = weight / weight_sum * maxrate + backlog[trch]; gps_req_comp[trch] = gps_req[trch]; if (gps_req_comp[trch] > queue_fill_ state[trch]) { gps_req_comp[trch] = queue_fill_state[trch];
} if (gps_req_comp[trch] > trch_max_rate[trch]) { gps_req_comp[trch} = trch_max_rate[trch];
} } /* Now we have our basis for selecting the TFC. Score all available
* TFCs by calculating how far they are from the modified GPS
* result. If there are several TFCs that can send the whole GPS
* result (or are * equally close) choose the one that maximises the throughput of
* highest QoS class. Note that the TFCIs are assumed to be in
* increasing order regarding the bandwidth usage */
for (tfci = o; tfci < MAX_TPCI; tfci++) { rate = score = bonus_score = 0; for (trch = 0; trch < MAX_TRCH; trch+-+) {
int tbs = tfcs [trch] [tfci] [0]; int tbss = tfcs [trch] [tfci] [ 1 ] ; rate += tbss;
if (tbss < gps_req_comp[trch]) { score += gps_req_comp [trch] - tbss; } else { if (tbss <= queue_fill_state(trch]) { bonus_score += QoS_vector[trch]*(tbss gps_req_comp [trch] ) ;
} }
} if (score < min_score) { tfc_to_use = tfci; min_score = tfcScore; max_bonus_score = bonus_score;
} if (score = min_score && bonus_score > max-bonus-score) { tfc_to_use = tfci; min_score = score; max_bonus_score = bonus_score; }
}
/* Now we have chosen the TFC to use. Update the backlog and output the
* right TFCI
*/
for (trch = 0; trch < MAX TRCH; trch++) {
tbss = tfcs [trch] [tfcToUse] [1]; if (tbss < queue_fill_state) { if (gps_req [trch] - gps_req_comp[trch]) { backlog [trch] = gpsReq [trch] - tbss; if (backlog[trch] < 0) backlog[trch] = 0; } else { backlog[trchGl] = 0; }
} return tfc_to_use;
}
Referring now to Figure 5, there is shown a portion of the second layer architecture depicted in Figure 3. More particularly, there is shown the MAC entity 320 of Figure 3 comprising a MAC-c entity 500, as described above, connected to a dedicated MAC-d entity 510, as likewise described above. Figure 5 further shows RLC entities 515, which receive data in the form of segments from respective RAB's and map the data onto corresponding logical channels 315. Each of the RLC ' s 515 is provided with a buffer 520 for buffering received data segments comprising PDU's. MAC-d entity 510 serves a single mobile station (not shown) and data transmitted by the MAC-d entity is directed through transport channel 325 to a dedicated physical Channel DPCH.
Referring further to Figure 5, there is shown the common MAC-c entity 500 provided with buffers 525 and connected to receive data, or more specifically PDU' s, from MAC-d entity 510 as well as from other MAC-d entities which are not shown, h accordance with the invention, it is desired to provide a flow control mechanism 530 between each of the dedicated MAC-d entities and the common MAC-c entity 500. By selectively managing traffic flow from the MAC-d entities to the buffer 525 of MAC-c entity 500, the flow control 530 enables a number of different MAC-d entities which are respectively in an active data flow mode to share the available free space of MAC-c buffer 525. The flow control is designed to provide each of the active MAC-d entities with a "fair share" of the additional data flow capacity provided by the MAC-d buffer free space, that is to ensure that all active MAC-d entities are given a reasonable opportunity to use such buffer capacity to enhance their respective data flow rates. Thus, the available common transfer channel data rate is shared among all the active dedicated logical channels. The flow control is further designed to maintain the fill level of the MAC-c entity buffer at or close to a desired optimum fill level.
Referring further to Figure 5, it is seen that data transmitted by MAC-c entity 500 is directed to a transport Channel FACH.
Referring to Figure 6, there is shown flow control 530 coupled to regulate data flow into the MAC-c PDU buffers 525 from each of a number RLCs 515, each coupled to a different mobile station or other User Equipment 1-n. In a useful embodiment of the invention, the flow control operates in accordance with a "round robin" or some other principle, that is, each of the MAC-d entities connected to a given MAC-c entity are enabled to transfer data thereto sequentially, or in turn, or by flow activity (greedy manner), hi this embodiment, credits are assigned to the respective MAC-d entities, in accordance with criteria described hereinafter in further detail. Upon receiving a credit, a MAC-d entity is entitled to transmit one packet data unit to the MAC-c buffer 525. Referring to Figure 7, there is shown MAC-c buffer 525, which is available for use by dedicated channels associated with MAC-d entities. The MAC-c buffer has an optimum level Qcopt, which is related to delay and throughput requirements in buffer operation. The flow control 530 endeavors to maintain such level, using feedback information received from the MAC-d entities. The flow control also functions to keep the MAC-c buffer as low as possible, so that delays related to use of a common channel will be equally distributed among different MAC-d users. If the level of buffer 525 at a particular time is Qc, the available buffer space Qcdiff is equal to Qcopt -
Qc. The flow control 530 operates to share this space amongst MAC-d users by assigning equal numbers of credits to them, provided they have PDU's available for transmission. The flow control calculates the credit for each MAC-d entity from both
MAC-d and MAC-c buffer fill levels. More specifically, the flow control establishes credit assignment criteria which is related to buffer level Qcopt, as well to levels Qcmax and Qcun, also shown in Figure 7. These criteria are as follows: (1) If Qc, MAC-c buffer fill level, is less than Qcun, an infinite or unlimited credit is given to MAC-d entities. (2) If the current MAC-c buffer fill level Qc is greater than Qcun but less than Qcopt, the difference (QCOpt-Qcun) *s divided among active MAC-d entities. (3) If the current MAC-c buffer fill level Qc is greater than Qcopt, no new credits are granted except initial credits. If the credits were previously set to 'unlimited' then they are cleared by sending ofa 'zero' credits to appropriate MAC-d entities.
It is anticipated that an algorithm can readily be generated to operate flow control 530 to distribute or assign credits in accordance with the above criteria.
Usefully, when a particular user becomes inactive, the algorithm will continue to distribute the remaining credits to remaining users. It is to be understood that an active user is a dedicated channel service that is connected to a common channel, and has data in its RLC-d buffer. An active user changes to a passive user when its RLC-d buffer becomes empty. The algorithm provides fair sharing of the total available band width between active users which have available band widths. The algorithm also minimizes packet delay, which is of particular importance for users operating with small packets in situations when other users have packets of large size. hi overload situations the flow control algorithm isolates different data from each other and increases RLC buffer fill level only for dedicated channels with the highest rates. The RLC buffer fill levels of other channels with unchanged rates will not be increased. Thus, the algorithm supports working of a channel switching function that can identify and switch the overloaded channels toward dedicated transport channels. The algorithm stores the user identification where it stops with the calculations, and continues with the next user identification when the flow control algorithm is used again.
The process of transferring data from the buffers of dedicated channels to buffer 525 of MAC-c entity 510, as well as the assignment or allocation of credits to respective dedicated channels by means of a sequential or round robin procedure, is illustrated in Figure 8. More specifically, Figure 8 shows steps 600, respectively numbered 1-18, which depict the sequential assignment of credits and corresponding transfer of data about with respect to several dedicated channels, respectively incorporating radio link controls RLC-1, RLC-2, and RLC-3. Each of the steps 1-12 displays a notation indicating the step number, and also certain count information in parentheses. As indicated in Figure 8 at item 620, the count information comprises the MAC-c buffer fill level Qc, the fill level Qd of a corresponding one of the dedicated channel buffers, and the available credit count at the conclusion of the step. Item 620 shows the notation for step 2, by way of illustration.
Referring further to Figure 8, there is shown item 610 thereof indicating that at the beginning of the procedure shown in Figure 8, the available data space Qcdiff in MAC-c buffer 525 is equivalent to 12 credits. As stated above, assigning a credit to a dedicated channel enables the channel to transfer a specified amount of data, such as one PDU, to the MAC-c buffer. Thus, during step 1 of Figure 8, the channel of RLC-1 receives one credit. As a result, the available space in the MAC-c buffer decreases from 12 to 11, and one PDU, corresponding to the 1 credit, can be transferred from the RLC-1 buffer to the MAC-c buffer. Accordingly, the data contents of the RLC-1 buffer which initially equivalent to 2 credits, diminishes to a Qd count of 1.
Referring further to Figure 8, it is seen that following step 2 the RLC-2 channel has received 1 credit, the available Qc count has decreased to 10, and the count Qd of buffer RLC-2 has decreased to 3 from an initial count of 4. The process is similar for step 3, associated with the RLC-3 buffer. However, the round robin procedure of the embodiment of the invention is illustrated by step 4, which shows the next-following credit again assigned to the RLC-1 channel. Upon receiving the credit, the Qd count of the RLC-1 count goes to zero, indicating that the channel has no more PDU's available. Thus, following step 5, directed to the RLC-2 channel, the next credit is assigned to the RLC-2 channel, as indicated in step 7. This is in accordance with criterion (2), set forth above. Similarly, the Qd count for the RLC-2 channel goes to zero following step 9, whereupon all successive credits are assigned to the RLC-3 channel. In a second embodiment of the invention, flow control 530 again operates in accordance with a round robin or with flow activity (greedy manner) credit based algorithm. Referring to Figure 9, there is shown MAC-c buffer 525, again used by dedicated channels. The Q optimum (Qcopt) dashed line in figure 9 represents the optimum level in regard to unwanted buffer overflow, delay variance and good throughput. The flow control endeavors to maintain the buffer at the Qcop, level by means of current buffer queue fill level (Qc) and queue maximum (Qcmax) threshold values, as well as by means of information pertaining to the active users routed to the MAC-c buffer. As stated above, an active user is a dedicated channel service that is connected to a common channel and has data in its RLC-d buffer. An active user changes to a passive user when its RLC-d buffer becomes empty.
In order to construct an algorithm for the flow control of the second embodiment, a credit C is calculated as follows:
Figure imgf000026_0001
QC0Pt = Th + Rcmax(2 " Td) Eqn. (2)
Figure imgf000027_0001
hi the above equations, Th is processing delay/handling delay, Td is transmission delay, and Rcmax is FACH transport channel maximum rate for this buffer. Nmac.d is the number of active MAC-d entities and Qcmax is a buffer high level. Default value for Qcmax could be 2 * QcopJ.
The flow control has an associated preprocessing function which can be triggered to run from an incoming PDU, a timer, or both. The preprocessor checks the credit status of users, the value of Qc and the number of active users of buffers. The flow control algorithm is not started if the Credit is greater than 0 or other predefined value.
Referring to Figure 10, there is shown the general operation of the flow control for the second embodiment of invention. Initially, at 0ms., Credit (C) is equal to 2, and 3 PDU' s are available at dedicated MAC-d users for transfer to MAC-c. With two credits available, two PDU's can be transferred, whereupon Credit (C) becomes 0.
This starts the flow control algorithm, which provides four credits as shown in Figure
10, which are calculated from Equation (3). The flow control is not again in process, until the number of Credits again becomes 0 or other predefined value, after 20 ms.
Figure 11 shows the relationship between Qc and Credits, in accordance with
Equations (1) - (3). Dashed lines indicate an adjustment which is made to limit C to a maximum value.
Referring to Figure 12, there is shown a modification which may usefully be employed with either of the above embodiments of the invention.
Packets from RLC-d buffers through MAC-d are first transmitted to MAC-c appropriate buffers and then to FACH transport channels. The MAC-d packets are transferred with Data Frames that also include RLC-d buffer fill level information, as indicated by path 700 in Figure 12. The MAC-c controls user data flow from MAC-d using Control Frames that include credits, i.e., the number of packets the user may transmit, represented in Figure 12 by path 710.
When a MAC-d user sends its last packet to MAC-c, the packet will be transferred with a Data Frame indicating "buffer empty", shown by path 720.
Accordingly, the credits for the MAC-d user will be set to initial value by the MAC-c entity. Thus, after receiving the last packet from the user, MAC-c will send a Control Frame message with an Initial Credits parameter to the MAC-d user, shown by path 730. However, sending such message after receiving the last packet from a user increases transmission delay of the next-arriving packets, and also increases the number of Control Frame messages, as shown by Figure 12. hi order to achieve a smaller delay for the next packet from a user after the buffer thereof has become temporarily empty, as well to decrease the number of control messages, an Early Initial Credit granting arrangement is used. Accordingly, when the flow control algorithm shows that the calculated credit is equal to or greater than the number of packets left in a particular RLC-d buffer, the flow control algorithm in the MAC-c shall add Initial credit to the calculated credit. Thus, an initial credit will be sent to the MAC-d in advance, and there will be no need to send any new credit parameter thereto after receiving the last packet. This is illustrated by Figure 13 , which shows that by using the Control Frame of path 740 (Credits and Initial Credits) the additional Control Frame of path 730 in Figure 12 is eliminated.
Although preferred embodiment(s) of the methods, systems, and arrangements of the present invention have been illustrated in the accompanying Drawings and described in the foregoing Detailed Description, it will be understood that the present invention is not limited to the embodiment(s) disclosed, but is capable of numerous rearrangements, modifications, and substitutions without departing from the spirit and scope of the present invention as set forth and defined by the following claims.

Claims

WHAT IS CLAIMED IS:
1. A method in a wireless communications system for providing flow control, comprising the steps of: providing a receiver entity; providing at least one transmitter entity, said at least one transmitter entity transmitting when said at least one transmitter entity has credit from said receiver entity; determining whether to give credit to said at least one transmitter entity; and giving credit to said at least one transmitter entity by said receiver entity if it is determined in said step of determining to give credit to said at least one transmitter entity.
2. The method according to Claim 1, further comprising the step of: transmitting a packet from said at least one transmitter entity to said receiver entity when said at least one transmitter entity has credit, transmitting of said packet being carried out in a round robin fashion, or in accordance with a flow activity (greedy manner) credit based principle.
3. The method according to Claim 1, wherein said receiver entity comprises a Medium Access Control (MAC)-c entity, and said at least one transmitter entity comprises a MAC-d entity, and said wireless communications system comprises a Universal Mobile Telecommunications System (UMTS).
4. The method according to Claim 1, wherein said receiver entity comprises a receiver buffer, and said at least one transmitter entity is associated with another buffer.
5. The method according to Claim 4, wherein the determination in said step of determining is based, at least in part, on both a fill level of said receiver buffer and a fill level of said another buffer.
6. The method according to Claim 4, wherein the determination in said step of determining is based, at least in part, on a fill level of said receiver buffer, but not on a fill level of said another buffer.
7. A method in a wireless communications system for providing flow control, comprising the steps of: providing a receiver entity, said receiver entity having a receiver buffer with a fill level; providing a plurality of transmitter entities, each one of said plurality of transmitter entities transmitting when said each one of said plurality of transmitter entities has been given credit from said receiver entity; analyzing said fill level of said receiver buffer with respect to a first level, a second level, and a third level; and giving credit from said receiver entity responsive to said step of analyzing.
8. The method according to Claim 7, wherein said step of analyzing comprises the step of determining whether said fill level is less than said first level, and if so, said step of giving credit comprises the step of giving infinite credit to all of said plurality of transmitter entities.
9. The method according to Claim 7, wherein said step of analyzing comprises the step of determining whether said fill level is greater than said first level but less than said second level, and if so, said step of giving credit comprises the step of giving the difference between said third level and a current level in credit divided over all active transmitter entities of said plurality of transmitter entities.
10. The method according to Claim 9, wherein said difference between said third level and said current level comprises an available credit amount and said step of giving the difference between said third level and a current level comprises the steps of: ascertaining if a first active transmitter entity of said all active transmitter entities of said plurality of transmitter entities has a current credit of less than a buffer fill level of an associated buffer; if so, increasing said current credit of said first active transmitter entity by one and decreasing said available credit amount by one; repeating said step of ascertaining for each active transmitter entity of said all active transmitter entities of said plurality of transmitter entities until either said available credit amount is exhausted or said all active transmitter entities of said plurality of transmitter entities has their corresponding current credit equal to their corresponding buffer fill level; and recording a last active transmitter entity of said all active transmitter entities of said plurality of transmitter entities to receive a credit and making the active transmitter entity after said last active transmitter entity the next first active transmitter entity.
11. The method according to Claim 7, wherein said step of analyzing comprises the step of determining whether said fill level is greater than said second level, and if so, said step of giving credit comprises the step of giving no new credits to any of said transmitter entity except initial credits.
12. The method according to Claim 11, wherein if the credits were previously set to 'unlimited', they are cleared by sending a zero credits message to corresponding transmitter entities.
13. A method in a wireless communications system for providing flow control, comprising the steps of: providing a receiver entity, said receiver entity having a receiver buffer with a fill level; providing a plurality of transmitter entities, each one of said plurality of transmitter entities transmitting when said each one of said plurality of transmitter entities has been given credit from said receiver entity; analyzing said fill level of said receiver buffer with respect to a first level, a second level, and a number of active transmitter entities of said plurality of transmitter entities; and giving credit from said receiver entity responsive to said step of analyzing.
14. The method according to Claim 13, wherein said step of analyzing comprises the step of determining whether said fill level is greater than said second level, and if so, said step of giving credit comprises the step of giving no new credit to all active transmitter entities of said plurality of transmitter entities, but said all active transmitter entities of said plurality of transmitter entities are permitted to transmit outstanding credit.
15. The method according to Claim 13, wherein said step of analyzing comprises the step of determining whether said fill level is less than said second level, and if so, said step of giving credit comprises the step of giving credit to all active transmitter entities of said plurality of transmitter entities in accordance with a value equal to a function times a quotient of said first level divided by said number of active transmitter entities of said plurality of transmitter entities, said function equal to a minimum of one and a quotient of an nth-power of a difference between said second level and said fill level divided by an nth-power of said first level.
16. The method according to Claim 15, wherein the variable n of said nth- power is equal to 2.
17. A method in a wireless communications system for providing flow control, comprising the steps of: receiving a data frame, said data frame including a buffer fill level indicator; and transmitting a control frame responsive to said data frame, said control frame including a credits provision, said credits provision equal to a sum of an ordinary credits provision and an initial credits provision.
18. The method according to Claim 17, further comprising the steps of: receiving a second data frame, said second data frame including a buffer empty indicator; and receiving a third data frame, said third data frame including a buffer fill level indicator.
19. The method according to Claim 17, wherein said step of transmitting a control frame is performed responsive to a determination that said credits provision is equal to or greater than said buffer fill level.
20. A method in a wireless communications system for providing flow control, comprising the steps of: providing a receiver entity; providing at least one transmitter entity, said at least one transmitter entity having a transmitter buffer with a buffer fill level; and comparing a credits provision that is allocated to said at least one transmitter entity with said buffer fill level.
21. The method according to Claim 20, further comprising the steps of: determining if said credits provision is equal to or greater than said buffer fill level responsive to said step of comparing; and if so, transmitting from said receiver entity to said at least one transmitter entity a control frame, said control frame including said credits provision and an initial credits provision.
PCT/SE2001/000407 2000-02-25 2001-02-23 Flow control between transmitter and receiver entities in a communications system WO2001063856A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP01908561A EP1264446A1 (en) 2000-02-25 2001-02-23 Flow control between transmitter and receiver entities in a communications system
AU2001236303A AU2001236303A1 (en) 2000-02-25 2001-02-23 Flow control between transmitter and receiver entities in a communications system

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US18497500P 2000-02-25 2000-02-25
US60/184,975 2000-02-25
US69878600A 2000-10-27 2000-10-27
US09/698,786 2000-10-27

Publications (1)

Publication Number Publication Date
WO2001063856A1 true WO2001063856A1 (en) 2001-08-30

Family

ID=26880661

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/SE2001/000407 WO2001063856A1 (en) 2000-02-25 2001-02-23 Flow control between transmitter and receiver entities in a communications system

Country Status (4)

Country Link
EP (1) EP1264446A1 (en)
CN (2) CN1312885C (en)
AU (1) AU2001236303A1 (en)
WO (1) WO2001063856A1 (en)

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2003043273A1 (en) * 2001-11-16 2003-05-22 Nortel Networks Limited Scheduler with fairness control and quality of service support
EP1315342A1 (en) * 2001-11-22 2003-05-28 NTT DoCoMo, Inc. Data flow control between base station and mobile station in a wireless communication system
WO2003061217A1 (en) * 2001-12-31 2003-07-24 Nokia Corporation Packet flow control method and device
EP1331768A1 (en) * 2002-01-25 2003-07-30 Lucent Technologies Inc. Rate control system and method for a link within a wireless communications system
WO2004057811A1 (en) * 2002-12-19 2004-07-08 Nokia Corporation Traffic channel scheduling
EP1478137A1 (en) * 2003-05-14 2004-11-17 NTT DoCoMo, Inc. Determination of a packet size in a packet communications system
EP1610575A1 (en) * 2003-03-31 2005-12-28 Fujitsu Limited Radio communication network and flow control method
DE102004037815A1 (en) * 2004-08-04 2006-02-23 Infineon Technologies Ag Mobile radio equipment has Automatic Repeat Request unit as Medium Access Control unit send buffer memory filling status information to transmit control unit
WO2006060957A1 (en) * 2004-12-10 2006-06-15 Huawei Technologies Co., Ltd. A FLOW CONTROL METHOD IN THE FORWARD ACCESS CHANNEL VIA Iur INTERFACE
CN1330153C (en) * 2002-08-19 2007-08-01 索马网络公司 Scheduler for a shared channel
WO2007116268A1 (en) * 2006-03-30 2007-10-18 Nokia Corporation A node
CN100456735C (en) * 2003-06-11 2009-01-28 三星电子株式会社 Transceiving network controller and method for controlling buffer memory allocation and data flow
US7830835B2 (en) 2006-08-21 2010-11-09 Interdigital Technology Corporation Method and apparatus for preventing transmission blocking in an HSUPA wireless communication system
EP2797376A1 (en) * 2002-12-20 2014-10-29 InterDigital Technology Corporation Scheduling data transmission by medium access control (mac) layer in a mobile network
US20160197743A1 (en) * 2013-09-13 2016-07-07 Huawei Technologies Co., Ltd. Data transmission method and apparatus
US9622066B2 (en) 2002-05-10 2017-04-11 Interdigital Technology Corporation System for permitting control of the purging of a node B by the serving radio network controller
WO2017103271A1 (en) * 2015-12-18 2017-06-22 Amesys Terminal and method for transmitting data via a strained channel

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100459607C (en) * 2003-08-15 2009-02-04 华为技术有限公司 Ground wireless access network flow control method for general mobile communication system
JP4301970B2 (en) * 2004-02-23 2009-07-22 株式会社エヌ・ティ・ティ・ドコモ Packet transmission control apparatus and packet transmission control method
CN1731727B (en) * 2004-08-06 2011-04-06 上海贝尔阿尔卡特股份有限公司 Packet dispatch and flux control method for share transmission channel
US7813279B2 (en) * 2006-01-13 2010-10-12 Futurewei Technologies, Inc. System for rate management of aggregate-rate communication services
US7881192B2 (en) 2006-01-13 2011-02-01 Futurewei Technologies, Inc. System for providing aggregate-rate communication services
US7817550B2 (en) 2006-01-13 2010-10-19 Futurewei Technologies, Inc. System for rate-control of aggregate-rate communication services
US7952998B2 (en) * 2007-01-10 2011-05-31 International Business Machines Corporation InfiniBand credit-less flow control for long distance links
CN101222671B (en) * 2007-12-06 2010-12-15 华为技术有限公司 Method, system and equipment for confirming inceptive service authorization value
CN101409894B (en) * 2008-11-16 2012-07-18 中兴通讯股份有限公司 Method for transmitting ascending control information and method for calculating transmission parameter

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997000568A1 (en) * 1995-06-14 1997-01-03 International Business Machines Corporation Packet data transmission in code-division multiple access communication systems
US5748613A (en) * 1996-03-29 1998-05-05 Hewlett-Packard Company Communication pacing method
US5831985A (en) * 1995-11-09 1998-11-03 Emc Corporation Method and apparatus for controlling concurrent data transmission from multiple sources in a channel communication system
WO2000041365A1 (en) * 1998-12-31 2000-07-13 Microsoft Corporation Method and system for credit-based data flow control
WO2000042792A1 (en) * 1999-01-15 2000-07-20 Nokia Networks Oy Flow control method in a telecommunications system
US6108713A (en) * 1997-02-11 2000-08-22 Xaqti Corporation Media access control architectures and network management systems

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FI98774C (en) * 1994-05-24 1997-08-11 Nokia Telecommunications Oy Method and apparatus for prioritizing traffic in an ATM network
CN1206526A (en) * 1995-12-28 1999-01-27 德纳克公司 Method and arrangement for network resource administration
US5809029A (en) * 1996-06-28 1998-09-15 Dsc Telecom L.P. Apparatus and method for mapping telecommunications signals onto a subscriber bus

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997000568A1 (en) * 1995-06-14 1997-01-03 International Business Machines Corporation Packet data transmission in code-division multiple access communication systems
US5831985A (en) * 1995-11-09 1998-11-03 Emc Corporation Method and apparatus for controlling concurrent data transmission from multiple sources in a channel communication system
US5748613A (en) * 1996-03-29 1998-05-05 Hewlett-Packard Company Communication pacing method
US6108713A (en) * 1997-02-11 2000-08-22 Xaqti Corporation Media access control architectures and network management systems
WO2000041365A1 (en) * 1998-12-31 2000-07-13 Microsoft Corporation Method and system for credit-based data flow control
WO2000042792A1 (en) * 1999-01-15 2000-07-20 Nokia Networks Oy Flow control method in a telecommunications system

Cited By (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100375467C (en) * 2001-11-16 2008-03-12 北方电讯网络有限公司 Scheduler with fairness control and quality of service support
US7103350B2 (en) 2001-11-16 2006-09-05 Nortel Networks Limited Scheduler with fairness control and quality of service support
WO2003043273A1 (en) * 2001-11-16 2003-05-22 Nortel Networks Limited Scheduler with fairness control and quality of service support
EP1315342A1 (en) * 2001-11-22 2003-05-28 NTT DoCoMo, Inc. Data flow control between base station and mobile station in a wireless communication system
CN1310540C (en) * 2001-11-22 2007-04-11 株式会社Ntt都科摩 Base station, wireless resource control device, mobile station, communication system and communication method
EP1605647A1 (en) * 2001-11-22 2005-12-14 NTT DoCoMo, Inc. Data flow control between base station and mobile station in a wireless communication system
USRE43593E1 (en) 2001-11-22 2012-08-21 Ntt Docomo, Inc. Base station, radio resource control equipment, mobile station, communication system, and communication method
US7359349B2 (en) 2001-11-22 2008-04-15 Ntt Docomo, Inc. Base station, radio resource control equipment, mobile station, communication system, and communication method
US7039013B2 (en) 2001-12-31 2006-05-02 Nokia Corporation Packet flow control method and device
WO2003061217A1 (en) * 2001-12-31 2003-07-24 Nokia Corporation Packet flow control method and device
EP1331768A1 (en) * 2002-01-25 2003-07-30 Lucent Technologies Inc. Rate control system and method for a link within a wireless communications system
US7031254B2 (en) 2002-01-25 2006-04-18 Lucent Technologies Inc. Rate control system and method for a link within a wireless communications system
US9622066B2 (en) 2002-05-10 2017-04-11 Interdigital Technology Corporation System for permitting control of the purging of a node B by the serving radio network controller
CN1330153C (en) * 2002-08-19 2007-08-01 索马网络公司 Scheduler for a shared channel
WO2004057811A1 (en) * 2002-12-19 2004-07-08 Nokia Corporation Traffic channel scheduling
NO341774B1 (en) * 2002-12-20 2018-01-15 Interdigital Tech Corp User Equipment (UE) and method of transmitting, by UE, a generated medium access control protocol data unit, MAC PDU
US9392490B2 (en) 2002-12-20 2016-07-12 Interdigital Technology Corporation Scheduling data transmission by medium access control (MAC) layer in a mobile network
EP2797376A1 (en) * 2002-12-20 2014-10-29 InterDigital Technology Corporation Scheduling data transmission by medium access control (mac) layer in a mobile network
US9867208B2 (en) 2002-12-20 2018-01-09 Interdigital Technology Corporation Scheduling data transmission by medium access control (MAC) layer in a mobile network
EP1610575A1 (en) * 2003-03-31 2005-12-28 Fujitsu Limited Radio communication network and flow control method
EP1610575A4 (en) * 2003-03-31 2010-07-21 Fujitsu Ltd Radio communication network and flow control method
EP1478137A1 (en) * 2003-05-14 2004-11-17 NTT DoCoMo, Inc. Determination of a packet size in a packet communications system
US7477604B2 (en) 2003-05-14 2009-01-13 Ntt Docomo, Inc. Packet communications system
CN100456735C (en) * 2003-06-11 2009-01-28 三星电子株式会社 Transceiving network controller and method for controlling buffer memory allocation and data flow
DE102004037815A1 (en) * 2004-08-04 2006-02-23 Infineon Technologies Ag Mobile radio equipment has Automatic Repeat Request unit as Medium Access Control unit send buffer memory filling status information to transmit control unit
DE102004037815B4 (en) * 2004-08-04 2013-01-03 Infineon Technologies Delta Gmbh Mobile radio device and method for controlling mobile radio transmitter resources in a mobile radio device
WO2006060957A1 (en) * 2004-12-10 2006-06-15 Huawei Technologies Co., Ltd. A FLOW CONTROL METHOD IN THE FORWARD ACCESS CHANNEL VIA Iur INTERFACE
US8111623B2 (en) 2006-03-30 2012-02-07 Nokia Corporation Node, method and system for control of communication including a buffer
WO2007116268A1 (en) * 2006-03-30 2007-10-18 Nokia Corporation A node
RU2420900C2 (en) * 2006-08-21 2011-06-10 Интердиджитал Текнолоджи Корпорейшн Method and device for preventing transmission blockage in hsupa wireless communication system
US7830835B2 (en) 2006-08-21 2010-11-09 Interdigital Technology Corporation Method and apparatus for preventing transmission blocking in an HSUPA wireless communication system
US10630448B2 (en) 2006-08-21 2020-04-21 Interdigital Technology Corporation Logical channel management in a wireless communication network
US9641304B2 (en) 2006-08-21 2017-05-02 Interdigital Technology Corporation Transmitting scheduling information in a wireless communication network
US11818068B2 (en) 2006-08-21 2023-11-14 Interdigital Technology Corporation Logical channel management in a wireless communication network
US10148405B2 (en) 2006-08-21 2018-12-04 Interdigital Technology Corporation Logical channel management in a wireless communication network
US8797873B2 (en) 2006-08-21 2014-08-05 Interdigital Technology Corporation Method and apparatus for transmitting scheduling information in a wireless communication network
US11626957B2 (en) 2006-08-21 2023-04-11 Interdigital Technology Corporation Logical channel management in a wireless communication network
CN106453028A (en) * 2013-09-13 2017-02-22 华为技术有限公司 Method and device for transmitting data
US10511460B2 (en) * 2013-09-13 2019-12-17 Huawei Technologies Co., Ltd. Data transmission method and apparatus
US20160197743A1 (en) * 2013-09-13 2016-07-07 Huawei Technologies Co., Ltd. Data transmission method and apparatus
CN106453028B (en) * 2013-09-13 2020-08-07 华为技术有限公司 Method and device for transmitting data
CN106453028B9 (en) * 2013-09-13 2020-09-11 华为技术有限公司 Method and device for transmitting data
US11722337B2 (en) 2013-09-13 2023-08-08 Huawei Technologies Co., Ltd. Data transmission method and apparatus
FR3045998A1 (en) * 2015-12-18 2017-06-23 Amesys TERMINAL AND METHOD FOR DATA TRANSMISSION VIA A CONTRAINTED CHANNEL
US10855607B2 (en) 2015-12-18 2020-12-01 Avantix Terminal and method for transmitting data via a strained channel
WO2017103271A1 (en) * 2015-12-18 2017-06-22 Amesys Terminal and method for transmitting data via a strained channel

Also Published As

Publication number Publication date
AU2001236303A1 (en) 2001-09-03
CN101018208A (en) 2007-08-15
CN101018208B (en) 2012-09-26
CN1312885C (en) 2007-04-25
CN1426651A (en) 2003-06-25
EP1264446A1 (en) 2002-12-11

Similar Documents

Publication Publication Date Title
US6850540B1 (en) Packet scheduling in a communications system
US6826193B1 (en) Data transmission in a telecommunications network
EP1264446A1 (en) Flow control between transmitter and receiver entities in a communications system
US7039013B2 (en) Packet flow control method and device
US7031254B2 (en) Rate control system and method for a link within a wireless communications system
WO2001063855A1 (en) Packet scheduling in umts using several calculated transfer rates
US6578082B1 (en) Distributed flow control system and method for GPRS networks based on leaky buckets
US6879561B1 (en) Method and system for wireless packet scheduling with per packet QoS support and link adaptation
US7190684B2 (en) Method and system for UMTS packet transmission scheduling on shared downlink channels
AU2004307505B2 (en) Coordinated data flow control and buffer sharing in UMTS
JP3866963B2 (en) Method and system for scheduling multiple data flows to coordinate quality of service in a CDMA system
US7502317B2 (en) Method for differentiating services and users in communication networks
WO2011057292A1 (en) Burst packet scheduler for improved ran efficiency in umts/hspa networks
CA2404523C (en) Transmitting packet data
EP1326463A1 (en) Method and apparatus for packet transmission scheduling by performing load control functionality
US20070248101A1 (en) Efficient policer based weighted fair bandwidth method and system
EP1209940A1 (en) Method and system for UMTS packet transmission scheduling on uplink channels
US20050052997A1 (en) Packet scheduling of real time packet data
US20030139145A1 (en) Data transmitting method and apparatus for guaranteeing quality of service in a data communication system
EP1264447A1 (en) Overload handling in a communications system
JP2004080768A (en) Method of utilizing admission control algorithm in radio communication system
Nádas et al. Providing congestion control in the Iub Transport Network for HSDPA
Wang et al. Performance comparison of scheduling algorithms in network mobility environment
Todinca et al. Novel prioritised EGPRS medium access regime for reduced file transfer delay during congested periods

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

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

AL Designated countries for regional patents

Kind code of ref document: A1

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

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

Ref document number: 2001908561

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 01808494X

Country of ref document: CN

WWP Wipo information: published in national office

Ref document number: 2001908561

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

NENP Non-entry into the national phase

Ref country code: JP

WWW Wipo information: withdrawn in national office

Ref document number: 2001908561

Country of ref document: EP