1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Monkey's Audio lossless audio decoder 3cabdff1aSopenharmony_ci * Copyright (c) 2007 Benjamin Zores <ben@geexbox.org> 4cabdff1aSopenharmony_ci * based upon libdemac from Dave Chapman. 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * This file is part of FFmpeg. 7cabdff1aSopenharmony_ci * 8cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 9cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 10cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 11cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 12cabdff1aSopenharmony_ci * 13cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 14cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 15cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16cabdff1aSopenharmony_ci * Lesser General Public License for more details. 17cabdff1aSopenharmony_ci * 18cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 19cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 20cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21cabdff1aSopenharmony_ci */ 22cabdff1aSopenharmony_ci 23cabdff1aSopenharmony_ci#include "config.h" 24cabdff1aSopenharmony_ci#include "libavutil/attributes.h" 25cabdff1aSopenharmony_ci#include "lossless_audiodsp.h" 26cabdff1aSopenharmony_ci 27cabdff1aSopenharmony_cistatic int32_t scalarproduct_and_madd_int16_c(int16_t *v1, const int16_t *v2, 28cabdff1aSopenharmony_ci const int16_t *v3, 29cabdff1aSopenharmony_ci int order, int mul) 30cabdff1aSopenharmony_ci{ 31cabdff1aSopenharmony_ci unsigned res = 0; 32cabdff1aSopenharmony_ci 33cabdff1aSopenharmony_ci do { 34cabdff1aSopenharmony_ci res += *v1 * *v2++; 35cabdff1aSopenharmony_ci *v1++ += mul * *v3++; 36cabdff1aSopenharmony_ci res += *v1 * *v2++; 37cabdff1aSopenharmony_ci *v1++ += mul * *v3++; 38cabdff1aSopenharmony_ci } while (order-=2); 39cabdff1aSopenharmony_ci return res; 40cabdff1aSopenharmony_ci} 41cabdff1aSopenharmony_ci 42cabdff1aSopenharmony_cistatic int32_t scalarproduct_and_madd_int32_c(int16_t *v1, const int32_t *v2, 43cabdff1aSopenharmony_ci const int16_t *v3, 44cabdff1aSopenharmony_ci int order, int mul) 45cabdff1aSopenharmony_ci{ 46cabdff1aSopenharmony_ci int res = 0; 47cabdff1aSopenharmony_ci 48cabdff1aSopenharmony_ci do { 49cabdff1aSopenharmony_ci res += *v1 * (uint32_t)*v2++; 50cabdff1aSopenharmony_ci *v1++ += mul * *v3++; 51cabdff1aSopenharmony_ci res += *v1 * (uint32_t)*v2++; 52cabdff1aSopenharmony_ci *v1++ += mul * *v3++; 53cabdff1aSopenharmony_ci } while (order-=2); 54cabdff1aSopenharmony_ci return res; 55cabdff1aSopenharmony_ci} 56cabdff1aSopenharmony_ci 57cabdff1aSopenharmony_ciav_cold void ff_llauddsp_init(LLAudDSPContext *c) 58cabdff1aSopenharmony_ci{ 59cabdff1aSopenharmony_ci c->scalarproduct_and_madd_int16 = scalarproduct_and_madd_int16_c; 60cabdff1aSopenharmony_ci c->scalarproduct_and_madd_int32 = scalarproduct_and_madd_int32_c; 61cabdff1aSopenharmony_ci 62cabdff1aSopenharmony_ci#if ARCH_ARM 63cabdff1aSopenharmony_ci ff_llauddsp_init_arm(c); 64cabdff1aSopenharmony_ci#elif ARCH_PPC 65cabdff1aSopenharmony_ci ff_llauddsp_init_ppc(c); 66cabdff1aSopenharmony_ci#elif ARCH_X86 67cabdff1aSopenharmony_ci ff_llauddsp_init_x86(c); 68cabdff1aSopenharmony_ci#endif 69cabdff1aSopenharmony_ci} 70