Commit 9ae766d1 authored by Philip Langdale's avatar Philip Langdale

avcodec/vdpau: Re-factor pre-hwaccel helper functions into separate header

h264.h and hevc.h are mutually exclusive due to defining some of the same
names. As such, we need to avoid forcing h264.h to be included if we want
hevc decode acceleration to be possible.

However, some of the pre-hwaccel helper functions need h264.h. To avoid
messy collisions, let's move the declaration of all those helpers to
a separate header which we will exclude for the hevc support (which will
be hwaccel-only).
Signed-off-by: 's avatarPhilip Langdale <philipl@overt.org>
parent 7ed5d78d
...@@ -40,7 +40,7 @@ ...@@ -40,7 +40,7 @@
#include "mpegvideo.h" #include "mpegvideo.h"
#include "msmpeg4.h" #include "msmpeg4.h"
#include "qpeldsp.h" #include "qpeldsp.h"
#include "vdpau_internal.h" #include "vdpau_compat.h"
#include "thread.h" #include "thread.h"
static enum AVPixelFormat h263_get_format(AVCodecContext *avctx) static enum AVPixelFormat h263_get_format(AVCodecContext *avctx)
......
...@@ -49,7 +49,7 @@ ...@@ -49,7 +49,7 @@
#include "rectangle.h" #include "rectangle.h"
#include "svq3.h" #include "svq3.h"
#include "thread.h" #include "thread.h"
#include "vdpau_internal.h" #include "vdpau_compat.h"
const uint16_t ff_h264_mb_sizes[4] = { 256, 384, 512, 768 }; const uint16_t ff_h264_mb_sizes[4] = { 256, 384, 512, 768 };
......
...@@ -42,7 +42,7 @@ ...@@ -42,7 +42,7 @@
#include "mpegutils.h" #include "mpegutils.h"
#include "rectangle.h" #include "rectangle.h"
#include "thread.h" #include "thread.h"
#include "vdpau_internal.h" #include "vdpau_compat.h"
void ff_h264_unref_picture(H264Context *h, H264Picture *pic) void ff_h264_unref_picture(H264Context *h, H264Picture *pic)
{ {
......
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
#include "mpegvideo.h" #include "mpegvideo.h"
#include "thread.h" #include "thread.h"
#include "version.h" #include "version.h"
#include "vdpau_internal.h" #include "vdpau_compat.h"
#include "xvmc_internal.h" #include "xvmc_internal.h"
typedef struct Mpeg1Context { typedef struct Mpeg1Context {
......
...@@ -35,7 +35,7 @@ ...@@ -35,7 +35,7 @@
#include "msmpeg4data.h" #include "msmpeg4data.h"
#include "vc1.h" #include "vc1.h"
#include "vc1data.h" #include "vc1data.h"
#include "vdpau_internal.h" #include "vdpau_compat.h"
#include "libavutil/avassert.h" #include "libavutil/avassert.h"
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
#include <assert.h> #include <assert.h>
#include "vdpau.h" #include "vdpau.h"
#include "vdpau_compat.h"
#include "vdpau_internal.h" #include "vdpau_internal.h"
/** /**
......
/*
* 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 FFmpeg.
*
* FFmpeg 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.
*
* FFmpeg 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 FFmpeg; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef AVCODEC_VDPAU_COMPAT_H
#define AVCODEC_VDPAU_COMPAT_H
#include <stdint.h>
#include "h264.h"
#include "mpeg4video.h"
void ff_vdpau_add_data_chunk(uint8_t *data, const uint8_t *buf,
int buf_size);
void ff_vdpau_mpeg_picture_complete(MpegEncContext *s, const uint8_t *buf,
int buf_size, int slice_count);
void ff_vdpau_h264_picture_start(H264Context *h);
void ff_vdpau_h264_set_reference_frames(H264Context *h);
void ff_vdpau_h264_picture_complete(H264Context *h);
void ff_vdpau_vc1_decode_picture(MpegEncContext *s, const uint8_t *buf,
int buf_size);
void ff_vdpau_mpeg4_decode_picture(Mpeg4DecContext *s, const uint8_t *buf,
int buf_size);
#endif /* AVCODEC_VDPAU_COMPAT_H */
...@@ -29,12 +29,10 @@ ...@@ -29,12 +29,10 @@
#if CONFIG_VDPAU #if CONFIG_VDPAU
#include <vdpau/vdpau.h> #include <vdpau/vdpau.h>
#endif #endif
#include "h264.h"
#include "libavutil/frame.h" #include "libavutil/frame.h"
#include "avcodec.h" #include "avcodec.h"
#include "mpeg4video.h"
/** Extract VdpVideoSurface from an AVFrame */ /** Extract VdpVideoSurface from an AVFrame */
static inline uintptr_t ff_vdpau_get_surface_id(AVFrame *pic) static inline uintptr_t ff_vdpau_get_surface_id(AVFrame *pic)
...@@ -125,21 +123,4 @@ int ff_vdpau_mpeg_end_frame(AVCodecContext *avctx); ...@@ -125,21 +123,4 @@ int ff_vdpau_mpeg_end_frame(AVCodecContext *avctx);
int ff_vdpau_add_buffer(struct vdpau_picture_context *pic, const uint8_t *buf, int ff_vdpau_add_buffer(struct vdpau_picture_context *pic, const uint8_t *buf,
uint32_t buf_size); uint32_t buf_size);
void ff_vdpau_add_data_chunk(uint8_t *data, const uint8_t *buf,
int buf_size);
void ff_vdpau_mpeg_picture_complete(MpegEncContext *s, const uint8_t *buf,
int buf_size, int slice_count);
void ff_vdpau_h264_picture_start(H264Context *h);
void ff_vdpau_h264_set_reference_frames(H264Context *h);
void ff_vdpau_h264_picture_complete(H264Context *h);
void ff_vdpau_vc1_decode_picture(MpegEncContext *s, const uint8_t *buf,
int buf_size);
void ff_vdpau_mpeg4_decode_picture(Mpeg4DecContext *s, const uint8_t *buf,
int buf_size);
#endif /* AVCODEC_VDPAU_INTERNAL_H */ #endif /* AVCODEC_VDPAU_INTERNAL_H */
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