blob: 7b2149ddce2c16b245261cfc81439860a17421b7 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
2 * Copyright (c) 2011 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
Henrik Kjellander2557b862015-11-18 22:00:21 +010011#ifndef WEBRTC_MODULES_VIDEO_CODING_RECEIVER_H_
12#define WEBRTC_MODULES_VIDEO_CODING_RECEIVER_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
kwiberg3f55dea2016-02-29 05:51:59 -080014#include <memory>
philipel9d3ab612015-12-21 04:12:39 -080015#include <vector>
16
Henrik Kjellander2557b862015-11-18 22:00:21 +010017#include "webrtc/modules/video_coding/jitter_buffer.h"
18#include "webrtc/modules/video_coding/packet.h"
19#include "webrtc/modules/video_coding/timing.h"
Henrik Kjellander98f53512015-10-28 18:17:40 +010020#include "webrtc/system_wrappers/include/critical_section_wrapper.h"
Henrik Kjellander2557b862015-11-18 22:00:21 +010021#include "webrtc/modules/video_coding/include/video_coding.h"
22#include "webrtc/modules/video_coding/include/video_coding_defines.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000023
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000024namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000025
stefan@webrtc.orga678a3b2013-01-21 07:42:11 +000026class Clock;
niklase@google.com470e71d2011-07-07 08:21:25 +000027class VCMEncodedFrame;
28
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000029class VCMReceiver {
30 public:
philipel9d3ab612015-12-21 04:12:39 -080031 VCMReceiver(VCMTiming* timing, Clock* clock, EventFactory* event_factory);
Qiang Chend4cec152015-06-19 09:17:00 -070032
33 // Using this constructor, you can specify a different event factory for the
34 // jitter buffer. Useful for unit tests when you want to simulate incoming
35 // packets, in which case the jitter buffer's wait event is different from
36 // that of VCMReceiver itself.
37 VCMReceiver(VCMTiming* timing,
38 Clock* clock,
kwiberg3f55dea2016-02-29 05:51:59 -080039 std::unique_ptr<EventWrapper> receiver_event,
40 std::unique_ptr<EventWrapper> jitter_buffer_event);
Qiang Chend4cec152015-06-19 09:17:00 -070041
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000042 ~VCMReceiver();
niklase@google.com470e71d2011-07-07 08:21:25 +000043
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000044 void Reset();
pkasting@chromium.org16825b12015-01-12 21:51:21 +000045 void UpdateRtt(int64_t rtt);
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000046 int32_t InsertPacket(const VCMPacket& packet,
47 uint16_t frame_width,
48 uint16_t frame_height);
49 VCMEncodedFrame* FrameForDecoding(uint16_t max_wait_time_ms,
philipel9d3ab612015-12-21 04:12:39 -080050 int64_t* next_render_time_ms,
perkj796cfaf2015-12-10 09:27:38 -080051 bool prefer_late_decoding);
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000052 void ReleaseFrame(VCMEncodedFrame* frame);
53 void ReceiveStatistics(uint32_t* bitrate, uint32_t* framerate);
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000054 uint32_t DiscardedPackets() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000055
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000056 // NACK.
stefan@webrtc.orga64300a2013-03-04 15:24:40 +000057 void SetNackMode(VCMNackMode nackMode,
pkasting@chromium.org16825b12015-01-12 21:51:21 +000058 int64_t low_rtt_nack_threshold_ms,
59 int64_t high_rtt_nack_threshold_ms);
stefan@webrtc.orgbecf9c82013-02-01 15:09:57 +000060 void SetNackSettings(size_t max_nack_list_size,
stefan@webrtc.orgef144882013-05-07 19:16:33 +000061 int max_packet_age_to_nack,
62 int max_incomplete_time_ms);
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000063 VCMNackMode NackMode() const;
Wan-Teh Changb1825a42015-06-03 15:03:35 -070064 std::vector<uint16_t> NackList(bool* request_key_frame);
niklase@google.com470e71d2011-07-07 08:21:25 +000065
mikhal@webrtc.orgef9f76a2013-02-15 23:22:18 +000066 // Receiver video delay.
67 int SetMinReceiverDelay(int desired_delay_ms);
68
mikhal@webrtc.orgdc3cd212013-04-25 20:27:04 +000069 // Decoding with errors.
agalusza@google.coma7e360e2013-08-01 03:15:08 +000070 void SetDecodeErrorMode(VCMDecodeErrorMode decode_error_mode);
71 VCMDecodeErrorMode DecodeErrorMode() const;
mikhal@webrtc.orgdc3cd212013-04-25 20:27:04 +000072
mikhal@webrtc.org381da4b2013-04-25 21:45:29 +000073 // Returns size in time (milliseconds) of complete continuous frames in the
mikhal@webrtc.org759b0412013-05-07 16:36:00 +000074 // jitter buffer. The render time is estimated based on the render delay at
75 // the time this function is called.
mikhal@webrtc.org381da4b2013-04-25 21:45:29 +000076 int RenderBufferSizeMs();
77
pbos@webrtc.org55707692014-12-19 15:45:03 +000078 void RegisterStatsCallback(VCMReceiveStatisticsCallback* callback);
pbos@webrtc.orgce4e9a32014-12-18 13:50:16 +000079
pbos@webrtc.org4dd40d62015-02-17 13:22:43 +000080 void TriggerDecoderShutdown();
81
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000082 private:
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000083 CriticalSectionWrapper* crit_sect_;
pbos@webrtc.org4dd40d62015-02-17 13:22:43 +000084 Clock* const clock_;
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000085 VCMJitterBuffer jitter_buffer_;
86 VCMTiming* timing_;
kwiberg3f55dea2016-02-29 05:51:59 -080087 std::unique_ptr<EventWrapper> render_wait_event_;
mikhal@webrtc.orgef9f76a2013-02-15 23:22:18 +000088 int max_video_delay_ms_;
niklase@google.com470e71d2011-07-07 08:21:25 +000089};
90
stefan@webrtc.org1ea4b502013-01-07 08:49:41 +000091} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +000092
Henrik Kjellander2557b862015-11-18 22:00:21 +010093#endif // WEBRTC_MODULES_VIDEO_CODING_RECEIVER_H_