android的img文件

(1)ramdisk.img
     一个分区影像文件,它会在kernel 启动的时候,以只读的方式被 mount , 这个文件中只是包含了 /init以及一些配置文件,这个ramdisk 被用来调用init,以及把真正的root file system mount起来。
     #其实ramdisk.img的内容就是/out/target/product/generic/root目录的压缩而已。
    
 方法1:  android编译生成后的ramdisk.img是一个gzip格式的文件,输入命令 #file ramdisk.img, 会得到 =>ramdisk.img: gzip compressed data, fromUnix
      
     那么先解压ramdisk.img,因为后缀不是.gz,所以用—S选项, # gunzip -S .imgramdisk.img
     这样就得到一个新文件ramdisk.img,用 # file ramdisk 查看格式 , 得到 =>ramdisk: ASCII cpio archive (SVR4 with no CRC)

         可以看出解压生成的ramdisk是cpio格式的文件,再次解压,为了防止解压后文件混乱,
         首次建立一个目录如: # mkdir rfs //rfs可以用来放ramdisk解压后的文件,  进入 # cd rfs
         解压 # cpio -i -F ../ramdisk

  方法2:将ramdisk.img复制一份到任何其他目录下,将其改名为ramdisk.img.gz,然后使用命令 # gunzipramdisk.img.gz,
        然后新建一个文件夹ramdisk,进入,输入命令 # cpio -i -F ../ramdisk.img



      得到结果如下
   drwxr-xr-x  8 rootroot   4096 2011-01-12 11:36./
   drwxr-xr-x 13 rootroot   4096 2011-01-12 11:35../
   drwxrwx--x  2 rootroot   4096 2011-01-12 11:36data/
   -rw-r--r--  1 rootroot    1182011-01-12 11:36 default.prop
   drwxr-xr-x  2 rootroot   4096 2011-01-12 11:36dev/
   -rwxr-x---  1 root root 1077842011-01-12 11:36 init*
   -rwxr-x---  1 rootroot    4922011-01-12 11:36 init.freescale.rc*
   -rwxr-x---  1 rootroot   1677 2011-01-12 11:36init.goldfish.rc*
   -rwxr-x---  1 rootroot  18263 2011-01-12 11:36 init.rc*
   drwxr-xr-x  2 rootroot   4096 2011-01-12 11:36proc/
   drwxr-x---  2 rootroot   4096 2011-01-12 11:36sbin/
   drwxr-xr-x  2 rootroot   4096 2011-01-12 11:36sys/
   drwxr-xr-x  2 rootroot   4096 2011-01-12 11:36system/

 #可以看出这写文件是和root目录下的内容完全一样,其实就是对root目录的打包和压缩。可以是用tree -L1来查看root的目录

(2)system.img
     它包含了整个系统,android 的framework,application 等等,会被挂接到 "/"上,包含了系统中所有的二进制文件
    #system.img是out/target.product/generic/目录下system目录的一个映射,类似与根文件系统的映像,放着android的应用程序、配置文件和字体等。

   root@root-OptiPlex-380:~/lonshinetech/src/SPU_B0_R0_0/out/target/product/generic/system$tree -L 1
   .
   |-- bin
   |-- build.prop
   |-- etc
   |-- fonts
   |-- framework
   |-- lib
   |-- usr
     -- xbin

重新打包system.img 具体办法
 a)在android编译后生成的out目录中查找这个工具 mkyaffs2image
   # find out/ -name mkyaffs2image
   得到=>out/host/linux-x86/bin/mkyaffs2image
 b)android编译后会生成system/ 这个目录,而这个目录就是用来生成system.img的
   mkyaffs2image system/ system.img

(3)userdata.img

   将会被挂接到 /data 下,包含了所有应用相关的配置文件,以及用户相关的数据 。

 

(4)Android启动过程


    Android启动过程使,会由UBOOT传入一个init参数,这个init参数制定了开机的时候运行的第一个运行的程序,默认就是init程序,这个程序就在ramdisk.img中,可以分析一下它的代码,看看在其中到底做了一些什么样的初始化任务,它的源文件在system/core/init/init.c中。

   它会调用init.rc初始化这个文件,这个文件在out/target/product/generic/root下。
   android启动时首先加载的是ramdisk.img镜像,并挂载到/目录下,并进行一系列的初始化动作,包括创建各种需要的目录,初始化console,开启服务等。system.img是在init.rc中指定一些脚本命令,通过init.c进行解析并挂载到根目录下的/system目录下的。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用方法:http://blog.csdn.net/asmcvc/article/details/11770851 工具: unyaffs,mkyaffs2image 其中unyaffs有windows版本和linux版本,mkyaffs2image只有linux版本。 windows版本的unyaffs用法: 把system.img复制到unyaffs的相同目录下,cmd命令下cd到unyaffs的目录下,然后执行命令:unyaffs system.img unyaffs会把system.img解压到其目录下。 linux版本的unyaffs用法: 把unyaffs复制到/usr/bin目录下,并修改权限为可执行。 然后cd到system.img目录下(假定目录为system目录),执行命令:unyaffs system.img 然后对system目录下的文件进行修改。 注意:修改完后的文件要修改一下权限,尽量和其他文件的权限保持一致。例如:chmod 644 framework-res.apk mkyaffs2image用法: 复制到/usr/bin目录下,并修改权限为可执行。 这里以打包system目录为system.img为例,执行命令: mkyaffs2image system system.img 然后把新生成的system.img复制替换掉原:adt-bundle-windows-x86\sdk\system-images\android-17\armeabi-v7a\system.img 执行bat批处理命令启动模拟器: D:\adt-bundle-windows-x86\sdk\tools\emulator-arm.exe -avd AndroidVM -partition-size 128 这里以修改android系统启动画面为例: 打开解包目录下的\framework\framework-res.apk 替换图片:framework-res.apk\assets\images\android-logo-mask.png为下图: 然后对\framework\framework-res.apk文件重新签名,复制到linux下后修改文件权限和原来一致。 然后mkyaffs2image system system.img打包生成新的system.img,替换原来的system.img,并启动模拟器,效果图如下: 修改代码: 工具:odextools(参考:《一键odex批量合并工具odextools的重新整理与使用》)、dexopt-wrapper 其中odextools.bat的代码: 批处理有一处bug:每打包一次会把odex文件删除掉,导致在后面的打包过程中会出现找不到:system/framework/core.odex类似的错误,因此只需要在打包完后不删除odex文件即可,找到del /f !apkx!.odex 1>nul 2>nul改为:::del /f !apkx!.odex 1>nul 2>nul,也就是注释掉这一行代码。 具体使用方法(操作在windows下): 在odextools\romdir目录下创建文件夹:system 利用unyaffs解包system.img后,把所有文件复制到system目录下。 然后运行odextools.bat,如图: 选择一个需要整合odex的目录选项即可。odextools.bat会自动设置环境变量,使用baksmali.jar来反编译odex为smali,然后再调用smali.jar打包为classes.dex, 然后再打包到相应的apk包(framework目录下对应的是jar后缀的,实际上也是个apk包),最后再重新签名。 如果要修改代码,则需要把上面重新打包生成的apk文件,利用常规方法反编译后修改smali代码,例如插桩输入log信息。然后再回编译并重新签名。 最后一步:因为system.img中的apk是优化过的,apk主目录下是没有classes.dex文件的,而是一个被优化过的odex文件,用于优化启动速度。 因此需要将修改后的apk包再用dexopt-wrapper优化apk包后生成出odex文件,然后删除apk包里的classes.dex,并在相同目录下放置与apk包同名的odex文件。 按照原system目录的文件结构组织好后,目录复制到linux环境下使用mkyaffs2image重新打包成system.img

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值