Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路


相信ROM的相关信息大家通过前几篇的学习都是有所了解了,这里就不在一一提示了,这里我们下载一个官方包,我们还是以之前的红米note为例子;

一.精简

相对于各个厂商的推广软件,你可以毫不留情的把他删掉

1.厂商内置APK

一般厂商的ROM还是会放一点点软件在里面的,不纯在纯净ROM之说,产商内置的软件在system/vendor/app目录下,你全部删掉就是了

MIUI一般不放在这个目录,放在data/目录下

2.系统APK

在system/app下,有些软件也是我们不想要的,比如应用商店,收音机之内的,我们也可以删掉,不过,那都是需要自己斟酌下了,删错了可是要付出代价的哦

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第1张图片

3.推广软件

一般官方包不会有这个目录,只有第三方才有,这里主要是我们用recovery刷ROM的时候推送到手机安装的一些aok,我们叫他推广软件,目录为data/app下,小米的结构好像要多一点(每个厂商的目录都有细微的变化)system/miui/app下

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第2张图片

4.去掉官方recovery

这里我们只要把根目录下的recovery文件夹删掉就行

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第3张图片

5.去掉标识

一些官方自带的东西都可以删掉,比如uboot.img,logo.img,这里我把他们都删掉了,只剩下

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第4张图片

二.修改刷机脚本updater-script

既然前面我们把该删掉的都删掉了,那么刷机脚本也是要修改一下咯

1.删除机型效验

getprop("ro.product.device") == "lcsh92_wet_tdd" || abort("This package is for \"lcsh92_wet_tdd\" devices; this is a \"" + getprop("ro.product.device") + "\".");
mount("ext4", "EMMC", "/dev/block/mmcblk0p3", "/data");

2.删除官方recovery解压

这里他是要把刚才根目录的官方recovery拷贝到手机里去,但是我们都已经精简了,所以这里就不用了

package_extract_dir("recovery", "/system") || abort("Failed to extract dir from \"recovery\" to \"/system\".");

recovery还没有删除干净哦,我们Ctrl+F搜索一些recovery

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第5张图片

很明显,这两个我们也是不要滴

这里要注意,你精简了什么东西,脚本中都有清单,你要对应的删掉

三.添加ROOT权限

这里是这样的,我们拿着一个机型,我们找到与他对应的root卡刷包,这里我就随便下了一个做示例

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第6张图片

注意,这里我只是找了个root包做演示,如果你要添加ROOT权限的话,要找对应型号的ROOT包

1.编译内核

因为厂商在boot中有一个反root的机制,所以,我们需要把boot里的一些东西去掉,这里提供了一个比较方便的编译内核的工具,下载地址:链接: http://pan.baidu.com/s/1i3MqggH 密码: 4g7q

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第7张图片

使用方法也是很简单,就不需要使用我们的厨房了,这个操作方便点,这里我们拷贝boot.img放在这个目录下,执行MTK解压boot.bat

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第8张图片

解压完成之后同目录下就有一个boot的文件夹了

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第9张图片

我们用notpad++打开boot/rmdisk/init.rc

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第10张图片

我们滑动到最末尾,删掉这么一段话(每个机型不同,大体位置差不多)

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第11张图片

这是另一个机型找的,MIUI是没有的

然后再删除boot/rmdisk/sbin/coolsec

然后执行根目录的MTK打包boot.bat打包回来替换到原来的ROM中去

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第12张图片

2.ROOT脚本

我们先来看看ROOT的脚本是什么样子的

//输出
ui_print("***********************************");
ui_print("  ROOTPKG for DASHEN, E.Y. v2.0  ");
ui_print("***********************************");
//进度
show_progress(0.500000, 0);

ui_print("Extract files...");
//写入这三个文件
package_extract_file("busybox", "/tmp/busybox");
package_extract_file("updater.sh", "/tmp/updater.sh");
package_extract_file("root.zip", "/tmp/UPDATE-SuperSU.zip");

//设置权限
set_perm(0, 0, 0770, "/tmp/busybox");
set_perm(0, 0, 0770, "/tmp/updater.sh");
set_perm(0, 0, 0660, "/tmp/UPDATE-SuperSU.zip");

ui_print("Install busybox...");
run_program("/tmp/busybox", "--install", "-s", "/sbin");
//执行
ui_print("Mount system partition...");
mount("ext4", "EMMC", "/system", "/system");

show_progress(0.200000, 0);
show_progress(0.200000, 10);

ui_print("Updating...");
run_program("/tmp/updater.sh", "/tmp/UPDATE-SuperSU.zip");

ui_print("Unmounting system...");
unmount("/system");

show_progress(0.100000, 0);
ui_print("Installation complete!");

这里不难看出,只是把ROOT包下的三个文件写入到了手机,也就是我选中的这三个文件

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第13张图片

既然如此,那就好办了,我们把这三个文件解压到我们的ROM中去

Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路_第14张图片

我们根据ROOT的脚本来看,她就做了三件事,解压,设置权限,执行,那我们照着改就是了,但是记住,Android4.2和Android4.4以及5.0,6.0的指令是不一样的,这里我们都是Android4.2的话,可以直接使用,我们就把这些放在挂载指令之前把

show_progress(0.500000, 0);

ui_print("Extract files...");
package_extract_file("busybox", "/tmp/busybox");
package_extract_file("updater.sh", "/tmp/updater.sh");
package_extract_file("root.zip", "/tmp/UPDATE-SuperSU.zip");

set_perm(0, 0, 0770, "/tmp/busybox");
set_perm(0, 0, 0770, "/tmp/updater.sh");
set_perm(0, 0, 0660, "/tmp/UPDATE-SuperSU.zip");

ui_print("Install busybox...");
run_program("/tmp/busybox", "--install", "-s", "/sbin");

ui_print("Mount system partition...");
mount("ext4", "EMMC", "/system", "/system");

show_progress(0.200000, 0);
show_progress(0.200000, 10);

ui_print("Updating...");
run_program("/tmp/updater.sh", "/tmp/UPDATE-SuperSU.zip");

ui_print("Unmounting system...");
unmount("/system");

我们现在其实就可以去测验了,首先,我没有这手机,所以也不好测试,其次,有真机的小伙伴野不要去测试,因为这篇博客只是抛砖引玉而已,并没有讲的多详细,我们只是把这个步骤和思想走下去,以后我们会用更高端的工具来测试

想继续连接的话,可以时刻关注一下,下一篇主要是分析从recovery中备份出来的ZIP包制作成ROM包

你可能感兴趣的:(Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路)