diff options
author | Rémi Denis-Courmont <remi@remlab.net> | 2022-10-04 20:17:16 +0300 |
---|---|---|
committer | Lynne <dev@lynne.ee> | 2022-10-05 06:51:11 +0200 |
commit | 64ab5779547628b032a3b68713dddbeca0c0686f (patch) | |
tree | a4c76df2397efe4fa95b5d3ffe686e5cb0997c9f /libavcodec | |
parent | 23411e6dcd3e610ac59cf6967c89115bcccb8d2e (diff) | |
download | ffmpeg-64ab5779547628b032a3b68713dddbeca0c0686f.tar.gz |
lavc/alacdsp: RISC-V V decorrelate_stereo
To avoid data dependencies, this does the following unroll, which
requires one extra but probably free addition:
coeff = (b * left_weight) >> decorr_shift;
b += a;
a -= coeff;
b -= coeff;
swap(a, b);
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/alacdsp.c | 4 | ||||
-rw-r--r-- | libavcodec/alacdsp.h | 1 | ||||
-rw-r--r-- | libavcodec/riscv/Makefile | 2 | ||||
-rw-r--r-- | libavcodec/riscv/alacdsp_init.c | 39 | ||||
-rw-r--r-- | libavcodec/riscv/alacdsp_rvv.S | 46 |
5 files changed, 91 insertions, 1 deletions
diff --git a/libavcodec/alacdsp.c b/libavcodec/alacdsp.c index b033a27970..a604566afb 100644 --- a/libavcodec/alacdsp.c +++ b/libavcodec/alacdsp.c @@ -58,7 +58,9 @@ av_cold void ff_alacdsp_init(ALACDSPContext *c) c->append_extra_bits[0] = c->append_extra_bits[1] = append_extra_bits; -#if ARCH_X86 +#if ARCH_RISCV + ff_alacdsp_init_riscv(c); +#elif ARCH_X86 ff_alacdsp_init_x86(c); #endif } diff --git a/libavcodec/alacdsp.h b/libavcodec/alacdsp.h index f8b56dd5dc..489ebc6704 100644 --- a/libavcodec/alacdsp.h +++ b/libavcodec/alacdsp.h @@ -29,6 +29,7 @@ typedef struct ALACDSPContext { } ALACDSPContext; void ff_alacdsp_init(ALACDSPContext *c); +void ff_alacdsp_init_riscv(ALACDSPContext *c); void ff_alacdsp_init_x86(ALACDSPContext *c); #endif /* AVCODEC_ALACDSP_H */ diff --git a/libavcodec/riscv/Makefile b/libavcodec/riscv/Makefile index 0fb2c81c75..81f4b985ac 100644 --- a/libavcodec/riscv/Makefile +++ b/libavcodec/riscv/Makefile @@ -1,5 +1,7 @@ OBJS-$(CONFIG_AAC_DECODER) += riscv/aacpsdsp_init.o RVV-OBJS-$(CONFIG_AAC_DECODER) += riscv/aacpsdsp_rvv.o +OBJS-$(CONFIG_ALAC_DECODER) += riscv/alacdsp_init.o +RVV-OBJS-$(CONFIG_ALAC_DECODER) += riscv/alacdsp_rvv.o OBJS-$(CONFIG_AUDIODSP) += riscv/audiodsp_init.o \ riscv/audiodsp_rvf.o RVV-OBJS-$(CONFIG_AUDIODSP) += riscv/audiodsp_rvv.o diff --git a/libavcodec/riscv/alacdsp_init.c b/libavcodec/riscv/alacdsp_init.c new file mode 100644 index 0000000000..9ddebaa60b --- /dev/null +++ b/libavcodec/riscv/alacdsp_init.c @@ -0,0 +1,39 @@ +/* + * Copyright © 2022 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 <stdint.h> + +#include "libavutil/attributes.h" +#include "libavutil/cpu.h" +#include "libavcodec/avcodec.h" +#include "libavcodec/alacdsp.h" + +void ff_alac_decorrelate_stereo_rvv(int32_t *buffer[2], int nb_samples, + int decorr_shift, int decorr_left_weight); + +av_cold void ff_alacdsp_init_riscv(ALACDSPContext *c) +{ +#if HAVE_RVV && (__riscv_xlen == 64) + int flags = av_get_cpu_flags(); + + if (flags & AV_CPU_FLAG_RVV_I32) + c->decorrelate_stereo = ff_alac_decorrelate_stereo_rvv; +#endif +} diff --git a/libavcodec/riscv/alacdsp_rvv.S b/libavcodec/riscv/alacdsp_rvv.S new file mode 100644 index 0000000000..5d75d6f2f9 --- /dev/null +++ b/libavcodec/riscv/alacdsp_rvv.S @@ -0,0 +1,46 @@ +/* + * Copyright © 2022 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 "config.h" +#include "libavutil/riscv/asm.S" + +#if (__riscv_xlen == 64) +func ff_alac_decorrelate_stereo_rvv, zve32x + ld a4, 8(a0) + ld a0, 0(a0) +1: + vsetvli t0, a1, e32, m1, ta, ma + vle32.v v24, (a4) + sub a1, a1, t0 + vle32.v v16, (a0) + vmul.vx v8, v24, a3 + vadd.vv v24, v24, v16 + vsra.vx v8, v8, a2 + vsub.vv v16, v16, v8 + vsub.vv v24, v24, v8 + vse32.v v16, (a4) + sh2add a4, t0, a4 + vse32.v v24, (a0) + sh2add a0, t0, a0 + bnez a1, 1b + + ret +endfunc +#endif |