|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "libavutil/cpu.h" |
|
#include "libavutil/cpu_internal.h" |
|
#include "libavutil/log.h" |
|
#include "config.h" |
|
|
|
#if HAVE_GETAUXVAL |
|
#include <sys/auxv.h> |
|
#define HWCAP_RV(letter) (1ul << ((letter) - 'A')) |
|
#endif |
|
|
|
int ff_get_cpu_flags_riscv(void) |
|
{ |
|
int ret = 0; |
|
#if HAVE_GETAUXVAL |
|
const unsigned long hwcap = getauxval(AT_HWCAP); |
|
|
|
if (hwcap & HWCAP_RV('I')) |
|
ret |= AV_CPU_FLAG_RVI; |
|
if (hwcap & HWCAP_RV('F')) |
|
ret |= AV_CPU_FLAG_RVF; |
|
if (hwcap & HWCAP_RV('D')) |
|
ret |= AV_CPU_FLAG_RVD; |
|
if (hwcap & HWCAP_RV('B')) |
|
ret |= AV_CPU_FLAG_RVB_ADDR | AV_CPU_FLAG_RVB_BASIC; |
|
|
|
|
|
if (hwcap & HWCAP_RV('V')) |
|
ret |= AV_CPU_FLAG_RVV_I32 | AV_CPU_FLAG_RVV_I64 |
|
| AV_CPU_FLAG_RVV_F32 | AV_CPU_FLAG_RVV_F64; |
|
#endif |
|
|
|
#ifdef __riscv_i |
|
ret |= AV_CPU_FLAG_RVI; |
|
#endif |
|
#if defined (__riscv_flen) && (__riscv_flen >= 32) |
|
ret |= AV_CPU_FLAG_RVF; |
|
#if (__riscv_flen >= 64) |
|
ret |= AV_CPU_FLAG_RVD; |
|
#endif |
|
#endif |
|
|
|
#ifdef __riscv_zba |
|
ret |= AV_CPU_FLAG_RVB_ADDR; |
|
#endif |
|
#ifdef __riscv_zbb |
|
ret |= AV_CPU_FLAG_RVB_BASIC; |
|
#endif |
|
|
|
|
|
#ifdef __riscv_vectors |
|
ret |= AV_CPU_FLAG_RVV_I32; |
|
#if __riscv_v_elen >= 64 |
|
ret |= AV_CPU_FLAG_RVV_I64; |
|
#endif |
|
#if __riscv_v_elen_fp >= 32 |
|
ret |= AV_CPU_FLAG_RVV_F32; |
|
#if __riscv_v_elen_fp >= 64 |
|
ret |= AV_CPU_FLAG_RVV_F64; |
|
#endif |
|
#endif |
|
#endif |
|
|
|
return ret; |
|
} |
|
|