| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 1 | /* tools/mkbootimg/bootimg.h | 
|  | 2 | ** | 
|  | 3 | ** Copyright 2007, The Android Open Source Project | 
|  | 4 | ** | 
|  | 5 | ** Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 6 | ** you may not use this file except in compliance with the License. | 
|  | 7 | ** You may obtain a copy of the License at | 
|  | 8 | ** | 
|  | 9 | **     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 10 | ** | 
|  | 11 | ** Unless required by applicable law or agreed to in writing, software | 
|  | 12 | ** distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 13 | ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 14 | ** See the License for the specific language governing permissions and | 
|  | 15 | ** limitations under the License. | 
|  | 16 | */ | 
|  | 17 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 18 | #include <stdint.h> | 
|  | 19 |  | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 20 | #ifndef _BOOT_IMAGE_H_ | 
|  | 21 | #define _BOOT_IMAGE_H_ | 
|  | 22 |  | 
|  | 23 | typedef struct boot_img_hdr boot_img_hdr; | 
|  | 24 |  | 
|  | 25 | #define BOOT_MAGIC "ANDROID!" | 
|  | 26 | #define BOOT_MAGIC_SIZE 8 | 
|  | 27 | #define BOOT_NAME_SIZE 16 | 
|  | 28 | #define BOOT_ARGS_SIZE 512 | 
| Andrew Boie | d35ce35 | 2013-08-21 15:48:40 -0700 | [diff] [blame] | 29 | #define BOOT_EXTRA_ARGS_SIZE 1024 | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 30 |  | 
|  | 31 | struct boot_img_hdr | 
|  | 32 | { | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 33 | uint8_t magic[BOOT_MAGIC_SIZE]; | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 34 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 35 | uint32_t kernel_size;  /* size in bytes */ | 
|  | 36 | uint32_t kernel_addr;  /* physical load addr */ | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 37 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 38 | uint32_t ramdisk_size; /* size in bytes */ | 
|  | 39 | uint32_t ramdisk_addr; /* physical load addr */ | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 40 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 41 | uint32_t second_size;  /* size in bytes */ | 
|  | 42 | uint32_t second_addr;  /* physical load addr */ | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 43 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 44 | uint32_t tags_addr;    /* physical addr for kernel tags */ | 
|  | 45 | uint32_t page_size;    /* flash page size we assume */ | 
| Sami Tolvanen | d162828 | 2016-03-14 09:08:59 -0700 | [diff] [blame] | 46 | uint32_t unused;       /* reserved for future expansion: MUST be 0 */ | 
|  | 47 |  | 
|  | 48 | /* operating system version and security patch level; for | 
|  | 49 | * version "A.B.C" and patch level "Y-M-D": | 
|  | 50 | * ver = A << 14 | B << 7 | C         (7 bits for each of A, B, C) | 
|  | 51 | * lvl = ((Y - 2000) & 127) << 4 | M  (7 bits for Y, 4 bits for M) | 
|  | 52 | * os_version = ver << 11 | lvl */ | 
|  | 53 | uint32_t os_version; | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 54 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 55 | uint8_t name[BOOT_NAME_SIZE]; /* asciiz product name */ | 
| Andrew Boie | d35ce35 | 2013-08-21 15:48:40 -0700 | [diff] [blame] | 56 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 57 | uint8_t cmdline[BOOT_ARGS_SIZE]; | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 58 |  | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 59 | uint32_t id[8]; /* timestamp / checksum / sha1 / etc */ | 
| Andrew Boie | d35ce35 | 2013-08-21 15:48:40 -0700 | [diff] [blame] | 60 |  | 
|  | 61 | /* Supplemental command line data; kept here to maintain | 
|  | 62 | * binary compatibility with older versions of mkbootimg */ | 
| Rom Lemarchand | dfff829 | 2015-05-07 14:08:31 -0700 | [diff] [blame] | 63 | uint8_t extra_cmdline[BOOT_EXTRA_ARGS_SIZE]; | 
|  | 64 | } __attribute__((packed)); | 
| The Android Open Source Project | dd7bc33 | 2009-03-03 19:32:55 -0800 | [diff] [blame] | 65 |  | 
|  | 66 | /* | 
|  | 67 | ** +-----------------+ | 
|  | 68 | ** | boot header     | 1 page | 
|  | 69 | ** +-----------------+ | 
|  | 70 | ** | kernel          | n pages | 
|  | 71 | ** +-----------------+ | 
|  | 72 | ** | ramdisk         | m pages | 
|  | 73 | ** +-----------------+ | 
|  | 74 | ** | second stage    | o pages | 
|  | 75 | ** +-----------------+ | 
|  | 76 | ** | 
|  | 77 | ** n = (kernel_size + page_size - 1) / page_size | 
|  | 78 | ** m = (ramdisk_size + page_size - 1) / page_size | 
|  | 79 | ** o = (second_size + page_size - 1) / page_size | 
|  | 80 | ** | 
|  | 81 | ** 0. all entities are page_size aligned in flash | 
|  | 82 | ** 1. kernel and ramdisk are required (size != 0) | 
|  | 83 | ** 2. second is optional (second_size == 0 -> no second) | 
|  | 84 | ** 3. load each element (kernel, ramdisk, second) at | 
|  | 85 | **    the specified physical address (kernel_addr, etc) | 
|  | 86 | ** 4. prepare tags at tag_addr.  kernel_args[] is | 
|  | 87 | **    appended to the kernel commandline in the tags. | 
|  | 88 | ** 5. r0 = 0, r1 = MACHINE_TYPE, r2 = tags_addr | 
|  | 89 | ** 6. if second_size != 0: jump to second_addr | 
|  | 90 | **    else: jump to kernel_addr | 
|  | 91 | */ | 
|  | 92 |  | 
|  | 93 | #if 0 | 
|  | 94 | typedef struct ptentry ptentry; | 
|  | 95 |  | 
|  | 96 | struct ptentry { | 
|  | 97 | char name[16];      /* asciiz partition name    */ | 
|  | 98 | unsigned start;     /* starting block number    */ | 
|  | 99 | unsigned length;    /* length in blocks         */ | 
|  | 100 | unsigned flags;     /* set to zero              */ | 
|  | 101 | }; | 
|  | 102 |  | 
|  | 103 | /* MSM Partition Table ATAG | 
|  | 104 | ** | 
|  | 105 | ** length: 2 + 7 * n | 
|  | 106 | ** atag:   0x4d534d70 | 
|  | 107 | **         <ptentry> x n | 
|  | 108 | */ | 
|  | 109 | #endif | 
|  | 110 |  | 
|  | 111 | #endif |