最近需要编译安卓系统,咨询了一个编译过安卓系统的朋友,说是下载源码就得下载两天,于是做好了长期抗战的准备,开始了下载安卓源码的旅程。在刚开始下载时,可以参照的内容只有官方教程,于是跟着官方教程一步一步走,遇到问题就百度谷歌,结果发现自己因为经验不足走了很多弯路,写下这篇教程是为了让以后打算下载安卓源码的朋友提供一些建议和思路。本篇教程会不断更新,力求弥补其他教程的不足并覆盖所有问题,希望大家看完本教程后可以一次性下载成功!
同时,也欢迎大家将遇到的问题以及解决方案告诉我,一起完善这个教程。
配置虚拟机
首先是搭建下载源码的环境,官方推荐是使用64位的Ubuntu,版本是12.04。如果使用Mac OSX的话,编译的时候还需要解决大小写问题,所以建议使用Ubuntu系统。另外由于之后还要编译源码,进行各种配置,所以建议配置一个虚拟机。本人使用的是Mac OSX Mountain Lion 10.8.5系统,VMware 5.03,使用的Ubuntu镜像是ubuntu-12.04-desktop-amd64.iso。
安装完VMware之后,下载好Ubuntu之后就可以开始配置虚拟机了,由于之后还要编译安卓系统,建议大家配置虚拟机磁盘空间为200G,内存为2G(如果电脑内存不足的话1G也行,但是编译的时候可能会慢一些)。
注意:
1.VMware默认为动态分配磁盘空间,所以不一定在创建的时候就要有200G的磁盘空间,但由于之后编译安卓源码需要一百多个G(具体等我编译完会告诉大家),所以请大家预留足够的空间。
2.虽然VMware支持动态增加磁盘空间,但请一次性分配200G,避免之后空间不够用。本人第一次下载源码的时候就只分配了20G,结果下载到一半提示空间不足。关闭虚拟机扩展磁盘空间之后,开机就再也无法进入系统了,只能通过新建虚拟机再挂载的形式恢复数据,所以请大家谨记。
3.由于下载或者编译源码中间可能会与外部系统有交互,方便起见,建议大家安装VMware Tools,可以自由复制以及进行文件共享。
配置下载源码环境
- Python 2.6 -- 2.7, which you can download from python.org.
- GNU Make 3.81 -- 3.82, which you can download from gnu.org,
- JDK 6 if you wish to build Gingerbread or newer; JDK 5 for Froyo or older. You can download both fromjava.sun.com.
- Git 1.7 or newer. You can find it at git-scm.com.
$ sudo add-apt-repository "deb http://archive.canonical.com/ lucid partner"$ sudo apt-get update$ sudo apt-get install sun-java6-jdk但是按照该步骤可能会报错如下:
Package sun-java6-jdk is not available, but is referred to by another package.This may mean that the package is missing, has been obsoleted, oris only available from another sourceE: Package sun-java6-jdk has no installation candidate网上给出了两种解决办法,第一种是:
sudo add-apt-repository ppa:ferramroberto/javasudo apt-get updatesudo apt-get install sun-java6-jdk第二种是:
1. 在终端输入:sudo gedit /ect/apt/sources.list文件2. 在sources.list最后添加一行deb http://us.archive.ubuntu.com/ubuntu/ hardy multiverse3. 保存关闭gedit4. 运行 sudo apt-get update5. 再次运行sudo apt-get install sun-java6-jdk。但很不幸的是,以上两种方法对本人都无效,所以无奈之下,只得手动下载jdk进行安装。如果大家的情况和我一样,建议手动安装,安装步骤可以参见这篇文章。
sudo apt-get install git最后配置一下其他必需的包:
$ sudo apt-get install git gnupg flex bison gperf build-essential \ zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \ libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \ libgl1-mesa-dev g++-multilib mingw32 tofrodos \ python-markdown libxml2-utils xsltproc zlib1g-dev:i386$ sudo ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/i386-linux-gnu/libGL.so官网上教程中的Configuring USB Access好像用不着,Setting up ccache和Using a separate output directory都是编译的时候用的。
安装下载源码的工具
$ mkdir ~/bin$ PATH=~/bin:$PATH
$ curl http://commondatastorage.googleapis.com/git-repo-downloads/repo > ~/bin/repo$ chmod a+x ~/bin/repo安装完下载工具之后,可以创建一个存放源码的目录,这里用WORKING_DIRECTORY代替:
$ mkdir WORKING_DIRECTORY$ cd WORKING_DIRECTORY
下载源码
现在万事俱备,只欠东风了。我们即将开始下载安卓系统源码。首先可以在这里选择要下载的安卓版本,例如本人选的是android-4.3_r2.3。
根据官网的说明,如果下载最新版本可以直接输入:
$ repo init -u https://android.googlesource.com/platform/manifest指定版本可以输入:
$ repo init -u https://android.googlesource.com/platform/manifest -b android-4.3_r2.3这个过程中会提示你输入名字和邮箱,名字随意,邮箱建议输入gmail的邮箱。最后执行:
$ repo sync即可开始下载。需要说明的是,repo支持断点续传,如果中间下载中断了或者出错了,可以再次执行repo sync来继续下载。
但是先不要急,由于下载过程还会遇到各种各样的问题,所以请大家稍安勿躁,再做一些准备工作,首先我们需要创建一个自动下载脚本,确保出错了之后会自动执行repo sync,可以省掉我们很多重复劳动。脚本如下:
#!/bin/bash echo "======start repo sync======" ../bin/repo sync while [ $? == 1 ]; do echo "======sync failed, re-sync again======" sleep 3 ../bin/repo sync done将以上脚本放入一个sh文件中(例如dw.sh),在终端中cd到该脚本的目录下,运行以下命令即可:
sudo sh ./dw.sh
需要注意的是,这个脚本并不能解决下载中间卡住的问题,如果在一个地方卡住超过10分钟以上,建议ctrl+z停掉以后重新运行脚本。本人就曾经第二天早上起来发现还卡在前天晚上的位置。
用浏览器登录https://android.googlesource.com/new-password,输入谷歌账号,点击允许访问,会进入一个信息页面,里面可以得到类似以下内容:
machine android.googlesource.com login git-jacky.rg4.net password 1/dkRiGEvvC8o8Pgg-GsM2AbMNS_32-U0Pf0_VWkYogIA machine android-review.googlesource.com login git-jacky.rg4.net password 1/dkRiGEvvC8o8Pgg-GsM2AbMNS_32-U0Pf0_VWkYogIA在~(/home/username/.netrc)目录下创建一个.netrc文件,将以上两行内容粘贴进去,保存。
repo init的时候地址需要加上/a
repo init -u https://android.googlesource.com/a/platform/manifest
需要注意的是,这两行内容每次登录有可能得到的不一样,但似乎不会有差别。
其他问题
No command 'repo' found, did you mean: Command 'rep' from package 'rep' (universe) Command 'repl' from package 'nmh' (universe) Command 'repl' from package 'mailutils-mh' (universe)repo: command not found出现这个错误的话,建议将~/bin目录下的repo文件夹删除,重新安装repo。注意,不是将安卓源码目录下的.repo文件删除,否则就需要重新下载之前下过的源码!本人就曾经误删除过.repo文件导致所有文件都要重新下载。
E: Sub-process /usr/bin/dpkg returned an error code (1)执行:
cd /var/lib/dpkg sudo mv info info.bak sudo mkdir info再次运行命令,遇到错误:
Errors were encountered while processing: libc6-dev:i386E: Sub-process /usr/bin/dpkg returned an error code (1)执行:
apt-get install linux-libc-dev:i386apt-get install libc6-dev:i386最后再次运行安装其他必需包命令,就没有错误了
error: Failed connect to android.googlesource.com:443; Connection timed out while accessing https://android.googlesource.com/a/platform/sdk/info/refsfatal: HTTP request failed可以尝试ping一下android.googlesource.com,如果ping不通的话,可以修改hosts。方法为,在终端中输入:
sudo gedit /etc/hosts在host文件中增加以下内容:
74.125.31.82 www.googlesource.com 74.125.31.82 android.googlesource.com 203.208.46.172 cache.pack.google.com59.24.3.173 cache.pack.google.com注意,一定要检查该域名是否能ping通,ping不通的话再改,本人就是本来能ping通的,改完就出错了
error: gnutls_handshake() failed: A TLS packet with unexpected length was received. while accessing https://android.googlesource.com/a/platform/packages/screensavers/WebView/info/refsfatal: HTTP request failed
error: frameworks/base/: platform/frameworks/base checkout 4b77609a983b08f163853df2a77e1d535d684aec进入到frameworks/base目录,执行:
git reset --hard
Fetching projects: 0% (1/363) Fetching project platform/hardware/samsung_slsi/exynos5fatal: Invalid gitfile format: /home/zhaoxy/develop/.repo/repo/.git/clone.bundlefatal: The remote end hung up unexpectedly