annotate src/opus-1.3/silk/x86/SigProc_FIX_sse.h @ 169:223a55898ab9 tip default

Add null config files
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 02 Mar 2020 14:03:47 +0000
parents 4664ac0c1032
children
rev   line source
cannam@154 1 /* Copyright (c) 2014, Cisco Systems, INC
cannam@154 2 Written by XiangMingZhu WeiZhou MinPeng YanWang
cannam@154 3
cannam@154 4 Redistribution and use in source and binary forms, with or without
cannam@154 5 modification, are permitted provided that the following conditions
cannam@154 6 are met:
cannam@154 7
cannam@154 8 - Redistributions of source code must retain the above copyright
cannam@154 9 notice, this list of conditions and the following disclaimer.
cannam@154 10
cannam@154 11 - Redistributions in binary form must reproduce the above copyright
cannam@154 12 notice, this list of conditions and the following disclaimer in the
cannam@154 13 documentation and/or other materials provided with the distribution.
cannam@154 14
cannam@154 15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
cannam@154 16 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
cannam@154 17 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
cannam@154 18 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
cannam@154 19 OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
cannam@154 20 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
cannam@154 21 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
cannam@154 22 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
cannam@154 23 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
cannam@154 24 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
cannam@154 25 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
cannam@154 26 */
cannam@154 27
cannam@154 28 #ifndef SIGPROC_FIX_SSE_H
cannam@154 29 #define SIGPROC_FIX_SSE_H
cannam@154 30
cannam@154 31 #ifdef HAVE_CONFIG_H
cannam@154 32 #include "config.h"
cannam@154 33 #endif
cannam@154 34
cannam@154 35 #if defined(OPUS_X86_MAY_HAVE_SSE4_1)
cannam@154 36 void silk_burg_modified_sse4_1(
cannam@154 37 opus_int32 *res_nrg, /* O Residual energy */
cannam@154 38 opus_int *res_nrg_Q, /* O Residual energy Q value */
cannam@154 39 opus_int32 A_Q16[], /* O Prediction coefficients (length order) */
cannam@154 40 const opus_int16 x[], /* I Input signal, length: nb_subfr * ( D + subfr_length ) */
cannam@154 41 const opus_int32 minInvGain_Q30, /* I Inverse of max prediction gain */
cannam@154 42 const opus_int subfr_length, /* I Input signal subframe length (incl. D preceding samples) */
cannam@154 43 const opus_int nb_subfr, /* I Number of subframes stacked in x */
cannam@154 44 const opus_int D, /* I Order */
cannam@154 45 int arch /* I Run-time architecture */
cannam@154 46 );
cannam@154 47
cannam@154 48 #if defined(OPUS_X86_PRESUME_SSE4_1)
cannam@154 49 #define silk_burg_modified(res_nrg, res_nrg_Q, A_Q16, x, minInvGain_Q30, subfr_length, nb_subfr, D, arch) \
cannam@154 50 ((void)(arch), silk_burg_modified_sse4_1(res_nrg, res_nrg_Q, A_Q16, x, minInvGain_Q30, subfr_length, nb_subfr, D, arch))
cannam@154 51
cannam@154 52 #else
cannam@154 53
cannam@154 54 extern void (*const SILK_BURG_MODIFIED_IMPL[OPUS_ARCHMASK + 1])(
cannam@154 55 opus_int32 *res_nrg, /* O Residual energy */
cannam@154 56 opus_int *res_nrg_Q, /* O Residual energy Q value */
cannam@154 57 opus_int32 A_Q16[], /* O Prediction coefficients (length order) */
cannam@154 58 const opus_int16 x[], /* I Input signal, length: nb_subfr * ( D + subfr_length ) */
cannam@154 59 const opus_int32 minInvGain_Q30, /* I Inverse of max prediction gain */
cannam@154 60 const opus_int subfr_length, /* I Input signal subframe length (incl. D preceding samples) */
cannam@154 61 const opus_int nb_subfr, /* I Number of subframes stacked in x */
cannam@154 62 const opus_int D, /* I Order */
cannam@154 63 int arch /* I Run-time architecture */);
cannam@154 64
cannam@154 65 # define silk_burg_modified(res_nrg, res_nrg_Q, A_Q16, x, minInvGain_Q30, subfr_length, nb_subfr, D, arch) \
cannam@154 66 ((*SILK_BURG_MODIFIED_IMPL[(arch) & OPUS_ARCHMASK])(res_nrg, res_nrg_Q, A_Q16, x, minInvGain_Q30, subfr_length, nb_subfr, D, arch))
cannam@154 67
cannam@154 68 #endif
cannam@154 69
cannam@154 70 opus_int64 silk_inner_prod16_aligned_64_sse4_1(
cannam@154 71 const opus_int16 *inVec1,
cannam@154 72 const opus_int16 *inVec2,
cannam@154 73 const opus_int len
cannam@154 74 );
cannam@154 75
cannam@154 76
cannam@154 77 #if defined(OPUS_X86_PRESUME_SSE4_1)
cannam@154 78
cannam@154 79 #define silk_inner_prod16_aligned_64(inVec1, inVec2, len, arch) \
cannam@154 80 ((void)(arch),silk_inner_prod16_aligned_64_sse4_1(inVec1, inVec2, len))
cannam@154 81
cannam@154 82 #else
cannam@154 83
cannam@154 84 extern opus_int64 (*const SILK_INNER_PROD16_ALIGNED_64_IMPL[OPUS_ARCHMASK + 1])(
cannam@154 85 const opus_int16 *inVec1,
cannam@154 86 const opus_int16 *inVec2,
cannam@154 87 const opus_int len);
cannam@154 88
cannam@154 89 # define silk_inner_prod16_aligned_64(inVec1, inVec2, len, arch) \
cannam@154 90 ((*SILK_INNER_PROD16_ALIGNED_64_IMPL[(arch) & OPUS_ARCHMASK])(inVec1, inVec2, len))
cannam@154 91
cannam@154 92 #endif
cannam@154 93 #endif
cannam@154 94 #endif