Commit 9056d0c9 authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '5b2b23f2'

* commit '5b2b23f2':
  dxva2: Retry IDirectXVideoDecoder_BeginFrame()

This also adds a missig #include to prevent breaking building
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents a69dd116 5b2b23f2
......@@ -21,6 +21,7 @@
*/
#include "dxva2_internal.h"
#include "libavutil/time.h"
void *ff_dxva2_get_surface(const Picture *picture)
{
......@@ -87,12 +88,19 @@ int ff_dxva2_common_end_frame(AVCodecContext *avctx, Picture *pic,
unsigned buffer_count = 0;
DXVA2_DecodeBufferDesc buffer[4];
DXVA2_DecodeExecuteParams exec = { 0 };
int result;
if (FAILED(IDirectXVideoDecoder_BeginFrame(ctx->decoder,
ff_dxva2_get_surface(pic),
NULL))) {
av_log(avctx, AV_LOG_ERROR, "Failed to begin frame\n");
int result, runs = 0;
HRESULT hr;
do {
hr = IDirectXVideoDecoder_BeginFrame(ctx->decoder,
ff_dxva2_get_surface(pic),
NULL);
if (hr == E_PENDING)
av_usleep(2000);
} while (hr == E_PENDING && ++runs < 50);
if (FAILED(hr)) {
av_log(avctx, AV_LOG_ERROR, "Failed to begin frame: 0x%x\n", hr);
return -1;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment