e3e158e81f
This function provides an explicit VDPAU device and VDPAU driver to libavcodec, so that the application is relieved from codec specifics and VdpDevice life cycle management. A stub flags parameter is added for future extension. For instance, it could be used to ignore codec level capabilities (if someone feels dangerous). Signed-off-by: Anton Khirnov <anton@khirnov.net>
118 lines
3.0 KiB
C
118 lines
3.0 KiB
C
/*
|
|
* Video Decode and Presentation API for UNIX (VDPAU) is used for
|
|
* HW decode acceleration for MPEG-1/2, H.264 and VC-1.
|
|
*
|
|
* Copyright (C) 2008 NVIDIA
|
|
*
|
|
* This file is part of Libav.
|
|
*
|
|
* Libav is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* Libav is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with Libav; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef AVCODEC_VDPAU_INTERNAL_H
|
|
#define AVCODEC_VDPAU_INTERNAL_H
|
|
|
|
#include <stdint.h>
|
|
#include <vdpau/vdpau.h>
|
|
|
|
#include "avcodec.h"
|
|
#include "mpegvideo.h"
|
|
#include "version.h"
|
|
|
|
/** Extract VdpVideoSurface from an AVFrame */
|
|
static inline uintptr_t ff_vdpau_get_surface_id(AVFrame *pic)
|
|
{
|
|
return (uintptr_t)pic->data[3];
|
|
}
|
|
|
|
#if !FF_API_BUFS_VDPAU
|
|
union AVVDPAUPictureInfo {
|
|
VdpPictureInfoH264 h264;
|
|
VdpPictureInfoMPEG1Or2 mpeg;
|
|
VdpPictureInfoVC1 vc1;
|
|
VdpPictureInfoMPEG4Part2 mpeg4;
|
|
};
|
|
#else
|
|
#include "vdpau.h"
|
|
#endif
|
|
|
|
typedef struct VDPAUHWContext {
|
|
AVVDPAUContext context;
|
|
VdpDevice device;
|
|
VdpGetProcAddress *get_proc_address;
|
|
char reset;
|
|
} VDPAUHWContext;
|
|
|
|
typedef struct VDPAUContext {
|
|
/**
|
|
* VDPAU device handle
|
|
*/
|
|
VdpDevice device;
|
|
|
|
/**
|
|
* VDPAU decoder handle
|
|
*/
|
|
VdpDecoder decoder;
|
|
|
|
/**
|
|
* VDPAU device driver
|
|
*/
|
|
VdpGetProcAddress *get_proc_address;
|
|
|
|
/**
|
|
* VDPAU decoder render callback
|
|
*/
|
|
VdpDecoderRender *render;
|
|
|
|
uint32_t width;
|
|
uint32_t height;
|
|
} VDPAUContext;
|
|
|
|
struct vdpau_picture_context {
|
|
/**
|
|
* VDPAU picture information.
|
|
*/
|
|
union AVVDPAUPictureInfo info;
|
|
|
|
/**
|
|
* Allocated size of the bitstream_buffers table.
|
|
*/
|
|
int bitstream_buffers_allocated;
|
|
|
|
/**
|
|
* Useful bitstream buffers in the bitstream buffers table.
|
|
*/
|
|
int bitstream_buffers_used;
|
|
|
|
/**
|
|
* Table of bitstream buffers.
|
|
*/
|
|
VdpBitstreamBuffer *bitstream_buffers;
|
|
};
|
|
|
|
int ff_vdpau_common_init(AVCodecContext *avctx, VdpDecoderProfile profile,
|
|
int level);
|
|
int ff_vdpau_common_uninit(AVCodecContext *avctx);
|
|
|
|
int ff_vdpau_common_start_frame(struct vdpau_picture_context *pic,
|
|
const uint8_t *buffer, uint32_t size);
|
|
int ff_vdpau_common_end_frame(AVCodecContext *avctx, AVFrame *frame,
|
|
struct vdpau_picture_context *pic);
|
|
int ff_vdpau_mpeg_end_frame(AVCodecContext *avctx);
|
|
int ff_vdpau_add_buffer(struct vdpau_picture_context *pic, const uint8_t *buf,
|
|
uint32_t buf_size);
|
|
|
|
#endif /* AVCODEC_VDPAU_INTERNAL_H */
|