Mac系统下编译Android系统源代码

不飞则已,一飞冲天;不鸣则已,一鸣惊人。这篇文章主要讲述Mac系统下编译Android系统源代码相关的知识,希望能为你提供帮助。
前言我们知道,android OS是基于Linux内核的移动操作系统,主要分成了

  • Application
  • ApplicationFramework(java)
  • System Libraries(Native C/C++)/Android Runtime
  • HAL(Hardware Abstraction Layer)
  • Linux Kernel
这几个部分。
作为一个Android Developer,熟练使用Android系统API是必不可少的(Application),但是在进阶的道路上,揭开API的『面具』,直面API背后的Android FW/Linux Kernel同样是一条必经之路。
今天就介绍一下,如何在Mac OSX上进行Android系统源代码的编译。
正文AOSP  是Google领导的Android系统开源项目,旨在为开发者创建定制的Android堆栈版本提供源代码以及相关信息。AOSP的相关简介可以在这里查看。
下面就分步进行Android系统源码的编译:
1. 创建区分大小写的磁盘映像AOSP项目使用git进行版本控制,mac默认的磁盘对大小写是非敏感的,在这类文件系统中,可能导致git的一些命令失效(比如:git status),因此需要创建出一个Case-sensitive的磁盘映像来存储AOSP项目代码。
  • 创建磁盘空间:
    hdiutil create -type SPARSE -fs ‘Case-sensitive Journaled HFS+‘ -size 40g ~/android.dmg

    执行完成后,会在用户根目录(命令行cd ~)创建出一个未挂载的磁盘映像android.dmg(也可能是android.dmg.sparseimage)
  • 调整磁盘大小:
    创建完成后,可对磁盘空间的大小进行调整
    hdiutil resize -size < new-size-you-want> g ~/android.dmg.sparseimage

这里如果想要完整编译master分支,resize的大小建议120G左右,否则空间不足会导致编译重置,并且mac存储空间中会多一部分无法删除的占用。
双击用户目录的android.dmg.sparseimage即可挂载磁盘空间。
2. 安装JDK需注意,AOSP项目必须基于Open JDK的版本。
  • 对于5.0.x的Android版本,需要下载安装JDK7
  • 对于4.4及以下的版本,需要安装JDK6
  • 对于master分支或者6.0+的版本,安装最新的JDK版本
3. 安装Xcode
  • 从App store下载xcode安装,完成后执行
    $ xcode-select --install

    Note:这里最好再运行一下
    sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer

    以防后面的步骤出现warning:
    Warning: Xcode appears to be installed but xcodebuild is unusable; some ports will likely fail to build.

4. 安装MacPorts
  • 根据自己的系统来选择  MacPorts的下载地址
  • 编辑.bash_profile文件(如果没有此文件,vi会自动创建)
    vi ~/.bash_profile

  • 复制export PATH=/opt/local/bin:$PATH到.bash_profile文件中。
  • 激活MacPorts命令:
    source ~/.bash_profile

5. 通过MacPorts安装Make、Git、GPG
POSIXLY_CORRECT=1 sudo port install gmake libsdl git gnupg

同时,由于mac中允许同时打开的文件描述符数较低,复制以下文本至.bash_profile文件中:
ulimit -S -n 1024

6. 下载源代码可以参阅  [官方教程]
  • 确保主目录下有一个bin/目录,在.bash_profile中添加:
    mkdir ~/bin PATH=~/bin:$PAT

    激活:
    source ~/.bash_profile

  • 下载repo
    curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo chmod a+x ~/bin/repo

    关于repo的介绍,看这里。
  • 初始化repo
    挂载的磁盘目录一般在/Volumes文件夹下,cd /Volumes进去后,找到挂载的磁盘名,cd进入磁盘目录后:
    repo init -u https://android.googlesource.com/platform/manifest

  • 开始下载源码
    repo sync

    Note:这里下载的为AOSP master分支的代码,也就是当前最新的Android版本。如需repo特定分支,请使用:
    repo init -u https://android.googlesource.com/platform/manifest -b android-4.0.1_r1

    你可以从这里查看源代码的各版本分支。
    如需使用本地镜像或者需要验证git,请参阅官方教程。
7. 编译编译过程在经历了多个Android版本之后变得更加简单明了。可以参考  [官方教程]
  • 设置环境
    source build/envsetup.sh

  • cd到源代码目录后:
    make -j17

    GNU Make 可以借助 -jN 参数处理并行任务,通常使用的任务数 N 介于编译时所用计算机上硬件线程数的 1-2 倍之间。
Note:此博文仅编译代码用于查看系统代码。如需要设备调试或者需要修改代码,请参阅郭霖的博客。
8. 在AndroidStudio中查看源码关于AndroidStuido的下载以及介绍,请移步  Android Studio官方网站。
  • 编译完成后,cd到源代码目录,如/Volumes/android/source,执行:
    mmm development/tools/idegen/

  • idegen完成后,执行:
    sh ./development/tools/idegen/idegen.sh

  • 以上两步完成以后,打开AndroidStudio -> File -> Open -> 源代码目录 -> android.ipr,即可在AndroidStuido中查看Android源代码。
写在后面网上其实有很多编译源码的教程,但是大多都是比较老旧的版本,亲测下来最新的master分支已经解决了很多遗留的编译问题。
整个过程并没有很复杂,最难以应对的就是mac昂贵的硬盘空间了,256G的HD结结实实折腾了几次才最终编译完成。
【Mac系统下编译Android系统源代码】遇到问题多看官方文档才是最正确的姿势。

    推荐阅读