make文件分类² 配置类 主要用来配置product、board,以及根据你的Host和Target选择相应的工具以及设定相应的通用编译选项:
这里解释下这里的board和product。board主要是设计到硬件芯片的配置,比如是否提供硬件的某些功能,比如说GPU等等,或者芯片支持浮点运算等等。product是指针对当前的芯片配置定义你将要生产产品的个性配置,主要是指APK方面的配置,哪些APK会包含在哪个product中,哪些APK在当前product中是不提供的。
config.mk是一个总括性的东西,它里面定义了各种module编译所需要使用的HOST工具以及如何来编译各种模块,比如说 BUILT_PREBUILT就定义了如何来编译预编译模块。envsetup.mk主要会读取由envsetup.sh写入环境变量中的一些变量来配置编译过程中的输出目录,combo里面主要定义了各种Host和Target结合的编译器和编译选项。
² 模块组织类 这类文件主要定义了如何来处理Module的Android.mk,以及采用何种方式来生成目标模块,这些模块生成规则都定义在config.mk里面。我们可以看看: CLEAR_VARS:= $(BUILD_SYSTEM)/clear_vars.mk BUILD_HOST_STATIC_LIBRARY:=$(BUILD_SYSTEM)/host_static_library.mk BUILD_HOST_SHARED_LIBRARY:=$(BUILD_SYSTEM)/host_shared_library.mk BUILD_STATIC_LIBRARY:=$(BUILD_SYSTEM)/static_library.mk BUILD_RAW_STATIC_LIBRARY :=$(BUILD_SYSTEM)/raw_static_library.mk BUILD_SHARED_LIBRARY:=$(BUILD_SYSTEM)/shared_library.mk BUILD_EXECUTABLE:= $(BUILD_SYSTEM)/executable.mk BUILD_RAW_EXECUTABLE:=$(BUILD_SYSTEM)/raw_executable.mk BUILD_HOST_EXECUTABLE:=$(BUILD_SYSTEM)/host_executable.mk BUILD_PACKAGE:= $(BUILD_SYSTEM)/package.mk BUILD_HOST_PREBUILT:=$(BUILD_SYSTEM)/host_prebuilt.mk BUILD_PREBUILT:= $(BUILD_SYSTEM)/prebuilt.mk BUILD_MULTI_PREBUILT:=$(BUILD_SYSTEM)/multi_prebuilt.mk BUILD_JAVA_LIBRARY:= $(BUILD_SYSTEM)/java_library.mk BUILD_STATIC_JAVA_LIBRARY:=$(BUILD_SYSTEM)/static_java_library.mk BUILD_HOST_JAVA_LIBRARY:=$(BUILD_SYSTEM)/host_java_library.mk BUILD_DROIDDOC:= $(BUILD_SYSTEM)/droiddoc.mk BUILD_COPY_HEADERS := $(BUILD_SYSTEM)/copy_headers.mk BUILD_KEY_CHAR_MAP :=$(BUILD_SYSTEM)/key_char_map.mk 除了CLEAR_VARS是清楚本地变量之外,其他所有的都对应了一种模块的生成规则,每一个本地模块最后都会include其中的一种来生成目标模块。大部分上面的.mk都会包含base_rules.mk,这是对模块进行处理的基础文件,建议要写本地模块的都去看看,看明白了为什么 Android.mk要这么写就会大致明白了。 ² 单个模块编译类 本地模块的Makefile文件就是我们在Android里面几乎上随处可见的Android.mk。Android进行编译的时候会通过下面的函数来遍历所有子目录中的Android.mk,一旦找到就不会再往层子目录继续寻找(所有你的模块定义的顶层Android.mk必须包含自己定义的子目录中的 Android.mk)。 subdir_makefiles += \ $(shellbuild/tools/findleaves.sh --prune="./out" $(subdirs) Android.mk) 不同类型的本地模块具有不同的语法,但基本上是相通的,只有个别变量的不同,如何添加模块在前面的帖子已经说过了,大家可以参考。
Android通过LOCAL_MODULE_TAGS来决定哪些本地模块会不会编译进系统,通过PRODUCT和LOCAL_MODULE_TAGS来决定哪些应用包会编译进系统,如果用户不指定LOCAL_MODULE_TAGS,默认它的值是user。此外用户可以通过buildspec.mk来指定你需要编译进系统的模块。用户也可以通过mm来编译指定模块,或者通过make clean-module_name来删除指定模块。
² 系统生成类 这主要指的是build/core/Makefile这个文件,它定义了生成各种img的方式,包括ramdisk.img userdata.img system.img update.zip recover.img等。我们可以看看这些img都是如何生成的,对应着我们常用的几个make goals。
在实际的过程中,我们也可以自己编辑out目录下的生成文件,然后手工打包相应生成 相应的img,最常用的是加入一些需要集成进的prebuilt file。所有的Makefile都通过build/core/main.mk这个文件组织在一起,它定义了一个默认goals:droid,当我们在TOP目录下敲Make实际上就等同于我们执行make droid。当Make include所有的文件,完成对所有make文件的解析以后就会寻找生成droid的规则,依次生成它的依赖,直到所有满足的模块被编译好,然后使用相应的工具打包成相应的img。
makefile文件控制整个android系统编译的make文件。其内容如下: ### DO NOT EDIT THIS FILE ### include build/core/main.mk ### DO NOT EDIT THIS FILE ###
可以看出,实际上控制编译的文件是:build/core/main.mk Make命令² make droid:等同于make命令。droid是默认的目标名称。
² clean-$(LOCAL_MODULE)和clean-$(LOCAL_PACKAGE_NAME): 删除某个模块的目标文件。例如:clean-libutils将删除所有的libutils.so以及和它相关的中间文件;clean-Home将删除Home应用。
²
²
注:还有一些命令,从make文件里面应该可以找到。本文不做探讨。 build/core/config.mkconfig.mk文件的主要内容如下: Ø 头文件的定义;(各种include文件夹的设定) 在定义头文件的部分,还include了pathmap.mk,如下: include $(BUILD_SYSTEM)/pathmap.mk 该文件设置include目录和frameworks/base下子目录等的信息。 Ø 编译系统内部mk文件的定义; <Build system internal files> Ø 设定通用的名称;<Set common values> Ø Include必要的子配置文件;<Include sub-configuration files> n buildspec.mk n envsetup.mk n BoardConfig.mk n /combo/select.mk n /combo/javac.mk Ø 检查BUILD_ENV_SEQUENCE_NUMBER版本号; In order to make easier for people when the build system changes, when it is necessary to make changes to buildspec.mk or to rerun the environment setup scripts, they contain a version number in the variable BUILD_ENV_SEQUENCE_NUMBER. If this variable does not match what the build system expects, it fails printing an error message explaining what happened. If you make a change that requires an update, you need to update two places so this message will be printed. · In config/envsetup.make, increment the CORRECT_BUILD_ENV_SEQUENCE_NUMBER definition. · In buildspec.mk.default, update the BUILD_ENV_SEQUENCE_DUMBER definition to match the one in config/envsetup.make The scripts automatically get the value from the build system, so they will trigger the warning as well. Ø 设置常用工具的常量;< Generic tools.> Ø 设置目标选项;< Set up final options.> Ø 遍历并设置SDK版本;
buildspec.mk默认情况下,buildspec.mk文件是不存在的,表示使用的多少默认选项。Android只提供了buildspec.mk文件的模板文件build/buildspec.mk.default。如果需要使用buildspec.mk文件,请将该文件拷贝到<srcDir>根目录下面,并命名为buildspec.mk。同时,需要将模板文件里面的一些必要的配置项启用或者修改为你所需要的目标选项。
buildspec.mk文件主要配置下面的选项: Ø TARGET_PRODUCT:设置编译之后的目标(产品)类型; 可以设置的值在:build/target/product/中定义。比如,product目录下有下面几个mk文件: ² AndroidProducts.mk ² core.mk ² full.mk ² generic.mk ² languages_full.mk ² languages_small.mk ² sdk.mk ² sim.mk 那么,在这里可以设置的值就为上面几个mk文件的前缀名称(generic等)。 Ø TARGET_BUILD_VARIANT:设置image的类型; 包括三个选项:user、userdebug、eng。 usr: 出厂时候面向用户的image; userdebug: 打开了一些debug选项的image; eng: 为了开发而包含了很多工具的image Ø CUSTOM_MODULES:设置额外的总是会被安装到系统的模块; 这里设置的模块名称采用的是简单目标名,比如:Browser或者MyApp等。这些名字在LOCAL_MODULE或者在LOCAL_PACKAGE_NAME里面定义的。
Ø TARGET_SIMULATOR:设置是否要编译成simulator <true or false>; Ø TARGET_BUILD_TYPE:设置是debug还是release版本 <release or debug>; Set this to debug or release if you care. Otherwise, it defaults to release for arm and debug for the simulator. Ø HOST_BUILD_TYPE:设置Host目标是debug版还是release版; <release or debug, default is debug> Ø DEBUG_MODULE_ModuleName:配置单个模块的版本是debug还是release;<ture or false> Ø TARGET_TOOLS_PREFIX:工具名前缀,默认为NULL Ø HOST_CUSTOM_DEBUG_CFLAGS/ TARGET_CUSTOM_DEBUG_CFLAGS:增加额外的编译选项LOCAL_CFLAGS。 LOCAL_CFLAGS:If you have additional flags to pass into the C or C++ compiler, add them here. For example: LOCAL_CFLAGS += -DLIBUTILS_NATIVE=1 Ø CUSTOM_LOCALES:增加额外的LOCALES到最总的image; Any locales that appear in CUSTOM_LOCALES but not in the locale list for the selected product will be added to the end of PRODUCT_LOCALES. Ø OUT_DIR:编译之后文件保存路径。默认为<build-root>/out目录; Ø ADDITIONAL_BUILD_PROPERTIES:指定(增加)额外的属性文件; Ø NO_FALLBACK_FONT:设置是否只支持英文(这将减少image的大小)。<true, false> Ø WEBCORE_INSTRUMENTATION:webcore支持; Ø ENABLE_SVG:SVG支持; Ø BUILD_ENV_SEQUENCE_NUMBER:编译系列号; |
|