Browse Source

avconv_vdpau: allocate video surface of VDPAU-specified size

Signed-off-by: Rémi Denis-Courmont <remi@remlab.net>
Signed-off-by: Anton Khirnov <anton@khirnov.net>
tags/n2.6
Rémi Denis-Courmont Anton Khirnov 11 years ago
parent
commit
1f9237f2ac
1 changed files with 7 additions and 2 deletions
  1. +7
    -2
      avconv_vdpau.c

+ 7
- 2
avconv_vdpau.c View File

@@ -90,9 +90,14 @@ static int vdpau_get_buffer(AVCodecContext *s, AVFrame *frame, int flags)
VDPAUContext *ctx = ist->hwaccel_ctx; VDPAUContext *ctx = ist->hwaccel_ctx;
VdpVideoSurface *surface; VdpVideoSurface *surface;
VdpStatus err; VdpStatus err;
VdpChromaType chroma;
uint32_t width, height;


av_assert0(frame->format == AV_PIX_FMT_VDPAU); av_assert0(frame->format == AV_PIX_FMT_VDPAU);


if (av_vdpau_get_surface_parameters(s, &chroma, &width, &height))
return AVERROR(ENOSYS);

surface = av_malloc(sizeof(*surface)); surface = av_malloc(sizeof(*surface));
if (!surface) if (!surface)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
@@ -108,8 +113,8 @@ static int vdpau_get_buffer(AVCodecContext *s, AVFrame *frame, int flags)
// properly we should keep a pool of surfaces instead of creating // properly we should keep a pool of surfaces instead of creating
// them anew for each frame, but since we don't care about speed // them anew for each frame, but since we don't care about speed
// much in this code, we don't bother // much in this code, we don't bother
err = ctx->video_surface_create(ctx->device, VDP_CHROMA_TYPE_420,
frame->width, frame->height, surface);
err = ctx->video_surface_create(ctx->device, chroma, width, height,
surface);
if (err != VDP_STATUS_OK) { if (err != VDP_STATUS_OK) {
av_log(NULL, AV_LOG_ERROR, "Error allocating a VDPAU video surface: %s\n", av_log(NULL, AV_LOG_ERROR, "Error allocating a VDPAU video surface: %s\n",
ctx->get_error_string(err)); ctx->get_error_string(err));


Loading…
Cancel
Save