mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-01 00:58:39 +02:00 
			
		
		
		
	binfmt_flat: prevent kernel dammage from corrupted executable headers
Signed-off-by: Nicolas Pitre <nico@linaro.org> Signed-off-by: Greg Ungerer <gerg@linux-m68k.org>
This commit is contained in:
		
							parent
							
								
									4adbb6ac4b
								
							
						
					
					
						commit
						c995ee28d2
					
				
					 1 changed files with 11 additions and 0 deletions
				
			
		|  | @ -465,6 +465,17 @@ static int load_flat_file(struct linux_binprm *bprm, | ||||||
| 		goto err; | 		goto err; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	/*
 | ||||||
|  | 	 * Make sure the header params are sane. | ||||||
|  | 	 * 28 bits (256 MB) is way more than reasonable in this case. | ||||||
|  | 	 * If some top bits are set we have probable binary corruption. | ||||||
|  | 	*/ | ||||||
|  | 	if ((text_len | data_len | bss_len | stack_len | full_data) >> 28) { | ||||||
|  | 		pr_err("bad header\n"); | ||||||
|  | 		ret = -ENOEXEC; | ||||||
|  | 		goto err; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	/*
 | 	/*
 | ||||||
| 	 * fix up the flags for the older format,  there were all kinds | 	 * fix up the flags for the older format,  there were all kinds | ||||||
| 	 * of endian hacks,  this only works for the simple cases | 	 * of endian hacks,  this only works for the simple cases | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Nicolas Pitre
						Nicolas Pitre