从2009年开始,Android内核源代码不再是Android源代码的一部分,而是需要单独下载。从2011年9月开始,Android源代码的官网已不可访问。因此,首先需要找到哪里可以下载到Android内核源代码。
经过几天的尝试,发现MSM/QSD Android Enablement Project(https://www.codeaurora.org/gitweb/quic/la/)上有android源代码的镜像。
  在https://www.codeaurora.org/xwiki/bin/QAEP/上面有对于MSM/QSD Android Enablement Project的介绍,通过这里的介绍可以知道MSM/QSD Android Enablement Project与AOSP(Android Open Source Platform)的关系。

一、下载Android源代码。
    下载Android的源代码,并且存放在目录~/Android下面,因为后面编译内核时需要~/Android/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3这个工具。(下面的命令根据codeaurora.org上面的说明写成,未经验证。验证需要很长时间啊,偷懒了吐舌头)。
如果已经有了Android的源代码的话,这一步可以省略 ;因为我已经2011年9月之前从官网下载了Android2.3.5源代码,所以我没有做这一步。
    $ repo init -u git://codeaurora.org/platform/manifest.git -b gingerbread -m M76XXUSNEKNLYA1050.xml --repo-url=git://codeaurora.org/tools/repo.git

    $ repo sync

    $  make

    $ make PRODUCT-sdk-sdk

二、下载内核源代码    
      1. 使用GIT工具下载,执行以下命令:
     USER-NAME@MACHINE-NAME:~/Android$ mkdir kernel
      USER-NAME@MACHINE-NAME:~/Android$ cd kernel
      USER-NAME@MACHIN-NAME:~/Android/kernel$ git clone git://codeaurora.org/kernel/common.git

      开始下载时速度较慢也许只有1~2KB/s,但是请耐心等待,经过一段时间(几个小时)以后,下载速度也许会变快,我下载的时候最快速度达到了约200KB/s。经过漫长的等待后,在kernel目录下有一个common目录,Linux内核代码就在这里了。
      2. 下载完成后,可以查看下载的内核代码版本:
     USER-NAME@MACHINE-NAME:~/Android/kernel$ cd  common
      USER-NAME@MACHINE-NAME:~/Android/kernel/common$ git  branch

      android-2.6.27

      3. 下载完Android的Linux内核代码后,会发现在arch/arm/configs下没有模拟器要使用的硬件配置文件
goldfish_defconfig,而这个配置文件是编译内核代码时需要用到的,因此,需要checkout goldfish版本:
     USER-NAME@MACHINE-NAME:~/Android/kernel/common$ git branch -a
* android-2.6.27
  remotes/origin/HEAD -> origin/android-2.6.27
  remotes/origin/android-2.6.25
  remotes/origin/android-2.6.27
  remotes/origin/android-2.6.29
  remotes/origin/android-goldfish-2.6.27
  remotes/origin/android-goldfish-2.6.29
  remotes/origin/aosp/android-2.6.25
  remotes/origin/aosp/android-2.6.27
  remotes/origin/aosp/android-2.6.29
  remotes/origin/aosp/android-2.6.32
  remotes/origin/aosp/android-2.6.35
  remotes/origin/aosp/android-2.6.35-rc3
  remotes/origin/aosp/android-2.6.36
  remotes/origin/aosp/android-2.6.37
  remotes/origin/aosp/android-2.6.38
  remotes/origin/aosp/android-2.6.39
  remotes/origin/aosp/android-3.0
  remotes/origin/aosp/android-goldfish-2.6.27
  remotes/origin/aosp/android-goldfish-2.6.29
  remotes/origin/aosp/archive/android-2.6.25
  remotes/origin/aosp/archive/android-2.6.27
  remotes/origin/aosp/archive/android-2.6.29
  remotes/origin/aosp/archive/android-2.6.32
  remotes/origin/aosp/archive/android-gldfish-2.6.29
  remotes/origin/aosp/archive/android-goldfish-2.6.27
  remotes/origin/aosp/linux-bcm43xx-2.6.39
  remotes/origin/aosp/linux-wl12xx-2.6.39

      USER-NAME@MACHINE-NAME:~/Android/kernel/common$ git checkout remotes/origin/aosp/archive/android-gldfish-2.6.29
      下载完毕后,就能在arch/arm/configs下看到goldfish_defconfig这个文件了。

  三. 编译内核代码。
     1. 设定环境变量
    打开用户目录下的.bashrc文件,
    USER-NAME@MACHINE-NAME:~/Android/kernel/common$gedit ~/.bashrc
    在后面添加如下代码:
       export PATH=$PATH:~/Android/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin
       export ARCH=arm

     2. 设定交叉编译参数
    a.修改common目录下的Makefile文件的以下行:
      CROSS_COMPILE ?= arm-eabi- #把CROSS_COMPILE的值设为交叉编译工具链arm-eabi-4.4.3的前缀
    b.然后,找到LDFLAGS_BUILD_ID,将其值设为如下形式
    LDFLAGS_BUILD_ID =

      3. 开始编译:
      USER-NAME@MACHINE-NAME:~/Android/kernel/common$ make goldfish_defconfig
      USER-NAME@MACHINE-NAME:~/Android/kernel/common$ make

     编译成功后,可看到下面两行:
      OBJCOPY arch/arm/boot/zImage
      Kernel: arch/arm/boot/zImage is ready
      在执行make命令前,你也可以执行make menuconfig先配置一下编译选项。
     四. 在模拟器中运行编译好的内核。

     1. 在启动模拟器之前,先设置模拟器的目录到环境变量$PATH中去:

     USER-NAME@MACHINE-NAME:~/Android$ export PATH=$PATH:~/Android/out/host/linux-x86/bin
      2. 设置ANDROID_PRODUCT_OUT环境变量:
      USER-NAME@MACHINE-NAME:~/Android$ export ANDROID_PRODUCT_OUT=~/Android/out/target/product/generic
      3. 在后台中指定内核文件启动模拟器:
      USER-NAME@MACHINE-NAME:~/Android$  emulator -kernel ./kernel/common/arch/arm/boot/zImage &
      4. 用adb工具连接模拟器,查看内核版本信息,看看模拟器上跑的内核是不是我们刚才编译出来的内核:
      USER-NAME@MACHINE-NAME:~/Android$ adb devices
      这时候如果是第一次运行 adb shell命令,会看到以下输出:
      * daemon not running. start it now on port 5037 *
      * daemon started successfully *
    List of devices attached
    emulator-5554    device

      USER-NAME@MACHINE-NAME:~/Android$adb shell
      切换到proc目录:
      root@android:/ # cd proc
      root@android:/proc # cat version

Linux version 2.6.29-00262-gb0d93fb-dirty (jim@ubuntu) (gcc version 4.4.0 (GCC) ) #1 Wed Oct 5 22:20:28 CST 2011

    从机器名jim@ubuntu和日期Wed Oct 5 22:20:28 CST 2011可以看出,模拟器使用的内核即为刚刚编译出来的内核。



Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐