[FFmpeg-devel] [PATCH] lavc/flacdsp: R-V Zvbb wasted33

Rémi Denis-Courmont remi at remlab.net
Thu Jun 6 19:04:52 EEST 2024


---
 libavcodec/riscv/Makefile       |  1 +
 libavcodec/riscv/flacdsp_init.c |  8 +++++++-
 libavcodec/riscv/flacdsp_rvvb.S | 35 +++++++++++++++++++++++++++++++++
 3 files changed, 43 insertions(+), 1 deletion(-)
 create mode 100644 libavcodec/riscv/flacdsp_rvvb.S

diff --git a/libavcodec/riscv/Makefile b/libavcodec/riscv/Makefile
index 590655f829..6c302b1a54 100644
--- a/libavcodec/riscv/Makefile
+++ b/libavcodec/riscv/Makefile
@@ -20,6 +20,7 @@ OBJS-$(CONFIG_EXR_DECODER) += riscv/exrdsp_init.o
 RVV-OBJS-$(CONFIG_EXR_DECODER) += riscv/exrdsp_rvv.o
 OBJS-$(CONFIG_FLAC_DECODER) += riscv/flacdsp_init.o
 RVV-OBJS-$(CONFIG_FLAC_DECODER) += riscv/flacdsp_rvv.o
+RVVB-OBJS-$(CONFIG_FLAC_DECODER) += riscv/flacdsp_rvvb.o
 OBJS-$(CONFIG_FMTCONVERT) += riscv/fmtconvert_init.o
 RVV-OBJS-$(CONFIG_FMTCONVERT) += riscv/fmtconvert_rvv.o
 OBJS-$(CONFIG_G722DSP) += riscv/g722dsp_init.o
diff --git a/libavcodec/riscv/flacdsp_init.c b/libavcodec/riscv/flacdsp_init.c
index 861276be28..49884b7d9f 100644
--- a/libavcodec/riscv/flacdsp_init.c
+++ b/libavcodec/riscv/flacdsp_init.c
@@ -35,6 +35,7 @@ void ff_flac_lpc33_rvv(int64_t *, const int32_t *, const int coeffs[32],
                        int pred_order, int qlevel, int len);
 void ff_flac_wasted32_rvv(int32_t *, int shift, int len);
 void ff_flac_wasted33_rvv(int64_t *, const int32_t *, int shift, int len);
+void ff_flac_wasted33_rvvb(int64_t *, const int32_t *, int shift, int len);
 void ff_flac_decorrelate_indep2_16_rvv(uint8_t **out, int32_t **in,
                                        int channels, int len, int shift);
 void ff_flac_decorrelate_indep4_16_rvv(uint8_t **out, int32_t **in,
@@ -89,8 +90,13 @@ av_cold void ff_flacdsp_init_riscv(FLACDSPContext *c, enum AVSampleFormat fmt,
 
         c->wasted32 = ff_flac_wasted32_rvv;
 
-        if (flags & AV_CPU_FLAG_RVV_I64)
+        if (flags & AV_CPU_FLAG_RVV_I64) {
             c->wasted33 = ff_flac_wasted33_rvv;
+# if HAVE_RV_ZVBB
+            if (flags & AV_CPU_FLAG_RV_ZVBB)
+                c->wasted33 = ff_flac_wasted33_rvvb;
+# endif
+        }
 
 # if (__riscv_xlen >= 64)
         switch (fmt) {
diff --git a/libavcodec/riscv/flacdsp_rvvb.S b/libavcodec/riscv/flacdsp_rvvb.S
new file mode 100644
index 0000000000..09c37d8936
--- /dev/null
+++ b/libavcodec/riscv/flacdsp_rvvb.S
@@ -0,0 +1,35 @@
+/*
+ * Copyright © 2024 Rémi Denis-Courmont.
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "libavutil/riscv/asm.S"
+
+func ff_flac_wasted33_rvvb, zve64x, zvbb
+1:
+        vsetvli  t0, a3, e32, m4, ta, ma
+        vle32.v  v8, (a1)
+        sub      a3, a3, t0
+        vwsll.vx v16, v8, a2
+        sh2add   a1, t0, a1
+        vse64.v  v16, (a0)
+        sh3add   a0, t0, a0
+        bnez     a3, 1b
+
+        ret
+endfunc
-- 
2.45.1



More information about the ffmpeg-devel mailing list