VARIABLE LINK AGGREGATION
20210409309 · 2021-12-30
Inventors
Cpc classification
H04L47/34
ELECTRICITY
International classification
Abstract
A system and method to transmit frames from a first node to a second node over a plurality of radio links comprising a classifier to classify said frames according to one of a plurality of flow and a sequence number within said one of said plurality of flow and adding said flow and sequence number in a header of said classified frame a splitter receiving said classified frames from said classifier and distributing said classified frames on one of said plurality of radio links for transmission to said second node, a joiner receiving said classified frames and reordering them using an indexed sequence queue corresponding to each of said plurality of flows, a timer for waiting for frames missing in the sequence in one of said indexed sequence queue, wherein when said timer expires, if said frame has not arrived it is deemed lost and a forwarder to extract frames from said sequence queue to forward.
Claims
1. A system to transmit frames from a first node to a second node over a plurality of radio links comprising: a classifier to classify said frames according to one of a plurality of flow and a sequence number within said one of said plurality of flow and adding said flow and sequence number in a header of said classified frame; a splitter receiving said classified frames from said classifier and distributing said classified frames on one of said plurality of radio links for transmission to said second node; a joiner receiving said classified frames and reordering them using an indexed sequence queue corresponding to each of said plurality of flows; a timer for waiting for frames missing in the sequence in one of said indexed sequence queue, wherein when said timer expires, if said frame has not arrived it is deemed lost; and a forwarder to extract frames from said sequence queue to forward.
2. The system of claim 1 wherein said joiner adds a flow identifier to a flow queue upon reception of said classified frames and said forwarder extracts said flow identifier from said flow queue to select which sequence queue to extract the next frame.
3. A method to transmit frames from a first node to a second node over a plurality of radio links comprising: classifying said frames according to one of a plurality of flow and a sequence number within said one of said plurality of flow and adding said flow and sequence number in a header of said classified frame; receiving said classified frames from said classifier and distributing said classified frames on one of said plurality of radio links for transmission to said second node; receiving said classified frames, at said second node, and reordering them using one of a plurality of indexed sequence queue corresponding to each of said plurality of flows; waiting, using a timer, for frames missing in the sequence in one of said indexed sequence queue, wherein when said timer expires, if said frame has not arrived it is deemed lost; and extracting said frames from said sequence queue to transmit on a radio link.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0008] To easily identify the discussion of any particular element or act, the most significant digit or digits in a reference number refer to the figure number in which that element is first introduced.
[0009]
[0010]
[0011]
[0012]
[0013]
[0014]
DETAILED DESCRIPTION
[0015] The details of one or more embodiments of the subject matter of this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
[0016] Like reference numbers and designations in the various drawings indicate like elements.
[0017]
[0018] In one embodiment, the traffic from a single flow is split across multiple links. This introduces the possibility that individual frames in the single flow arrive out of order at the remote node 20. This embodiment optimally splits traffic from a single flow (or multiple flows) across multiple variable speed wireless links and recombines it efficiently at the remote side so proper flow ordering is maintained while still providing predictable Quality of Service (QoS).
[0019]
[0020]
[0021]
[0022] In a preferred embodiment, the flow identifier is optionally placed in a Flow Queue 314. A forwarder 318 reads the flow identifier at the top of the flow queue 314 and uses it to access the appropriate sequence queue to read from. If there is no frame at the head (dropped or out of order) then the flow identifier is requeued in the flow queue and a timer is started for this flow queue. If a frame is available at the head of the sequence queue, the forwarder reads the frame and forwards it, and if the timer was previously started, it is reset. If there is no frame at the head and the timer has expired, then the forwarder assumes this frame is lost and advances to the next frame in the queue.
[0023] The frames exit the forwarder 320 in the right order with respect to their specific flow but can be reordered with respect to other flows and the original frame arrival 322 which does not create an issue.
[0024]
[0025]
[0026] When the forwarder reads A from the flow queue 314, it reads the first frame 510 and transmits it. The next time the forwarder reads A from the flow queue 314, it sees an empty slot (“NULL”) 514 entry in the sequence queue 316b, a timer 520 is started and the forwarder reinserts A back into the flow queue 314. When the forwarder reads A again from the flow queue 314, packet #2 518 has arrived and the forwarder reads and transmits it, then resets the timer.
[0027] There are a limited number of sequence numbers and the system can use a modulo function to wrap around the number. For example, using 8 bits, there can be 256 sequence numbers (0-255).
[0028] The foregoing descriptions of specific embodiments of the present invention have been presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention and method of use to the precise forms disclosed. Obviously, many modifications and variations are possible in light of the above teaching. The embodiments described were chosen and described in order to best explain the principles of the invention and its practical application, and to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is understood that various omissions or substitutions of equivalents are contemplated as circumstance may suggest or render expedient but is intended to cover the application or implementation without departing from the spirit or scope of the claims of the present invention.