Android内核开发:源码的版本与分支详解

我想很多初学者或许跟我一样,看完Android×××相关的文章以后,就开始兴致勃勃地去下载Android源码了,但是下载完了源码后,有没有像我一样产生如下几个困惑呢?

创新互联始终坚持【策划先行,效果至上】的经营理念,通过多达十多年累计超上千家客户的网站建设总结了一套系统有效的全网整合营销推广解决方案,现已广泛运用于各行各业的客户,其中包括:成都玻璃贴膜等企业,备受客户赞赏。

(1) Android版本有哪些分支可用?每个分支的TAG是什么?

(2) Android×××完了怎么没有看到Linux内核代码?Android源码对应Linux内核是否可以从kernel.org官网去下载?Android对标准的Linux内核做了哪些修改?

(3) Android源码分支与Linux版本分支的对应关系是什么样的?高版本的Android源码能否使用低版本的Linux内核?或者低版本Android源码能否使用高版本的Linux内核?

(4) 开发板厂商提供的Android源码与AOSP官网下载的Android源码是什么关系呢?

作为我的《Android内核开发》系列文章的第三篇,本文主要来解答一下上面提到的几个问题。

1.  Android版本有哪些分支可用?每个分支的TAG是什么?

Android官网详细地介绍了当前Android的各个版本名称、Version、对应的API Level、Branch TAG、以及Supported devices,该链接地址如下:

http://source.android.com/source/build-numbers.html

由于官网被墙,这里我也给出了一份保存下来的离线html文档,你可以下载下来用浏览器打开查看,地址如下:

https://github.com/Jhuster/AOSP/tree/master/documents

当然,想查看当前可用的Android源码分支和版本,也可以在下载好的Android源码根目录下执行如下命令:

$ git --git-dir .repo/manifests/.git/ branch -a

或者

$ cd .repo/manifests
$ git branch -a | cut -d / -f 3

得到的结果示例如下(只截取了部分):

Android内核开发:源码的版本与分支详解

那么,如果你想切换到其他Android分支,只需要重新执行 repo init 和 repo sync 即可,示例如下:

$ repo init -b android-4.2.2_r1 
$ repo sync

2.  Android源码与Linux内核代码的关系?

文章开头提到的第二个问题主要涉及到Android源码与Linux内核代码的关系,我们首先要了解一个重要的概念:

Android并没有使用标准的Linux内核,而是做了很多的修改。

Android对标准的Linux内核代码做了大量的剪裁和优化,并且添加了许多特有的代码,主要包括:自定义UI系统,采用Bionic Libc库代替glibc库,添加Gold-Fish平台,编写专有的驱动程序,如Binder、Logger、PowerManager等等。

由于版权分歧等原因,这些修改并没有merge到Linux主分支中去,因此,我们不能直接从Linux Kernel的官网(kernel.org)去下载适用于Android源码的Linux内核代码,而是要到Google官网提供的kernel网址去下载经过修改后的Linux内核代码。

Google提供了多个版本的Linux Kernel,分别对应不同的设备或者厂商版本,你可以通过 git clone 命令来完成下载,如下所示:

Android内核开发:源码的版本与分支详解   

如果你只是使用Android模拟器来跑Android内核,那么就可以选择goldfish版本作为你的Linux Kernel,如果你手头有上述内核支持的设备,那么,你就下载对应的kernel即可。

那么,如果你手头的设备或者开发板不在上述支持的列表中怎么办呢?

放心,一般而言,Android开发板的厂商会在上述Linux Kernel的基础上针对自己的开发板修改适配出一套可用的Linux Kernel的,你只需要到厂商的官网或者论坛查找对应的代码即可。对于自己设计开发的板子,则需要下载相近的kernel代码(如CPU型号相同),然后针对性的修改和移植即可。

3.  Android分支与Linux分支的关系

Android版本迭代更新的过程中,Linux Kernel也在不断的迭代更新,因此,往往新的Android版本会使用较新的Linux内核分支,具体的分支对应关系我在Google官网上没有找到,但是在维基百科和stackoverflow上找到了一份表格,如下所示:

Android内核开发:源码的版本与分支详解    

维基百科讲的更加详细,具体介绍了每一个Android分支到底有哪些修改,地址如下:

http://en.wikipedia.org/wiki/Android_version_history

一般情况下,不同的Android分支最好能使用对应的Linux内核分支版本,这样才能保证系统的正常编译通过和运行无误,但是,也可以详细了解某个Android版本对应的Linux内核到底做了哪些修改,并且把这些修改移植到其他版本的Linux内核上,也是可以实现低版本的Android运行在高版本的Linux内核上的,当然,反过来难度比较大,因为一般高版本的Android内核会用到高版本的Linux内核特性,移植起来会麻烦很多。

4.  厂商提供的Android版本与AOSP的关系

很多厂商会提供专门的针对该开发板的Android×××地址,那么,我们是否可以直接使用从AOSP官网上下载的Android源码呢?

厂商一般会对官网的Android源码进行修改,但是修改的部分一般会打个patch包,因此,你只需要下载厂商提供的patch包,并且将手头的官网上下载的Android源码切换到对应的分支,打上patch补丁即可。

5.  小结

关于Android源码的版本与分支就介绍到这里了,有任何疑问欢迎留言或者来信lujun.hust@gmail.com交流,也欢迎关注我的新浪微博 @卢_俊 获取最新的文章和资讯。


新闻标题:Android内核开发:源码的版本与分支详解
网站URL:http://scyanting.com/article/pcpjdo.html