安卓的构建层次
一个arch对应多个Board/device,一个Board/device对应多个Product。
Board/device属于硬件定义,Product属于软件定义。
同样一个硬件,可以创建出多个product。
如果要定义一个新的product,可以参考链接中操作。这里说明一下几个重要的文件
- AndroidProducts.mk: 该文件指定了产品配置,并概述了一些关键细节,如 AndroidProducts.mk 中的 PRODUCT_MAKEFILES 所定义的内置软件模块。
- BoardConfig.mk: 该文件包含硬件相关配置,包括芯片硬件设置和分区配置等元素。它对于定制产品的硬件要求至关重要。
- Product.mk:产品配置文件: 该文件封装了与软件模块有关的指令,是对 AndroidProducts.mk 中定义的补充,即包含产品的软件相关配置,例如 AndroidProducts.mk 中的 PRODUCT_MAKEFILES 指定了哪些内置软件模块。Product.mk只是举例,可以更改为”自定义.mk”,然后被AndroidProducts.mk引用即可,例如在/device/google/marlin目录下的AndroidProducts.mk中指定了两个具体的产品的mk文件:
在 Android 中,AndroidProducts.mk 中定义了一个名为 PRODUCT_MAKEFILES 的变量。该变量列出了您在前面步骤中添加的产品的配置文件。在本例中,我们有两个product配置文件,aosp_marlin.mk,aosp_sailfish.mk。
COMMON_LUNCH_CHOICE :它基本上取代了旧版本中使用的文件 vendorsetup.sh 的作用,是属于build的范畴。
目录层次
根目录:/device/google/marlin
product定义
AndroidProducts.mk
aosp_marlin.mk
aosp_sailfish.mk
board定义
./sailfish/BoardConfig.mk
./marlin/BoardConfig.mk
/marlin/BoardConfig.mk实例
芯片硬件配置
分区
aosp_marlin.mk
继承自device-marlin.mk和device-vendor-marlin.mk
PRODUCT_DEVICE与 BoardConfig.mk 紧密相关。编译系统会根据 $PRODUCT_DEVICE 的设置从指定的目录加载相应的 BoardConfig.mk 文件。这是一种确保一切都能按我们想要的方式工作的方法。
PRODUCT_NAME 必须与配置文件的名称一致。该变量在确定编译的输出目录方面起着关键作用。
参考:
https://medium.com/android-knowledge-store/add-new-product-in-aosp-source-81d385a87f26
https://source.android.com/docs/setup/create/new-device#prod-def
https://wladimir-tm4pda.github.io/porting/build_new_device.html#androidBuildSystemProductDefFiles