summaryrefslogtreecommitdiffstats
path: root/libMpegTPDec/src/tpdec_adts.h
blob: 13c66a41ab9b29cb42f8ad378c70e9c04478f039 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
/*****************************  MPEG-4 AAC Decoder  **************************

                        (C) Copyright Fraunhofer IIS (2004)
                               All Rights Reserved

    Please be advised that this software and/or program delivery is
    Confidential Information of Fraunhofer and subject to and covered by the

    Fraunhofer IIS Software Evaluation Agreement
    between Google Inc. and  Fraunhofer
    effective and in full force since March 1, 2012.

    You may use this software and/or program only under the terms and
    conditions described in the above mentioned Fraunhofer IIS Software
    Evaluation Agreement. Any other and/or further use requires a separate agreement.


   $Id$
   Author(s):   Josef Hoepfl
   Description: ADTS interface

   This software and/or program is protected by copyright law and international
   treaties. Any reproduction or distribution of this software and/or program,
   or any portion of it, may result in severe civil and criminal penalties, and
   will be prosecuted to the maximum extent possible under law.

******************************************************************************/

#ifndef TPDEC_ADTS_H
#define TPDEC_ADTS_H

#include "tpdec_lib.h"


#define ADTS_SYNCWORD               ( 0xfff )
#define ADTS_SYNCLENGTH             ( 12 )     /* in bits */
#define ADTS_HEADERLENGTH           ( 56 )     /* minimum header size in bits */
#define ADTS_FIXED_HEADERLENGTH     ( 28 )     /* in bits */
#define ADTS_VARIABLE_HEADERLENGTH  ( ADTS_HEADERLENGTH - ADTS_FIXED_HEADERLENGTH )

#ifdef CHECK_TWO_SYNCS
 #define ADTS_MIN_TP_BUF_SIZE       ( 8191 + 2 )
#else
 #define ADTS_MIN_TP_BUF_SIZE       ( 8191 )
#endif

#include "FDK_crc.h"

typedef struct {
  /* ADTS header fields */
  UCHAR mpeg_id;
  UCHAR layer;
  UCHAR protection_absent;
  UCHAR profile;
  UCHAR sample_freq_index;
  UCHAR private_bit;
  UCHAR channel_config;
  UCHAR original;
  UCHAR home;
  UCHAR copyright_id;
  UCHAR copyright_start;
  USHORT frame_length;
  USHORT adts_fullness;
  UCHAR num_raw_blocks;
  UCHAR num_pce_bits;
} STRUCT_ADTS_BS;

struct STRUCT_ADTS {

  STRUCT_ADTS_BS bs;

  UCHAR decoderCanDoMpeg4;
  UCHAR BufferFullnesStartFlag;

  FDK_CRCINFO crcInfo;             /* CRC state info */
  USHORT      crcReadValue;        /* CRC value read from bitstream data */
  USHORT      rawDataBlockDist[4]; /* distance between each raw data block. Not the same as found in the bitstream */
} ;

typedef struct STRUCT_ADTS *HANDLE_ADTS;

/*!
  \brief Initialize ADTS CRC

  The function initialzes the crc buffer and the crc lookup table.

  \return  none
*/
void adtsRead_CrcInit( HANDLE_ADTS pAdts );

/**
 * \brief Starts CRC region with a maximum number of bits
 *        If mBits is positive zero padding will be used for CRC calculation, if there
 *        are less than mBits bits available.
 *        If mBits is negative no zero padding is done.
 *        If mBits is zero the memory for the buffer is allocated dynamically, the
 *        number of bits is not limited.
 *
 * \param pAdts ADTS data handle
 * \param hBs bitstream handle, on which the CRC region referes to
 * \param mBits max number of bits in crc region to be considered
 *
 * \return  ID for the created region, -1 in case of an error
 */
int adtsRead_CrcStartReg(
        HANDLE_ADTS pAdts,
        HANDLE_FDK_BITSTREAM hBs,
        int mBits
        );

/**
 * \brief Ends CRC region identified by reg
 *
 * \param pAdts ADTS data handle
 * \param hBs bitstream handle, on which the CRC region referes to
 * \param reg CRC regions ID returned by adtsRead_CrcStartReg()
 *
 * \return  none
 */
void adtsRead_CrcEndReg(
        HANDLE_ADTS pAdts,
        HANDLE_FDK_BITSTREAM hBs,
        int reg
        );

/**
 * \brief Check CRC
 *
 * Checks if the currently calculated CRC matches the CRC field read from the bitstream
 * Deletes all CRC regions.
 *
 * \param pAdts ADTS data handle
 *
 * \return Returns 0 if they are identical otherwise 1
 */
TRANSPORTDEC_ERROR adtsRead_CrcCheck( HANDLE_ADTS pAdts );


/**
 * \brief Check if we have a valid ADTS frame at the current bitbuffer position
 *
 * This function assumes enough bits in buffer for the current frame.
 * It reads out the header bits to prepare the bitbuffer for the decode loop.
 * In case the header bits show an invalid bitstream/frame, the whole frame is skipped.
 *
 * \param pAdts ADTS data handle which is filled with parsed ADTS header data
 * \param bs handle of bitstream from whom the ADTS header is read
 *
 * \return  error status
 */
TRANSPORTDEC_ERROR adtsRead_DecodeHeader(
        HANDLE_ADTS           pAdts,
        CSAudioSpecificConfig *pAsc,
        HANDLE_FDK_BITSTREAM  bs,
        const INT             ignoreBufferFullness
        );

/**
 * \brief Get the raw data block length of the given block number.
 *
 * \param pAdts ADTS data handle
 * \param blockNum current raw data block index
 * \param pLength pointer to an INT where the length of the given raw data block is stored into
 *                the returned value might be -1, in which case the raw data block length is unknown.
 *
 * \return  error status
 */
int adtsRead_GetRawDataBlockLength(
        HANDLE_ADTS pAdts,
        INT         blockNum
        );


#endif /* TPDEC_ADTS_H */