rtp_rtcp implementation. This refactoring significantly reduces the receive-side RTP parser and receiver complexity, and makes it possible to implement RTX correctly by having two instances of receive-statistics. With this change the dead-or-alive and packet timeout APIs are removed. TEST=trybots, vie_auto_test, voe_auto_test BUG=1811 R=mflodman@webrtc.org, pbos@webrtc.org, xians@webrtc.org Review URL: https://webrtc-codereview.appspot.com/1745004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@4301 4adac7df-926f-26a2-2b94-8c16560cd09d
42 lines
1.3 KiB
C++
42 lines
1.3 KiB
C++
/*
|
|
* Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_receiver_strategy.h"
|
|
|
|
#include <cstdlib>
|
|
|
|
#include "webrtc/system_wrappers/interface/critical_section_wrapper.h"
|
|
|
|
namespace webrtc {
|
|
|
|
RTPReceiverStrategy::RTPReceiverStrategy(RtpData* data_callback)
|
|
: crit_sect_(CriticalSectionWrapper::CreateCriticalSection()),
|
|
data_callback_(data_callback) {
|
|
memset(&last_payload_, 0, sizeof(last_payload_));
|
|
}
|
|
|
|
void RTPReceiverStrategy::GetLastMediaSpecificPayload(
|
|
PayloadUnion* payload) const {
|
|
CriticalSectionScoped cs(crit_sect_.get());
|
|
memcpy(payload, &last_payload_, sizeof(*payload));
|
|
}
|
|
|
|
void RTPReceiverStrategy::SetLastMediaSpecificPayload(
|
|
const PayloadUnion& payload) {
|
|
CriticalSectionScoped cs(crit_sect_.get());
|
|
memcpy(&last_payload_, &payload, sizeof(last_payload_));
|
|
}
|
|
|
|
int RTPReceiverStrategy::Energy(uint8_t array_of_energy[kRtpCsrcSize]) const {
|
|
return 0;
|
|
}
|
|
|
|
} // namespace webrtc
|