mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-03 05:10:03 +02:00
lavc/vp8dsp: fix RV32 stack alignment
SP must be a multiple of 16 bytes at all times on POSIX - even in leaf functions - so that signal handlers have a properly aligned stack.
This commit is contained in:
parent
60b1750134
commit
896c22ef00
@ -457,14 +457,14 @@ endfunc
|
||||
.macro epel_hv len hsize vsize
|
||||
func ff_put_vp8_epel\len\()_h\hsize\()v\vsize\()_rvv, zve32x
|
||||
#if __riscv_xlen == 64
|
||||
addi sp, sp, -48
|
||||
addi sp, sp, -48
|
||||
.irp n,0,1,2,3,4,5
|
||||
sd s\n, \n\()<<3(sp)
|
||||
sd s\n, (\n * 8)(sp)
|
||||
.endr
|
||||
#else
|
||||
addi sp, sp, -24
|
||||
addi sp, sp, -32
|
||||
.irp n,0,1,2,3,4,5
|
||||
sw s\n, \n\()<<2(sp)
|
||||
sw s\n, (\n * 4)(sp)
|
||||
.endr
|
||||
#endif
|
||||
sub a2, a2, a3
|
||||
@ -506,14 +506,14 @@ func ff_put_vp8_epel\len\()_h\hsize\()v\vsize\()_rvv, zve32x
|
||||
|
||||
#if __riscv_xlen == 64
|
||||
.irp n,0,1,2,3,4,5
|
||||
ld s\n, \n\()<<3(sp)
|
||||
ld s\n, (\n * 8)(sp)
|
||||
.endr
|
||||
addi sp, sp, 48
|
||||
addi sp, sp, 48
|
||||
#else
|
||||
.irp n,0,1,2,3,4,5
|
||||
lw s\n, \n\()<<2(sp)
|
||||
lw s\n, (\n * 4)(sp)
|
||||
.endr
|
||||
addi sp, sp, 24
|
||||
addi sp, sp, 32
|
||||
#endif
|
||||
|
||||
ret
|
||||
|
Loading…
Reference in New Issue
Block a user