`

Android源码编译后

阅读更多
在out/target/product/generic下生成的三个镜像文件:ramdisk.img,system.img,userdata.img以及它们对应的目录树root,system,data。ramdisk.img是根文件系统,system.img包括了主要的包、库等文件,userdata.img包括了一些用户数据,android加载这3个映像文件后,会把 system和 userdata分别加载到 ramdisk文件系统中的system和 data目录下。

  三个镜像文件及其三个目录树之间的生成关系是我们进行ROM制作的基础,下面将做详细介绍。 Ramdisk镜像是采用cpio打包,gzip压缩的。用file验证:

  # file ramdisk.img

  输出:

  # ramdisk.img: gzip compressed data, from Unix

  为了便于说明问题,我们将ramdisk.img拷贝到其它一个目录,然后按以下步骤将ramdisk.img还原为目录树:

  # mv ramdisk.img ramdisk.img.gz

  # gunzip ramdisk.img.gz

  # mkdir ramdisk

  #cd ramdisk

  # cpio –i –F ../ramdisk.img

  这样,就得到一个完整的ramdisk目录,与out/target/product/generic/root对比后,我们发现它们是一样的内容。

  通过执行以下的操作,我们可由目录树再生成ramdisk镜像

  # cd ramdisk

  # find . | cpio -o -H newc | gzip > ../ramdisk-new.img 这两个镜像都属于yaffs2文件格式,生成方式是一样的。我们就以system.img为例来说明。

  System.img >> system目录树 所需工具unyaffs, 下载地址

  # mkdir system

  # cd system

  # unyaffs ../system.img

  system目录树 >> system.img

  所需工具 mkyaffs2image,Android源码编译后会生成该工具,在 out/host/linux-x86/bin 目录下。

  命令格式:

  # mkyaffs2image system/ system_new.img

  了解以上方法的意义在于,我们可以对镜像文件镜像修改,定制,以符合自己的需求。 网上有很多制作Android ROM的教程,这里罗列一些链接:

  北理工的陈罡写的两篇文章,是我目前发现的最好的教程,写的非常详细 这两篇文章参考了国外论坛的几个经典教程: _Unpack%2C_Edit%2C_and_Re-Pack_Boot_Images 国内还有一篇文章写的也不错,这篇文章更侧重于制作类似Patch的ROM包 这里基于自己的理解和测试,总结了一些方法步骤。 Android 的ROM包通常称为update.zip包,你可以到www.hiapk.com上下载现成的.zip包。要学习ROM包的制作,我们可以从这样一个zip包开始。解开zip包后,通常有这样一些内容: boot.img 文件 这是编译内核源代码生成的内核映像,然后与android源码编译出来的ramdisk.img一起通过mkbootimg工具创建出来的,图省事的朋友也可以从网上其他的刷机包里面拷贝一个能用的出来即可,基本上都差不多。 META-INF 目录 这个目录是手工创建的,主要用来存放一个升级脚本update-script(这个脚本的内容与system目录中包含的文件有很大关联)以及签名。 system 目录 这个目录就是编译android的平台源代码生成的 要创建自己的ROM,我们通常会涉及到以下的一些工作:

  1. 编译内核生成内核映像。但一般情况下,我们没有必要自己去编,直接从刷机包里面取出一个就可以。譬如,你要做一个2.2版本的升级包。可以到网上找一个与自己机型相匹配的刷机包,从里面取出相应的kernel.img。

  2. ramdisk.img的修改。ramdisk.img 是根文件系统,Ugg boots,里面包含了启动配置脚本。

  3. update-script的修改。

  4. System的修改。

  我们先做个简单的测试工作,来为后面更复杂的工作做好铺垫。测试内容为:先对zip进行解包,然后分别在ramdisk和system的根目录下添加一个小文件,接着,生成新的ROM,并验证ROM是否可用。

  详细的步骤可以参考 html。这里要指出的是,这篇文章以及网上许多类似网站提到的方法都是针对HTC G1或 Nexus one的。而我在测试的时候,用的是HTC G3 Hero。以上的方法导致的一个后果是,重新打包后再烧录,机器无法正常启动,adb shell也无法登陆。后来在国外的一篇博客上看到了对此问题的说明,问题的根源很简单,从G3开始,打包的时候需要指定“--base”参数。对于Hero,参数为”--base 0x19200000”,但对于其它型号的机器,”--base"要设定为多少,需要参考内核代码的实现。

  解包打包可用两个脚本完成unpack-bootimg.pl, repack-bootimg.pl。其中打包脚本用到的mkbootimg工具,在out/host/linux-x86/bin目录下。unpack-bootimg.pl可直接将boot.img生成内核镜像boot.img-kernel和ramdisk目录树boot.img-ramdisk。repack-bootimg.pl可将boot.img-kernel和boot.img-ramdisk重新生成boot.img。

  在解包后,我们在ramdisk和system目录下,各添加一个测试小文件(譬如叫mytest)。做完这些开始组包,重新生成update.zip。到这里我们的工作并没有完全结束,还有最后的一步——签名。签名需要用到签名工具testsign.jar,这是一个基于java 1.6版本的工具。在编译Android源码的时候,我们强调要用java 1.5。在这里,我们必须切换到1.6版本。切换办法见这里。 1)重新生成boot.img

  将前面解包得到的boot.img-ramdisk 和 编译源码后out/target/product/generic/下的root目录树放在一个目录下,然后用repack-bootimg.pl重新生成boot.img

  2) 创建一个目录 myupdate,将上面生成的boot.img放到这个目录下

  3)将编译Android后,out/target/product/generic/生成的system目录树拷贝到myupdate目录

  4)在myupdate目录下创建update-script脚本目录

  # mkdir -p META-INF/com/google/android

  5)删除system/bin目录下的“符号链接”,创建update-script脚本

  update-script脚本的语法可以参考 这里 。研究原有的update-script脚本,我们可以大致看出update-script负责文件删除拷贝,权限设置,符号链接创建等工作。我们可以在原有update-script的基础上进行修改以得到我们自己的update-script。这里,我们要注意的是,要保证update-script的link创建成功,必须把/system/bin下的link删除。我们可以用一个脚本来做这个工作 delsymlink。我修改后与自己编译的Android2.2 system目录树相匹配的脚本。

  6)重新打包并签名

  7)自制ROM下载时报错

  在试验过程中,我经常遇到如下的报错

  Can't open/sdcard/download/update.hiapk

  问题原因:当 update-script 中有命令操作错误,脚本就会停止,并报这个错误,解决的办法就是修正脚本。你可以从这个错误前面的提示,知道脚本哪一行出错了。 很多时候,你并不需要创建一个完整的ROM包。你需要的只是,添加删除或修改一些功能(譬如你仅想添加一个应用,或者你想添加busybox工具)。我们可以参考这里,来实现这个目的。

  我用一个简单的例子来说明这个过程。该例子是在system目录下添加一个mytest文件,同时创建一个指向这个文件的符合链接mylink。以下是过程:

  1) 创建patch_update目录,并在该目录下执行

  # mkdir system

  # mkdir –p META-INF/com/google/android

  2) 在system目录下生成mytest文件

  3)在 META-INF/com/google/android 创建如下的update-script

  show_progress 0.1 0

  copy_dir PACKAGE:system SYSTEM:

  symlink mytest SYSTEM:mylink

  set_perm 0 0 0755 SYSTEM:mytest

  4) 打包签名

  如果前面的3步曲,你已经很好的掌握了,应付你的日常工作应该没有太大的问题。但要成为真正的ROM高手,你还有很多东西要修炼。你要了解整个启动过程,内核编译,Android源码的编译及配置,文件系统及启动配置。。。

  HTC的官网上有一篇文章 这里 详细介绍了镜像包及烧机方法。通常用两种烧录方式:recovery模式,fastboot模式。通过一些组合键,可以进入烧录模式。以HTC G3 Hero为例,“Home + Power”同时按,可以进入Recovery模式,“Back + Power”可以进入fastboot模式。

  Recovery模式比较常用,它相当菜单界面的下载模式。直接把前面所述的update.zip文件放到SD卡上,然后通过在机器上操作控制菜单,就可完成烧录。Fastboot是基于命令行的较低级的下载模式,它可直接烧录.img文件。Fastboot工具也在out/host/linux-x86/bin目录下。

  在我测试过程中,发现fastboot模式无法烧录,当我试图烧录system.img的时候,出现下面的出错信息:

  # fastboot flash system system.img

  # writing 'system'... INFOsignature checking...

  FAILED (remote: signature verify fail)

  在网上查了之后,发现这和签名有关系,SPL要重新刷一下才可,默认是SPL-on,即检测签名,改成SPL-off,就不会出现这个问题,目前没有什么好办法来处理这个问题。好在recovery模式已经能很好地满足需求了,可以先放弃fastboot。

  如果你通过recovery模式烧录后,发现系统无法正常启动,没有关系,recovery还是可以进去的。在recovery模式下,你可以通过adb shell登陆机器。可能你进去后,发现SD卡并没有挂接上来(执行mount就可以查看挂载情况)。但recovry模式要求update.zip必须放在SD卡根目录下,怎么办?很简单,执行“mount –a”就可把SD卡区域挂接上来。如果这招也不行,还有一招,就是把userdata分区手动挂接到sdcard目录,这样就骗过了recovery。

  # mount /dev/mtdblock5 /sdcard

  然后,你再用adb push把新的update.zip拷贝到sdcard目录,重新进行烧录。一般来说,在执行“Flash zip from sdcard”之前,都要先进行Wipe操作,以清除旧的用户数据。

  如何更新recovery?

  可以参考 Hero更新成了recovery-RA-hero-v1.6.2-blue.img。不过,一般无特别的需求,最好不要更新recovery。毕竟有一定风险,一不小心就成了板砖。

  知名的Android论坛: 国内:www.hiapk.com

  国外: 很多国内论坛的文章都是参考或翻译 的

  国内一个很好的博客: ,有很多对Android的研究专题

  国外一个很好的博客: ,这个博客帮我解决了在烧录 HTC G3 HERO的时候,自己打的ROM包烧录后无法启动的问题

  Android 文件系统

   itrd/

  

   ;a=blob;f=Documentation/filesystems/ramfs-rootfs-in itramfs.txt

   s/20090901/173312.html

  Android init脚本的语法

   =2237012
分享到:
评论

相关推荐

    android P android9源码编译.ipr.iml文件

    需要注意的是,编译Android源码可能需要大量的计算资源,包括内存和磁盘空间。此外,由于源码的复杂性,可能需要解决依赖问题、编译错误或配置问题。熟悉Android的构建系统,如`build.gradle`文件和`Android.mk`文件...

    Android源码编译流程借鉴.pdf

    在Eclipse开发环境中,Android源码编译后的调试工作也非常重要。Eclipse提供了几个关键视图:DDMS(Dalvik Debug Monitor Service)用于查看设备状态和内存信息;Java编辑视图是日常编码的主要界面;而Debug视图则在...

    Android 源码编译的jar包

    在Android开发中,源码编译的jar包是开发者深入理解系统运作、定制化系统或者进行二次开发的重要工具。本文将详细阐述如何编译Android源码以生成`classes.jar`,以及这个过程中的关键知识点。 首先,让我们了解`...

    Android源码编译.html

    Android源码编译

    android 源码编译环境搭建

    android 源码编译环境搭建,LINUX环境。

    Android源码编译make的各类错误解决方案汇总

    Android源码编译make错误解决方案汇总 Android源码编译make过程中经常会遇到各种错误,这篇文章将总结各种常见错误的解决方案。 错误一:Java版本不正确 编译Android源码时,make命令可能会报错,提示您使用了...

    Android交叉编译环境&Iperf3;.0源码编译

    9. **测试iperf**:在Android设备上运行编译后的iperf,验证其是否正常工作。 总结,Android交叉编译iperf3.0涉及到多个环节,包括安装环境、配置编译选项、编译源码、生成动态库以及打包和测试。每个步骤都需要...

    Ubuntu系统下Android源码编译.pdf

    首先,要进行Android源码编译,必须确保Ubuntu系统已安装了基础的开发工具。这通常包括GCC编译器、Git版本控制系统、Java Development Kit (JDK) 和Android SDK。JDK是Android应用程序的基础,因为Android的构建工具...

    Android 源码编译过程

    Android源码编译过程是Android开发中的核心环节,它涉及到一系列复杂的步骤,旨在将源代码转化为可以在Android设备上运行的二进制系统映像。这个过程对于开发者来说至关重要,因为它允许自定义和优化Android系统,以...

    Android源码编译参考文档.zip

    本文将深入探讨“Android源码编译参考文档”中的关键知识点,包括高通编译参考和Android Build System。 首先,我们关注的是“高通编译参考文档”。高通是Android设备中广泛使用的芯片制造商,其编译过程涉及到特定...

    zbar android源码编译

    首先,我们来看标题“zbar android源码编译”。这意味着我们要把ZBar的源代码转换为适用于Android平台的库。这通常涉及到Android Native Development Kit (NDK)的使用,NDK是Google提供的一套工具,允许开发者在C/...

    Android源码编译文档

    总的来说,Android源码编译是一个复杂而深入的过程,涉及多方面的技术知识。从源码下载、环境配置到编译和镜像制作,每个环节都需要开发者具备扎实的Linux基础、Git操作技能以及对Android系统结构的深刻理解。通过...

    Android源码编译make的错误处理

    ### Android源码编译make的错误处理 #### 一、概览 在进行Android源码编译的过程中,可能会遇到各种各样的错误。本文主要针对在Linux环境下编译Android 4.0.1版本源码时遇到的一些典型问题,提供详细的解决方案。 ...

    android源码上编译APK

    完成源码编译后,你需要进入源码目录并执行`. build/envsetup.sh`。这个脚本初始化构建环境,使你能够使用如`mm`这样的构建命令。如果出现权限问题,你可以通过`chmod 777 envsetup.sh`来更改文件权限,确保脚本可...

    android源码编译及rom制作.pptx

    ### Android源码编译及ROM制作 #### 一、概览 在《android源码编译及rom制作.pptx》这份文档中,主要讲解了如何进行Android源码的编译以及ROM的制作过程。这一过程对于那些希望深入了解Android操作系统工作原理、...

    VLC Media Player - Android 源码 编译过程

    VLC Media Player - Android 源码 编译过程 (整个编译过程中的命令行日志信息, 可对照查看自己的编译错误位置, 在哪卡住了) 参考博客 : http://blog.csdn.net/shulianghan/article/details/42707293

Global site tag (gtag.js) - Google Analytics