mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 13:50:40 +01:00

There's been reports of dropped frames that are not counted and correctly reported by getStats(). If a HW decoder is used and the system is provoked by stressing the system, I've been able to reproduce this problem. It turns out that we've missed frames that are dropped because there is no callback to the Decoded() function. This CL restructures the code so that dropped frames are counted even in cases where there's no corresponding callback for some frames. Bug: webrtc:11229 Change-Id: I0216edba3733399c188649908d459ee86a9093d0 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/214783 Commit-Queue: Johannes Kron <kron@webrtc.org> Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Cr-Commit-Position: refs/heads/master@{#33671}
63 lines
1.7 KiB
C++
63 lines
1.7 KiB
C++
/*
|
|
* Copyright (c) 2011 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.
|
|
*/
|
|
|
|
#ifndef MODULES_VIDEO_CODING_TIMESTAMP_MAP_H_
|
|
#define MODULES_VIDEO_CODING_TIMESTAMP_MAP_H_
|
|
|
|
#include <memory>
|
|
|
|
#include "absl/types/optional.h"
|
|
#include "api/rtp_packet_infos.h"
|
|
#include "api/units/timestamp.h"
|
|
#include "api/video/encoded_image.h"
|
|
#include "api/video/video_content_type.h"
|
|
#include "api/video/video_rotation.h"
|
|
#include "api/video/video_timing.h"
|
|
|
|
namespace webrtc {
|
|
|
|
struct VCMFrameInformation {
|
|
int64_t renderTimeMs;
|
|
absl::optional<Timestamp> decodeStart;
|
|
void* userData;
|
|
VideoRotation rotation;
|
|
VideoContentType content_type;
|
|
EncodedImage::Timing timing;
|
|
int64_t ntp_time_ms;
|
|
RtpPacketInfos packet_infos;
|
|
// ColorSpace is not stored here, as it might be modified by decoders.
|
|
};
|
|
|
|
class VCMTimestampMap {
|
|
public:
|
|
explicit VCMTimestampMap(size_t capacity);
|
|
~VCMTimestampMap();
|
|
|
|
void Add(uint32_t timestamp, const VCMFrameInformation& data);
|
|
absl::optional<VCMFrameInformation> Pop(uint32_t timestamp);
|
|
size_t Size() const;
|
|
void Clear();
|
|
|
|
private:
|
|
struct TimestampDataTuple {
|
|
uint32_t timestamp;
|
|
VCMFrameInformation data;
|
|
};
|
|
bool IsEmpty() const;
|
|
|
|
std::unique_ptr<TimestampDataTuple[]> ring_buffer_;
|
|
const size_t capacity_;
|
|
size_t next_add_idx_;
|
|
size_t next_pop_idx_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_VIDEO_CODING_TIMESTAMP_MAP_H_
|