Fix potential VCMReceiver crash.
BUG= TEST= Review URL: https://webrtc-codereview.appspot.com/368012 git-svn-id: http://webrtc.googlecode.com/svn/trunk@1578 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
2919e95c2a
commit
91c630851a
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
|
* Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Use of this source code is governed by a BSD-style license
|
* 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
|
* that can be found in the LICENSE file in the root of the source
|
||||||
@ -8,17 +8,17 @@
|
|||||||
* be found in the AUTHORS file in the root of the source tree.
|
* be found in the AUTHORS file in the root of the source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "receiver.h"
|
#include "modules/video_coding/main/source/receiver.h"
|
||||||
|
|
||||||
#include "encoded_frame.h"
|
|
||||||
#include "internal_defines.h"
|
|
||||||
#include "media_opt_util.h"
|
|
||||||
#include "tick_time_base.h"
|
|
||||||
#include "trace.h"
|
|
||||||
#include "video_coding.h"
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "modules/video_coding/main/interface/video_coding.h"
|
||||||
|
#include "modules/video_coding/main/source/encoded_frame.h"
|
||||||
|
#include "modules/video_coding/main/source/internal_defines.h"
|
||||||
|
#include "modules/video_coding/main/source/media_opt_util.h"
|
||||||
|
#include "modules/video_coding/main/source/tick_time_base.h"
|
||||||
|
#include "system_wrappers/interface/trace.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
|
|
||||||
VCMReceiver::VCMReceiver(VCMTiming& timing,
|
VCMReceiver::VCMReceiver(VCMTiming& timing,
|
||||||
@ -26,8 +26,7 @@ VCMReceiver::VCMReceiver(VCMTiming& timing,
|
|||||||
WebRtc_Word32 vcmId,
|
WebRtc_Word32 vcmId,
|
||||||
WebRtc_Word32 receiverId,
|
WebRtc_Word32 receiverId,
|
||||||
bool master)
|
bool master)
|
||||||
:
|
: _critSect(CriticalSectionWrapper::CreateCriticalSection()),
|
||||||
_critSect(CriticalSectionWrapper::CreateCriticalSection()),
|
|
||||||
_vcmId(vcmId),
|
_vcmId(vcmId),
|
||||||
_clock(clock),
|
_clock(clock),
|
||||||
_receiverId(receiverId),
|
_receiverId(receiverId),
|
||||||
@ -35,9 +34,7 @@ _master(master),
|
|||||||
_jitterBuffer(_clock, vcmId, receiverId, master),
|
_jitterBuffer(_clock, vcmId, receiverId, master),
|
||||||
_timing(timing),
|
_timing(timing),
|
||||||
_renderWaitEvent(*new VCMEvent()),
|
_renderWaitEvent(*new VCMEvent()),
|
||||||
_state(kPassive)
|
_state(kPassive) {}
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
VCMReceiver::~VCMReceiver()
|
VCMReceiver::~VCMReceiver()
|
||||||
{
|
{
|
||||||
@ -98,11 +95,11 @@ VCMReceiver::InsertPacket(const VCMPacket& packet,
|
|||||||
{
|
{
|
||||||
return VCM_OK;
|
return VCM_OK;
|
||||||
}
|
}
|
||||||
else if (error < 0)
|
else if (error != VCM_OK)
|
||||||
{
|
{
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
assert(buffer);
|
||||||
{
|
{
|
||||||
CriticalSectionScoped cs(_critSect);
|
CriticalSectionScoped cs(_critSect);
|
||||||
|
|
||||||
@ -193,9 +190,10 @@ VCMReceiver::InsertPacket(const VCMPacket& packet,
|
|||||||
return VCM_OK;
|
return VCM_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
VCMEncodedFrame*
|
VCMEncodedFrame* VCMReceiver::FrameForDecoding(WebRtc_UWord16 maxWaitTimeMs,
|
||||||
VCMReceiver::FrameForDecoding(WebRtc_UWord16 maxWaitTimeMs, WebRtc_Word64& nextRenderTimeMs,
|
WebRtc_Word64& nextRenderTimeMs,
|
||||||
bool renderTiming, VCMReceiver* dualReceiver)
|
bool renderTiming,
|
||||||
|
VCMReceiver* dualReceiver)
|
||||||
{
|
{
|
||||||
// No need to enter the critical section here since the jitter buffer
|
// No need to enter the critical section here since the jitter buffer
|
||||||
// is thread-safe.
|
// is thread-safe.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user