throbber
Network Working Group
`Request for Comments: 3550
`Obsoletes: 1889
`Category: Standards Track
`
`H. Schulzrinne
`Columbia University
`S. Casner
`Packet Design
`R. Frederick
`Blue Coat Systems Inc.
`V. Jacobson
`Packet Design
`July 2003
`
`RTP: A Transport Protocol for Real-Time Applications
`
`Status of this Memo
`
`This document speci(cid:12)es an Internet standards track protocol for the Internet community, and
`requests discussion and suggestions for improvements. Please refer to the current edition of the
`\Internet O(cid:14)cial Protocol Standards" (STD 1) for the standardization state and status of this
`protocol. Distribution of this memo is unlimited.
`
`Copyright Notice
`
`Copyright (C) The Internet Society (2003). All Rights Reserved.
`
`Abstract
`
`This memorandum describes RTP, the real-time transport protocol. RTP provides end-to-end
`network transport functions suitable for applications transmitting real-time data, such as audio,
`video or simulation data, over multicast or unicast network services. RTP does not address resource
`reservation and does not guarantee quality-of-service for real-time services. The data transport is
`augmented by a control protocol (RTCP) to allow monitoring of the data delivery in a manner
`scalable to large multicast networks, and to provide minimal control and identi(cid:12)cation functionality.
`RTP and RTCP are designed to be independent of the underlying transport and network layers.
`The protocol supports the use of RTP-level translators and mixers.
`Most of the text in this memorandum is identical to RFC 1889 which it obsoletes. There are no
`changes in the packet formats on the wire, only changes to the rules and algorithms governing how
`the protocol is used. The biggest change is an enhancement to the scalable timer algorithm for
`calculating when to send RTCP packets in order to minimize transmission in excess of the intended
`rate when many participants join a session simultaneously.
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 1]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 1 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`Table of Contents
`
`1.
`
`Introduction
`1.1 Terminology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
`
`2. RTP Use Scenarios
`2.1 Simple Multicast Audio Conference . . . . . . . . . . . . . . . . . . . . . . . . . . .
`2.2 Audio and Video Conference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
`2.3 Mixers and Translators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
`2.4 Layered Encodings
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
`
`3. Definitions
`
`4. Byte Order, Alignment, and Time Format
`
`5
`6
`
`6
`6
`7
`7
`8
`
`8
`
`11
`
`12
`5. RTP Data Transfer Protocol
`5.1 RTP Fixed Header Fields . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
`5.2 Multiplexing RTP Sessions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
`5.3 Pro(cid:12)le-Speci(cid:12)c Modi(cid:12)cations to the RTP Header
`. . . . . . . . . . . . . . . . . . . 15
`5.3.1 RTP Header Extension . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
`
`17
`6. RTP Control Protocol — RTCP
`6.1 RTCP Packet Format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
`6.2 RTCP Transmission Interval . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
`6.2.1 Maintaining the Number of Session Members
`. . . . . . . . . . . . . . . . . 23
`6.3 RTCP Packet Send and Receive Rules
`. . . . . . . . . . . . . . . . . . . . . . . . . 24
`6.3.1 Computing the RTCP Transmission Interval . . . . . . . . . . . . . . . . . . 25
`6.3.2
`Initialization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
`6.3.3 Receiving an RTP or Non-BYE RTCP Packet . . . . . . . . . . . . . . . . . 26
`6.3.4 Receiving an RTCP BYE Packet
`. . . . . . . . . . . . . . . . . . . . . . . . 26
`6.3.5 Timing Out an SSRC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
`6.3.6 Expiration of Transmission Timer . . . . . . . . . . . . . . . . . . . . . . . . 27
`6.3.7 Transmitting a BYE Packet . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
`6.3.8 Updating we
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`6.3.9 Allocation of Source Description Bandwidth . . . . . . . . . . . . . . . . . . 28
`6.4 Sender and Receiver Reports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
`6.4.1
`SR: Sender Report RTCP Packet . . . . . . . . . . . . . . . . . . . . . . . . 30
`6.4.2 RR: Receiver Report RTCP Packet . . . . . . . . . . . . . . . . . . . . . . . 35
`6.4.3 Extending the Sender and Receiver Reports . . . . . . . . . . . . . . . . . . 35
`6.4.4 Analyzing Sender and Receiver Reports
`. . . . . . . . . . . . . . . . . . . . 36
`6.5 SDES: Source Description RTCP Packet
`. . . . . . . . . . . . . . . . . . . . . . . . 37
`6.5.1 CNAME: Canonical End-Point Identi(cid:12)er SDES Item . . . . . . . . . . . . . 38
`6.5.2 NAME: User Name SDES Item . . . . . . . . . . . . . . . . . . . . . . . . . 40
`6.5.3 EMAIL: Electronic Mail Address SDES Item . . . . . . . . . . . . . . . . . 40
`6.5.4 PHONE: Phone Number SDES Item . . . . . . . . . . . . . . . . . . . . . . 40
`6.5.5 LOC: Geographic User Location SDES Item . . . . . . . . . . . . . . . . . . 41
`6.5.6 TOOL: Application or Tool Name SDES Item . . . . . . . . . . . . . . . . . 41
`6.5.7 NOTE: Notice/Status SDES Item . . . . . . . . . . . . . . . . . . . . . . . . 41
`6.5.8 PRIV: Private Extensions SDES Item . . . . . . . . . . . . . . . . . . . . . . 42
`6.6 BYE: Goodbye RTCP Packet
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
`6.7 APP: Application-De(cid:12)ned RTCP Packet . . . . . . . . . . . . . . . . . . . . . . . . 44
`
`45
`7. RTP Translators and Mixers
`7.1 General Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
`7.2 RTCP Processing in Translators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
`7.3 RTCP Processing in Mixers
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
`7.4 Cascaded Mixers
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
`
`49
`8. SSRC Identifier Allocation and Use
`8.1 Probability of Collision . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
`8.2 Collision Resolution and Loop Detection . . . . . . . . . . . . . . . . . . . . . . . . 50
`8.3 Use with Layered Encodings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
`
`54
`9. Security
`9.1 Con(cid:12)dentiality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
`9.2 Authentication and Message Integrity . . . . . . . . . . . . . . . . . . . . . . . . . . 56
`
`10. Congestion Control
`
`56
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 3]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 3 of 89
`
`

`

`RFC 3550
`
`RTP
`
`11. RTP over Network and Transport Protocols
`
`July 2003
`
`56
`
`58
`12. Summary of Protocol Constants
`12.1 RTCP Packet Types
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
`12.2 SDES Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
`
`13. RTP Profiles and Payload Format Specifications
`
`14. Security Considerations
`
`15. IANA Considerations
`
`16. Intellectual Property Rights Statement
`
`17. Acknowledgments
`
`59
`
`60
`
`61
`
`61
`
`61
`
`62
`Appendix A. Algorithms
`A.1 RTP Data Header Validity Checks . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
`A.2 RTCP Header Validity Checks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
`A.3 Determining Number of Packets Expected and Lost . . . . . . . . . . . . . . . . . . 69
`A.4 Generating RTCP SDES Packets
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
`A.5 Parsing RTCP SDES Packets
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
`A.6 Generating a Random 32-bit Identi(cid:12)er
`. . . . . . . . . . . . . . . . . . . . . . . . . 72
`A.7 Computing the RTCP Transmission Interval
`. . . . . . . . . . . . . . . . . . . . . . 74
`A.8 Estimating the Interarrival Jitter
`. . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
`
`Appendix B. Changes from RFC 1889
`
`81
`
`85
`References
`Normative References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
`Informative References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
`
`Authors’ Addresses
`
`Full Copyright Statement
`
`88
`
`89
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 4]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 4 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`1.
`
`Introduction
`
`This memorandum speci(cid:12)es the real-time transport protocol (RTP), which provides end-to-end
`delivery services for data with real-time characteristics, such as interactive audio and video. Those
`services include payload type identi(cid:12)cation, sequence numbering, timestamping and delivery mon-
`itoring. Applications typically run RTP on top of UDP to make use of its multiplexing and check-
`sum services; both protocols contribute parts of the transport protocol functionality. However,
`RTP may be used with other suitable underlying network or transport protocols (see Section 11).
`RTP supports data transfer to multiple destinations using multicast distribution if provided by the
`underlying network.
`Note that RTP itself does not provide any mechanism to ensure timely delivery or provide other
`It does not guarantee
`quality-of-service guarantees, but relies on lower-layer services to do so.
`delivery or prevent out-of-order delivery, nor does it assume that the underlying network is reliable
`and delivers packets in sequence. The sequence numbers included in RTP allow the receiver to
`reconstruct the sender’s packet sequence, but sequence numbers might also be used to determine
`the proper location of a packet, for example in video decoding, without necessarily decoding packets
`in sequence.
`While RTP is primarily designed to satisfy the needs of multi-participant multimedia conferences,
`it is not limited to that particular application. Storage of continuous data, interactive distributed
`simulation, active badge, and control and measurement applications may also (cid:12)nd RTP applicable.
`This document de(cid:12)nes RTP, consisting of two closely-linked parts:
`(cid:15) the real-time transport protocol (RTP), to carry data that has real-time properties.
`(cid:15) the RTP control protocol (RTCP), to monitor the quality of service and to convey information
`about the participants in an on-going session. The latter aspect of RTCP may be su(cid:14)cient for
`\loosely controlled" sessions, i.e., where there is no explicit membership control and set-up,
`but it is not necessarily intended to support all of an application’s control communication
`requirements. This functionality may be fully or partially subsumed by a separate session
`control protocol, which is beyond the scope of this document.
`
`RTP represents a new style of protocol following the principles of application level framing and
`integrated layer processing proposed by Clark and Tennenhouse [10]. That is, RTP is intended
`to be malleable to provide the information required by a particular application and will often
`be integrated into the application processing rather than being implemented as a separate layer.
`RTP is a protocol framework that is deliberately not complete. This document speci(cid:12)es those
`functions expected to be common across all the applications for which RTP would be appropriate.
`Unlike conventional protocols in which additional functions might be accommodated by making
`the protocol more general or by adding an option mechanism that would require parsing, RTP is
`intended to be tailored through modi(cid:12)cations and/or additions to the headers as needed. Examples
`are given in Sections 5.3 and 6.4.3.
`Therefore, in addition to this document, a complete speci(cid:12)cation of RTP for a particular application
`will require one or more companion documents (see Section 13):
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 5]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 5 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`(cid:15) a profile speci(cid:12)cation document, which de(cid:12)nes a set of payload type codes and their mapping
`to payload formats (e.g., media encodings). A pro(cid:12)le may also de(cid:12)ne extensions or modi(cid:12)ca-
`tions to RTP that are speci(cid:12)c to a particular class of applications. Typically an application
`will operate under only one pro(cid:12)le. A pro(cid:12)le for audio and video data may be found in the
`companion RFC 3551 [1].
`(cid:15) payload format speci(cid:12)cation documents, which de(cid:12)ne how a particular payload, such as an
`audio or video encoding, is to be carried in RTP.
`
`A discussion of real-time services and algorithms for their implementation as well as background
`discussion on some of the RTP design decisions can be found in [11].
`
`1.1 Terminology
`
`The key words \must", \must not", \required", \shall", \shall not", \should", \should
`not", \recommended", \may", and \optional" in this document are to be interpreted as de-
`scribed in BCP 14, RFC 2119 [2] and indicate requirement levels for compliant RTP implementa-
`tions.
`
`2. RTP Use Scenarios
`
`The following sections describe some aspects of the use of RTP. The examples were chosen to
`illustrate the basic operation of applications using RTP, not to limit what RTP may be used for.
`In these examples, RTP is carried on top of IP and UDP, and follows the conventions established
`by the pro(cid:12)le for audio and video speci(cid:12)ed in the companion RFC 3551.
`
`2.1 Simple Multicast Audio Conference
`
`A working group of the IETF meets to discuss the latest protocol document, using the IP multicast
`services of the Internet for voice communications. Through some allocation mechanism the working
`group chair obtains a multicast group address and pair of ports. One port is used for audio data,
`and the other is used for control (RTCP) packets. This address and port information is distributed
`to the intended participants. If privacy is desired, the data and control packets may be encrypted
`as speci(cid:12)ed in Section 9.1, in which case an encryption key must also be generated and distributed.
`The exact details of these allocation and distribution mechanisms are beyond the scope of RTP.
`The audio conferencing application used by each conference participant sends audio data in small
`chunks of, say, 20 ms duration. Each chunk of audio data is preceded by an RTP header; RTP
`header and data are in turn contained in a UDP packet. The RTP header indicates what type of
`audio encoding (such as PCM, ADPCM or LPC) is contained in each packet so that senders can
`change the encoding during a conference, for example, to accommodate a new participant that is
`connected through a low-bandwidth link or react to indications of network congestion.
`The Internet, like other packet networks, occasionally loses and reorders packets and delays them
`by variable amounts of time. To cope with these impairments, the RTP header contains timing
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 6]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 6 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`information and a sequence number that allow the receivers to reconstruct the timing produced by
`the source, so that in this example, chunks of audio are contiguously played out the speaker every
`20 ms. This timing reconstruction is performed separately for each source of RTP packets in the
`conference. The sequence number can also be used by the receiver to estimate how many packets
`are being lost.
`Since members of the working group join and leave during the conference, it is useful to know who
`is participating at any moment and how well they are receiving the audio data. For that purpose,
`each instance of the audio application in the conference periodically multicasts a reception report
`plus the name of its user on the RTCP (control) port. The reception report indicates how well the
`current speaker is being received and may be used to control adaptive encodings. In addition to
`the user name, other identifying information may also be included subject to control bandwidth
`limits. A site sends the RTCP BYE packet (Section 6.6) when it leaves the conference.
`
`2.2 Audio and Video Conference
`
`If both audio and video media are used in a conference, they are transmitted as separate RTP
`sessions. That is, separate RTP and RTCP packets are transmitted for each medium using two
`di(cid:11)erent UDP port pairs and/or multicast addresses. There is no direct coupling at the RTP level
`between the audio and video sessions, except that a user participating in both sessions should use
`the same distinguished (canonical) name in the RTCP packets for both so that the sessions can be
`associated.
`One motivation for this separation is to allow some participants in the conference to receive only
`one medium if they choose. Further explanation is given in Section 5.2. Despite the separation,
`synchronized playback of a source’s audio and video can be achieved using timing information
`carried in the RTCP packets for both sessions.
`
`2.3 Mixers and Translators
`
`So far, we have assumed that all sites want to receive media data in the same format. However, this
`may not always be appropriate. Consider the case where participants in one area are connected
`through a low-speed link to the majority of the conference participants who enjoy high-speed net-
`work access. Instead of forcing everyone to use a lower-bandwidth, reduced-quality audio encoding,
`an RTP-level relay called a mixer may be placed near the low-bandwidth area. This mixer resyn-
`chronizes incoming audio packets to reconstruct the constant 20 ms spacing generated by the sender,
`mixes these reconstructed audio streams into a single stream, translates the audio encoding to a
`lower-bandwidth one and forwards the lower-bandwidth packet stream across the low-speed link.
`These packets might be unicast to a single recipient or multicast on a di(cid:11)erent address to multiple
`recipients. The RTP header includes a means for mixers to identify the sources that contributed
`to a mixed packet so that correct talker indication can be provided at the receivers.
`Some of the intended participants in the audio conference may be connected with high bandwidth
`links but might not be directly reachable via IP multicast. For example, they might be behind
`an application-level (cid:12)rewall that will not let any IP packets pass. For these sites, mixing may
`not be necessary, in which case another type of RTP-level relay called a translator may be used.
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 7]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 7 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`Two translators are installed, one on either side of the (cid:12)rewall, with the outside one funneling all
`multicast packets received through a secure connection to the translator inside the (cid:12)rewall. The
`translator inside the (cid:12)rewall sends them again as multicast packets to a multicast group restricted
`to the site’s internal network.
`Mixers and translators may be designed for a variety of purposes. An example is a video mixer that
`scales the images of individual people in separate video streams and composites them into one video
`stream to simulate a group scene. Other examples of translation include the connection of a group
`of hosts speaking only IP/UDP to a group of hosts that understand only ST-II, or the packet-by-
`packet encoding translation of video streams from individual sources without resynchronization or
`mixing. Details of the operation of mixers and translators are given in Section 7.
`
`2.4 Layered Encodings
`
`Multimedia applications should be able to adjust the transmission rate to match the capacity of
`the receiver or to adapt to network congestion. Many implementations place the responsibility of
`rate-adaptivity at the source. This does not work well with multicast transmission because of the
`conflicting bandwidth requirements of heterogeneous receivers. The result is often a least-common
`denominator scenario, where the smallest pipe in the network mesh dictates the quality and (cid:12)delity
`of the overall live multimedia \broadcast".
`Instead, responsibility for rate-adaptation can be placed at the receivers by combining a layered
`encoding with a layered transmission system. In the context of RTP over IP multicast, the source
`can stripe the progressive layers of a hierarchically represented signal across multiple RTP sessions
`each carried on its own multicast group. Receivers can then adapt to network heterogeneity and
`control their reception bandwidth by joining only the appropriate subset of the multicast groups.
`Details of the use of RTP with layered encodings are given in Sections 6.3.9, 8.3 and 11.
`
`3. Definitions
`
`RTP payload: The data transported by RTP in a packet, for example audio samples or com-
`pressed video data. The payload format and interpretation are beyond the scope of this
`document.
`
`RTP packet: A data packet consisting of the (cid:12)xed RTP header, a possibly empty list of contribut-
`ing sources (see below), and the payload data. Some underlying protocols may require an
`encapsulation of the RTP packet to be de(cid:12)ned. Typically one packet of the underlying pro-
`tocol contains a single RTP packet, but several RTP packets may be contained if permitted
`by the encapsulation method (see Section 11).
`
`RTCP packet: A control packet consisting of a (cid:12)xed header part similar to that of RTP data
`packets, followed by structured elements that vary depending upon the RTCP packet type.
`The formats are de(cid:12)ned in Section 6. Typically, multiple RTCP packets are sent together as
`a compound RTCP packet in a single packet of the underlying protocol; this is enabled by
`the length (cid:12)eld in the (cid:12)xed header of each RTCP packet.
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 8]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 8 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`Port: The \abstraction that transport protocols use to distinguish among multiple destinations
`within a given host computer. TCP/IP protocols identify ports using small positive integers."
`[12] The transport selectors (TSEL) used by the OSI transport layer are equivalent to ports.
`RTP depends upon the lower-layer protocol to provide some mechanism such as ports to
`multiplex the RTP and RTCP packets of a session.
`
`Transport address: The combination of a network address and port that identi(cid:12)es a transport-
`level endpoint, for example an IP address and a UDP port. Packets are transmitted from a
`source transport address to a destination transport address.
`
`RTP media type: An RTP media type is the collection of payload types which can be carried
`within a single RTP session. The RTP Pro(cid:12)le assigns RTP media types to RTP payload
`types.
`
`Multimedia session: A set of concurrent RTP sessions among a common group of participants.
`For example, a videoconference (which is a multimedia session) may contain an audio RTP
`session and a video RTP session.
`
`RTP session: An association among a set of participants communicating with RTP. A participant
`may be involved in multiple RTP sessions at the same time. In a multimedia session, each
`medium is typically carried in a separate RTP session with its own RTCP packets unless
`the the encoding itself multiplexes multiple media into a single data stream. A participant
`distinguishes multiple RTP sessions by reception of di(cid:11)erent sessions using di(cid:11)erent pairs of
`destination transport addresses, where a pair of transport addresses comprises one network
`address plus a pair of ports for RTP and RTCP. All participants in an RTP session may
`share a common destination transport address pair, as in the case of IP multicast, or the pairs
`may be di(cid:11)erent for each participant, as in the case of individual unicast network addresses
`and port pairs. In the unicast case, a participant may receive from all other participants in
`the session using the same pair of ports, or may use a distinct pair of ports for each.
`The distinguishing feature of an RTP session is that each maintains a full, separate space of
`SSRC identi(cid:12)ers (de(cid:12)ned next). The set of participants included in one RTP session consists
`of those that can receive an SSRC identi(cid:12)er transmitted by any one of the participants either
`in RTP as the SSRC or a CSRC (also de(cid:12)ned below) or in RTCP. For example, consider a
`three-party conference implemented using unicast UDP with each participant receiving from
`the other two on separate port pairs. If each participant sends RTCP feedback about data
`received from one other participant only back to that participant, then the conference is
`composed of three separate point-to-point RTP sessions. If each participant provides RTCP
`feedback about its reception of one other participant to both of the other participants, then
`the conference is composed of one multi-party RTP session. The latter case simulates the
`behavior that would occur with IP multicast communication among the three participants.
`The RTP framework allows the variations de(cid:12)ned here, but a particular control protocol or
`application design will usually impose constraints on these variations.
`
`Synchronization source (SSRC): The source of a stream of RTP packets, identi(cid:12)ed by a 32-bit
`numeric SSRC identi(cid:12)er carried in the RTP header so as not to be dependent upon the network
`address. All packets from a synchronization source form part of the same timing and sequence
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 9]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 9 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`number space, so a receiver groups packets by synchronization source for playback. Examples
`of synchronization sources include the sender of a stream of packets derived from a signal
`source such as a microphone or a camera, or an RTP mixer (see below). A synchronization
`source may change its data format, e.g., audio encoding, over time. The SSRC identi(cid:12)er is
`a randomly chosen value meant to be globally unique within a particular RTP session (see
`Section 8). A participant need not use the same SSRC identi(cid:12)er for all the RTP sessions
`in a multimedia session; the binding of the SSRC identi(cid:12)ers is provided through RTCP (see
`Section 6.5.1). If a participant generates multiple streams in one RTP session, for example
`from separate video cameras, each must be identi(cid:12)ed as a di(cid:11)erent SSRC.
`
`Contributing source (CSRC): A source of a stream of RTP packets that has contributed to
`the combined stream produced by an RTP mixer (see below). The mixer inserts a list of the
`SSRC identi(cid:12)ers of the sources that contributed to the generation of a particular packet into
`the RTP header of that packet. This list is called the CSRC list. An example application
`is audio conferencing where a mixer indicates all the talkers whose speech was combined to
`produce the outgoing packet, allowing the receiver to indicate the current talker, even though
`all the audio packets contain the same SSRC identi(cid:12)er (that of the mixer).
`
`End system: An application that generates the content to be sent in RTP packets and/or con-
`sumes the content of received RTP packets. An end system can act as one or more synchro-
`nization sources in a particular RTP session, but typically only one.
`
`Mixer: An intermediate system that receives RTP packets from one or more sources, possibly
`changes the data format, combines the packets in some manner and then forwards a new RTP
`packet. Since the timing among multiple input sources will not generally be synchronized,
`the mixer will make timing adjustments among the streams and generate its own timing for
`the combined stream. Thus, all data packets originating from a mixer will be identi(cid:12)ed as
`having the mixer as their synchronization source.
`
`Translator: An intermediate system that forwards RTP packets with their synchronization source
`identi(cid:12)er intact. Examples of translators include devices that convert encodings without
`mixing, replicators from multicast to unicast, and application-level (cid:12)lters in (cid:12)rewalls.
`
`Monitor: An application that receives RTCP packets sent by participants in an RTP session, in
`particular the reception reports, and estimates the current quality of service for distribution
`monitoring, fault diagnosis and long-term statistics. The monitor function is likely to be built
`into the application(s) participating in the session, but may also be a separate application
`that does not otherwise participate and does not send or receive the RTP data packets (since
`they are on a separate port). These are called third-party monitors. It is also acceptable for a
`third-party monitor to receive the RTP data packets but not send RTCP packets or otherwise
`be counted in the session.
`
`Non-RTP means: Protocols and mechanisms that may be needed in addition to RTP to provide
`a usable service. In particular, for multimedia conferences, a control protocol may distribute
`multicast addresses and keys for encryption, negotiate the encryption algorithm to be used,
`and de(cid:12)ne dynamic mappings between RTP payload type values and the payload formats they
`represent for formats that do not have a prede(cid:12)ned payload type value. Examples of such
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 10]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 10 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`protocols include the Session Initiation Protocol (SIP) (RFC 3261 [13]), ITU Recommendation
`H.323 [14] and applications using SDP (RFC 2327 [15]), such as RTSP (RFC 2326 [16]).
`For simple applications, electronic mail or a conference database may also be used. The
`speci(cid:12)cation of such protocols and mechanisms is outside the scope of this document.
`
`4. Byte Order, Alignment, and Time Format
`
`All integer (cid:12)elds are carried in network byte order, that is, most signi(cid:12)cant byte (octet) (cid:12)rst. This
`byte order is commonly known as big-endian. The transmission order is described in detail in [3,
`Appendix A]. Unless otherwise noted, numeric constants are in decimal (base 10).
`All header data is aligned to its natural length, i.e., 16-bit (cid:12)elds are aligned on even o(cid:11)sets, 32-bit
`(cid:12)elds are aligned at o(cid:11)sets divisible by four, etc. Octets designated as padding have the value zero.
`Wallclock time (absolute date and time) is represented using the timestamp format of the Network
`Time Protocol (NTP), which is in seconds relative to 0h UTC on 1 January 1900 [4]. The full
`resolution NTP timestamp is a 64-bit unsigned (cid:12)xed-point number with the integer part in the
`(cid:12)rst 32 bits and the fractional part in the last 32 bits.
`In some (cid:12)elds where a more compact
`representation is appropriate, only the middle 32 bits are used; that is, the low 16 bits of the
`integer part and the high 16 bits of the fractional part. The high 16 bits of the integer part must
`be determined independently.
`An implementation is not required to run the Network Time Protocol in order to use RTP. Other
`time sources, or none at all, may be used (see the description of the NTP timestamp (cid:12)eld in Section
`6.4.1). However, running NTP may be useful for synchronizing streams transmitted from separate
`hosts.
`The NTP timestamp will wrap around to zero some time in the year 2036, but for RTP purposes,
`only di(cid:11)erences between pairs of NTP timestamps are used. So long as the pairs of timestamps
`can be assumed to be within 68 years of each other, using modular arithmetic for subtractions and
`comparisons makes the wraparound irrelevant.
`
`Schulzrinne, et al.
`
`Standards Track
`
`[Page 11]
`
`Ingenico Inc. v. IOENGINE, LLC
`IPR2019-00879 (US 9,059,969)
`Exhibit 2136
`Page 11 of 89
`
`

`

`RFC 3550
`
`RTP
`
`July 2003
`
`5. RTP Data Transfer Protocol
`
`5.1 RTP Fixed Header Fields
`
`The RTP header has the following format:
`
`3
`2
`1
`0
`0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
`+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
`|V=2|P|X| CC
`|M|
`PT
`|
`sequence number
`|
`+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
`|
`timestamp
`|
`+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
`|
`synchronization source (SSRC) identifier
`|
`+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
`|
`contributing source (CSRC) identifiers
`|
`|
`....
`|
`+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

This document is available on Docket Alarm but you must sign up to view it.


Or .

Accessing this document will incur an additional charge of $.

After purchase, you can access this document again without charge.

Accept $ Charge
throbber

Still Working On It

This document is taking longer than usual to download. This can happen if we need to contact the court directly to obtain the document and their servers are running slowly.

Give it another minute or two to complete, and then try the refresh button.

throbber

A few More Minutes ... Still Working

It can take up to 5 minutes for us to download a document if the court servers are running slowly.

Thank you for your continued patience.

This document could not be displayed.

We could not find this document within its docket. Please go back to the docket page and check the link. If that does not work, go back to the docket and refresh it to pull the newest information.

Your account does not support viewing this document.

You need a Paid Account to view this document. Click here to change your account type.

Your account does not support viewing this document.

Set your membership status to view this document.

With a Docket Alarm membership, you'll get a whole lot more, including:

  • Up-to-date information for this case.
  • Email alerts whenever there is an update.
  • Full text search for other cases.
  • Get email alerts whenever a new case matches your search.

Become a Member

One Moment Please

The filing “” is large (MB) and is being downloaded.

Please refresh this page in a few minutes to see if the filing has been downloaded. The filing will also be emailed to you when the download completes.

Your document is on its way!

If you do not receive the document in five minutes, contact support at support@docketalarm.com.

Sealed Document

We are unable to display this document, it may be under a court ordered seal.

If you have proper credentials to access the file, you may proceed directly to the court's system using your government issued username and password.


Access Government Site

We are redirecting you
to a mobile optimized page.





Document Unreadable or Corrupt

Refresh this Document
Go to the Docket

We are unable to display this document.

Refresh this Document
Go to the Docket