mirror of https://github.com/FFmpeg/FFmpeg.git
add_int16_128_c: 2390.5 add_int16_128_rvv_i32: 832.0 add_int16_rnd_width_c: 2390.2 add_int16_rnd_width_rvv_i32: 832.5release/7.0
parent
7e1cdc69fb
commit
424c8ceb08
5 changed files with 81 additions and 1 deletions
@ -0,0 +1,37 @@ |
|||||||
|
/*
|
||||||
|
* Copyright © 2023 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/attributes.h" |
||||||
|
#include "libavutil/cpu.h" |
||||||
|
#include "libavcodec/huffyuvdsp.h" |
||||||
|
|
||||||
|
void ff_add_int16_rvv(uint16_t *dst, const uint16_t *src, unsigned m, int w); |
||||||
|
|
||||||
|
av_cold void ff_huffyuvdsp_init_riscv(HuffYUVDSPContext *c, |
||||||
|
enum AVPixelFormat pix_fmt) |
||||||
|
{ |
||||||
|
#if HAVE_RVV |
||||||
|
int flags = av_get_cpu_flags(); |
||||||
|
|
||||||
|
if ((flags & AV_CPU_FLAG_RVV_I32) && (flags & AV_CPU_FLAG_RVB_ADDR)) |
||||||
|
c->add_int16 = ff_add_int16_rvv; |
||||||
|
#endif |
||||||
|
} |
@ -0,0 +1,37 @@ |
|||||||
|
/* |
||||||
|
* Copyright © 2023 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_add_int16_rvv, zve32x |
||||||
|
1: |
||||||
|
vsetvli t0, a3, e16, m8, ta, ma |
||||||
|
vle16.v v16, (a0) |
||||||
|
sub a3, a3, t0 |
||||||
|
vle16.v v24, (a1) |
||||||
|
sh1add a1, t0, a1 |
||||||
|
vadd.vv v16, v16, v24 |
||||||
|
vand.vx v16, v16, a2 |
||||||
|
vse16.v v16, (a0) |
||||||
|
sh1add a0, t0, a0 |
||||||
|
bnez a3, 1b |
||||||
|
|
||||||
|
ret |
||||||
|
endfunc |
Loading…
Reference in new issue