xref: /third_party/ffmpeg/libavcodec/alacdsp.c (revision cabdff1a)
1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * ALAC (Apple Lossless Audio Codec) decoder
3cabdff1aSopenharmony_ci * Copyright (c) 2005 David Hammerton
4cabdff1aSopenharmony_ci *
5cabdff1aSopenharmony_ci * This file is part of FFmpeg.
6cabdff1aSopenharmony_ci *
7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
11cabdff1aSopenharmony_ci *
12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15cabdff1aSopenharmony_ci * Lesser General Public License for more details.
16cabdff1aSopenharmony_ci *
17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20cabdff1aSopenharmony_ci */
21cabdff1aSopenharmony_ci
22cabdff1aSopenharmony_ci#include "libavutil/attributes.h"
23cabdff1aSopenharmony_ci#include "alacdsp.h"
24cabdff1aSopenharmony_ci#include "config.h"
25cabdff1aSopenharmony_ci
26cabdff1aSopenharmony_cistatic void decorrelate_stereo(int32_t *buffer[2], int nb_samples,
27cabdff1aSopenharmony_ci                               int decorr_shift, int decorr_left_weight)
28cabdff1aSopenharmony_ci{
29cabdff1aSopenharmony_ci    int i;
30cabdff1aSopenharmony_ci
31cabdff1aSopenharmony_ci    for (i = 0; i < nb_samples; i++) {
32cabdff1aSopenharmony_ci        uint32_t a, b;
33cabdff1aSopenharmony_ci
34cabdff1aSopenharmony_ci        a = buffer[0][i];
35cabdff1aSopenharmony_ci        b = buffer[1][i];
36cabdff1aSopenharmony_ci
37cabdff1aSopenharmony_ci        a -= (int)(b * decorr_left_weight) >> decorr_shift;
38cabdff1aSopenharmony_ci        b += a;
39cabdff1aSopenharmony_ci
40cabdff1aSopenharmony_ci        buffer[0][i] = b;
41cabdff1aSopenharmony_ci        buffer[1][i] = a;
42cabdff1aSopenharmony_ci    }
43cabdff1aSopenharmony_ci}
44cabdff1aSopenharmony_ci
45cabdff1aSopenharmony_cistatic void append_extra_bits(int32_t *buffer[2], int32_t *extra_bits_buffer[2],
46cabdff1aSopenharmony_ci                              int extra_bits, int channels, int nb_samples)
47cabdff1aSopenharmony_ci{
48cabdff1aSopenharmony_ci    int i, ch;
49cabdff1aSopenharmony_ci
50cabdff1aSopenharmony_ci    for (ch = 0; ch < channels; ch++)
51cabdff1aSopenharmony_ci        for (i = 0; i < nb_samples; i++)
52cabdff1aSopenharmony_ci            buffer[ch][i] = ((unsigned)buffer[ch][i] << extra_bits) | extra_bits_buffer[ch][i];
53cabdff1aSopenharmony_ci}
54cabdff1aSopenharmony_ci
55cabdff1aSopenharmony_ciav_cold void ff_alacdsp_init(ALACDSPContext *c)
56cabdff1aSopenharmony_ci{
57cabdff1aSopenharmony_ci    c->decorrelate_stereo   = decorrelate_stereo;
58cabdff1aSopenharmony_ci    c->append_extra_bits[0] =
59cabdff1aSopenharmony_ci    c->append_extra_bits[1] = append_extra_bits;
60cabdff1aSopenharmony_ci
61cabdff1aSopenharmony_ci#if ARCH_X86
62cabdff1aSopenharmony_ci    ff_alacdsp_init_x86(c);
63cabdff1aSopenharmony_ci#endif
64cabdff1aSopenharmony_ci}
65