| /*===---- riscv_vector.h - RISC-V V-extension RVVIntrinsics -------------------=== |
| * |
| * |
| * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| * See https://llvm.org/LICENSE.txt for license information. |
| * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| * |
| *===-----------------------------------------------------------------------=== |
| */ |
| |
| #ifndef __RISCV_VECTOR_H |
| #define __RISCV_VECTOR_H |
| |
| #include <stdint.h> |
| #include <stddef.h> |
| |
| #ifndef __riscv_vector |
| #error "Vector intrinsics require the vector extension." |
| #endif |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #pragma clang riscv intrinsic vector |
| |
| |
| enum __RISCV_FRM { |
| __RISCV_FRM_RNE = 0, |
| __RISCV_FRM_RTZ = 1, |
| __RISCV_FRM_RDN = 2, |
| __RISCV_FRM_RUP = 3, |
| __RISCV_FRM_RMM = 4, |
| }; |
| |
| #define __riscv_vlenb() __builtin_rvv_vlenb() |
| |
| #define __riscv_vsetvl_e8mf4(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 6) |
| #define __riscv_vsetvl_e8mf2(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 7) |
| #define __riscv_vsetvl_e8m1(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 0) |
| #define __riscv_vsetvl_e8m2(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 1) |
| #define __riscv_vsetvl_e8m4(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 2) |
| #define __riscv_vsetvl_e8m8(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 3) |
| |
| #define __riscv_vsetvl_e16mf2(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 7) |
| #define __riscv_vsetvl_e16m1(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 0) |
| #define __riscv_vsetvl_e16m2(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 1) |
| #define __riscv_vsetvl_e16m4(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 2) |
| #define __riscv_vsetvl_e16m8(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 3) |
| |
| #define __riscv_vsetvl_e32m1(avl) __builtin_rvv_vsetvli((size_t)(avl), 2, 0) |
| #define __riscv_vsetvl_e32m2(avl) __builtin_rvv_vsetvli((size_t)(avl), 2, 1) |
| #define __riscv_vsetvl_e32m4(avl) __builtin_rvv_vsetvli((size_t)(avl), 2, 2) |
| #define __riscv_vsetvl_e32m8(avl) __builtin_rvv_vsetvli((size_t)(avl), 2, 3) |
| |
| #if __riscv_v_elen >= 64 |
| #define __riscv_vsetvl_e8mf8(avl) __builtin_rvv_vsetvli((size_t)(avl), 0, 5) |
| #define __riscv_vsetvl_e16mf4(avl) __builtin_rvv_vsetvli((size_t)(avl), 1, 6) |
| #define __riscv_vsetvl_e32mf2(avl) __builtin_rvv_vsetvli((size_t)(avl), 2, 7) |
| |
| #define __riscv_vsetvl_e64m1(avl) __builtin_rvv_vsetvli((size_t)(avl), 3, 0) |
| #define __riscv_vsetvl_e64m2(avl) __builtin_rvv_vsetvli((size_t)(avl), 3, 1) |
| #define __riscv_vsetvl_e64m4(avl) __builtin_rvv_vsetvli((size_t)(avl), 3, 2) |
| #define __riscv_vsetvl_e64m8(avl) __builtin_rvv_vsetvli((size_t)(avl), 3, 3) |
| #endif |
| |
| #define __riscv_vsetvlmax_e8mf4() __builtin_rvv_vsetvlimax(0, 6) |
| #define __riscv_vsetvlmax_e8mf2() __builtin_rvv_vsetvlimax(0, 7) |
| #define __riscv_vsetvlmax_e8m1() __builtin_rvv_vsetvlimax(0, 0) |
| #define __riscv_vsetvlmax_e8m2() __builtin_rvv_vsetvlimax(0, 1) |
| #define __riscv_vsetvlmax_e8m4() __builtin_rvv_vsetvlimax(0, 2) |
| #define __riscv_vsetvlmax_e8m8() __builtin_rvv_vsetvlimax(0, 3) |
| |
| #define __riscv_vsetvlmax_e16mf2() __builtin_rvv_vsetvlimax(1, 7) |
| #define __riscv_vsetvlmax_e16m1() __builtin_rvv_vsetvlimax(1, 0) |
| #define __riscv_vsetvlmax_e16m2() __builtin_rvv_vsetvlimax(1, 1) |
| #define __riscv_vsetvlmax_e16m4() __builtin_rvv_vsetvlimax(1, 2) |
| #define __riscv_vsetvlmax_e16m8() __builtin_rvv_vsetvlimax(1, 3) |
| |
| #define __riscv_vsetvlmax_e32m1() __builtin_rvv_vsetvlimax(2, 0) |
| #define __riscv_vsetvlmax_e32m2() __builtin_rvv_vsetvlimax(2, 1) |
| #define __riscv_vsetvlmax_e32m4() __builtin_rvv_vsetvlimax(2, 2) |
| #define __riscv_vsetvlmax_e32m8() __builtin_rvv_vsetvlimax(2, 3) |
| |
| #if __riscv_v_elen >= 64 |
| #define __riscv_vsetvlmax_e8mf8() __builtin_rvv_vsetvlimax(0, 5) |
| #define __riscv_vsetvlmax_e16mf4() __builtin_rvv_vsetvlimax(1, 6) |
| #define __riscv_vsetvlmax_e32mf2() __builtin_rvv_vsetvlimax(2, 7) |
| |
| #define __riscv_vsetvlmax_e64m1() __builtin_rvv_vsetvlimax(3, 0) |
| #define __riscv_vsetvlmax_e64m2() __builtin_rvv_vsetvlimax(3, 1) |
| #define __riscv_vsetvlmax_e64m4() __builtin_rvv_vsetvlimax(3, 2) |
| #define __riscv_vsetvlmax_e64m8() __builtin_rvv_vsetvlimax(3, 3) |
| #endif |
| |
| |
| enum __RISCV_VXRM { |
| __RISCV_VXRM_RNU = 0, |
| __RISCV_VXRM_RNE = 1, |
| __RISCV_VXRM_RDN = 2, |
| __RISCV_VXRM_ROD = 3, |
| }; |
| typedef __rvv_bool64_t vbool64_t; |
| typedef __rvv_bool32_t vbool32_t; |
| typedef __rvv_bool16_t vbool16_t; |
| typedef __rvv_bool8_t vbool8_t; |
| typedef __rvv_bool4_t vbool4_t; |
| typedef __rvv_bool2_t vbool2_t; |
| typedef __rvv_bool1_t vbool1_t; |
| typedef __rvv_int8mf8_t vint8mf8_t; |
| typedef __rvv_uint8mf8_t vuint8mf8_t; |
| typedef __rvv_int8mf8x2_t vint8mf8x2_t; |
| typedef __rvv_uint8mf8x2_t vuint8mf8x2_t; |
| typedef __rvv_int8mf8x3_t vint8mf8x3_t; |
| typedef __rvv_uint8mf8x3_t vuint8mf8x3_t; |
| typedef __rvv_int8mf8x4_t vint8mf8x4_t; |
| typedef __rvv_uint8mf8x4_t vuint8mf8x4_t; |
| typedef __rvv_int8mf8x5_t vint8mf8x5_t; |
| typedef __rvv_uint8mf8x5_t vuint8mf8x5_t; |
| typedef __rvv_int8mf8x6_t vint8mf8x6_t; |
| typedef __rvv_uint8mf8x6_t vuint8mf8x6_t; |
| typedef __rvv_int8mf8x7_t vint8mf8x7_t; |
| typedef __rvv_uint8mf8x7_t vuint8mf8x7_t; |
| typedef __rvv_int8mf8x8_t vint8mf8x8_t; |
| typedef __rvv_uint8mf8x8_t vuint8mf8x8_t; |
| typedef __rvv_int8mf4_t vint8mf4_t; |
| typedef __rvv_uint8mf4_t vuint8mf4_t; |
| typedef __rvv_int8mf4x2_t vint8mf4x2_t; |
| typedef __rvv_uint8mf4x2_t vuint8mf4x2_t; |
| typedef __rvv_int8mf4x3_t vint8mf4x3_t; |
| typedef __rvv_uint8mf4x3_t vuint8mf4x3_t; |
| typedef __rvv_int8mf4x4_t vint8mf4x4_t; |
| typedef __rvv_uint8mf4x4_t vuint8mf4x4_t; |
| typedef __rvv_int8mf4x5_t vint8mf4x5_t; |
| typedef __rvv_uint8mf4x5_t vuint8mf4x5_t; |
| typedef __rvv_int8mf4x6_t vint8mf4x6_t; |
| typedef __rvv_uint8mf4x6_t vuint8mf4x6_t; |
| typedef __rvv_int8mf4x7_t vint8mf4x7_t; |
| typedef __rvv_uint8mf4x7_t vuint8mf4x7_t; |
| typedef __rvv_int8mf4x8_t vint8mf4x8_t; |
| typedef __rvv_uint8mf4x8_t vuint8mf4x8_t; |
| typedef __rvv_int8mf2_t vint8mf2_t; |
| typedef __rvv_uint8mf2_t vuint8mf2_t; |
| typedef __rvv_int8mf2x2_t vint8mf2x2_t; |
| typedef __rvv_uint8mf2x2_t vuint8mf2x2_t; |
| typedef __rvv_int8mf2x3_t vint8mf2x3_t; |
| typedef __rvv_uint8mf2x3_t vuint8mf2x3_t; |
| typedef __rvv_int8mf2x4_t vint8mf2x4_t; |
| typedef __rvv_uint8mf2x4_t vuint8mf2x4_t; |
| typedef __rvv_int8mf2x5_t vint8mf2x5_t; |
| typedef __rvv_uint8mf2x5_t vuint8mf2x5_t; |
| typedef __rvv_int8mf2x6_t vint8mf2x6_t; |
| typedef __rvv_uint8mf2x6_t vuint8mf2x6_t; |
| typedef __rvv_int8mf2x7_t vint8mf2x7_t; |
| typedef __rvv_uint8mf2x7_t vuint8mf2x7_t; |
| typedef __rvv_int8mf2x8_t vint8mf2x8_t; |
| typedef __rvv_uint8mf2x8_t vuint8mf2x8_t; |
| typedef __rvv_int8m1_t vint8m1_t; |
| typedef __rvv_uint8m1_t vuint8m1_t; |
| typedef __rvv_int8m1x2_t vint8m1x2_t; |
| typedef __rvv_uint8m1x2_t vuint8m1x2_t; |
| typedef __rvv_int8m1x3_t vint8m1x3_t; |
| typedef __rvv_uint8m1x3_t vuint8m1x3_t; |
| typedef __rvv_int8m1x4_t vint8m1x4_t; |
| typedef __rvv_uint8m1x4_t vuint8m1x4_t; |
| typedef __rvv_int8m1x5_t vint8m1x5_t; |
| typedef __rvv_uint8m1x5_t vuint8m1x5_t; |
| typedef __rvv_int8m1x6_t vint8m1x6_t; |
| typedef __rvv_uint8m1x6_t vuint8m1x6_t; |
| typedef __rvv_int8m1x7_t vint8m1x7_t; |
| typedef __rvv_uint8m1x7_t vuint8m1x7_t; |
| typedef __rvv_int8m1x8_t vint8m1x8_t; |
| typedef __rvv_uint8m1x8_t vuint8m1x8_t; |
| typedef __rvv_int8m2_t vint8m2_t; |
| typedef __rvv_uint8m2_t vuint8m2_t; |
| typedef __rvv_int8m2x2_t vint8m2x2_t; |
| typedef __rvv_uint8m2x2_t vuint8m2x2_t; |
| typedef __rvv_int8m2x3_t vint8m2x3_t; |
| typedef __rvv_uint8m2x3_t vuint8m2x3_t; |
| typedef __rvv_int8m2x4_t vint8m2x4_t; |
| typedef __rvv_uint8m2x4_t vuint8m2x4_t; |
| typedef __rvv_int8m4_t vint8m4_t; |
| typedef __rvv_uint8m4_t vuint8m4_t; |
| typedef __rvv_int8m4x2_t vint8m4x2_t; |
| typedef __rvv_uint8m4x2_t vuint8m4x2_t; |
| typedef __rvv_int8m8_t vint8m8_t; |
| typedef __rvv_uint8m8_t vuint8m8_t; |
| typedef __rvv_int16mf4_t vint16mf4_t; |
| typedef __rvv_uint16mf4_t vuint16mf4_t; |
| typedef __rvv_int16mf4x2_t vint16mf4x2_t; |
| typedef __rvv_uint16mf4x2_t vuint16mf4x2_t; |
| typedef __rvv_int16mf4x3_t vint16mf4x3_t; |
| typedef __rvv_uint16mf4x3_t vuint16mf4x3_t; |
| typedef __rvv_int16mf4x4_t vint16mf4x4_t; |
| typedef __rvv_uint16mf4x4_t vuint16mf4x4_t; |
| typedef __rvv_int16mf4x5_t vint16mf4x5_t; |
| typedef __rvv_uint16mf4x5_t vuint16mf4x5_t; |
| typedef __rvv_int16mf4x6_t vint16mf4x6_t; |
| typedef __rvv_uint16mf4x6_t vuint16mf4x6_t; |
| typedef __rvv_int16mf4x7_t vint16mf4x7_t; |
| typedef __rvv_uint16mf4x7_t vuint16mf4x7_t; |
| typedef __rvv_int16mf4x8_t vint16mf4x8_t; |
| typedef __rvv_uint16mf4x8_t vuint16mf4x8_t; |
| typedef __rvv_int16mf2_t vint16mf2_t; |
| typedef __rvv_uint16mf2_t vuint16mf2_t; |
| typedef __rvv_int16mf2x2_t vint16mf2x2_t; |
| typedef __rvv_uint16mf2x2_t vuint16mf2x2_t; |
| typedef __rvv_int16mf2x3_t vint16mf2x3_t; |
| typedef __rvv_uint16mf2x3_t vuint16mf2x3_t; |
| typedef __rvv_int16mf2x4_t vint16mf2x4_t; |
| typedef __rvv_uint16mf2x4_t vuint16mf2x4_t; |
| typedef __rvv_int16mf2x5_t vint16mf2x5_t; |
| typedef __rvv_uint16mf2x5_t vuint16mf2x5_t; |
| typedef __rvv_int16mf2x6_t vint16mf2x6_t; |
| typedef __rvv_uint16mf2x6_t vuint16mf2x6_t; |
| typedef __rvv_int16mf2x7_t vint16mf2x7_t; |
| typedef __rvv_uint16mf2x7_t vuint16mf2x7_t; |
| typedef __rvv_int16mf2x8_t vint16mf2x8_t; |
| typedef __rvv_uint16mf2x8_t vuint16mf2x8_t; |
| typedef __rvv_int16m1_t vint16m1_t; |
| typedef __rvv_uint16m1_t vuint16m1_t; |
| typedef __rvv_int16m1x2_t vint16m1x2_t; |
| typedef __rvv_uint16m1x2_t vuint16m1x2_t; |
| typedef __rvv_int16m1x3_t vint16m1x3_t; |
| typedef __rvv_uint16m1x3_t vuint16m1x3_t; |
| typedef __rvv_int16m1x4_t vint16m1x4_t; |
| typedef __rvv_uint16m1x4_t vuint16m1x4_t; |
| typedef __rvv_int16m1x5_t vint16m1x5_t; |
| typedef __rvv_uint16m1x5_t vuint16m1x5_t; |
| typedef __rvv_int16m1x6_t vint16m1x6_t; |
| typedef __rvv_uint16m1x6_t vuint16m1x6_t; |
| typedef __rvv_int16m1x7_t vint16m1x7_t; |
| typedef __rvv_uint16m1x7_t vuint16m1x7_t; |
| typedef __rvv_int16m1x8_t vint16m1x8_t; |
| typedef __rvv_uint16m1x8_t vuint16m1x8_t; |
| typedef __rvv_int16m2_t vint16m2_t; |
| typedef __rvv_uint16m2_t vuint16m2_t; |
| typedef __rvv_int16m2x2_t vint16m2x2_t; |
| typedef __rvv_uint16m2x2_t vuint16m2x2_t; |
| typedef __rvv_int16m2x3_t vint16m2x3_t; |
| typedef __rvv_uint16m2x3_t vuint16m2x3_t; |
| typedef __rvv_int16m2x4_t vint16m2x4_t; |
| typedef __rvv_uint16m2x4_t vuint16m2x4_t; |
| typedef __rvv_int16m4_t vint16m4_t; |
| typedef __rvv_uint16m4_t vuint16m4_t; |
| typedef __rvv_int16m4x2_t vint16m4x2_t; |
| typedef __rvv_uint16m4x2_t vuint16m4x2_t; |
| typedef __rvv_int16m8_t vint16m8_t; |
| typedef __rvv_uint16m8_t vuint16m8_t; |
| typedef __rvv_int32mf2_t vint32mf2_t; |
| typedef __rvv_uint32mf2_t vuint32mf2_t; |
| typedef __rvv_int32mf2x2_t vint32mf2x2_t; |
| typedef __rvv_uint32mf2x2_t vuint32mf2x2_t; |
| typedef __rvv_int32mf2x3_t vint32mf2x3_t; |
| typedef __rvv_uint32mf2x3_t vuint32mf2x3_t; |
| typedef __rvv_int32mf2x4_t vint32mf2x4_t; |
| typedef __rvv_uint32mf2x4_t vuint32mf2x4_t; |
| typedef __rvv_int32mf2x5_t vint32mf2x5_t; |
| typedef __rvv_uint32mf2x5_t vuint32mf2x5_t; |
| typedef __rvv_int32mf2x6_t vint32mf2x6_t; |
| typedef __rvv_uint32mf2x6_t vuint32mf2x6_t; |
| typedef __rvv_int32mf2x7_t vint32mf2x7_t; |
| typedef __rvv_uint32mf2x7_t vuint32mf2x7_t; |
| typedef __rvv_int32mf2x8_t vint32mf2x8_t; |
| typedef __rvv_uint32mf2x8_t vuint32mf2x8_t; |
| typedef __rvv_int32m1_t vint32m1_t; |
| typedef __rvv_uint32m1_t vuint32m1_t; |
| typedef __rvv_int32m1x2_t vint32m1x2_t; |
| typedef __rvv_uint32m1x2_t vuint32m1x2_t; |
| typedef __rvv_int32m1x3_t vint32m1x3_t; |
| typedef __rvv_uint32m1x3_t vuint32m1x3_t; |
| typedef __rvv_int32m1x4_t vint32m1x4_t; |
| typedef __rvv_uint32m1x4_t vuint32m1x4_t; |
| typedef __rvv_int32m1x5_t vint32m1x5_t; |
| typedef __rvv_uint32m1x5_t vuint32m1x5_t; |
| typedef __rvv_int32m1x6_t vint32m1x6_t; |
| typedef __rvv_uint32m1x6_t vuint32m1x6_t; |
| typedef __rvv_int32m1x7_t vint32m1x7_t; |
| typedef __rvv_uint32m1x7_t vuint32m1x7_t; |
| typedef __rvv_int32m1x8_t vint32m1x8_t; |
| typedef __rvv_uint32m1x8_t vuint32m1x8_t; |
| typedef __rvv_int32m2_t vint32m2_t; |
| typedef __rvv_uint32m2_t vuint32m2_t; |
| typedef __rvv_int32m2x2_t vint32m2x2_t; |
| typedef __rvv_uint32m2x2_t vuint32m2x2_t; |
| typedef __rvv_int32m2x3_t vint32m2x3_t; |
| typedef __rvv_uint32m2x3_t vuint32m2x3_t; |
| typedef __rvv_int32m2x4_t vint32m2x4_t; |
| typedef __rvv_uint32m2x4_t vuint32m2x4_t; |
| typedef __rvv_int32m4_t vint32m4_t; |
| typedef __rvv_uint32m4_t vuint32m4_t; |
| typedef __rvv_int32m4x2_t vint32m4x2_t; |
| typedef __rvv_uint32m4x2_t vuint32m4x2_t; |
| typedef __rvv_int32m8_t vint32m8_t; |
| typedef __rvv_uint32m8_t vuint32m8_t; |
| typedef __rvv_int64m1_t vint64m1_t; |
| typedef __rvv_uint64m1_t vuint64m1_t; |
| typedef __rvv_int64m1x2_t vint64m1x2_t; |
| typedef __rvv_uint64m1x2_t vuint64m1x2_t; |
| typedef __rvv_int64m1x3_t vint64m1x3_t; |
| typedef __rvv_uint64m1x3_t vuint64m1x3_t; |
| typedef __rvv_int64m1x4_t vint64m1x4_t; |
| typedef __rvv_uint64m1x4_t vuint64m1x4_t; |
| typedef __rvv_int64m1x5_t vint64m1x5_t; |
| typedef __rvv_uint64m1x5_t vuint64m1x5_t; |
| typedef __rvv_int64m1x6_t vint64m1x6_t; |
| typedef __rvv_uint64m1x6_t vuint64m1x6_t; |
| typedef __rvv_int64m1x7_t vint64m1x7_t; |
| typedef __rvv_uint64m1x7_t vuint64m1x7_t; |
| typedef __rvv_int64m1x8_t vint64m1x8_t; |
| typedef __rvv_uint64m1x8_t vuint64m1x8_t; |
| typedef __rvv_int64m2_t vint64m2_t; |
| typedef __rvv_uint64m2_t vuint64m2_t; |
| typedef __rvv_int64m2x2_t vint64m2x2_t; |
| typedef __rvv_uint64m2x2_t vuint64m2x2_t; |
| typedef __rvv_int64m2x3_t vint64m2x3_t; |
| typedef __rvv_uint64m2x3_t vuint64m2x3_t; |
| typedef __rvv_int64m2x4_t vint64m2x4_t; |
| typedef __rvv_uint64m2x4_t vuint64m2x4_t; |
| typedef __rvv_int64m4_t vint64m4_t; |
| typedef __rvv_uint64m4_t vuint64m4_t; |
| typedef __rvv_int64m4x2_t vint64m4x2_t; |
| typedef __rvv_uint64m4x2_t vuint64m4x2_t; |
| typedef __rvv_int64m8_t vint64m8_t; |
| typedef __rvv_uint64m8_t vuint64m8_t; |
| typedef __rvv_float16mf4_t vfloat16mf4_t; |
| typedef __rvv_float16mf4x2_t vfloat16mf4x2_t; |
| typedef __rvv_float16mf4x3_t vfloat16mf4x3_t; |
| typedef __rvv_float16mf4x4_t vfloat16mf4x4_t; |
| typedef __rvv_float16mf4x5_t vfloat16mf4x5_t; |
| typedef __rvv_float16mf4x6_t vfloat16mf4x6_t; |
| typedef __rvv_float16mf4x7_t vfloat16mf4x7_t; |
| typedef __rvv_float16mf4x8_t vfloat16mf4x8_t; |
| typedef __rvv_float16mf2_t vfloat16mf2_t; |
| typedef __rvv_float16mf2x2_t vfloat16mf2x2_t; |
| typedef __rvv_float16mf2x3_t vfloat16mf2x3_t; |
| typedef __rvv_float16mf2x4_t vfloat16mf2x4_t; |
| typedef __rvv_float16mf2x5_t vfloat16mf2x5_t; |
| typedef __rvv_float16mf2x6_t vfloat16mf2x6_t; |
| typedef __rvv_float16mf2x7_t vfloat16mf2x7_t; |
| typedef __rvv_float16mf2x8_t vfloat16mf2x8_t; |
| typedef __rvv_float16m1_t vfloat16m1_t; |
| typedef __rvv_float16m1x2_t vfloat16m1x2_t; |
| typedef __rvv_float16m1x3_t vfloat16m1x3_t; |
| typedef __rvv_float16m1x4_t vfloat16m1x4_t; |
| typedef __rvv_float16m1x5_t vfloat16m1x5_t; |
| typedef __rvv_float16m1x6_t vfloat16m1x6_t; |
| typedef __rvv_float16m1x7_t vfloat16m1x7_t; |
| typedef __rvv_float16m1x8_t vfloat16m1x8_t; |
| typedef __rvv_float16m2_t vfloat16m2_t; |
| typedef __rvv_float16m2x2_t vfloat16m2x2_t; |
| typedef __rvv_float16m2x3_t vfloat16m2x3_t; |
| typedef __rvv_float16m2x4_t vfloat16m2x4_t; |
| typedef __rvv_float16m4_t vfloat16m4_t; |
| typedef __rvv_float16m4x2_t vfloat16m4x2_t; |
| typedef __rvv_float16m8_t vfloat16m8_t; |
| typedef __rvv_float32mf2_t vfloat32mf2_t; |
| typedef __rvv_float32mf2x2_t vfloat32mf2x2_t; |
| typedef __rvv_float32mf2x3_t vfloat32mf2x3_t; |
| typedef __rvv_float32mf2x4_t vfloat32mf2x4_t; |
| typedef __rvv_float32mf2x5_t vfloat32mf2x5_t; |
| typedef __rvv_float32mf2x6_t vfloat32mf2x6_t; |
| typedef __rvv_float32mf2x7_t vfloat32mf2x7_t; |
| typedef __rvv_float32mf2x8_t vfloat32mf2x8_t; |
| typedef __rvv_float32m1_t vfloat32m1_t; |
| typedef __rvv_float32m1x2_t vfloat32m1x2_t; |
| typedef __rvv_float32m1x3_t vfloat32m1x3_t; |
| typedef __rvv_float32m1x4_t vfloat32m1x4_t; |
| typedef __rvv_float32m1x5_t vfloat32m1x5_t; |
| typedef __rvv_float32m1x6_t vfloat32m1x6_t; |
| typedef __rvv_float32m1x7_t vfloat32m1x7_t; |
| typedef __rvv_float32m1x8_t vfloat32m1x8_t; |
| typedef __rvv_float32m2_t vfloat32m2_t; |
| typedef __rvv_float32m2x2_t vfloat32m2x2_t; |
| typedef __rvv_float32m2x3_t vfloat32m2x3_t; |
| typedef __rvv_float32m2x4_t vfloat32m2x4_t; |
| typedef __rvv_float32m4_t vfloat32m4_t; |
| typedef __rvv_float32m4x2_t vfloat32m4x2_t; |
| typedef __rvv_float32m8_t vfloat32m8_t; |
| typedef __rvv_float64m1_t vfloat64m1_t; |
| typedef __rvv_float64m1x2_t vfloat64m1x2_t; |
| typedef __rvv_float64m1x3_t vfloat64m1x3_t; |
| typedef __rvv_float64m1x4_t vfloat64m1x4_t; |
| typedef __rvv_float64m1x5_t vfloat64m1x5_t; |
| typedef __rvv_float64m1x6_t vfloat64m1x6_t; |
| typedef __rvv_float64m1x7_t vfloat64m1x7_t; |
| typedef __rvv_float64m1x8_t vfloat64m1x8_t; |
| typedef __rvv_float64m2_t vfloat64m2_t; |
| typedef __rvv_float64m2x2_t vfloat64m2x2_t; |
| typedef __rvv_float64m2x3_t vfloat64m2x3_t; |
| typedef __rvv_float64m2x4_t vfloat64m2x4_t; |
| typedef __rvv_float64m4_t vfloat64m4_t; |
| typedef __rvv_float64m4x2_t vfloat64m4x2_t; |
| typedef __rvv_float64m8_t vfloat64m8_t; |
| #define __riscv_v_intrinsic_overloading 1 |
| |
| #ifdef __cplusplus |
| } |
| #endif // __cplusplus |
| #endif // __RISCV_VECTOR_H |