xref: /aosp_15_r20/external/speex/libspeexdsp/misc_bfin.h (revision 28e138c64d234588b5cd2a8a403b584bd3036e4e)
1*28e138c6SAndroid Build Coastguard Worker /* Copyright (C) 2005 Analog Devices */
2*28e138c6SAndroid Build Coastguard Worker /**
3*28e138c6SAndroid Build Coastguard Worker    @file misc_bfin.h
4*28e138c6SAndroid Build Coastguard Worker    @author Jean-Marc Valin
5*28e138c6SAndroid Build Coastguard Worker    @brief Various compatibility routines for Speex (Blackfin version)
6*28e138c6SAndroid Build Coastguard Worker */
7*28e138c6SAndroid Build Coastguard Worker /*
8*28e138c6SAndroid Build Coastguard Worker    Redistribution and use in source and binary forms, with or without
9*28e138c6SAndroid Build Coastguard Worker    modification, are permitted provided that the following conditions
10*28e138c6SAndroid Build Coastguard Worker    are met:
11*28e138c6SAndroid Build Coastguard Worker 
12*28e138c6SAndroid Build Coastguard Worker    - Redistributions of source code must retain the above copyright
13*28e138c6SAndroid Build Coastguard Worker    notice, this list of conditions and the following disclaimer.
14*28e138c6SAndroid Build Coastguard Worker 
15*28e138c6SAndroid Build Coastguard Worker    - Redistributions in binary form must reproduce the above copyright
16*28e138c6SAndroid Build Coastguard Worker    notice, this list of conditions and the following disclaimer in the
17*28e138c6SAndroid Build Coastguard Worker    documentation and/or other materials provided with the distribution.
18*28e138c6SAndroid Build Coastguard Worker 
19*28e138c6SAndroid Build Coastguard Worker    - Neither the name of the Xiph.org Foundation nor the names of its
20*28e138c6SAndroid Build Coastguard Worker    contributors may be used to endorse or promote products derived from
21*28e138c6SAndroid Build Coastguard Worker    this software without specific prior written permission.
22*28e138c6SAndroid Build Coastguard Worker 
23*28e138c6SAndroid Build Coastguard Worker    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24*28e138c6SAndroid Build Coastguard Worker    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25*28e138c6SAndroid Build Coastguard Worker    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26*28e138c6SAndroid Build Coastguard Worker    A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
27*28e138c6SAndroid Build Coastguard Worker    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28*28e138c6SAndroid Build Coastguard Worker    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29*28e138c6SAndroid Build Coastguard Worker    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30*28e138c6SAndroid Build Coastguard Worker    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31*28e138c6SAndroid Build Coastguard Worker    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32*28e138c6SAndroid Build Coastguard Worker    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33*28e138c6SAndroid Build Coastguard Worker    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34*28e138c6SAndroid Build Coastguard Worker */
35*28e138c6SAndroid Build Coastguard Worker 
36*28e138c6SAndroid Build Coastguard Worker #include "bfin.h"
37*28e138c6SAndroid Build Coastguard Worker 
38*28e138c6SAndroid Build Coastguard Worker #define OVERRIDE_SPEEX_MOVE
speex_move(void * dest,void * src,int n)39*28e138c6SAndroid Build Coastguard Worker void *speex_move (void *dest, void *src, int n)
40*28e138c6SAndroid Build Coastguard Worker {
41*28e138c6SAndroid Build Coastguard Worker    __asm__ __volatile__
42*28e138c6SAndroid Build Coastguard Worker          (
43*28e138c6SAndroid Build Coastguard Worker          "L0 = 0;\n\t"
44*28e138c6SAndroid Build Coastguard Worker          "I0 = %0;\n\t"
45*28e138c6SAndroid Build Coastguard Worker          "R0 = [I0++];\n\t"
46*28e138c6SAndroid Build Coastguard Worker          "LOOP move%= LC0 = %2;\n\t"
47*28e138c6SAndroid Build Coastguard Worker          "LOOP_BEGIN move%=;\n\t"
48*28e138c6SAndroid Build Coastguard Worker             "[%1++] = R0 || R0 = [I0++];\n\t"
49*28e138c6SAndroid Build Coastguard Worker          "LOOP_END move%=;\n\t"
50*28e138c6SAndroid Build Coastguard Worker          "[%1++] = R0;\n\t"
51*28e138c6SAndroid Build Coastguard Worker    : "=a" (src), "=a" (dest)
52*28e138c6SAndroid Build Coastguard Worker    : "a" ((n>>2)-1), "0" (src), "1" (dest)
53*28e138c6SAndroid Build Coastguard Worker    : "R0", "I0", "L0", "memory" BFIN_HWLOOP0_REGS
54*28e138c6SAndroid Build Coastguard Worker          );
55*28e138c6SAndroid Build Coastguard Worker    return dest;
56*28e138c6SAndroid Build Coastguard Worker }
57