mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-26 19:01:44 +02:00
avcodec/mpeg4audio: Move ff_copy_pce_data() to a header of its own
It is only used by three of the thirty files that (potentially indirectly) include mpeg4audio.h. Twenty of these files won't have a put_bits.h inclusion any more after this patch. Reviewed-by: Michael Niedermayer <michael@niedermayer.cc> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
parent
5c94b6694a
commit
7eed125dbb
@ -26,6 +26,7 @@
|
|||||||
#include "put_bits.h"
|
#include "put_bits.h"
|
||||||
#include "get_bits.h"
|
#include "get_bits.h"
|
||||||
#include "mpeg4audio.h"
|
#include "mpeg4audio.h"
|
||||||
|
#include "mpeg4audio_copy_pce.h"
|
||||||
|
|
||||||
typedef struct AACBSFContext {
|
typedef struct AACBSFContext {
|
||||||
int first_frame_done;
|
int first_frame_done;
|
||||||
|
@ -21,7 +21,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "get_bits.h"
|
#include "get_bits.h"
|
||||||
#include "put_bits.h"
|
|
||||||
#include "mpeg4audio.h"
|
#include "mpeg4audio.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -24,10 +24,7 @@
|
|||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#include "libavutil/attributes.h"
|
|
||||||
|
|
||||||
#include "get_bits.h"
|
#include "get_bits.h"
|
||||||
#include "put_bits.h"
|
|
||||||
|
|
||||||
typedef struct MPEG4AudioConfig {
|
typedef struct MPEG4AudioConfig {
|
||||||
int object_type;
|
int object_type;
|
||||||
@ -120,44 +117,4 @@ enum AudioObjectType {
|
|||||||
#define MAX_PCE_SIZE 320 ///<Maximum size of a PCE including the 3-bit ID_PCE
|
#define MAX_PCE_SIZE 320 ///<Maximum size of a PCE including the 3-bit ID_PCE
|
||||||
///<marker and the comment
|
///<marker and the comment
|
||||||
|
|
||||||
static av_always_inline unsigned int ff_pce_copy_bits(PutBitContext *pb,
|
|
||||||
GetBitContext *gb,
|
|
||||||
int bits)
|
|
||||||
{
|
|
||||||
unsigned int el = get_bits(gb, bits);
|
|
||||||
put_bits(pb, bits, el);
|
|
||||||
return el;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int ff_copy_pce_data(PutBitContext *pb, GetBitContext *gb)
|
|
||||||
{
|
|
||||||
int five_bit_ch, four_bit_ch, comment_size, bits;
|
|
||||||
int offset = put_bits_count(pb);
|
|
||||||
|
|
||||||
ff_pce_copy_bits(pb, gb, 10); // Tag, Object Type, Frequency
|
|
||||||
five_bit_ch = ff_pce_copy_bits(pb, gb, 4); // Front
|
|
||||||
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Side
|
|
||||||
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Back
|
|
||||||
four_bit_ch = ff_pce_copy_bits(pb, gb, 2); // LFE
|
|
||||||
four_bit_ch += ff_pce_copy_bits(pb, gb, 3); // Data
|
|
||||||
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Coupling
|
|
||||||
if (ff_pce_copy_bits(pb, gb, 1)) // Mono Mixdown
|
|
||||||
ff_pce_copy_bits(pb, gb, 4);
|
|
||||||
if (ff_pce_copy_bits(pb, gb, 1)) // Stereo Mixdown
|
|
||||||
ff_pce_copy_bits(pb, gb, 4);
|
|
||||||
if (ff_pce_copy_bits(pb, gb, 1)) // Matrix Mixdown
|
|
||||||
ff_pce_copy_bits(pb, gb, 3);
|
|
||||||
for (bits = five_bit_ch*5+four_bit_ch*4; bits > 16; bits -= 16)
|
|
||||||
ff_pce_copy_bits(pb, gb, 16);
|
|
||||||
if (bits)
|
|
||||||
ff_pce_copy_bits(pb, gb, bits);
|
|
||||||
align_put_bits(pb);
|
|
||||||
align_get_bits(gb);
|
|
||||||
comment_size = ff_pce_copy_bits(pb, gb, 8);
|
|
||||||
for (; comment_size > 0; comment_size--)
|
|
||||||
ff_pce_copy_bits(pb, gb, 8);
|
|
||||||
|
|
||||||
return put_bits_count(pb) - offset;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* AVCODEC_MPEG4AUDIO_H */
|
#endif /* AVCODEC_MPEG4AUDIO_H */
|
||||||
|
69
libavcodec/mpeg4audio_copy_pce.h
Normal file
69
libavcodec/mpeg4audio_copy_pce.h
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/*
|
||||||
|
* MPEG-4 Audio PCE copying function
|
||||||
|
*
|
||||||
|
* 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_MPEG4AUDIO_COPY_PCE_H
|
||||||
|
#define AVCODEC_MPEG4AUDIO_COPY_PCE_H
|
||||||
|
|
||||||
|
#include "libavutil/attributes.h"
|
||||||
|
|
||||||
|
#include "get_bits.h"
|
||||||
|
#include "put_bits.h"
|
||||||
|
|
||||||
|
static av_always_inline unsigned int ff_pce_copy_bits(PutBitContext *pb,
|
||||||
|
GetBitContext *gb,
|
||||||
|
int bits)
|
||||||
|
{
|
||||||
|
unsigned int el = get_bits(gb, bits);
|
||||||
|
put_bits(pb, bits, el);
|
||||||
|
return el;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int ff_copy_pce_data(PutBitContext *pb, GetBitContext *gb)
|
||||||
|
{
|
||||||
|
int five_bit_ch, four_bit_ch, comment_size, bits;
|
||||||
|
int offset = put_bits_count(pb);
|
||||||
|
|
||||||
|
ff_pce_copy_bits(pb, gb, 10); // Tag, Object Type, Frequency
|
||||||
|
five_bit_ch = ff_pce_copy_bits(pb, gb, 4); // Front
|
||||||
|
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Side
|
||||||
|
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Back
|
||||||
|
four_bit_ch = ff_pce_copy_bits(pb, gb, 2); // LFE
|
||||||
|
four_bit_ch += ff_pce_copy_bits(pb, gb, 3); // Data
|
||||||
|
five_bit_ch += ff_pce_copy_bits(pb, gb, 4); // Coupling
|
||||||
|
if (ff_pce_copy_bits(pb, gb, 1)) // Mono Mixdown
|
||||||
|
ff_pce_copy_bits(pb, gb, 4);
|
||||||
|
if (ff_pce_copy_bits(pb, gb, 1)) // Stereo Mixdown
|
||||||
|
ff_pce_copy_bits(pb, gb, 4);
|
||||||
|
if (ff_pce_copy_bits(pb, gb, 1)) // Matrix Mixdown
|
||||||
|
ff_pce_copy_bits(pb, gb, 3);
|
||||||
|
for (bits = five_bit_ch*5+four_bit_ch*4; bits > 16; bits -= 16)
|
||||||
|
ff_pce_copy_bits(pb, gb, 16);
|
||||||
|
if (bits)
|
||||||
|
ff_pce_copy_bits(pb, gb, bits);
|
||||||
|
align_put_bits(pb);
|
||||||
|
align_get_bits(gb);
|
||||||
|
comment_size = ff_pce_copy_bits(pb, gb, 8);
|
||||||
|
for (; comment_size > 0; comment_size--)
|
||||||
|
ff_pce_copy_bits(pb, gb, 8);
|
||||||
|
|
||||||
|
return put_bits_count(pb) - offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* AVCODEC_MPEG4AUDIO_COPY_PCE_H */
|
@ -26,6 +26,7 @@
|
|||||||
#include "libavcodec/codec_par.h"
|
#include "libavcodec/codec_par.h"
|
||||||
#include "libavcodec/packet.h"
|
#include "libavcodec/packet.h"
|
||||||
#include "libavcodec/mpeg4audio.h"
|
#include "libavcodec/mpeg4audio.h"
|
||||||
|
#include "libavcodec/mpeg4audio_copy_pce.h"
|
||||||
#include "libavutil/opt.h"
|
#include "libavutil/opt.h"
|
||||||
#include "avformat.h"
|
#include "avformat.h"
|
||||||
#include "apetag.h"
|
#include "apetag.h"
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include "libavcodec/codec_par.h"
|
#include "libavcodec/codec_par.h"
|
||||||
#include "libavcodec/packet.h"
|
#include "libavcodec/packet.h"
|
||||||
#include "libavcodec/mpeg4audio.h"
|
#include "libavcodec/mpeg4audio.h"
|
||||||
|
#include "libavcodec/mpeg4audio_copy_pce.h"
|
||||||
#include "libavutil/opt.h"
|
#include "libavutil/opt.h"
|
||||||
#include "avformat.h"
|
#include "avformat.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user