11 #define BOOT_MAGIC "ANDROID!"
12 #define BOOT_MAGIC_SIZE 8
13 #define BOOT_NAME_SIZE 16
14 #define BOOT_ARGS_SIZE 512
15 #define BOOT_EXTRA_ARGS_SIZE 1024
17 #define ADD_REMAINDER(val, aln) ((val) + ((aln) != 0 ? ((val) % (aln)) : 0))
18 #define ROUND_DOWN(val, aln) ((aln) != 0 ? (((val) / (aln)) * (aln)) : (val))
68 for (
i = 0;
i < 8;
i++) {
116 return bio ? bio->
bi.kernel_addr : 0;
152 return r > 12 && !strncmp((
const char *)
tmp,
"ANDROID!", 8);
170 ptr->
paddr = bi->page_size;
171 ptr->
vaddr = bi->kernel_addr;
195 ptr->
vsize = bi->page_size;
205 ptr->
size = bi->kernel_size;
207 ptr->
paddr = bi->page_size;
208 ptr->
vaddr = bi->kernel_addr;
212 if (bi->ramdisk_size > 0) {
213 ut64 base = bi->kernel_size + 2 * bi->page_size - 1;
218 ptr->
size = bi->ramdisk_size;
221 ptr->
vaddr = bi->ramdisk_addr;
226 if (bi->second_size > 0) {
227 ut64 base = bi->kernel_size + bi->ramdisk_size + 2 * bi->page_size - 1;
232 ptr->
size = bi->second_size;
235 ptr->
vaddr = bi->second_addr;
245 .desc =
"Android Boot Image",
259 #ifndef RZ_PLUGIN_INCORE
RZ_API RZ_OWN RzList * rz_bin_maps_of_file_sections(RZ_NONNULL RzBinFile *binfile)
Create a list of RzBinMap from RzBinSections queried from the given file.
static Sdb * get_sdb(RzBinFile *bf)
#define BOOT_EXTRA_ARGS_SIZE
struct boot_img_hdr BootImage
static int bootimg_header_load(BootImageObj *obj, Sdb *db)
static bool check_buffer(RzBuffer *buf)
static bool load_buffer(RzBinFile *bf, RzBinObject *obj, RzBuffer *buf, Sdb *sdb)
RZ_PACKED(struct boot_img_hdr { ut8 magic[BOOT_MAGIC_SIZE];ut32 kernel_size;ut32 kernel_addr;ut32 ramdisk_size;ut32 ramdisk_addr;ut32 second_size;ut32 second_addr;ut32 tags_addr;ut32 page_size;ut32 unused[2];ut8 name[BOOT_NAME_SIZE];ut8 cmdline[BOOT_ARGS_SIZE];ut32 id[8];ut8 extra_cmdline[BOOT_EXTRA_ARGS_SIZE];})
static RzList * strings(RzBinFile *bf)
static void destroy(RzBinFile *bf)
RZ_API RzLibStruct rizin_plugin
static RzBinInfo * info(RzBinFile *bf)
static ut64 baddr(RzBinFile *bf)
static RzList * entries(RzBinFile *bf)
RzBinPlugin rz_bin_plugin_bootimg
static RzList * sections(RzBinFile *bf)
#define ADD_REMAINDER(val, aln)
#define ROUND_DOWN(val, aln)
RZ_API void Ht_() free(HtName_(Ht) *ht)
RZ_API RZ_OWN RzList * rz_list_newf(RzListFree f)
Returns a new initialized RzList pointer and sets the free method.
RZ_API RZ_OWN RzList * rz_list_new(void)
Returns a new initialized RzList pointer (free method is not initialized)
RZ_API RZ_BORROW RzListIter * rz_list_append(RZ_NONNULL RzList *list, void *data)
Appends at the end of the list a new element.
return strdup("=SP r13\n" "=LR r14\n" "=PC r15\n" "=A0 r0\n" "=A1 r1\n" "=A2 r2\n" "=A3 r3\n" "=ZF zf\n" "=SF nf\n" "=OF vf\n" "=CF cf\n" "=SN or0\n" "gpr lr .32 56 0\n" "gpr pc .32 60 0\n" "gpr cpsr .32 64 0 ____tfiae_________________qvczn\n" "gpr or0 .32 68 0\n" "gpr tf .1 64.5 0 thumb\n" "gpr ef .1 64.9 0 endian\n" "gpr jf .1 64.24 0 java\n" "gpr qf .1 64.27 0 sticky_overflow\n" "gpr vf .1 64.28 0 overflow\n" "gpr cf .1 64.29 0 carry\n" "gpr zf .1 64.30 0 zero\n" "gpr nf .1 64.31 0 negative\n" "gpr itc .4 64.10 0 if_then_count\n" "gpr gef .4 64.16 0 great_or_equal\n" "gpr r0 .32 0 0\n" "gpr r1 .32 4 0\n" "gpr r2 .32 8 0\n" "gpr r3 .32 12 0\n" "gpr r4 .32 16 0\n" "gpr r5 .32 20 0\n" "gpr r6 .32 24 0\n" "gpr r7 .32 28 0\n" "gpr r8 .32 32 0\n" "gpr r9 .32 36 0\n" "gpr r10 .32 40 0\n" "gpr r11 .32 44 0\n" "gpr r12 .32 48 0\n" "gpr r13 .32 52 0\n" "gpr r14 .32 56 0\n" "gpr r15 .32 60 0\n" "gpr r16 .32 64 0\n" "gpr r17 .32 68 0\n")
RZ_API int sdb_ns_set(Sdb *s, const char *name, Sdb *r)
RZ_API int sdb_num_set(Sdb *s, const char *key, ut64 v, ut32 cas)
RZ_API RzBuffer * rz_buf_ref(RzBuffer *b)
Increment the reference count of the buffer.
RZ_API st64 rz_buf_read_at(RZ_NONNULL RzBuffer *b, ut64 addr, RZ_NONNULL RZ_OUT ut8 *buf, ut64 len)
Read len bytes of the buffer at the specified address.
RZ_API void rz_buf_free(RzBuffer *b)
Free all internal data hold by the buffer and the buffer.
RZ_API ut64 rz_buf_size(RZ_NONNULL RzBuffer *b)
Return the size of the buffer.
RZ_API char * rz_str_ndup(RZ_NULLABLE const char *ptr, int len)
Create new copy of string ptr limited to size len.
RZ_API int sdb_set(Sdb *s, const char *key, const char *val, ut32 cas)
RZ_API Sdb * sdb_new0(void)
XX curplugin == o->plugin.
ut64(WINAPI *w32_GetEnabledXStateFeatures)()