blob: 1e9e374c644e83513760e6dbb1a65f30e66d72cc [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
pwestin@webrtc.orgddab60b2012-04-23 14:52:15 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "modules/video_coding/encoded_frame.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000012
Yves Gerey3e707812018-11-28 16:47:49 +010013#include <string.h>
14
15#include "absl/types/variant.h"
16#include "api/video/video_timing.h"
17#include "modules/video_coding/codecs/interface/common_constants.h"
18#include "modules/video_coding/codecs/vp8/include/vp8_globals.h"
19#include "modules/video_coding/codecs/vp9/include/vp9_globals.h"
20
niklase@google.com470e71d2011-07-07 08:21:25 +000021namespace webrtc {
22
23VCMEncodedFrame::VCMEncodedFrame()
guoweis@webrtc.org54d072e2015-03-17 21:54:50 +000024 : webrtc::EncodedImage(),
25 _renderTimeMs(-1),
26 _payloadType(0),
27 _missingFrame(false),
philipel5dacece2019-09-26 10:59:41 +020028 _codec(kVideoCodecGeneric) {
Kári Tristan Helgason84ccb2d2018-08-16 14:35:26 +020029 _codecSpecificInfo.codecType = kVideoCodecGeneric;
niklase@google.com470e71d2011-07-07 08:21:25 +000030}
31
philipel6c42d922019-06-20 11:13:03 +020032VCMEncodedFrame::VCMEncodedFrame(const VCMEncodedFrame&) = default;
33
philipel9d3ab612015-12-21 04:12:39 -080034VCMEncodedFrame::~VCMEncodedFrame() {
philipel9d3ab612015-12-21 04:12:39 -080035 Reset();
niklase@google.com470e71d2011-07-07 08:21:25 +000036}
37
philipel9d3ab612015-12-21 04:12:39 -080038void VCMEncodedFrame::Reset() {
Niels Möller23775882018-08-16 10:24:12 +020039 SetTimestamp(0);
Sergey Silkin61832dd2018-12-20 14:32:14 +010040 SetSpatialIndex(absl::nullopt);
philipel9d3ab612015-12-21 04:12:39 -080041 _renderTimeMs = -1;
philipel9d3ab612015-12-21 04:12:39 -080042 _payloadType = 0;
Niels Möller8f7ce222019-03-21 15:43:58 +010043 _frameType = VideoFrameType::kVideoFrameDelta;
philipel9d3ab612015-12-21 04:12:39 -080044 _encodedWidth = 0;
45 _encodedHeight = 0;
46 _completeFrame = false;
47 _missingFrame = false;
Niels Möller77536a22019-01-15 08:50:01 +010048 set_size(0);
Kári Tristan Helgason84ccb2d2018-08-16 14:35:26 +020049 _codecSpecificInfo.codecType = kVideoCodecGeneric;
50 _codec = kVideoCodecGeneric;
perkj414dda12016-07-04 01:45:23 -070051 rotation_ = kVideoRotation_0;
ilnik00d802b2017-04-11 10:34:31 -070052 content_type_ = VideoContentType::UNSPECIFIED;
Ilya Nikolaevskiyb6c462d2018-06-05 15:21:32 +020053 timing_.flags = VideoSendTiming::kInvalid;
niklase@google.com470e71d2011-07-07 08:21:25 +000054}
55
philipel9d3ab612015-12-21 04:12:39 -080056void VCMEncodedFrame::CopyCodecSpecific(const RTPVideoHeader* header) {
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000057 if (header) {
58 switch (header->codec) {
Niels Möller520ca4e2018-06-04 11:14:38 +020059 case kVideoCodecVP8: {
Philip Eliassond52a1a62018-09-07 13:03:55 +000060 const auto& vp8_header =
61 absl::get<RTPVideoHeaderVP8>(header->video_type_header);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000062 if (_codecSpecificInfo.codecType != kVideoCodecVP8) {
63 // This is the first packet for this frame.
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000064 _codecSpecificInfo.codecSpecific.VP8.temporalIdx = 0;
65 _codecSpecificInfo.codecSpecific.VP8.layerSync = false;
66 _codecSpecificInfo.codecSpecific.VP8.keyIdx = -1;
67 _codecSpecificInfo.codecType = kVideoCodecVP8;
henrik.lundin@webrtc.org473bac82011-08-17 09:47:33 +000068 }
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000069 _codecSpecificInfo.codecSpecific.VP8.nonReference =
Philip Eliassond52a1a62018-09-07 13:03:55 +000070 vp8_header.nonReference;
71 if (vp8_header.temporalIdx != kNoTemporalIdx) {
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000072 _codecSpecificInfo.codecSpecific.VP8.temporalIdx =
Philip Eliassond52a1a62018-09-07 13:03:55 +000073 vp8_header.temporalIdx;
74 _codecSpecificInfo.codecSpecific.VP8.layerSync = vp8_header.layerSync;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000075 }
Philip Eliassond52a1a62018-09-07 13:03:55 +000076 if (vp8_header.keyIdx != kNoKeyIdx) {
77 _codecSpecificInfo.codecSpecific.VP8.keyIdx = vp8_header.keyIdx;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000078 }
79 break;
80 }
Niels Möller520ca4e2018-06-04 11:14:38 +020081 case kVideoCodecVP9: {
philipel29d88462018-08-08 14:26:00 +020082 const auto& vp9_header =
83 absl::get<RTPVideoHeaderVP9>(header->video_type_header);
asaperssona9455ab2015-07-31 06:10:09 -070084 if (_codecSpecificInfo.codecType != kVideoCodecVP9) {
85 // This is the first packet for this frame.
asaperssona9455ab2015-07-31 06:10:09 -070086 _codecSpecificInfo.codecSpecific.VP9.temporal_idx = 0;
asaperssona9455ab2015-07-31 06:10:09 -070087 _codecSpecificInfo.codecSpecific.VP9.gof_idx = 0;
88 _codecSpecificInfo.codecSpecific.VP9.inter_layer_predicted = false;
asaperssona9455ab2015-07-31 06:10:09 -070089 _codecSpecificInfo.codecType = kVideoCodecVP9;
90 }
91 _codecSpecificInfo.codecSpecific.VP9.inter_pic_predicted =
philipel29d88462018-08-08 14:26:00 +020092 vp9_header.inter_pic_predicted;
asaperssona9455ab2015-07-31 06:10:09 -070093 _codecSpecificInfo.codecSpecific.VP9.flexible_mode =
philipel29d88462018-08-08 14:26:00 +020094 vp9_header.flexible_mode;
philipelcfc319b2015-11-10 07:17:23 -080095 _codecSpecificInfo.codecSpecific.VP9.num_ref_pics =
philipel29d88462018-08-08 14:26:00 +020096 vp9_header.num_ref_pics;
97 for (uint8_t r = 0; r < vp9_header.num_ref_pics; ++r) {
philipelcfc319b2015-11-10 07:17:23 -080098 _codecSpecificInfo.codecSpecific.VP9.p_diff[r] =
philipel29d88462018-08-08 14:26:00 +020099 vp9_header.pid_diff[r];
philipelcfc319b2015-11-10 07:17:23 -0800100 }
asaperssona9455ab2015-07-31 06:10:09 -0700101 _codecSpecificInfo.codecSpecific.VP9.ss_data_available =
philipel29d88462018-08-08 14:26:00 +0200102 vp9_header.ss_data_available;
103 if (vp9_header.temporal_idx != kNoTemporalIdx) {
asaperssona9455ab2015-07-31 06:10:09 -0700104 _codecSpecificInfo.codecSpecific.VP9.temporal_idx =
philipel29d88462018-08-08 14:26:00 +0200105 vp9_header.temporal_idx;
asaperssona9455ab2015-07-31 06:10:09 -0700106 _codecSpecificInfo.codecSpecific.VP9.temporal_up_switch =
philipel29d88462018-08-08 14:26:00 +0200107 vp9_header.temporal_up_switch;
asaperssona9455ab2015-07-31 06:10:09 -0700108 }
philipel29d88462018-08-08 14:26:00 +0200109 if (vp9_header.spatial_idx != kNoSpatialIdx) {
asaperssona9455ab2015-07-31 06:10:09 -0700110 _codecSpecificInfo.codecSpecific.VP9.inter_layer_predicted =
philipel29d88462018-08-08 14:26:00 +0200111 vp9_header.inter_layer_predicted;
Sergey Silkin61832dd2018-12-20 14:32:14 +0100112 SetSpatialIndex(vp9_header.spatial_idx);
asaperssona9455ab2015-07-31 06:10:09 -0700113 }
philipel29d88462018-08-08 14:26:00 +0200114 if (vp9_header.gof_idx != kNoGofIdx) {
115 _codecSpecificInfo.codecSpecific.VP9.gof_idx = vp9_header.gof_idx;
asaperssona9455ab2015-07-31 06:10:09 -0700116 }
philipel29d88462018-08-08 14:26:00 +0200117 if (vp9_header.ss_data_available) {
asaperssona9455ab2015-07-31 06:10:09 -0700118 _codecSpecificInfo.codecSpecific.VP9.num_spatial_layers =
philipel29d88462018-08-08 14:26:00 +0200119 vp9_header.num_spatial_layers;
asaperssona9455ab2015-07-31 06:10:09 -0700120 _codecSpecificInfo.codecSpecific.VP9
121 .spatial_layer_resolution_present =
philipel29d88462018-08-08 14:26:00 +0200122 vp9_header.spatial_layer_resolution_present;
123 if (vp9_header.spatial_layer_resolution_present) {
124 for (size_t i = 0; i < vp9_header.num_spatial_layers; ++i) {
asaperssona9455ab2015-07-31 06:10:09 -0700125 _codecSpecificInfo.codecSpecific.VP9.width[i] =
philipel29d88462018-08-08 14:26:00 +0200126 vp9_header.width[i];
asaperssona9455ab2015-07-31 06:10:09 -0700127 _codecSpecificInfo.codecSpecific.VP9.height[i] =
philipel29d88462018-08-08 14:26:00 +0200128 vp9_header.height[i];
asaperssona9455ab2015-07-31 06:10:09 -0700129 }
130 }
131 _codecSpecificInfo.codecSpecific.VP9.gof.CopyGofInfoVP9(
philipel29d88462018-08-08 14:26:00 +0200132 vp9_header.gof);
asaperssona9455ab2015-07-31 06:10:09 -0700133 }
134 break;
135 }
Niels Möller520ca4e2018-06-04 11:14:38 +0200136 case kVideoCodecH264: {
stefan@webrtc.org2ec56062014-07-31 14:59:24 +0000137 _codecSpecificInfo.codecType = kVideoCodecH264;
Johnny Lee1a1c52b2019-02-08 14:25:40 -0500138
139 // The following H264 codec specific data are not used elsewhere.
140 // Instead they are read directly from the frame marking extension.
141 // These codec specific data structures should be removed
142 // when frame marking is used.
143 _codecSpecificInfo.codecSpecific.H264.temporal_idx = kNoTemporalIdx;
144 if (header->frame_marking.temporal_id != kNoTemporalIdx) {
145 _codecSpecificInfo.codecSpecific.H264.temporal_idx =
146 header->frame_marking.temporal_id;
147 _codecSpecificInfo.codecSpecific.H264.base_layer_sync =
148 header->frame_marking.base_layer_sync;
149 _codecSpecificInfo.codecSpecific.H264.idr_frame =
150 header->frame_marking.independent_frame;
151 }
stefan@webrtc.org2ec56062014-07-31 14:59:24 +0000152 break;
153 }
Niels Möller520ca4e2018-06-04 11:14:38 +0200154 default: {
Kári Tristan Helgason84ccb2d2018-08-16 14:35:26 +0200155 _codecSpecificInfo.codecType = kVideoCodecGeneric;
stefan@webrtc.org2ec56062014-07-31 14:59:24 +0000156 break;
157 }
henrik.lundin@webrtc.org473bac82011-08-17 09:47:33 +0000158 }
stefan@webrtc.org2ec56062014-07-31 14:59:24 +0000159 }
henrik.lundin@webrtc.org473bac82011-08-17 09:47:33 +0000160}
161
pbos22993e12015-10-19 02:39:06 -0700162} // namespace webrtc