Index: remoting/host/capture_scheduler.h |
diff --git a/remoting/host/capture_scheduler.h b/remoting/host/capture_scheduler.h |
index b3136e78d84d88f5b526b830dd095893b10de7e9..42a1657879506e8176bc9bdfc6e0f644c98afe30 100644 |
--- a/remoting/host/capture_scheduler.h |
+++ b/remoting/host/capture_scheduler.h |
@@ -2,29 +2,35 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-// This class chooses a capture interval so as to limit CPU usage to not exceed |
-// a specified %age. It bases this on the CPU usage of recent capture and encode |
-// operations, and on the number of available CPUs. |
- |
#ifndef REMOTING_HOST_CAPTURE_SCHEDULER_H_ |
#define REMOTING_HOST_CAPTURE_SCHEDULER_H_ |
#include "base/callback.h" |
-#include "base/threading/non_thread_safe.h" |
+#include "base/threading/thread_checker.h" |
#include "base/time/tick_clock.h" |
#include "base/time/time.h" |
#include "base/timer/timer.h" |
#include "remoting/base/running_average.h" |
+#include "remoting/protocol/video_feedback_stub.h" |
namespace remoting { |
+class VideoPacket; |
+ |
// CaptureScheduler is used by the VideoFramePump to schedule frame capturer, |
// taking into account capture delay, encoder delay, network bandwidth, etc. |
-class CaptureScheduler : public base::NonThreadSafe { |
+// It implements VideoFeedbackStub to receive frame acknowledgments from the |
+// client. |
+// |
+// It attempts to achieve the following goals when scheduling frames: |
+// - Keep round-trip latency as low a possible. |
+// - Parallelize capture, encode and transmission, to achieve frame rate as |
+// close to the target of 30fps as possible. |
+// - Limit CPU usage to 50%. |
+class CaptureScheduler : public protocol::VideoFeedbackStub { |
public: |
- // |capture_closure| is called every time a new frame needs to be captured. |
explicit CaptureScheduler(const base::Closure& capture_closure); |
- ~CaptureScheduler(); |
+ ~CaptureScheduler() override; |
// Starts the scheduler. |
void Start(); |
@@ -35,12 +41,16 @@ class CaptureScheduler : public base::NonThreadSafe { |
// Notifies the scheduler that a capture has been completed. |
void OnCaptureCompleted(); |
- // Notifies the scheduler that a frame has been encoded. |
- void OnFrameEncoded(base::TimeDelta encode_time); |
+ // Notifies the scheduler that a frame has been encoded. The scheduler can |
+ // change |packet| if necessary, e.g. set |frame_id|. |
+ void OnFrameEncoded(VideoPacket* packet); |
// Notifies the scheduler that a frame has been sent. |
void OnFrameSent(); |
+ // VideoFeedbackStub interface. |
+ void ProcessVideoAck(scoped_ptr<VideoAck> video_ack) override; |
+ |
// Sets minimum interval between frames. |
void set_minimum_interval(base::TimeDelta minimum_interval) { |
minimum_interval_ = minimum_interval; |
@@ -63,6 +73,9 @@ class CaptureScheduler : public base::NonThreadSafe { |
base::Closure capture_closure_; |
+ // Set to true if the connection supports video frame acknowledgments. |
+ bool acks_supported_; |
+ |
scoped_ptr<base::TickClock> tick_clock_; |
// Timer used to schedule CaptureNextFrame(). |
@@ -76,8 +89,14 @@ class CaptureScheduler : public base::NonThreadSafe { |
RunningAverage capture_time_; |
RunningAverage encode_time_; |
- // Total number of pending frames that are being captured, encoded or sent. |
- int pending_frames_; |
+ // Number of frames pending encoding. |
+ int num_encoding_frames_; |
+ |
+ // Number of frames in the sending queue. |
+ int num_sending_frames_; |
+ |
+ // Number of outgoing frames for which we haven't received an acknowledgment. |
+ int num_unacknowledged_frames_; |
// Set to true when capture is pending. |
bool capture_pending_; |
@@ -87,6 +106,11 @@ class CaptureScheduler : public base::NonThreadSafe { |
bool is_paused_; |
+ // Frame ID to be assigned to the next outgoing video frame. |
+ uint32_t next_frame_id_; |
+ |
+ base::ThreadChecker thread_checker_; |
+ |
DISALLOW_COPY_AND_ASSIGN(CaptureScheduler); |
}; |