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

Unified Diff: webrtc/video/vie_encoder.h

Issue 1993113003: Refactor how padding is calculated. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Fixed unitialized memory. Created 4 years, 6 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/vie_encoder.h
diff --git a/webrtc/video/vie_encoder.h b/webrtc/video/vie_encoder.h
index 4372bd11c905615def67adc198d51b6438619331..880732abb3ff3a9476198ccd51687c4aee21bd17 100644
--- a/webrtc/video/vie_encoder.h
+++ b/webrtc/video/vie_encoder.h
@@ -49,6 +49,23 @@ class VideoEncoder;
// the encoded bit stream.
// 5. Call Start.
// 6. For each available raw video frame call EncodeVideoFrame.
+
+class VideoEncoderSink : public EncodedImageCallback {
+ public:
+ static const int TimeOutMs = 2000;
+
+ // Triggered if the encoder has not produced a frame for |TimeOutMs|.
+ // The effect of this call is that no padding will be sent for this stream and
+ // thus, this method should thus not be called if padding is needed.
+ // Note that this method should not be called if the encoder is
+ // not supposed to produce data. Ie, the current allowed bitrate is zero.
+ // May be called on an arbitrary thread.
+ virtual void OnEncoderActivityChanged(bool running) = 0;
+
+ protected:
+ virtual ~VideoEncoderSink() {}
+};
+
class ViEEncoder : public VideoEncoderRateObserver,
public EncodedImageCallback,
public VCMSendStatisticsCallback {
@@ -59,8 +76,7 @@ class ViEEncoder : public VideoEncoderRateObserver,
ProcessThread* module_process_thread,
SendStatisticsProxy* stats_proxy,
OveruseFrameDetector* overuse_detector,
- EncodedImageCallback* sink);
-
+ VideoEncoderSink* sink);
~ViEEncoder();
vcm::VideoSender* video_sender();
@@ -78,12 +94,19 @@ class ViEEncoder : public VideoEncoderRateObserver,
bool internal_source);
int32_t DeRegisterExternalEncoder(uint8_t pl_type);
void SetEncoder(const VideoCodec& video_codec,
- int min_transmit_bitrate_bps,
size_t max_data_payload_length);
void EncodeVideoFrame(const VideoFrame& video_frame);
void SendKeyFrame();
+ // Checks to see if the encoder has produced anything during the last
+ // VideoEncoderSink::TimeOutMs period and if the state has changed, calls
+ // VideoEncoderSink::OnEncoderActivityChanged.
+ // Must be called periodically.
+ // TODO(perkj): CheckForActivity should be replaced with an internal timer
+ // once ViEncoder owns the encoder thread.
+ void CheckForActivity();
+
// Implements VideoEncoderRateObserver.
// TODO(perkj): Refactor VideoEncoderRateObserver. This is only used for
// stats. The stats should be set in VideoSendStream instead.
@@ -106,8 +129,6 @@ class ViEEncoder : public VideoEncoderRateObserver,
virtual void OnReceivedSLI(uint8_t picture_id);
virtual void OnReceivedRPSI(uint64_t picture_id);
- int GetPaddingNeededBps() const;
-
void OnBitrateUpdated(uint32_t bitrate_bps,
uint8_t fraction_lost,
int64_t round_trip_time_ms);
@@ -118,7 +139,7 @@ class ViEEncoder : public VideoEncoderRateObserver,
void TraceFrameDropEnd() EXCLUSIVE_LOCKS_REQUIRED(data_cs_);
const uint32_t number_of_cores_;
- EncodedImageCallback* const sink_;
+ VideoEncoderSink* const sink_;
const std::unique_ptr<VideoProcessing> vp_;
vcm::VideoSender video_sender_;
@@ -133,10 +154,10 @@ class ViEEncoder : public VideoEncoderRateObserver,
// padding.
int64_t time_of_last_frame_activity_ms_ GUARDED_BY(data_cs_);
VideoCodec encoder_config_ GUARDED_BY(data_cs_);
- int min_transmit_bitrate_bps_ GUARDED_BY(data_cs_);
uint32_t last_observed_bitrate_bps_ GUARDED_BY(data_cs_);
bool encoder_paused_ GUARDED_BY(data_cs_);
bool encoder_paused_and_dropped_frame_ GUARDED_BY(data_cs_);
+ bool reported_timeout_ GUARDED_BY(data_cs_);
ProcessThread* module_process_thread_;

Powered by Google App Engine
This is Rietveld 408576698