mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
lavc/pixblockdsp: RISC-V V 16-bit get_pixels & get_pixels_unaligned
This commit is contained in:
parent
676b08cb70
commit
ebee25855a
@ -34,6 +34,8 @@ void ff_get_pixels_16_rvi(int16_t *block, const uint8_t *pixels,
|
||||
|
||||
void ff_get_pixels_8_rvv(int16_t *block, const uint8_t *pixels,
|
||||
ptrdiff_t stride);
|
||||
void ff_get_pixels_16_rvv(int16_t *block, const uint8_t *pixels,
|
||||
ptrdiff_t stride);
|
||||
|
||||
av_cold void ff_pixblockdsp_init_riscv(PixblockDSPContext *c,
|
||||
AVCodecContext *avctx,
|
||||
@ -50,7 +52,9 @@ av_cold void ff_pixblockdsp_init_riscv(PixblockDSPContext *c,
|
||||
|
||||
#if HAVE_RVV
|
||||
if ((cpu_flags & AV_CPU_FLAG_RVV_I32) && ff_get_rv_vlenb() >= 16) {
|
||||
if (!high_bit_depth)
|
||||
if (high_bit_depth)
|
||||
c->get_pixels_unaligned = c->get_pixels = ff_get_pixels_16_rvv;
|
||||
else
|
||||
c->get_pixels_unaligned = c->get_pixels = ff_get_pixels_8_rvv;
|
||||
}
|
||||
#endif
|
||||
|
@ -35,3 +35,10 @@ func ff_get_pixels_8_rvv, zve32x
|
||||
vsseg8e16.v v8, (a0)
|
||||
ret
|
||||
endfunc
|
||||
|
||||
func ff_get_pixels_16_rvv, zve32x
|
||||
vsetivli zero, 8, e16, m1, ta, ma
|
||||
vlsseg8e16.v v0, (a1), a2
|
||||
vsseg8e16.v v0, (a0)
|
||||
ret
|
||||
endfunc
|
||||
|
Loading…
Reference in New Issue
Block a user