解包Android的boot.img

2023-05-16

我們知道Adnroid的Boot.img包其實就是就是把kernel和ramdisk.img再加一個page的頭碼成的。其結構就如下所示


/*
** +-----------------+ 
** | boot header     | 1 page
** +-----------------+
** | kernel          | n pages  
** +-----------------+
** | ramdisk         | m pages  
** +-----------------+
** | second stage    | o pages
** +-----------------+
**
** n = (kernel_size + page_size - 1) / page_size
** m = (ramdisk_size + page_size - 1) / page_size
** o = (second_size + page_size - 1) / page_size
**
** 0. all entities are page_size aligned in flash
** 1. kernel and ramdisk are required (size != 0)
** 2. second is optional (second_size == 0 -> no second)
** 3. load each element (kernel, ramdisk, second) at
**    the specified physical address (kernel_addr, etc)
** 4. prepare tags at tag_addr.  kernel_args[] is
**    appended to the kernel commandline in the tags.
** 5. r0 = 0, r1 = MACHINE_TYPE, r2 = tags_addr
** 6. if second_size != 0: jump to second_addr
**    else: jump to kernel_addr
*/  

參考android的mkbootfs的源碼和網上的一些資料寫了一個解壓boot.img的程序。代碼實在是太丑了。寫得有點急,就只管功能了~大笑(大神繞過)

費話不說,上代碼。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>

//#include "mincrypt/sha.h"
//typedef struct boot_img_hdr boot_img_hdr;

#define BOOT_MAGIC "ANDROID!"
#define BOOT_MAGIC_SIZE 8
#define BOOT_NAME_SIZE 16
#define BOOT_ARGS_SIZE 512



struct boot_img_hdr
{
	unsigned char magic[BOOT_MAGIC_SIZE];
	
	unsigned kernel_size;
	unsigned kernel_addr;
	
	unsigned ramdisk_size;
	unsigned ramdisk_addr;
	
	unsigned second_size;
	unsigned second_addr;
	
	unsigned tags_addr;
	unsigned page_size;
	unsigned unused[2];
	
	unsigned char name[BOOT_NAME_SIZE];
	unsigned char cmdline[BOOT_ARGS_SIZE];

	unsigned id[8];

};


static void *load_file(const char *fname)
{
	int fd;
	int img_size;
	char *buffer;

	 fd=open(fname, O_RDONLY);
        if(fd < 0)
        {
                return 0;
        }

        img_size = lseek(fd, 0, SEEK_END);
        if(img_size < 0) goto oops;

	printf("\nimg_size is %d\n",img_size);
        if(lseek(fd, 0, SEEK_SET) !=0) goto oops;

        buffer = (char *) malloc(img_size);
        if(buffer == 0) goto oops;

        if(read(fd, buffer, img_size) != img_size) goto oops;
		


	return buffer;
	printf("you cant't see this\n");

oops:
        close(fd);
        if(buffer != 0) free(buffer);
        return 0;

}


int main(int argc, char ** argv)
{
	struct boot_img_hdr hdr;	
	int pagesize=2048;
	char boot_name[10];
	char *ramdisk_name="ramdisk.img";
	char *kernel_name="kernel";
	int num_kpage;
	int img_size;
	void *image_buffer;
	char * kernel_buffer;
	char * ramdisk_buffer;
	int kfd;
	int rfd;

	memset(&hdr, 0, sizeof(hdr));
	
	if(argc != 2)
	{
		printf("Paramater error\n");
		exit(0);
	}
	strcpy(boot_name, argv[1]);
	
	image_buffer = load_file(boot_name);
	
	memcpy(&hdr, image_buffer, sizeof(hdr));
	
	printf("kernel_size is%d\nkernel_addr is%d\nramdisk_size is%d\nramdisk_addr is%d\ncommand_line%s\n", hdr.kernel_size, hdr.kernel_addr,hdr.ramdisk_size, hdr.ramdisk_addr,hdr.cmdline);
	
	kernel_buffer = (char *) malloc(hdr.kernel_size);
	memcpy(kernel_buffer, image_buffer+2048, hdr.kernel_size);

	kfd = open(kernel_name, O_CREAT | O_TRUNC | O_WRONLY, 0644);	
	if((write(kfd,kernel_buffer,hdr.kernel_size)!=hdr.kernel_size))
	{
		printf(" write kernel fail\n");
	}
	
	num_kpage= (hdr.kernel_size+ pagesize -1)/pagesize;
	num_kpage++;
	ramdisk_buffer = (char *) malloc(hdr.ramdisk_size);
	
	
	memcpy(ramdisk_buffer, image_buffer+num_kpage*2048, hdr.ramdisk_size);
	rfd = open(ramdisk_name, O_CREAT | O_TRUNC | O_WRONLY, 0644);
	if((write(rfd,ramdisk_buffer,hdr.ramdisk_size)!=hdr.ramdisk_size))
	{
		printf(" write ramdisk.img fail\n");
	}

	printf("\nUnpack to %s , %s \n",kernel_name,ramdisk_name);	
	printf("unpacking finished!\n\n");

	free(kernel_buffer);
	close(kfd);
	free(ramdisk_buffer);
	close(rfd);
	free(image_buffer);
	
	printf("=======================================\n\n");
	return (0);

}


作者:華

轉載請注明出處:http://blog.csdn.net/godisagirl2/article/details/8664808


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

解包Android的boot.img 的相关文章

随机推荐

  • Ubuntu 增加swap交换内存

    一 创建虚拟内存 在实际开发中发现swap交换分区不够用了 xff0c 于是需要创建虚拟内存来增加交换分区的大小 在系统空闲空间位置创建swap虚拟内存专用文件夹 cd data 切到你想要创建交换分区的目录 mkdir swap 新建文件
  • 闲扯原码,补码和反码

    闲扯原码 xff0c 补码和反码 始发于 goal00001111 的专栏 xff1b 允许自由转载 xff0c 但必须注明作者和出处 人类习惯使用十进制数进行数值计算 xff0c 而计算机则采用二进制 xff0c 所以为了让计算机帮助人类
  • switch 无法启动软件,请在HOME菜单中再试一次

    本人的是11 0 1 0 18 1 xff0c 刚升级完成后所有游戏都提示 xff1a 无法启动软件 xff0c 请在HOME菜单中再试一次 xff1b 然后搜索一番之后亲测有效 1将如下资源下载到本地 xff0c 2解压后放到对应的文件夹
  • switch如何更新大气层,和进入hekate界面

    0 xff0c 使用windows xff0c 使用windows xff0c 使用windoes xff01 1 xff0c 下载hekate最新版 xff0c 下载最新版大气层固件 xff0c 替换掉SD卡对应地方的文件即可 xff0c
  • RxJava简单入门

    前言之前 span style color fe2c24 首先来认识一下接下来我们将要接触的关键单词 xff0c Observeable Observer subscrib国内基本都翻译成 xff0c 被观察者 xff0c 观察者 xff0
  • WebView加载网页出错:ERR_UNKNOWN_URL_SCHEME

    一 原因 因为webview只能识别http https这样的协议 xff0c 像一些微信 weixin 去哪儿 qunaraphone xff0c 他们自定义的协议webView是无法识别的 xff0c 因此就会出现 xff1a ERR
  • ESP32-CAM搭建Arduino及简单使用

    准备 需要一个ESP32 CAM模块 xff0c 我买的是这种 xff0c 下面带了个下载模块的 xff0c 接上USB就能用了 xff0c 很方便 xff0c 如果没有买下面那个那就得自行用USB TTL了 配置环境 有了硬件 xff0c
  • Failed resolution of: Landroidx/databinding/DataBinderMapperImpl;

    报错 xff1a Failed resolution of Landroidx databinding DataBinderMapperImpl 原因 xff1a lib工程gradle文件中加了dataBinding xff0c 且能使用
  • 谷歌浏览器调试工具使用基础版(一)

    知识采集出处 一 先来认识一下这些按钮 先来看这张图最上头的一行是一个功能菜单 xff0c 每一个菜单都有它相应的功能和使用方法 xff0c 依次从左往右来看 1 箭头按钮 xff1a 用于在页面选择一个元素来审查和查看它的相关信息 xff
  • Android studio 按ctrl+v变成insert的解决办法

    Android studio 按ctrl 43 v变成insert的解决办法 Mac版 android studio 竖线的光标突然变成了矩形 解决方法 xff1a File Settings Editor General Apperanc
  • Windows Server2012多远程桌面配置

    一 配置相关信息 1 win 43 R 输入gpedit msc 计算机配置 管理模板 windows组件 远程桌面服务 远程桌面会话主机 连接 2 将远程桌面服务限制到单独的远程桌面会话禁用 3 启用拒绝将已登录到控制台的管理员注销 不启
  • Android屏幕适配dp、px两套解决办法

    最新最全文章 2018 08 25 xff1a Android dp方式的屏幕适配 原理 后期补充完整讲解 手机dp输出是横屏还是竖屏 android阿杜的博客 CSDN博客 又是屏幕适配 xff0c 这类文章网上不是很多了吗 xff1f
  • Android项目构建变体不能切换打包debug模式和release模式

    Android项目build variants不能切换打包debug模式和release模式 xff0c 不能切换active abi类型 我的项目发现的原因 xff1a 就是项目文件夹名称 xff0c 和包名不同 xff0c 如包名写的是
  • Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES: ... has no certificates at entry AndroidManifest.xml]

    很长一段时间都用快速打包 packer ng plugin xff0c 没注意到底用Android Studio打包会有什么区别 xff0c 今天写了个demo xff0c 居然发现我输入了签名之后只有一次是安装成功的 xff0c 后边都是
  • Mac顶部菜单栏(Menubar)卡死

    升级了Mojave后 xff0c Mac pro 2015 early 顶部菜单栏经常卡死 重启菜单栏 xff08 Menubar xff09 笔者接下来分享两种常见的重启菜单栏的方法 方法一 xff1a 使用活动监视器 打开 OS X 预
  • 计算机专业术语大全(中~英文版)

    AGP Accelerated Graphics Port xff0d 图形加速接口 Access Time xff0d 存取时间 Address 地址 ANSI American National Standards Institute
  • hdfs 的启动

    xff08 1 xff09 先配置文件 修改 core site xml 如下 修改 hdfs site xml 如下 xff1a lt configuration gt lt property gt lt name gt dfs repl
  • Matlab并行化计算

    Matlab并行化计算及GPU计算教程 前置要求和设置 要求电脑CPU有超过2个核心 xff0c 内存大于2G 建议先调试好代码 xff0c 再进行并行化计算 查看并行化计算工具箱版本 gt gt gt ver parallel MATLA
  • 程序员怎么写情书

    今天 xff0c 我们再写一封情书去求爱 Dear xff0c 99669999996669999996699666699666999966699666699 9969999999969999999969966669966996699669
  • 解包Android的boot.img

    我們知道Adnroid的Boot img包其實就是就是把kernel和ramdisk img再加一個page的頭碼成的 其結構就如下所示 43 43 boot header 1 page 43 43 kernel n pages 43 43