[FFmpeg-devel] [PATCH] avcodec/libdav1d: add support for closed captions stored in ITU-T T35 metadata
Marton Balint
cus at passwd.hu
Wed Jun 3 23:47:47 EEST 2020
On Tue, 2 Jun 2020, James Almer wrote:
> Based on code from h264_sei.c
hevc_sei.c also has a similar code snippet.
This seems like something that should be factorized to common code... Or
is it too much pain for some reason?
Thanks,
Marton
>
> Signed-off-by: James Almer <jamrial at gmail.com>
> ---
> configure | 2 +-
> libavcodec/libdav1d.c | 49 +++++++++++++++++++++++++++++++++++++++++++
> 2 files changed, 50 insertions(+), 1 deletion(-)
>
> diff --git a/configure b/configure
> index 8569a60bf8..2961118682 100755
> --- a/configure
> +++ b/configure
> @@ -6295,7 +6295,7 @@ enabled libcelt && require libcelt celt/celt.h celt_decode -lcelt0 &&
> die "ERROR: libcelt must be installed and version must be >= 0.11.0."; }
> enabled libcaca && require_pkg_config libcaca caca caca.h caca_create_canvas
> enabled libcodec2 && require libcodec2 codec2/codec2.h codec2_create -lcodec2
> -enabled libdav1d && require_pkg_config libdav1d "dav1d >= 0.4.0" "dav1d/dav1d.h" dav1d_version
> +enabled libdav1d && require_pkg_config libdav1d "dav1d >= 0.5.0" "dav1d/dav1d.h" dav1d_version
> enabled libdavs2 && require_pkg_config libdavs2 "davs2 >= 1.6.0" davs2.h davs2_decoder_open
> enabled libdc1394 && require_pkg_config libdc1394 libdc1394-2 dc1394/dc1394.h dc1394_new
> enabled libdrm && require_pkg_config libdrm libdrm xf86drm.h drmGetVersion
> diff --git a/libavcodec/libdav1d.c b/libavcodec/libdav1d.c
> index bbb3ec1e6c..e8010655d0 100644
> --- a/libavcodec/libdav1d.c
> +++ b/libavcodec/libdav1d.c
> @@ -28,6 +28,7 @@
>
> #include "avcodec.h"
> #include "decode.h"
> +#include "get_bits.h"
> #include "internal.h"
>
> typedef struct Libdav1dContext {
> @@ -364,6 +365,54 @@ FF_ENABLE_DEPRECATION_WARNINGS
> light->MaxCLL = p->content_light->max_content_light_level;
> light->MaxFALL = p->content_light->max_frame_average_light_level;
> }
> + if (p->itut_t35) {
> + GetBitContext gb;
> + unsigned int user_identifier;
> +
> + res = init_get_bits8(&gb, p->itut_t35->payload, p->itut_t35->payload_size);
> + if (res < 0)
> + return res;
> +
> + skip_bits(&gb, 8); // terminal provider code
> + skip_bits(&gb, 8); // terminal provider oriented code
> + user_identifier = get_bits_long(&gb, 32);
> + switch (user_identifier) {
> + case MKBETAG('G', 'A', '9', '4'): // closed captions
> + if (get_bits(&gb, 8) == 0x3) { // user_data_type_code
> + int flag;
> +
> + skip_bits(&gb, 1); // reserved
> + flag = get_bits(&gb, 1); // process_cc_data_flag
> + if (flag) {
> + int size, cc_count;
> +
> + skip_bits(&gb, 1); // zero bit
> + cc_count = get_bits(&gb, 5);
> + skip_bits(&gb, 8); // reserved
> +
> + size = cc_count * 3;
> + if (cc_count && (get_bits_left(&gb) >> 3) >= size + 1) {
> + AVFrameSideData *sd = av_frame_new_side_data(frame, AV_FRAME_DATA_A53_CC, size);
> + if (!sd) {
> + res = AVERROR(ENOMEM);
> + goto fail;
> + }
> +
> + for (int i = 0, j = 0; i < cc_count; i++) {
> + sd->data[j++] = get_bits(&gb, 8);
> + sd->data[j++] = get_bits(&gb, 8);
> + sd->data[j++] = get_bits(&gb, 8);
> + }
> +
> + skip_bits(&gb, 8); // marker_bits
> + }
> + }
> + }
> + break;
> + default: // ignore unsupported identifiers
> + break;
> + }
> + }
>
> res = 0;
> fail:
> --
> 2.26.2
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
More information about the ffmpeg-devel
mailing list