Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(408)

Unified Diff: webrtc/video/video_stream_decoder.h

Issue 1929313002: Removed all RTP dependencies from ViEChannel and renamed class. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/video/video_stream_decoder.h
diff --git a/webrtc/video/vie_channel.h b/webrtc/video/video_stream_decoder.h
similarity index 63%
rename from webrtc/video/vie_channel.h
rename to webrtc/video/video_stream_decoder.h
index 041185782696582bf7c2427050e369351299de5a..c6306fc5c49dae168b94688935a6f8532cc7bde2 100644
--- a/webrtc/video/vie_channel.h
+++ b/webrtc/video/video_stream_decoder.h
@@ -8,8 +8,8 @@
* be found in the AUTHORS file in the root of the source tree.
*/
-#ifndef WEBRTC_VIDEO_VIE_CHANNEL_H_
-#define WEBRTC_VIDEO_VIE_CHANNEL_H_
+#ifndef WEBRTC_VIDEO_VIDEO_STREAM_DECODER_H_
+#define WEBRTC_VIDEO_VIDEO_STREAM_DECODER_H_
#include <list>
#include <map>
@@ -20,12 +20,9 @@
#include "webrtc/base/platform_thread.h"
#include "webrtc/base/scoped_ref_ptr.h"
#include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h"
-#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h"
-#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h"
#include "webrtc/modules/video_coding/include/video_coding_defines.h"
#include "webrtc/system_wrappers/include/tick_util.h"
#include "webrtc/typedefs.h"
-#include "webrtc/video/rtp_stream_receiver.h"
#include "webrtc/video/vie_sync_module.h"
namespace webrtc {
@@ -36,12 +33,7 @@ class Config;
class EncodedImageCallback;
class I420FrameCallback;
class IncomingVideoStream;
-class PacedSender;
-class PacketRouter;
-class PayloadRouter;
class ReceiveStatisticsProxy;
-class RtcpRttStats;
-class ViERTPObserver;
class VideoRenderCallback;
class VoEVideoSync;
@@ -54,40 +46,25 @@ enum StreamType {
kViEStreamTypeRtx = 1 // Retransmission media stream
};
-class ViEChannel : public VCMFrameTypeCallback,
- public VCMReceiveCallback,
- public VCMReceiveStatisticsCallback,
- public VCMDecoderTimingCallback,
- public VCMPacketRequestCallback {
+class VideoStreamDecoder : public VCMReceiveCallback,
+ public VCMReceiveStatisticsCallback,
+ public VCMDecoderTimingCallback {
public:
friend class ChannelStatsObserver;
- ViEChannel(vcm::VideoReceiver* video_receiver,
- RtpStreamReceiver* rtp_stream_receiver);
- ~ViEChannel();
-
- int32_t Init();
-
- RtpRtcp* rtp_rtcp() const { return rtp_rtcp_; }
-
- void SetProtectionMode(bool enable_nack,
- bool enable_fec,
- int payload_type_red,
- int payload_type_fec);
-
- RtpState GetRtpStateForSsrc(uint32_t ssrc) const;
-
+ VideoStreamDecoder(vcm::VideoReceiver* video_receiver,
+ VCMFrameTypeCallback* vcm_frame_type_callback,
+ VCMPacketRequestCallback* vcm_packet_request_callback,
+ bool enable_nack,
+ ReceiveStatisticsProxy* receive_statistics_proxy);
+ ~VideoStreamDecoder();
CallStatsObserver* GetStatsObserver();
// Implements VCMReceiveCallback.
virtual int32_t FrameToRender(VideoFrame& video_frame); // NOLINT
-
- // Implements VCMReceiveCallback.
virtual int32_t ReceivedDecodedReferenceFrame(
const uint64_t picture_id);
-
- // Implements VCMReceiveCallback.
pbos-webrtc 2016/05/02 00:59:03 Add back, this still implements that?
mflodman 2016/05/02 19:01:27 That is already said above FrameToRender and doesn
void OnIncomingPayloadType(int payload_type) override;
void OnDecoderImplementationName(const char* implementation_name) override;
@@ -105,21 +82,8 @@ class ViEChannel : public VCMFrameTypeCallback,
int min_playout_delay_ms,
int render_delay_ms);
- // Implements FrameTypeCallback.
- virtual int32_t RequestKeyFrame();
-
- // Implements FrameTypeCallback.
- virtual int32_t SliceLossIndicationRequest(
- const uint64_t picture_id);
-
- // Implements VideoPacketRequestCallback.
- int32_t ResendPackets(const uint16_t* sequence_numbers,
- uint16_t length) override;
-
void RegisterPreRenderCallback(I420FrameCallback* pre_render_callback);
- void RegisterRtcpPacketTypeCounterObserver(
- RtcpPacketTypeCounterObserver* observer);
void RegisterReceiveStatisticsProxy(
ReceiveStatisticsProxy* receive_statistics_proxy);
void SetIncomingVideoStream(IncomingVideoStream* incoming_video_stream);
@@ -132,26 +96,19 @@ class ViEChannel : public VCMFrameTypeCallback,
void StartDecodeThread();
void StopDecodeThread();
- void ProcessNACKRequest(const bool enable);
- // Compute NACK list parameters for the buffering mode.
- int GetRequiredNackListSize(int target_delay_ms);
-
// Used for all registered callbacks except rendering.
rtc::CriticalSection crit_;
vcm::VideoReceiver* const video_receiver_;
- RtpStreamReceiver* const rtp_stream_receiver_;
- RtpRtcp* const rtp_rtcp_;
// Helper to report call statistics.
std::unique_ptr<ChannelStatsObserver> stats_observer_;
// Not owned.
pbos-webrtc 2016/05/02 00:59:03 This comment bothers me, can you remove it? :)
mflodman 2016/05/02 19:01:27 Done.
- ReceiveStatisticsProxy* receive_stats_callback_ GUARDED_BY(crit_);
+ ReceiveStatisticsProxy* const receive_stats_callback_;
FrameCounts receive_frame_counts_ GUARDED_BY(crit_);
IncomingVideoStream* incoming_video_stream_ GUARDED_BY(crit_);
- int max_nack_reordering_threshold_;
I420FrameCallback* pre_render_callback_ GUARDED_BY(crit_);
int64_t last_rtt_ms_ GUARDED_BY(crit_);
@@ -159,4 +116,4 @@ class ViEChannel : public VCMFrameTypeCallback,
} // namespace webrtc
-#endif // WEBRTC_VIDEO_VIE_CHANNEL_H_
+#endif // WEBRTC_VIDEO_VIDEO_STREAM_DECODER_H_

Powered by Google App Engine
This is Rietveld 408576698