Add an android kernel loader that could load kernel from storage device. This android boot image BDS add addtitional cmdline/dtb/ramfs support besides kernel that is introduced by Android boot header. This patch is derived from Haojian's code as below link. https://patches.linaro.org/patch/94683/ Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Jun Nie <jun.nie@linaro.org> Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
|   Copyright (c) 2013-2014, ARM Ltd. All rights reserved.<BR>
 | |
|   Copyright (c) 2017, Linaro.
 | |
| 
 | |
|   This program and the accompanying materials
 | |
|   are licensed and made available under the terms and conditions of the BSD License
 | |
|   which accompanies this distribution.  The full text of the license may be found at
 | |
|   http://opensource.org/licenses/bsd-license.php
 | |
| 
 | |
|   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | |
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef __ABOOTIMG_H__
 | |
| #define __ABOOTIMG_H__
 | |
| 
 | |
| #include <Library/BaseLib.h>
 | |
| #include <Library/DebugLib.h>
 | |
| #include <Library/MemoryAllocationLib.h>
 | |
| 
 | |
| #include <Uefi/UefiBaseType.h>
 | |
| #include <Uefi/UefiSpec.h>
 | |
| 
 | |
| #define ANDROID_BOOTIMG_KERNEL_ARGS_SIZE  512
 | |
| 
 | |
| #define ANDROID_BOOT_MAGIC                "ANDROID!"
 | |
| #define ANDROID_BOOT_MAGIC_LENGTH         (sizeof (ANDROID_BOOT_MAGIC) - 1)
 | |
| 
 | |
| // No documentation for this really - sizes of fields has been determined
 | |
| // empirically.
 | |
| #pragma pack(1)
 | |
| /* https://android.googlesource.com/platform/system/core/+/master/mkbootimg/bootimg.h */
 | |
| typedef struct {
 | |
|   UINT8   BootMagic[ANDROID_BOOT_MAGIC_LENGTH];
 | |
|   UINT32  KernelSize;
 | |
|   UINT32  KernelAddress;
 | |
|   UINT32  RamdiskSize;
 | |
|   UINT32  RamdiskAddress;
 | |
|   UINT32  SecondStageBootloaderSize;
 | |
|   UINT32  SecondStageBootloaderAddress;
 | |
|   UINT32  KernelTaggsAddress;
 | |
|   UINT32  PageSize;
 | |
|   UINT32  Reserved[2];
 | |
|   CHAR8   ProductName[16];
 | |
|   CHAR8   KernelArgs[ANDROID_BOOTIMG_KERNEL_ARGS_SIZE];
 | |
|   UINT32  Id[32];
 | |
| } ANDROID_BOOTIMG_HEADER;
 | |
| #pragma pack ()
 | |
| 
 | |
| /* Check Val (unsigned) is a power of 2 (has only one bit set) */
 | |
| #define IS_POWER_OF_2(Val)       ((Val) != 0 && (((Val) & ((Val) - 1)) == 0))
 | |
| /* Android boot image page size is not specified, but it should be power of 2
 | |
|  * and larger than boot header */
 | |
| #define IS_VALID_ANDROID_PAGE_SIZE(Val)   \
 | |
|              (IS_POWER_OF_2(Val) && (Val > sizeof(ANDROID_BOOTIMG_HEADER)))
 | |
| 
 | |
| EFI_STATUS
 | |
| AndroidBootImgGetImgSize (
 | |
|   IN  VOID    *BootImg,
 | |
|   OUT UINTN   *ImgSize
 | |
|   );
 | |
| 
 | |
| EFI_STATUS
 | |
| AndroidBootImgBoot (
 | |
|   IN VOID                   *Buffer,
 | |
|   IN UINTN                   BufferSize
 | |
|   );
 | |
| 
 | |
| #endif /* __ABOOTIMG_H__ */
 |