1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-24 13:56:33 +02:00

avcodec/cbs: add cbs implementation for H266/VVC

Add CodedBitstreamContext to parse VPS,SPS,PPS in VVC nal units.
Implement parsing and writing of SPS,PPS,VPS,PH,AUD,SEI and slices.
Add ff_cbs_type_h266 to cbs types tables and AV_CODEC_ID_H266
to cbs codec ids.

Co-authored-by: Thomas Siedel <thomas.ff@spin-digital.com>
Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
Nuo Mi 2023-03-21 16:01:15 +01:00 committed by James Almer
parent 136e96a8a8
commit dfc62fd1c6
8 changed files with 4390 additions and 2 deletions

2
configure vendored
View File

@ -2477,6 +2477,7 @@ CONFIG_EXTRA="
cbs_av1
cbs_h264
cbs_h265
cbs_h266
cbs_jpeg
cbs_mpeg2
cbs_vp9
@ -2761,6 +2762,7 @@ threads_if_any="$THREADS_LIST"
cbs_av1_select="cbs"
cbs_h264_select="cbs"
cbs_h265_select="cbs"
cbs_h266_select="cbs"
cbs_jpeg_select="cbs"
cbs_mpeg2_select="cbs"
cbs_vp9_select="cbs"

View File

@ -76,6 +76,7 @@ OBJS-$(CONFIG_CBS) += cbs.o cbs_bsf.o
OBJS-$(CONFIG_CBS_AV1) += cbs_av1.o
OBJS-$(CONFIG_CBS_H264) += cbs_h2645.o cbs_sei.o h2645_parse.o
OBJS-$(CONFIG_CBS_H265) += cbs_h2645.o cbs_sei.o h2645_parse.o
OBJS-$(CONFIG_CBS_H266) += cbs_h2645.o cbs_sei.o h2645_parse.o
OBJS-$(CONFIG_CBS_JPEG) += cbs_jpeg.o
OBJS-$(CONFIG_CBS_MPEG2) += cbs_mpeg2.o
OBJS-$(CONFIG_CBS_VP9) += cbs_vp9.o

View File

@ -40,6 +40,9 @@ static const CodedBitstreamType *const cbs_type_table[] = {
#if CONFIG_CBS_H265
&ff_cbs_type_h265,
#endif
#if CONFIG_CBS_H266
&ff_cbs_type_h266,
#endif
#if CONFIG_CBS_JPEG
&ff_cbs_type_jpeg,
#endif
@ -61,6 +64,9 @@ const enum AVCodecID ff_cbs_all_codec_ids[] = {
#if CONFIG_CBS_H265
AV_CODEC_ID_H265,
#endif
#if CONFIG_CBS_H266
AV_CODEC_ID_H266,
#endif
#if CONFIG_CBS_JPEG
AV_CODEC_ID_MJPEG,
#endif

View File

@ -24,9 +24,11 @@
#include "cbs_internal.h"
#include "cbs_h264.h"
#include "cbs_h265.h"
#include "cbs_h266.h"
#include "h264.h"
#include "h2645_parse.h"
#include "hevc.h"
#include "vvc.h"
static int cbs_read_ue_golomb(CodedBitstreamContext *ctx, GetBitContext *gbc,
@ -255,6 +257,7 @@ static int cbs_h265_payload_extension_present(GetBitContext *gbc, uint32_t paylo
#define FUNC_NAME1(rw, codec, name) FUNC_NAME2(rw, codec, name)
#define FUNC_H264(name) FUNC_NAME1(READWRITE, h264, name)
#define FUNC_H265(name) FUNC_NAME1(READWRITE, h265, name)
#define FUNC_H266(name) FUNC_NAME1(READWRITE, h266, name)
#define FUNC_SEI(name) FUNC_NAME1(READWRITE, sei, name)
#define SUBSCRIPTS(subs, ...) (subs > 0 ? ((int[subs + 1]){ subs, __VA_ARGS__ }) : NULL)
@ -369,6 +372,10 @@ static int cbs_h2645_read_more_rbsp_data(GetBitContext *gbc)
#include "cbs_h265_syntax_template.c"
#undef FUNC
#define FUNC(name) FUNC_H266(name)
#include "cbs_h266_syntax_template.c"
#undef FUNC
#undef READ
#undef READWRITE
#undef RWContext
@ -447,6 +454,10 @@ static int cbs_h2645_read_more_rbsp_data(GetBitContext *gbc)
#include "cbs_h265_syntax_template.c"
#undef FUNC
#define FUNC(name) FUNC_H266(name)
#include "cbs_h266_syntax_template.c"
#undef FUNC
#undef WRITE
#undef READWRITE
#undef RWContext
@ -476,8 +487,9 @@ static int cbs_h2645_fragment_add_nals(CodedBitstreamContext *ctx,
const H2645NAL *nal = &packet->nals[i];
AVBufferRef *ref;
size_t size = nal->size;
enum AVCodecID codec_id = ctx->codec->codec_id;
if (nal->nuh_layer_id > 0)
if (codec_id != AV_CODEC_ID_VVC && nal->nuh_layer_id > 0)
continue;
// Remove trailing zeroes.
@ -513,6 +525,12 @@ static int cbs_h2645_split_fragment(CodedBitstreamContext *ctx,
if (frag->data_size == 0)
return 0;
if (codec_id == AV_CODEC_ID_VVC) {
//we deactive picture header here to avoid reuse previous au's ph.
CodedBitstreamH266Context *h266 = ctx->priv_data;
h266->priv.ph = NULL;
}
if (header && frag->data[0] && codec_id == AV_CODEC_ID_H264) {
// AVCC header.
size_t size, start, end;
@ -640,6 +658,71 @@ static int cbs_h2645_split_fragment(CodedBitstreamContext *ctx,
return err;
}
} else if(header && frag->data[0] && codec_id == AV_CODEC_ID_VVC) {
// VVCC header.
int ptl_present_flag, num_arrays;
int b, i, j;
priv->mp4 = 1;
bytestream2_init(&gbc, frag->data, frag->data_size);
b = bytestream2_get_byte(&gbc);
priv->nal_length_size = ((b >> 1) & 3) + 1;
ptl_present_flag = b & 1;
if(ptl_present_flag) {
int num_sublayers, num_bytes_constraint_info, num_sub_profiles;
num_sublayers = (bytestream2_get_be16u(&gbc) >> 4) & 7;
bytestream2_skip(&gbc, 1);
// begin VvcPTLRecord(num_sublayers);
num_bytes_constraint_info = bytestream2_get_byte(&gbc) & 0x3f;
bytestream2_skip(&gbc, 2 + num_bytes_constraint_info);
if(num_sublayers > 1) {
int count_present_flags = 0;
b = bytestream2_get_byte(&gbc);
for(i = num_sublayers - 2; i >= 0; i--) {
if((b >> (7 - (num_sublayers - 2 - i))) & 0x01)
count_present_flags++;
}
bytestream2_skip(&gbc, count_present_flags);
}
num_sub_profiles = bytestream2_get_byte(&gbc);
bytestream2_skip(&gbc, num_sub_profiles * 4);
// end VvcPTLRecord(num_sublayers);
bytestream2_skip(&gbc, 3 * 2);
}
num_arrays = bytestream2_get_byte(&gbc);
for(j = 0; j < num_arrays; j++) {
size_t start, end, size;
int nal_unit_type = bytestream2_get_byte(&gbc) & 0x1f;
unsigned int num_nalus = 1;
if(nal_unit_type != VVC_DCI_NUT && nal_unit_type != VVC_OPI_NUT)
num_nalus = bytestream2_get_be16u(&gbc);
start = bytestream2_tell(&gbc);
for(i = 0; i < num_nalus; i++) {
size = bytestream2_get_be16(&gbc);
bytestream2_skip(&gbc, size);
}
end = bytestream2_tell(&gbc);
err = ff_h2645_packet_split(&priv->read_packet,
frag->data + start, end - start,
ctx->log_ctx, 1, 2, AV_CODEC_ID_VVC, 1, 1);
if (err < 0) {
av_log(ctx->log_ctx, AV_LOG_ERROR, "Failed to split "
"VVCC array %d (%d NAL units of type %d).\n",
i, num_nalus, nal_unit_type);
return err;
}
err = cbs_h2645_fragment_add_nals(ctx, frag, &priv->read_packet);
if (err < 0)
return err;
}
} else {
// Annex B, or later MP4 with already-known parameters.
@ -686,6 +769,46 @@ cbs_h2645_replace_ps(5, VPS, vps, vps_video_parameter_set_id)
cbs_h2645_replace_ps(5, SPS, sps, sps_seq_parameter_set_id)
cbs_h2645_replace_ps(5, PPS, pps, pps_pic_parameter_set_id)
#define cbs_h266_replace_ps(h26n, ps_name, ps_var, id_element) \
static int cbs_h26 ## h26n ## _replace_ ## ps_var(CodedBitstreamContext *ctx, \
CodedBitstreamUnit *unit) \
{ \
CodedBitstreamH26 ## h26n ## Context *priv = ctx->priv_data; \
H26 ## h26n ## Raw ## ps_name *ps_var = unit->content; \
unsigned int id = ps_var->id_element; \
int err = ff_cbs_make_unit_refcounted(ctx, unit); \
if (err < 0) \
return err; \
av_buffer_unref(&priv->ps_var ## _ref[id]); \
av_assert0(unit->content_ref); \
priv->ps_var ## _ref[id] = av_buffer_ref(unit->content_ref); \
if (!priv->ps_var ## _ref[id]) \
return AVERROR(ENOMEM); \
priv->ps_var[id] = (H26 ## h26n ## Raw ## ps_name *)priv->ps_var ## _ref[id]->data; \
return 0; \
}
cbs_h266_replace_ps(6, VPS, vps, vps_video_parameter_set_id)
cbs_h266_replace_ps(6, SPS, sps, sps_seq_parameter_set_id)
cbs_h266_replace_ps(6, PPS, pps, pps_pic_parameter_set_id)
static int cbs_h266_replace_ph(CodedBitstreamContext *ctx,
CodedBitstreamUnit *unit)
{
CodedBitstreamH266Context *h266 = ctx->priv_data;
int err;
h266->priv.ph = NULL;
err = ff_cbs_make_unit_refcounted(ctx, unit);
if (err < 0)
return err;
err = av_buffer_replace(&h266->priv.ph_ref, unit->content_ref);
if (err < 0)
return err;
h266->priv.ph = (H266RawPH*)h266->priv.ph_ref->data;
return 0;
}
static int cbs_h264_read_nal_unit(CodedBitstreamContext *ctx,
CodedBitstreamUnit *unit)
{
@ -926,6 +1049,130 @@ static int cbs_h265_read_nal_unit(CodedBitstreamContext *ctx,
return 0;
}
static int cbs_h266_read_nal_unit(CodedBitstreamContext *ctx,
CodedBitstreamUnit *unit)
{
GetBitContext gbc;
int err;
err = init_get_bits8(&gbc, unit->data, unit->data_size);
if (err < 0)
return err;
err = ff_cbs_alloc_unit_content(ctx, unit);
if (err < 0)
return err;
switch (unit->type) {
case VVC_VPS_NUT:
{
H266RawVPS *vps = unit->content;
err = cbs_h266_read_vps(ctx, &gbc, vps);
if (err < 0)
return err;
err = cbs_h266_replace_vps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_SPS_NUT:
{
H266RawSPS *sps = unit->content;
err = cbs_h266_read_sps(ctx, &gbc, sps);
if (err < 0)
return err;
err = cbs_h266_replace_sps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_PPS_NUT:
{
H266RawPPS *pps = unit->content;
err = cbs_h266_read_pps(ctx, &gbc, pps);
if (err < 0)
return err;
err = cbs_h266_replace_pps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_PH_NUT:
{
H266RawPH *ph = unit->content;
err = cbs_h266_read_ph(ctx, &gbc, ph);
if (err < 0)
return err;
err = cbs_h266_replace_ph(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_TRAIL_NUT:
case VVC_STSA_NUT:
case VVC_RADL_NUT:
case VVC_RASL_NUT:
case VVC_IDR_W_RADL:
case VVC_IDR_N_LP:
case VVC_CRA_NUT:
case VVC_GDR_NUT:
{
H266RawSlice *slice = unit->content;
int pos, len;
err = cbs_h266_read_slice_header(ctx, &gbc, &slice->header);
if (err < 0)
return err;
if (!cbs_h2645_read_more_rbsp_data(&gbc))
return AVERROR_INVALIDDATA;
pos = get_bits_count(&gbc);
len = unit->data_size;
slice->data_size = len - pos / 8;
slice->data_ref = av_buffer_ref(unit->data_ref);
if (!slice->data_ref)
return AVERROR(ENOMEM);
slice->data = unit->data + pos / 8;
slice->data_bit_start = pos % 8;
}
break;
case VVC_AUD_NUT:
{
err = cbs_h266_read_aud(ctx, &gbc, unit->content);
if (err < 0)
return err;
}
break;
case VVC_PREFIX_SEI_NUT:
case VVC_SUFFIX_SEI_NUT:
{
err = cbs_h266_read_sei(ctx, &gbc, unit->content,
unit->type == VVC_PREFIX_SEI_NUT);
if (err < 0)
return err;
}
break;
default:
return AVERROR(ENOSYS);
}
return 0;
}
static int cbs_h2645_write_slice_data(CodedBitstreamContext *ctx,
PutBitContext *pbc, const uint8_t *data,
size_t data_size, int data_bit_start)
@ -1338,11 +1585,127 @@ static int cbs_h265_discarded_nal_unit(CodedBitstreamContext *ctx,
return 0;
}
static int cbs_h266_write_nal_unit(CodedBitstreamContext *ctx,
CodedBitstreamUnit *unit,
PutBitContext *pbc)
{
int err;
switch (unit->type) {
case VVC_VPS_NUT:
{
H266RawVPS *vps = unit->content;
err = cbs_h266_write_vps(ctx, pbc, vps);
if (err < 0)
return err;
err = cbs_h266_replace_vps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_SPS_NUT:
{
H266RawSPS *sps = unit->content;
err = cbs_h266_write_sps(ctx, pbc, sps);
if (err < 0)
return err;
err = cbs_h266_replace_sps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_PPS_NUT:
{
H266RawPPS *pps = unit->content;
err = cbs_h266_write_pps(ctx, pbc, pps);
if (err < 0)
return err;
err = cbs_h266_replace_pps(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_PH_NUT:
{
H266RawPH *ph = unit->content;
err = cbs_h266_write_ph(ctx, pbc, ph);
if (err < 0)
return err;
err = cbs_h266_replace_ph(ctx, unit);
if (err < 0)
return err;
}
break;
case VVC_TRAIL_NUT:
case VVC_STSA_NUT:
case VVC_RADL_NUT:
case VVC_RASL_NUT:
case VVC_IDR_W_RADL:
case VVC_IDR_N_LP:
case VVC_CRA_NUT:
case VVC_GDR_NUT:
{
H266RawSlice *slice = unit->content;
err = cbs_h266_write_slice_header(ctx, pbc, &slice->header);
if (err < 0)
return err;
if (slice->data) {
err = cbs_h2645_write_slice_data(ctx, pbc, slice->data,
slice->data_size,
slice->data_bit_start);
if (err < 0)
return err;
} else {
// No slice data - that was just the header.
}
}
break;
case VVC_AUD_NUT:
{
err = cbs_h266_write_aud(ctx, pbc, unit->content);
if (err < 0)
return err;
}
break;
case VVC_PREFIX_SEI_NUT:
case VVC_SUFFIX_SEI_NUT:
{
err = cbs_h266_write_sei(ctx, pbc, unit->content,
unit->type == VVC_PREFIX_SEI_NUT);
if (err < 0)
return err;
}
break;
default:
av_log(ctx->log_ctx, AV_LOG_ERROR, "Write unimplemented for "
"NAL unit type %"PRIu32".\n", unit->type);
return AVERROR_PATCHWELCOME;
}
return 0;
}
static int cbs_h2645_unit_requires_zero_byte(enum AVCodecID codec_id,
CodedBitstreamUnitType type,
int nal_unit_index)
{
// Section B.1.2 in H.264, section B.2.2 in H.265.
// Section B.1.2 in H.264, section B.2.2 in H.265, H.266.
if (nal_unit_index == 0) {
// Assume that this is the first NAL unit in an access unit.
return 1;
@ -1351,6 +1714,8 @@ static int cbs_h2645_unit_requires_zero_byte(enum AVCodecID codec_id,
return type == H264_NAL_SPS || type == H264_NAL_PPS;
if (codec_id == AV_CODEC_ID_HEVC)
return type == HEVC_NAL_VPS || type == HEVC_NAL_SPS || type == HEVC_NAL_PPS;
if (codec_id == AV_CODEC_ID_VVC)
return type >= VVC_OPI_NUT && type <= VVC_SUFFIX_APS_NUT;
return 0;
}
@ -1502,6 +1867,35 @@ static void cbs_h265_close(CodedBitstreamContext *ctx)
av_buffer_unref(&h265->pps_ref[i]);
}
static void cbs_h266_flush(CodedBitstreamContext *ctx)
{
CodedBitstreamH266Context *h266 = ctx->priv_data;
for (int i = 0; i < FF_ARRAY_ELEMS(h266->vps); i++) {
av_buffer_unref(&h266->vps_ref[i]);
h266->vps[i] = NULL;
}
for (int i = 0; i < FF_ARRAY_ELEMS(h266->sps); i++) {
av_buffer_unref(&h266->sps_ref[i]);
h266->sps[i] = NULL;
}
for (int i = 0; i < FF_ARRAY_ELEMS(h266->pps); i++) {
av_buffer_unref(&h266->pps_ref[i]);
h266->pps[i] = NULL;
}
av_buffer_unref(&h266->priv.ph_ref);
h266->priv.ph = NULL;
}
static void cbs_h266_close(CodedBitstreamContext *ctx)
{
CodedBitstreamH266Context *h266 = ctx->priv_data;
cbs_h266_flush(ctx);
ff_h2645_packet_uninit(&h266->common.read_packet);
}
static void cbs_h264_free_sei(void *opaque, uint8_t *content)
{
H264RawSEI *sei = (H264RawSEI*)content;
@ -1556,6 +1950,33 @@ static const CodedBitstreamUnitTypeDescriptor cbs_h265_unit_types[] = {
CBS_UNIT_TYPE_END_OF_LIST
};
static void cbs_h266_free_sei(void *opaque, uint8_t *content)
{
H266RawSEI *sei = (H266RawSEI*)content;
ff_cbs_sei_free_message_list(&sei->message_list);
av_free(content);
}
static const CodedBitstreamUnitTypeDescriptor cbs_h266_unit_types[] = {
CBS_UNIT_TYPE_INTERNAL_REF(VVC_VPS_NUT, H266RawVPS, extension_data.data),
CBS_UNIT_TYPE_INTERNAL_REF(VVC_SPS_NUT, H266RawSPS, extension_data.data),
CBS_UNIT_TYPE_INTERNAL_REF(VVC_PPS_NUT, H266RawPPS, extension_data.data),
CBS_UNIT_TYPE_POD(VVC_PH_NUT , H266RawPH),
CBS_UNIT_TYPE_POD(VVC_AUD_NUT, H266RawAUD),
CBS_UNIT_RANGE_INTERNAL_REF(VVC_TRAIL_NUT, VVC_RASL_NUT,
H266RawSlice, data),
CBS_UNIT_RANGE_INTERNAL_REF(VVC_IDR_W_RADL, VVC_GDR_NUT,
H266RawSlice, data),
CBS_UNIT_TYPES_COMPLEX((VVC_PREFIX_SEI_NUT, VVC_SUFFIX_SEI_NUT),
H266RawSEI, cbs_h266_free_sei),
CBS_UNIT_TYPE_END_OF_LIST
};
const CodedBitstreamType ff_cbs_type_h264 = {
.codec_id = AV_CODEC_ID_H264,
@ -1590,6 +2011,22 @@ const CodedBitstreamType ff_cbs_type_h265 = {
.close = &cbs_h265_close,
};
const CodedBitstreamType ff_cbs_type_h266 = {
.codec_id = AV_CODEC_ID_VVC,
.priv_data_size = sizeof(CodedBitstreamH266Context),
.unit_types = cbs_h266_unit_types,
.split_fragment = &cbs_h2645_split_fragment,
.read_unit = &cbs_h266_read_nal_unit,
.write_unit = &cbs_h266_write_nal_unit,
.assemble_fragment = &cbs_h2645_assemble_fragment,
.flush = &cbs_h266_flush,
.close = &cbs_h266_close,
};
static const SEIMessageTypeDescriptor cbs_sei_common_types[] = {
{
SEI_TYPE_FILLER_PAYLOAD,
@ -1740,6 +2177,16 @@ static const SEIMessageTypeDescriptor cbs_sei_h265_types[] = {
SEI_MESSAGE_TYPE_END
};
static const SEIMessageTypeDescriptor cbs_sei_h266_types[] = {
{
SEI_TYPE_DECODED_PICTURE_HASH,
0, 1,
sizeof(H266RawSEIDecodedPictureHash),
SEI_MESSAGE_RW(h266, sei_decoded_picture_hash),
},
SEI_MESSAGE_TYPE_END
};
const SEIMessageTypeDescriptor *ff_cbs_sei_find_type(CodedBitstreamContext *ctx,
int payload_type)
{
@ -1758,6 +2205,9 @@ const SEIMessageTypeDescriptor *ff_cbs_sei_find_type(CodedBitstreamContext *ctx,
case AV_CODEC_ID_H265:
codec_list = cbs_sei_h265_types;
break;
case AV_CODEC_ID_H266:
codec_list = cbs_sei_h266_types;
break;
default:
return NULL;
}

783
libavcodec/cbs_h266.h Normal file
View File

@ -0,0 +1,783 @@
/*
* This file is part of FFmpeg.
*
* FFmpeg is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* FFmpeg is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with FFmpeg; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef AVCODEC_CBS_H266_H
#define AVCODEC_CBS_H266_H
#include <stddef.h>
#include <stdint.h>
#include "cbs_h2645.h"
#include "cbs_sei.h"
#include "vvc.h"
typedef struct H266RawNALUnitHeader {
uint8_t nuh_layer_id;
uint8_t nal_unit_type;
uint8_t nuh_temporal_id_plus1;
uint8_t nuh_reserved_zero_bit;
} H266RawNALUnitHeader;
typedef struct H266GeneralConstraintsInfo {
uint8_t gci_present_flag;
/* general */
uint8_t gci_intra_only_constraint_flag;
uint8_t gci_all_layers_independent_constraint_flag;
uint8_t gci_one_au_only_constraint_flag;
/* picture format */
uint8_t gci_sixteen_minus_max_bitdepth_constraint_idc;
uint8_t gci_three_minus_max_chroma_format_constraint_idc;
/* NAL unit type related */
uint8_t gci_no_mixed_nalu_types_in_pic_constraint_flag;
uint8_t gci_no_trail_constraint_flag;
uint8_t gci_no_stsa_constraint_flag;
uint8_t gci_no_rasl_constraint_flag;
uint8_t gci_no_radl_constraint_flag;
uint8_t gci_no_idr_constraint_flag;
uint8_t gci_no_cra_constraint_flag;
uint8_t gci_no_gdr_constraint_flag;
uint8_t gci_no_aps_constraint_flag;
uint8_t gci_no_idr_rpl_constraint_flag;
/* tile, slice, subpicture partitioning */
uint8_t gci_one_tile_per_pic_constraint_flag;
uint8_t gci_pic_header_in_slice_header_constraint_flag;
uint8_t gci_one_slice_per_pic_constraint_flag;
uint8_t gci_no_rectangular_slice_constraint_flag;
uint8_t gci_one_slice_per_subpic_constraint_flag;
uint8_t gci_no_subpic_info_constraint_flag;
/* CTU and block partitioning */
uint8_t gci_three_minus_max_log2_ctu_size_constraint_idc;
uint8_t gci_no_partition_constraints_override_constraint_flag;
uint8_t gci_no_mtt_constraint_flag;
uint8_t gci_no_qtbtt_dual_tree_intra_constraint_flag;
/* intra */
uint8_t gci_no_palette_constraint_flag;
uint8_t gci_no_ibc_constraint_flag;
uint8_t gci_no_isp_constraint_flag;
uint8_t gci_no_mrl_constraint_flag;
uint8_t gci_no_mip_constraint_flag;
uint8_t gci_no_cclm_constraint_flag;
/* inter */
uint8_t gci_no_ref_pic_resampling_constraint_flag;
uint8_t gci_no_res_change_in_clvs_constraint_flag;;
uint8_t gci_no_weighted_prediction_constraint_flag;
uint8_t gci_no_ref_wraparound_constraint_flag;
uint8_t gci_no_temporal_mvp_constraint_flag;
uint8_t gci_no_sbtmvp_constraint_flag;
uint8_t gci_no_amvr_constraint_flag;
uint8_t gci_no_bdof_constraint_flag;
uint8_t gci_no_smvd_constraint_flag;
uint8_t gci_no_dmvr_constraint_flag;
uint8_t gci_no_mmvd_constraint_flag;
uint8_t gci_no_affine_motion_constraint_flag;
uint8_t gci_no_prof_constraint_flag;
uint8_t gci_no_bcw_constraint_flag;
uint8_t gci_no_ciip_constraint_flag;
uint8_t gci_no_gpm_constraint_flag;
/* transform, quantization, residual */
uint8_t gci_no_luma_transform_size_64_constraint_flag;
uint8_t gci_no_transform_skip_constraint_flag;
uint8_t gci_no_bdpcm_constraint_flag;
uint8_t gci_no_mts_constraint_flag;
uint8_t gci_no_lfnst_constraint_flag;
uint8_t gci_no_joint_cbcr_constraint_flag;
uint8_t gci_no_sbt_constraint_flag;
uint8_t gci_no_act_constraint_flag;
uint8_t gci_no_explicit_scaling_list_constraint_flag;
uint8_t gci_no_dep_quant_constraint_flag;
uint8_t gci_no_sign_data_hiding_constraint_flag;
uint8_t gci_no_cu_qp_delta_constraint_flag;
uint8_t gci_no_chroma_qp_offset_constraint_flag;
/* loop filter */
uint8_t gci_no_sao_constraint_flag;
uint8_t gci_no_alf_constraint_flag;
uint8_t gci_no_ccalf_constraint_flag;
uint8_t gci_no_lmcs_constraint_flag;
uint8_t gci_no_ladf_constraint_flag;
uint8_t gci_no_virtual_boundaries_constraint_flag;
uint8_t gci_num_reserved_bits;
uint8_t gci_reserved_zero_bit[255];
} H266GeneralConstraintsInfo;
typedef struct H266RawProfileTierLevel {
uint8_t general_profile_idc;
uint8_t general_tier_flag;
uint8_t general_level_idc;
uint8_t ptl_frame_only_constraint_flag;
uint8_t ptl_multilayer_enabled_flag;
H266GeneralConstraintsInfo general_constraints_info;
uint8_t ptl_sublayer_level_present_flag[VVC_MAX_SUBLAYERS - 1];
uint8_t sublayer_level_idc[VVC_MAX_SUBLAYERS - 1];
uint8_t ptl_num_sub_profiles;
uint32_t general_sub_profile_idc[VVC_MAX_SUB_PROFILES];
uint8_t ptl_reserved_zero_bit;
} H266RawProfileTierLevel;
typedef struct H266RawExtensionData {
uint8_t *data;
AVBufferRef *data_ref;
size_t bit_length;
} H266RawExtensionData;
typedef struct H266DpbParameters {
uint8_t dpb_max_dec_pic_buffering_minus1[VVC_MAX_SUBLAYERS];
uint8_t dpb_max_num_reorder_pics[VVC_MAX_SUBLAYERS];
uint8_t dpb_max_latency_increase_plus1[VVC_MAX_SUBLAYERS];
} H266DpbParameters;
typedef struct H266RefPicListStruct {
uint8_t num_ref_entries;
uint8_t ltrp_in_header_flag;
uint8_t inter_layer_ref_pic_flag[VVC_MAX_REF_ENTRIES];
uint8_t st_ref_pic_flag[VVC_MAX_REF_ENTRIES];
uint8_t abs_delta_poc_st[VVC_MAX_REF_ENTRIES];
uint8_t strp_entry_sign_flag[VVC_MAX_REF_ENTRIES];
uint8_t rpls_poc_lsb_lt[VVC_MAX_REF_ENTRIES];
uint8_t ilrp_idx[VVC_MAX_REF_ENTRIES];
} H266RefPicListStruct;
typedef struct H266RefPicLists {
uint8_t rpl_sps_flag[2];
uint8_t rpl_idx[2];
H266RefPicListStruct rpl_ref_list[2];
uint16_t poc_lsb_lt[2][VVC_MAX_REF_ENTRIES];
uint8_t delta_poc_msb_cycle_present_flag[2][VVC_MAX_REF_ENTRIES];
uint16_t delta_poc_msb_cycle_lt[2][VVC_MAX_REF_ENTRIES];
} H266RefPicLists;
typedef struct H266RawGeneralTimingHrdParameters {
uint32_t num_units_in_tick;
uint32_t time_scale;
uint8_t general_nal_hrd_params_present_flag;
uint8_t general_vcl_hrd_params_present_flag;
uint8_t general_same_pic_timing_in_all_ols_flag;
uint8_t general_du_hrd_params_present_flag;
uint8_t tick_divisor_minus2;
uint8_t bit_rate_scale;
uint8_t cpb_size_scale;
uint8_t cpb_size_du_scale;
uint8_t hrd_cpb_cnt_minus1;
} H266RawGeneralTimingHrdParameters;
typedef struct H266RawSubLayerHRDParameters {
uint32_t bit_rate_value_minus1[VVC_MAX_SUBLAYERS][VVC_MAX_CPB_CNT];
uint32_t cpb_size_value_minus1[VVC_MAX_SUBLAYERS][VVC_MAX_CPB_CNT];
uint32_t cpb_size_du_value_minus1[VVC_MAX_SUBLAYERS][VVC_MAX_CPB_CNT];
uint32_t bit_rate_du_value_minus1[VVC_MAX_SUBLAYERS][VVC_MAX_CPB_CNT];
uint8_t cbr_flag[VVC_MAX_SUBLAYERS][VVC_MAX_CPB_CNT];
} H266RawSubLayerHRDParameters;
typedef struct H266RawOlsTimingHrdParameters {
uint8_t fixed_pic_rate_general_flag[VVC_MAX_SUBLAYERS];
uint8_t fixed_pic_rate_within_cvs_flag[VVC_MAX_SUBLAYERS];
uint16_t elemental_duration_in_tc_minus1[VVC_MAX_SUBLAYERS];
uint8_t low_delay_hrd_flag[VVC_MAX_SUBLAYERS];
H266RawSubLayerHRDParameters nal_sub_layer_hrd_parameters;
H266RawSubLayerHRDParameters vcl_sub_layer_hrd_parameters;
} H266RawOlsTimingHrdParameters;
typedef struct H266RawVUI {
uint8_t vui_progressive_source_flag;
uint8_t vui_interlaced_source_flag;
uint8_t vui_non_packed_constraint_flag;
uint8_t vui_non_projected_constraint_flag;
uint8_t vui_aspect_ratio_info_present_flag;
uint8_t vui_aspect_ratio_constant_flag;
uint8_t vui_aspect_ratio_idc;
uint16_t vui_sar_width;
uint16_t vui_sar_height;;
uint8_t vui_overscan_info_present_flag;
uint8_t vui_overscan_appropriate_flag;
uint8_t vui_colour_description_present_flag;
uint8_t vui_colour_primaries;
uint8_t vui_transfer_characteristics;
uint8_t vui_matrix_coeffs;
uint8_t vui_full_range_flag;
uint8_t vui_chroma_loc_info_present_flag;
uint8_t vui_chroma_sample_loc_type_frame;
uint8_t vui_chroma_sample_loc_type_top_field;
uint8_t vui_chroma_sample_loc_type_bottom_field;
H266RawExtensionData extension_data;
} H266RawVUI;
typedef struct H266RawVPS {
H266RawNALUnitHeader nal_unit_header;
uint8_t vps_video_parameter_set_id;
uint8_t vps_max_layers_minus1;
uint8_t vps_max_sublayers_minus1;
uint8_t vps_default_ptl_dpb_hrd_max_tid_flag;
uint8_t vps_all_independent_layers_flag;
uint8_t vps_layer_id[VVC_MAX_LAYERS];
uint8_t vps_independent_layer_flag[VVC_MAX_LAYERS];
uint8_t vps_max_tid_ref_present_flag[VVC_MAX_LAYERS];
uint8_t vps_direct_ref_layer_flag[VVC_MAX_LAYERS][VVC_MAX_LAYERS - 1];
uint8_t vps_max_tid_il_ref_pics_plus1[VVC_MAX_LAYERS][VVC_MAX_LAYERS - 1];
uint8_t vps_each_layer_is_an_ols_flag;
uint8_t vps_ols_mode_idc;
uint8_t vps_num_output_layer_sets_minus2;
uint8_t vps_ols_output_layer_flag[VVC_MAX_TOTAL_NUM_OLSS][VVC_MAX_LAYERS];
uint8_t vps_num_ptls_minus1;
uint8_t vps_pt_present_flag[VVC_MAX_PTLS];
uint8_t vps_ptl_max_tid[VVC_MAX_PTLS];
H266RawProfileTierLevel vps_profile_tier_level[VVC_MAX_PTLS];
uint8_t vps_ols_ptl_idx[VVC_MAX_TOTAL_NUM_OLSS];
uint16_t vps_num_dpb_params_minus1;
uint8_t vps_sublayer_dpb_params_present_flag;
uint8_t vps_dpb_max_tid[VVC_MAX_TOTAL_NUM_OLSS];
H266DpbParameters vps_dpb_params[VVC_MAX_TOTAL_NUM_OLSS];
uint16_t vps_ols_dpb_pic_width[VVC_MAX_TOTAL_NUM_OLSS];
uint16_t vps_ols_dpb_pic_height[VVC_MAX_TOTAL_NUM_OLSS];
uint8_t vps_ols_dpb_chroma_format[VVC_MAX_TOTAL_NUM_OLSS];
uint8_t vps_ols_dpb_bitdepth_minus8[VVC_MAX_TOTAL_NUM_OLSS];
uint16_t vps_ols_dpb_params_idx[VVC_MAX_TOTAL_NUM_OLSS];
uint8_t vps_timing_hrd_params_present_flag;
H266RawGeneralTimingHrdParameters vps_general_timing_hrd_parameters;
uint8_t vps_sublayer_cpb_params_present_flag;
uint16_t vps_num_ols_timing_hrd_params_minus1;
uint8_t vps_hrd_max_tid[VVC_MAX_TOTAL_NUM_OLSS];
H266RawOlsTimingHrdParameters vps_ols_timing_hrd_parameters;
uint8_t vps_ols_timing_hrd_idx[VVC_MAX_TOTAL_NUM_OLSS];
uint8_t vps_extension_flag;
H266RawExtensionData extension_data;
} H266RawVPS;
typedef struct H266RawSPS {
H266RawNALUnitHeader nal_unit_header;
uint8_t sps_seq_parameter_set_id;
uint8_t sps_video_parameter_set_id;
uint8_t sps_max_sublayers_minus1;
uint8_t sps_chroma_format_idc;
uint8_t sps_log2_ctu_size_minus5;
uint8_t sps_ptl_dpb_hrd_params_present_flag;
H266RawProfileTierLevel profile_tier_level;
uint8_t sps_gdr_enabled_flag;
uint8_t sps_ref_pic_resampling_enabled_flag;
uint8_t sps_res_change_in_clvs_allowed_flag;
uint16_t sps_pic_width_max_in_luma_samples;
uint16_t sps_pic_height_max_in_luma_samples;
uint8_t sps_conformance_window_flag;
uint16_t sps_conf_win_left_offset;
uint16_t sps_conf_win_right_offset;
uint16_t sps_conf_win_top_offset;
uint16_t sps_conf_win_bottom_offset;
uint8_t sps_subpic_info_present_flag;
uint16_t sps_num_subpics_minus1;
uint8_t sps_independent_subpics_flag;
uint8_t sps_subpic_same_size_flag;
uint16_t sps_subpic_ctu_top_left_x[VVC_MAX_SLICES];
uint16_t sps_subpic_ctu_top_left_y[VVC_MAX_SLICES];
uint16_t sps_subpic_width_minus1[VVC_MAX_SLICES];
uint16_t sps_subpic_height_minus1[VVC_MAX_SLICES];
uint8_t sps_subpic_treated_as_pic_flag[VVC_MAX_SLICES];
uint8_t sps_loop_filter_across_subpic_enabled_flag[VVC_MAX_SLICES];
uint8_t sps_subpic_id_len_minus1;
uint8_t sps_subpic_id_mapping_explicitly_signalled_flag;
uint8_t sps_subpic_id_mapping_present_flag;
uint32_t sps_subpic_id[VVC_MAX_SLICES];
uint8_t sps_bitdepth_minus8;
uint8_t sps_entropy_coding_sync_enabled_flag;
uint8_t sps_entry_point_offsets_present_flag;
uint8_t sps_log2_max_pic_order_cnt_lsb_minus4;
uint8_t sps_poc_msb_cycle_flag;
uint8_t sps_poc_msb_cycle_len_minus1;
uint8_t sps_num_extra_ph_bytes;
uint8_t sps_extra_ph_bit_present_flag[16];
uint8_t sps_num_extra_sh_bytes;
uint8_t sps_extra_sh_bit_present_flag[16];
uint8_t sps_sublayer_dpb_params_flag;
H266DpbParameters sps_dpb_params;
uint8_t sps_log2_min_luma_coding_block_size_minus2;
uint8_t sps_partition_constraints_override_enabled_flag;
uint8_t sps_log2_diff_min_qt_min_cb_intra_slice_luma;
uint8_t sps_max_mtt_hierarchy_depth_intra_slice_luma;
uint8_t sps_log2_diff_max_bt_min_qt_intra_slice_luma;
uint8_t sps_log2_diff_max_tt_min_qt_intra_slice_luma;
uint8_t sps_qtbtt_dual_tree_intra_flag;
uint8_t sps_log2_diff_min_qt_min_cb_intra_slice_chroma;
uint8_t sps_max_mtt_hierarchy_depth_intra_slice_chroma;
uint8_t sps_log2_diff_max_bt_min_qt_intra_slice_chroma;
uint8_t sps_log2_diff_max_tt_min_qt_intra_slice_chroma;
uint8_t sps_log2_diff_min_qt_min_cb_inter_slice;
uint8_t sps_max_mtt_hierarchy_depth_inter_slice;
uint8_t sps_log2_diff_max_bt_min_qt_inter_slice;
uint8_t sps_log2_diff_max_tt_min_qt_inter_slice;
uint8_t sps_max_luma_transform_size_64_flag;
uint8_t sps_transform_skip_enabled_flag;
uint8_t sps_log2_transform_skip_max_size_minus2;
uint8_t sps_bdpcm_enabled_flag;
uint8_t sps_mts_enabled_flag;
uint8_t sps_explicit_mts_intra_enabled_flag;
uint8_t sps_explicit_mts_inter_enabled_flag;
uint8_t sps_lfnst_enabled_flag;
uint8_t sps_joint_cbcr_enabled_flag;
uint8_t sps_same_qp_table_for_chroma_flag;
int8_t sps_qp_table_start_minus26[VVC_MAX_SAMPLE_ARRAYS];
uint8_t sps_num_points_in_qp_table_minus1[VVC_MAX_SAMPLE_ARRAYS];
uint8_t sps_delta_qp_in_val_minus1[VVC_MAX_SAMPLE_ARRAYS][VVC_MAX_POINTS_IN_QP_TABLE];
uint8_t sps_delta_qp_diff_val[VVC_MAX_SAMPLE_ARRAYS][VVC_MAX_POINTS_IN_QP_TABLE];
uint8_t sps_sao_enabled_flag;
uint8_t sps_alf_enabled_flag;
uint8_t sps_ccalf_enabled_flag;
uint8_t sps_lmcs_enabled_flag;
uint8_t sps_weighted_pred_flag;
uint8_t sps_weighted_bipred_flag;
uint8_t sps_long_term_ref_pics_flag;
uint8_t sps_inter_layer_prediction_enabled_flag;
uint8_t sps_idr_rpl_present_flag;
uint8_t sps_rpl1_same_as_rpl0_flag;
uint8_t sps_num_ref_pic_lists[2];
H266RefPicListStruct sps_ref_pic_list_struct[2][VVC_MAX_REF_PIC_LISTS];
uint8_t sps_ref_wraparound_enabled_flag;
uint8_t sps_temporal_mvp_enabled_flag;
uint8_t sps_sbtmvp_enabled_flag;
uint8_t sps_amvr_enabled_flag;
uint8_t sps_bdof_enabled_flag;
uint8_t sps_bdof_control_present_in_ph_flag;
uint8_t sps_smvd_enabled_flag;
uint8_t sps_dmvr_enabled_flag;
uint8_t sps_dmvr_control_present_in_ph_flag;
uint8_t sps_mmvd_enabled_flag;
uint8_t sps_mmvd_fullpel_only_enabled_flag;
uint8_t sps_six_minus_max_num_merge_cand;
uint8_t sps_sbt_enabled_flag;
uint8_t sps_affine_enabled_flag;
uint8_t sps_five_minus_max_num_subblock_merge_cand;
uint8_t sps_6param_affine_enabled_flag;
uint8_t sps_affine_amvr_enabled_flag;
uint8_t sps_affine_prof_enabled_flag;
uint8_t sps_prof_control_present_in_ph_flag;
uint8_t sps_bcw_enabled_flag;
uint8_t sps_ciip_enabled_flag;
uint8_t sps_gpm_enabled_flag;
uint8_t sps_max_num_merge_cand_minus_max_num_gpm_cand;
uint8_t sps_log2_parallel_merge_level_minus2;
uint8_t sps_isp_enabled_flag;
uint8_t sps_mrl_enabled_flag;
uint8_t sps_mip_enabled_flag;
uint8_t sps_cclm_enabled_flag;
uint8_t sps_chroma_horizontal_collocated_flag;
uint8_t sps_chroma_vertical_collocated_flag;
uint8_t sps_palette_enabled_flag;
uint8_t sps_act_enabled_flag;
uint8_t sps_min_qp_prime_ts;
uint8_t sps_ibc_enabled_flag;
uint8_t sps_six_minus_max_num_ibc_merge_cand;
uint8_t sps_ladf_enabled_flag;
uint8_t sps_num_ladf_intervals_minus2;
int8_t sps_ladf_lowest_interval_qp_offset;
int8_t sps_ladf_qp_offset[4];
uint16_t sps_ladf_delta_threshold_minus1[4];
uint8_t sps_explicit_scaling_list_enabled_flag;
uint8_t sps_scaling_matrix_for_lfnst_disabled_flag;
uint8_t sps_scaling_matrix_for_alternative_colour_space_disabled_flag;
uint8_t sps_scaling_matrix_designated_colour_space_flag;
uint8_t sps_dep_quant_enabled_flag;
uint8_t sps_sign_data_hiding_enabled_flag;
uint8_t sps_virtual_boundaries_enabled_flag;
uint8_t sps_virtual_boundaries_present_flag;
uint8_t sps_num_ver_virtual_boundaries;
uint16_t sps_virtual_boundary_pos_x_minus1[3];
uint8_t sps_num_hor_virtual_boundaries;
uint16_t sps_virtual_boundary_pos_y_minus1[3];
uint8_t sps_timing_hrd_params_present_flag;
uint8_t sps_sublayer_cpb_params_present_flag;
H266RawGeneralTimingHrdParameters sps_general_timing_hrd_parameters;
H266RawOlsTimingHrdParameters sps_ols_timing_hrd_parameters;
uint8_t sps_field_seq_flag;
uint8_t sps_vui_parameters_present_flag;
uint16_t sps_vui_payload_size_minus1;
H266RawVUI vui;
uint8_t sps_extension_flag;
H266RawExtensionData extension_data;
} H266RawSPS;
typedef struct H266RawPPS {
H266RawNALUnitHeader nal_unit_header;
uint8_t pps_pic_parameter_set_id;
uint8_t pps_seq_parameter_set_id;
uint8_t pps_mixed_nalu_types_in_pic_flag;
uint16_t pps_pic_width_in_luma_samples;
uint16_t pps_pic_height_in_luma_samples;
uint8_t pps_conformance_window_flag;
uint16_t pps_conf_win_left_offset;
uint16_t pps_conf_win_right_offset;
uint16_t pps_conf_win_top_offset;
uint16_t pps_conf_win_bottom_offset;
uint8_t pps_scaling_window_explicit_signalling_flag;
int16_t pps_scaling_win_left_offset;
int16_t pps_scaling_win_right_offset;
int16_t pps_scaling_win_top_offset;
int16_t pps_scaling_win_bottom_offset;
uint8_t pps_output_flag_present_flag;
uint8_t pps_no_pic_partition_flag;
uint8_t pps_subpic_id_mapping_present_flag;
uint16_t pps_num_subpics_minus1;
uint8_t pps_subpic_id_len_minus1;
uint16_t pps_subpic_id[VVC_MAX_SLICES];
uint8_t pps_log2_ctu_size_minus5;
uint8_t pps_num_exp_tile_columns_minus1;
uint8_t pps_num_exp_tile_rows_minus1;
uint16_t pps_tile_column_width_minus1[VVC_MAX_TILE_COLUMNS];
uint16_t pps_tile_row_height_minus1[VVC_MAX_TILE_ROWS];
uint8_t pps_loop_filter_across_tiles_enabled_flag;
uint8_t pps_rect_slice_flag;
uint8_t pps_single_slice_per_subpic_flag;
uint16_t pps_num_slices_in_pic_minus1;
uint8_t pps_tile_idx_delta_present_flag;
uint16_t pps_slice_width_in_tiles_minus1[VVC_MAX_SLICES];
uint16_t pps_slice_height_in_tiles_minus1[VVC_MAX_SLICES];
uint16_t pps_num_exp_slices_in_tile[VVC_MAX_SLICES];
uint16_t pps_exp_slice_height_in_ctus_minus1[VVC_MAX_SLICES][VVC_MAX_TILE_ROWS];
int16_t pps_tile_idx_delta_val[VVC_MAX_SLICES];
uint8_t pps_loop_filter_across_slices_enabled_flag;
uint8_t pps_cabac_init_present_flag;
uint8_t pps_num_ref_idx_default_active_minus1[2];
uint8_t pps_rpl1_idx_present_flag;
uint8_t pps_weighted_pred_flag;
uint8_t pps_weighted_bipred_flag;
uint8_t pps_ref_wraparound_enabled_flag;
uint16_t pps_pic_width_minus_wraparound_offset;
int8_t pps_init_qp_minus26;
uint8_t pps_cu_qp_delta_enabled_flag;
uint8_t pps_chroma_tool_offsets_present_flag;
int8_t pps_cb_qp_offset;
int8_t pps_cr_qp_offset;
uint8_t pps_joint_cbcr_qp_offset_present_flag;
int8_t pps_joint_cbcr_qp_offset_value;
uint8_t pps_slice_chroma_qp_offsets_present_flag;
uint8_t pps_cu_chroma_qp_offset_list_enabled_flag;
uint8_t pps_chroma_qp_offset_list_len_minus1;
uint8_t pps_cb_qp_offset_list[6];
uint8_t pps_cr_qp_offset_list[6];
uint8_t pps_joint_cbcr_qp_offset_list[6];
uint8_t pps_deblocking_filter_control_present_flag;
uint8_t pps_deblocking_filter_override_enabled_flag;
uint8_t pps_deblocking_filter_disabled_flag;
uint8_t pps_dbf_info_in_ph_flag;
int8_t pps_luma_beta_offset_div2;
int8_t pps_luma_tc_offset_div2;
int8_t pps_cb_beta_offset_div2;
int8_t pps_cb_tc_offset_div2;
int8_t pps_cr_beta_offset_div2;
int8_t pps_cr_tc_offset_div2;
uint8_t pps_rpl_info_in_ph_flag;
uint8_t pps_sao_info_in_ph_flag;
uint8_t pps_alf_info_in_ph_flag;
uint8_t pps_wp_info_in_ph_flag;
uint8_t pps_qp_delta_info_in_ph_flag;
uint8_t pps_picture_header_extension_present_flag;
uint8_t pps_slice_header_extension_present_flag;
uint8_t pps_extension_flag;
H266RawExtensionData extension_data;
//calculated value;
uint16_t num_tile_columns;
uint16_t num_tile_rows;
uint16_t num_tiles_in_pic;
uint16_t slice_height_in_ctus[VVC_MAX_SLICES];
uint16_t num_slices_in_subpic[VVC_MAX_SLICES];
} H266RawPPS;
typedef struct H266RawAUD {
H266RawNALUnitHeader nal_unit_header;
uint8_t aud_irap_or_gdr_flag;
uint8_t aud_pic_type;
} H266RawAUD;
typedef struct H266RawPredWeightTable {
uint8_t luma_log2_weight_denom;
int8_t delta_chroma_log2_weight_denom;
uint8_t num_l0_weights;
uint8_t luma_weight_l0_flag[15];
uint8_t chroma_weight_l0_flag[15];
int8_t delta_luma_weight_l0[15];
int8_t luma_offset_l0[15];
int8_t delta_chroma_weight_l0[15][2];
int16_t delta_chroma_offset_l0[15][2];
uint8_t num_l1_weights;
uint8_t luma_weight_l1_flag[15];
uint8_t chroma_weight_l1_flag[15];
int8_t delta_luma_weight_l1[15];
int8_t luma_offset_l1[15];
int8_t delta_chroma_weight_l1[15][2];
int16_t delta_chroma_offset_l1[15][2];
} H266RawPredWeightTable;
typedef struct H266RawPH {
H266RawNALUnitHeader nal_unit_header;
uint8_t ph_gdr_or_irap_pic_flag;
uint8_t ph_non_ref_pic_flag;
uint8_t ph_gdr_pic_flag;
uint8_t ph_inter_slice_allowed_flag;
uint8_t ph_intra_slice_allowed_flag;
uint8_t ph_pic_parameter_set_id;
uint16_t ph_pic_order_cnt_lsb;
uint8_t ph_recovery_poc_cnt;
uint8_t ph_extra_bit[16];
uint8_t ph_poc_msb_cycle_present_flag;
uint8_t ph_poc_msb_cycle_val;
uint8_t ph_alf_enabled_flag;
uint8_t ph_num_alf_aps_ids_luma;
uint8_t ph_alf_aps_id_luma[8];
uint8_t ph_alf_cb_enabled_flag;
uint8_t ph_alf_cr_enabled_flag;
uint8_t ph_alf_aps_id_chroma;
uint8_t ph_alf_cc_cb_enabled_flag;
uint8_t ph_alf_cc_cb_aps_id;
uint8_t ph_alf_cc_cr_enabled_flag;
uint8_t ph_alf_cc_cr_aps_id;
uint8_t ph_lmcs_enabled_flag;
uint8_t ph_lmcs_aps_id;
uint8_t ph_chroma_residual_scale_flag;
uint8_t ph_explicit_scaling_list_enabled_flag;
uint8_t ph_scaling_list_aps_id;
uint8_t ph_virtual_boundaries_present_flag;
uint8_t ph_num_ver_virtual_boundaries;
uint16_t ph_virtual_boundary_pos_x_minus1[3];
uint8_t ph_num_hor_virtual_boundaries;
uint16_t ph_virtual_boundary_pos_y_minus1[3];
uint8_t ph_pic_output_flag;
H266RefPicLists ph_ref_pic_lists;
uint8_t ph_partition_constraints_override_flag;
uint8_t ph_log2_diff_min_qt_min_cb_intra_slice_luma;
uint8_t ph_max_mtt_hierarchy_depth_intra_slice_luma;
uint8_t ph_log2_diff_max_bt_min_qt_intra_slice_luma;
uint8_t ph_log2_diff_max_tt_min_qt_intra_slice_luma;
uint8_t ph_log2_diff_min_qt_min_cb_intra_slice_chroma;
uint8_t ph_max_mtt_hierarchy_depth_intra_slice_chroma;
uint8_t ph_log2_diff_max_bt_min_qt_intra_slice_chroma;
uint8_t ph_log2_diff_max_tt_min_qt_intra_slice_chroma;
uint8_t ph_cu_qp_delta_subdiv_intra_slice;
uint8_t ph_cu_chroma_qp_offset_subdiv_intra_slice;
uint8_t ph_log2_diff_min_qt_min_cb_inter_slice;
uint8_t ph_max_mtt_hierarchy_depth_inter_slice;
uint8_t ph_log2_diff_max_bt_min_qt_inter_slice;
uint8_t ph_log2_diff_max_tt_min_qt_inter_slice;
uint8_t ph_cu_qp_delta_subdiv_inter_slice;
uint8_t ph_cu_chroma_qp_offset_subdiv_inter_slice;
uint8_t ph_temporal_mvp_enabled_flag;
uint8_t ph_collocated_from_l0_flag;
uint8_t ph_collocated_ref_idx;
uint8_t ph_mmvd_fullpel_only_flag;
uint8_t ph_mvd_l1_zero_flag;
uint8_t ph_bdof_disabled_flag;
uint8_t ph_dmvr_disabled_flag;
uint8_t ph_prof_disabled_flag;
H266RawPredWeightTable ph_pred_weight_table;
int8_t ph_qp_delta;
uint8_t ph_joint_cbcr_sign_flag;
uint8_t ph_sao_luma_enabled_flag;
uint8_t ph_sao_chroma_enabled_flag;
uint8_t ph_deblocking_params_present_flag;
uint8_t ph_deblocking_filter_disabled_flag;
int8_t ph_luma_beta_offset_div2;
int8_t ph_luma_tc_offset_div2;
int8_t ph_cb_beta_offset_div2;
int8_t ph_cb_tc_offset_div2;
int8_t ph_cr_beta_offset_div2;
int8_t ph_cr_tc_offset_div2;
uint8_t ph_extension_length;
uint8_t ph_extension_data_byte[256];
} H266RawPH;
typedef struct H266RawSliceHeader {
H266RawNALUnitHeader nal_unit_header;
uint8_t sh_picture_header_in_slice_header_flag;
H266RawPH sh_picture_header;
uint16_t sh_subpic_id;
uint16_t sh_slice_address;
uint8_t sh_extra_bit[16];
uint8_t sh_num_tiles_in_slice_minus1;
uint8_t sh_slice_type;
uint8_t sh_no_output_of_prior_pics_flag;
uint8_t sh_alf_enabled_flag;
uint8_t sh_num_alf_aps_ids_luma;
uint8_t sh_alf_aps_id_luma[8];
uint8_t sh_alf_cb_enabled_flag;
uint8_t sh_alf_cr_enabled_flag;
uint8_t sh_alf_aps_id_chroma;
uint8_t sh_alf_cc_cb_enabled_flag;
uint8_t sh_alf_cc_cb_aps_id;
uint8_t sh_alf_cc_cr_enabled_flag;
uint8_t sh_alf_cc_cr_aps_id;
uint8_t sh_lmcs_used_flag;
uint8_t sh_explicit_scaling_list_used_flag;
H266RefPicLists sh_ref_pic_lists;
uint8_t sh_num_ref_idx_active_override_flag;
uint8_t sh_num_ref_idx_active_minus1[2];
uint8_t sh_cabac_init_flag;
uint8_t sh_collocated_from_l0_flag;
uint8_t sh_collocated_ref_idx;
H266RawPredWeightTable sh_pred_weight_table;
int8_t sh_qp_delta;
int8_t sh_cb_qp_offset;
int8_t sh_cr_qp_offset;
int8_t sh_joint_cbcr_qp_offset;
uint8_t sh_cu_chroma_qp_offset_enabled_flag;
uint8_t sh_sao_luma_used_flag;
uint8_t sh_sao_chroma_used_flag;
uint8_t sh_deblocking_params_present_flag;
uint8_t sh_deblocking_filter_disabled_flag;
int8_t sh_luma_beta_offset_div2;
int8_t sh_luma_tc_offset_div2;
int8_t sh_cb_beta_offset_div2;
int8_t sh_cb_tc_offset_div2;
int8_t sh_cr_beta_offset_div2;
int8_t sh_cr_tc_offset_div2;
uint8_t sh_dep_quant_used_flag;
uint8_t sh_sign_data_hiding_used_flag;
uint8_t sh_ts_residual_coding_disabled_flag;
uint16_t sh_slice_header_extension_length;
uint8_t sh_slice_header_extension_data_byte[256];
uint8_t sh_entry_offset_len_minus1;
uint32_t sh_entry_point_offset_minus1[VVC_MAX_ENTRY_POINTS];
} H266RawSliceHeader;
typedef struct H266RawSlice {
H266RawSliceHeader header;
uint8_t *data;
AVBufferRef *data_ref;
size_t data_size;
int data_bit_start;
} H266RawSlice;
typedef struct H266RawSEIDecodedPictureHash {
uint8_t dph_sei_hash_type;
uint8_t dph_sei_single_component_flag;
uint8_t dph_sei_picture_md5[3][16];
uint16_t dph_sei_picture_crc[3];
uint32_t dph_sei_picture_checksum[3];
uint8_t dph_sei_reserved_zero_7bits;
} H266RawSEIDecodedPictureHash;
typedef struct H266RawSEI {
H266RawNALUnitHeader nal_unit_header;
SEIRawMessageList message_list;
} H266RawSEI;
typedef struct CodedBitstreamH266Context {
// Reader/writer context in common with the H.264 implementation.
CodedBitstreamH2645Context common;
// All currently available parameter sets. These are updated when
// any parameter set NAL unit is read/written with this context.
AVBufferRef *vps_ref[VVC_MAX_VPS_COUNT];
AVBufferRef *sps_ref[VVC_MAX_SPS_COUNT];
AVBufferRef *pps_ref[VVC_MAX_PPS_COUNT];
H266RawVPS *vps[VVC_MAX_SPS_COUNT];
H266RawSPS *sps[VVC_MAX_SPS_COUNT];
H266RawPPS *pps[VVC_MAX_PPS_COUNT];
struct {
AVBufferRef *ph_ref;
H266RawPH *ph;
} priv;
} CodedBitstreamH266Context;
#endif /* AVCODEC_CBS_H266_H */

File diff suppressed because it is too large Load Diff

View File

@ -251,6 +251,7 @@ int ff_cbs_write_signed(CodedBitstreamContext *ctx, PutBitContext *pbc,
extern const CodedBitstreamType ff_cbs_type_av1;
extern const CodedBitstreamType ff_cbs_type_h264;
extern const CodedBitstreamType ff_cbs_type_h265;
extern const CodedBitstreamType ff_cbs_type_h266;
extern const CodedBitstreamType ff_cbs_type_jpeg;
extern const CodedBitstreamType ff_cbs_type_mpeg2;
extern const CodedBitstreamType ff_cbs_type_vp9;

View File

@ -20,6 +20,7 @@
#include "cbs_internal.h"
#include "cbs_h264.h"
#include "cbs_h265.h"
#include "cbs_h266.h"
#include "cbs_sei.h"
static void cbs_free_user_data_registered(void *opaque, uint8_t *data)
@ -132,6 +133,13 @@ static int cbs_sei_get_unit(CodedBitstreamContext *ctx,
else
sei_type = HEVC_NAL_SEI_SUFFIX;
break;
case AV_CODEC_ID_H266:
highest_vcl_type = VVC_RSV_IRAP_11;
if (prefix)
sei_type = VVC_PREFIX_SEI_NUT;
else
sei_type = VVC_SUFFIX_SEI_NUT;
break;
default:
return AVERROR(EINVAL);
}
@ -207,6 +215,18 @@ static int cbs_sei_get_unit(CodedBitstreamContext *ctx,
memcpy(unit->content, &sei, sizeof(sei));
}
break;
case AV_CODEC_ID_H266:
{
H266RawSEI sei = {
.nal_unit_header = {
.nal_unit_type = sei_type,
.nuh_layer_id = 0,
.nuh_temporal_id_plus1 = 1,
},
};
memcpy(unit->content, &sei, sizeof(sei));
}
break;
default:
av_assert0(0);
}
@ -237,6 +257,15 @@ static int cbs_sei_get_message_list(CodedBitstreamContext *ctx,
*list = &sei->message_list;
}
break;
case AV_CODEC_ID_H266:
{
H266RawSEI *sei = unit->content;
if (unit->type != VVC_PREFIX_SEI_NUT &&
unit->type != VVC_SUFFIX_SEI_NUT)
return AVERROR(EINVAL);
*list = &sei->message_list;
}
break;
default:
return AVERROR(EINVAL);
}