summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLynne <dev@lynne.ee>2022-04-01 22:25:38 +0200
committerNiklas Haas <github-daiK1o@haasn.dev>2022-04-05 15:02:18 +0200
commit3194ed4b5833efcb21e5bba8f6b6b7aa9a6107bc (patch)
tree658f627d0d270934f3d16c58689862e754d00aff
parent083ae8e736832695f636b87f0c8b07d76764b9ec (diff)
downloadmpv-3194ed4b5833efcb21e5bba8f6b6b7aa9a6107bc.tar.bz2
mpv-3194ed4b5833efcb21e5bba8f6b6b7aa9a6107bc.tar.xz
mp_image: support film grain parameters
-rw-r--r--video/mp_image.c10
-rw-r--r--video/mp_image.h2
2 files changed, 12 insertions, 0 deletions
diff --git a/video/mp_image.c b/video/mp_image.c
index 176497627e..ffcc1c138e 100644
--- a/video/mp_image.c
+++ b/video/mp_image.c
@@ -205,6 +205,7 @@ static void mp_image_destructor(void *ptr)
av_buffer_unref(&mpi->icc_profile);
av_buffer_unref(&mpi->a53_cc);
av_buffer_unref(&mpi->dovi);
+ av_buffer_unref(&mpi->film_grain);
for (int n = 0; n < mpi->num_ff_side_data; n++)
av_buffer_unref(&mpi->ff_side_data[n].buf);
talloc_free(mpi->ff_side_data);
@@ -340,6 +341,7 @@ struct mp_image *mp_image_new_ref(struct mp_image *img)
ref_buffer(&ok, &new->icc_profile);
ref_buffer(&ok, &new->a53_cc);
ref_buffer(&ok, &new->dovi);
+ ref_buffer(&ok, &new->film_grain);
new->ff_side_data = talloc_memdup(NULL, new->ff_side_data,
new->num_ff_side_data * sizeof(new->ff_side_data[0]));
@@ -382,6 +384,7 @@ struct mp_image *mp_image_new_dummy_ref(struct mp_image *img)
new->icc_profile = NULL;
new->a53_cc = NULL;
new->dovi = NULL;
+ new->film_grain = NULL;
new->num_ff_side_data = 0;
new->ff_side_data = NULL;
return new;
@@ -532,6 +535,7 @@ void mp_image_copy_attributes(struct mp_image *dst, struct mp_image *src)
}
assign_bufref(&dst->icc_profile, src->icc_profile);
assign_bufref(&dst->dovi, src->dovi);
+ assign_bufref(&dst->film_grain, src->film_grain);
assign_bufref(&dst->a53_cc, src->a53_cc);
}
@@ -1012,6 +1016,12 @@ struct mp_image *mp_image_from_av_frame(struct AVFrame *src)
dst->dovi = sd->buf;
#endif
+#if LIBAVUTIL_VERSION_INT >= AV_VERSION_INT(56, 61, 100)
+ sd = av_frame_get_side_data(src, AV_FRAME_DATA_FILM_GRAIN_PARAMS);
+ if (sd)
+ dst->film_grain = sd->buf;
+#endif
+
for (int n = 0; n < src->nb_side_data; n++) {
sd = src->side_data[n];
struct mp_ff_side_data mpsd = {
diff --git a/video/mp_image.h b/video/mp_image.h
index 17c0eae53f..ac23252fff 100644
--- a/video/mp_image.h
+++ b/video/mp_image.h
@@ -110,6 +110,8 @@ typedef struct mp_image {
struct AVBufferRef *a53_cc;
// Dolby Vision metadata, if any
struct AVBufferRef *dovi;
+ // Film grain data, if any
+ struct AVBufferRef *film_grain;
// Other side data we don't care about.
struct mp_ff_side_data *ff_side_data;
int num_ff_side_data;