forked from mirrors/linux
		
	x86/elf: Remove the unnecessary ADDR_NO_RANDOMIZE checks
The ADDR_NO_RANDOMIZE checks in stack_maxrandom_size() and randomize_stack_top() are not required. PF_RANDOMIZE is set by load_elf_binary() only if ADDR_NO_RANDOMIZE is not set, no need to re-check after that. Signed-off-by: Oleg Nesterov <oleg@redhat.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Dmitry Safonov <dsafonov@virtuozzo.com> Cc: stable@vger.kernel.org Cc: Andy Lutomirski <luto@amacapital.net> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Borislav Petkov <bp@suse.de> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: "Kirill A. Shutemov" <kirill.shutemov@linux.intel.com> Link: http://lkml.kernel.org/r/20170815154011.GB1076@redhat.com
This commit is contained in:
		
							parent
							
								
									47ac5484fd
								
							
						
					
					
						commit
						01578e3616
					
				
					 2 changed files with 2 additions and 4 deletions
				
			
		| 
						 | 
					@ -50,8 +50,7 @@ unsigned long tasksize_64bit(void)
 | 
				
			||||||
static unsigned long stack_maxrandom_size(unsigned long task_size)
 | 
					static unsigned long stack_maxrandom_size(unsigned long task_size)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	unsigned long max = 0;
 | 
						unsigned long max = 0;
 | 
				
			||||||
	if ((current->flags & PF_RANDOMIZE) &&
 | 
						if (current->flags & PF_RANDOMIZE) {
 | 
				
			||||||
		!(current->personality & ADDR_NO_RANDOMIZE)) {
 | 
					 | 
				
			||||||
		max = (-1UL) & __STACK_RND_MASK(task_size == tasksize_32bit());
 | 
							max = (-1UL) & __STACK_RND_MASK(task_size == tasksize_32bit());
 | 
				
			||||||
		max <<= PAGE_SHIFT;
 | 
							max <<= PAGE_SHIFT;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -664,8 +664,7 @@ static unsigned long randomize_stack_top(unsigned long stack_top)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	unsigned long random_variable = 0;
 | 
						unsigned long random_variable = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((current->flags & PF_RANDOMIZE) &&
 | 
						if (current->flags & PF_RANDOMIZE) {
 | 
				
			||||||
		!(current->personality & ADDR_NO_RANDOMIZE)) {
 | 
					 | 
				
			||||||
		random_variable = get_random_long();
 | 
							random_variable = get_random_long();
 | 
				
			||||||
		random_variable &= STACK_RND_MASK;
 | 
							random_variable &= STACK_RND_MASK;
 | 
				
			||||||
		random_variable <<= PAGE_SHIFT;
 | 
							random_variable <<= PAGE_SHIFT;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue