From 6a4430407404bfe55581e66a86a496c9adf6fb44 Mon Sep 17 00:00:00 2001 From: Diego Biurrun Date: Thu, 7 Feb 2013 21:25:55 +0100 Subject: [PATCH] dsputil: Move ff_h264_idct function declarations to a separate header --- libavcodec/dsputil.h | 18 ------------------ libavcodec/h264dsp.c | 1 + libavcodec/h264idct.c | 2 ++ libavcodec/h264idct.h | 42 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 45 insertions(+), 18 deletions(-) create mode 100644 libavcodec/h264idct.h diff --git a/libavcodec/dsputil.h b/libavcodec/dsputil.h index 22c204c475..8b42eee638 100644 --- a/libavcodec/dsputil.h +++ b/libavcodec/dsputil.h @@ -50,24 +50,6 @@ void ff_fdct_mmx(int16_t *block); void ff_fdct_mmxext(int16_t *block); void ff_fdct_sse2(int16_t *block); -#define H264_IDCT(depth) \ -void ff_h264_idct8_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ -void ff_h264_idct_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ -void ff_h264_idct8_dc_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ -void ff_h264_idct_dc_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ -void ff_h264_idct_add16_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ -void ff_h264_idct_add16intra_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ -void ff_h264_idct8_add4_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ -void ff_h264_idct_add8_422_ ## depth ## _c(uint8_t **dest, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ -void ff_h264_idct_add8_ ## depth ## _c(uint8_t **dest, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ -void ff_h264_luma_dc_dequant_idct_ ## depth ## _c(int16_t *output, int16_t *input, int qmul);\ -void ff_h264_chroma422_dc_dequant_idct_ ## depth ## _c(int16_t *block, int qmul);\ -void ff_h264_chroma_dc_dequant_idct_ ## depth ## _c(int16_t *block, int qmul); - -H264_IDCT( 8) -H264_IDCT( 9) -H264_IDCT(10) - void ff_svq3_luma_dc_dequant_idct_c(int16_t *output, int16_t *input, int qp); void ff_svq3_add_idct_c(uint8_t *dst, int16_t *block, int stride, int qp, int dc); diff --git a/libavcodec/h264dsp.c b/libavcodec/h264dsp.c index 1353c1a72f..d29c685008 100644 --- a/libavcodec/h264dsp.c +++ b/libavcodec/h264dsp.c @@ -28,6 +28,7 @@ #include #include "avcodec.h" #include "h264dsp.h" +#include "h264idct.h" #include "libavutil/common.h" #define BIT_DEPTH 8 diff --git a/libavcodec/h264idct.c b/libavcodec/h264idct.c index 1634a00835..ea08d03b07 100644 --- a/libavcodec/h264idct.c +++ b/libavcodec/h264idct.c @@ -25,6 +25,8 @@ * @author Michael Niedermayer */ +#include "h264idct.h" + #define BIT_DEPTH 8 #include "h264idct_template.c" #undef BIT_DEPTH diff --git a/libavcodec/h264idct.h b/libavcodec/h264idct.h new file mode 100644 index 0000000000..816a8251ba --- /dev/null +++ b/libavcodec/h264idct.h @@ -0,0 +1,42 @@ +/* + * 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_H264IDCT_H +#define AVCODEC_H264IDCT_H + +#include + +#define H264_IDCT(depth) \ +void ff_h264_idct8_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ +void ff_h264_idct_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ +void ff_h264_idct8_dc_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ +void ff_h264_idct_dc_add_ ## depth ## _c(uint8_t *dst, int16_t *block, int stride);\ +void ff_h264_idct_add16_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ +void ff_h264_idct_add16intra_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ +void ff_h264_idct8_add4_ ## depth ## _c(uint8_t *dst, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ +void ff_h264_idct_add8_422_ ## depth ## _c(uint8_t **dest, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ +void ff_h264_idct_add8_ ## depth ## _c(uint8_t **dest, const int *blockoffset, int16_t *block, int stride, const uint8_t nnzc[6*8]);\ +void ff_h264_luma_dc_dequant_idct_ ## depth ## _c(int16_t *output, int16_t *input, int qmul);\ +void ff_h264_chroma422_dc_dequant_idct_ ## depth ## _c(int16_t *block, int qmul);\ +void ff_h264_chroma_dc_dequant_idct_ ## depth ## _c(int16_t *block, int qmul); + +H264_IDCT( 8) +H264_IDCT( 9) +H264_IDCT(10) + +#endif /* AVCODEC_H264IDCT_H */