RISC-V: vDSO: Wire up getrandom() vDSO implementation
authorXi Ruoyao <xry111@xry111.site>
Fri, 11 Apr 2025 02:46:00 +0000 (10:46 +0800)
committerPalmer Dabbelt <palmer@dabbelt.com>
Thu, 5 Jun 2025 21:03:09 +0000 (14:03 -0700)
commitee0d03053e7009a3a3532fb37f6c94bfa0a8cca3
tree34bf27155e35245602344027be5fb8acb7ced1e7
parenta869b8c29f864b9530a6473a30c09546333b571a
RISC-V: vDSO: Wire up getrandom() vDSO implementation

Hook up the generic vDSO implementation to the generic vDSO getrandom
implementation by providing the required __arch_chacha20_blocks_nostack
and getrandom_syscall implementations. Also wire up the selftests.

The benchmark result:

vdso: 25000000 times in 2.466341333 seconds
libc: 25000000 times in 41.447720005 seconds
syscall: 25000000 times in 41.043926672 seconds

vdso: 25000000 x 256 times in 162.286219353 seconds
libc: 25000000 x 256 times in 2953.855018685 seconds
syscall: 25000000 x 256 times in 2796.268546000 seconds

[ alex: - Fix dynamic relocation
        - Squash Nathan's fix https://lore.kernel.org/all/20250423-riscv-fix-compat_vdso-lld-v2-1-b7bbbc244501@kernel.org/
- Add comment from Loongarch ]

Signed-off-by: Xi Ruoyao <xry111@xry111.site>
Link: https://lore.kernel.org/r/20250411024600.16045-1-xry111@xry111.site
Tested-by: Alexandre Ghiti <alexghiti@rivosinc.com>
Signed-off-by: Alexandre Ghiti <alexghiti@rivosinc.com>
Signed-off-by: Palmer Dabbelt <palmer@dabbelt.com>
arch/riscv/Kconfig
arch/riscv/include/asm/vdso/getrandom.h [new file with mode: 0644]
arch/riscv/kernel/vdso/Makefile
arch/riscv/kernel/vdso/getrandom.c [new file with mode: 0644]
arch/riscv/kernel/vdso/vdso.lds.S
arch/riscv/kernel/vdso/vgetrandom-chacha.S [new file with mode: 0644]
tools/testing/selftests/vDSO/vgetrandom-chacha.S