mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-05-13 21:26:33 +02:00
avcodec/mpeg12.h: Move decoder-only stuff to a new header
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
parent
f78ffe382c
commit
977d8b6297
@ -36,8 +36,8 @@
|
|||||||
#include "eaidct.h"
|
#include "eaidct.h"
|
||||||
#include "idctdsp.h"
|
#include "idctdsp.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
#include "mpeg12.h"
|
|
||||||
#include "mpeg12data.h"
|
#include "mpeg12data.h"
|
||||||
|
#include "mpeg12dec.h"
|
||||||
|
|
||||||
typedef struct TqiContext {
|
typedef struct TqiContext {
|
||||||
AVCodecContext *avctx;
|
AVCodecContext *avctx;
|
||||||
|
@ -33,8 +33,9 @@
|
|||||||
#include "blockdsp.h"
|
#include "blockdsp.h"
|
||||||
#include "bswapdsp.h"
|
#include "bswapdsp.h"
|
||||||
#include "idctdsp.h"
|
#include "idctdsp.h"
|
||||||
#include "mpeg12.h"
|
#include "internal.h"
|
||||||
#include "mpeg12data.h"
|
#include "mpeg12data.h"
|
||||||
|
#include "mpeg12dec.h"
|
||||||
#include "thread.h"
|
#include "thread.h"
|
||||||
|
|
||||||
typedef struct MDECContext {
|
typedef struct MDECContext {
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#include "mpegvideo.h"
|
#include "mpegvideo.h"
|
||||||
#include "mpeg12.h"
|
#include "mpeg12.h"
|
||||||
#include "mpeg12data.h"
|
#include "mpeg12data.h"
|
||||||
|
#include "mpeg12dec.h"
|
||||||
#include "mpegvideodata.h"
|
#include "mpegvideodata.h"
|
||||||
#include "startcode.h"
|
#include "startcode.h"
|
||||||
|
|
||||||
@ -234,7 +235,7 @@ int ff_mpeg1_find_frame_end(ParseContext *pc, const uint8_t *buf, int buf_size,
|
|||||||
|
|
||||||
int ff_mpeg1_decode_block_intra(GetBitContext *gb,
|
int ff_mpeg1_decode_block_intra(GetBitContext *gb,
|
||||||
const uint16_t *quant_matrix,
|
const uint16_t *quant_matrix,
|
||||||
uint8_t *const scantable, int last_dc[3],
|
const uint8_t *scantable, int last_dc[3],
|
||||||
int16_t *block, int index, int qscale)
|
int16_t *block, int index, int qscale)
|
||||||
{
|
{
|
||||||
int dc, diff, i = 0, component;
|
int dc, diff, i = 0, component;
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
#ifndef AVCODEC_MPEG12_H
|
#ifndef AVCODEC_MPEG12_H
|
||||||
#define AVCODEC_MPEG12_H
|
#define AVCODEC_MPEG12_H
|
||||||
|
|
||||||
#include "mpeg12vlc.h"
|
|
||||||
#include "mpegvideo.h"
|
#include "mpegvideo.h"
|
||||||
|
|
||||||
/* Start codes. */
|
/* Start codes. */
|
||||||
@ -37,38 +36,8 @@
|
|||||||
|
|
||||||
void ff_mpeg12_common_init(MpegEncContext *s);
|
void ff_mpeg12_common_init(MpegEncContext *s);
|
||||||
|
|
||||||
#define INIT_2D_VLC_RL(rl, static_size, flags)\
|
|
||||||
{\
|
|
||||||
static RL_VLC_ELEM rl_vlc_table[static_size];\
|
|
||||||
rl.rl_vlc[0] = rl_vlc_table;\
|
|
||||||
ff_init_2d_vlc_rl(&rl, static_size, flags);\
|
|
||||||
}
|
|
||||||
|
|
||||||
void ff_init_2d_vlc_rl(RLTable *rl, unsigned static_size, int flags);
|
|
||||||
void ff_mpeg1_init_uni_ac_vlc(const RLTable *rl, uint8_t *uni_ac_vlc_len);
|
void ff_mpeg1_init_uni_ac_vlc(const RLTable *rl, uint8_t *uni_ac_vlc_len);
|
||||||
|
|
||||||
static inline int decode_dc(GetBitContext *gb, int component)
|
|
||||||
{
|
|
||||||
int code, diff;
|
|
||||||
|
|
||||||
if (component == 0) {
|
|
||||||
code = get_vlc2(gb, ff_dc_lum_vlc.table, DC_VLC_BITS, 2);
|
|
||||||
} else {
|
|
||||||
code = get_vlc2(gb, ff_dc_chroma_vlc.table, DC_VLC_BITS, 2);
|
|
||||||
}
|
|
||||||
if (code == 0) {
|
|
||||||
diff = 0;
|
|
||||||
} else {
|
|
||||||
diff = get_xbits(gb, code);
|
|
||||||
}
|
|
||||||
return diff;
|
|
||||||
}
|
|
||||||
|
|
||||||
int ff_mpeg1_decode_block_intra(GetBitContext *gb,
|
|
||||||
const uint16_t *quant_matrix,
|
|
||||||
uint8_t *const scantable, int last_dc[3],
|
|
||||||
int16_t *block, int index, int qscale);
|
|
||||||
|
|
||||||
void ff_mpeg1_clean_buffers(MpegEncContext *s);
|
void ff_mpeg1_clean_buffers(MpegEncContext *s);
|
||||||
#if FF_API_FLAG_TRUNCATED
|
#if FF_API_FLAG_TRUNCATED
|
||||||
int ff_mpeg1_find_frame_end(ParseContext *pc, const uint8_t *buf, int buf_size, AVCodecParserContext *s);
|
int ff_mpeg1_find_frame_end(ParseContext *pc, const uint8_t *buf, int buf_size, AVCodecParserContext *s);
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
#include "mpeg_er.h"
|
#include "mpeg_er.h"
|
||||||
#include "mpeg12.h"
|
#include "mpeg12.h"
|
||||||
#include "mpeg12data.h"
|
#include "mpeg12data.h"
|
||||||
|
#include "mpeg12dec.h"
|
||||||
#include "mpegutils.h"
|
#include "mpegutils.h"
|
||||||
#include "mpegvideo.h"
|
#include "mpegvideo.h"
|
||||||
#include "mpegvideodata.h"
|
#include "mpegvideodata.h"
|
||||||
|
60
libavcodec/mpeg12dec.h
Normal file
60
libavcodec/mpeg12dec.h
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* MPEG-1/2 decoder header
|
||||||
|
* Copyright (c) 2007 Aurelien Jacobs <aurel@gnuage.org>
|
||||||
|
*
|
||||||
|
* 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_MPEG12DEC_H
|
||||||
|
#define AVCODEC_MPEG12DEC_H
|
||||||
|
|
||||||
|
#include "get_bits.h"
|
||||||
|
#include "mpeg12vlc.h"
|
||||||
|
#include "rl.h"
|
||||||
|
|
||||||
|
#define INIT_2D_VLC_RL(rl, static_size, flags)\
|
||||||
|
{\
|
||||||
|
static RL_VLC_ELEM rl_vlc_table[static_size];\
|
||||||
|
rl.rl_vlc[0] = rl_vlc_table;\
|
||||||
|
ff_init_2d_vlc_rl(&rl, static_size, flags);\
|
||||||
|
}
|
||||||
|
|
||||||
|
void ff_init_2d_vlc_rl(RLTable *rl, unsigned static_size, int flags);
|
||||||
|
|
||||||
|
static inline int decode_dc(GetBitContext *gb, int component)
|
||||||
|
{
|
||||||
|
int code, diff;
|
||||||
|
|
||||||
|
if (component == 0) {
|
||||||
|
code = get_vlc2(gb, ff_dc_lum_vlc.table, DC_VLC_BITS, 2);
|
||||||
|
} else {
|
||||||
|
code = get_vlc2(gb, ff_dc_chroma_vlc.table, DC_VLC_BITS, 2);
|
||||||
|
}
|
||||||
|
if (code == 0) {
|
||||||
|
diff = 0;
|
||||||
|
} else {
|
||||||
|
diff = get_xbits(gb, code);
|
||||||
|
}
|
||||||
|
return diff;
|
||||||
|
}
|
||||||
|
|
||||||
|
int ff_mpeg1_decode_block_intra(GetBitContext *gb,
|
||||||
|
const uint16_t *quant_matrix,
|
||||||
|
const uint8_t *scantable, int last_dc[3],
|
||||||
|
int16_t *block, int index, int qscale);
|
||||||
|
|
||||||
|
#endif /* AVCODEC_MPEG12DEC_H */
|
@ -31,11 +31,13 @@
|
|||||||
#include "libavutil/mem_internal.h"
|
#include "libavutil/mem_internal.h"
|
||||||
|
|
||||||
#include "avcodec.h"
|
#include "avcodec.h"
|
||||||
|
#include "blockdsp.h"
|
||||||
#include "get_bits.h"
|
#include "get_bits.h"
|
||||||
|
#include "idctdsp.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
#include "libavutil/thread.h"
|
#include "libavutil/thread.h"
|
||||||
#include "mathops.h"
|
#include "mathops.h"
|
||||||
#include "mpeg12.h"
|
#include "mpeg12dec.h"
|
||||||
#include "mpeg12data.h"
|
#include "mpeg12data.h"
|
||||||
#include "mpeg12vlc.h"
|
#include "mpeg12vlc.h"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user