blob: ea098da710b87b6a5834b8ab88a7f1c46e65e6aa [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
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000014#include <string>
15
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020016#include "modules/include/module_common_types.h"
17#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
18#include "rtc_base/constructormagic.h"
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000019
20namespace webrtc {
danilchape545e5d2016-12-05 02:26:44 -080021class RtpPacketToSend;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000022
23class RtpPacketizer {
24 public:
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000025 static RtpPacketizer* Create(RtpVideoCodecTypes type,
26 size_t max_payload_len,
ilnik7a3006b2017-05-23 09:34:21 -070027 size_t last_packet_reduction_len,
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000028 const RTPVideoTypeHeader* rtp_type_header,
29 FrameType frame_type);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000030
31 virtual ~RtpPacketizer() {}
32
ilnik7a3006b2017-05-23 09:34:21 -070033 // Returns total number of packets which would be produced by the packetizer.
34 virtual size_t SetPayloadData(
35 const uint8_t* payload_data,
36 size_t payload_size,
37 const RTPFragmentationHeader* fragmentation) = 0;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000038
39 // Get the next payload with payload header.
danilchape545e5d2016-12-05 02:26:44 -080040 // Write payload and set marker bit of the |packet|.
danilchape545e5d2016-12-05 02:26:44 -080041 // Returns true on success, false otherwise.
ilnik7a3006b2017-05-23 09:34:21 -070042 virtual bool NextPacket(RtpPacketToSend* packet) = 0;
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000043
pbos@webrtc.orgb5e6bfc2014-09-12 11:05:55 +000044 virtual std::string ToString() = 0;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000045};
46
sprang52033d62016-06-02 02:43:32 -070047// TODO(sprang): Update the depacketizer to return a std::unqie_ptr with a copy
48// of the parsed payload, rather than just a pointer into the incoming buffer.
49// This way we can move some parsing out from the jitter buffer into here, and
50// the jitter buffer can just store that pointer rather than doing a copy there.
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000051class RtpDepacketizer {
52 public:
pbos@webrtc.org730d2702014-09-29 08:00:22 +000053 struct ParsedPayload {
pbos@webrtc.org730d2702014-09-29 08:00:22 +000054 const uint8_t* payload;
55 size_t payload_length;
pbos@webrtc.orgd42a3ad2014-11-07 11:02:12 +000056 FrameType frame_type;
57 RTPTypeHeader type;
pbos@webrtc.org730d2702014-09-29 08:00:22 +000058 };
59
60 static RtpDepacketizer* Create(RtpVideoCodecTypes type);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000061
62 virtual ~RtpDepacketizer() {}
63
pbos@webrtc.org730d2702014-09-29 08:00:22 +000064 // Parses the RTP payload, parsed result will be saved in |parsed_payload|.
65 virtual bool Parse(ParsedPayload* parsed_payload,
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000066 const uint8_t* payload_data,
67 size_t payload_data_length) = 0;
68};
69} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020070#endif // MODULES_RTP_RTCP_SOURCE_RTP_FORMAT_H_