Android系统recovery刷机脚本updater-script语法说明

来源:互联网 发布:累计消费金额的算法 编辑:程序博客网 时间:2024/05/22 06:20
Android系统recovery刷机脚本updater-script语法说明
这篇教程部分说明来源于网络,主要为了让大家了解updater-script语法和使用,以及熟悉权限的定义和如何使用

unmount
    • unmount(mount_point);
    • mount_point---是mount设置产生的值。作用与挂载相对应,卸载分区或设备。此函数与mount配套使用。
    • unmount("/system");   卸载/system分区

    复制代码
  • format
    • format(type, location);
    • type="MTD"  location=partition(分区),location参数代表分区。
    • format("MTD", "system");  格式化system分区

    复制代码
  • mount
    • mount(type, location, mount_point);
    • type="MTD"   location="" 挂载yaffs2文件系统分区;type="vfat"  location="/dev/block/"  挂载设备。
    • mount("MTD", "system", "/system");         挂载system分区,返回值"/system”
    • mount("ext4", "/dev/block/mmcblk1p2", "/system");     挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为ext4
    • mount("vfat", "/dev/block/mmcblk1p2", "/system");     挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为vfat

    复制代码
  • Delete
    • delete();删除文件
    • delete("/data/zipalign.log");    删除文件/data/zipalign.log

    复制代码
  • delete_recursive
    • delete_recursive();删除文件夹
    • delete_recursive("/data/dalvik-cache");删除文件夹/data/dalvik-cache

    复制代码
  • show_progress
    • show_progress(,);为下面进行的程序操作显示进度条,进度条会根据设置的参数前进
    • show_progress(0.1, 10);show_progress下面的操作可能进行10s,完成后进度条前进0.1(也就是10%)

    复制代码
  • package_extract_dir
    • package_extract_dir(package_path, destination_path);解压package_path文件夹到destination_path目录
    • package_extract_dir("system", "/system");  解压ROM包里system文件夹下所有文件和子文件夹至/system目录

    复制代码
  • package_extract_file
    • package_extract_file(package_path, destination_path);解压package_path文件到destination_path目录
    • package_extract_dir("my.zip", "/system");  解压ROM包里的my.zip文件到/system目录

    复制代码
  • Symlink
    • symlink(...);建立指向target符号链接src1,src2,也就是软链接
    • symlink("toolbox", "/system/bin/ps");建立指向toolbox的符号链接/system/bin/ps

    复制代码
  • set_perm
    • set_perm(...);设置文件的用户为uid,用户组为gid,权限为mode
    • set_perm(1002, 1002, 0440, "/system/etc/dbus.conf");  设置文件/system/etc/dbus.conf的所有者为1002,所属用户组为1002,权限为:所有者有读权限,所属用户组有读权限,其他无任何权限。

    复制代码
    【语法】set_perm(<uid>,<gid>,<mode>, "<path>");
    <uid>表示用户名称
    <gid>表示用户组名称
    <mode>表示权限模式
    <path> 表示文件路径,可以使多个,用空格隔开 
    【作用】设置单个文件或目录的所有者和权限,像linux中的chmod、chown或chgrp命令一样,只是集中在了一个命令当中 
    【举例】set_perm(0,2000,0550,"system/etc/init.goldfish.sh")(设置手机system中的etc/init.goldfish.sh的用户为root,用户组为shell,所有者以及所属用户组成员可以进行读取和执行操作,其他用户无操作权限)
    【说明】在此命令中最难明白的是0 2000 0550这几组参数所代表的意思,这是Linux相关的参数
    具体如下:0代表用户为root,2000代表用户组为shell。0550这组数据的最后三位550,分别代表所有者\组用户\其他用户的权限,也就是我们在RE管理中“用户\群组\其他”三行。
    我们以XXX来表示这三组权限,其中: 
    ×=4 读的权限  
    ×=2 写的权限  
    ×=1 执行的权限  
    我们必须首先了解用数字表示的属性含义:0表示没有权限,1表示可执行权限,2表示可写权限,4表示可读权限,然后将其相加。所以数字属性的格式应为3个从0到7的八进制数。 
    例如:想让某个文件的属性有"读/写"两种权限,需要把4(可读)+2(可写)=6(读/写)。若要rwx属性则4+2+1=7;若要rw-属性则4+2=6;若要r-x属性则4+1=5。 
    常用修改权限的命令:  
    Set_perm 0 0 0600 ××× (只有所有者有读和写的权限)  
    Set_perm 0 0 0644 ××× (所有者有读和写的权限,组用户只有读的权限)  
    Set_perm 0 0 0700 ××× (只有所有者有读和写以及执行的权限)  
    Set_perm 0 0 0666 ××× (每个人都有读和写的权限)  
    Set_perm 0 0 0777 ××× (每个人都有读和写以及执行的权限)  
    范例 : 
    -rw------- (600) -- 只有用户有读写权限。 
    -rw-r--r-- (644) -- 只有用户有读写权限;而组用户和其他用户只有读权限。 
    -rwx------ (700) -- 只有用户有读、写、执行权限。 
    -rwxr-xr-x (755) -- 用户有读、写、执行权限;而组用户和其他用户只有读、执行权限。 
    -rwx--x--x (711) -- 用户有读、写、执行权限;而组用户和其他用户只有执行权限。 
    -rw-rw-rw- (666) -- 所有用户都有文件读、写权限。这种做法不可取。 
    -rwxrwxrwx (777) -- 所有用户都有读、写、执行权限。更不可取的做法。

  • set_perm_recursive
    • set_perm_recursive(...);设置文件夹和文件夹内文件的权限
    • set_perm_recursive(1000, 1000, 0771, 0644, "/data/app");   设置/data/app的所有者和所属用户组为1000,app文件夹的权限是:所有者和所属组拥有全部权限,其他有执行权限;
    • app文件夹下的文件权限是:所有者有读写权限,所属组有读权限,其他有读权限。

    复制代码
    【语法】set_perm_recursive <uid> <gid> <dir-mode> <file-mode> <path> [...<pathN>]
    <uid>表示用户,<gid>表示用户组,<dir-mode>表示文件夹的权限,<file-mode>表示文件的权限,<path> [... <pathN>]表示文件夹的路径,可以多个,用空格分开 
    【作用】设置文件夹及文件夹中的文件的所有者和用户组 
    【说明】其中<dir-mode> <file-mode>分别代表目录和file的权限,具体参数如上述 
    【举例】set_perm_recursive 0 0 0755 0644 SYSTEM:app(设置手机system/app文件夹及其中文件的用户为root,用户组为root,app文件夹权限为所有者可以进行读、写、执行操作,其他用户可以进行读取和执行操作,其中的文件的权限为所有者可以进行读写操作,其他用户可以进行读取操作) 
    下面是我们常用的两组修改权限的命令:
    一组是常规程序用RE管理器拷贝到system/app后修改的权限命令如下: 
    set_perm(0,0,0644,"/system/app/Calendar.apk"); 
    一组是我们要移动dalvik-cache到cache过程中拷贝修改mot_boot_mode.bin命令如下:
    set_perm(0,0,0755,"/system/bin");

  • ui_print
    • ui_print("pwelyn");屏幕打印输出"pwelyn"
    • ui_print("GR[GreatRom/GfanRom]");    屏幕打印GR[GreatRom/GfanRom]

    复制代码
  • run_program
    • run_program();运行shell脚本
    • run_program("/system/xbin/installbusybox.sh");    运行installbusybox.sh脚本文件

    复制代码
  • write_raw_image
    • write_raw_image(, partition);写入至partition分区
    • write_raw_image("/tmp/boot.img", "boot")将boot.img直接写入boot分区

    复制代码
  • assert
    • assert(...);如果执行sub1不返回错误则执行sub2,如果sub2不返回错误则执行sub3一次类推。
    • assert(package_extract_file("boot.img", "/tmp/boot.img"),
    • write_raw_image("/tmp/boot.img", "boot"),
    • delete("/tmp/boot.img"));   执行package_extract_file,如果不返回错误则执行write_raw_image,如果write_raw_image不出错则执行delete

    复制代码
  • 刷机后自动重启
    • run_program("/sbin/sleep", "3");
    • run_program("/sbin/reboot");

    复制代码
  • 结束
    教程结束感谢大家支持
0 0
原创粉丝点击