// SPDX-License-Identifier: GPL-2.0-only /* * Copyright (C) 2024 Xi Ruoyao . All Rights Reserved. */ #ifndef __ASM_VDSO_GETRANDOM_H #define __ASM_VDSO_GETRANDOM_H #ifndef __ASSEMBLY__ #include #include static __always_inline ssize_t getrandom_syscall(void *_buffer, size_t _len, unsigned int _flags) { register long ret asm("a0"); register long nr asm("a7") = __NR_getrandom; register void *buffer asm("a0") = _buffer; register size_t len asm("a1") = _len; register unsigned int flags asm("a2") = _flags; asm volatile( " syscall 0\n" : "+r" (ret) : "r" (nr), "r" (buffer), "r" (len), "r" (flags) : "$t0", "$t1", "$t2", "$t3", "$t4", "$t5", "$t6", "$t7", "$t8", "memory"); return ret; } static __always_inline const struct vdso_rng_data *__arch_get_vdso_rng_data(void) { return (const struct vdso_rng_data *)(get_vdso_data() + VVAR_LOONGARCH_PAGES_START * PAGE_SIZE + offsetof(struct loongarch_vdso_data, rng_data)); } #endif /* !__ASSEMBLY__ */ #endif /* __ASM_VDSO_GETRANDOM_H */