ROM包详解

本文详细介绍了Android ROM包的结构,包括boot.img、system/目录和META-INF下的文件。重点讲解了update-binary和updater-script的作用,以及在升级过程中如何操作system分区,如安装应用、设置权限等。此外,还提到了System目录下各子目录的功能,如app、bin、Frameworks等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

rom里有什么?

解压缩后可以看到rom里有三个文件,其中boot.img是更新boot分区所需要的文件。这个boot.img主要包括kernel+ramdisk。system/目录的内容在升级后会放在系统的system分区。主要用来更新系统的一些应用或则应用会用到的一些库等等。

META-INF目录下主要有六个文件:

(1).update-binary是一个二进制文件,相当于一个脚本解释器,能够识别updater-script中描述的操作。该文件在Android源码编译后out/target/product/xxx/system bin/updater生成,可将updater重命名为update-binary得到。(该文件在具体的更新包中的名字由源码中bootable/recovery/install.c中的宏ASSUMED_UPDATE_BINARY_NAME的值而定)

(2).updater-script:此文件是一个脚本文件,具体描述了更新过程。我们可以根据具体情况编写该脚本来适应我们的具体需求。(该文件的命名由源码中bootable/recovery/updater/updater.c文件中的宏SCRIPT_NAME的值而定)

(3).metadata文件是描述设备信息及环境变量的元数据。主要包括一些编译选项,签名公钥,时间戳以及设备型号等。

(4).这个manifest文件定义了与包的组成结构相关的数据。类似Android应用的mainfest.xml文件。

(5).CERT.RSA:与签名文件相关联的签名程序块文件,它存储了用于签名JAR文件的公共签名。

(6). CERT.SF:这是JAR文件的签名文件,其中前缀CERT代表签名者。

 updater-script

根据流程图,我们先来看看recovery的脚本文件updater-script

一大堆代码正在靠近...

1 assert(getprop("ro.product.device") == "cooper" || getprop("ro.build.product") == "cooper" || getprop("ro.product.board") == "cooper" || getprop("ro.product.device") == "GT-S5830" || getprop("ro.build.product") == "GT-S5830" || getprop("ro.product.board") == "GT-S5830");  

2 package_extract_file("system/bin/backuptool.sh", "/tmp/backuptool.sh");  

3  set_perm(0, 0, 0777, "/tmp/backuptool.sh");  

4 run_program("/tmp/backuptool.sh", "backup");  

5 show_progress(0.500000, 0);  

6 format("ext4", "EMMC", "/dev/block/stl12");  

7 mount("ext4", "EMMC", "/dev/block/stl12", "/system");  

8 package_extract_dir("recovery", "/system");  

9 package_extract_dir("system", "/system");  

10 symlink("busybox", "/system/xbin/[", "/system/xbin/[[",  

11 "/system/xbin/arp",   

12 "/system/xbin/ash",   

13 "/system/xbin/awk",  

14 "/system/xbin/base64",   

15 "/system/xbin/basename",   

16 "/system/xbin/bbconfig",  

17 ..........省略.............  

18 "/system/xbin/xz",   

19 "/system/xbin/xzcat",   

20 "/system/xbin/yes",  

21 "/system/xbin/zcat");  

22 symlink("toolbox", "/system/bin/cat", "/system/bin/cmp",  

23 "/system/bin/date", "/system/bin/dd",   

24 "/system/bin/getevent",  

25 ..........省略.............  

26 "/system/bin/vmstat", "/system/bin/watchprops",  

27 "/system/bin/wipe");  

28 set_perm_recursive(0, 0, 0755, 0644, "/system");  

29 ..........省略.............  

30 set_perm(0, 0, 06755, "/system/xbin/tcpdump");  

31 show_progress(0.200000, 0);  

32 show_progress(0.200000, 10);  

33 package_extract_file("system/bin/backuptool.sh", "/tmp/backuptool.sh");  

34 set_perm(0, 0, 0777, "/tmp/backuptool.sh");  

35 run_program("/tmp/backuptool.sh", "restore");  

36 package_extract_file("system/bin/modelid_cfg.sh", "/tmp/modelid_cfg.sh");  

37 set_perm(0, 0, 0777, "/tmp/modelid_cfg.sh");  

38 run_program("/tmp/modelid_cfg.sh");  

39 package_extract_file("system/bin/verify_cache_partition_size.sh", "/tmp/verify_cache_partition_size.sh");  

40 set_perm(0, 0,0777, "/tmp/verify_cache_partition_size.sh");  

41 run_program("/tmp/verify_cache_partition_size.sh");  

42 show_progress(0.200000, 10);  

43 assert(package_extract_file("boot.img", "/tmp/boot.img"),  

44 write_raw_image("/tmp/boot.img", "boot"),  

45 delete("/tmp/boot.img"));  

46 show_progress(0.100000, 0);  

47 unmount("/system");  

 

代码段1:

48  assert(getprop("ro.product.device") == "cooper" || getprop("ro.build.product") == "cooper" || getprop("ro.product.board") == "cooper" ||       getprop("ro.product.device") == "GT-S5830" || getprop("ro.build.product") == "GT-S5830" || getprop("ro.product.board") == "GT-S5830");  

这段代码的含义是获取手机信息,验证你的手机到底是不是GT-S5830,否则将无法刷入。这是为了防止让一些其他机型的小白误刷咱们GT-S5830的Rom从而发生变砖的惨剧。不加这行的Rom所有机型都可以刷入,建议Rom同行或者补丁制作者们一定要加上,人性化关怀。当然,你不加这些,但在补丁或Rom发布时仔细说明适用机型的话也是可以的。代码段2:

49 format("ext4", "EMMC", "/dev/block/stl12");  

50 mount("ext4", "EMMC", "/dev/block/stl12", "/system");  

51 package_extract_dir("recovery", "/system");  

52 package_extract_dir("system", "/system");   

这是非常重要的一段代码,第一步,格式化EMMC为ext4格式,分区命名为"/dev/block/stl12,就是咱们常常说的system分区了;
第二步,以ext4格式将此分区挂载到/system挂载点;
最后,解压缩Rom文件里的recovery和system目录到/system。
这样,Rom里的recovery和system文件夹下所有内容已经写入system分区了。

代码段3:

53 symlink("busybox", "/system/xbin/[", "/system/xbin/[[","/system/xbin/arp", "/system/xbin/ash", "/system/xbin/awk",         

54 ..........省略.............  

55 "/system/xbin/xz", "/system/xbin/xzcat",   

56 "/system/xbin/yes",          

57 "/system/xbin/zcat");  

58 symlink("toolbox", "/system/bin/cat", "/system/bin/cmp",  

59 ..........省略.............  

60 "/system/bin/vmstat", "/system/bin/watchprops",  

61 "/system/bin/wipe");  

62 set_perm_recursive(0, 0, 0755, 0644, "/system");  

63 ..........省略.............  

64 set_perm(0, 0, 06755, "/system/xbin/tcpdump");  

这是刷机脚本的主体,是最长的一段代码。
symlink是创建xbin目录下的各种工具与其存放路径的链接,著名的busybox工具也在其中。set_perm是设置权限,类似Ubuntu下的chmod。这些代码把相应的文件全部设置成正确的权限。
其中,set_perm_recursive(0, 0, 0755, 0644, "/system");与set_perm_recursive(0, 2000, 0755, 0755, "/system/bin");
是以递归方式将目录及目录下的文件设成相应的权限。
余下的代码是把一些特殊的文件设置成需要的权限。

 

代码段4:

65 assert(package_extract_file("boot.img", "/tmp/boot.img"),  

66 write_raw_image("/tmp/boot.img", "boot"),  

67 delete("/tmp/boot.img"));  

这段代码的动作分三步

.将包中的boot.img提取到/tmp/boot.img。

2).将/tmp/boot.img镜像文件写入到boot分区。

3).删除/tmp/boot.img。

代码段5:

68 show_progress(0.100000, 0);  

69 unmount("/system");  

show_progress(p, t);是个显示进程的脚本,即在t秒的时间内显示的进度条增加p。
unmount("/system");卸载前面挂载的system分区。

 

至此,整个updater-script脚本已经差不多了。如果你想要制作内核单刷包,则只需要代码段4和5就够了,如果想要升级,则只需要package_extract_file("system/app", "/system/app")就可以完成基本功能。

 

System

System目录下有很多文件:

app:放置系统软件的目录,所以内置软件就是在制作Rom包的时候把apk文件放入此文件夹

bin:Android系统本地程序,主要是Linux系统自带的组件

Etc文件夹:放置android系统配置文件,如apn文件等

Fonts文件夹:放置字体文件,包含标准字体和粗体、斜体、中文、英文等

Framework文件夹:放置android系统平台框架文件及布局控制

Lib文件夹:放置系统底层库及运行库文件

Media文件夹:放置系统铃声音乐文件夹及开机动画文件,需要说明一下开机动画其实是多张静态图片的帧动画效果

Tts文件夹:放置手机的语音文件

Usr文件夹: 放置用户文件,包含共享、键盘布局、时间区域文件等

Vendor文件夹:放置ROM厂商定制内容

Xbin文件夹:放置用户系统支持程序文件

Build.prop文件:系统属性配置文件,如我们在设置-关于里看到的内容

如果我们想要修改一些rom的东西,就得在这个文件夹下做动作了,如果对rom自带的apk不敢兴趣,可以将app文件夹下的apk删除,也可以增加一些自己想要的apk进去;如果想要修改框架层的东西,就要修改Framework文件夹里的内容;如果想要修改开机画面和系统铃声,就要修改Media文件夹里的内容;具体的修改方法会在后面说明。

 boot.img

boot.img是启动分区boot的镜像文件,而内核就在这个文件里面;如果我们解开这个img文件,会看到里面包含一个kernel文件、一个ramdisk.gz压缩包;解压ramdisk.gz会得到一个ramdisk文件;

kernel是最核心的东西,是不能乱改的(除非你知道你机器的硬件参数)

ramdisk映像是一个最基础的小型文件系统,它包括了初始化系统所需要的全部核心文件,例如:初始化init进程以及init.rc(可以用于设置很多系统的参数)等文件,如果你您希望了解更多关于此文件的信息可以参考以下网址:
http://git.source.android.com/?p=kernel/common.git;a=blob;f=Documentation/filesystems/ramfs-rootfs-initramfs.txt
以下是一个典型的ramdisk中包含的文件列表:

70 ./init.机型名称.rc  

71 ./default.prop  

72 ./proc  

73 ./dev  

74 ./init.rc  

75 ./init  

76 ./sys  

77 ./init.goldfish.rc  

78 ./sbin  

79 ./sbin/adbd  

80 ./system  

81 ./data  

 

转载于:https://www.cnblogs.com/chenyang44/p/4444266.html

NBH格式刷机编辑器 ----ROM利器! 常用工具} NBH格式刷机编辑器 ----ROM利器!htcRIE_0.4.0.47 应该有人发过,但注意的人不多,其实这是一个相当棒的软件。 列一下我平常用的几个功能: 1、最简单的,查看NBH文件里含的内容。 咱们现在的机子都已刷过HARDSPL,俗称解锁; 都说是不死之身, 其实不然,是可以随意刷纯OS的ROM、没错,但如果ROM含SPL或IPL, 而这SPL和你机子不对应,就会出意外。 所以在刷机之前可以使用这软件查看ROM里的内容, 看下面两图的对比,第一张是纯OS的,可以随意刷; 第二张的内容就多了,刷过HARDSPL的朋友别轻意尝试这种ROM! 1.纯OS ROM(除了 OS 其它都是灰色的) 2.内容很丰富,但不一定适合你 2、修改ROM,这是我最喜好的功能。 以前改过830的ROM,基本得先DUMP_OS--> 修改--> 再BUILD_OS,相当费时。 而htcRIE就不同了,直接打开NBH文件,ROM里的文件一目了然, 可随意进行提取、替换、添加、删除文件等操作;(前提是你应该知道那些文件不能动) 最后根据自已的机型保存就可以了,(我们是Herald机型:HTC P4350、国行C858、C800、TWING) 定制的成品ROM,发现小问题,我都会用这软件时行修改; 像加个软件,换个拨号面板,改注册表等等都能通过这软件轻易实现, 添加铃声,更改开机画面就更不在话下了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值