In a shared-medium communications network, such as a wireless network or a wired network, a medium access control (MAC) mechanism is required to control access to a shared communications medium, such as a bus or an electromagnetic spectrum. For example, an arbitration mechanism can be used to orchestrate the access to the shared communications medium and eventually allow any communications node to transmit data through the shared communications medium. For instance, Ethernet as defined in IEEE 802.3 uses a CSMA/CD (Carrier Sense Multiple Access, Collision Detection) scheme, Wi-Fi transmission uses a CSMA/CA (Carrier Sense Multiple Access, Collision Avoidance) scheme, and distributed coordination function (DCF) in a Controller Area Network uses a CSMA/CA scheme.
Embodiments of a method, a device and a computer-readable storage medium are disclosed. In an embodiment, a method for controlling access to a communications medium involves replenishing a credit value assigned to a communications node in a communications round, granting or denying access to the communications medium to the communications node during the communications round based on the credit value, and controlling the credit value in response to granting or denying access to the communications medium to the communications node during the communications round. Other embodiments are also described.
In an embodiment, replenishing the credit value assigned to the communications node in the communications round involves replenishing the credit value assigned to the communications node in the communications round with a fixed replenishment value at a start of the communications round.
In an embodiment, replenishing the credit value assigned to the communications node in the communications round with the fixed replenishment value at the start of the communications round involves replenishing the credit value assigned to the communications node in the communications round with the fixed replenishment value before granting or denying access to the communications medium to the communications node during the communications round based on the credit value.
In an embodiment, the method further involves determining a replenishment value as a function of the credit value, and replenishing the credit to value assigned to the communications node in the communications round involves replenishing the credit value assigned to the communications node in the communications round with the replenishment value.
In an embodiment, determining the replenishment value as the function of the credit value involves determining the replenishment value as the function of the credit value and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round.
In an embodiment, the method further involves receiving, at the communications node, a message from the second communications node containing the second credit value.
In an embodiment, the method further involves comprising estimating the second credit value based on a data frame transmitted by the second communications node in a predetermined time slot during the communications round.
In an embodiment, determining the replenishment value as the function of the credit value and the second credit value involves determining the replenishment value based on a maximum value or a minimum value of the credit value and the second credit value.
In an embodiment, granting or denying access to the communications medium to the communications node during the communications round based on the credit value involves allowing or prohibiting the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round based on the credit value.
In an embodiment, granting or denying access to the communications medium to the communications node during the communications round based on the credit value involves comparing the credit value with a credit threshold and allowing or prohibiting the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round based on a comparison result between credit value and the credit threshold.
In an embodiment, granting or denying access to the communications medium to the communications node during the communications round based on the credit value involves comparing the credit value with a credit threshold, if the credit value is greater than the credit threshold, allowing the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round, and if the credit value is less than the credit threshold, allowing the communications node to transmit a stall message that indicates the communications node is not allowed to transmit the data frame through the communications medium in the predetermined time slot during the communications round.
In an embodiment, controlling the credit value in response to granting or denying access to the communications medium to the communications node during the communications round involves deducting a credit consumption value from the credit value in response to granting access to the communications medium to the communications node during the communications round and maintaining the credit value for a subsequent communications round in response to denying access to the communications medium to the communications node during the communications round.
In an embodiment, the method further involves determining the credit consumption value based on a characteristic of a data frame that is transmitted by the communications node through the communications medium in a predetermined time slot during the communications round.
In an embodiment, determining the credit consumption value based on the characteristic of the data frame that is transmitted by the communications node through the communications medium in the predetermined time slot during the communications round involves calculating the credit consumption value as a function of a size of the data frame that is transmitted by the communications node through the communications medium in the predetermined time slot during the communications round.
In an embodiment, a device for controlling access to a communications medium includes a credit protocol manager configured to replenish a credit value assigned to a communications device in a communications round, a distributed round-robin scheduler configured to grant or deny access to the communications medium for the communications device during the communications round based on the credit value, and a credit counter configured to control the credit value in response to granting or denying access to the communications medium for the communications device during the communications round.
In an embodiment, the credit protocol manager is further configured to replenish the credit value assigned to the communications node in the communications round with a fixed replenishment value before granting or denying access to the communications medium to the communications node during the communications round based on the credit value.
In an embodiment, the credit protocol manager is further configured to determine a replenishment value as the function of the credit value and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round and replenish the credit value assigned to the communications node in the communications round with the replenishment value.
In an embodiment, the distributed round-robin scheduler is further configured to if the credit value is greater than a credit threshold, allow the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round and if the credit value is less than the credit threshold, allow the communications node to transmit a stall message that indicates the communications node is not allowed to transmit the data frame through the communications medium in the predetermined time slot during the communications round.
In an embodiment, the credit counter is further configured to deduct a credit consumption value from the credit value as a function of a size of a data frame that is transmitted by the communications node through the communications medium in a predetermined time slot during the communications round and maintain the credit value for a subsequent communications round in response to denying access to the communications medium to the communications node during the communications round.
In an embodiment, a non-transitory computer-readable medium containing program instructions for controlling access to a communications medium is described. Execution of the program instructions by one or more processors causes the one or more processors to perform steps comprising replenishing a credit value assigned to a communications node in a communications round, granting or denying access to the communications medium to the communications node during the communications round based on the credit value, and controlling the credit value in response to granting or denying access to the communications medium to the communications node during the communications round.
Other aspects in accordance with the invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrated by way of example of the principles of the invention.
Throughout the description, similar reference numbers may be used to identify similar elements.
It will be readily understood that the components of the embodiments as generally described herein and illustrated in the appended figures could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of various embodiments, as represented in the figures, is not intended to limit the scope of the present disclosure, but is merely representative of various embodiments. While the various aspects of the embodiments are presented in drawings, the drawings are not necessarily drawn to scale unless specifically indicated.
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by this detailed description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Reference throughout this specification to features, advantages, or similar language does not imply that all of the features and advantages that may be realized with the present invention should be or are in any single embodiment of the invention. Rather, language referring to the features and advantages is understood to mean that a specific feature, advantage, or characteristic described in connection with an embodiment is included in at least one embodiment of the present invention. Thus, discussions of the features and advantages, and similar language, throughout this specification may, but do not necessarily, refer to the same embodiment.
Furthermore, the described features, advantages, and characteristics of the invention may be combined in any suitable manner in one or more embodiments. One skilled in the relevant art will recognize, in light of the description herein, that the invention can be practiced without one or more of the specific features or advantages of a particular embodiment. In other instances, additional features and advantages may be recognized in certain embodiments that may not be present in all embodiments of the invention.
Reference throughout this specification to “one embodiment”, “an embodiment”, or similar language means that a particular feature, structure, or characteristic described in connection with the indicated embodiment is included in at least one embodiment of the present invention. Thus, the phrases “in one embodiment”, “in an embodiment”, and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment.
Techniques described herein can be applied to any type of shared medium communications networks, included wired communications networks and wireless communications networks. Although in some embodiments a specific type of communications networks is described, it should be noted that the invention is not restricted to a specific type of communications network.
The communications network 100 depicted in
The transceivers 106-1, 106-2, . . . , 106-N, which may be wired transceivers or wireless transceivers, are configured to decode messages received through the shared communications medium 102 and to generate appropriate outgoing messages to be transmitted through the shared communications medium. Each of the transceivers may include at least one antenna (not shown) for transmitting signal through an electromagnetic spectrum. In some embodiments, the transceivers are connected to at least one device (not shown) such as a sensor, an actuator, or some other control device. In some embodiments, at least one of the transceivers is an IEEE 802.3cg compatible transceiver. In some embodiments, the transceivers implement physical layer operations. For example, in receive operations, a transceiver converts analog signals from a bus or from an antenna to digital signals that the corresponding communications node can interpret. The transceiver may also protect a corresponding MAC unit from extreme electrical conditions on a bus, e.g., electrical surges. In transmit operations, a transceiver converts digital bits received into analog differential signals that are sent on a bus or though an antenna. In some embodiments, a bus carries analog signals and includes high and low bus lines.
The MAC units 108-1, 108-2, . . . , 108-N are configured to perform medium access control for the corresponding communications nodes 104-1, 104-2, . . . , 104-N. The MAC units may be implemented as processors, such as microcontrollers also referred to as host processors, hosts, or digital signal processors (DSPs), or central processing units (CPUs). In some embodiments, at least one of the MAC units is included within the PHY layer module of an IEEE 802.3cg compatible Ethernet communications device. Although the illustrated MAC units are shown in
In some embodiments, the communications nodes 104-1, 104-2, . . . , 104-N in the communications network 100 communicate in a round-robin fashion. In an embodiment, a round of communications, which is also referred to as a communications round, is a fixed sequence (e.g., a fixed order of transmission) of transmit opportunities or time slots. In each communications round, the sequence of transmission or the order of transmission (e.g., Node A then Node B) may be fixed for the communications nodes. For example, when the communications nodes 104-1, 104-2 transmit in communications rounds, the communications node 104-1 transmits during a first time slot in each communications round while the communications node 104-2 transmits during a second time slot in each communications round in the fixed order of transmission. When the communications nodes 104-1, 104-2, 104-3 transmit in communications rounds, the communications node 104-1 transmits during a first time slot in each communications round, the communications node 104-2 transmits during a second time slot in each communications round, and the communications node 104-3 transmits during a third time slot in each communications round in the fixed order of transmission. Each communications round may be preceded by a special beacon to indicate the start of the communications round. The duration of the time slots is determined by the length of data frames during the time slots. In some embodiments, a communications node transmits a yield message or command in a time slot assigned to the communications node to yield the communications medium to other communications node(s) (i.e., give access to the communications medium to other communications node(s)).
In some embodiments, each of the MAC units 108-1, 108-2, . . . , 108-N implements a fairness control mechanism for a corresponding communications node 104-1, 104-2, . . . , or 104-N. In these embodiments, each MAC unit controls medium admission for a corresponding communications node by keeping track of recent data transmissions. A credit value or level may be maintained by each communications node individually. In an embodiment, the credit value is replenished in each communications round and is consumed if a data frame is transmitted and admission to the communications medium is only granted when credit is available. In an example operation of the communications node 104-1, 104-2, . . . , or 104-N, a credit value assigned to the communications node is replenished in a communications round, access to the communications medium to the communications node during the communications round is granted or denied based on the credit value, and the credit value is controlled in response to granting or denying access to the communications medium to the communications node during the communications round. In an embodiment, the credit value assigned to the communications node in the communications round is replenished with a fixed replenishment value at a start of the communications round (e.g., before granting or denying access to the communications medium to the communications node during the communications round based on the credit value). In an embodiment, the replenishment value is determined as a function of the credit value and the credit value assigned to the communications node in the communications round is replenished with the replenishment value. For example, the replenishment value is determined as the function of the credit value and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round. A message from the second communications node containing the second credit value may be received at the communications node. Alternatively, the second credit value may be estimated based on a data frame transmitted by the second communications node in a predetermined time slot during the communications round.
Compared to a typical communications network, the communications network depicted 100 in
Compared to a credit-based approach that replenishes a communications credit value or level assigned to a communications node based on passed time or bit time, the MAC unit 408 depicted in
In the embodiment of
In some embodiments, the distributed round-robin scheduler 414 is configured to grant or deny access to the communications medium 102 to a corresponding communications node 104-1, 104-2, . . . , or 104-N during a communications round based on a credit value assigned to the communications node in the communications round. The distributed round-robin scheduler may allow or prohibit the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round based on the credit value. In some embodiments, the distributed round-robin scheduler allows or prohibits the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round based on a comparison result between a credit value assigned to the communications node in a communications round and a credit threshold. The distributed round-robin scheduler, the credit protocol manager 416, and/or the credit counter 418 may compare a credit value assigned to the communications node in a communications round with a credit threshold. If the credit value is greater than the credit threshold, the distributed round-robin scheduler allows the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round. If the credit value is less than the credit threshold, the distributed round-robin scheduler allows the communications node to transmit a stall message that indicates the communications node is not allowed to transmit the data frame through the communications medium in the predetermined time slot during the communications round.
In the embodiment of
In some embodiments, the credit protocol manager 416 determines an adjustment (e.g., a replenishment) to the credit value assigned to corresponding communications node 104-1, 104-2, . . . , or 104-N, e.g., at the start of a communications round. In some embodiments, the credit protocol manager determines a fixed replenishment per communications round (e.g., 1 credit per round, 2 credit per round or any other suitable value) to the credit value at the start of a communications round. The credit protocol manager may replenish a credit value assigned to a communications node in a communications round with a fixed replenishment value before granting or denying access to the communications medium 102 to the communications node during the communications round based on the credit value. In some embodiments, the credit protocol manager determines a replenishment value as a function of a credit value assigned to a communications node in a communications round. The credit protocol manager may determine a replenishment value as a function of a credit value assigned to a communications node in a communications round and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round. The second credit value may be derived from a message node containing the second credit value that is received at the communication node from the second communications node. Alternatively, the credit protocol manager may estimate the second credit value based on a data frame transmitted by the second communications node in a predetermined time slot during the communications round. In some embodiments, the credit protocol manager determines the replenishment value based on a maximum value or a minimum value of a credit value assigned to a communications node in a communications round and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round.
In some embodiments, the credit protocol manager 416 determines an adjustment (e.g., a reduction or a consumption value) to the credit value at an end of a communications round based on access to the communications medium by a corresponding communications node 104-1, 104-2, . . . , or 104-N during the communications round. For example, the credit protocol manager determines an adjustment (e.g., a reduction or a consumption value) to the credit value, e.g., at an end of a communications round based on the size of the data frame transmitted by a corresponding communications node 104 during an assigned time slot in the communications round. In some embodiments, the credit protocol manager determines a reduction or a consumption value that is applied to the credit value based on a predefined credit-to-byte ratio (e.g., 1 credit per 32 byte transmitted, 1 credit per 64 byte transmitted, 1 credit per 128 byte transmitted, or any other suitable value).
In some embodiments, the credit protocol manager 416 resets the credit value assigned to a corresponding communications node 104-1, 104-2, . . . , or 104-N, e.g., at the start of a communications round to a predefined value based on access to the communications medium 102 by a corresponding communications node 104 during the communications round. For example, the credit protocol manager resets the credit value assigned to the communications node 104-1, e.g., at the start of a communications round, to a predefined value if the communications node has an empty queue and no pending transmissions and if the credit value assigned to the communications node 104-1 is greater than or equal to a predefined threshold (e.g., greater than or equal to zero).
In some embodiments, the credit protocol manager 416 is configured to issue a yield message to yield the communications medium to other communications node(s) during a communications round if a corresponding communications node 104-1, 104-2, . . . , or 104-N has no data to be transmitted in the communications round. In some embodiments, the credit protocol manager is configured to issue a stall message to notify other communications node(s) during a communications round if the credit value assigned to the communications node 104-1 during the communications round is below (e.g., less than) a predefined threshold to allow access to the communications medium 102.
In the embodiment of
In some embodiments, the credit counter 418 is configured to compare the credit value assigned to a corresponding communications node 104-1, 104-2, . . . , or 104-N during a communications round with a predefined threshold to allow or deny access to the communications medium 102 during the communications round. For example, if the credit value is below (e.g., less than) the predefined threshold during a communications round, access to the communications medium 102 during the communications round by the communications node is denied. If the credit value is above (e.g., greater than) the predefined threshold during a communications round, access to the communications medium 102 during the communications round by the communications node is granted. The credit counter may transmit a grant demand or message to the credit protocol manager if access to the communications medium 102 during the communications round by the communications node is granted.
In some embodiments, the credit counter 418 performs an adjustment (e.g., applies a replenishment value) to the credit value assigned to a corresponding communications node 104-1, 104-2, . . . , or 104-N at the start of a communications round. For example, the credit counter adds a fixed replenishment per communications round (e.g., 1 credit added per round, 2 credit added per round or any other suitable value) to the credit value, e.g., at the start of a communications round.
In some embodiments, the credit counter 418 performs an adjustment (e.g., applies a reduction or a consumption value) to the credit value at an end of a communications round based on access to the communications medium by a corresponding communications node 104-1, 104-2, . . . , or 104-N during the communications round. For example, the credit counter deducts a reduction value or a consumption value from the credit value at an end of a communications round based on the size of the data frame transmitted by the corresponding communications node during an assignment time slot in the communications round. In some embodiments, the credit counter deducts a reduction value or a consumption value from the credit value based on a predefined credit-to-byte ratio (e.g., 1 credit deduction per 32 byte transmitted, 1 credit deduction per 64 byte transmitted, 1 credit deduction per 128 byte transmitted, or any other suitable value).
In some embodiments, the credit counter 418 resets the credit value assigned to a corresponding communications node 104-1, 104-2, . . . , or 104-N, e.g., at the start of a communications round to a predefined value based on access to the communications medium 102 by the corresponding communications node during the communications round. For example, the credit counter resets the credit value assigned to the corresponding communications node, e.g., at the start of a communications round to a predefined value if the communications node has an empty queue and no pending transmissions.
In some embodiments, the credit protocol manager 416 is configured to replenish a credit value assigned to a communications node 104-1, 104-2, . . . , or 104-N in a communications round, the distributed round-robin scheduler 414 is configured to grant or deny access to the communications medium for the communications device during the communications round based on the credit value, and the credit counter 418 is configured to control the credit value in response to granting or denying access to the communications medium for the communications device during the communications round. For example, the credit protocol manager may be further configured to replenish the credit value assigned to the communications node in the communications round with a fixed replenishment value before granting or denying access to the communications medium to the communications node during the communications round based on the credit value. In another example, the credit protocol manager is further configured to determine a replenishment value as a function of the credit value and a second credit value that is assigned to a second communications node having access to the communications medium in the communications round and to replenish the credit value assigned to the communications node in the communications round with the replenishment value. The distributed round-robin scheduler may be further configured to compare the credit value with a credit threshold, if the credit value is greater than the credit threshold, allow the communications node to transmit a data frame through the communications medium in a predetermined time slot during the communications round, and if the credit value is less than the credit threshold, allow the communications node to transmit a stall message that indicates the communications node is not allowed to transmit the data frame through the communications medium in the predetermined time slot during the communications round. The credit counter may be further configured to deduct a credit consumption value from the credit value as a function of a size of a data frame that is transmitted by the communications node through the communications medium in a predetermined time slot during the communications round and to maintain the credit value for a subsequent communications round in response to denying access to the communications medium to the communications node during the communications round.
CreditA2=CreditA1−ConsumptionA1 (1)
where ConsumptionA1 represents a credit consumption value of the communications node 104-1 in round 1. The credit consumption value,
ConsumptionA1, of the communications node 104-1 in round 1 can be computed as:
ConsumptionA1=F(DFSize) (2)
where F( )represents a function, which may be a linear function or a non-linear function, and DFSize represents the size of the data frame 560-1 that the communications node 104-1 transmits during the time slot TSA-1. For the communications node 104-1, ConsumptionA1 is 24 credits deducted per round and the credit value, CreditA2 for round 2 is −24 (i.e., 0−24=−24). For the communications node 104-2, the credit consumption value, “ConsumptionB1,” of the communications node 104-2 in round 1 is 1 credit deducted per round and the credit value, CreditB2 for round 2 is −1 (i.e., 0−1=−1).
At the beginning of round 2, the credit value, CreditA2, assigned to the communications node 104-1 and the credit value, CreditB2, assigned to the communications node 104-2 are replenished with a fixed replenishment. In the embodiment depicted in
At the beginning of round 3, the credit value, CreditA3, assigned to the communications node 104-1 and the credit value, CreditB3, assigned to the communications node 104-2 are replenished and the replenished credit value, CreditA3, is set to −22 (i.e., −23+1=−22), while the replenished credit value, CreditB3, is set to 0 (i.e. −1+1=0). In round 3, a stall message 560-5 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-3, and subsequently a data frame 560-6 of 64 bytes is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-3. After the communications node 104-1 transmits the stall message 560-5 during the time slot TSA-3, the credit value, CreditA4 for round 4 (i.e., the credit value at the end of round 3) of the communications node 104-1 is kept or maintained at −22 because the communications node 104-1 does not transmit any data frame during the time slot TSA-3. For the communications node 104-2, the credit value, CreditA3 for round 4 is 0−1=−1 (i.e., the credit consumption value for the communications node 104-2 at round 3 is 1 credit deducted per round) because the communications node 104-2 transmits the data frame 560-6 during the time slot TSB-3.
At the beginning of round 4, the credit value, CreditA4, assigned to the communications node 104-1 and the credit value, CreditB4, assigned to the communications node 104-2 are replenished and the replenished credit value, CreditA4, is set to −21 (i.e., −22+1=−21), while the replenished credit value, CreditB4, is set to 0 (i.e. −1+1=0). In round 4, a stall message 560-7 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-4, and subsequently a data frame 560-8 of 64 bytes is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-4. After the communications node 104-1 transmits the stall message 560-7 during the time slot TSA-4, the credit value, CreditA5 for round 5 (i.e., the credit value at the end of round 4) of the communications node 104-1 is kept or maintained at −21 because the communications node 104-1 does not transmit any data frame during the time slot TSA-4. For the communications node 104-2, the credit value, CreditA4 for round 4 is 0−1=−1 (i.e., the credit consumption value for the communications node 104-2 at round 4 is 1 credit deducted per round) because the communications node 104-2 transmits the data frame 560-8 during the time slot TSB-4. After 24 rounds of communications, the credit value, “CreditAM,” assigned to the communications node 104-1 and the credit value, “CreditBM,” assigned to the communications node 104-2 are both zero in round M (where M is an integer that is greater than 24) and the communications node 104-1 is allowed to access the communications medium 102 in predetermined time slots 560-2M-1, 560-2M.
In some scenarios, if a communications node sends a large data frame (e.g. the communications node 104-1 sends a 1526 byte data frame) while other communications node(s) has no data to send, medium bandwidth can be wasted and link capacity can be lost (e.g., not all of the transmission capacity of the communications medium 102 are used).
In round 1, a first data frame 660-1 of 1526 bytes (e.g., the maximum frame size that can be transmitted through Ethernet) is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-1, and subsequently an idle message 660-2 is transmitted through the communications medium by the communications node 104-2 during a time slot
TSB-1. In the embodiment depicted in
At the beginning of round 2, the credit replenishment value for round 2 is 1 credit added per round and the credit value, CreditA2, assigned to the communications node 104-1 is replenished to −23. In round 2, a stall message 660-3 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-2, and subsequently an idle message 660-4 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-2. After the communications node 104-1 transmits the stall message 660-3 during the time slot TSA-2, the credit value, CreditA3 for round 3 (i.e., the credit value at the end of round 2) of the communications node 104-1 is kept or maintained at −23 because the communications node 104-1 does not transmit any data frame during the time slot TSA-2.
At the beginning of round 3, the credit replenishment value for round 3 is 1 credit added per round and the credit value, CreditA3, assigned to the communications node 104-1 is replenished and the replenished credit value, CreditA3, is set to −22. In round 3, a stall message 660-5 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-3, and subsequently an idle message 660-6 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-3. After the communications node 104-1 transmits the stall message 560-5 during the time slot TSA-3, the credit value, CreditA4 for round 4 (i.e., the credit value at the end of round 3) of the communications node 104-1 is kept or maintained at −22 because the communications node 104-1 does not transmit any data frame during the time slot TSA-3.
At the beginning of round 4, the credit replenishment value for round 4 is 1 credit added per round and the credit value, CreditA4, assigned to the communications node 104-1 is replenished and the replenished credit value, CreditA4, is set to −21. In round 4, a stall message 660-7 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-4, and subsequently an idle message 660-8 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-4. After the communications node 104-1 transmits the stall message 560-7 during the time slot TSA-4, the credit value, CreditA5 for round 5 (i.e., the credit value at the end of round 4) of the communications node 104-1 is kept or maintained at −21 because the communications node 104-1 does not transmit any data frame during the time slot TSA-4. After 24 rounds of communications, the credit value, “CreditA25,” assigned to the communications node 104-1 is zero in round 25 (and the communications node 104-1 is allowed to access the communications medium 102.
In some embodiments, to address the lost of link capacity (e.g., inefficient use of available transmission capacity of the communications medium 102) when a communications node is stalled while other communications node(s) has no data to send, the communications node transmits its assigned credit value to other communications node(s) during stall time slots (i.e., time slots in which the communications node is stalled. In these embodiments, other communications node(s) may also broadcast its assigned credit value. The communications nodes may collectively determine an increased replenishment value (i.e., decide how many replenishment rounds can be skipped). Alternatively, each communications node may independently determine an increased replenishment value (i.e., decide how many replenishment rounds can be skipped).
At the beginning of round 2, the credit replenishment value for round 2 is 1 credit added per round and the credit value, CreditA2, assigned to the communications node 104-1 is replenished to −23 (i.e., −24+1=−23) while the credit value, CreditB2, assigned to the communications node 104-2 is zero (i.e., −1+1=0). In round 2, a message 760-3 containing the credit value of the communications node 104-1 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-2, and subsequently an idle message 760-4 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-2. After the communications node 104-1 transmits the message 760-3 containing the credit value of the communications node 104-1 during the time slot TSA-2, the credit value, CreditA3 for round 3 (i.e., the credit value at the end of round 2) of the communications node 104-1 is set to zero (i.e., 23 replenishment rounds are skipped) while for the communications node 104-2, the credit value, CreditB3 for round 3 is kept or maintained at zero because the communications node 104-2 does not transmit any data frame during the time slot TSB-2.
At the beginning of round 3, the credit value, CreditA3, assigned to the communications node 104-1 and the credit value, CreditB3 for round 3 are maintained at zero (i.e., saturated at maximum credit value, which is zero in the example of
At the beginning of round 2, the credit replenishment value for round 2 is 1 credit added per round and the credit value, CreditA2, assigned to the communications node 104-1 is replenished to −23 (i.e., −24+1=−23) while the credit value, CreditB2, assigned to the communications node 104-2 is replenished to 0 (i.e., −1+1=0). In round 2, a message 860-3 containing the credit value (−23) of the communications node 104-1 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-2, and subsequently a data frame 860-2 of 192 bytes is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-2. After the communications node 104-1 transmits the message 860-3 containing the credit value of the communications node 104-1 during the time slot TSA-2, the credit value, CreditA3 for round 3 (i.e., the credit value at the end of round 2) of the communications node 104-1 is kept or maintained at −23 because the communications node 104-1 does not transmit any data frame during the time slot TSA-2 while for the communications node 104-2, the credit value, CreditB3 for round 3 is deducted to −3 (i.e., 0−3=−3) because the communications node 104-2 transmits the data frame 860-4 during the time slot TSB-2.
At the beginning of round 3, the credit replenishment value for round 3 is 1 credit added per round and the credit value, CreditA3, assigned to the communications node 104-1 and the credit value, CreditB3, assigned to the communications node 104-2 for round 3 are replenished to −22 (i.e., −23+1=−22) and −2 (i.e., −3+1=−2), respectively. In round 3, a message 860-5 containing the credit value (−22) of the communications node 104-1 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-3, and subsequently a message 860-6 containing the credit value (−2) of the communications node 104-2 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-3. In the embodiment depicted in
A=−max(−22, −2)=2 (3)
each communications node advance by 2 rounds in round 4 (i.e., the credit replenishment value for round 4 is 2 credit added per round).
At the beginning of round 4, the credit replenishment value for round 4 is 2 credit added per round and the credit value, CreditA4, assigned to the communications node 104-1 and the credit value, CreditB4, assigned to the communications node 104-2 for round 4 are replenished to −20 (i.e., −22+2=20) and 0 (i.e., −2+2=0), respectively. In round 4, a message 860-7 containing the credit value (−20) of the communications node 104-1 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-4, and subsequently a data frame 860-8 of 192 bytes is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-4. In the embodiment depicted in
At the beginning of round 5, the credit replenishment value for round 5 is 1 credit added per round, and the credit value, CreditA5, assigned to the communications node 104-1 and the credit value, CreditB5, assigned to the communications node 104-2 for round 5 are replenished to −19 (i.e., −20+1=−19) and −2 (i.e., −3+1=−2), respectively. In round 5, a message 860-9 containing the credit value (−19) of the communications node 104-1 is transmitted through the communications medium 102 by the communications node 104-1 during a time slot TSA-5, and subsequently a message 860-10 containing the credit value (−2) of the communications node 104-2 is transmitted through the communications medium by the communications node 104-2 during a time slot TSB-5. In the embodiment depicted in
A=−max(−19, −2)=2 (4)
each communications node advance by 2 rounds in round 6 (i.e., the credit replenishment value for round 6 is 2 credit added per round).
At block 902, a credit value assigned to a communications node is replenished in a communications round. At block 904, access to the communications medium to the communications node during the communications round is granted or denied based on the credit value. At block 906, the credit value is controlled in response to granting or denying access to the communications medium to the communications node during the communications round. The communications node may be the same as or similar to the communications nodes 104-1, 104-2, . . . , 104-N depicted in
In the above description, specific details of various embodiments are provided. However, some embodiments may be practiced with less than all of these specific details. In other instances, certain methods, procedures, components, structures, and/or functions are described in no more detail than to enable the various embodiments of the invention, for the sake of brevity and clarity.
Although the operations of the method(s) herein are shown and described in a particular order, the order of the operations of each method may be altered so that certain operations may be performed in an inverse order or so that certain operations may be performed, at least in part, concurrently with other operations. In another embodiment, instructions or sub-operations of distinct operations may be implemented in an intermittent and/or alternating manner.
It should also be noted that at least some of the operations for the methods described herein may be implemented using software instructions stored on a computer useable storage medium for execution by a computer. As an example, an embodiment of a computer program product includes a computer useable storage medium to store a computer readable program.
The computer-useable or computer-readable storage medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device). Examples of non-transitory computer-useable and computer-readable storage media include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and an optical disk. Current examples of optical disks include a compact disk with read only memory (CD-ROM), a compact disk with read/write (CD-R/W), and a digital video disk (DVD).
Alternatively, embodiments of the invention may be implemented entirely in hardware or in an implementation containing both hardware and software elements. In embodiments which use software, the software may include but is not limited to firmware, resident software, microcode, etc.
Although specific embodiments of the invention have been described and illustrated, the invention is not to be limited to the specific forms or arrangements of parts so described and illustrated. The scope of the invention is to be defined by the claims appended hereto and their equivalents.