003 File Manager
Current Path:
/usr/lib/clang/11.0.1/include
usr
/
lib
/
clang
/
11.0.1
/
include
/
📁
..
📄
__clang_cuda_builtin_vars.h
(4.56 KB)
📄
__clang_cuda_cmath.h
(16.37 KB)
📄
__clang_cuda_complex_builtins.h
(8.5 KB)
📄
__clang_cuda_device_functions.h
(55.59 KB)
📄
__clang_cuda_intrinsics.h
(21.59 KB)
📄
__clang_cuda_libdevice_declares.h
(21.73 KB)
📄
__clang_cuda_math.h
(15.91 KB)
📄
__clang_cuda_math_forward_declares.h
(8.21 KB)
📄
__clang_cuda_runtime_wrapper.h
(14.85 KB)
📄
__clang_hip_libdevice_declares.h
(19.19 KB)
📄
__clang_hip_math.h
(35.41 KB)
📄
__clang_hip_runtime_wrapper.h
(1.79 KB)
📄
__stddef_max_align_t.h
(857 B)
📄
__wmmintrin_aes.h
(5.14 KB)
📄
__wmmintrin_pclmul.h
(2.01 KB)
📄
adxintrin.h
(2.32 KB)
📄
altivec.h
(609.12 KB)
📄
ammintrin.h
(7.42 KB)
📄
amxintrin.h
(8.24 KB)
📄
arm64intr.h
(993 B)
📄
arm_acle.h
(21.87 KB)
📄
arm_bf16.h
(548 B)
📄
arm_cde.h
(32.67 KB)
📄
arm_cmse.h
(6.21 KB)
📄
arm_fp16.h
(16.97 KB)
📄
arm_mve.h
(1.48 MB)
📄
arm_neon.h
(2.31 MB)
📄
arm_sve.h
(1.14 MB)
📄
armintr.h
(843 B)
📄
avx2intrin.h
(38.11 KB)
📄
avx512bf16intrin.h
(10.45 KB)
📄
avx512bitalgintrin.h
(2.41 KB)
📄
avx512bwintrin.h
(75.17 KB)
📄
avx512cdintrin.h
(4.12 KB)
📄
avx512dqintrin.h
(58.3 KB)
📄
avx512erintrin.h
(11.7 KB)
📄
avx512fintrin.h
(377.18 KB)
📄
avx512ifmaintrin.h
(2.49 KB)
📄
avx512ifmavlintrin.h
(4.44 KB)
📄
avx512pfintrin.h
(4.53 KB)
📄
avx512vbmi2intrin.h
(13.1 KB)
📄
avx512vbmiintrin.h
(3.72 KB)
📄
avx512vbmivlintrin.h
(6.94 KB)
📄
avx512vlbf16intrin.h
(17.88 KB)
📄
avx512vlbitalgintrin.h
(4.23 KB)
📄
avx512vlbwintrin.h
(110.39 KB)
📄
avx512vlcdintrin.h
(7.66 KB)
📄
avx512vldqintrin.h
(46.24 KB)
📄
avx512vlintrin.h
(322.04 KB)
📄
avx512vlvbmi2intrin.h
(25.59 KB)
📄
avx512vlvnniintrin.h
(7.87 KB)
📄
avx512vlvp2intersectintrin.h
(4.44 KB)
📄
avx512vnniintrin.h
(4.21 KB)
📄
avx512vp2intersectintrin.h
(2.9 KB)
📄
avx512vpopcntdqintrin.h
(2 KB)
📄
avx512vpopcntdqvlintrin.h
(3.31 KB)
📄
avxintrin.h
(193.62 KB)
📄
bmi2intrin.h
(2.25 KB)
📄
bmiintrin.h
(14.02 KB)
📄
cet.h
(1.49 KB)
📄
cetintrin.h
(2.78 KB)
📄
cldemoteintrin.h
(1.18 KB)
📄
clflushoptintrin.h
(861 B)
📄
clwbintrin.h
(1.2 KB)
📄
clzerointrin.h
(1.13 KB)
📄
cpuid.h
(10.42 KB)
📁
cuda_wrappers
📄
emmintrin.h
(180.78 KB)
📄
enqcmdintrin.h
(2.12 KB)
📄
f16cintrin.h
(5.37 KB)
📄
fma4intrin.h
(6.82 KB)
📄
fmaintrin.h
(6.83 KB)
📁
fuzzer
📄
fxsrintrin.h
(2.82 KB)
📄
gfniintrin.h
(7.66 KB)
📄
htmintrin.h
(6.14 KB)
📄
htmxlintrin.h
(9.01 KB)
📄
ia32intrin.h
(12.65 KB)
📄
immintrin.h
(18.38 KB)
📄
invpcidintrin.h
(764 B)
📄
lwpintrin.h
(5 KB)
📄
lzcntintrin.h
(3.18 KB)
📄
mm3dnow.h
(4.5 KB)
📄
mm_malloc.h
(1.7 KB)
📄
mmintrin.h
(55.85 KB)
📄
module.modulemap
(3.33 KB)
📄
movdirintrin.h
(1.57 KB)
📄
msa.h
(25.01 KB)
📄
mwaitxintrin.h
(1.07 KB)
📄
nmmintrin.h
(580 B)
📄
opencl-c-base.h
(20.83 KB)
📄
opencl-c.h
(835.47 KB)
📁
openmp_wrappers
📄
pconfigintrin.h
(1.19 KB)
📄
pkuintrin.h
(934 B)
📄
pmmintrin.h
(10.09 KB)
📄
popcntintrin.h
(1.58 KB)
📁
ppc_wrappers
📄
prfchwintrin.h
(1.93 KB)
📁
profile
📄
ptwriteintrin.h
(1.05 KB)
📄
rdseedintrin.h
(1.16 KB)
📄
rtmintrin.h
(1.24 KB)
📄
s390intrin.h
(604 B)
📁
sanitizer
📄
serializeintrin.h
(881 B)
📄
sgxintrin.h
(1.77 KB)
📄
shaintrin.h
(1.87 KB)
📄
smmintrin.h
(98.76 KB)
📄
tbmintrin.h
(3.15 KB)
📄
tmmintrin.h
(29.37 KB)
📄
tsxldtrkintrin.h
(1.97 KB)
📄
vadefs.h
(1.39 KB)
📄
vaesintrin.h
(2.39 KB)
📄
vecintrin.h
(356.66 KB)
📄
vpclmulqdqintrin.h
(1 KB)
📄
waitpkgintrin.h
(1.33 KB)
📄
wasm_simd128.h
(45.99 KB)
📄
wbnoinvdintrin.h
(749 B)
📄
wmmintrin.h
(530 B)
📄
x86intrin.h
(1.67 KB)
📄
xmmintrin.h
(106.24 KB)
📄
xopintrin.h
(19.91 KB)
📁
xray
📄
xsavecintrin.h
(1010 B)
📄
xsaveintrin.h
(1.64 KB)
📄
xsaveoptintrin.h
(1 KB)
📄
xsavesintrin.h
(1.24 KB)
📄
xtestintrin.h
(873 B)
Editing: arm_fp16.h
/*===---- arm_fp16.h - ARM FP16 intrinsics ---------------------------------=== * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. * *===-----------------------------------------------------------------------=== */ #ifndef __ARM_FP16_H #define __ARM_FP16_H #include <stdint.h> typedef __fp16 float16_t; #define __ai static __inline__ __attribute__((__always_inline__, __nodebug__)) #if defined(__ARM_FEATURE_FP16_SCALAR_ARITHMETIC) && defined(__aarch64__) #define vabdh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vabdh_f16(__s0, __s1); \ __ret; \ }) #define vabsh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vabsh_f16(__s0); \ __ret; \ }) #define vaddh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vaddh_f16(__s0, __s1); \ __ret; \ }) #define vcageh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcageh_f16(__s0, __s1); \ __ret; \ }) #define vcagth_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcagth_f16(__s0, __s1); \ __ret; \ }) #define vcaleh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcaleh_f16(__s0, __s1); \ __ret; \ }) #define vcalth_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcalth_f16(__s0, __s1); \ __ret; \ }) #define vceqh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vceqh_f16(__s0, __s1); \ __ret; \ }) #define vceqzh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vceqzh_f16(__s0); \ __ret; \ }) #define vcgeh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcgeh_f16(__s0, __s1); \ __ret; \ }) #define vcgezh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcgezh_f16(__s0); \ __ret; \ }) #define vcgth_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcgth_f16(__s0, __s1); \ __ret; \ }) #define vcgtzh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcgtzh_f16(__s0); \ __ret; \ }) #define vcleh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcleh_f16(__s0, __s1); \ __ret; \ }) #define vclezh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vclezh_f16(__s0); \ __ret; \ }) #define vclth_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vclth_f16(__s0, __s1); \ __ret; \ }) #define vcltzh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcltzh_f16(__s0); \ __ret; \ }) #define vcvth_n_s16_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvth_n_s16_f16(__s0, __p1); \ __ret; \ }) #define vcvth_n_s32_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvth_n_s32_f16(__s0, __p1); \ __ret; \ }) #define vcvth_n_s64_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvth_n_s64_f16(__s0, __p1); \ __ret; \ }) #define vcvth_n_u16_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvth_n_u16_f16(__s0, __p1); \ __ret; \ }) #define vcvth_n_u32_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvth_n_u32_f16(__s0, __p1); \ __ret; \ }) #define vcvth_n_u64_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvth_n_u64_f16(__s0, __p1); \ __ret; \ }) #define vcvth_s16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvth_s16_f16(__s0); \ __ret; \ }) #define vcvth_s32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvth_s32_f16(__s0); \ __ret; \ }) #define vcvth_s64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvth_s64_f16(__s0); \ __ret; \ }) #define vcvth_u16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvth_u16_f16(__s0); \ __ret; \ }) #define vcvth_u32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvth_u32_f16(__s0); \ __ret; \ }) #define vcvth_u64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvth_u64_f16(__s0); \ __ret; \ }) #define vcvtah_s16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvtah_s16_f16(__s0); \ __ret; \ }) #define vcvtah_s32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvtah_s32_f16(__s0); \ __ret; \ }) #define vcvtah_s64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvtah_s64_f16(__s0); \ __ret; \ }) #define vcvtah_u16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvtah_u16_f16(__s0); \ __ret; \ }) #define vcvtah_u32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvtah_u32_f16(__s0); \ __ret; \ }) #define vcvtah_u64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvtah_u64_f16(__s0); \ __ret; \ }) #define vcvth_f16_u16(__p0) __extension__ ({ \ uint16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_u16(__s0); \ __ret; \ }) #define vcvth_f16_s16(__p0) __extension__ ({ \ int16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_s16(__s0); \ __ret; \ }) #define vcvth_f16_u32(__p0) __extension__ ({ \ uint32_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_u32(__s0); \ __ret; \ }) #define vcvth_f16_s32(__p0) __extension__ ({ \ int32_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_s32(__s0); \ __ret; \ }) #define vcvth_f16_u64(__p0) __extension__ ({ \ uint64_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_u64(__s0); \ __ret; \ }) #define vcvth_f16_s64(__p0) __extension__ ({ \ int64_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_f16_s64(__s0); \ __ret; \ }) #define vcvth_n_f16_u32(__p0, __p1) __extension__ ({ \ uint32_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_u32(__s0, __p1); \ __ret; \ }) #define vcvth_n_f16_s32(__p0, __p1) __extension__ ({ \ int32_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_s32(__s0, __p1); \ __ret; \ }) #define vcvth_n_f16_u64(__p0, __p1) __extension__ ({ \ uint64_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_u64(__s0, __p1); \ __ret; \ }) #define vcvth_n_f16_s64(__p0, __p1) __extension__ ({ \ int64_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_s64(__s0, __p1); \ __ret; \ }) #define vcvth_n_f16_u16(__p0, __p1) __extension__ ({ \ uint16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_u16(__s0, __p1); \ __ret; \ }) #define vcvth_n_f16_s16(__p0, __p1) __extension__ ({ \ int16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vcvth_n_f16_s16(__s0, __p1); \ __ret; \ }) #define vcvtmh_s16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvtmh_s16_f16(__s0); \ __ret; \ }) #define vcvtmh_s32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvtmh_s32_f16(__s0); \ __ret; \ }) #define vcvtmh_s64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvtmh_s64_f16(__s0); \ __ret; \ }) #define vcvtmh_u16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvtmh_u16_f16(__s0); \ __ret; \ }) #define vcvtmh_u32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvtmh_u32_f16(__s0); \ __ret; \ }) #define vcvtmh_u64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvtmh_u64_f16(__s0); \ __ret; \ }) #define vcvtnh_s16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvtnh_s16_f16(__s0); \ __ret; \ }) #define vcvtnh_s32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvtnh_s32_f16(__s0); \ __ret; \ }) #define vcvtnh_s64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvtnh_s64_f16(__s0); \ __ret; \ }) #define vcvtnh_u16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvtnh_u16_f16(__s0); \ __ret; \ }) #define vcvtnh_u32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvtnh_u32_f16(__s0); \ __ret; \ }) #define vcvtnh_u64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvtnh_u64_f16(__s0); \ __ret; \ }) #define vcvtph_s16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int16_t __ret; \ __ret = (int16_t) __builtin_neon_vcvtph_s16_f16(__s0); \ __ret; \ }) #define vcvtph_s32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int32_t __ret; \ __ret = (int32_t) __builtin_neon_vcvtph_s32_f16(__s0); \ __ret; \ }) #define vcvtph_s64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ int64_t __ret; \ __ret = (int64_t) __builtin_neon_vcvtph_s64_f16(__s0); \ __ret; \ }) #define vcvtph_u16_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint16_t __ret; \ __ret = (uint16_t) __builtin_neon_vcvtph_u16_f16(__s0); \ __ret; \ }) #define vcvtph_u32_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint32_t __ret; \ __ret = (uint32_t) __builtin_neon_vcvtph_u32_f16(__s0); \ __ret; \ }) #define vcvtph_u64_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ uint64_t __ret; \ __ret = (uint64_t) __builtin_neon_vcvtph_u64_f16(__s0); \ __ret; \ }) #define vdivh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vdivh_f16(__s0, __s1); \ __ret; \ }) #define vfmah_f16(__p0, __p1, __p2) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __s2 = __p2; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vfmah_f16(__s0, __s1, __s2); \ __ret; \ }) #define vfmsh_f16(__p0, __p1, __p2) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __s2 = __p2; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vfmsh_f16(__s0, __s1, __s2); \ __ret; \ }) #define vmaxh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vmaxh_f16(__s0, __s1); \ __ret; \ }) #define vmaxnmh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vmaxnmh_f16(__s0, __s1); \ __ret; \ }) #define vminh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vminh_f16(__s0, __s1); \ __ret; \ }) #define vminnmh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vminnmh_f16(__s0, __s1); \ __ret; \ }) #define vmulh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vmulh_f16(__s0, __s1); \ __ret; \ }) #define vmulxh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vmulxh_f16(__s0, __s1); \ __ret; \ }) #define vnegh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vnegh_f16(__s0); \ __ret; \ }) #define vrecpeh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrecpeh_f16(__s0); \ __ret; \ }) #define vrecpsh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrecpsh_f16(__s0, __s1); \ __ret; \ }) #define vrecpxh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrecpxh_f16(__s0); \ __ret; \ }) #define vrndh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndh_f16(__s0); \ __ret; \ }) #define vrndah_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndah_f16(__s0); \ __ret; \ }) #define vrndih_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndih_f16(__s0); \ __ret; \ }) #define vrndmh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndmh_f16(__s0); \ __ret; \ }) #define vrndnh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndnh_f16(__s0); \ __ret; \ }) #define vrndph_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndph_f16(__s0); \ __ret; \ }) #define vrndxh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrndxh_f16(__s0); \ __ret; \ }) #define vrsqrteh_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrsqrteh_f16(__s0); \ __ret; \ }) #define vrsqrtsh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vrsqrtsh_f16(__s0, __s1); \ __ret; \ }) #define vsqrth_f16(__p0) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vsqrth_f16(__s0); \ __ret; \ }) #define vsubh_f16(__p0, __p1) __extension__ ({ \ float16_t __s0 = __p0; \ float16_t __s1 = __p1; \ float16_t __ret; \ __ret = (float16_t) __builtin_neon_vsubh_f16(__s0, __s1); \ __ret; \ }) #endif #undef __ai #endif /* __ARM_FP16_H */
Upload File
Create Folder