OLD | NEW |
1 /* Copyright (c) 2010 Xiph.Org Foundation | 1 /* Copyright (c) 2014, Cisco Systems, INC |
2 * Copyright (c) 2013 Parrot */ | 2 Written by XiangMingZhu WeiZhou MinPeng YanWang |
3 /* | 3 |
4 Redistribution and use in source and binary forms, with or without | 4 Redistribution and use in source and binary forms, with or without |
5 modification, are permitted provided that the following conditions | 5 modification, are permitted provided that the following conditions |
6 are met: | 6 are met: |
7 | 7 |
8 - Redistributions of source code must retain the above copyright | 8 - Redistributions of source code must retain the above copyright |
9 notice, this list of conditions and the following disclaimer. | 9 notice, this list of conditions and the following disclaimer. |
10 | 10 |
11 - Redistributions in binary form must reproduce the above copyright | 11 - Redistributions in binary form must reproduce the above copyright |
12 notice, this list of conditions and the following disclaimer in the | 12 notice, this list of conditions and the following disclaimer in the |
13 documentation and/or other materials provided with the distribution. | 13 documentation and/or other materials provided with the distribution. |
14 | 14 |
15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
16 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 16 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
17 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 17 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
18 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER | 18 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER |
19 OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 19 OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
20 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 20 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
21 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 21 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
22 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | 22 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
23 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | 23 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
24 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | 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. | 25 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 */ | 26 */ |
27 | 27 |
28 #ifdef HAVE_CONFIG_H | 28 #if defined(HAVE_CONFIG_H) |
29 #include "config.h" | 29 #include "config.h" |
30 #endif | 30 #endif |
31 | 31 |
| 32 #include "x86/x86cpu.h" |
| 33 #include "celt_lpc.h" |
32 #include "pitch.h" | 34 #include "pitch.h" |
| 35 #include "pitch_sse.h" |
33 | 36 |
34 #if defined(OPUS_HAVE_RTCD) | 37 #if defined(OPUS_HAVE_RTCD) |
35 | 38 |
36 # if defined(FIXED_POINT) | 39 # if defined(FIXED_POINT) |
37 opus_val32 (*const CELT_PITCH_XCORR_IMPL[OPUS_ARCHMASK+1])(const opus_val16 *, | 40 |
38 const opus_val16 *, opus_val32 *, int , int) = { | 41 void (*const CELT_FIR_IMPL[OPUS_ARCHMASK + 1])( |
39 celt_pitch_xcorr_c, /* ARMv4 */ | 42 const opus_val16 *x, |
40 MAY_HAVE_EDSP(celt_pitch_xcorr), /* EDSP */ | 43 const opus_val16 *num, |
41 MAY_HAVE_MEDIA(celt_pitch_xcorr), /* Media */ | 44 opus_val16 *y, |
42 MAY_HAVE_NEON(celt_pitch_xcorr) /* NEON */ | 45 int N, |
| 46 int ord, |
| 47 opus_val16 *mem, |
| 48 int arch |
| 49 ) = { |
| 50 celt_fir_c, /* non-sse */ |
| 51 celt_fir_c, |
| 52 MAY_HAVE_SSE4_1(celt_fir), /* sse4.1 */ |
| 53 NULL |
43 }; | 54 }; |
| 55 |
| 56 void (*const XCORR_KERNEL_IMPL[OPUS_ARCHMASK + 1])( |
| 57 const opus_val16 *x, |
| 58 const opus_val16 *y, |
| 59 opus_val32 sum[4], |
| 60 int len |
| 61 ) = { |
| 62 xcorr_kernel_c, /* non-sse */ |
| 63 xcorr_kernel_c, |
| 64 MAY_HAVE_SSE4_1(xcorr_kernel), /* sse4.1 */ |
| 65 NULL |
| 66 }; |
| 67 |
| 68 opus_val32 (*const CELT_INNER_PROD_IMPL[OPUS_ARCHMASK + 1])( |
| 69 const opus_val16 *x, |
| 70 const opus_val16 *y, |
| 71 int N |
| 72 ) = { |
| 73 celt_inner_prod_c, /* non-sse */ |
| 74 MAY_HAVE_SSE2(celt_inner_prod), |
| 75 MAY_HAVE_SSE4_1(celt_inner_prod), /* sse4.1 */ |
| 76 NULL |
| 77 }; |
| 78 |
44 # else | 79 # else |
45 # error "Floating-point implementation is not supported by ARM asm yet." \ | 80 # error "Floating-point implementation is not supported by x86 RTCD yet." \ |
46 "Reconfigure with --disable-rtcd or send patches." | 81 "Reconfigure with --disable-rtcd or send patches." |
47 # endif | 82 # endif |
48 | 83 |
49 #endif | 84 #endif |
OLD | NEW |