mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-23 00:20:52 -05:00
random: vDSO: reject unknown getrandom() flags
Like the getrandom() syscall, vDSO getrandom() must also reject unknown flags. [1] It would be possible to return -EINVAL from vDSO itself, but in the possible case that a new flag is added to getrandom() syscall in the future, it would be easier to get the behavior from the syscall, instead of erroring until the vDSO is extended to support the new flag or explicitly falling back. [1] Designing the API: Planning for Extension https://docs.kernel.org/process/adding-syscalls.html#designing-the-api-planning-for-extension Signed-off-by: Yann Droneaud <yann@droneaud.fr> [Jason: reworded commit message] Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
parent
dc1c8034e3
commit
28f5df210d
1 changed files with 4 additions and 0 deletions
|
@ -85,6 +85,10 @@ __cvdso_getrandom_data(const struct vdso_rng_data *rng_info, void *buffer, size_
|
||||||
if (unlikely(((unsigned long)opaque_state & ~PAGE_MASK) + sizeof(*state) > PAGE_SIZE))
|
if (unlikely(((unsigned long)opaque_state & ~PAGE_MASK) + sizeof(*state) > PAGE_SIZE))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
|
||||||
|
/* Handle unexpected flags by falling back to the kernel. */
|
||||||
|
if (unlikely(flags & ~(GRND_NONBLOCK | GRND_RANDOM | GRND_INSECURE)))
|
||||||
|
goto fallback_syscall;
|
||||||
|
|
||||||
/* If the caller passes the wrong size, which might happen due to CRIU, fallback. */
|
/* If the caller passes the wrong size, which might happen due to CRIU, fallback. */
|
||||||
if (unlikely(opaque_len != sizeof(*state)))
|
if (unlikely(opaque_len != sizeof(*state)))
|
||||||
goto fallback_syscall;
|
goto fallback_syscall;
|
||||||
|
|
Loading…
Reference in a new issue