1. Android源码目录介绍

bionic/		    C库
build/		    编译系统规则基础开发包配置
cts/		    兼容性测试
dalvik/		    java虚拟机
external/	    Android引入的第三方模块
frameworks/	    Android核心框架
hardware/	    硬件适配层(HAL)
system/		    底层文件系统库,应用和组件
device/		    产品目标目录
out/		    目标文件目录
packages/app	Android原生的app
sdk/ndk		    Android原生sdk

2. Android开发环境搭建

2.1 安装Ubuntu

2.2 配置开发环境

sudo apt-get install git-core gnupg flex bison gperf zip
sudo apt-get install curl libc6-dev-i386 lib32ncurses5-dev
sudo apt-get install lib32readline-gplv2-dev lib32z-dev

2.3 下载jdk到Ubuntu并安装,配置环境变量,打开.bashrc文件,添加如下内容

export JAVA_HOME=jdk目录
export PATH=$JAVA_HOME/bin:$PATH
export classPath=$JAVA_HOME

3. Android开机模式

Android设备的两种开机模式:在uboot阶段会进行判断(比如是否有组合键按下)是否进入recovery模式。

recovery升级模式:挂起system分区,启动recovery分区上的内核和文件系统;差量包升级,将差量包与system分区进行对比,将不同的内容新增(写操作)到system分区上;全包升级,将整个包覆盖(写操作)到system分区。

正常开机模式:启动system分区上的内核和文件系统。

 

4. Android.mk 解析

以下是一个简洁版的Android.mk文件,以它为例进行分析

LOCAL_PATH:=$(call my-dir)        获取当前模块的相对路径(调用my-dir函数),此时MAKEFILE_LIST变量被设置为当前Android.mk所在路径
include $(CLEAR_VARS)             清空当前环境变量,此时MAKEFILE_LIST变量被设置为build/core/路径
LOCAL_MODULE:=test                编译生成的模块名称
LOCAL_SRC_FILES:test.c xxx.c      编译该模块需要的所有源文件
include $(BUILD_EXECUTABLE)       编译所生成的目标文件格式

4.1 Android编译相关的规则、配置大多在build/ 路径下,通过在build/下搜索my-dir可知,该函数定义在build/core/definitions.mk中

###########################################################
## Retrieve the directory of the current makefile
###########################################################
# Figure out where we are.
define my-dir
$(strip \
  $(eval LOCAL_MODULE_MAKEFILE := $$(lastword $$(MAKEFILE_LIST))) \
  $(if $(filter $(CLEAR_VARS),$(LOCAL_MODULE_MAKEFILE)), \
    $(error LOCAL_PATH must be set before including $$(CLEAR_VARS)) \
   , \
    $(patsubst %/,%,$(dir $(LOCAL_MODULE_MAKEFILE))) \
   ) \
 )
endef

my-dir函数的功能就是从MAKEFILE_LIST中取出并执行最后一个makefile,取出该makefile中所有符合CLEAR_VARS模式的单词,如果有符合的就打印错误,否则返回当前makefile所在的路径。

4.2 通过在build/下搜索CLEAR_VARS可知,可知该变量定义在build/core/config.mk中

CLEAR_VARS:= $(BUILD_SYSTEM)/clear_vars.mk
build/目录下搜索BUILD_SYSTEM可知其定义在build/core/main.mk文件中
BUILD_SYSTEM := $(TOPDIR)build/core

所以CLEAR_VARS:=build/core/clear_vars.mk,这个是makefile中规则模板使用的所有变量,全部置空,只保留了最后一个变量MAKEFILE_LIST := $(lastword $(MAKEFILE_LIST))即clear_vars.mk文件,所以这个脚本不能放到LOCAL_PATH的前面,否则得到的就是build/core/路径,而不是当前模块所处的路径。

【注:】保留最后一个MAKEFILE_LIST变量是为了$(call my-dir)时就不需要每次迭代数千个条目,同时确保不会丢失当前makefile文件中任何我们期望得到的内容。