| Index: webrtc/video/encoder_state_feedback.cc
|
| diff --git a/webrtc/video/encoder_state_feedback.cc b/webrtc/video/encoder_state_feedback.cc
|
| index f0b03a13fef4a15f3206d74bd17cd62b7d5ced27..0240e487a6a7090d0c8919683948322f5451932a 100644
|
| --- a/webrtc/video/encoder_state_feedback.cc
|
| +++ b/webrtc/video/encoder_state_feedback.cc
|
| @@ -10,113 +10,75 @@
|
|
|
| #include "webrtc/video/encoder_state_feedback.h"
|
|
|
| -#include <assert.h>
|
| -
|
| #include "webrtc/base/checks.h"
|
| -#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h"
|
| #include "webrtc/video/vie_encoder.h"
|
|
|
| namespace webrtc {
|
|
|
| -// Helper class registered at the RTP module relaying callbacks to
|
| -// EncoderStatFeedback.
|
| -class EncoderStateFeedbackObserver : public RtcpIntraFrameObserver {
|
| - public:
|
| - explicit EncoderStateFeedbackObserver(EncoderStateFeedback* owner)
|
| - : owner_(owner) {}
|
| - ~EncoderStateFeedbackObserver() {}
|
| -
|
| - // Implements RtcpIntraFrameObserver.
|
| - virtual void OnReceivedIntraFrameRequest(uint32_t ssrc) {
|
| - owner_->OnReceivedIntraFrameRequest(ssrc);
|
| - }
|
| - virtual void OnReceivedSLI(uint32_t ssrc, uint8_t picture_id) {
|
| - owner_->OnReceivedSLI(ssrc, picture_id);
|
| - }
|
| - virtual void OnReceivedRPSI(uint32_t ssrc, uint64_t picture_id) {
|
| - owner_->OnReceivedRPSI(ssrc, picture_id);
|
| - }
|
| -
|
| - virtual void OnLocalSsrcChanged(uint32_t old_ssrc, uint32_t new_ssrc) {
|
| - owner_->OnLocalSsrcChanged(old_ssrc, new_ssrc);
|
| - }
|
| -
|
| - private:
|
| - EncoderStateFeedback* owner_;
|
| -};
|
| -
|
| -EncoderStateFeedback::EncoderStateFeedback()
|
| - : observer_(new EncoderStateFeedbackObserver(this)) {}
|
| +EncoderStateFeedback::EncoderStateFeedback() : vie_encoder_(nullptr) {}
|
|
|
| -EncoderStateFeedback::~EncoderStateFeedback() {
|
| - assert(encoders_.empty());
|
| -}
|
| -
|
| -void EncoderStateFeedback::AddEncoder(const std::vector<uint32_t>& ssrcs,
|
| - ViEEncoder* encoder) {
|
| +void EncoderStateFeedback::Init(const std::vector<uint32_t>& ssrcs,
|
| + ViEEncoder* encoder) {
|
| RTC_DCHECK(!ssrcs.empty());
|
| rtc::CritScope lock(&crit_);
|
| - for (uint32_t ssrc : ssrcs) {
|
| - RTC_DCHECK(encoders_.find(ssrc) == encoders_.end());
|
| - encoders_[ssrc] = encoder;
|
| - }
|
| + ssrcs_ = ssrcs;
|
| + vie_encoder_ = encoder;
|
| }
|
|
|
| -void EncoderStateFeedback::RemoveEncoder(const ViEEncoder* encoder) {
|
| +void EncoderStateFeedback::TearDown() {
|
| rtc::CritScope lock(&crit_);
|
| - SsrcEncoderMap::iterator it = encoders_.begin();
|
| - while (it != encoders_.end()) {
|
| - if (it->second == encoder) {
|
| - encoders_.erase(it++);
|
| - } else {
|
| - ++it;
|
| - }
|
| - }
|
| + RTC_DCHECK(vie_encoder_);
|
| + ssrcs_.clear();
|
| + vie_encoder_ = nullptr;
|
| }
|
|
|
| -RtcpIntraFrameObserver* EncoderStateFeedback::GetRtcpIntraFrameObserver() {
|
| - return observer_.get();
|
| +bool EncoderStateFeedback::HasSsrc(uint32_t ssrc) {
|
| + for (uint32_t registered_ssrc : ssrcs_) {
|
| + if (registered_ssrc == ssrc)
|
| + return true;
|
| + }
|
| + return false;
|
| }
|
|
|
| void EncoderStateFeedback::OnReceivedIntraFrameRequest(uint32_t ssrc) {
|
| rtc::CritScope lock(&crit_);
|
| - SsrcEncoderMap::iterator it = encoders_.find(ssrc);
|
| - if (it == encoders_.end())
|
| + if (!HasSsrc(ssrc))
|
| return;
|
| + RTC_DCHECK(vie_encoder_);
|
|
|
| - it->second->OnReceivedIntraFrameRequest(ssrc);
|
| + vie_encoder_->OnReceivedIntraFrameRequest(ssrc);
|
| }
|
|
|
| void EncoderStateFeedback::OnReceivedSLI(uint32_t ssrc, uint8_t picture_id) {
|
| rtc::CritScope lock(&crit_);
|
| - SsrcEncoderMap::iterator it = encoders_.find(ssrc);
|
| - if (it == encoders_.end())
|
| + if (!HasSsrc(ssrc))
|
| return;
|
| + RTC_DCHECK(vie_encoder_);
|
|
|
| - it->second->OnReceivedSLI(ssrc, picture_id);
|
| + vie_encoder_->OnReceivedSLI(ssrc, picture_id);
|
| }
|
|
|
| void EncoderStateFeedback::OnReceivedRPSI(uint32_t ssrc, uint64_t picture_id) {
|
| rtc::CritScope lock(&crit_);
|
| - SsrcEncoderMap::iterator it = encoders_.find(ssrc);
|
| - if (it == encoders_.end())
|
| + if (!HasSsrc(ssrc))
|
| return;
|
| + RTC_DCHECK(vie_encoder_);
|
|
|
| - it->second->OnReceivedRPSI(ssrc, picture_id);
|
| + vie_encoder_->OnReceivedRPSI(ssrc, picture_id);
|
| }
|
|
|
| +// Sending SSRCs for this encoder should never change since they are configured
|
| +// once and not reconfigured.
|
| void EncoderStateFeedback::OnLocalSsrcChanged(uint32_t old_ssrc,
|
| uint32_t new_ssrc) {
|
| + if (!RTC_DCHECK_IS_ON)
|
| + return;
|
| rtc::CritScope lock(&crit_);
|
| - SsrcEncoderMap::iterator it = encoders_.find(old_ssrc);
|
| - if (it == encoders_.end() || encoders_.find(new_ssrc) != encoders_.end()) {
|
| + if (ssrcs_.empty()) // Encoder not yet attached (or detached for teardown).
|
| return;
|
| - }
|
| -
|
| - ViEEncoder* encoder = it->second;
|
| - encoders_.erase(it);
|
| - encoders_[new_ssrc] = encoder;
|
| - encoder->OnLocalSsrcChanged(old_ssrc, new_ssrc);
|
| + // SSRC shouldn't change to something we haven't already registered with the
|
| + // encoder.
|
| + RTC_DCHECK(HasSsrc(new_ssrc));
|
| }
|
|
|
| } // namespace webrtc
|
|
|