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  

 

版权声明:本文为chenyang44原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/chenyang44/p/4444266.html