[FFmpeg-cvslog] libavutil/hwcontext_amf: add format validation in transfer_data functions
Dmitrii Ovchinnikov
git at videolan.org
Fri Mar 21 18:39:51 EET 2025
ffmpeg | branch: master | Dmitrii Ovchinnikov <ovchinnikov.dmitrii at 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);
More information about the ffmpeg-cvslog
mailing list