Message ID | 20230718185253.18927-1-remi@remlab.net |
---|---|
State | Accepted |
Commit | d3948e4db50666da05368d2bc84134fea2e20006 |
Headers | show |
Series | [FFmpeg-devel,1/3] swscale: inline ff_shuffle_bytes_3210_rvv | expand |
Context | Check | Description |
---|---|---|
yinshiyou/make_loongarch64 | success | Make finished |
yinshiyou/make_fate_loongarch64 | success | Make fate finished |
andriy/make_x86 | success | Make finished |
andriy/make_fate_x86 | success | Make fate finished |
diff --git a/libswscale/riscv/rgb2rgb_rvv.S b/libswscale/riscv/rgb2rgb_rvv.S index bbdfdbebbc..8f30d760cb 100644 --- a/libswscale/riscv/rgb2rgb_rvv.S +++ b/libswscale/riscv/rgb2rgb_rvv.S @@ -74,7 +74,24 @@ func ff_shuffle_bytes_3210_rvv, zve32x addi t2, a0, 1 addi t3, a0, 0 addi a0, a0, 3 - j 1b + srai a2, a2, 2 + li t4, 4 +1: + vsetvli t0, a2, e8, m1, ta, ma + sub a2, a2, t0 + vlse8.v v8, (a0), t4 + sh2add a0, t0, a0 + vlse8.v v9, (t1), t4 + sh2add t1, t0, t1 + vlse8.v v10, (t2), t4 + sh2add t2, t0, t2 + vlse8.v v11, (t3), t4 + sh2add t3, t0, t3 + vsseg4e8.v v8, (a1) + sh2add a1, t0, a1 + bnez a2, 1b + + ret endfunc func ff_interleave_bytes_rvv, zve32x