summaryrefslogtreecommitdiffstats
path: root/lib/rbcodec/codecs/libatrac/atrac3.h
blob: e73d8f2045965dbde4c1a0b0d64e4dbec2507499 (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
/***************************************************************************
 *             __________               __   ___.
 *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 *                     \/            \/     \/    \/            \/
 * $Id$
 *
 * Copyright (C) 2009 Mohamed Tarek
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 * KIND, either express or implied.
 *
 ****************************************************************************/

#include "ffmpeg_get_bits.h"
#include "../librm/rm.h"
#include "codeclib.h"

#if (CONFIG_CPU == PP5022) || (CONFIG_CPU == PP5024) || \
    (CONFIG_CPU == MCF5250) || defined(CPU_S5L87XX)
/* PP5022/24, MCF5250 and S5L87xx have larger IRAM */
#define IBSS_ATTR_LARGE_IRAM    IBSS_ATTR
#define ICODE_ATTR_LARGE_IRAM   ICODE_ATTR
#define ICONST_ATTR_LARGE_IRAM  ICONST_ATTR
#else
/* other CPUs IRAM is not large enough */
#define IBSS_ATTR_LARGE_IRAM
#define ICODE_ATTR_LARGE_IRAM
#define ICONST_ATTR_LARGE_IRAM
#endif

/* These structures are needed to store the parsed gain control data. */
typedef struct {
    int   num_gain_data;
    int   levcode[8];
    int   loccode[8];
} gain_info;

typedef struct {
    gain_info   gBlock[4];
} gain_block;

typedef struct {
    int     pos;
    int     numCoefs;
    int32_t coef[8];
} tonal_component;

typedef struct {
    int               bandsCoded;
    int               numComponents;
    tonal_component   components[64];
    int32_t           *prevFrame;
    int               gcBlkSwitch;
    gain_block        gainBlock[2];

    int32_t           *spectrum;
    int32_t           *IMDCT_buf;

    int32_t           delayBuf1[46] MEM_ALIGN_ATTR; ///<qmf delay buffers
    int32_t           delayBuf2[46] MEM_ALIGN_ATTR;
    int32_t           delayBuf3[46] MEM_ALIGN_ATTR;
} channel_unit;

typedef struct {
    int32_t             outSamples[2048] MEM_ALIGN_ATTR;
    GetBitContext       gb;
    //@{
    /** stream data */
    int                 channels;
    int                 codingMode;
    int                 bit_rate;
    int                 sample_rate;
    int                 samples_per_channel;
    int                 samples_per_frame;

    int                 bits_per_frame;
    int                 bytes_per_frame;
    int                 pBs;
    channel_unit*       pUnits;
    //@}
    //@{
    /** joint-stereo related variables */
    int                 matrix_coeff_index_prev[4];
    int                 matrix_coeff_index_now[4];
    int                 matrix_coeff_index_next[4];
    int                 weighting_delay[6];
    //@}
    //@{
    /** data buffers */    
    uint8_t             decoded_bytes_buffer[1024] MEM_ALIGN_ATTR;
    int32_t             tempBuf[1070]              MEM_ALIGN_ATTR;
    //@}
    //@{
    /** extradata */
    int                 atrac3version;
    int                 delay;
    int                 scrambled_stream;
    int                 frame_factor;
    //@}
} ATRAC3Context;

int atrac3_decode_init(ATRAC3Context *q, struct mp3entry *id3, uint16_t channels, uint32_t extradata_size);

int atrac3_decode_frame(unsigned long block_align, ATRAC3Context *q,
                        int *data_size, const uint8_t *buf, int buf_size);