xref: /aosp_15_r20/prebuilts/sdk/renderscript/clang-include/fmaintrin.h (revision 344a7f5ef16c479e7a7f54ee6567a9d112f9e72b)
1*344a7f5eSAndroid Build Coastguard Worker /*===---- fma4intrin.h - FMA4 intrinsics -----------------------------------===
2*344a7f5eSAndroid Build Coastguard Worker  *
3*344a7f5eSAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a copy
4*344a7f5eSAndroid Build Coastguard Worker  * of this software and associated documentation files (the "Software"), to deal
5*344a7f5eSAndroid Build Coastguard Worker  * in the Software without restriction, including without limitation the rights
6*344a7f5eSAndroid Build Coastguard Worker  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7*344a7f5eSAndroid Build Coastguard Worker  * copies of the Software, and to permit persons to whom the Software is
8*344a7f5eSAndroid Build Coastguard Worker  * furnished to do so, subject to the following conditions:
9*344a7f5eSAndroid Build Coastguard Worker  *
10*344a7f5eSAndroid Build Coastguard Worker  * The above copyright notice and this permission notice shall be included in
11*344a7f5eSAndroid Build Coastguard Worker  * all copies or substantial portions of the Software.
12*344a7f5eSAndroid Build Coastguard Worker  *
13*344a7f5eSAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14*344a7f5eSAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15*344a7f5eSAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16*344a7f5eSAndroid Build Coastguard Worker  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17*344a7f5eSAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18*344a7f5eSAndroid Build Coastguard Worker  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19*344a7f5eSAndroid Build Coastguard Worker  * THE SOFTWARE.
20*344a7f5eSAndroid Build Coastguard Worker  *
21*344a7f5eSAndroid Build Coastguard Worker  *===-----------------------------------------------------------------------===
22*344a7f5eSAndroid Build Coastguard Worker  */
23*344a7f5eSAndroid Build Coastguard Worker 
24*344a7f5eSAndroid Build Coastguard Worker #ifndef __IMMINTRIN_H
25*344a7f5eSAndroid Build Coastguard Worker #error "Never use <fmaintrin.h> directly; include <immintrin.h> instead."
26*344a7f5eSAndroid Build Coastguard Worker #endif
27*344a7f5eSAndroid Build Coastguard Worker 
28*344a7f5eSAndroid Build Coastguard Worker #ifndef __FMAINTRIN_H
29*344a7f5eSAndroid Build Coastguard Worker #define __FMAINTRIN_H
30*344a7f5eSAndroid Build Coastguard Worker 
31*344a7f5eSAndroid Build Coastguard Worker /* Define the default attributes for the functions in this file. */
32*344a7f5eSAndroid Build Coastguard Worker #define __DEFAULT_FN_ATTRS __attribute__((__always_inline__, __nodebug__, __target__("fma")))
33*344a7f5eSAndroid Build Coastguard Worker 
34*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmadd_ps(__m128 __A,__m128 __B,__m128 __C)35*344a7f5eSAndroid Build Coastguard Worker _mm_fmadd_ps(__m128 __A, __m128 __B, __m128 __C)
36*344a7f5eSAndroid Build Coastguard Worker {
37*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmaddps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
38*344a7f5eSAndroid Build Coastguard Worker }
39*344a7f5eSAndroid Build Coastguard Worker 
40*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmadd_pd(__m128d __A,__m128d __B,__m128d __C)41*344a7f5eSAndroid Build Coastguard Worker _mm_fmadd_pd(__m128d __A, __m128d __B, __m128d __C)
42*344a7f5eSAndroid Build Coastguard Worker {
43*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmaddpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
44*344a7f5eSAndroid Build Coastguard Worker }
45*344a7f5eSAndroid Build Coastguard Worker 
46*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmadd_ss(__m128 __A,__m128 __B,__m128 __C)47*344a7f5eSAndroid Build Coastguard Worker _mm_fmadd_ss(__m128 __A, __m128 __B, __m128 __C)
48*344a7f5eSAndroid Build Coastguard Worker {
49*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmaddss((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
50*344a7f5eSAndroid Build Coastguard Worker }
51*344a7f5eSAndroid Build Coastguard Worker 
52*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmadd_sd(__m128d __A,__m128d __B,__m128d __C)53*344a7f5eSAndroid Build Coastguard Worker _mm_fmadd_sd(__m128d __A, __m128d __B, __m128d __C)
54*344a7f5eSAndroid Build Coastguard Worker {
55*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmaddsd((__v2df)__A, (__v2df)__B, (__v2df)__C);
56*344a7f5eSAndroid Build Coastguard Worker }
57*344a7f5eSAndroid Build Coastguard Worker 
58*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmsub_ps(__m128 __A,__m128 __B,__m128 __C)59*344a7f5eSAndroid Build Coastguard Worker _mm_fmsub_ps(__m128 __A, __m128 __B, __m128 __C)
60*344a7f5eSAndroid Build Coastguard Worker {
61*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmsubps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
62*344a7f5eSAndroid Build Coastguard Worker }
63*344a7f5eSAndroid Build Coastguard Worker 
64*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmsub_pd(__m128d __A,__m128d __B,__m128d __C)65*344a7f5eSAndroid Build Coastguard Worker _mm_fmsub_pd(__m128d __A, __m128d __B, __m128d __C)
66*344a7f5eSAndroid Build Coastguard Worker {
67*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmsubpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
68*344a7f5eSAndroid Build Coastguard Worker }
69*344a7f5eSAndroid Build Coastguard Worker 
70*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmsub_ss(__m128 __A,__m128 __B,__m128 __C)71*344a7f5eSAndroid Build Coastguard Worker _mm_fmsub_ss(__m128 __A, __m128 __B, __m128 __C)
72*344a7f5eSAndroid Build Coastguard Worker {
73*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmsubss((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
74*344a7f5eSAndroid Build Coastguard Worker }
75*344a7f5eSAndroid Build Coastguard Worker 
76*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmsub_sd(__m128d __A,__m128d __B,__m128d __C)77*344a7f5eSAndroid Build Coastguard Worker _mm_fmsub_sd(__m128d __A, __m128d __B, __m128d __C)
78*344a7f5eSAndroid Build Coastguard Worker {
79*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmsubsd((__v2df)__A, (__v2df)__B, (__v2df)__C);
80*344a7f5eSAndroid Build Coastguard Worker }
81*344a7f5eSAndroid Build Coastguard Worker 
82*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fnmadd_ps(__m128 __A,__m128 __B,__m128 __C)83*344a7f5eSAndroid Build Coastguard Worker _mm_fnmadd_ps(__m128 __A, __m128 __B, __m128 __C)
84*344a7f5eSAndroid Build Coastguard Worker {
85*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfnmaddps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
86*344a7f5eSAndroid Build Coastguard Worker }
87*344a7f5eSAndroid Build Coastguard Worker 
88*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fnmadd_pd(__m128d __A,__m128d __B,__m128d __C)89*344a7f5eSAndroid Build Coastguard Worker _mm_fnmadd_pd(__m128d __A, __m128d __B, __m128d __C)
90*344a7f5eSAndroid Build Coastguard Worker {
91*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfnmaddpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
92*344a7f5eSAndroid Build Coastguard Worker }
93*344a7f5eSAndroid Build Coastguard Worker 
94*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fnmadd_ss(__m128 __A,__m128 __B,__m128 __C)95*344a7f5eSAndroid Build Coastguard Worker _mm_fnmadd_ss(__m128 __A, __m128 __B, __m128 __C)
96*344a7f5eSAndroid Build Coastguard Worker {
97*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfnmaddss((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
98*344a7f5eSAndroid Build Coastguard Worker }
99*344a7f5eSAndroid Build Coastguard Worker 
100*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fnmadd_sd(__m128d __A,__m128d __B,__m128d __C)101*344a7f5eSAndroid Build Coastguard Worker _mm_fnmadd_sd(__m128d __A, __m128d __B, __m128d __C)
102*344a7f5eSAndroid Build Coastguard Worker {
103*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfnmaddsd((__v2df)__A, (__v2df)__B, (__v2df)__C);
104*344a7f5eSAndroid Build Coastguard Worker }
105*344a7f5eSAndroid Build Coastguard Worker 
106*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fnmsub_ps(__m128 __A,__m128 __B,__m128 __C)107*344a7f5eSAndroid Build Coastguard Worker _mm_fnmsub_ps(__m128 __A, __m128 __B, __m128 __C)
108*344a7f5eSAndroid Build Coastguard Worker {
109*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfnmsubps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
110*344a7f5eSAndroid Build Coastguard Worker }
111*344a7f5eSAndroid Build Coastguard Worker 
112*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fnmsub_pd(__m128d __A,__m128d __B,__m128d __C)113*344a7f5eSAndroid Build Coastguard Worker _mm_fnmsub_pd(__m128d __A, __m128d __B, __m128d __C)
114*344a7f5eSAndroid Build Coastguard Worker {
115*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfnmsubpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
116*344a7f5eSAndroid Build Coastguard Worker }
117*344a7f5eSAndroid Build Coastguard Worker 
118*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fnmsub_ss(__m128 __A,__m128 __B,__m128 __C)119*344a7f5eSAndroid Build Coastguard Worker _mm_fnmsub_ss(__m128 __A, __m128 __B, __m128 __C)
120*344a7f5eSAndroid Build Coastguard Worker {
121*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfnmsubss((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
122*344a7f5eSAndroid Build Coastguard Worker }
123*344a7f5eSAndroid Build Coastguard Worker 
124*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fnmsub_sd(__m128d __A,__m128d __B,__m128d __C)125*344a7f5eSAndroid Build Coastguard Worker _mm_fnmsub_sd(__m128d __A, __m128d __B, __m128d __C)
126*344a7f5eSAndroid Build Coastguard Worker {
127*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfnmsubsd((__v2df)__A, (__v2df)__B, (__v2df)__C);
128*344a7f5eSAndroid Build Coastguard Worker }
129*344a7f5eSAndroid Build Coastguard Worker 
130*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmaddsub_ps(__m128 __A,__m128 __B,__m128 __C)131*344a7f5eSAndroid Build Coastguard Worker _mm_fmaddsub_ps(__m128 __A, __m128 __B, __m128 __C)
132*344a7f5eSAndroid Build Coastguard Worker {
133*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmaddsubps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
134*344a7f5eSAndroid Build Coastguard Worker }
135*344a7f5eSAndroid Build Coastguard Worker 
136*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmaddsub_pd(__m128d __A,__m128d __B,__m128d __C)137*344a7f5eSAndroid Build Coastguard Worker _mm_fmaddsub_pd(__m128d __A, __m128d __B, __m128d __C)
138*344a7f5eSAndroid Build Coastguard Worker {
139*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmaddsubpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
140*344a7f5eSAndroid Build Coastguard Worker }
141*344a7f5eSAndroid Build Coastguard Worker 
142*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128 __DEFAULT_FN_ATTRS
_mm_fmsubadd_ps(__m128 __A,__m128 __B,__m128 __C)143*344a7f5eSAndroid Build Coastguard Worker _mm_fmsubadd_ps(__m128 __A, __m128 __B, __m128 __C)
144*344a7f5eSAndroid Build Coastguard Worker {
145*344a7f5eSAndroid Build Coastguard Worker   return (__m128)__builtin_ia32_vfmsubaddps((__v4sf)__A, (__v4sf)__B, (__v4sf)__C);
146*344a7f5eSAndroid Build Coastguard Worker }
147*344a7f5eSAndroid Build Coastguard Worker 
148*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m128d __DEFAULT_FN_ATTRS
_mm_fmsubadd_pd(__m128d __A,__m128d __B,__m128d __C)149*344a7f5eSAndroid Build Coastguard Worker _mm_fmsubadd_pd(__m128d __A, __m128d __B, __m128d __C)
150*344a7f5eSAndroid Build Coastguard Worker {
151*344a7f5eSAndroid Build Coastguard Worker   return (__m128d)__builtin_ia32_vfmsubaddpd((__v2df)__A, (__v2df)__B, (__v2df)__C);
152*344a7f5eSAndroid Build Coastguard Worker }
153*344a7f5eSAndroid Build Coastguard Worker 
154*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fmadd_ps(__m256 __A,__m256 __B,__m256 __C)155*344a7f5eSAndroid Build Coastguard Worker _mm256_fmadd_ps(__m256 __A, __m256 __B, __m256 __C)
156*344a7f5eSAndroid Build Coastguard Worker {
157*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfmaddps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
158*344a7f5eSAndroid Build Coastguard Worker }
159*344a7f5eSAndroid Build Coastguard Worker 
160*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fmadd_pd(__m256d __A,__m256d __B,__m256d __C)161*344a7f5eSAndroid Build Coastguard Worker _mm256_fmadd_pd(__m256d __A, __m256d __B, __m256d __C)
162*344a7f5eSAndroid Build Coastguard Worker {
163*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfmaddpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
164*344a7f5eSAndroid Build Coastguard Worker }
165*344a7f5eSAndroid Build Coastguard Worker 
166*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fmsub_ps(__m256 __A,__m256 __B,__m256 __C)167*344a7f5eSAndroid Build Coastguard Worker _mm256_fmsub_ps(__m256 __A, __m256 __B, __m256 __C)
168*344a7f5eSAndroid Build Coastguard Worker {
169*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfmsubps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
170*344a7f5eSAndroid Build Coastguard Worker }
171*344a7f5eSAndroid Build Coastguard Worker 
172*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fmsub_pd(__m256d __A,__m256d __B,__m256d __C)173*344a7f5eSAndroid Build Coastguard Worker _mm256_fmsub_pd(__m256d __A, __m256d __B, __m256d __C)
174*344a7f5eSAndroid Build Coastguard Worker {
175*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfmsubpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
176*344a7f5eSAndroid Build Coastguard Worker }
177*344a7f5eSAndroid Build Coastguard Worker 
178*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fnmadd_ps(__m256 __A,__m256 __B,__m256 __C)179*344a7f5eSAndroid Build Coastguard Worker _mm256_fnmadd_ps(__m256 __A, __m256 __B, __m256 __C)
180*344a7f5eSAndroid Build Coastguard Worker {
181*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfnmaddps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
182*344a7f5eSAndroid Build Coastguard Worker }
183*344a7f5eSAndroid Build Coastguard Worker 
184*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fnmadd_pd(__m256d __A,__m256d __B,__m256d __C)185*344a7f5eSAndroid Build Coastguard Worker _mm256_fnmadd_pd(__m256d __A, __m256d __B, __m256d __C)
186*344a7f5eSAndroid Build Coastguard Worker {
187*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfnmaddpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
188*344a7f5eSAndroid Build Coastguard Worker }
189*344a7f5eSAndroid Build Coastguard Worker 
190*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fnmsub_ps(__m256 __A,__m256 __B,__m256 __C)191*344a7f5eSAndroid Build Coastguard Worker _mm256_fnmsub_ps(__m256 __A, __m256 __B, __m256 __C)
192*344a7f5eSAndroid Build Coastguard Worker {
193*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfnmsubps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
194*344a7f5eSAndroid Build Coastguard Worker }
195*344a7f5eSAndroid Build Coastguard Worker 
196*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fnmsub_pd(__m256d __A,__m256d __B,__m256d __C)197*344a7f5eSAndroid Build Coastguard Worker _mm256_fnmsub_pd(__m256d __A, __m256d __B, __m256d __C)
198*344a7f5eSAndroid Build Coastguard Worker {
199*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfnmsubpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
200*344a7f5eSAndroid Build Coastguard Worker }
201*344a7f5eSAndroid Build Coastguard Worker 
202*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fmaddsub_ps(__m256 __A,__m256 __B,__m256 __C)203*344a7f5eSAndroid Build Coastguard Worker _mm256_fmaddsub_ps(__m256 __A, __m256 __B, __m256 __C)
204*344a7f5eSAndroid Build Coastguard Worker {
205*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfmaddsubps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
206*344a7f5eSAndroid Build Coastguard Worker }
207*344a7f5eSAndroid Build Coastguard Worker 
208*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fmaddsub_pd(__m256d __A,__m256d __B,__m256d __C)209*344a7f5eSAndroid Build Coastguard Worker _mm256_fmaddsub_pd(__m256d __A, __m256d __B, __m256d __C)
210*344a7f5eSAndroid Build Coastguard Worker {
211*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfmaddsubpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
212*344a7f5eSAndroid Build Coastguard Worker }
213*344a7f5eSAndroid Build Coastguard Worker 
214*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256 __DEFAULT_FN_ATTRS
_mm256_fmsubadd_ps(__m256 __A,__m256 __B,__m256 __C)215*344a7f5eSAndroid Build Coastguard Worker _mm256_fmsubadd_ps(__m256 __A, __m256 __B, __m256 __C)
216*344a7f5eSAndroid Build Coastguard Worker {
217*344a7f5eSAndroid Build Coastguard Worker   return (__m256)__builtin_ia32_vfmsubaddps256((__v8sf)__A, (__v8sf)__B, (__v8sf)__C);
218*344a7f5eSAndroid Build Coastguard Worker }
219*344a7f5eSAndroid Build Coastguard Worker 
220*344a7f5eSAndroid Build Coastguard Worker static __inline__ __m256d __DEFAULT_FN_ATTRS
_mm256_fmsubadd_pd(__m256d __A,__m256d __B,__m256d __C)221*344a7f5eSAndroid Build Coastguard Worker _mm256_fmsubadd_pd(__m256d __A, __m256d __B, __m256d __C)
222*344a7f5eSAndroid Build Coastguard Worker {
223*344a7f5eSAndroid Build Coastguard Worker   return (__m256d)__builtin_ia32_vfmsubaddpd256((__v4df)__A, (__v4df)__B, (__v4df)__C);
224*344a7f5eSAndroid Build Coastguard Worker }
225*344a7f5eSAndroid Build Coastguard Worker 
226*344a7f5eSAndroid Build Coastguard Worker #undef __DEFAULT_FN_ATTRS
227*344a7f5eSAndroid Build Coastguard Worker 
228*344a7f5eSAndroid Build Coastguard Worker #endif /* __FMAINTRIN_H */
229