blob: b2afb205f002d468f3907ec668e1ecf62bdfdf29 [file] [log] [blame]
stefan@webrtc.org2ec56062014-07-31 14:59:24 +00001/*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_RTP_RTCP_SOURCE_RTP_FORMAT_H_
12#define MODULES_RTP_RTCP_SOURCE_RTP_FORMAT_H_
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000013
Yves Gerey988cc082018-10-23 12:03:01 +020014#include <stdint.h>
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020015#include <memory>
Danil Chapovalov376e1142018-09-04 16:11:58 +020016#include <vector>
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000017
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020018#include "api/array_view.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020019#include "modules/include/module_common_types.h"
Yves Gerey988cc082018-10-23 12:03:01 +020020#include "modules/rtp_rtcp/source/rtp_video_header.h"
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000021
22namespace webrtc {
Yves Gerey988cc082018-10-23 12:03:01 +020023
danilchape545e5d2016-12-05 02:26:44 -080024class RtpPacketToSend;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000025
26class RtpPacketizer {
27 public:
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020028 struct PayloadSizeLimits {
Danil Chapovalovfa5ec8d2018-09-07 10:57:26 +020029 int max_payload_len = 1200;
30 int first_packet_reduction_len = 0;
31 int last_packet_reduction_len = 0;
Danil Chapovalovfcebe0e2018-10-12 17:51:22 +020032 // Reduction len for packet that is first & last at the same time.
33 int single_packet_reduction_len = 0;
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020034 };
35 static std::unique_ptr<RtpPacketizer> Create(
36 VideoCodecType type,
37 rtc::ArrayView<const uint8_t> payload,
38 PayloadSizeLimits limits,
39 // Codec-specific details.
40 const RTPVideoHeader& rtp_video_header,
Niels Möller87e2d782019-03-07 10:18:23 +010041 VideoFrameType frame_type,
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020042 const RTPFragmentationHeader* fragmentation);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000043
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020044 virtual ~RtpPacketizer() = default;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000045
Danil Chapovalovf7f8a1f2018-08-28 19:45:31 +020046 // Returns number of remaining packets to produce by the packetizer.
47 virtual size_t NumPackets() const = 0;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000048
49 // Get the next payload with payload header.
danilchape545e5d2016-12-05 02:26:44 -080050 // Write payload and set marker bit of the |packet|.
danilchape545e5d2016-12-05 02:26:44 -080051 // Returns true on success, false otherwise.
ilnik7a3006b2017-05-23 09:34:21 -070052 virtual bool NextPacket(RtpPacketToSend* packet) = 0;
Danil Chapovalov376e1142018-09-04 16:11:58 +020053
54 // Split payload_len into sum of integers with respect to |limits|.
Danil Chapovalovfa5ec8d2018-09-07 10:57:26 +020055 // Returns empty vector on failure.
56 static std::vector<int> SplitAboutEqually(int payload_len,
57 const PayloadSizeLimits& limits);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000058};
59
sprang52033d62016-06-02 02:43:32 -070060// TODO(sprang): Update the depacketizer to return a std::unqie_ptr with a copy
61// of the parsed payload, rather than just a pointer into the incoming buffer.
62// This way we can move some parsing out from the jitter buffer into here, and
63// the jitter buffer can just store that pointer rather than doing a copy there.
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000064class RtpDepacketizer {
65 public:
pbos@webrtc.org730d2702014-09-29 08:00:22 +000066 struct ParsedPayload {
philipel011dc642018-07-04 16:55:55 +020067 RTPVideoHeader& video_header() { return video; }
68 const RTPVideoHeader& video_header() const { return video; }
Niels Möller58fa7162019-04-18 11:14:27 +020069
70 // TODO(bugs.webrtc.org/10397): These are temporary accessors, to enable
71 // move of the frame_type member to inside RTPVideoHeader, without breaking
72 // downstream code.
73 VideoFrameType FrameType() const { return frame_type; }
74 void SetFrameType(VideoFrameType type) { frame_type = type; }
75
philipel011dc642018-07-04 16:55:55 +020076 RTPVideoHeader video;
77
pbos@webrtc.org730d2702014-09-29 08:00:22 +000078 const uint8_t* payload;
79 size_t payload_length;
Niels Möller87e2d782019-03-07 10:18:23 +010080 VideoFrameType frame_type;
pbos@webrtc.org730d2702014-09-29 08:00:22 +000081 };
82
Niels Möller520ca4e2018-06-04 11:14:38 +020083 static RtpDepacketizer* Create(VideoCodecType type);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000084
85 virtual ~RtpDepacketizer() {}
86
pbos@webrtc.org730d2702014-09-29 08:00:22 +000087 // Parses the RTP payload, parsed result will be saved in |parsed_payload|.
88 virtual bool Parse(ParsedPayload* parsed_payload,
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000089 const uint8_t* payload_data,
90 size_t payload_data_length) = 0;
91};
92} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020093#endif // MODULES_RTP_RTCP_SOURCE_RTP_FORMAT_H_