[FFmpeg-cvslog] avcodec/dovi_rpuenc: respect dv_md_compression
Niklas Haas
git at videolan.org
Fri Aug 16 12:51:52 EEST 2024
ffmpeg | branch: master | Niklas Haas <git at haasn.dev> | Thu Jul 18 15:45:15 2024 +0200| [c62b364dcb549bc0a882af7da3e338d443f78128] | committer: Niklas Haas
avcodec/dovi_rpuenc: respect dv_md_compression
Limited mode can only ever maintain a single VDR RPU reference, and
furthermore requires vdr_rpu_id == 0. So in practice, it will only ever
use VDR RPU slot 0. All remaining slots get flushed in this case, to
avoid leaking partial state.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=c62b364dcb549bc0a882af7da3e338d443f78128
---
libavcodec/dovi_rpuenc.c | 26 +++++++++++++++++++++++++-
1 file changed, 25 insertions(+), 1 deletion(-)
diff --git a/libavcodec/dovi_rpuenc.c b/libavcodec/dovi_rpuenc.c
index 63cbde8718..2a6131eff5 100644
--- a/libavcodec/dovi_rpuenc.c
+++ b/libavcodec/dovi_rpuenc.c
@@ -464,12 +464,37 @@ int ff_dovi_rpu_generate(DOVIContext *s, const AVDOVIMetadata *metadata,
}
vdr_rpu_id = mapping->vdr_rpu_id;
+ use_prev_vdr_rpu = 0;
+
if (!s->vdr[vdr_rpu_id]) {
s->vdr[vdr_rpu_id] = ff_refstruct_allocz(sizeof(AVDOVIDataMapping));
if (!s->vdr[vdr_rpu_id])
return AVERROR(ENOMEM);
}
+ switch (s->cfg.dv_md_compression) {
+ case AV_DOVI_COMPRESSION_LIMITED:
+ /* Limited metadata compression requires vdr_rpi_id == 0 */
+ if (vdr_rpu_id != 0)
+ break;
+ /* fall through */
+ case AV_DOVI_COMPRESSION_EXTENDED:
+ if (s->vdr[vdr_rpu_id])
+ use_prev_vdr_rpu = !memcmp(s->vdr[vdr_rpu_id], mapping, sizeof(*mapping));
+ break;
+ case AV_DOVI_COMPRESSION_RESERVED:
+ return AVERROR(EINVAL);
+ }
+
+ if (s->cfg.dv_md_compression != AV_DOVI_COMPRESSION_EXTENDED) {
+ /* Flush VDRs to avoid leaking old state; maintaining multiple VDR
+ * references requires extended compression */
+ for (int i = 0; i <= DOVI_MAX_DM_ID; i++) {
+ if (i != vdr_rpu_id)
+ ff_refstruct_unref(&s->vdr[i]);
+ }
+ }
+
num_ext_blocks_v1 = num_ext_blocks_v2 = 0;
for (int i = 0; i < metadata->num_ext_blocks; i++) {
const AVDOVIDmData *dm = av_dovi_get_ext(metadata, i);
@@ -504,7 +529,6 @@ int ff_dovi_rpu_generate(DOVIContext *s, const AVDOVIMetadata *metadata,
}
vdr_dm_metadata_present = memcmp(color, &ff_dovi_color_default, sizeof(*color));
- use_prev_vdr_rpu = !memcmp(s->vdr[vdr_rpu_id], mapping, sizeof(*mapping));
if (num_ext_blocks_v1 || num_ext_blocks_v2)
vdr_dm_metadata_present = 1;
More information about the ffmpeg-cvslog
mailing list