mirror of
https://github.com/rd-stuffs/msm-4.14.git
synced 2025-02-20 11:45:48 +08:00
binfmt_elf: Use get_random_int() to fix entropy depleting
Changes: -------- v4->v3: - s/random_stack_user()/get_atrandom_bytes()/ - Move this function to ahead of its use to avoid the predeclaration. v3->v2: - Tweak code comments of random_stack_user(). - Remove redundant bits mask and shift upon the random variable. v2->v1: - Fix random copy to check up buffer length that are not 4-byte multiples. v3 can be found at: http://www.spinics.net/lists/linux-fsdevel/msg59597.html v2 can be found at: http://www.spinics.net/lists/linux-fsdevel/msg59418.html v1 can be found at: http://www.spinics.net/lists/linux-fsdevel/msg59128.html Thanks, -Jeff Entropy is quickly depleted under normal operations like ls(1), cat(1), etc... between 2.6.30 to current mainline, for instance: $ cat /proc/sys/kernel/random/entropy_avail 3428 $ cat /proc/sys/kernel/random/entropy_avail 2911 $cat /proc/sys/kernel/random/entropy_avail 2620 We observed this problem has been occurring since 2.6.30 with fs/binfmt_elf.c: create_elf_tables()->get_random_bytes(), introduced by f06295b44c296c8f ("ELF: implement AT_RANDOM for glibc PRNG seeding"). /* * Generate 16 random bytes for userspace PRNG seeding. */ get_random_bytes(k_rand_bytes, sizeof(k_rand_bytes)); The patch introduces a wrapper around get_random_int() which has lower overhead than calling get_random_bytes() directly. With this patch applied: $ cat /proc/sys/kernel/random/entropy_avail 2731 $ cat /proc/sys/kernel/random/entropy_avail 2802 $ cat /proc/sys/kernel/random/entropy_avail 2878 Analyzed by John Sobecki. Signed-off-by: Jie Liu <jeff.liu@oracle.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Andreas Dilger <aedilger@gmail.com> Cc: Alan Cox <alan@linux.intel.com> Cc: Arnd Bergmann <arnn@arndb.de> Cc: John Sobecki <john.sobecki@oracle.com> Cc: James Morris <james.l.morris@oracle.com> Cc: Jakub Jelinek <jakub@redhat.com> Cc: Ted Ts'o <tytso@mit.edu> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Kees Cook <keescook@chromium.org> Cc: Ulrich Drepper <drepper@redhat.com> Signed-off-by: Alex Naidis <alex.naidis@linux.com>
This commit is contained in:
parent
69a4259154
commit
406cbc0149
@ -156,6 +156,25 @@ static int padzero(unsigned long elf_bss)
|
||||
#define ELF_BASE_PLATFORM NULL
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Use get_random_int() to implement AT_RANDOM while avoiding depletion
|
||||
* of the entropy pool.
|
||||
*/
|
||||
static void get_atrandom_bytes(unsigned char *buf, size_t nbytes)
|
||||
{
|
||||
unsigned char *p = buf;
|
||||
|
||||
while (nbytes) {
|
||||
unsigned int random_variable;
|
||||
size_t chunk = min(nbytes, sizeof(random_variable));
|
||||
|
||||
random_variable = get_random_int();
|
||||
memcpy(p, &random_variable, chunk);
|
||||
p += chunk;
|
||||
nbytes -= chunk;
|
||||
}
|
||||
}
|
||||
|
||||
static int
|
||||
create_elf_tables(struct linux_binprm *bprm, struct elfhdr *exec,
|
||||
unsigned long load_addr, unsigned long interp_load_addr)
|
||||
@ -215,7 +234,7 @@ create_elf_tables(struct linux_binprm *bprm, struct elfhdr *exec,
|
||||
/*
|
||||
* Generate 16 random bytes for userspace PRNG seeding.
|
||||
*/
|
||||
get_random_bytes(k_rand_bytes, sizeof(k_rand_bytes));
|
||||
get_atrandom_bytes(k_rand_bytes, sizeof(k_rand_bytes));
|
||||
u_rand_bytes = (elf_addr_t __user *)
|
||||
STACK_ALLOC(p, sizeof(k_rand_bytes));
|
||||
if (__copy_to_user(u_rand_bytes, k_rand_bytes, sizeof(k_rand_bytes)))
|
||||
|
Loading…
x
Reference in New Issue
Block a user