]> git.proxmox.com Git - mirror_edk2.git/blame - EmbeddedPkg/Application/AndroidFastboot/AndroidBootImg.c
UefiCpuPkg: Move AsmRelocateApLoopStart from Mpfuncs.nasm to AmdSev.nasm
[mirror_edk2.git] / EmbeddedPkg / Application / AndroidFastboot / AndroidBootImg.c
CommitLineData
f6755908
OM
1/** @file\r
2\r
3 Copyright (c) 2013-2014, ARM Ltd. All rights reserved.<BR>\r
4\r
878b807a 5 SPDX-License-Identifier: BSD-2-Clause-Patent\r
f6755908
OM
6\r
7**/\r
8\r
9#include "AndroidFastbootApp.h"\r
10\r
f6755908 11// Find the kernel and ramdisk in an Android boot.img.\r
c6a72cd7 12// return EFI_INVALID_PARAMETER if the boot.img is invalid (i.e. doesn't have the\r
f6755908
OM
13// right magic value),\r
14// return EFI_NOT_FOUND if there was no kernel in the boot.img.\r
15// Note that the Ramdisk is optional - *Ramdisk won't be touched if it isn't\r
16// present, but RamdiskSize will be set to 0.\r
17EFI_STATUS\r
18ParseAndroidBootImg (\r
e7108d0e 19 IN VOID *BootImg,\r
f6755908 20 OUT VOID **Kernel,\r
e7108d0e 21 OUT UINTN *KernelSize,\r
f6755908 22 OUT VOID **Ramdisk,\r
e7108d0e
MK
23 OUT UINTN *RamdiskSize,\r
24 OUT CHAR8 *KernelArgs\r
f6755908
OM
25 )\r
26{\r
e7108d0e
MK
27 ANDROID_BOOTIMG_HEADER *Header;\r
28 UINT8 *BootImgBytePtr;\r
f6755908
OM
29\r
30 // Cast to UINT8 so we can do pointer arithmetic\r
e7108d0e 31 BootImgBytePtr = (UINT8 *)BootImg;\r
f6755908 32\r
e7108d0e 33 Header = (ANDROID_BOOTIMG_HEADER *)BootImg;\r
f6755908 34\r
e7108d0e
MK
35 if (AsciiStrnCmp (\r
36 (CONST CHAR8 *)Header->BootMagic,\r
37 ANDROID_BOOT_MAGIC,\r
38 ANDROID_BOOT_MAGIC_LENGTH\r
39 ) != 0)\r
40 {\r
f6755908
OM
41 return EFI_INVALID_PARAMETER;\r
42 }\r
43\r
44 if (Header->KernelSize == 0) {\r
45 return EFI_NOT_FOUND;\r
46 }\r
47\r
6e414300 48 ASSERT (IS_VALID_ANDROID_PAGE_SIZE (Header->PageSize));\r
f6755908 49\r
e7108d0e
MK
50 *KernelSize = Header->KernelSize;\r
51 *Kernel = BootImgBytePtr + Header->PageSize;\r
f6755908
OM
52 *RamdiskSize = Header->RamdiskSize;\r
53\r
54 if (Header->RamdiskSize != 0) {\r
e7108d0e
MK
55 *Ramdisk = (VOID *)(BootImgBytePtr\r
56 + Header->PageSize\r
57 + ALIGN_VALUE (Header->KernelSize, Header->PageSize));\r
f6755908
OM
58 }\r
59\r
e7108d0e
MK
60 AsciiStrnCpyS (\r
61 KernelArgs,\r
62 ANDROID_BOOTIMG_KERNEL_ARGS_SIZE,\r
63 Header->KernelArgs,\r
64 ANDROID_BOOTIMG_KERNEL_ARGS_SIZE\r
65 );\r
f6755908
OM
66\r
67 return EFI_SUCCESS;\r
68}\r