Android ROM包定制(解包,增删模块,打包)

之前刚用手机的时候,常常能够在玩机论坛上看到不少发ROM包的帖子,譬如什么大深度定制ROM,什么大深度深度精简纯净版ROM...相信不少喜欢搞机的都有见过这类帖子。后来本身不满每次刷机后都要手动设置一大堆东西,遂按照论坛上的教程改了Defy+的cm11的ROM,集成了绿色守护,默认容许安装未知来源的应用,默认电池百分号显示等等。时隔4年,又玩起了ROM包定制,感慨颇多python

1. 解包

假设有一个名为update.zip的ROM包,咱们要在Ubuntu下对它进行定制。首先把system.transfer.listsystem.new.dat.br(有些旧版的系统的镜像多是system.new.dat)从update.zip解压出来,转成system.img(原始镜像格式),修改完后又按步骤打包回原来的格式。本文只写了system分区的定制方法,可是对于其余分区也是相似的,都要转成原始镜像格式后才能对它修改。若是使用file system.img命令来查看system.img文件信息,会获得相似下面的信息:android

system.img: Linux rev 1.0 ext4 filesystem data, UUID=da594c53-9beb-f85c-85c5-cedf76546f7a, volume name "system" (extents) (large files)

1.1 system.new.dat.br转换为system.new.dat

brotli -d system.new.dat.brgit

注:若是镜像就是system.new.dat格式,就跳过这步github

1.2 system.new.dat转成system.img

git clone https://github.com/xpirt/sdat2img
cd sdat2img
python sdat2img.py system.transfer.list system.new.dat system.img

1.3 挂载system.img

sudo mkdir -p /mnt/system
sudo mount -o loop system.img /mnt/system

1.4 扩容(可选)

挂载后能够经过df -h来查看挂载点/mnt/system剩余空间有多少,若是没有剩余,就要对它进行扩容,下面的例子是给它增长128M的空间,扩容以前要先取消挂载app

dd if=/dev/zero bs=1M count=128 >> system.img
e2fsck -f system.img
resize2fs system.img

2. 修改

如今,能够在/mnt/system目录下根据本身的需求增删文件了oop

system_files

增删文件须要注意:spa

  1. 对/mnt/system进行写操做须要root权限
  2. 若是须要往/system/app目录或者/system/priv-app目录下加入本身的apk,须要注意除了把apk复制进去外,还要把apk里面的so文件复制进去(若是有的话),复制进去时注意apk和so文件的路径,能够参考其余系统App是怎么存放的
  3. 对于非Apk文件,复制进去后,还要使用chmod,chown等命令给它们合理的权限才能生效

3. 打包

打包其实就是解包的逆过程unix

3.1 生成system.img

sudo make_ext4fs -T 0 -S file_contexts -l 1024M -a system system_new.img /mnt/system
  • -T 表明对镜像中的unix文件时间戳进行设置,这里设置为0,表示1970-1-1
  • -S 指定file_contexts
  • -l 表示目标镜像的大小。若是不懂得写多少可使用df -h命令查看挂载点/mnt/system的总大小,而后取整数(512M,1024M,2048M...),好比查得挂载点空间大小是992M,你就得写1024M
  • -a 指定目标img文件在Android中的挂载点
  • system_new.img 表示生成的镜像
  • /mnt/system/ 表示源目录

注: file_contexts能够去这里的private目录获取,根据系统版本选择分支(Android7.0对应的是cm14.0分支,Android7.1对应的是cm14.1分支,Android8.0对应lineage-15.0分支,以此类推),下载后也能够根据本身的需求定制file_contextscode

成功后会在当前目录下生成system_new.img。若是发生错误,根据错误进行调整参数,直到没有错误提示为止。blog

3.2 卸载system

sudo umount /mnt/system

3.3 把system.img转成system.new.dat

转换以前能够对以前解压出来的文件进行备份:

mv system.transfer.list system.transfer.list.bak
mv system.new.dat system.new.dat.bak

开始转换

git clone https://github.com/jazchen/rimg2sdat
cd rimg2sdat
python rimg2sdat.py system_new.img

成功后会在当前目录下生成system.transfer.list和system.new.dat

3.4 system.new.dat转成system.new.dat.br

brotli -0 system.new.dat

注:若是开始解压出来的镜像就是system.new.dat格式,就跳过这步

3.5 更新文件到刷机包

zip update.zip <system.new.dat.br或者system.new.dat> system.transfer.list

4. 扩展知识

在有些刷机包里,它里面包含的system.img镜像是sparse image格式的,若是用file命令查看它的信息,显示以下:

system.img: Android sparse image, version: 1.0, Total of 655360 4096-byte output blocks in 6009 input chunks.

对于这种格式的镜像,若是想把它挂载和修改,就要转成咱们上面提到的raw image(原始镜像)格式,命令以下:

simg2img <sparse_image_files> <raw_image_file>

修改完成后,取消挂载,再使用下面的命令将raw image转成sparse image:

img2simg <raw_image_file> <sparse_image_file> [<block_size>]

5. 总结

相对于修改Android源码的方式,直接修改镜像的方法对PC配置要求低不少。若是咱们只想增长一些现有的模块和删除没必要要的模块,这是很好的方式。并且对于一些手机厂商,他们没有提供Android源码,咱们就只能用直接修改镜像的方式来定制咱们的ROM。修改ROM的方法是灵活的,总结下来就是,看见一个镜像,能够根据后缀名和file命令确认它的格式,看状况将它转成原始镜像格式并挂载,就能够修改了,修改后又转回它原来的格式,最后替换刷机包中原有的镜像

相关文章
相关标签/搜索