diff options
author | Sean Bartell <wingedtachikoma@gmail.com> | 2011-06-25 21:32:25 -0400 |
---|---|---|
committer | Nils Wallménius <nils@rockbox.org> | 2012-04-25 22:13:20 +0200 |
commit | f40bfc9267b13b54e6379dfe7539447662879d24 (patch) | |
tree | 9b20069d5e62809ff434061ad730096836f916f2 /lib/rbcodec/codecs/libfaad/ms.c | |
parent | a0009907de7a0107d49040d8a180f140e2eff299 (diff) | |
download | rockbox-f40bfc9267b13b54e6379dfe7539447662879d24.tar.gz rockbox-f40bfc9267b13b54e6379dfe7539447662879d24.zip |
Add codecs to librbcodec.
Change-Id: Id7f4717d51ed02d67cb9f9cb3c0ada4a81843f97
Reviewed-on: http://gerrit.rockbox.org/137
Reviewed-by: Nils Wallménius <nils@rockbox.org>
Tested-by: Nils Wallménius <nils@rockbox.org>
Diffstat (limited to 'lib/rbcodec/codecs/libfaad/ms.c')
-rw-r--r-- | lib/rbcodec/codecs/libfaad/ms.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/lib/rbcodec/codecs/libfaad/ms.c b/lib/rbcodec/codecs/libfaad/ms.c new file mode 100644 index 0000000000..b42e95a408 --- /dev/null +++ b/lib/rbcodec/codecs/libfaad/ms.c | |||
@@ -0,0 +1,73 @@ | |||
1 | /* | ||
2 | ** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding | ||
3 | ** Copyright (C) 2003-2004 M. Bakker, Ahead Software AG, http://www.nero.com | ||
4 | ** | ||
5 | ** This program is free software; you can redistribute it and/or modify | ||
6 | ** it under the terms of the GNU General Public License as published by | ||
7 | ** the Free Software Foundation; either version 2 of the License, or | ||
8 | ** (at your option) any later version. | ||
9 | ** | ||
10 | ** This program is distributed in the hope that it will be useful, | ||
11 | ** but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | ** GNU General Public License for more details. | ||
14 | ** | ||
15 | ** You should have received a copy of the GNU General Public License | ||
16 | ** along with this program; if not, write to the Free Software | ||
17 | ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
18 | ** | ||
19 | ** Any non-GPL usage of this software or parts of this software is strictly | ||
20 | ** forbidden. | ||
21 | ** | ||
22 | ** Commercial non-GPL licensing of this software is possible. | ||
23 | ** For more info contact Ahead Software through Mpeg4AAClicense@nero.com. | ||
24 | ** | ||
25 | ** $Id$ | ||
26 | **/ | ||
27 | |||
28 | #include "common.h" | ||
29 | #include "structs.h" | ||
30 | |||
31 | #include "syntax.h" | ||
32 | #include "ms.h" | ||
33 | #include "is.h" | ||
34 | #include "pns.h" | ||
35 | |||
36 | void ms_decode(ic_stream *ics, ic_stream *icsr, real_t *l_spec, real_t *r_spec, | ||
37 | uint16_t frame_len) | ||
38 | { | ||
39 | uint8_t g, b, sfb; | ||
40 | uint8_t group = 0; | ||
41 | uint16_t nshort = frame_len/8; | ||
42 | |||
43 | uint16_t i, k; | ||
44 | |||
45 | if (ics->ms_mask_present >= 1) | ||
46 | { | ||
47 | for (g = 0; g < ics->num_window_groups; g++) | ||
48 | { | ||
49 | for (b = 0; b < ics->window_group_length[g]; b++) | ||
50 | { | ||
51 | for (sfb = 0; sfb < ics->max_sfb; sfb++) | ||
52 | { | ||
53 | /* If intensity stereo coding or noise substitution is on | ||
54 | for a particular scalefactor band, no M/S stereo decoding | ||
55 | is carried out. | ||
56 | */ | ||
57 | if ((ics->ms_used[g][sfb] || ics->ms_mask_present == 2) && | ||
58 | !is_intensity(icsr, g, sfb) && !is_noise(ics, g, sfb)) | ||
59 | { | ||
60 | k = (group*nshort) + ics->swb_offset[sfb]; | ||
61 | for (i = ics->swb_offset[sfb]; i < ics->swb_offset[sfb+1]; i++, k++) | ||
62 | { | ||
63 | /* L' = L+R, R' = L-R */ | ||
64 | l_spec[k] = l_spec[k] + r_spec[k]; | ||
65 | r_spec[k] = l_spec[k] - (r_spec[k]<<1); | ||
66 | } | ||
67 | } | ||
68 | } | ||
69 | group++; | ||
70 | } | ||
71 | } | ||
72 | } | ||
73 | } | ||