Index: webrtc/modules/video_coding/generic_decoder.cc |
diff --git a/webrtc/modules/video_coding/generic_decoder.cc b/webrtc/modules/video_coding/generic_decoder.cc |
index b1059e8a1b6997a378b85400d57860a5b7cdf878..34500c69e2a39f9b69b0e2488318ce75ee0e370f 100644 |
--- a/webrtc/modules/video_coding/generic_decoder.cc |
+++ b/webrtc/modules/video_coding/generic_decoder.cc |
@@ -48,6 +48,16 @@ |
int32_t VCMDecodedFrameCallback::Decoded(VideoFrame& decodedImage, |
int64_t decode_time_ms) { |
+ Decoded(decodedImage, |
+ decode_time_ms >= 0 ? rtc::Optional<int32_t>(decode_time_ms) |
+ : rtc::Optional<int32_t>(), |
+ rtc::Optional<uint8_t>()); |
+ return WEBRTC_VIDEO_CODEC_OK; |
+} |
+ |
+void VCMDecodedFrameCallback::Decoded(VideoFrame& decodedImage, |
+ rtc::Optional<int32_t> decode_time_ms, |
+ rtc::Optional<uint8_t> qp) { |
TRACE_EVENT_INSTANT1("webrtc", "VCMDecodedFrameCallback::Decoded", |
"timestamp", decodedImage.timestamp()); |
// TODO(holmer): We should improve this so that we can handle multiple |
@@ -63,15 +73,15 @@ |
if (frameInfo == NULL) { |
LOG(LS_WARNING) << "Too many frames backed up in the decoder, dropping " |
"this one."; |
- return WEBRTC_VIDEO_CODEC_OK; |
+ return; |
} |
const int64_t now_ms = _clock->TimeInMilliseconds(); |
- if (decode_time_ms < 0) { |
+ if (!decode_time_ms) { |
decode_time_ms = |
- static_cast<int32_t>(now_ms - frameInfo->decodeStartTimeMs); |
- } |
- _timing->StopDecodeTimer(decodedImage.timestamp(), decode_time_ms, now_ms, |
+ rtc::Optional<int32_t>(now_ms - frameInfo->decodeStartTimeMs); |
+ } |
+ _timing->StopDecodeTimer(decodedImage.timestamp(), *decode_time_ms, now_ms, |
frameInfo->renderTimeMs); |
decodedImage.set_timestamp_us( |
@@ -80,11 +90,10 @@ |
// TODO(sakal): Investigate why callback is NULL sometimes and replace if |
// statement with a DCHECK. |
if (callback) { |
- callback->FrameToRender(decodedImage); |
+ callback->FrameToRender(decodedImage, qp); |
} else { |
LOG(LS_WARNING) << "No callback, dropping frame."; |
} |
- return WEBRTC_VIDEO_CODEC_OK; |
} |
int32_t VCMDecodedFrameCallback::ReceivedDecodedReferenceFrame( |