ffmpeg | branch: master | Dmitrii Ovchinnikov <ovchinnikov.dmit...@gmail.com> | 
Wed Mar 12 16:15:53 2025 +0100| [5b460bde8b31145e0a092e3922e46bea2969ae01] | 
committer: Dmitrii Ovchinnikov

libavutil/hwcontext_amf: add format validation in transfer_data functions

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5b460bde8b31145e0a092e3922e46bea2969ae01
---

 libavutil/hwcontext_amf.c | 6 ++++++
 1 file changed, 6 insertions(+)

diff --git a/libavutil/hwcontext_amf.c b/libavutil/hwcontext_amf.c
index b751a3c1ad..24731c20ec 100644
--- a/libavutil/hwcontext_amf.c
+++ b/libavutil/hwcontext_amf.c
@@ -277,6 +277,9 @@ static int amf_transfer_data_to(AVHWFramesContext *ctx, 
AVFrame *dst,
     int w = FFMIN(dst->width,  src->width);
     int h = FFMIN(dst->height, src->height);
 
+    if (dst->hw_frames_ctx->data != (uint8_t *)ctx || src->format != 
ctx->sw_format)
+        return AVERROR(EINVAL);
+
     if (!surface) {
         AVHWDeviceContext   *hwdev_ctx = ctx->device_ctx;
         AVAMFDeviceContext  *amf_device_ctx = (AVAMFDeviceContext 
*)hwdev_ctx->hwctx;
@@ -319,6 +322,9 @@ static int amf_transfer_data_from(AVHWFramesContext *ctx, 
AVFrame *dst,
     int h = FFMIN(dst->height, src->height);
     int ret;
 
+    if (src->hw_frames_ctx->data != (uint8_t *)ctx || dst->format != 
ctx->sw_format)
+        return AVERROR(EINVAL);
+
     ret = surface->pVtbl->Convert(surface, AMF_MEMORY_HOST);
     AMF_RETURN_IF_FALSE(ctx, ret == AMF_OK, AVERROR_UNKNOWN, 
"Convert(amf::AMF_MEMORY_HOST) failed with error %d\n", AVERROR_UNKNOWN);
 

_______________________________________________
ffmpeg-cvslog mailing list
ffmpeg-cvslog@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-cvslog

To unsubscribe, visit link above, or email
ffmpeg-cvslog-requ...@ffmpeg.org with subject "unsubscribe".

Reply via email to