FFmpeg
libavcodec
amr.h
Go to the documentation of this file.
1
/*
2
* Shared functions between AMR codecs
3
*
4
* Copyright (c) 2010 Marcelo Galvao Povoa
5
*
6
* This file is part of FFmpeg.
7
*
8
* FFmpeg is free software; you can redistribute it and/or
9
* modify it under the terms of the GNU Lesser General Public
10
* License as published by the Free Software Foundation; either
11
* version 2.1 of the License, or (at your option) any later version.
12
*
13
* FFmpeg is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
* Lesser General Public License for more details.
17
*
18
* You should have received a copy of the GNU Lesser General Public
19
* License along with FFmpeg; if not, write to the Free Software
20
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21
*/
22
23
#ifndef AVCODEC_AMR_H
24
#define AVCODEC_AMR_H
25
26
#include <string.h>
27
28
#include "
avcodec.h
"
29
30
#ifdef AMR_USE_16BIT_TABLES
31
typedef
uint16_t
R_TABLE_TYPE
;
32
#else
33
typedef
uint8_t
R_TABLE_TYPE
;
34
#endif
35
36
/**
37
* Fill the frame structure variables from bitstream by parsing the
38
* given reordering table that uses the following format:
39
*
40
* Each field (16 bits) in the AMR Frame is stored as:
41
* - one byte for the number of bits in the field
42
* - one byte for the field index
43
* - then, one byte for each bit of the field (from most-significant to least)
44
* of the position of that bit in the AMR frame.
45
*
46
* @param out pointer to the frame struct
47
* @param size the size in bytes of the frame struct
48
* @param data input bitstream after the frame header
49
* @param ord_table the reordering table as above
50
*/
51
static
inline
void
ff_amr_bit_reorder
(uint16_t *
out
,
int
size
,
52
const
uint8_t *
data
,
53
const
R_TABLE_TYPE
*ord_table)
54
{
55
int
field_size;
56
57
memset(
out
, 0,
size
);
58
while
((field_size = *ord_table++)) {
59
int
field
= 0;
60
int
field_offset = *ord_table++;
61
while
(field_size--) {
62
int
bit
= *ord_table++;
63
field
<<= 1;
64
field
|=
data
[
bit
>> 3] >> (
bit
& 7) & 1;
65
}
66
out
[field_offset >> 1] =
field
;
67
}
68
}
69
70
#endif
/* AVCODEC_AMR_H */
out
FILE * out
Definition:
movenc.c:54
data
const char data[16]
Definition:
mxf.c:146
bit
#define bit(string, value)
Definition:
cbs_mpeg2.c:58
R_TABLE_TYPE
uint8_t R_TABLE_TYPE
Definition:
amr.h:33
field
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this field
Definition:
writing_filters.txt:78
size
int size
Definition:
twinvq_data.h:10344
avcodec.h
ff_amr_bit_reorder
static void ff_amr_bit_reorder(uint16_t *out, int size, const uint8_t *data, const R_TABLE_TYPE *ord_table)
Fill the frame structure variables from bitstream by parsing the given reordering table that uses the...
Definition:
amr.h:51
Generated on Tue Feb 28 2023 21:33:07 for FFmpeg by
1.8.17