xref: /aosp_15_r20/external/speex/libspeexdsp/fixed_arm5e.h (revision 28e138c64d234588b5cd2a8a403b584bd3036e4e)
1*28e138c6SAndroid Build Coastguard Worker /* Copyright (C) 2003 Jean-Marc Valin */
2*28e138c6SAndroid Build Coastguard Worker /**
3*28e138c6SAndroid Build Coastguard Worker    @file fixed_arm5e.h
4*28e138c6SAndroid Build Coastguard Worker    @brief ARM-tuned fixed-point operations
5*28e138c6SAndroid Build Coastguard Worker */
6*28e138c6SAndroid Build Coastguard Worker /*
7*28e138c6SAndroid Build Coastguard Worker    Redistribution and use in source and binary forms, with or without
8*28e138c6SAndroid Build Coastguard Worker    modification, are permitted provided that the following conditions
9*28e138c6SAndroid Build Coastguard Worker    are met:
10*28e138c6SAndroid Build Coastguard Worker 
11*28e138c6SAndroid Build Coastguard Worker    - Redistributions of source code must retain the above copyright
12*28e138c6SAndroid Build Coastguard Worker    notice, this list of conditions and the following disclaimer.
13*28e138c6SAndroid Build Coastguard Worker 
14*28e138c6SAndroid Build Coastguard Worker    - Redistributions in binary form must reproduce the above copyright
15*28e138c6SAndroid Build Coastguard Worker    notice, this list of conditions and the following disclaimer in the
16*28e138c6SAndroid Build Coastguard Worker    documentation and/or other materials provided with the distribution.
17*28e138c6SAndroid Build Coastguard Worker 
18*28e138c6SAndroid Build Coastguard Worker    - Neither the name of the Xiph.org Foundation nor the names of its
19*28e138c6SAndroid Build Coastguard Worker    contributors may be used to endorse or promote products derived from
20*28e138c6SAndroid Build Coastguard Worker    this software without specific prior written permission.
21*28e138c6SAndroid Build Coastguard Worker 
22*28e138c6SAndroid Build Coastguard Worker    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23*28e138c6SAndroid Build Coastguard Worker    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24*28e138c6SAndroid Build Coastguard Worker    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25*28e138c6SAndroid Build Coastguard Worker    A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
26*28e138c6SAndroid Build Coastguard Worker    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
27*28e138c6SAndroid Build Coastguard Worker    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
28*28e138c6SAndroid Build Coastguard Worker    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
29*28e138c6SAndroid Build Coastguard Worker    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
30*28e138c6SAndroid Build Coastguard Worker    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
31*28e138c6SAndroid Build Coastguard Worker    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
32*28e138c6SAndroid Build Coastguard Worker    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33*28e138c6SAndroid Build Coastguard Worker */
34*28e138c6SAndroid Build Coastguard Worker 
35*28e138c6SAndroid Build Coastguard Worker #ifndef FIXED_ARM5E_H
36*28e138c6SAndroid Build Coastguard Worker #define FIXED_ARM5E_H
37*28e138c6SAndroid Build Coastguard Worker 
38*28e138c6SAndroid Build Coastguard Worker #undef MULT16_16
MULT16_16(spx_word16_t x,spx_word16_t y)39*28e138c6SAndroid Build Coastguard Worker static inline spx_word32_t MULT16_16(spx_word16_t x, spx_word16_t y) {
40*28e138c6SAndroid Build Coastguard Worker   int res;
41*28e138c6SAndroid Build Coastguard Worker   asm ("smulbb  %0,%1,%2;\n"
42*28e138c6SAndroid Build Coastguard Worker               : "=&r"(res)
43*28e138c6SAndroid Build Coastguard Worker               : "%r"(x),"r"(y));
44*28e138c6SAndroid Build Coastguard Worker   return(res);
45*28e138c6SAndroid Build Coastguard Worker }
46*28e138c6SAndroid Build Coastguard Worker 
47*28e138c6SAndroid Build Coastguard Worker #undef MAC16_16
MAC16_16(spx_word32_t a,spx_word16_t x,spx_word32_t y)48*28e138c6SAndroid Build Coastguard Worker static inline spx_word32_t MAC16_16(spx_word32_t a, spx_word16_t x, spx_word32_t y) {
49*28e138c6SAndroid Build Coastguard Worker   int res;
50*28e138c6SAndroid Build Coastguard Worker   asm ("smlabb  %0,%1,%2,%3;\n"
51*28e138c6SAndroid Build Coastguard Worker               : "=&r"(res)
52*28e138c6SAndroid Build Coastguard Worker                : "%r"(x),"r"(y),"r"(a));
53*28e138c6SAndroid Build Coastguard Worker   return(res);
54*28e138c6SAndroid Build Coastguard Worker }
55*28e138c6SAndroid Build Coastguard Worker 
56*28e138c6SAndroid Build Coastguard Worker #undef MULT16_32_Q15
MULT16_32_Q15(spx_word16_t x,spx_word32_t y)57*28e138c6SAndroid Build Coastguard Worker static inline spx_word32_t MULT16_32_Q15(spx_word16_t x, spx_word32_t y) {
58*28e138c6SAndroid Build Coastguard Worker   int res;
59*28e138c6SAndroid Build Coastguard Worker   asm ("smulwb  %0,%1,%2;\n"
60*28e138c6SAndroid Build Coastguard Worker               : "=&r"(res)
61*28e138c6SAndroid Build Coastguard Worker                : "%r"(y<<1),"r"(x));
62*28e138c6SAndroid Build Coastguard Worker   return(res);
63*28e138c6SAndroid Build Coastguard Worker }
64*28e138c6SAndroid Build Coastguard Worker 
65*28e138c6SAndroid Build Coastguard Worker #undef MAC16_32_Q15
MAC16_32_Q15(spx_word32_t a,spx_word16_t x,spx_word32_t y)66*28e138c6SAndroid Build Coastguard Worker static inline spx_word32_t MAC16_32_Q15(spx_word32_t a, spx_word16_t x, spx_word32_t y) {
67*28e138c6SAndroid Build Coastguard Worker   int res;
68*28e138c6SAndroid Build Coastguard Worker   asm ("smlawb  %0,%1,%2,%3;\n"
69*28e138c6SAndroid Build Coastguard Worker               : "=&r"(res)
70*28e138c6SAndroid Build Coastguard Worker                : "%r"(y<<1),"r"(x),"r"(a));
71*28e138c6SAndroid Build Coastguard Worker   return(res);
72*28e138c6SAndroid Build Coastguard Worker }
73*28e138c6SAndroid Build Coastguard Worker 
74*28e138c6SAndroid Build Coastguard Worker #undef DIV32_16
DIV32_16(int a,int b)75*28e138c6SAndroid Build Coastguard Worker static inline short DIV32_16(int a, int b)
76*28e138c6SAndroid Build Coastguard Worker {
77*28e138c6SAndroid Build Coastguard Worker    int res=0;
78*28e138c6SAndroid Build Coastguard Worker    int dead1, dead2, dead3, dead4, dead5;
79*28e138c6SAndroid Build Coastguard Worker    __asm__ __volatile__ (
80*28e138c6SAndroid Build Coastguard Worker          "\teor %5, %0, %1\n"
81*28e138c6SAndroid Build Coastguard Worker          "\tmovs %4, %0\n"
82*28e138c6SAndroid Build Coastguard Worker          "\trsbmi %0, %0, #0 \n"
83*28e138c6SAndroid Build Coastguard Worker          "\tmovs %4, %1\n"
84*28e138c6SAndroid Build Coastguard Worker          "\trsbmi %1, %1, #0 \n"
85*28e138c6SAndroid Build Coastguard Worker          "\tmov %4, #1\n"
86*28e138c6SAndroid Build Coastguard Worker 
87*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #14 \n"
88*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #14 \n"
89*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
90*28e138c6SAndroid Build Coastguard Worker 
91*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #13 \n"
92*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #13 \n"
93*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
94*28e138c6SAndroid Build Coastguard Worker 
95*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #12 \n"
96*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #12 \n"
97*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
98*28e138c6SAndroid Build Coastguard Worker 
99*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #11 \n"
100*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #11 \n"
101*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
102*28e138c6SAndroid Build Coastguard Worker 
103*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #10 \n"
104*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #10 \n"
105*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
106*28e138c6SAndroid Build Coastguard Worker 
107*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #9 \n"
108*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #9 \n"
109*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
110*28e138c6SAndroid Build Coastguard Worker 
111*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #8 \n"
112*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #8 \n"
113*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
114*28e138c6SAndroid Build Coastguard Worker 
115*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #7 \n"
116*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #7 \n"
117*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
118*28e138c6SAndroid Build Coastguard Worker 
119*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #6 \n"
120*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #6 \n"
121*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
122*28e138c6SAndroid Build Coastguard Worker 
123*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #5 \n"
124*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #5 \n"
125*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
126*28e138c6SAndroid Build Coastguard Worker 
127*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #4 \n"
128*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #4 \n"
129*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
130*28e138c6SAndroid Build Coastguard Worker 
131*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #3 \n"
132*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #3 \n"
133*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
134*28e138c6SAndroid Build Coastguard Worker 
135*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #2 \n"
136*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #2 \n"
137*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
138*28e138c6SAndroid Build Coastguard Worker 
139*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1, asl #1 \n"
140*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4, asl #1 \n"
141*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
142*28e138c6SAndroid Build Coastguard Worker 
143*28e138c6SAndroid Build Coastguard Worker          "\tsubs %3, %0, %1 \n"
144*28e138c6SAndroid Build Coastguard Worker          "\torrpl %2, %2, %4 \n"
145*28e138c6SAndroid Build Coastguard Worker          "\tmovpl %0, %3 \n"
146*28e138c6SAndroid Build Coastguard Worker 
147*28e138c6SAndroid Build Coastguard Worker          "\tmovs %5, %5, lsr #31 \n"
148*28e138c6SAndroid Build Coastguard Worker          "\trsbne %2, %2, #0 \n"
149*28e138c6SAndroid Build Coastguard Worker    : "=r" (dead1), "=r" (dead2), "=r" (res),
150*28e138c6SAndroid Build Coastguard Worker    "=r" (dead3), "=r" (dead4), "=r" (dead5)
151*28e138c6SAndroid Build Coastguard Worker    : "0" (a), "1" (b), "2" (res)
152*28e138c6SAndroid Build Coastguard Worker    : "memory", "cc"
153*28e138c6SAndroid Build Coastguard Worker                         );
154*28e138c6SAndroid Build Coastguard Worker    return res;
155*28e138c6SAndroid Build Coastguard Worker }
156*28e138c6SAndroid Build Coastguard Worker 
157*28e138c6SAndroid Build Coastguard Worker 
158*28e138c6SAndroid Build Coastguard Worker 
159*28e138c6SAndroid Build Coastguard Worker 
160*28e138c6SAndroid Build Coastguard Worker #endif
161