boot.img与recovery.img的解包

本文详细介绍了如何解包Android设备的boot.img和recovery.img文件。通过使用split_bootimg.pl脚本,可以将这些映像分解为kernel和ramdisk。该脚本解析bootimg.h头文件中的格式信息,确保正确解压根文件系统。文章还提供了脚本的源代码,展示了如何根据boot header信息拆分不同部分。
摘要由CSDN通过智能技术生成
boot.img与recovery.img的结构很相似,都是kernel加上一个根文件系统。所以是可以用同一个工具(脚本)来分解,下面以分解boot.img为例分析如下:

1, cat /dev/block/mtdblock0 > /sdcard/boot.img
    不同的机型可能对应着不同的分区,需要先核实

2, split_bootimg.pl boot.img
    这个脚本是高手写的,可以用来解包boot.img或recovery.img,输出为kernel和ramdisk
 
3, gunzip -c boot.img-ramdisk.gz | cpio -i
     将解包出来的ramdisk部分再解出整个根文件系统

其中split_bootimg.pl的源码如下,能够分解出来是因为recovery.img的header有足够的信息,保证分解过程可以逆向的把它的根文件系统正确的解压出来。

#!/usr/bin/perl
######################################################################
#
#   File          : split_bootimg.pl
#   Author(s)     : William Enck <enck@cse.psu.edu>
#   Description   : Split appart an Android boot image created 
#                   with mkbootimg. The format can be found in
#                   android-src/system/core/mkbootimg/bootimg.h
#
#                   Thanks to alansj on xda-developers.com for 
#                   identifying the format i
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
工具主要语言为python,分两处版本,源文件及windows下可执行文件exe,内容及用法完全一致。 这是2010.11.02.2更新的版本。 运行方法: 在cmd下cd到文件所在目录,输入"bootimg.exe 功能 参数"(用源文件的话就是bootimg.py) 目前支持以下功能: --repack-ramdisk, 生成 ramdisk --unpack-ramdisk, 解开 ramdisk --repack-bootimg, 生成 bootimg (包括boot.imgrecovery.img) --unpack-bootimg, 解开 bootimg --unpack-updata, 解开 updata.app --unpack-yafffs, 解开 yafffs(包括data.img及system.img) ps:下面的这些参数就算看不懂也没关系,我们的小u可以不用加参数,直接用默认的就行,如解包 updata.app的话就输入bootimg --unpack-updata就好。 下面一一说明功能中的参数。 --unpack-updata [文件] [文件]为空时,默认使用UPDATA.APP 解开后,会有四个文件,boot.img, recovery.img, system.img, userdata.img 这些都是刷机时可能需要的。 --unpack-bootimg [文件] [文件]为空时,默认使用boot.img 解开后,会有两个文件,kernel和ramdisk.gz 同时,注意输出,比如base, cmdline, name等等 --repack-bootimg [base] [cmdline] [base]为空时,使用0x200000 [cmdline]为空时,使用mem=211 console=null androidboot.hardware=qcom 生成bootimg时,会使用kernel和ramdisk.gz(如果存在ramdisk.cpio.gz,优先使用),生成boot.img 更新: --repack-bootimg [base] [cmdline] [page_size] [padding_header] [padding_kernel] [padding_ramdisk] 具体的参数请在注意unpack时的原始参数。 --unpack-ramdisk [文件] [目录] [文件]为空时,使用ramdisk.gz [目录]为空时,使用initrd, (请保证这个目录不存在) 输出:cpiolist.txt, initrd目录下的文件 --repack-ramdisk [cpiolist] [cpiolist]为空时,读取cpiolist.txt 根据cpiolist.txt生成ramdisk.cpio.gz cpiolist.txt格式 1). 文件 file 目标系统路径 当前系统路径 目标系统权限 2). 目录 dir 目录系统路径 目录系统权限 3). 软链接 slink 目录系统路径 链接路径 目标系统权限 --unpack-yafffs [文件] [目录] [文件]为空时,使用userdata.img (呃,这个比system.img小) [目录]为空时,使用文件除.img外的其它内容,比如userdata.img时使用userdata 注:目录必须不存在 将把文件解开到目录下去
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值