avcodec/cbs_internal, cbs_h2645: Add and use new descriptor macros

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
pull/388/head
Andreas Rheinhardt 2 years ago
parent 715d3286bc
commit b37805ddbd
  1. 56
      libavcodec/cbs_h2645.c
  2. 31
      libavcodec/cbs_internal.h

@ -1396,18 +1396,9 @@ static const CodedBitstreamUnitTypeDescriptor cbs_h264_unit_types[] = {
CBS_UNIT_TYPE_INTERNAL_REF(H264_NAL_PPS, H264RawPPS, slice_group_id), CBS_UNIT_TYPE_INTERNAL_REF(H264_NAL_PPS, H264RawPPS, slice_group_id),
{ CBS_UNIT_TYPES_INTERNAL_REF((H264_NAL_IDR_SLICE,
.nb_unit_types = 3, H264_NAL_SLICE,
.unit_types = { H264_NAL_AUXILIARY_SLICE), H264RawSlice, data),
H264_NAL_IDR_SLICE,
H264_NAL_SLICE,
H264_NAL_AUXILIARY_SLICE,
},
.content_type = CBS_CONTENT_TYPE_INTERNAL_REFS,
.content_size = sizeof(H264RawSlice),
.nb_ref_offsets = 1,
.ref_offsets = { offsetof(H264RawSlice, data) },
},
CBS_UNIT_TYPE_POD(H264_NAL_AUD, H264RawAUD), CBS_UNIT_TYPE_POD(H264_NAL_AUD, H264RawAUD),
CBS_UNIT_TYPE_POD(H264_NAL_FILLER_DATA, H264RawFiller), CBS_UNIT_TYPE_POD(H264_NAL_FILLER_DATA, H264RawFiller),
@ -1433,40 +1424,15 @@ static const CodedBitstreamUnitTypeDescriptor cbs_h265_unit_types[] = {
CBS_UNIT_TYPE_POD(HEVC_NAL_AUD, H265RawAUD), CBS_UNIT_TYPE_POD(HEVC_NAL_AUD, H265RawAUD),
{ // Slices of non-IRAP pictures.
// Slices of non-IRAP pictures. CBS_UNIT_RANGE_INTERNAL_REF(HEVC_NAL_TRAIL_N, HEVC_NAL_RASL_R,
.nb_unit_types = CBS_UNIT_TYPE_RANGE, H265RawSlice, data),
.unit_type_range_start = HEVC_NAL_TRAIL_N, // Slices of IRAP pictures.
.unit_type_range_end = HEVC_NAL_RASL_R, CBS_UNIT_RANGE_INTERNAL_REF(HEVC_NAL_BLA_W_LP, HEVC_NAL_CRA_NUT,
H265RawSlice, data),
.content_type = CBS_CONTENT_TYPE_INTERNAL_REFS,
.content_size = sizeof(H265RawSlice),
.nb_ref_offsets = 1,
.ref_offsets = { offsetof(H265RawSlice, data) },
},
{ CBS_UNIT_TYPES_COMPLEX((HEVC_NAL_SEI_PREFIX, HEVC_NAL_SEI_SUFFIX),
// Slices of IRAP pictures. H265RawSEI, cbs_h265_free_sei),
.nb_unit_types = CBS_UNIT_TYPE_RANGE,
.unit_type_range_start = HEVC_NAL_BLA_W_LP,
.unit_type_range_end = HEVC_NAL_CRA_NUT,
.content_type = CBS_CONTENT_TYPE_INTERNAL_REFS,
.content_size = sizeof(H265RawSlice),
.nb_ref_offsets = 1,
.ref_offsets = { offsetof(H265RawSlice, data) },
},
{
.nb_unit_types = 2,
.unit_types = {
HEVC_NAL_SEI_PREFIX,
HEVC_NAL_SEI_SUFFIX
},
.content_type = CBS_CONTENT_TYPE_COMPLEX,
.content_size = sizeof(H265RawSEI),
.content_free = &cbs_h265_free_sei,
},
CBS_UNIT_TYPE_END_OF_LIST CBS_UNIT_TYPE_END_OF_LIST
}; };

@ -181,28 +181,45 @@ int ff_cbs_write_signed(CodedBitstreamContext *ctx, PutBitContext *pbc,
// range_min in the above functions. // range_min in the above functions.
#define MIN_INT_BITS(length) (-(INT64_C(1) << ((length) - 1))) #define MIN_INT_BITS(length) (-(INT64_C(1) << ((length) - 1)))
#define TYPE_LIST(...) { __VA_ARGS__ }
#define CBS_UNIT_TYPE_POD(type, structure) { \ #define CBS_UNIT_TYPE_POD(type, structure) { \
.nb_unit_types = 1, \ .nb_unit_types = 1, \
.unit_types = { type }, \ .unit_types = { type }, \
.content_type = CBS_CONTENT_TYPE_POD, \ .content_type = CBS_CONTENT_TYPE_POD, \
.content_size = sizeof(structure), \ .content_size = sizeof(structure), \
} }
#define CBS_UNIT_TYPE_INTERNAL_REF(type, structure, ref_field) { \
.nb_unit_types = 1, \ #define CBS_UNIT_TYPES_INTERNAL_REF(types, structure, ref_field) { \
.unit_types = { type }, \ .nb_unit_types = FF_ARRAY_ELEMS((CodedBitstreamUnitType[])TYPE_LIST types), \
.unit_types = TYPE_LIST types, \
.content_type = CBS_CONTENT_TYPE_INTERNAL_REFS, \ .content_type = CBS_CONTENT_TYPE_INTERNAL_REFS, \
.content_size = sizeof(structure), \ .content_size = sizeof(structure), \
.nb_ref_offsets = 1, \ .nb_ref_offsets = 1, \
.ref_offsets = { offsetof(structure, ref_field) }, \ .ref_offsets = { offsetof(structure, ref_field) }, \
} }
#define CBS_UNIT_TYPE_COMPLEX(type, structure, free_func) { \ #define CBS_UNIT_TYPE_INTERNAL_REF(type, structure, ref_field) \
.nb_unit_types = 1, \ CBS_UNIT_TYPES_INTERNAL_REF((type), structure, ref_field)
.unit_types = { type }, \
#define CBS_UNIT_RANGE_INTERNAL_REF(range_start, range_end, structure, ref_field) { \
.nb_unit_types = CBS_UNIT_TYPE_RANGE, \
.unit_type_range_start = range_start, \
.unit_type_range_end = range_end, \
.content_type = CBS_CONTENT_TYPE_INTERNAL_REFS, \
.content_size = sizeof(structure), \
.nb_ref_offsets = 1, \
.ref_offsets = { offsetof(structure, ref_field) }, \
}
#define CBS_UNIT_TYPES_COMPLEX(types, structure, free_func) { \
.nb_unit_types = FF_ARRAY_ELEMS((CodedBitstreamUnitType[])TYPE_LIST types), \
.unit_types = TYPE_LIST types, \
.content_type = CBS_CONTENT_TYPE_COMPLEX, \ .content_type = CBS_CONTENT_TYPE_COMPLEX, \
.content_size = sizeof(structure), \ .content_size = sizeof(structure), \
.content_free = free_func, \ .content_free = free_func, \
} }
#define CBS_UNIT_TYPE_COMPLEX(type, structure, free_func) \
CBS_UNIT_TYPES_COMPLEX((type), structure, free_func)
#define CBS_UNIT_TYPE_END_OF_LIST { .nb_unit_types = 0 } #define CBS_UNIT_TYPE_END_OF_LIST { .nb_unit_types = 0 }

Loading…
Cancel
Save