diff options
author | Sam Lantinga <slouken@libsdl.org> | 2014-01-19 15:42:36 +0100 |
---|---|---|
committer | Luca Barbato <lu_zero@gentoo.org> | 2014-01-21 12:46:29 +0100 |
commit | 9d80b1ae9590a3d764b1b334fc2d1ef0097bcc1c (patch) | |
tree | 79cdd6c92036bbf258ad8fcabb541989dd654116 | |
parent | 5b2b23f2d69e05c5fcd1c933e383fe60e185574d (diff) | |
download | ffmpeg-9d80b1ae9590a3d764b1b334fc2d1ef0097bcc1c.tar.gz |
dxva2: Log errors verbosely
Signed-off-by: Luca Barbato <lu_zero@gentoo.org>
-rw-r--r-- | libavcodec/dxva2.c | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/libavcodec/dxva2.c b/libavcodec/dxva2.c index b6efa157d0..f8b8eba4bf 100644 --- a/libavcodec/dxva2.c +++ b/libavcodec/dxva2.c @@ -50,10 +50,13 @@ int ff_dxva2_commit_buffer(AVCodecContext *avctx, void *dxva_data; unsigned dxva_size; int result; + HRESULT hr; - if (FAILED(IDirectXVideoDecoder_GetBuffer(ctx->decoder, type, - &dxva_data, &dxva_size))) { - av_log(avctx, AV_LOG_ERROR, "Failed to get a buffer for %d\n", type); + hr = IDirectXVideoDecoder_GetBuffer(ctx->decoder, type, + &dxva_data, &dxva_size); + if (FAILED(hr)) { + av_log(avctx, AV_LOG_ERROR, "Failed to get a buffer for %d: 0x%x\n", + type, hr); return -1; } if (size <= dxva_size) { @@ -69,8 +72,12 @@ int ff_dxva2_commit_buffer(AVCodecContext *avctx, av_log(avctx, AV_LOG_ERROR, "Buffer for type %d was too small\n", type); result = -1; } - if (FAILED(IDirectXVideoDecoder_ReleaseBuffer(ctx->decoder, type))) { - av_log(avctx, AV_LOG_ERROR, "Failed to release buffer type %d\n", type); + + hr = IDirectXVideoDecoder_ReleaseBuffer(ctx->decoder, type); + if (FAILED(hr)) { + av_log(avctx, AV_LOG_ERROR, + "Failed to release buffer type %d: 0x%x\n", + type, hr); result = -1; } return result; @@ -142,14 +149,16 @@ int ff_dxva2_common_end_frame(AVCodecContext *avctx, Picture *pic, exec.NumCompBuffers = buffer_count; exec.pCompressedBuffers = buffer; exec.pExtensionData = NULL; - if (FAILED(IDirectXVideoDecoder_Execute(ctx->decoder, &exec))) { - av_log(avctx, AV_LOG_ERROR, "Failed to execute\n"); + hr = IDirectXVideoDecoder_Execute(ctx->decoder, &exec); + if (FAILED(hr)) { + av_log(avctx, AV_LOG_ERROR, "Failed to execute: 0x%x\n", hr); result = -1; } end: - if (FAILED(IDirectXVideoDecoder_EndFrame(ctx->decoder, NULL))) { - av_log(avctx, AV_LOG_ERROR, "Failed to end frame\n"); + hr = IDirectXVideoDecoder_EndFrame(ctx->decoder, NULL); + if (FAILED(hr)) { + av_log(avctx, AV_LOG_ERROR, "Failed to end frame: 0x%x\n", hr); result = -1; } |