summaryrefslogtreecommitdiff
path: root/lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c')
-rw-r--r--lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c167
1 files changed, 167 insertions, 0 deletions
diff --git a/lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c b/lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c
new file mode 100644
index 0000000000..d39d88edec
--- /dev/null
+++ b/lib/rbcodec/codecs/libopus/celt/x86/x86_celt_map.c
@@ -0,0 +1,167 @@
1/* Copyright (c) 2014, Cisco Systems, INC
2 Written by XiangMingZhu WeiZhou MinPeng YanWang
3
4 Redistribution and use in source and binary forms, with or without
5 modification, are permitted provided that the following conditions
6 are met:
7
8 - Redistributions of source code must retain the above copyright
9 notice, this list of conditions and the following disclaimer.
10
11 - Redistributions in binary form must reproduce the above copyright
12 notice, this list of conditions and the following disclaimer in the
13 documentation and/or other materials provided with the distribution.
14
15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
19 OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
23 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*/
27
28#if defined(HAVE_CONFIG_H)
29#include "config.h"
30#endif
31
32#include "x86/x86cpu.h"
33#include "celt_lpc.h"
34#include "pitch.h"
35#include "pitch_sse.h"
36#include "vq.h"
37
38#if defined(OPUS_HAVE_RTCD)
39
40# if defined(FIXED_POINT)
41
42#if defined(OPUS_X86_MAY_HAVE_SSE4_1) && !defined(OPUS_X86_PRESUME_SSE4_1)
43
44void (*const CELT_FIR_IMPL[OPUS_ARCHMASK + 1])(
45 const opus_val16 *x,
46 const opus_val16 *num,
47 opus_val16 *y,
48 int N,
49 int ord,
50 int arch
51) = {
52 celt_fir_c, /* non-sse */
53 celt_fir_c,
54 celt_fir_c,
55 MAY_HAVE_SSE4_1(celt_fir), /* sse4.1 */
56 MAY_HAVE_SSE4_1(celt_fir) /* avx */
57};
58
59void (*const XCORR_KERNEL_IMPL[OPUS_ARCHMASK + 1])(
60 const opus_val16 *x,
61 const opus_val16 *y,
62 opus_val32 sum[4],
63 int len
64) = {
65 xcorr_kernel_c, /* non-sse */
66 xcorr_kernel_c,
67 xcorr_kernel_c,
68 MAY_HAVE_SSE4_1(xcorr_kernel), /* sse4.1 */
69 MAY_HAVE_SSE4_1(xcorr_kernel) /* avx */
70};
71
72#endif
73
74#if (defined(OPUS_X86_MAY_HAVE_SSE4_1) && !defined(OPUS_X86_PRESUME_SSE4_1)) || \
75 (!defined(OPUS_X86_MAY_HAVE_SSE_4_1) && defined(OPUS_X86_MAY_HAVE_SSE2) && !defined(OPUS_X86_PRESUME_SSE2))
76
77opus_val32 (*const CELT_INNER_PROD_IMPL[OPUS_ARCHMASK + 1])(
78 const opus_val16 *x,
79 const opus_val16 *y,
80 int N
81) = {
82 celt_inner_prod_c, /* non-sse */
83 celt_inner_prod_c,
84 MAY_HAVE_SSE2(celt_inner_prod),
85 MAY_HAVE_SSE4_1(celt_inner_prod), /* sse4.1 */
86 MAY_HAVE_SSE4_1(celt_inner_prod) /* avx */
87};
88
89#endif
90
91# else
92
93#if defined(OPUS_X86_MAY_HAVE_SSE) && !defined(OPUS_X86_PRESUME_SSE)
94
95void (*const XCORR_KERNEL_IMPL[OPUS_ARCHMASK + 1])(
96 const opus_val16 *x,
97 const opus_val16 *y,
98 opus_val32 sum[4],
99 int len
100) = {
101 xcorr_kernel_c, /* non-sse */
102 MAY_HAVE_SSE(xcorr_kernel),
103 MAY_HAVE_SSE(xcorr_kernel),
104 MAY_HAVE_SSE(xcorr_kernel),
105 MAY_HAVE_SSE(xcorr_kernel)
106};
107
108opus_val32 (*const CELT_INNER_PROD_IMPL[OPUS_ARCHMASK + 1])(
109 const opus_val16 *x,
110 const opus_val16 *y,
111 int N
112) = {
113 celt_inner_prod_c, /* non-sse */
114 MAY_HAVE_SSE(celt_inner_prod),
115 MAY_HAVE_SSE(celt_inner_prod),
116 MAY_HAVE_SSE(celt_inner_prod),
117 MAY_HAVE_SSE(celt_inner_prod)
118};
119
120void (*const DUAL_INNER_PROD_IMPL[OPUS_ARCHMASK + 1])(
121 const opus_val16 *x,
122 const opus_val16 *y01,
123 const opus_val16 *y02,
124 int N,
125 opus_val32 *xy1,
126 opus_val32 *xy2
127) = {
128 dual_inner_prod_c, /* non-sse */
129 MAY_HAVE_SSE(dual_inner_prod),
130 MAY_HAVE_SSE(dual_inner_prod),
131 MAY_HAVE_SSE(dual_inner_prod),
132 MAY_HAVE_SSE(dual_inner_prod)
133};
134
135void (*const COMB_FILTER_CONST_IMPL[OPUS_ARCHMASK + 1])(
136 opus_val32 *y,
137 opus_val32 *x,
138 int T,
139 int N,
140 opus_val16 g10,
141 opus_val16 g11,
142 opus_val16 g12
143) = {
144 comb_filter_const_c, /* non-sse */
145 MAY_HAVE_SSE(comb_filter_const),
146 MAY_HAVE_SSE(comb_filter_const),
147 MAY_HAVE_SSE(comb_filter_const),
148 MAY_HAVE_SSE(comb_filter_const)
149};
150
151
152#endif
153
154#if defined(OPUS_X86_MAY_HAVE_SSE2) && !defined(OPUS_X86_PRESUME_SSE2)
155opus_val16 (*const OP_PVQ_SEARCH_IMPL[OPUS_ARCHMASK + 1])(
156 celt_norm *_X, int *iy, int K, int N, int arch
157) = {
158 op_pvq_search_c, /* non-sse */
159 op_pvq_search_c,
160 MAY_HAVE_SSE2(op_pvq_search),
161 MAY_HAVE_SSE2(op_pvq_search),
162 MAY_HAVE_SSE2(op_pvq_search)
163};
164#endif
165
166#endif
167#endif