hwaccel: Deinitialize hardware acceleration early enough
The application will destroy the underlying hardware handles when get_format() gets called again. Also this ensures the deinitialization takes place if the get_format callback returns an error. Regression from 1c80c9d7ef809180042257200c7b5f6b81d0b0e2. Signed-off-by: Luca Barbato <lu_zero@gentoo.org>
This commit is contained in:
parent
77ab341c0c
commit
4ff670d99b
@ -948,6 +948,11 @@ int ff_get_format(AVCodecContext *avctx, const enum AVPixelFormat *fmt)
|
|||||||
memcpy(choices, fmt, (n + 1) * sizeof(*choices));
|
memcpy(choices, fmt, (n + 1) * sizeof(*choices));
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
if (avctx->hwaccel && avctx->hwaccel->uninit)
|
||||||
|
avctx->hwaccel->uninit(avctx);
|
||||||
|
av_freep(&avctx->internal->hwaccel_priv_data);
|
||||||
|
avctx->hwaccel = NULL;
|
||||||
|
|
||||||
ret = avctx->get_format(avctx, choices);
|
ret = avctx->get_format(avctx, choices);
|
||||||
|
|
||||||
desc = av_pix_fmt_desc_get(ret);
|
desc = av_pix_fmt_desc_get(ret);
|
||||||
@ -956,11 +961,6 @@ int ff_get_format(AVCodecContext *avctx, const enum AVPixelFormat *fmt)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (avctx->hwaccel && avctx->hwaccel->uninit)
|
|
||||||
avctx->hwaccel->uninit(avctx);
|
|
||||||
av_freep(&avctx->internal->hwaccel_priv_data);
|
|
||||||
avctx->hwaccel = NULL;
|
|
||||||
|
|
||||||
if (!(desc->flags & AV_PIX_FMT_FLAG_HWACCEL))
|
if (!(desc->flags & AV_PIX_FMT_FLAG_HWACCEL))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user