mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	If vboot successfully verifies a kernel, it will leave it in place and basically ready to boot. The zeropage table which is part of the x86 boot protocol is at the end of the kernel, though, instead of the beginning, and because the image is already in place there's no need to copy it around. This change refactors the code which implements the zboot command so that the configuration of the zeropage table and loading the pieces of the kernel into memory are done separately. Also, because the command line goes before the zeropage table in vboot which is somewhat incompatible with the normal protocol, where to put the command line is a now a parameter instead of being hard coded. Signed-off-by: Gabe Black <gabeblack@chromium.org>
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2002
 | |
|  * Daniel Engström, Omicron Ceti AB, daniel@omicron.se
 | |
|  *
 | |
|  * See file CREDITS for list of people who contributed to this
 | |
|  * project.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License as
 | |
|  * published by the Free Software Foundation; either version 2 of
 | |
|  * the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 | |
|  * MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_ZIMAGE_H_
 | |
| #define _ASM_ZIMAGE_H_
 | |
| 
 | |
| #include <asm/bootparam.h>
 | |
| #include <asm/e820.h>
 | |
| 
 | |
| /* linux i386 zImage/bzImage header. Offsets relative to
 | |
|  * the start of the image */
 | |
| 
 | |
| #define HEAP_FLAG           0x80
 | |
| #define BIG_KERNEL_FLAG     0x01
 | |
| 
 | |
| /* magic numbers */
 | |
| #define KERNEL_MAGIC        0xaa55
 | |
| #define KERNEL_V2_MAGIC     0x53726448
 | |
| #define COMMAND_LINE_MAGIC  0xA33F
 | |
| 
 | |
| /* limits */
 | |
| #define BZIMAGE_MAX_SIZE   15*1024*1024     /* 15MB */
 | |
| #define ZIMAGE_MAX_SIZE    512*1024         /* 512k */
 | |
| #define SETUP_MAX_SIZE     32768
 | |
| 
 | |
| #define SETUP_START_OFFSET 0x200
 | |
| #define BZIMAGE_LOAD_ADDR  0x100000
 | |
| #define ZIMAGE_LOAD_ADDR   0x10000
 | |
| 
 | |
| /* Implementation defined function to install an e820 map. */
 | |
| unsigned install_e820_map(unsigned max_entries, struct e820entry *);
 | |
| 
 | |
| struct boot_params *load_zimage(char *image, unsigned long kernel_size,
 | |
| 				void **load_address);
 | |
| int setup_zimage(struct boot_params *setup_base, char *cmd_line, int auto_boot,
 | |
| 		 unsigned long initrd_addr, unsigned long initrd_size);
 | |
| 
 | |
| void boot_zimage(void *setup_base, void *load_address);
 | |
| 
 | |
| #endif
 |