mirror of
https://github.com/librempeg/librempeg
synced 2024-11-22 18:49:58 +00:00
lavu/riscv: add CPU flag for B bit manipulations
The B extension was finally ratified in May 2024, encompassing: - Zba (addresses), - Zbb (basics) and - Zbs (single bits). It does not include Zbc (base-2 polynomials). Signed-off-by: Paul B Mahol <onemda@gmail.com>
This commit is contained in:
parent
323adda36d
commit
a113208ab0
@ -2,6 +2,9 @@ The last version increases of all libraries were on 2024-03-07
|
|||||||
|
|
||||||
API changes, most recent first:
|
API changes, most recent first:
|
||||||
|
|
||||||
|
2024-07-25 - xxxxxxxxx - lavu 59.29.100 - cpu.h
|
||||||
|
Add AV_CPU_FLAG_RVB.
|
||||||
|
|
||||||
2024-07-xx - xxxxxxxxxx - lavf 61 - avformat.h
|
2024-07-xx - xxxxxxxxxx - lavf 61 - avformat.h
|
||||||
Deprecate avformat_transfer_internal_stream_timing_info()
|
Deprecate avformat_transfer_internal_stream_timing_info()
|
||||||
and av_stream_get_codec_timebase() without replacement.
|
and av_stream_get_codec_timebase() without replacement.
|
||||||
|
@ -186,6 +186,7 @@ int av_parse_cpu_caps(unsigned *flags, const char *s)
|
|||||||
{ "rvi", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVI }, .unit = "flags" },
|
{ "rvi", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVI }, .unit = "flags" },
|
||||||
{ "rvf", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVF }, .unit = "flags" },
|
{ "rvf", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVF }, .unit = "flags" },
|
||||||
{ "rvd", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVD }, .unit = "flags" },
|
{ "rvd", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVD }, .unit = "flags" },
|
||||||
|
{ "rvb", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVB }, .unit = "flags" },
|
||||||
{ "zve32x", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_I32 }, .unit = "flags" },
|
{ "zve32x", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_I32 }, .unit = "flags" },
|
||||||
{ "zve32f", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_F32 }, .unit = "flags" },
|
{ "zve32f", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_F32 }, .unit = "flags" },
|
||||||
{ "zve64x", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_I64 }, .unit = "flags" },
|
{ "zve64x", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_RVV_I64 }, .unit = "flags" },
|
||||||
|
@ -92,6 +92,7 @@
|
|||||||
#define AV_CPU_FLAG_RVB_ADDR (1 << 8) ///< Address bit-manipulations
|
#define AV_CPU_FLAG_RVB_ADDR (1 << 8) ///< Address bit-manipulations
|
||||||
#define AV_CPU_FLAG_RV_ZVBB (1 << 9) ///< Vector basic bit-manipulations
|
#define AV_CPU_FLAG_RV_ZVBB (1 << 9) ///< Vector basic bit-manipulations
|
||||||
#define AV_CPU_FLAG_RV_MISALIGNED (1 <<10) ///< Fast misaligned accesses
|
#define AV_CPU_FLAG_RV_MISALIGNED (1 <<10) ///< Fast misaligned accesses
|
||||||
|
#define AV_CPU_FLAG_RVB (1 <<11) ///< B (bit manipulations)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the flags which specify extensions supported by the CPU.
|
* Return the flags which specify extensions supported by the CPU.
|
||||||
|
@ -72,6 +72,12 @@ int ff_get_cpu_flags_riscv(void)
|
|||||||
#ifdef RISCV_HWPROBE_EXT_ZBB
|
#ifdef RISCV_HWPROBE_EXT_ZBB
|
||||||
if (pairs[1].value & RISCV_HWPROBE_EXT_ZBB)
|
if (pairs[1].value & RISCV_HWPROBE_EXT_ZBB)
|
||||||
ret |= AV_CPU_FLAG_RVB_BASIC;
|
ret |= AV_CPU_FLAG_RVB_BASIC;
|
||||||
|
#if defined (RISCV_HWPROBE_EXT_ZBA) && defined (RISCV_HWPROBE_EXT_ZBS)
|
||||||
|
if ((pairs[1].value & RISCV_HWPROBE_EXT_ZBA) &&
|
||||||
|
(pairs[1].value & RISCV_HWPROBE_EXT_ZBB) &&
|
||||||
|
(pairs[1].value & RISCV_HWPROBE_EXT_ZBS))
|
||||||
|
ret |= AV_CPU_FLAG_RVB;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#ifdef RISCV_HWPROBE_EXT_ZVBB
|
#ifdef RISCV_HWPROBE_EXT_ZVBB
|
||||||
if (pairs[1].value & RISCV_HWPROBE_EXT_ZVBB)
|
if (pairs[1].value & RISCV_HWPROBE_EXT_ZVBB)
|
||||||
@ -94,6 +100,9 @@ int ff_get_cpu_flags_riscv(void)
|
|||||||
ret |= AV_CPU_FLAG_RVF;
|
ret |= AV_CPU_FLAG_RVF;
|
||||||
if (hwcap & HWCAP_RV('D'))
|
if (hwcap & HWCAP_RV('D'))
|
||||||
ret |= AV_CPU_FLAG_RVD;
|
ret |= AV_CPU_FLAG_RVD;
|
||||||
|
if (hwcap & HWCAP_RV('B'))
|
||||||
|
ret |= AV_CPU_FLAG_RVB_ADDR | AV_CPU_FLAG_RVB_BASIC |
|
||||||
|
AV_CPU_FLAG_RVB;
|
||||||
|
|
||||||
/* The V extension implies all Zve* functional subsets */
|
/* The V extension implies all Zve* functional subsets */
|
||||||
if (hwcap & HWCAP_RV('V'))
|
if (hwcap & HWCAP_RV('V'))
|
||||||
@ -118,6 +127,10 @@ int ff_get_cpu_flags_riscv(void)
|
|||||||
#ifdef __riscv_zbb
|
#ifdef __riscv_zbb
|
||||||
ret |= AV_CPU_FLAG_RVB_BASIC;
|
ret |= AV_CPU_FLAG_RVB_BASIC;
|
||||||
#endif
|
#endif
|
||||||
|
#if defined (__riscv_b) || \
|
||||||
|
(defined (__riscv_zba) && defined (__riscv_zbb) && defined (__riscv_zbs))
|
||||||
|
ret |= AV_CPU_FLAG_RVB;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* If RV-V is enabled statically at compile-time, check the details. */
|
/* If RV-V is enabled statically at compile-time, check the details. */
|
||||||
#ifdef __riscv_vector
|
#ifdef __riscv_vector
|
||||||
|
@ -90,6 +90,7 @@ static const struct {
|
|||||||
{ AV_CPU_FLAG_RVD, "rvd" },
|
{ AV_CPU_FLAG_RVD, "rvd" },
|
||||||
{ AV_CPU_FLAG_RVB_ADDR, "zba" },
|
{ AV_CPU_FLAG_RVB_ADDR, "zba" },
|
||||||
{ AV_CPU_FLAG_RVB_BASIC, "zbb" },
|
{ AV_CPU_FLAG_RVB_BASIC, "zbb" },
|
||||||
|
{ AV_CPU_FLAG_RVB, "rvb" },
|
||||||
{ AV_CPU_FLAG_RVV_I32, "zve32x" },
|
{ AV_CPU_FLAG_RVV_I32, "zve32x" },
|
||||||
{ AV_CPU_FLAG_RVV_F32, "zve32f" },
|
{ AV_CPU_FLAG_RVV_F32, "zve32f" },
|
||||||
{ AV_CPU_FLAG_RVV_I64, "zve64x" },
|
{ AV_CPU_FLAG_RVV_I64, "zve64x" },
|
||||||
|
@ -79,7 +79,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_MAJOR 59
|
#define LIBAVUTIL_VERSION_MAJOR 59
|
||||||
#define LIBAVUTIL_VERSION_MINOR 28
|
#define LIBAVUTIL_VERSION_MINOR 29
|
||||||
#define LIBAVUTIL_VERSION_MICRO 100
|
#define LIBAVUTIL_VERSION_MICRO 100
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
||||||
|
@ -295,6 +295,7 @@ static const struct {
|
|||||||
{ "RVD", "rvd", AV_CPU_FLAG_RVD },
|
{ "RVD", "rvd", AV_CPU_FLAG_RVD },
|
||||||
{ "RVBaddr", "rvb_a", AV_CPU_FLAG_RVB_ADDR },
|
{ "RVBaddr", "rvb_a", AV_CPU_FLAG_RVB_ADDR },
|
||||||
{ "RVBbasic", "rvb_b", AV_CPU_FLAG_RVB_BASIC },
|
{ "RVBbasic", "rvb_b", AV_CPU_FLAG_RVB_BASIC },
|
||||||
|
{ "RVB", "rvb", AV_CPU_FLAG_RVB },
|
||||||
{ "RVVi32", "rvv_i32", AV_CPU_FLAG_RVV_I32 },
|
{ "RVVi32", "rvv_i32", AV_CPU_FLAG_RVV_I32 },
|
||||||
{ "RVVf32", "rvv_f32", AV_CPU_FLAG_RVV_F32 },
|
{ "RVVf32", "rvv_f32", AV_CPU_FLAG_RVV_F32 },
|
||||||
{ "RVVi64", "rvv_i64", AV_CPU_FLAG_RVV_I64 },
|
{ "RVVi64", "rvv_i64", AV_CPU_FLAG_RVV_I64 },
|
||||||
|
Loading…
Reference in New Issue
Block a user