annotate src/opus-1.3/silk/x86/x86_silk_map.c @ 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 #if defined(HAVE_CONFIG_H)
cannam@154 29 #include "config.h"
cannam@154 30 #endif
cannam@154 31
cannam@154 32 #include "celt/x86/x86cpu.h"
cannam@154 33 #include "structs.h"
cannam@154 34 #include "SigProc_FIX.h"
cannam@154 35 #include "pitch.h"
cannam@154 36 #include "main.h"
cannam@154 37
cannam@154 38 #if !defined(OPUS_X86_PRESUME_SSE4_1)
cannam@154 39
cannam@154 40 #if defined(FIXED_POINT)
cannam@154 41
cannam@154 42 #include "fixed/main_FIX.h"
cannam@154 43
cannam@154 44 opus_int64 (*const SILK_INNER_PROD16_ALIGNED_64_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 45 const opus_int16 *inVec1,
cannam@154 46 const opus_int16 *inVec2,
cannam@154 47 const opus_int len
cannam@154 48 ) = {
cannam@154 49 silk_inner_prod16_aligned_64_c, /* non-sse */
cannam@154 50 silk_inner_prod16_aligned_64_c,
cannam@154 51 silk_inner_prod16_aligned_64_c,
cannam@154 52 MAY_HAVE_SSE4_1( silk_inner_prod16_aligned_64 ), /* sse4.1 */
cannam@154 53 MAY_HAVE_SSE4_1( silk_inner_prod16_aligned_64 ) /* avx */
cannam@154 54 };
cannam@154 55
cannam@154 56 #endif
cannam@154 57
cannam@154 58 opus_int (*const SILK_VAD_GETSA_Q8_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 59 silk_encoder_state *psEncC,
cannam@154 60 const opus_int16 pIn[]
cannam@154 61 ) = {
cannam@154 62 silk_VAD_GetSA_Q8_c, /* non-sse */
cannam@154 63 silk_VAD_GetSA_Q8_c,
cannam@154 64 silk_VAD_GetSA_Q8_c,
cannam@154 65 MAY_HAVE_SSE4_1( silk_VAD_GetSA_Q8 ), /* sse4.1 */
cannam@154 66 MAY_HAVE_SSE4_1( silk_VAD_GetSA_Q8 ) /* avx */
cannam@154 67 };
cannam@154 68
cannam@154 69 #if 0 /* FIXME: SSE disabled until the NSQ code gets updated. */
cannam@154 70 void (*const SILK_NSQ_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 71 const silk_encoder_state *psEncC, /* I Encoder State */
cannam@154 72 silk_nsq_state *NSQ, /* I/O NSQ state */
cannam@154 73 SideInfoIndices *psIndices, /* I/O Quantization Indices */
cannam@154 74 const opus_int32 x_Q3[], /* I Prefiltered input signal */
cannam@154 75 opus_int8 pulses[], /* O Quantized pulse signal */
cannam@154 76 const opus_int16 PredCoef_Q12[ 2 * MAX_LPC_ORDER ], /* I Short term prediction coefs */
cannam@154 77 const opus_int16 LTPCoef_Q14[ LTP_ORDER * MAX_NB_SUBFR ], /* I Long term prediction coefs */
cannam@154 78 const opus_int16 AR2_Q13[ MAX_NB_SUBFR * MAX_SHAPE_LPC_ORDER ], /* I Noise shaping coefs */
cannam@154 79 const opus_int HarmShapeGain_Q14[ MAX_NB_SUBFR ], /* I Long term shaping coefs */
cannam@154 80 const opus_int Tilt_Q14[ MAX_NB_SUBFR ], /* I Spectral tilt */
cannam@154 81 const opus_int32 LF_shp_Q14[ MAX_NB_SUBFR ], /* I Low frequency shaping coefs */
cannam@154 82 const opus_int32 Gains_Q16[ MAX_NB_SUBFR ], /* I Quantization step sizes */
cannam@154 83 const opus_int pitchL[ MAX_NB_SUBFR ], /* I Pitch lags */
cannam@154 84 const opus_int Lambda_Q10, /* I Rate/distortion tradeoff */
cannam@154 85 const opus_int LTP_scale_Q14 /* I LTP state scaling */
cannam@154 86 ) = {
cannam@154 87 silk_NSQ_c, /* non-sse */
cannam@154 88 silk_NSQ_c,
cannam@154 89 silk_NSQ_c,
cannam@154 90 MAY_HAVE_SSE4_1( silk_NSQ ), /* sse4.1 */
cannam@154 91 MAY_HAVE_SSE4_1( silk_NSQ ) /* avx */
cannam@154 92 };
cannam@154 93 #endif
cannam@154 94
cannam@154 95 #if 0 /* FIXME: SSE disabled until silk_VQ_WMat_EC_sse4_1() gets updated. */
cannam@154 96 void (*const SILK_VQ_WMAT_EC_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 97 opus_int8 *ind, /* O index of best codebook vector */
cannam@154 98 opus_int32 *rate_dist_Q14, /* O best weighted quant error + mu * rate */
cannam@154 99 opus_int *gain_Q7, /* O sum of absolute LTP coefficients */
cannam@154 100 const opus_int16 *in_Q14, /* I input vector to be quantized */
cannam@154 101 const opus_int32 *W_Q18, /* I weighting matrix */
cannam@154 102 const opus_int8 *cb_Q7, /* I codebook */
cannam@154 103 const opus_uint8 *cb_gain_Q7, /* I codebook effective gain */
cannam@154 104 const opus_uint8 *cl_Q5, /* I code length for each codebook vector */
cannam@154 105 const opus_int mu_Q9, /* I tradeoff betw. weighted error and rate */
cannam@154 106 const opus_int32 max_gain_Q7, /* I maximum sum of absolute LTP coefficients */
cannam@154 107 opus_int L /* I number of vectors in codebook */
cannam@154 108 ) = {
cannam@154 109 silk_VQ_WMat_EC_c, /* non-sse */
cannam@154 110 silk_VQ_WMat_EC_c,
cannam@154 111 silk_VQ_WMat_EC_c,
cannam@154 112 MAY_HAVE_SSE4_1( silk_VQ_WMat_EC ), /* sse4.1 */
cannam@154 113 MAY_HAVE_SSE4_1( silk_VQ_WMat_EC ) /* avx */
cannam@154 114 };
cannam@154 115 #endif
cannam@154 116
cannam@154 117 #if 0 /* FIXME: SSE disabled until the NSQ code gets updated. */
cannam@154 118 void (*const SILK_NSQ_DEL_DEC_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 119 const silk_encoder_state *psEncC, /* I Encoder State */
cannam@154 120 silk_nsq_state *NSQ, /* I/O NSQ state */
cannam@154 121 SideInfoIndices *psIndices, /* I/O Quantization Indices */
cannam@154 122 const opus_int32 x_Q3[], /* I Prefiltered input signal */
cannam@154 123 opus_int8 pulses[], /* O Quantized pulse signal */
cannam@154 124 const opus_int16 PredCoef_Q12[ 2 * MAX_LPC_ORDER ], /* I Short term prediction coefs */
cannam@154 125 const opus_int16 LTPCoef_Q14[ LTP_ORDER * MAX_NB_SUBFR ], /* I Long term prediction coefs */
cannam@154 126 const opus_int16 AR2_Q13[ MAX_NB_SUBFR * MAX_SHAPE_LPC_ORDER ], /* I Noise shaping coefs */
cannam@154 127 const opus_int HarmShapeGain_Q14[ MAX_NB_SUBFR ], /* I Long term shaping coefs */
cannam@154 128 const opus_int Tilt_Q14[ MAX_NB_SUBFR ], /* I Spectral tilt */
cannam@154 129 const opus_int32 LF_shp_Q14[ MAX_NB_SUBFR ], /* I Low frequency shaping coefs */
cannam@154 130 const opus_int32 Gains_Q16[ MAX_NB_SUBFR ], /* I Quantization step sizes */
cannam@154 131 const opus_int pitchL[ MAX_NB_SUBFR ], /* I Pitch lags */
cannam@154 132 const opus_int Lambda_Q10, /* I Rate/distortion tradeoff */
cannam@154 133 const opus_int LTP_scale_Q14 /* I LTP state scaling */
cannam@154 134 ) = {
cannam@154 135 silk_NSQ_del_dec_c, /* non-sse */
cannam@154 136 silk_NSQ_del_dec_c,
cannam@154 137 silk_NSQ_del_dec_c,
cannam@154 138 MAY_HAVE_SSE4_1( silk_NSQ_del_dec ), /* sse4.1 */
cannam@154 139 MAY_HAVE_SSE4_1( silk_NSQ_del_dec ) /* avx */
cannam@154 140 };
cannam@154 141 #endif
cannam@154 142
cannam@154 143 #if defined(FIXED_POINT)
cannam@154 144
cannam@154 145 void (*const SILK_BURG_MODIFIED_IMPL[ OPUS_ARCHMASK + 1 ] )(
cannam@154 146 opus_int32 *res_nrg, /* O Residual energy */
cannam@154 147 opus_int *res_nrg_Q, /* O Residual energy Q value */
cannam@154 148 opus_int32 A_Q16[], /* O Prediction coefficients (length order) */
cannam@154 149 const opus_int16 x[], /* I Input signal, length: nb_subfr * ( D + subfr_length ) */
cannam@154 150 const opus_int32 minInvGain_Q30, /* I Inverse of max prediction gain */
cannam@154 151 const opus_int subfr_length, /* I Input signal subframe length (incl. D preceding samples) */
cannam@154 152 const opus_int nb_subfr, /* I Number of subframes stacked in x */
cannam@154 153 const opus_int D, /* I Order */
cannam@154 154 int arch /* I Run-time architecture */
cannam@154 155 ) = {
cannam@154 156 silk_burg_modified_c, /* non-sse */
cannam@154 157 silk_burg_modified_c,
cannam@154 158 silk_burg_modified_c,
cannam@154 159 MAY_HAVE_SSE4_1( silk_burg_modified ), /* sse4.1 */
cannam@154 160 MAY_HAVE_SSE4_1( silk_burg_modified ) /* avx */
cannam@154 161 };
cannam@154 162
cannam@154 163 #endif
cannam@154 164 #endif