mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-21 23:10:13 +00:00
lavc/riscv: vset macro for simplify if-else
This commit is contained in:
parent
952508ae05
commit
6b31e42c47
@ -20,88 +20,46 @@
|
|||||||
|
|
||||||
#include "libavutil/riscv/asm.S"
|
#include "libavutil/riscv/asm.S"
|
||||||
|
|
||||||
.macro vsetvlstatic8 w, vlen
|
.macro vsetvlstatic w, vlen, en, mn1, mn2, mn3, mn4, mn5, mn6
|
||||||
.if \w == 2 && \vlen == 128
|
.if \w == 2 && \vlen == 128
|
||||||
vsetivli zero, \w, e8, mf8, ta, ma
|
vsetivli zero, \w, \en, \mn1, ta, ma
|
||||||
.elseif \w <= 4 && \vlen == 128
|
.elseif \w <= 4 && \vlen == 128
|
||||||
vsetivli zero, \w, e8, mf4, ta, ma
|
vsetivli zero, \w, \en, \mn2, ta, ma
|
||||||
.elseif \w <= 8 && \vlen == 128
|
.elseif \w <= 8 && \vlen == 128
|
||||||
vsetivli zero, \w, e8, mf2, ta, ma
|
vsetivli zero, \w, \en, \mn3, ta, ma
|
||||||
.elseif \w <= 16 && \vlen == 128
|
.elseif \w <= 16 && \vlen == 128
|
||||||
vsetivli zero, \w, e8, m1, ta, ma
|
vsetivli zero, \w, \en, \mn4, ta, ma
|
||||||
.elseif \w <= 32 && \vlen == 128
|
.elseif \w <= 32 && \vlen == 128
|
||||||
li t0, \w
|
li t0, \w
|
||||||
vsetvli zero, t0, e8, m2, ta, ma
|
vsetvli zero, t0, \en, \mn5, ta, ma
|
||||||
.elseif \w <= 4 && \vlen == 256
|
.elseif \w <= 4 && \vlen == 256
|
||||||
vsetivli zero, \w, e8, mf8, ta, ma
|
vsetivli zero, \w, \en, \mn1, ta, ma
|
||||||
.elseif \w <= 8 && \vlen == 256
|
.elseif \w <= 8 && \vlen == 256
|
||||||
vsetivli zero, \w, e8, mf4, ta, ma
|
vsetivli zero, \w, \en, \mn2, ta, ma
|
||||||
.elseif \w <= 16 && \vlen == 256
|
.elseif \w <= 16 && \vlen == 256
|
||||||
vsetivli zero, \w, e8, mf2, ta, ma
|
vsetivli zero, \w, \en, \mn3, ta, ma
|
||||||
.elseif \w <= 32 && \vlen == 256
|
.elseif \w <= 32 && \vlen == 256
|
||||||
li t0, \w
|
li t0, \w
|
||||||
vsetvli zero, t0, e8, m1, ta, ma
|
vsetvli zero, t0, \en, \mn4, ta, ma
|
||||||
.elseif \w <= 64 && \vlen == 256
|
.elseif \w <= 64 && \vlen == 256
|
||||||
li t0, \w
|
li t0, \w
|
||||||
vsetvli zero, t0, e8, m2, ta, ma
|
vsetvli zero, t0, \en, \mn5, ta, ma
|
||||||
.else
|
.else
|
||||||
li t0, \w
|
li t0, \w
|
||||||
vsetvli zero, t0, e8, m4, ta, ma
|
vsetvli zero, t0, \en, \mn6, ta, ma
|
||||||
.endif
|
.endif
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
.macro vsetvlstatic8 w, vlen
|
||||||
|
vsetvlstatic \w, \vlen, e8, mf8, mf4, mf2, m1, m2, m4
|
||||||
|
.endm
|
||||||
|
|
||||||
.macro vsetvlstatic16 w, vlen
|
.macro vsetvlstatic16 w, vlen
|
||||||
.if \w == 2 && \vlen == 128
|
vsetvlstatic \w, \vlen, e16, mf4, mf2, m1, m2, m4, m8
|
||||||
vsetivli zero, \w, e16, mf4, ta, ma
|
|
||||||
.elseif \w <= 4 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e16, mf2, ta, ma
|
|
||||||
.elseif \w <= 8 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e16, m1, ta, ma
|
|
||||||
.elseif \w <= 16 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e16, m2, ta, ma
|
|
||||||
.elseif \w <= 32 && \vlen == 128
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e16, m4, ta, ma
|
|
||||||
.elseif \w <= 4 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e16, mf4, ta, ma
|
|
||||||
.elseif \w <= 8 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e16, mf2, ta, ma
|
|
||||||
.elseif \w <= 16 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e16, m1, ta, ma
|
|
||||||
.elseif \w <= 32 && \vlen == 256
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e16, m2, ta, ma
|
|
||||||
.elseif \w <= 64 && \vlen == 256
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e16, m4, ta, ma
|
|
||||||
.else
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e16, m8, ta, ma
|
|
||||||
.endif
|
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro vsetvlstatic32 w, vlen
|
.macro vsetvlstatic32 w, vlen
|
||||||
.if \w == 2
|
vsetvlstatic \w, \vlen, e32, mf2, m1, m2, m4, m8, m8
|
||||||
vsetivli zero, \w, e32, mf2, ta, ma
|
|
||||||
.elseif \w <= 4 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e32, m1, ta, ma
|
|
||||||
.elseif \w <= 8 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e32, m2, ta, ma
|
|
||||||
.elseif \w <= 16 && \vlen == 128
|
|
||||||
vsetivli zero, \w, e32, m4, ta, ma
|
|
||||||
.elseif \w <= 4 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e32, mf2, ta, ma
|
|
||||||
.elseif \w <= 8 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e32, m1, ta, ma
|
|
||||||
.elseif \w <= 16 && \vlen == 256
|
|
||||||
vsetivli zero, \w, e32, m2, ta, ma
|
|
||||||
.elseif \w <= 32 && \vlen == 256
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e32, m4, ta, ma
|
|
||||||
.else
|
|
||||||
li t0, \w
|
|
||||||
vsetvli zero, t0, e32, m8, ta, ma
|
|
||||||
.endif
|
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro POW2_JMP_TABLE id, vlen
|
.macro POW2_JMP_TABLE id, vlen
|
||||||
|
Loading…
Reference in New Issue
Block a user