This application enables Android FastBoot on UEFI. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Olivier Martin <olivier.martin@arm.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15312 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
|   Copyright (c) 2013-2014, ARM Ltd. All rights reserved.<BR>
 | |
| 
 | |
|   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.
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "AndroidFastbootApp.h"
 | |
| 
 | |
| #define BOOT_MAGIC        "ANDROID!"
 | |
| #define BOOT_MAGIC_LENGTH sizeof (BOOT_MAGIC) - 1
 | |
| 
 | |
| // 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))
 | |
| 
 | |
| // No documentation for this really - sizes of fields has been determined
 | |
| // empirically.
 | |
| #pragma pack(1)
 | |
| typedef struct {
 | |
|   CHAR8   BootMagic[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[BOOTIMG_KERNEL_ARGS_SIZE];
 | |
|   UINT32  Id[32];
 | |
| } ANDROID_BOOTIMG_HEADER;
 | |
| #pragma pack()
 | |
| 
 | |
| // Find the kernel and ramdisk in an Android boot.img.
 | |
| // return EFI_INVALID_PARAMTER if the boot.img is invalid (i.e. doesn't have the
 | |
| //  right magic value),
 | |
| // return EFI_NOT_FOUND if there was no kernel in the boot.img.
 | |
| // Note that the Ramdisk is optional - *Ramdisk won't be touched if it isn't
 | |
| // present, but RamdiskSize will be set to 0.
 | |
| EFI_STATUS
 | |
| ParseAndroidBootImg (
 | |
|   IN  VOID    *BootImg,
 | |
|   OUT VOID   **Kernel,
 | |
|   OUT UINTN   *KernelSize,
 | |
|   OUT VOID   **Ramdisk,
 | |
|   OUT UINTN   *RamdiskSize,
 | |
|   OUT CHAR8   *KernelArgs
 | |
|   )
 | |
| {
 | |
|   ANDROID_BOOTIMG_HEADER   *Header;
 | |
|   UINT8                    *BootImgBytePtr;
 | |
| 
 | |
|   // Cast to UINT8 so we can do pointer arithmetic
 | |
|   BootImgBytePtr = (UINT8 *) BootImg;
 | |
| 
 | |
|   Header = (ANDROID_BOOTIMG_HEADER *) BootImg;
 | |
| 
 | |
|   if (AsciiStrnCmp (Header->BootMagic, BOOT_MAGIC, BOOT_MAGIC_LENGTH) != 0) {
 | |
|     return EFI_INVALID_PARAMETER;
 | |
|   }
 | |
| 
 | |
|   if (Header->KernelSize == 0) {
 | |
|     return EFI_NOT_FOUND;
 | |
|   }
 | |
| 
 | |
|   ASSERT (IS_POWER_OF_2 (Header->PageSize));
 | |
| 
 | |
|   *KernelSize = Header->KernelSize;
 | |
|   *Kernel = BootImgBytePtr + Header->PageSize;
 | |
|   *RamdiskSize = Header->RamdiskSize;
 | |
| 
 | |
|   if (Header->RamdiskSize != 0) {
 | |
|     *Ramdisk = (VOID *) (BootImgBytePtr
 | |
|                  + Header->PageSize
 | |
|                  + ALIGN_VALUE (Header->KernelSize, Header->PageSize));
 | |
|   }
 | |
| 
 | |
|   AsciiStrnCpy (KernelArgs, Header->KernelArgs, BOOTIMG_KERNEL_ARGS_SIZE);
 | |
| 
 | |
|   return EFI_SUCCESS;
 | |
| }
 |