summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2023-03-03 13:19:02 -0300
committerJames Almer <jamrial@gmail.com>2023-03-08 12:44:27 -0300
commitb465e6fed0f7bc1b9a0bf934c8674bc56cb82e36 (patch)
tree68d771fd3be924ab080c733c496a09d33c217a72
parentcc76e8340d28438c1ac56ee7dfd774d25e944264 (diff)
avcodec/libdav1d: export Dynamic HDR10+ frame metadata
As defined in https://aomediacodec.github.io/av1-hdr10plus/ Reviewed-by: Ronald S. Bultje <rsbultje@gmail.com> Signed-off-by: James Almer <jamrial@gmail.com>
-rw-r--r--libavcodec/libdav1d.c36
1 files changed, 32 insertions, 4 deletions
diff --git a/libavcodec/libdav1d.c b/libavcodec/libdav1d.c
index 2488a709c7..1f0c36fc55 100644
--- a/libavcodec/libdav1d.c
+++ b/libavcodec/libdav1d.c
@@ -33,6 +33,7 @@
#include "bytestream.h"
#include "codec_internal.h"
#include "decode.h"
+#include "dynamic_hdr10_plus.h"
#include "internal.h"
#define FF_DAV1D_VERSION_AT_LEAST(x,y) \
@@ -511,12 +512,14 @@ FF_ENABLE_DEPRECATION_WARNINGS
}
if (p->itut_t35) {
GetByteContext gb;
- unsigned int user_identifier;
+ int provider_code;
bytestream2_init(&gb, p->itut_t35->payload, p->itut_t35->payload_size);
- bytestream2_skip(&gb, 1); // terminal provider code
- bytestream2_skip(&gb, 1); // terminal provider oriented code
- user_identifier = bytestream2_get_be32(&gb);
+
+ provider_code = bytestream2_get_be16(&gb);
+ switch (provider_code) {
+ case 0x31: { // atsc_provider_code
+ uint32_t user_identifier = bytestream2_get_be32(&gb);
switch (user_identifier) {
case MKBETAG('G', 'A', '9', '4'): { // closed captions
AVBufferRef *buf = NULL;
@@ -536,6 +539,31 @@ FF_ENABLE_DEPRECATION_WARNINGS
default: // ignore unsupported identifiers
break;
}
+ }
+ case 0x3C: { // smpte_provider_code
+ AVDynamicHDRPlus *hdrplus;
+ int provider_oriented_code = bytestream2_get_be16(&gb);
+ int application_identifier = bytestream2_get_byte(&gb);
+
+ if (p->itut_t35->country_code != 0xB5 ||
+ provider_oriented_code != 1 || application_identifier != 4)
+ break;
+
+ hdrplus = av_dynamic_hdr_plus_create_side_data(frame);
+ if (!hdrplus) {
+ res = AVERROR(ENOMEM);
+ goto fail;
+ }
+
+ res = ff_parse_itu_t_t35_to_dynamic_hdr10_plus(hdrplus, gb.buffer,
+ bytestream2_get_bytes_left(&gb));
+ if (res < 0)
+ goto fail;
+ break;
+ }
+ default: // ignore unsupported provider codes
+ break;
+ }
}
if (p->frame_hdr->film_grain.present && (!dav1d->apply_grain ||
(c->export_side_data & AV_CODEC_EXPORT_DATA_FILM_GRAIN))) {