Chromium Code Reviews| Index: webrtc/modules/video_coding/codecs/vp9/vp9_impl.h |
| diff --git a/webrtc/modules/video_coding/codecs/vp9/vp9_impl.h b/webrtc/modules/video_coding/codecs/vp9/vp9_impl.h |
| index c164a63980f2dedf54149e4f6e30477682f947e8..32475e64ddb0b7d21f780c28ea5c6c8419e188d4 100644 |
| --- a/webrtc/modules/video_coding/codecs/vp9/vp9_impl.h |
| +++ b/webrtc/modules/video_coding/codecs/vp9/vp9_impl.h |
| @@ -21,6 +21,8 @@ |
| namespace webrtc { |
| +class ScreenshareLayersVP9; |
| + |
| class VP9EncoderImpl : public VP9Encoder { |
| public: |
| VP9EncoderImpl(); |
| @@ -45,6 +47,20 @@ class VP9EncoderImpl : public VP9Encoder { |
| void OnDroppedFrame() override {} |
| + struct LayerFrameRefSettings { |
| + int8_t upd_buf = -1; // -1 - no update, 0..7 - update buffer 0..7 |
| + int8_t ref_buf1 = -1; // -1 - no reference, 0..7 - reference buffer 0..7 |
| + int8_t ref_buf2 = -1; // -1 - no reference, 0..7 - reference buffer 0..7 |
| + int8_t ref_buf3 = -1; // -1 - no reference, 0..7 - reference buffer 0..7 |
| + }; |
| + |
| + struct SuperFrameRefSettings { |
| + LayerFrameRefSettings layer[kMaxVp9NumberOfSpatialLayers]; |
| + uint8_t start_layer = 0; |
| + uint8_t stop_layer = 0; // Not used anywhere right now |
|
sprang_webrtc
2015/09/15 15:41:22
Either don't include it or comment on what it shou
philipel
2015/09/16 09:35:54
Hmmm... tricky situation where the field is used b
|
| + bool is_keyframe = false; |
| + }; |
| + |
| private: |
| // Determine number of encoder threads to use. |
| int NumberOfThreads(int width, int height, int number_of_cores); |
| @@ -58,6 +74,17 @@ class VP9EncoderImpl : public VP9Encoder { |
| bool SetSvcRates(); |
| + /* |
| + * Used for flexible mode to set the flags and buffer references used |
| + * by the encoder. Also calculates the references used by the RTP |
| + * packetizer. |
| + * |
| + * Has to be called for every frame (keyframes included) to update the |
| + * state used to calculate references. |
| + */ |
| + vpx_svc_ref_frame_config GenerateRefsAndFlags( |
| + const SuperFrameRefSettings& settings); |
| + |
| virtual int GetEncodedLayerFrame(const vpx_codec_cx_pkt* pkt); |
| // Callback function for outputting packets per spatial layer. |
| @@ -88,9 +115,17 @@ class VP9EncoderImpl : public VP9Encoder { |
| GofInfoVP9 gof_; // Contains each frame's temporal information for |
| // non-flexible mode. |
| uint8_t tl0_pic_idx_; // Only used in non-flexible mode. |
| - size_t gof_idx_; // Only used in non-flexible mode. |
| + size_t frames_since_kf_; |
| uint8_t num_temporal_layers_; |
| uint8_t num_spatial_layers_; |
| + |
| + // Used for flexible mode |
|
sprang_webrtc
2015/09/15 15:41:22
.
philipel
2015/09/16 09:35:54
Done.
|
| + bool is_flexible_mode_; |
| + int64_t buf_upd_at_frame_[8]; |
|
sprang_webrtc
2015/09/15 15:41:22
Use a named constant instead of 8.
philipel
2015/09/16 09:35:54
Done.
|
| + int64_t frames_encoded_; |
| + uint8_t num_ref_pics_[kMaxVp9NumberOfSpatialLayers]; |
| + uint16_t p_diff_[kMaxVp9NumberOfSpatialLayers][kMaxVp9RefPics]; |
| + rtc::scoped_ptr<ScreenshareLayersVP9> spatial_layer_; |
| }; |