US20120281704A1 - Methods and apparatus for isochronous data delivery within a network - Google Patents

Methods and apparatus for isochronous data delivery within a network Download PDF

Info

Publication number
US20120281704A1
US20120281704A1 US13/098,934 US201113098934A US2012281704A1 US 20120281704 A1 US20120281704 A1 US 20120281704A1 US 201113098934 A US201113098934 A US 201113098934A US 2012281704 A1 US2012281704 A1 US 2012281704A1
Authority
US
United States
Prior art keywords
packets
time
isochronous
data
packet
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US13/098,934
Inventor
Ashley I. Butterworth
Girault W. Jones, Jr.
Matthew X. Mora
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple Inc
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 Apple Inc filed Critical Apple Inc
Priority to US13/098,934 priority Critical patent/US20120281704A1/en
Assigned to APPLE INC. reassignment APPLE INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BUTTERWORTH, ASHLEY I., JONES, GIRAULT W., JR., MORA, MATTHEW X.
Priority to TW101115614A priority patent/TWI526024B/en
Priority to PCT/US2012/036188 priority patent/WO2012151323A2/en
Publication of US20120281704A1 publication Critical patent/US20120281704A1/en
Priority to US14/458,139 priority patent/US10992404B2/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/16Time-division multiplex systems in which the time allocation to individual channels within a transmission cycle is variable, e.g. to accommodate varying complexity of signals, to vary number of channels transmitted
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/56Queue scheduling implementing delay-aware scheduling
    • H04L47/564Attaching a deadline to packets, e.g. earliest due date first
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/02Topology update or discovery
    • H04L45/10Routing in connection-oriented networks, e.g. X.25 or ATM
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/56Queue scheduling implementing delay-aware scheduling
    • H04L47/568Calendar queues or timing rings
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/90Buffering arrangements
    • H04L49/9063Intermediate storage in different physical parts of a node or terminal
    • H04L49/9068Intermediate storage in different physical parts of a node or terminal in the network interface card
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/52Queue scheduling by attributing bandwidth to queues
    • H04L47/521Static queue service slot or fixed bandwidth allocation

Definitions

  • the present invention relates generally to the field of computerized devices, networks and buses. More particularly, in one exemplary aspect, the present invention is directed to efficiently servicing isochronous streams associated with a network.
  • isochronous generally refers to processes where data must be delivered within certain time constraints for use.
  • an isochronous transport mechanism ensures that data is delivered with enough time to render audio and video to provide smooth, uninterrupted content to the user or consumer. Data which is not delivered in time for rendering cannot be used, and is generally ignored.
  • asynchronous refers to processes where data transfer does not have a guaranteed time constrained delivery.
  • Asynchronous delivery is also sometimes referred to as “best effort delivery”; each user receives the “best effort” the network can support, based on existing traffic conditions and requirements.
  • IEEE Std. 802.3 and IEEE Std. 802.11 network infrastructures have been designed to support asynchronous data delivery.
  • typical IEEE Std. 802.3 compliant Ethernet network interface controllers (NICs) operate on a First-In-First-Out (FIFO) basis.
  • FIFO operation is well suited for asynchronous data delivery over flexible network topologies.
  • IEEE Std. 1394 compliant systems have been designed to support isochronous data delivery.
  • IEEE Std. 1394 compliant systems reserve an amount of bandwidth for each isochronous channel. The reserved bandwidth is further allocated for each node, from source to destination. In this fashion, each source is isolated from the behavior of other sources, and the overall transmission delay between source and destination is fixed and predictable.
  • IEEE Std. 802.3 (and IEEE 802.11 Std.) type networks have very loose time synchronization which can create problems with launch time guarantees.
  • each data stream has its own time base, combining multiple streams can fill the FIFO with out-of-order packets. Out-of-order packets will be dropped or delivered too late, with using the existing launch time guarantees. Consequently, existing devices cannot support multiple isochronous data streams.
  • the present invention satisfies the foregoing needs by providing, inter alia, methods and apparatus for efficiently servicing isochronous streams for a data network.
  • a method of managing a plurality of isochronous processes includes receiving multiple isochronous data streams, each isochronous data stream includes a plurality of isochronous data packets, where each packet has a presentation time; sorting each isochronous data packet according to the presentation time; calculating a launch time for each isochronous data packet of the multiple isochronous data streams; and transmitting the isochronous data packets according to the launch time.
  • the method additionally includes receiving asynchronous data packets; and transmitting the asynchronous data packets.
  • the asynchronous data packets are sorted with the isochronous data packets.
  • a first portion of bandwidth is reserved for isochronous data packets, and a second portion of bandwidth is reserved for asynchronous data packets.
  • the act of sorting includes storing the isochronous data packets into a ring buffer according to presentation time.
  • At least one of the multiple isochronous data streams comprises video and/or data.
  • At least one of the multiple isochronous data streams have different time base.
  • the act of calculating comprises adjusting the launch time of the isochronous data packets according to a master time base.
  • a method for reconstructing a plurality of isochronous processes includes receiving one or more unreserved time slots of packet data, the time slot comprising a plurality of packets transmitted in chronological order. At least one packet has a presentation time associated therewith, and the method further includes extracting the at least one packet, and presenting the at least one packet at the associated presentation time.
  • the at least one packet includes an isochronous data packet.
  • At least another packet includes an asynchronous data packet.
  • the subset of packets are stored in order of arrival into a First-In-First-Out (FIFO) buffer.
  • FIFO First-In-First-Out
  • the at least one packet includes video data.
  • the at least one packet includes one or more subpackets of data.
  • the one or more subpackets of data include a video subpacket and an audio subpacket.
  • a network interface apparatus in a third aspect of the invention, includes: a transmission queue, the transmission queue configured to transmit a plurality of slots of data at a designated time; a data interface configured to receive a plurality of isochronous data streams, the plurality of isochronous data streams having one or more different time references; a network interface clock, the network interface clock configured to generate a designated time reference; and at least one controller.
  • the at least one controller is configured to: extract one or more data packets from the plurality of isochronous data streams; sort the one or more data packets based at least in part on a presentation time; calculate a launch time for each of the one or more data packets; and transmit the slots of data at the calculated launch time.
  • the calculated launch time is based at least in part on a difference between the one or more different time references and the designated time reference.
  • the sorted one or more data packets are assigned to a slot of data.
  • a method of processing isochronous data streams includes: receiving multiple isochronous data streams, each isochronous data stream comprising a plurality of isochronous data packets; determining a sorting criterion for the multiple isochronous data streams; sorting at least a portion of the isochronous data packets in each stream according to the determined sorting criterion to produce a sorted order of data packets; and transmitting the isochronous data packets according to the sorted order.
  • a computer readable medium for processing isochronous data streams is disclosed.
  • an endpoint device for processing isochronous data streams is disclosed.
  • a node device for processing isochronous data streams is disclosed.
  • FIG. 1 is a functional block diagram illustrating one exemplary prior art packet-switched network.
  • FIG. 2 is a logical flow diagram illustrating one embodiment of a generalized method for scheduling multiple independent chronological streams of packets according to the invention.
  • FIG. 3 is a graphical representation of one exemplary technique for interleaving multiple independent chronological streams of packets in accordance with the present invention.
  • FIG. 4 is a graphical representation of one exemplary technique for deinterleaving a chronological stream of packets in accordance with the present invention.
  • FIG. 5 is a logical flow diagram illustrating one exemplary embodiment of a method for scheduling a time division multiplexed (TDM) packing scheme, according to the present invention.
  • FIG. 6 is a block diagram of an exemplary apparatus useful for implementing the methods of the present invention.
  • the present invention provides, inter alia, methods and apparatus for efficiently servicing isochronous streams, such as may be used in a data network.
  • the invention leverages incipient improvements in extant controller architectures (e.g., Ethernet network interface controllers (NICs)) by adding scheduling capabilities to various components of the network.
  • the scheduling algorithms interleave and/or deinterleave multiple independent chronological streams of packets by calculating a launch time for each packet (based at least in part on the packet's presentation time). Scheduling each packet for transmission ensures that the packets are transmitted in their proper presentation sequence.
  • an Isochronous Cycle Manager receives multiple isochronous streams of packets, where each packet has a required presentation time.
  • the ICM generates an interleaved output stream of packets by pre-sorting the packets in accordance with the presentation time base.
  • Each packet of the interleaved output stream is further assigned a launch time and queued for transmission.
  • the network interface controller transmits the queue of packets, where each packet is transmitted according to launch time.
  • the ICM receives an isochronous stream of packets, and deinterleaves the stream into multiple streams of packets that are pre-sorted according to the presentation time base, assigned a launch time, and transmitted according to launch time.
  • the ICM of the exemplary embodiment considers multiple factors when calculating launch time. By pre-sorting packets for transmission, each isochronous data stream can be delivered efficiently (i.e., without network resource under-utilization) within the appropriate time restriction(s). For example, in one variant, a device can handle heterogenous mixtures of asynchronous and isochronous packets. Still other variants may consider parameters such as packet priority, packet type, etc.
  • a device can support any arbitrary mapping of M isochronous streams to N isochronous streams.
  • packet networks refers without limitation to any network configured to transfer data as suitably-sized groupings called packets.
  • Packet networks can deliver streams of data (composed of sequences of packets) to a community of devices. During transfer, packets are buffered and queued, and may experience variable delays and throughput depending on the traffic load in the network.
  • packet-based networks include the Internet (i.e., the global system of interconnected computer networks), as well as privatized internets, and intranets.
  • the term “source” refers to a device or interface configured to packetize information for transfer via a packet-based network.
  • destination refers without limitation to a device or interface configured to extract information from a packet.
  • endpoint generally refers without limitation to the portion of a device that is a “source” and/or “destination” of information in a communication flow between devices.
  • a “node” refers without limitation to a device which receives packets, and forwards the packets to another device.
  • a client device or other entity may or may not include a logical or physical “endpoint” and/or “node” within the network. It is further appreciated that a device may (and generally will) simultaneously implement source, destination and node functionalities; the foregoing distinctions being made only for the purposes of clarifying various aspects of the present invention.
  • WLANs such as IEEE Std. 802.11 wireless networks
  • WMANs such as IEEE Std. 802.16 wireless networks
  • PANs personal area networks
  • BluetoothTM infrared, and optical communication links.
  • FIG. 1 illustrates one exemplary prior art packet-based network 100 .
  • the network 100 includes a number of sources (M) 102 in communication with a number of sinks (N) 104 via a network of nodes 106 .
  • the packet-based network 100 has a network time base 110 associated therewith.
  • the network 100 is composed of a collection of nodes connected to a collection of endpoints.
  • endpoints include, but are not limited to, personal computers (PCs), whether desktop, laptop, handheld or otherwise, network media devices (such as digital settop boxes), and mobile devices such as smartphones, PDAs, digital and video cameras, personal media devices (PMDs) (such as MP3 players, printers or rendering devices), or any combinations of the foregoing.
  • nodes include, but are not limited to, servers, computers, routers, firewalls, gateways, etc.
  • NICs Ethernet network interface controllers
  • launch time i.e., the NIC can transmit a packet at a specified time.
  • a first source 102 A can connect via a collection of nodes 106 to a first sink 104 A. Accordingly, the first source and the first sink can establish a guaranteed isochronous connection within those time constraints.
  • Ethernet network time 110 can vary by as much as ten milliseconds (10 ms) between devices, whereas packet transmission can occur in only a fraction of that time. Consequently, the NIC (which has a much higher time resolution) cannot optimally determine transmission times based only on packet presentation time.
  • an Isochronous Cycle Manager interleaves and/or deinterleaves multiple independent chronological streams of packets based on presentation time, and one or more additional considerations.
  • the ICM scheduler can handle a wide population of presentation requirements (e.g., streams which have stringent requirements can be serviced with streams that have loose requirements).
  • a device or process receives one or more input stream(s), each stream having a plurality of packets.
  • the streams include both isochronous and asynchronous data streams.
  • an Ethernet interface is configured to service a first portion (isochronous data traffic), and a second portion (asynchronous data traffic).
  • the method 200 is in no way limited to two (i.e., first and second portions); for instance, three streams might be used (such as one asynchronous and two isochronous, etc.)
  • Various other combinations/permutations will be recognized by those of ordinary skill given the present disclosure.
  • first and second portions may be further subdivided by type or another criterion, such as priority.
  • a “Class A” and “Class B” isochronous data traffic might be used.
  • One such implementation may support e.g., up to (but not exceeding) seventy five percent (75%) isochronous traffic, which is subdivided into Class A and Class B (where Class A traffic is always prioritized over Class B traffic), and twenty five percent (25%) asynchronous traffic.
  • isochronous data include video data, audio data, game content (e.g., player position, game synchronization information, etc.), and conference content (e.g., mouse movements, key presses, etc.)
  • game content e.g., player position, game synchronization information, etc.
  • conference content e.g., mouse movements, key presses, etc.
  • any data having temporal relevance may be transported as isochronous data (e.g., environment, presence, location, time, etc.).
  • each isochronous stream may be composed of packets, where each packet may be further subdivided into subpackets.
  • packets may be further subdivided into subpackets.
  • Such implementations are common where multiple types of data are bundled together for a common playback time. For example, audio and video data that are played together can be bundled together in the same packet.
  • data may be bundled together where the data must be decoded together, but are separated for logical reasons (e.g., parity, error checking, etc.)
  • the input streams may be received from the same device, or alternately may be received from multiple different devices.
  • several source endpoints may generate multiple streams that are aggregated together at a destination endpoint.
  • a single source endpoint may generate multiple streams (e.g., multiple applications running simultaneously), for one or more destination endpoints.
  • the isochronous data includes: (i) a header describing one or more isochronous data, (ii) the one or more isochronous data, and (iii) error checking information.
  • information that may be included within the header include: (i) source address, (ii) destination address, (iii) presentation or playback time, (iv) packet identifier, etc.
  • the header may comprise other information such as: (i) path information (e.g., intermediate node addresses), (ii) length of the packet, (iii) total length of the stream, (iv) encoding type, (v) codec information, (vi) Quality of Service (QoS) or priority information, etc.
  • the device sorts the received packets according to their presentation time.
  • the device received data packets from multiple chronological sources, and interleaves them into chronological order. While each source provides a chronological sequence of packets, packets supplied from independent sources may not be chronological (due to discrepancies in device timing, network synchronization issues, etc.).
  • the packets are sorted into a buffering mechanism by presentation time.
  • a suitable buffering system is a so-called “ring” buffer.
  • a simple ring buffer is constructed of a memory with a read pointer, where the read pointer is configured to increment, and where the pointer “rolls over” to the first address after the last address.
  • Each packet is written into the ring buffer according to the order of presentation.
  • Other common examples of suitable memory structures include normal buffers and queues, linked lists, stacks, etc.
  • the packets are additionally interspersed with other packet types.
  • Such other packet types may include asynchronous packets (“best effort”), isochronous packets of a different priority (e.g., Class A, Class B), etc.
  • the buffer is populated with up to a first percentage (e.g., seventy five percent (75%)) isochronous packets, and a second percentage (e.g., twenty five percent (25%)) asynchronous packets.
  • the packets are further divided into priority classes, so that the allotments to isochronous and asynchronous data are necessarily filled with higher priority packets before adding lower priority packets.
  • the buffer may further include priority information; such priority information may be based on: data type (e.g., Class A, Class B, etc.), temporal considerations (e.g., priority is increased as the packet gets closer to the desired presentation time), source consideration (e.g., the packet was sent from a high priority source, etc.)
  • data type e.g., Class A, Class B, etc.
  • temporal considerations e.g., priority is increased as the packet gets closer to the desired presentation time
  • source consideration e.g., the packet was sent from a high priority source, etc.
  • the buffer may include information about the packetized data.
  • information may include a media stream identifier, a source identifier, a destination identifier, a media type identifier, etc.
  • implementations which subdivide packets into subpackets may further itemize the subpacket information, which may include similar information (e.g., a media stream identifier, a source identifier, a destination identifier, a media type identifier, etc.)
  • the device calculates each packet's launch time.
  • the device reads the presentation time of the packet from its header, and calculates a launch time of the packet according to one or more considerations.
  • considerations may include, but are not limited to: (i) the device's own master time, (ii) the network time, (iii) the recipient device's master time, (iv) the network interface controller (NIC) time, path delay, and/or (v) packet characteristics (e.g., packet priority, packet type, etc.).
  • a calculated launch time include, but are not limited to: (i) an assigned time slot, (ii) a range of acceptable time slots, (iii) an assigned transmission time, and (iv) a range of acceptable transmission times. In some embodiments, it may be acceptable, or even desired, that certain packets are not assigned a launch time (e.g., low priority packets, asynchronous packets, etc.). In one implementation, the calculated launch time corresponds to a time base of a network interface controller (NIC).
  • NIC network interface controller
  • Ethernet does not have stringent time synchronization requirements (the network time base can vary by as much as ten milliseconds (10 ms) between devices).
  • the aforementioned modified Ethernet network interface controllers (NICs) have internal clocking which is significantly faster; exemplary Ethernet NICs can transmit in time slots which are accurate to within one microsecond (1 ⁇ s).
  • ns nanoseconds
  • EQN. 1 and EQN. 2 provide exemplary equations for converting from one time base to another time base.
  • EQN. 1 can be used where both the device time base (t d ), and the source time base (t s ) have the same clock rate, but may have an offset in time:
  • T′ the adjusted presentation time for the device time base (t d );
  • T the presentation time for the source time base (t s );
  • EQN. 2 can be used where both the device time base (t d ), and the source time base (t s ) have a fixed proportionate relationship, even though the clock rates differ:
  • T′ kT+T 0 , (EQN. 2)
  • T′ the adjusted presentation time for the device time base (t d );
  • T the presentation time for the source time base (t s );
  • T 0 an offset value
  • time base may require more complicated schemes. For example, some time bases may not be continuous (i.e., may start and stop), may use non-constant clock rates (i.e., 1 ⁇ rate, 2 ⁇ rate, 4 ⁇ rate, etc.), and/or may need to compensate for clock artifacts (e.g., excessive jitter, clock drift, etc.).
  • non-constant clock rates i.e., 1 ⁇ rate, 2 ⁇ rate, 4 ⁇ rate, etc.
  • clock artifacts e.g., excessive jitter, clock drift, etc.
  • each time base is a network interface controller (NIC) clock (e.g., a crystal oscillator within the NIC).
  • NIC network interface controller
  • a device receiving two (2) input streams and generating one (1) output stream will calculate launch times for each packet received from the two (2) input streams, for the NIC.
  • a device receiving three (3) input streams and generating two (2) output streams will calculate launch times for each packet received from the three (3) input streams, corresponding to the appropriate time base for the desired output streams (e.g., a packet destined for the first output stream time will have launch times corresponding to a first NIC a packet destined for the second output stream time will have launch times corresponding to a second NIC).
  • the output time bases may be based on a single master time base (where a single NIC transmits multiple streams, where multiple NICs share a time base, and/or where multiple NIC time bases are based on a master clock).
  • packet formats composed of multiple subpackets may be divided into constituent subpackets, recombined, etc.
  • a device receiving one (1) input stream consisting of packets containing audio and video subpackets can be divided into: (i) an audio stream consisting of packets containing audio subpackets that have been re-timed for an audio time base, and (ii) a video stream consisting of packets containing video subpackets, that have been re-timed for a video time base. These time bases may be the same or different.
  • the presentation time is preserved throughout transfer (i.e., the launch time has no impact on presentation time), or that the presentation time indicated in the packet is the same between the source and destination endpoint.
  • the presentation times of the packets can be adjusted.
  • some embodiments may add or update a metadata field with the presentation time information.
  • the device generates the one or more output stream(s) based on the calculated packet launch times.
  • the device has previously negotiated, or was assigned a network resource, for transmitting buffered data.
  • a network resources include time slots, frequency bands, spreading codes, time-frequency resources, etc.
  • the resources are arbitrated during operation, in some cases, with acceptable levels of collision.
  • Transmission of each packet over the network resource is performed by reading the packets out of the buffer, and transmitting them on the network resource. Since the packets have been stored within the buffer in the exemplary embodiment with a calculated launch time, the resulting stream will be properly ordered for transmission. In some situations, where packets or resources are dropped or where the source and destination endpoint lose synchronization, it may be necessary to increment and/or decrement the reading or writing of the buffer accordingly.
  • a very simple processing engine of the network interface controller (NIC) can execute transmission.
  • the NIC can perform direct memory access (DMA) type transactions, transmitting packets out of the buffer without further supervision (e.g., unmoderated by the application processor, etc.)
  • each packet is assigned a slot time during which the packet can be transmitted.
  • packets are assigned slot times as slots are available, the packets are transmitted according to presentation order.
  • the device may not be assigned a sufficient number of time slots to transmit all of its data.
  • “Stale” isochronous packets i.e., isochronous packets which have not or cannot meet their delivery time requirements
  • postponing asynchronous packet delivery and/or skipping stale isochronous packets may require that the buffer is reordered.
  • the buffers for isochronous and asynchronous data are separated, to prevent the asynchronous data from overwriting asynchronous data.
  • a first stream includes an isochronous series of packets arriving according to a first time base (t 1 ), and a second stream includes an isochronous series of packets arriving according to a second time base (t 2 ).
  • the packets are aggregated by an Isochronous Cycle Manager (e.g., ICM), and transmitted according to a third time base (t 3 ).
  • ICM Isochronous Cycle Manager
  • t 3 third time base
  • the time bases are different, and not shown to scale. More specifically, while each stream provides a sequence of packets in chronological presentation time order; the packets from multiple streams may not arrive in proper chronological presentation time order. For example, as shown, packet C arrives after packet J, even though packet C has a presentation time before packet J.
  • the ICM receives the first and second stream of packets, where the received packets are sorted, and then inserted into a buffering mechanism (e.g., ring buffer) according to their required presentation time.
  • a buffering mechanism e.g., ring buffer
  • the ring buffer also contains a mapping between the stream (first, second), and the slots assigned to that stream (if multiple are available).
  • the Isochronous Cycle Manager (e.g., ICM) operates according to a time division multiplexed (TDM) scheme, where each of a plurality of cycles is subdivided into time slots.
  • TDM time division multiplexed
  • each cycle consists of one-hundred twenty five (125) time slots, where each time slot is one microsecond (1 ⁇ s) in duration.
  • the ICM negotiates, or alternatively is assigned) time slots to transmit during each cycle.
  • the ICM calculates and assigns each packet a corresponding launch time.
  • a cycle timer counts a designated multiple of the isochronous cycle time period; each time that the timer fires, the designated multiple cycles worth of data are transferred to the NIC.
  • the launch times of each packet correspond to the NIC's time domain.
  • the NIC subsequently transmits each of the packets in accordance with the calculated launch times.
  • an input stream includes an isochronous series of packets according to a first time base (t 1 ).
  • the packets are deinterleaved (separated) into the first and second constituent streams by the Isochronous Cycle Manager (e.g., ICM), and transmitted according to the second and third time bases respectively (t 2 , t 3 ).
  • ICM Isochronous Cycle Manager
  • the ICM receives the input stream of packets, and splits the received packets into first and second First-In-First-Out (FIFO) buffers, with launch times configured for the first and second NIC hardware respectively.
  • the first buffer is transferred to a first NIC according to the second time base in order to generate the first isochronous output data stream.
  • the second buffer is transferred to a second NIC according to the third time base, thereby generating the second isochronous output data stream.
  • a cycle timer for each NIC counts a designated multiple of the isochronous cycle time period; each time that the timer fires, the designated multiple cycles worth of data are transferred to the respective NIC.
  • Each NIC subsequently transmits each of the packets in accordance with the calculated launch times.
  • the NICs share a common time base; however, other embodiments may have a distinct time base for each NIC.
  • FIG. 5 one exemplary embodiment of a method for scheduling a time division multiplexed (TDM) packing scheme according to the present invention is illustrated.
  • the ICM negotiates or allocates time slots to stream the isochronous data stream (and deallocates time slots when streams are finished).
  • the ICM (or another entity/process acting as a proxy) calculates the required number of slots to transmit all the data for the cycle. For example, the number of microseconds ( ⁇ s) or time slots necessary to transmit the collected data is tallied, and rounded up to the nearest increment.
  • the required number of slots must additionally be contiguous. Contiguous slots can improve overall network overhead by reducing switching overhead, arbitration overhead, etc.
  • non-contiguous slots may be used e.g., where additional flexibility is required, and/or where certain services can be prioritized, etc. For example, in one such embodiment, best-effort delivery or even low priority isochronous packets can be delivered when slots are available (such as during gaps between other high priority traffic).
  • a timer counts down a time interval (e.g., one or more multiples of the isochronous cycle time period), during which time a buffer collects data from the input streams.
  • a time interval e.g., one or more multiples of the isochronous cycle time period
  • the buffer continues to collect data until a full cycle of data has been buffered.
  • the collected data is sorted by presentation time (step 506 ), and a launch time is calculated for each packet (step 508 ).
  • each packet is assigned a time slot for transmission in the NIC's time base (e.g., adding an offset, or scaling by a scale or difference factor). In this manner, even if the input stream packets arrive out of sequence, the output of the node has been sorted into appropriate presentation time order, and assigned a launch time (according to that order).
  • one sorting criterion may comprise sorting based on packet type (e.g., where Emergency Medical Services (EMS) type packets may be granted a higher priority, etc.)
  • packet type e.g., where Emergency Medical Services (EMS) type packets may be granted a higher priority, etc.
  • the time slots are provided to the NIC for transmission. This greatly reduces processor burden.
  • the NIC can perform direct memory access (DMA) type transactions, transmitting packets out of the buffer according to their calculated launch time.
  • DMA direct memory access
  • the transmitted time slots retain the sorted order; i.e., packets are transmitted in the order of their presentation time.
  • packets are transmitted in the order of their presentation time.
  • the packet which is to be presented next is always transmitted in the first available time slot preceding presentation.
  • each time slot is inspected for packets; when a packet is extracted, it is routed to the appropriate buffer queue (e.g., a queue for each stream). Since the packets arrive in the proper chronological order (e.g., presentation order), the queues are correctly ordered for subsequent use or processing, such as audio/video playback in the illustrated example.
  • the appropriate buffer queue e.g., a queue for each stream. Since the packets arrive in the proper chronological order (e.g., presentation order), the queues are correctly ordered for subsequent use or processing, such as audio/video playback in the illustrated example.
  • packets While the packets are chronologically ordered, in some cases packets may be dropped, corrupted, etc. Accordingly, in some embodiments, the packets may be further processed or checked; e.g., to facilitate lost packet identification or recovery, decryption. For example, data streams which can tolerate some packet loss may utilize a running packet count, to determine if a packet has been dropped. Similarly, error checking routines (e.g., Cyclic Redundancy Check (CRC)) may be executed to identify corrupted packets. Still other embodiments may recover various packet errors, based on e.g., parity bits, Forward Error Recovery (FEC) techniques (viterbi coding, turbo coding, etc.)
  • FEC Forward Error Recovery
  • FIG. 6 illustrates one exemplary embodiment of an apparatus 600 useful for implementing various methods of the present invention.
  • the apparatus of FIG. 6 includes a processor subsystem 602 such as a digital signal processor, microprocessor, field-programmable gate array, or plurality of processing components mounted on one or more substrates.
  • the processing subsystem may also include an internal cache memory.
  • the processing subsystem is in communication with a memory subsystem 604 including memory which may for example, comprise SRAM, Flash and SDRAM components.
  • the memory subsystem may implement one or a more of direct memory access (DMA) type hardware, so as to facilitate data accesses as is well known in the art.
  • DMA direct memory access
  • the memory subsystem contains computer-executable instructions which are executable by the processor subsystem.
  • the processor subsystem 602 is further configured to track a master time base 603 .
  • This master time base may be derived from an internal clock such as an internal oscillator circuit (e.g., Voltage Controlled Temperature Controlled Crystal Oscillator (VCTCXO), etc., or alternately may be reported or received from an external device or entity, such as a Global Positioning System (GPS), IEEE Std. 1588 (Precision Time Protocol), etc.
  • GPS Global Positioning System
  • IEEE Std. 1588 Precision Time Protocol
  • the apparatus includes a communications controller (e.g., NIC) 606 , which manages communications between endpoints.
  • the NIC is in operative communication with one or more network interfaces 608 .
  • the network interfaces are further configured to transmit and/or receive packetized traffic.
  • each network interface is associated with a corresponding time base. Each time base may or may not be further synchronized with the other time bases.
  • the NIC subsystem 606 further includes an internal time base 609 .
  • This NIC time base may be derived from an internal clock such as an internal oscillator circuit (e.g., Voltage Controlled Temperature Controlled Crystal Oscillator (VCTCXO), Voltage Controlled Crystal Oscillator (VCXO), Crystal Oscillator (VCO), etc.
  • an internal oscillator circuit e.g., Voltage Controlled Temperature Controlled Crystal Oscillator (VCTCXO), Voltage Controlled Crystal Oscillator (VCXO), Crystal Oscillator (VCO), etc.
  • the one or more network interfaces are Ethernet compliant interfaces (IEEE Std. 802.3). In alternate embodiments, the one or more network interfaces are configured for use with a serial bus protocol. Common examples of such serial bus protocols useful with the invention include but are not limited to: Universal Serial Bus (USB), FireWire (IEEE Std. 1394), High Definition Multimedia Interface (HDMI), Digital Visual Interface (DVI), and DisplayPort.
  • USB Universal Serial Bus
  • FireWire IEEE Std. 1394
  • HDMI High Definition Multimedia Interface
  • DVI Digital Visual Interface
  • DisplayPort DisplayPort
  • the network interfaces are time division multiplexed (TDM).
  • TDM time division multiplexed
  • the network interface transmits and/or receives packets only during assigned and/or negotiated time slots of a cycle.
  • the transmission/reception may be implemented for example as full- or half-duplex.
  • the network interfaces are frequency division multiplexed (FDM), where the network interface is configured to transmit and/or receive packets via a specified frequency band.
  • FDM frequency division multiplexed
  • the network interfaces are code division multiplexed, which are configured to transmit and/or receive packets using a spreading factor.
  • Orthogonal Frequency Division Multiplexing may also be used, which specifies both time and frequency resources.
  • packetized traffic is data which has been formatted into discrete units or packets of data.
  • Each packet includes at least routing information and payload.
  • the routing information provides e.g., source and destination addresses, error detection codes, and sequence information.
  • isochronous data packets contain presentation information, where the presentation information is specific to the packet's time base.
  • the packetized traffic may provide various guarantees for reliability.
  • a “reliable” service may provide explicit acknowledgment (ACK) or non-acknowledgement (NAK)
  • “unreliable” service may not provide any feedback as to transmission success or failure.
  • packetized traffic encompasses unreliable “datagrams” (such as those used in real-time traffic protocols such as Real Time Protocol (RTP) and User Datagram Protocol (UDP)), as well as more specialized audio/visual formats (such as Packetized Elementary Stream (PES)).
  • RTP Real Time Protocol
  • UDP User Datagram Protocol
  • PES Packetized Elementary Stream
  • Packetized traffic can consist of varying portions of asynchronous and isochronous data.
  • the packetized traffic is a mixture of isochronous packets and asynchronous packets, where at least a portion of the packets are further prioritized.
  • Such prioritization can be in accordance with a given proportion (e.g., seventy five percent (75%) isochronous, twenty five percent (25%) asynchronous), which may be fixed or variable as a function of time or other parameter(s). Alternately, such prioritization may be based on data class (e.g., Class A, Class B), or according to various requirements for quality of service (QoS).
  • QoS quality of service
  • the exemplary apparatus 600 of FIG. 6 has one or more transmit buffers 610 for transmitting isochronous data via at least one of the network interfaces.
  • Each transmit buffer is further configured to transmit its contents in an orderly sequential fashion.
  • the transmit buffer may be for example a ring buffer of the type previously described herein.
  • the buffer may have finite depth, where the depth is commensurate with an allowed transmission capacity. During such transmission, the buffer is read to completion, and rewritten for the next available transmission.
  • received isochronous packets are re-timed according to the NIC master time base 609 (or the time base associated with the transmit queue).
  • the isochronous packets are sorted according to e.g., presentation time, into the transmission buffer. Each packet's launch time is determined, the resulting buffer of packets is properly ordered for timely transmission.
  • the buffer does not distinguish between isochronous and asynchronous data.
  • the data may be further prioritized. For example, in one such prioritization scheme, asynchronous data can be added in any proportion, as long as the higher priority data (e.g., isochronous data) is serviced first.
  • isochronous data and asynchronous data are transmitted from different memory buffers.
  • the transmit buffers of the apparatus of FIG. 6 are further configured to transmit a packet at a designated launch time.
  • the designated launch time may acceptable within a design tolerance (such tolerances can be imposed by hardware limitations, network limitations, application limitations, etc.)
  • the transmit buffers are configured to transmit packets via a designated network resource; e,g, a time slot, frequency band, spreading code, etc.
  • the transmit buffers may also be configured to transmit packets within a range of time and/or network resources.
  • a transmit buffer may transmit isochronous packets according to a range of time slots, or alternatively as network resources permit.
  • the exemplary apparatus 600 of FIG. 6 also has one or more receive buffers 612 for receiving isochronous data via at least one of the network interfaces.
  • the illustrated receive buffer is a First-In-First-Out (FIFO) buffer configured to receive a packets in a sequential fashion, although it will be recognized by those of ordinary skill that other buffer configurations may be used consistent with the invention.
  • FIFO First-In-First-Out
  • the device may also include a user interface subsystem that includes any number of well-known I/O mechanisms including, without limitation: a keypad, touch screen (e.g., multi-touch interface), LCD display, backlight, speaker, and/or microphone.
  • a user interface subsystem that includes any number of well-known I/O mechanisms including, without limitation: a keypad, touch screen (e.g., multi-touch interface), LCD display, backlight, speaker, and/or microphone.
  • the device may additionally comprise various Audio/Visual (AV) apparatus.
  • AV Audio/Visual

Landscapes

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

Abstract

Methods and apparatus for efficiently servicing isochronous streams (such as media data streams) associated with a network. In one embodiment, an Isochronous Cycle Manager (ICM), receives multiple independent streams of packets that include isochronous packets arriving according to different time bases (e.g., where each stream has a different time base). The packets are sorted by the ICM into a buffering mechanism according to their required presentation time. Additionally the ICM calculates a launch time for each packet. The NIC transmits the packets from the queue according to an access scheme, such as a time division multiplexed (TDM) scheme where each of a plurality of cycles is subdivided into time slots. During appropriate time slots, the NIC transmits the packets in chronological order, as read out of the buffering mechanism.

Description

    COPYRIGHT
  • A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.
  • BACKGROUND OF THE INVENTION
  • 1. Field of Invention
  • The present invention relates generally to the field of computerized devices, networks and buses. More particularly, in one exemplary aspect, the present invention is directed to efficiently servicing isochronous streams associated with a network.
  • 2. Description of Related Technology
  • Certain types of multimedia content processing are based on isochronous data delivery protocols. The term “isochronous” generally refers to processes where data must be delivered within certain time constraints for use. For example, as used in streaming multimedia, an isochronous transport mechanism ensures that data is delivered with enough time to render audio and video to provide smooth, uninterrupted content to the user or consumer. Data which is not delivered in time for rendering cannot be used, and is generally ignored.
  • In contrast, the term “asynchronous” refers to processes where data transfer does not have a guaranteed time constrained delivery. Asynchronous delivery is also sometimes referred to as “best effort delivery”; each user receives the “best effort” the network can support, based on existing traffic conditions and requirements.
  • IEEE Std. 802.3 and IEEE Std. 802.11 network infrastructures have been designed to support asynchronous data delivery. For example, typical IEEE Std. 802.3 compliant Ethernet network interface controllers (NICs) operate on a First-In-First-Out (FIFO) basis. Part of the reason for this is that FIFO operation is well suited for asynchronous data delivery over flexible network topologies. Consider a node with M sources and N destinations (where M and N may be different); each packet received from each of the M sources is sent in turn to the next node. By chaining multiple “hops” together, the network topology can be made arbitrarily complex. This feature is especially useful for networks which experience constant flux or intermittent failures because packet routing can be changed on-the-fly to resolve network obstructions.
  • In contrast, IEEE Std. 1394 compliant systems have been designed to support isochronous data delivery. For example, IEEE Std. 1394 compliant systems reserve an amount of bandwidth for each isochronous channel. The reserved bandwidth is further allocated for each node, from source to destination. In this fashion, each source is isolated from the behavior of other sources, and the overall transmission delay between source and destination is fixed and predictable.
  • Recent improvements to existing network technologies (e.g., IEEE Std. 802.3 and IEEE Std. 802.11 type networks, etc.) have incorporated some isochronous data delivery capabilities. For example, existing Ethernet NICs can transmit packets at designated launch times, which can support delivery of isochronous data at regular time intervals.
  • However, IEEE Std. 802.3 (and IEEE 802.11 Std.) type networks have very loose time synchronization which can create problems with launch time guarantees. In particular, since each data stream has its own time base, combining multiple streams can fill the FIFO with out-of-order packets. Out-of-order packets will be dropped or delivered too late, with using the existing launch time guarantees. Consequently, existing devices cannot support multiple isochronous data streams.
  • Accordingly, incipient research is directed to further improvements for delivery of isochronous data content within existing network infrastructures
  • SUMMARY OF THE INVENTION
  • The present invention satisfies the foregoing needs by providing, inter alia, methods and apparatus for efficiently servicing isochronous streams for a data network.
  • In one aspect of the present invention, a method of managing a plurality of isochronous processes is disclosed. In one embodiment, the method includes receiving multiple isochronous data streams, each isochronous data stream includes a plurality of isochronous data packets, where each packet has a presentation time; sorting each isochronous data packet according to the presentation time; calculating a launch time for each isochronous data packet of the multiple isochronous data streams; and transmitting the isochronous data packets according to the launch time.
  • In one variant, the method additionally includes receiving asynchronous data packets; and transmitting the asynchronous data packets. In one exemplary configuration, the asynchronous data packets are sorted with the isochronous data packets. In another exemplary configuration, a first portion of bandwidth is reserved for isochronous data packets, and a second portion of bandwidth is reserved for asynchronous data packets.
  • In another variant, the act of sorting includes storing the isochronous data packets into a ring buffer according to presentation time.
  • In yet another variant, at least one of the multiple isochronous data streams comprises video and/or data.
  • In still other variants, at least one of the multiple isochronous data streams have different time base. In one such exemplary implementation, the act of calculating comprises adjusting the launch time of the isochronous data packets according to a master time base.
  • In a second aspect of the invention, a method for reconstructing a plurality of isochronous processes is disclosed. In one embodiment, the method includes receiving one or more unreserved time slots of packet data, the time slot comprising a plurality of packets transmitted in chronological order. At least one packet has a presentation time associated therewith, and the method further includes extracting the at least one packet, and presenting the at least one packet at the associated presentation time.
  • In a first variant, the at least one packet includes an isochronous data packet.
  • In a second variant, at least another packet includes an asynchronous data packet.
  • In a third variant, only a subset of packets have a presentation time associated therewith.
  • In a fourth variant, the subset of packets are stored in order of arrival into a First-In-First-Out (FIFO) buffer.
  • In some embodiments, the at least one packet includes video data. Alternately, the at least one packet includes one or more subpackets of data. In one such example, the one or more subpackets of data include a video subpacket and an audio subpacket.
  • In a third aspect of the invention, a network interface apparatus is disclosed. In one embodiment, the network apparatus includes: a transmission queue, the transmission queue configured to transmit a plurality of slots of data at a designated time; a data interface configured to receive a plurality of isochronous data streams, the plurality of isochronous data streams having one or more different time references; a network interface clock, the network interface clock configured to generate a designated time reference; and at least one controller. The at least one controller is configured to: extract one or more data packets from the plurality of isochronous data streams; sort the one or more data packets based at least in part on a presentation time; calculate a launch time for each of the one or more data packets; and transmit the slots of data at the calculated launch time.
  • In one variant, the calculated launch time is based at least in part on a difference between the one or more different time references and the designated time reference.
  • In other variants, the sorted one or more data packets are assigned to a slot of data.
  • In a fourth aspect of the invention, a method of processing isochronous data streams is disclosed. In one embodiment, the method includes: receiving multiple isochronous data streams, each isochronous data stream comprising a plurality of isochronous data packets; determining a sorting criterion for the multiple isochronous data streams; sorting at least a portion of the isochronous data packets in each stream according to the determined sorting criterion to produce a sorted order of data packets; and transmitting the isochronous data packets according to the sorted order.
  • In a fifth aspect of the invention, a computer readable medium for processing isochronous data streams is disclosed.
  • In a sixth aspect of the invention, an endpoint device for processing isochronous data streams is disclosed.
  • In a seventh aspect of the invention, a node device for processing isochronous data streams is disclosed.
  • Other features and advantages of the present invention will immediately be recognized by persons of ordinary skill in the art with reference to the attached drawings and detailed description of exemplary embodiments as given below.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a functional block diagram illustrating one exemplary prior art packet-switched network.
  • FIG. 2 is a logical flow diagram illustrating one embodiment of a generalized method for scheduling multiple independent chronological streams of packets according to the invention.
  • FIG. 3 is a graphical representation of one exemplary technique for interleaving multiple independent chronological streams of packets in accordance with the present invention.
  • FIG. 4 is a graphical representation of one exemplary technique for deinterleaving a chronological stream of packets in accordance with the present invention.
  • FIG. 5 is a logical flow diagram illustrating one exemplary embodiment of a method for scheduling a time division multiplexed (TDM) packing scheme, according to the present invention.
  • FIG. 6 is a block diagram of an exemplary apparatus useful for implementing the methods of the present invention.
  • DETAILED DESCRIPTION OF THE INVENTION Overview
  • The present invention provides, inter alia, methods and apparatus for efficiently servicing isochronous streams, such as may be used in a data network. As described in greater detail herein, the invention leverages incipient improvements in extant controller architectures (e.g., Ethernet network interface controllers (NICs)) by adding scheduling capabilities to various components of the network. Specifically, in one embodiment, the scheduling algorithms interleave and/or deinterleave multiple independent chronological streams of packets by calculating a launch time for each packet (based at least in part on the packet's presentation time). Scheduling each packet for transmission ensures that the packets are transmitted in their proper presentation sequence.
  • In one implementation, an Isochronous Cycle Manager (ICM) receives multiple isochronous streams of packets, where each packet has a required presentation time. The ICM generates an interleaved output stream of packets by pre-sorting the packets in accordance with the presentation time base. Each packet of the interleaved output stream is further assigned a launch time and queued for transmission. Thereafter, the network interface controller (NIC) transmits the queue of packets, where each packet is transmitted according to launch time. In an alternate implementation, the ICM receives an isochronous stream of packets, and deinterleaves the stream into multiple streams of packets that are pre-sorted according to the presentation time base, assigned a launch time, and transmitted according to launch time.
  • Since existing network technologies (e.g., IEEE Std. 802.3 and IEEE Std. 802.11 type networks, etc.) do not have strict time synchronization requirements, the ICM of the exemplary embodiment considers multiple factors when calculating launch time. By pre-sorting packets for transmission, each isochronous data stream can be delivered efficiently (i.e., without network resource under-utilization) within the appropriate time restriction(s). For example, in one variant, a device can handle heterogenous mixtures of asynchronous and isochronous packets. Still other variants may consider parameters such as packet priority, packet type, etc.
  • Various combinations of the interleaving and deinterleaving of packets are also described. For example, in one variant, a device can support any arbitrary mapping of M isochronous streams to N isochronous streams.
  • Detailed Description of Exemplary Embodiments
  • Exemplary embodiments of the present invention are now described in detail. While these embodiments are discussed primarily in terms of the IEEE 802.3 family of Ethernet network standards (and the IEEE 802.11 family of Wireless Local Area Network (WLAN)), it will be recognized by those of ordinary skill that the present invention is not in any way limited to the foregoing network technologies. In fact, various aspects of the present invention can be adapted for use in any packet-based network that is capable of enforcing presentation time requirements for packets.
  • As used herein, the term “network” refers without limitation to any network configured to transfer data as suitably-sized groupings called packets. Packet networks can deliver streams of data (composed of sequences of packets) to a community of devices. During transfer, packets are buffered and queued, and may experience variable delays and throughput depending on the traffic load in the network. Common examples of packet-based networks include the Internet (i.e., the global system of interconnected computer networks), as well as privatized internets, and intranets.
  • As used herein, the term “source” refers to a device or interface configured to packetize information for transfer via a packet-based network. As used herein, the terms “destination”, “target”, and/or “sink” refer without limitation to a device or interface configured to extract information from a packet. Moreover, as used herein the term “endpoint” generally refers without limitation to the portion of a device that is a “source” and/or “destination” of information in a communication flow between devices. Similarly, as used herein, a “node” refers without limitation to a device which receives packets, and forwards the packets to another device.
  • These definitions should in no way be considered limiting; e.g., a client device or other entity may or may not include a logical or physical “endpoint” and/or “node” within the network. It is further appreciated that a device may (and generally will) simultaneously implement source, destination and node functionalities; the foregoing distinctions being made only for the purposes of clarifying various aspects of the present invention.
  • Furthermore, while some embodiments are shown in the context of a wired data bus or connection, the invention is equally applicable to wireless alternatives or interfaces such as, without limitation, WLANs such as IEEE Std. 802.11 wireless networks, WMANs such as IEEE Std. 802.16 wireless networks, personal area networks (PANs), Bluetooth™, infrared, and optical communication links.
  • Prior Art Operation
  • FIG. 1 illustrates one exemplary prior art packet-based network 100. In the illustrated embodiment, the network 100 includes a number of sources (M) 102 in communication with a number of sinks (N) 104 via a network of nodes 106. The packet-based network 100 has a network time base 110 associated therewith.
  • The network 100 is composed of a collection of nodes connected to a collection of endpoints. Common examples of endpoints include, but are not limited to, personal computers (PCs), whether desktop, laptop, handheld or otherwise, network media devices (such as digital settop boxes), and mobile devices such as smartphones, PDAs, digital and video cameras, personal media devices (PMDs) (such as MP3 players, printers or rendering devices), or any combinations of the foregoing. Typically, nodes include, but are not limited to, servers, computers, routers, firewalls, gateways, etc.
  • Incipient modifications to Ethernet network interface controllers (NICs) have incorporated so-called “launch time” guarantees (i.e., the NIC can transmit a packet at a specified time). Referring back to FIG. 1, a first source 102A can connect via a collection of nodes 106 to a first sink 104A. Accordingly, the first source and the first sink can establish a guaranteed isochronous connection within those time constraints.
  • Unfortunately, existing Ethernet infrastructure does not have stringent time synchronization requirements. For example, Ethernet network time 110 can vary by as much as ten milliseconds (10 ms) between devices, whereas packet transmission can occur in only a fraction of that time. Consequently, the NIC (which has a much higher time resolution) cannot optimally determine transmission times based only on packet presentation time.
  • Method
  • Referring now to FIG. 2, one embodiment of a generalized method 200 for efficiently servicing isochronous streams in a network according to the invention is illustrated. Various aspects of the present invention leverage the incipient improvements in isochronous data delivery by pre-sorting isochronous data for transmission. Specifically, in one embodiment, an Isochronous Cycle Manager (ICM) interleaves and/or deinterleaves multiple independent chronological streams of packets based on presentation time, and one or more additional considerations. The ICM scheduler can handle a wide population of presentation requirements (e.g., streams which have stringent requirements can be serviced with streams that have loose requirements).
  • At step 202 of the method, a device or process receives one or more input stream(s), each stream having a plurality of packets. In one exemplary embodiment, the streams include both isochronous and asynchronous data streams. For example, in one implementation, an Ethernet interface is configured to service a first portion (isochronous data traffic), and a second portion (asynchronous data traffic). It will be appreciated that the method 200 is in no way limited to two (i.e., first and second portions); for instance, three streams might be used (such as one asynchronous and two isochronous, etc.) Various other combinations/permutations will be recognized by those of ordinary skill given the present disclosure.
  • Additionally, these first and second portions may be further subdivided by type or another criterion, such as priority. For example, a “Class A” and “Class B” isochronous data traffic might be used. One such implementation may support e.g., up to (but not exceeding) seventy five percent (75%) isochronous traffic, which is subdivided into Class A and Class B (where Class A traffic is always prioritized over Class B traffic), and twenty five percent (25%) asynchronous traffic.
  • Common examples of isochronous data include video data, audio data, game content (e.g., player position, game synchronization information, etc.), and conference content (e.g., mouse movements, key presses, etc.) In fact, any data having temporal relevance may be transported as isochronous data (e.g., environment, presence, location, time, etc.).
  • Moreover, it is further appreciated that each isochronous stream may be composed of packets, where each packet may be further subdivided into subpackets. Such implementations are common where multiple types of data are bundled together for a common playback time. For example, audio and video data that are played together can be bundled together in the same packet. In some other implementations, data may be bundled together where the data must be decoded together, but are separated for logical reasons (e.g., parity, error checking, etc.)
  • The input streams may be received from the same device, or alternately may be received from multiple different devices. For example, several source endpoints may generate multiple streams that are aggregated together at a destination endpoint. In other examples, a single source endpoint may generate multiple streams (e.g., multiple applications running simultaneously), for one or more destination endpoints.
  • In one exemplary embodiment, the isochronous data includes: (i) a header describing one or more isochronous data, (ii) the one or more isochronous data, and (iii) error checking information. Common examples of information that may be included within the header include: (i) source address, (ii) destination address, (iii) presentation or playback time, (iv) packet identifier, etc. The header may comprise other information such as: (i) path information (e.g., intermediate node addresses), (ii) length of the packet, (iii) total length of the stream, (iv) encoding type, (v) codec information, (vi) Quality of Service (QoS) or priority information, etc.
  • At step 204, the device sorts the received packets according to their presentation time. In one embodiment, the device received data packets from multiple chronological sources, and interleaves them into chronological order. While each source provides a chronological sequence of packets, packets supplied from independent sources may not be chronological (due to discrepancies in device timing, network synchronization issues, etc.).
  • In one exemplary embodiment, the packets are sorted into a buffering mechanism by presentation time. One example of a suitable buffering system is a so-called “ring” buffer. A simple ring buffer is constructed of a memory with a read pointer, where the read pointer is configured to increment, and where the pointer “rolls over” to the first address after the last address. Each packet is written into the ring buffer according to the order of presentation. Other common examples of suitable memory structures include normal buffers and queues, linked lists, stacks, etc.
  • In one variant, the packets are additionally interspersed with other packet types. Such other packet types may include asynchronous packets (“best effort”), isochronous packets of a different priority (e.g., Class A, Class B), etc. For example, in one such scheme, the buffer is populated with up to a first percentage (e.g., seventy five percent (75%)) isochronous packets, and a second percentage (e.g., twenty five percent (25%)) asynchronous packets. In some implementations, the packets are further divided into priority classes, so that the allotments to isochronous and asynchronous data are necessarily filled with higher priority packets before adding lower priority packets.
  • The buffer may further include priority information; such priority information may be based on: data type (e.g., Class A, Class B, etc.), temporal considerations (e.g., priority is increased as the packet gets closer to the desired presentation time), source consideration (e.g., the packet was sent from a high priority source, etc.)
  • In yet other variants, the buffer may include information about the packetized data. For example, such information may include a media stream identifier, a source identifier, a destination identifier, a media type identifier, etc. In addition, implementations which subdivide packets into subpackets may further itemize the subpacket information, which may include similar information (e.g., a media stream identifier, a source identifier, a destination identifier, a media type identifier, etc.)
  • At step 206, the device calculates each packet's launch time. In one exemplary embodiment, the device reads the presentation time of the packet from its header, and calculates a launch time of the packet according to one or more considerations. Such considerations may include, but are not limited to: (i) the device's own master time, (ii) the network time, (iii) the recipient device's master time, (iv) the network interface controller (NIC) time, path delay, and/or (v) packet characteristics (e.g., packet priority, packet type, etc.).
  • Common examples of a calculated launch time include, but are not limited to: (i) an assigned time slot, (ii) a range of acceptable time slots, (iii) an assigned transmission time, and (iv) a range of acceptable transmission times. In some embodiments, it may be acceptable, or even desired, that certain packets are not assigned a launch time (e.g., low priority packets, asynchronous packets, etc.). In one implementation, the calculated launch time corresponds to a time base of a network interface controller (NIC).
  • As a brief aside, Ethernet does not have stringent time synchronization requirements (the network time base can vary by as much as ten milliseconds (10 ms) between devices). However, the aforementioned modified Ethernet network interface controllers (NICs) have internal clocking which is significantly faster; exemplary Ethernet NICs can transmit in time slots which are accurate to within one microsecond (1 μs). Furthermore, it is not uncommon for networked devices to also maintain an internal master time which can be accurate to several nanoseconds (ns).
  • EQN. 1 and EQN. 2 provide exemplary equations for converting from one time base to another time base. EQN. 1 can be used where both the device time base (td), and the source time base (ts) have the same clock rate, but may have an offset in time:

  • T′=T+τ,  (EQN. 1)
  • where:
  • T′=the adjusted presentation time for the device time base (td);
  • T=the presentation time for the source time base (ts); and
  • τ=td−ts.
  • EQN. 2 can be used where both the device time base (td), and the source time base (ts) have a fixed proportionate relationship, even though the clock rates differ:

  • T′=kT+T 0,  (EQN. 2)
  • where:
  • T′=the adjusted presentation time for the device time base (td);
  • T=the presentation time for the source time base (ts);
  • k=ts/td; and
  • T0=an offset value.
  • Other differences in time base may require more complicated schemes. For example, some time bases may not be continuous (i.e., may start and stop), may use non-constant clock rates (i.e., 1× rate, 2× rate, 4× rate, etc.), and/or may need to compensate for clock artifacts (e.g., excessive jitter, clock drift, etc.). However, it is appreciated that a wide range of conversion algorithms exist in the related arts for converting times from one clock domain to another clock domain.
  • More generally, the method of the embodiment of FIG. 2 calculates launch times for each packet according to one time base for each output stream. Consequently, a device receiving a first number of input streams and generating a second number of output streams will adjust each of the packets according to their respective output time bases. In one embodiment, each time base is a network interface controller (NIC) clock (e.g., a crystal oscillator within the NIC). For example, a device receiving two (2) input streams and generating one (1) output stream will calculate launch times for each packet received from the two (2) input streams, for the NIC. Similarly, a device receiving three (3) input streams and generating two (2) output streams will calculate launch times for each packet received from the three (3) input streams, corresponding to the appropriate time base for the desired output streams (e.g., a packet destined for the first output stream time will have launch times corresponding to a first NIC a packet destined for the second output stream time will have launch times corresponding to a second NIC). In simplified embodiments, the output time bases may be based on a single master time base (where a single NIC transmits multiple streams, where multiple NICs share a time base, and/or where multiple NIC time bases are based on a master clock).
  • Furthermore, while discussed above with respect to packet formats, it is further appreciated that packet formats composed of multiple subpackets may be divided into constituent subpackets, recombined, etc. For instance, a device receiving one (1) input stream consisting of packets containing audio and video subpackets can be divided into: (i) an audio stream consisting of packets containing audio subpackets that have been re-timed for an audio time base, and (ii) a video stream consisting of packets containing video subpackets, that have been re-timed for a video time base. These time bases may be the same or different.
  • Moreover, in one exemplary embodiment, the presentation time is preserved throughout transfer (i.e., the launch time has no impact on presentation time), or that the presentation time indicated in the packet is the same between the source and destination endpoint. However, it is appreciated that in some embodiments, the presentation times of the packets can be adjusted. Similarly, some embodiments may add or update a metadata field with the presentation time information.
  • At step 208 of the method 200, the device generates the one or more output stream(s) based on the calculated packet launch times. In one embodiment, the device has previously negotiated, or was assigned a network resource, for transmitting buffered data. Common examples of a network resources include time slots, frequency bands, spreading codes, time-frequency resources, etc. In other embodiments, the resources are arbitrated during operation, in some cases, with acceptable levels of collision.
  • Transmission of each packet over the network resource is performed by reading the packets out of the buffer, and transmitting them on the network resource. Since the packets have been stored within the buffer in the exemplary embodiment with a calculated launch time, the resulting stream will be properly ordered for transmission. In some situations, where packets or resources are dropped or where the source and destination endpoint lose synchronization, it may be necessary to increment and/or decrement the reading or writing of the buffer accordingly. In one exemplary embodiment, a very simple processing engine of the network interface controller (NIC) can execute transmission. In some embodiments, the NIC can perform direct memory access (DMA) type transactions, transmitting packets out of the buffer without further supervision (e.g., unmoderated by the application processor, etc.)
  • In one implementation of the present invention, each packet is assigned a slot time during which the packet can be transmitted. In alternate implementations, packets are assigned slot times as slots are available, the packets are transmitted according to presentation order.
  • In some embodiments, the device may not be assigned a sufficient number of time slots to transmit all of its data. “Stale” isochronous packets (i.e., isochronous packets which have not or cannot meet their delivery time requirements) can generally be discarded; however, asynchronous packets can be delivered at the next opportunity for spare bandwidth since these packets do not have time requirements. In some cases, postponing asynchronous packet delivery and/or skipping stale isochronous packets may require that the buffer is reordered.
  • In yet other embodiments, the buffers for isochronous and asynchronous data are separated, to prevent the asynchronous data from overwriting asynchronous data.
  • Example Operation
  • Referring now to FIG. 3, one exemplary scheme for interleaving multiple independent chronological streams of packets is graphically illustrated. As shown, a first stream includes an isochronous series of packets arriving according to a first time base (t1), and a second stream includes an isochronous series of packets arriving according to a second time base (t2). The packets are aggregated by an Isochronous Cycle Manager (e.g., ICM), and transmitted according to a third time base (t3). The time bases are different, and not shown to scale. More specifically, while each stream provides a sequence of packets in chronological presentation time order; the packets from multiple streams may not arrive in proper chronological presentation time order. For example, as shown, packet C arrives after packet J, even though packet C has a presentation time before packet J.
  • The ICM receives the first and second stream of packets, where the received packets are sorted, and then inserted into a buffering mechanism (e.g., ring buffer) according to their required presentation time. Additionally, the ring buffer also contains a mapping between the stream (first, second), and the slots assigned to that stream (if multiple are available).
  • In one embodiment, the Isochronous Cycle Manager (e.g., ICM) operates according to a time division multiplexed (TDM) scheme, where each of a plurality of cycles is subdivided into time slots. In one implementation, each cycle consists of one-hundred twenty five (125) time slots, where each time slot is one microsecond (1 μs) in duration. The ICM negotiates, or alternatively is assigned) time slots to transmit during each cycle. In one embodiment, the ICM calculates and assigns each packet a corresponding launch time.
  • During execution, a cycle timer counts a designated multiple of the isochronous cycle time period; each time that the timer fires, the designated multiple cycles worth of data are transferred to the NIC. The launch times of each packet correspond to the NIC's time domain. The NIC subsequently transmits each of the packets in accordance with the calculated launch times.
  • The reverse process is shown in FIG. 4, where one exemplary scheme for deinterleaving an aggregated chronological stream of packets according to the invention is illustrated. As shown, an input stream includes an isochronous series of packets according to a first time base (t1). The packets are deinterleaved (separated) into the first and second constituent streams by the Isochronous Cycle Manager (e.g., ICM), and transmitted according to the second and third time bases respectively (t2, t3).
  • The ICM receives the input stream of packets, and splits the received packets into first and second First-In-First-Out (FIFO) buffers, with launch times configured for the first and second NIC hardware respectively. The first buffer is transferred to a first NIC according to the second time base in order to generate the first isochronous output data stream. Similarly, the second buffer is transferred to a second NIC according to the third time base, thereby generating the second isochronous output data stream.
  • During execution, a cycle timer for each NIC counts a designated multiple of the isochronous cycle time period; each time that the timer fires, the designated multiple cycles worth of data are transferred to the respective NIC. Each NIC subsequently transmits each of the packets in accordance with the calculated launch times. In some embodiments, the NICs share a common time base; however, other embodiments may have a distinct time base for each NIC.
  • Referring now to FIG. 5, one exemplary embodiment of a method for scheduling a time division multiplexed (TDM) packing scheme according to the present invention is illustrated.
  • Initially at step 502, the ICM negotiates or allocates time slots to stream the isochronous data stream (and deallocates time slots when streams are finished). The ICM (or another entity/process acting as a proxy) calculates the required number of slots to transmit all the data for the cycle. For example, the number of microseconds (μs) or time slots necessary to transmit the collected data is tallied, and rounded up to the nearest increment. In some implementations, the required number of slots must additionally be contiguous. Contiguous slots can improve overall network overhead by reducing switching overhead, arbitration overhead, etc. However, in some embodiments, non-contiguous slots may be used e.g., where additional flexibility is required, and/or where certain services can be prioritized, etc. For example, in one such embodiment, best-effort delivery or even low priority isochronous packets can be delivered when slots are available (such as during gaps between other high priority traffic).
  • At step 504, a timer counts down a time interval (e.g., one or more multiples of the isochronous cycle time period), during which time a buffer collects data from the input streams. In one implementation, the buffer continues to collect data until a full cycle of data has been buffered.
  • The collected data is sorted by presentation time (step 506), and a launch time is calculated for each packet (step 508). For example, each packet is assigned a time slot for transmission in the NIC's time base (e.g., adding an offset, or scaling by a scale or difference factor). In this manner, even if the input stream packets arrive out of sequence, the output of the node has been sorted into appropriate presentation time order, and assigned a launch time (according to that order).
  • It will be appreciated that other sorting orders and/or intervals may be applied consistent with the invention. For instance, one sorting criterion may comprise sorting based on packet type (e.g., where Emergency Medical Services (EMS) type packets may be granted a higher priority, etc.)
  • At step 510, the time slots are provided to the NIC for transmission. This greatly reduces processor burden. In some embodiments, the NIC can perform direct memory access (DMA) type transactions, transmitting packets out of the buffer according to their calculated launch time.
  • In one embodiment, the transmitted time slots retain the sorted order; i.e., packets are transmitted in the order of their presentation time. Thus, the packet which is to be presented next is always transmitted in the first available time slot preceding presentation.
  • Unpacking the TDM packed stream is simpler. In one embodiment, each time slot is inspected for packets; when a packet is extracted, it is routed to the appropriate buffer queue (e.g., a queue for each stream). Since the packets arrive in the proper chronological order (e.g., presentation order), the queues are correctly ordered for subsequent use or processing, such as audio/video playback in the illustrated example.
  • While the packets are chronologically ordered, in some cases packets may be dropped, corrupted, etc. Accordingly, in some embodiments, the packets may be further processed or checked; e.g., to facilitate lost packet identification or recovery, decryption. For example, data streams which can tolerate some packet loss may utilize a running packet count, to determine if a packet has been dropped. Similarly, error checking routines (e.g., Cyclic Redundancy Check (CRC)) may be executed to identify corrupted packets. Still other embodiments may recover various packet errors, based on e.g., parity bits, Forward Error Recovery (FEC) techniques (viterbi coding, turbo coding, etc.)
  • Exemplary Apparatus
  • FIG. 6 illustrates one exemplary embodiment of an apparatus 600 useful for implementing various methods of the present invention. The apparatus of FIG. 6 includes a processor subsystem 602 such as a digital signal processor, microprocessor, field-programmable gate array, or plurality of processing components mounted on one or more substrates. The processing subsystem may also include an internal cache memory. The processing subsystem is in communication with a memory subsystem 604 including memory which may for example, comprise SRAM, Flash and SDRAM components. The memory subsystem may implement one or a more of direct memory access (DMA) type hardware, so as to facilitate data accesses as is well known in the art. The memory subsystem contains computer-executable instructions which are executable by the processor subsystem.
  • The processor subsystem 602 is further configured to track a master time base 603. This master time base may be derived from an internal clock such as an internal oscillator circuit (e.g., Voltage Controlled Temperature Controlled Crystal Oscillator (VCTCXO), etc., or alternately may be reported or received from an external device or entity, such as a Global Positioning System (GPS), IEEE Std. 1588 (Precision Time Protocol), etc.
  • Additionally, the apparatus includes a communications controller (e.g., NIC) 606, which manages communications between endpoints. The NIC is in operative communication with one or more network interfaces 608. The network interfaces are further configured to transmit and/or receive packetized traffic. In one embodiment, each network interface is associated with a corresponding time base. Each time base may or may not be further synchronized with the other time bases.
  • The NIC subsystem 606 further includes an internal time base 609. This NIC time base may be derived from an internal clock such as an internal oscillator circuit (e.g., Voltage Controlled Temperature Controlled Crystal Oscillator (VCTCXO), Voltage Controlled Crystal Oscillator (VCXO), Crystal Oscillator (VCO), etc.
  • In one exemplary embodiment, the one or more network interfaces are Ethernet compliant interfaces (IEEE Std. 802.3). In alternate embodiments, the one or more network interfaces are configured for use with a serial bus protocol. Common examples of such serial bus protocols useful with the invention include but are not limited to: Universal Serial Bus (USB), FireWire (IEEE Std. 1394), High Definition Multimedia Interface (HDMI), Digital Visual Interface (DVI), and DisplayPort.
  • In one exemplary embodiment, the network interfaces are time division multiplexed (TDM). During TDM operation, the network interface transmits and/or receives packets only during assigned and/or negotiated time slots of a cycle. The transmission/reception may be implemented for example as full- or half-duplex.
  • In another embodiment, the network interfaces are frequency division multiplexed (FDM), where the network interface is configured to transmit and/or receive packets via a specified frequency band.
  • In yet other embodiments, the network interfaces are code division multiplexed, which are configured to transmit and/or receive packets using a spreading factor. Orthogonal Frequency Division Multiplexing may also be used, which specifies both time and frequency resources.
  • Yet other medium access schemes may be used consistent with the invention.
  • As previously described, packetized traffic is data which has been formatted into discrete units or packets of data. Each packet includes at least routing information and payload. The routing information provides e.g., source and destination addresses, error detection codes, and sequence information. Additionally, isochronous data packets contain presentation information, where the presentation information is specific to the packet's time base.
  • In some embodiments of the present invention, the packetized traffic may provide various guarantees for reliability. For example, a “reliable” service may provide explicit acknowledgment (ACK) or non-acknowledgement (NAK), whereas “unreliable” service may not provide any feedback as to transmission success or failure. Moreover, it is further recognized that packetized traffic encompasses unreliable “datagrams” (such as those used in real-time traffic protocols such as Real Time Protocol (RTP) and User Datagram Protocol (UDP)), as well as more specialized audio/visual formats (such as Packetized Elementary Stream (PES)).
  • Packetized traffic can consist of varying portions of asynchronous and isochronous data. In one exemplary embodiment of the invention, the packetized traffic is a mixture of isochronous packets and asynchronous packets, where at least a portion of the packets are further prioritized. Such prioritization can be in accordance with a given proportion (e.g., seventy five percent (75%) isochronous, twenty five percent (25%) asynchronous), which may be fixed or variable as a function of time or other parameter(s). Alternately, such prioritization may be based on data class (e.g., Class A, Class B), or according to various requirements for quality of service (QoS).
  • The exemplary apparatus 600 of FIG. 6 has one or more transmit buffers 610 for transmitting isochronous data via at least one of the network interfaces. Each transmit buffer is further configured to transmit its contents in an orderly sequential fashion. The transmit buffer may be for example a ring buffer of the type previously described herein. Alternatively, the buffer may have finite depth, where the depth is commensurate with an allowed transmission capacity. During such transmission, the buffer is read to completion, and rewritten for the next available transmission.
  • During operation, received isochronous packets are re-timed according to the NIC master time base 609 (or the time base associated with the transmit queue). The isochronous packets are sorted according to e.g., presentation time, into the transmission buffer. Each packet's launch time is determined, the resulting buffer of packets is properly ordered for timely transmission.
  • In some variants, only a portion of the buffer can be filled with isochronous data, the remaining portion is filled with asynchronous data. Alternatively, the buffer does not distinguish between isochronous and asynchronous data. In such cases, the data may be further prioritized. For example, in one such prioritization scheme, asynchronous data can be added in any proportion, as long as the higher priority data (e.g., isochronous data) is serviced first. In yet other variants, isochronous data and asynchronous data are transmitted from different memory buffers.
  • The transmit buffers of the apparatus of FIG. 6 are further configured to transmit a packet at a designated launch time. In some systems the designated launch time may acceptable within a design tolerance (such tolerances can be imposed by hardware limitations, network limitations, application limitations, etc.) In alternate implementations, the transmit buffers are configured to transmit packets via a designated network resource; e,g, a time slot, frequency band, spreading code, etc.
  • The transmit buffers may also be configured to transmit packets within a range of time and/or network resources. For example, a transmit buffer may transmit isochronous packets according to a range of time slots, or alternatively as network resources permit.
  • The exemplary apparatus 600 of FIG. 6 also has one or more receive buffers 612 for receiving isochronous data via at least one of the network interfaces. The illustrated receive buffer is a First-In-First-Out (FIFO) buffer configured to receive a packets in a sequential fashion, although it will be recognized by those of ordinary skill that other buffer configurations may be used consistent with the invention.
  • The device may also include a user interface subsystem that includes any number of well-known I/O mechanisms including, without limitation: a keypad, touch screen (e.g., multi-touch interface), LCD display, backlight, speaker, and/or microphone. Moreover, in some embodiments, the device may additionally comprise various Audio/Visual (AV) apparatus.
  • It will be recognized that while certain aspects of the invention are described in terms of a specific sequence of steps of a method, these descriptions are only illustrative of the broader methods of the invention, and may be modified as required by the particular application. Certain steps may be rendered unnecessary or optional under certain circumstances. Additionally, certain steps or functionality may be added to the disclosed embodiments, or the order of performance of two or more steps permuted. All such variations are considered to be encompassed within the invention disclosed and claimed herein.
  • While the above detailed description has shown, described, and pointed out novel features of the invention as applied to various embodiments, it will be understood that various omissions, substitutions, and changes in the form and details of the device or process illustrated may be made by those skilled in the art without departing from the invention. The foregoing description is of the best mode presently contemplated of carrying out the invention. This description is in no way meant to be limiting, but rather should be taken as illustrative of the general principles of the invention. The scope of the invention should be determined with reference to the claims.

Claims (25)

1. A method of managing a plurality of isochronous processes, the method comprising:
receiving multiple isochronous data streams, each isochronous data stream comprising a plurality of isochronous data packets, each packet having a presentation time associated therewith;
sorting each isochronous data packet according to the presentation time;
calculating a launch time for each isochronous data packet of the multiple isochronous data streams; and
transmitting the isochronous data packets according to the launch time.
2. The method of claim 1, additionally comprising:
receiving asynchronous data packets; and
transmitting the asynchronous data packets.
3. The method of claim 2, additionally comprising sorting the asynchronous data packets with the isochronous data packets.
4. The method of claim 2, wherein a first portion of transmission bandwidth is reserved for isochronous data packets, and a second portion of transmission bandwidth is reserved for asynchronous data packets.
5. The method of claim 1, wherein the act of sorting comprises storing the isochronous data packets in a ring buffer according to presentation time.
6. The method of claim 1, wherein at least one of the multiple isochronous data streams comprises video data.
7. The method of claim 6, wherein at least one of the multiple isochronous data streams comprises audio data.
8. The method of claim 1, wherein at least one of the multiple isochronous data streams has a time base that differs from a master time base.
9. The method of claim 8, wherein the act of calculating comprises adjusting the launch time of the isochronous data packets according to the master time base.
10. A method of reconstructing a plurality of isochronous processes, the method comprising:
receiving one or more unreserved time slots of packet data, the one or more unreserved time slots comprising a plurality of packets transmitted in chronological order, at least one of the plurality of packets having a presentation time associated therewith;
extracting the at least one packet; and
presenting the at least one packet at the associated presentation time.
11. The method of claim 10, wherein the at least one packet comprises an isochronous data packet.
12. The method of claim 10, where at least one other packet of the plurality of packets comprises an asynchronous data packet.
13. The method of claim 10, wherein only a subset of the plurality of packets have a presentation time associated therewith.
14. The method of claim 13, additionally comprising storing the subset of the plurality of packets in order of arrival into a First-In-First-Out buffer.
15. The method of claim 10, wherein the at least one packet comprises video data.
16. The method of claim 10, wherein the at least one packet comprises one or more subpackets of data.
17. The method of claim 16, wherein the one or more subpackets of data comprise a video subpacket and an audio subpacket.
18. A network interface apparatus, comprising:
a transmission queue configured to transmit a plurality of slots of data at a designated time;
a data interface configured to receive a plurality of isochronous data streams, the plurality of isochronous data streams comprising one or more different time references;
a network interface clock, the network interface clock configured to generate a designated time reference; and
at least one controller configured to:
extract one or more data packets from the plurality of isochronous data streams;
sort the one or more data packets based at least in part on a presentation time;
calculate a launch time for each of the one or more data packets; and
transmit the slots of data at the calculated launch time.
19. The network interface apparatus of claim 18, wherein the determined launch time is based at least in part on a difference between the one or more different time references and the designated time reference.
20. The network interface apparatus of claim 18, additionally comprising assigning the sorted one or more data packets to a slot of data.
21. A method of processing isochronous data streams, the method comprising:
receiving multiple isochronous data streams, each isochronous data stream comprising a plurality of isochronous data packets;
determining a sorting criterion for the multiple isochronous data streams;
sorting at least a portion of the isochronous data packets in each stream according to the determined sorting criterion to produce a sorted order of data packets; and
transmitting the isochronous data packets according to the sorted order.
22. The method of claim 21, additionally comprising:
receiving asynchronous data packets;
sorting the asynchronous data packets with the isochronous data packets according to at least one of (i) the sorting criterion; and/or (ii) a second sorting criterion, to produce a sorted order of asynchronous packets; and
transmitting the sorted order of asynchronous data packets.
23. The method of claim 21, wherein the sorting criterion is at least temporally based.
24. The method of claim 21, wherein the sorting criterion is based at least in part on a priority.
25. The method of claim 21, wherein at least one of the multiple isochronous data streams comprises both video and audio data.
US13/098,934 2011-05-02 2011-05-02 Methods and apparatus for isochronous data delivery within a network Abandoned US20120281704A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
US13/098,934 US20120281704A1 (en) 2011-05-02 2011-05-02 Methods and apparatus for isochronous data delivery within a network
TW101115614A TWI526024B (en) 2011-05-02 2012-05-02 Methods and apparatus for isochronous data delivery within a network
PCT/US2012/036188 WO2012151323A2 (en) 2011-05-02 2012-05-02 Methods and apparatus for isochronous data delivery within a network
US14/458,139 US10992404B2 (en) 2011-05-02 2014-08-12 Methods and apparatus for isochronous data delivery within a network

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US13/098,934 US20120281704A1 (en) 2011-05-02 2011-05-02 Methods and apparatus for isochronous data delivery within a network

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US14/458,139 Continuation US10992404B2 (en) 2011-05-02 2014-08-12 Methods and apparatus for isochronous data delivery within a network

Publications (1)

Publication Number Publication Date
US20120281704A1 true US20120281704A1 (en) 2012-11-08

Family

ID=46331673

Family Applications (2)

Application Number Title Priority Date Filing Date
US13/098,934 Abandoned US20120281704A1 (en) 2011-05-02 2011-05-02 Methods and apparatus for isochronous data delivery within a network
US14/458,139 Active 2033-03-01 US10992404B2 (en) 2011-05-02 2014-08-12 Methods and apparatus for isochronous data delivery within a network

Family Applications After (1)

Application Number Title Priority Date Filing Date
US14/458,139 Active 2033-03-01 US10992404B2 (en) 2011-05-02 2014-08-12 Methods and apparatus for isochronous data delivery within a network

Country Status (3)

Country Link
US (2) US20120281704A1 (en)
TW (1) TWI526024B (en)
WO (1) WO2012151323A2 (en)

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130028272A1 (en) * 2011-07-27 2013-01-31 Nec Corporation Communication apparatus, packetization period change method, and program
US20130182641A1 (en) * 2012-01-12 2013-07-18 Yael Maguire System and Method for Distance-Dependent Data Exchange Between Wireless Communication Devices
US20140068128A1 (en) * 2011-05-17 2014-03-06 Panasonic Corporation Stream processor
WO2014017668A3 (en) * 2012-07-26 2014-04-24 Kabushiki Kaisha Toshiba Wireless communication apparatus, wireless communication method and wireless communication system
US9055433B2 (en) 2012-01-12 2015-06-09 Facebook, Inc. Distance-dependent or user-dependent data exchange between wireless communication devices
US20150163131A1 (en) * 2013-12-09 2015-06-11 Alcatel-Lucent Usa Inc. Online application testing of grown application capacity
WO2015148844A1 (en) * 2014-03-26 2015-10-01 Nant Holdings Ip, Llc Protocols for interacting with content via multiple devices, systems and methods
US20160350247A1 (en) * 2015-05-26 2016-12-01 Intel Corporation Latency improvements on a bus using modified transfers
US20190132148A1 (en) * 2017-10-30 2019-05-02 Intel Corporation Streaming On Diverse Transports
US20210377807A1 (en) * 2017-10-31 2021-12-02 Sk Telecom Co., Ltd. Data transmission/reception apparatus and operation method for data transmission/reception apparatus
US11263165B2 (en) 2016-12-31 2022-03-01 Intel Corporation Apparatuses for periodic universal serial bus (USB) transaction scheduling at fractional bus intervals

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106330493B (en) * 2015-06-23 2020-01-03 中兴通讯股份有限公司 Network element signaling ordering method and device and network management system
US20220124708A1 (en) * 2019-02-22 2022-04-21 Ntt Docomo, Inc. Radio base station and user equipment

Citations (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3944927A (en) * 1971-09-01 1976-03-16 The United States Of America As Represented By The Secretary Of The Army Digital transmission system
US5742623A (en) * 1995-08-04 1998-04-21 General Instrument Corporation Of Delaware Error detection and recovery for high rate isochronous data in MPEG-2 data streams
US6021403A (en) * 1996-07-19 2000-02-01 Microsoft Corporation Intelligent user assistance facility
US20010007568A1 (en) * 1999-12-30 2001-07-12 U.S. Philips Corporation Method and apparatus for converting data streams
US20010019561A1 (en) * 1998-02-20 2001-09-06 Erik P. Staats Method for setting time stamp in syt field of packet headers for ieee-1394 devices
US20020041603A1 (en) * 2000-06-20 2002-04-11 Sony Corporation Control method and communication device
US20020057893A1 (en) * 1998-08-11 2002-05-16 Anthony Wood Digital recording and playback
US20020078273A1 (en) * 2000-12-20 2002-06-20 Jason Jacobs Method and apparatus for controlling a multi-mode I/O interface
US20020150126A1 (en) * 2001-04-11 2002-10-17 Kovacevic Branko D. System for frame based audio synchronization and method thereof
US20030021298A1 (en) * 2001-07-30 2003-01-30 Tomokazu Murakami Data multiplexing method, data recorded medium, data recording apparatus and data recording program
US6598172B1 (en) * 1999-10-29 2003-07-22 Intel Corporation System and method for clock skew compensation between encoder and decoder clocks by calculating drift metric, and using it to modify time-stamps of data packets
US20030142696A1 (en) * 2000-06-06 2003-07-31 Oyvind Holmeide Method for ensuring access to a transmission medium
US6680944B1 (en) * 1998-03-09 2004-01-20 Sony Corporation Apparatus for and method of predictive time stamping of isochronous data packets transmitted over an IEEE 1394-1995 serial bus network
US20040114607A1 (en) * 2002-12-17 2004-06-17 Tls Corporation Low latency digital audio over packet switched networks
US20040133661A1 (en) * 2002-12-07 2004-07-08 Lg Electronics Inc. Method for reproducing data recorded on an interactive recording medium in conjunction with associated auxiliary data
US20040264485A1 (en) * 1999-03-23 2004-12-30 Yamaha Corporation Packet handler of audio data by isochronous mode
US20040264577A1 (en) * 2003-06-24 2004-12-30 Samsung Electronics Co., Ltd. Apparatus and method for controlling the synchronization of a video transport stream
US20050169175A1 (en) * 2004-01-30 2005-08-04 Apostolopoulos John G. Methods and systems that use information about encrypted data packets to determine an order for sending the data packets
US20060083232A1 (en) * 2004-10-15 2006-04-20 Samsung Electronics Co., Ltd. Method and apparatus for transmitting isochronous stream
US20070291678A1 (en) * 2006-06-19 2007-12-20 Starent System and method for measuring and reporting service usage
US20080256272A1 (en) * 2004-01-30 2008-10-16 Telefonaktiebolaget Lm Ericsson Packet Scheduling for Data Stream Transmission
US20090083811A1 (en) * 2007-09-26 2009-03-26 Verivue, Inc. Unicast Delivery of Multimedia Content
US20090182939A1 (en) * 2008-01-11 2009-07-16 Verivue, Inc. Asynchronous and Distributed Storage of Data
US20090285217A1 (en) * 2008-05-15 2009-11-19 Verivue, Inc. Statistical multiplexing of compressed video streams
US20110149967A1 (en) * 2009-12-22 2011-06-23 Industrial Technology Research Institute System and method for transmitting network packets adapted for multimedia streams
US20120023357A1 (en) * 2003-12-29 2012-01-26 Apple Inc. Cyclemaster synchronization in a distributed bridge

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR0136460B1 (en) * 1994-12-24 1998-05-15 이헌조 Data interleaving method for a variable bit rate coding device
US5761430A (en) * 1996-04-12 1998-06-02 Peak Audio, Inc. Media access control for isochronous data packets in carrier sensing multiple access systems
US6137834A (en) * 1996-05-29 2000-10-24 Sarnoff Corporation Method and apparatus for splicing compressed information streams
US6611624B1 (en) * 1998-03-13 2003-08-26 Cisco Systems, Inc. System and method for frame accurate splicing of compressed bitstreams
US6161160A (en) * 1998-09-03 2000-12-12 Advanced Micro Devices, Inc. Network interface device architecture for storing transmit and receive data in a random access buffer memory across independent clock domains
US7035246B2 (en) * 2001-03-13 2006-04-25 Pulse-Link, Inc. Maintaining a global time reference among a group of networked devices
US7103051B2 (en) * 2001-11-01 2006-09-05 International Business Machines Corporation QoS scheduler and method for implementing quality of service with aging time stamps
CA2506557A1 (en) * 2002-11-27 2004-06-17 Rgb Networks, Inc. Apparatus and method for dynamic channel mapping and optimized scheduling of data packets
JP4594923B2 (en) * 2003-01-16 2010-12-08 ソニー ヨーロッパ リミテッド Video / audio network
US7725202B2 (en) * 2003-07-24 2010-05-25 General Instrument Corporation Audio splice process for digital Ad insertion
US7733919B2 (en) * 2004-07-12 2010-06-08 General Instrument Corporation Method and apparatus for processing transport stream packets to compensate for jitter
KR100899659B1 (en) * 2006-12-01 2009-05-27 한국전자통신연구원 Packet scheduler and packet scheduling method
JP4983923B2 (en) * 2007-08-27 2012-07-25 富士通株式会社 Decoder device and decoding method
US20110072148A1 (en) * 2009-09-24 2011-03-24 Cisco Technology, Inc. Distributed Coordination of Network Elements for Packet Encapsulation

Patent Citations (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3944927A (en) * 1971-09-01 1976-03-16 The United States Of America As Represented By The Secretary Of The Army Digital transmission system
US5742623A (en) * 1995-08-04 1998-04-21 General Instrument Corporation Of Delaware Error detection and recovery for high rate isochronous data in MPEG-2 data streams
US6021403A (en) * 1996-07-19 2000-02-01 Microsoft Corporation Intelligent user assistance facility
US20010019561A1 (en) * 1998-02-20 2001-09-06 Erik P. Staats Method for setting time stamp in syt field of packet headers for ieee-1394 devices
US20040125825A1 (en) * 1998-03-09 2004-07-01 Lym Kevin K. Predictive time stamping of transmitted data
US6680944B1 (en) * 1998-03-09 2004-01-20 Sony Corporation Apparatus for and method of predictive time stamping of isochronous data packets transmitted over an IEEE 1394-1995 serial bus network
US20020057893A1 (en) * 1998-08-11 2002-05-16 Anthony Wood Digital recording and playback
US20040264485A1 (en) * 1999-03-23 2004-12-30 Yamaha Corporation Packet handler of audio data by isochronous mode
US6598172B1 (en) * 1999-10-29 2003-07-22 Intel Corporation System and method for clock skew compensation between encoder and decoder clocks by calculating drift metric, and using it to modify time-stamps of data packets
US20010007568A1 (en) * 1999-12-30 2001-07-12 U.S. Philips Corporation Method and apparatus for converting data streams
US20030142696A1 (en) * 2000-06-06 2003-07-31 Oyvind Holmeide Method for ensuring access to a transmission medium
US20020041603A1 (en) * 2000-06-20 2002-04-11 Sony Corporation Control method and communication device
US20020078273A1 (en) * 2000-12-20 2002-06-20 Jason Jacobs Method and apparatus for controlling a multi-mode I/O interface
US20020150126A1 (en) * 2001-04-11 2002-10-17 Kovacevic Branko D. System for frame based audio synchronization and method thereof
US20030021298A1 (en) * 2001-07-30 2003-01-30 Tomokazu Murakami Data multiplexing method, data recorded medium, data recording apparatus and data recording program
US20040133661A1 (en) * 2002-12-07 2004-07-08 Lg Electronics Inc. Method for reproducing data recorded on an interactive recording medium in conjunction with associated auxiliary data
US20040114607A1 (en) * 2002-12-17 2004-06-17 Tls Corporation Low latency digital audio over packet switched networks
US20040264577A1 (en) * 2003-06-24 2004-12-30 Samsung Electronics Co., Ltd. Apparatus and method for controlling the synchronization of a video transport stream
US20120023357A1 (en) * 2003-12-29 2012-01-26 Apple Inc. Cyclemaster synchronization in a distributed bridge
US20050169175A1 (en) * 2004-01-30 2005-08-04 Apostolopoulos John G. Methods and systems that use information about encrypted data packets to determine an order for sending the data packets
US20080256272A1 (en) * 2004-01-30 2008-10-16 Telefonaktiebolaget Lm Ericsson Packet Scheduling for Data Stream Transmission
US20060083232A1 (en) * 2004-10-15 2006-04-20 Samsung Electronics Co., Ltd. Method and apparatus for transmitting isochronous stream
US20070291678A1 (en) * 2006-06-19 2007-12-20 Starent System and method for measuring and reporting service usage
US20090083811A1 (en) * 2007-09-26 2009-03-26 Verivue, Inc. Unicast Delivery of Multimedia Content
US20090182939A1 (en) * 2008-01-11 2009-07-16 Verivue, Inc. Asynchronous and Distributed Storage of Data
US20090285217A1 (en) * 2008-05-15 2009-11-19 Verivue, Inc. Statistical multiplexing of compressed video streams
US20110149967A1 (en) * 2009-12-22 2011-06-23 Industrial Technology Research Institute System and method for transmitting network packets adapted for multimedia streams

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140068128A1 (en) * 2011-05-17 2014-03-06 Panasonic Corporation Stream processor
US20130028272A1 (en) * 2011-07-27 2013-01-31 Nec Corporation Communication apparatus, packetization period change method, and program
US20130182641A1 (en) * 2012-01-12 2013-07-18 Yael Maguire System and Method for Distance-Dependent Data Exchange Between Wireless Communication Devices
US9008114B2 (en) * 2012-01-12 2015-04-14 Facebook, Inc. System and method for distance-dependent data exchange between wireless communication devices
US9055433B2 (en) 2012-01-12 2015-06-09 Facebook, Inc. Distance-dependent or user-dependent data exchange between wireless communication devices
WO2014017668A3 (en) * 2012-07-26 2014-04-24 Kabushiki Kaisha Toshiba Wireless communication apparatus, wireless communication method and wireless communication system
US20150163131A1 (en) * 2013-12-09 2015-06-11 Alcatel-Lucent Usa Inc. Online application testing of grown application capacity
WO2015148844A1 (en) * 2014-03-26 2015-10-01 Nant Holdings Ip, Llc Protocols for interacting with content via multiple devices, systems and methods
US20160350247A1 (en) * 2015-05-26 2016-12-01 Intel Corporation Latency improvements on a bus using modified transfers
WO2016190979A1 (en) * 2015-05-26 2016-12-01 Intel Corporation Latency improvements on a bus using modified transfers
US11263165B2 (en) 2016-12-31 2022-03-01 Intel Corporation Apparatuses for periodic universal serial bus (USB) transaction scheduling at fractional bus intervals
US20190132148A1 (en) * 2017-10-30 2019-05-02 Intel Corporation Streaming On Diverse Transports
US10791003B2 (en) * 2017-10-30 2020-09-29 Intel Corporation Streaming on diverse transports
US11258631B2 (en) 2017-10-30 2022-02-22 Intel Corporation Streaming on diverse transports
US11764996B2 (en) 2017-10-30 2023-09-19 Tahoe Research, Ltd. Streaming on diverse transports
US20210377807A1 (en) * 2017-10-31 2021-12-02 Sk Telecom Co., Ltd. Data transmission/reception apparatus and operation method for data transmission/reception apparatus
US11963044B2 (en) * 2017-10-31 2024-04-16 Sk Telecom Co., Ltd. Data transmission/reception apparatus and operation method for data transmission/reception apparatus

Also Published As

Publication number Publication date
TWI526024B (en) 2016-03-11
WO2012151323A2 (en) 2012-11-08
TW201251380A (en) 2012-12-16
US20140348174A1 (en) 2014-11-27
WO2012151323A3 (en) 2013-03-14
US10992404B2 (en) 2021-04-27

Similar Documents

Publication Publication Date Title
US10992404B2 (en) Methods and apparatus for isochronous data delivery within a network
US11249688B2 (en) High-speed data packet capture and storage with playback capabilities
US10541770B2 (en) Efficient recovery of lost packets using double parity forward error correction
KR101576344B1 (en) Methods and apparatus for transporting data through network tunnels
US11362957B2 (en) Jitter elimination and latency compensation at DetNet transport egress
US7908393B2 (en) Network bandwidth detection, distribution and traffic prioritization
US10439940B2 (en) Latency correction between transport layer host and deterministic interface circuit
US9307298B2 (en) System and method for video statistical multiplexing adapting to internet protocol networks
Zinner et al. Application and realization of gateways between conventional automotive and IP/Ethernet-based networks
CN108282416B (en) Scheduling method and device based on data frame
Hari et al. An architecture for packet-striping protocols
CN108989246B (en) Audio transmission between devices using sparse streams
KR101119300B1 (en) Residential Ethernet Node Apparatus For Strict Guarantee of Super Frame's Start and Its Frame Processing Method
WO2023123104A1 (en) Message transmission method and network device
KR101035766B1 (en) Synchronous Data Constructing Method In Residential Ethernet System
JP6830516B1 (en) Fast data packet capture and storage with playback capabilities
US20080159332A1 (en) Methods and devices for using variable length subpackets in data transmissions
US20080130675A1 (en) Method and System for Data Traffic Integration Using Dynamic Data Packet Fragmentation
JP2006054653A (en) Ethernet frame transfer device and method therefor
KR100744333B1 (en) Wireless residential ethernet node apparatus and clock synchronization data transmission method

Legal Events

Date Code Title Description
AS Assignment

Owner name: APPLE INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BUTTERWORTH, ASHLEY I.;JONES, GIRAULT W., JR.;MORA, MATTHEW X.;REEL/FRAME:026738/0299

Effective date: 20110627

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION