android Android.mk属性说明及预置系统app操作说明系

. 常见AOSP目录

目录名介绍
build/core/MakefileAOSP整个编译过程中核心的编译规则makefile
build/envsetup.sh编译初始化脚本
build/targetAOSP自带的Target(模拟器)的一些makefile
build/tools/编译中使用的shell及python写的工具脚本
packagess系统app以及一些provider,输入法等桌面看不到的app
framework/av/多媒体相关的native层源码目录
framework/webview/浏览器内核chromium的源码目录
framework/native/power、surface、input、binder等服务的native层实现源码目录
framework/base/core/framework.jar、framework-res.apk、libandroid_runtime.so等的源文件
framework/base/native/libandroid.so的源代码目录.java中的api的native实现.比如looper,assertManager
framework/base/media/多媒体相关的JavaApi和jni层的源文件
framework/base/packages/SettingProviders,SystemUI等不在桌面启动的APP源码
framework/base/service/service.jar、libandroid_service.so的源文件,wifi服务相关的JavaApi,WifiManager,WifiService等
device/(vendor_name)/(product_name)跟某些厂商的某个硬件平台相关的内核,硬件配置等
vendor/(vendor_name)/(product_name)厂商对AOSP进行的修改或者定制,放在vendor目录。包括但不限于framework层新增API,新增APP等业务需求,但是现在Google更推荐放在devices目录下
/out/host该目录下包含了针对当前操作系统所编译出的Android开发工具产物,例如adb,aapt,fastboot等命令
/out/target/common/该目录包含了针对Android设备的通用的编译产物,主要是java应用代码和java库。Framework.jar,services.jar,android.policy.jar等等
/out/target/(product)/(product_name)包含了针对特定设备的编译结果以及平台相关的C/C++库和二进制文件。其中,product_name是具体目标设备的名称

PRODUCT_PACKAGES  指定make时需要编译进system中的包,这部分虽然也生成apk,但用户是删不掉的

LOCAL_OVERRIDES_PACKAGES覆盖替换   如果预置的APK,要覆盖原生apk,则需在android.mk中的添加LOCAL_OVERRIDES_PACKAGES,此变量可以使其他的模块不加入编译。

如: 需要预置第三方的浏览器,替换掉HTMLViewer,则在预置apk的mk文件中加入:

LOCAL_OVERRIDES_PACKAGES := HTMLViewer

2. AndroidBuildSystem

andorid build系统用来编译android系统,android sdk以及相关文档.该系统主要由make文件,shell脚本以及python脚本组成,在编译时能够支持面向不同的硬件设备,不同的编译类型,且提供面向各个厂商的定制扩展

2.1 什么是makefile

makefile是一些有特定语法的,可供make命令读取并执行的脚本性质的配置文件。作用就是可以告知编译系统,对哪些源文件进行编译,怎么编译,怎么处理依赖关系。makefile可以定义变量,函数,调用系统命令,shell、python脚本,管理module之间的依赖。整个Android Build系统中的 Make 文件可以分为三类:

  1. Build系统核心 Makefile
    这类makefile定义了整个Build系统的框架,而其他所有Make文件都是在这个框架的基础上编写出来的。位于/build/core目录下。
  2. 针对某个产品的Makefile
    这类makefile是针对某个产品Make文件,这些文件通常位于device/<vendor>/<product>目录下。
  3. 针对某个模块的Makefile Android.mk
    第三类是针对某个模块的makefile文件.AOSP中,不会针对某一个文件进行编译,每一个编译单位都是一个模块,每一个模块由一个名为"Android.mk"的makefile来声明。该文件中定义了如何编译当前模块。

2.2 make文件中的内容

LOCAL_PATH := $(call my-dir)表示源代码的目录在哪
include $(CLEAR_VARS)表示变量全部清空,其中CLEAR_VARS也是一个makefile文件
LOCAL_MODULE_TAGS := optional表示是哪个TAG,可为eng,user,userdebug,optional等,在哪个版本下执行编译等...

3. ABS思维导图

ABS思维导图
ps:原谅我不会在markdown上画思维导图

android编译.png

略丑的流程图

ps:图不是重点,重点是掌握build系统的流程

ABS流程.jpg

附上文字描述:

第一步:  在项目根目录执行 make   命令即就找到当前目录的makefile文件,文件什么也没有就引用build/core/main.mk文件:
### DO NOT EDIT THIS FILE ###
include build/core/main.mk
### DO NOT EDIT THIS FILE ###

  1. build/core/main.mk:
    1. 检查当前的编译环境inclue build/core/下的核心makefile文件从而完成编译环境的配置
    2. 检索所有的BoardConfig.mkAndroidProduct.mk载入到编译系统
    3. main.mk里会使用python脚本遍历AOSP下的所有模块(AndroidProduct.mk)并include
  2. 所有模块下的AndroidProduct.mk:
    告诉编译系统,当前module的一些配置信息(源文件,依赖库等)和编译输出类型(可执行文件,共享库,静态库,java库,app等)。根据不同的输出类型,会include不同的makefile(package.mk java_library.mk等),这些makefile会调用相关的编译工具,达到编译目的

作者:RexHuang
链接:https://www.jianshu.com/p/d6e752636ba3
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


1、带源码的apk
1)&nBSP;    在 packages/apps 下面以需要预置的 APK的 名字创建一个新文件夹,以预置一个名为Test的APK 为例
2)     将 Test APK的Source code 拷贝到 Test 文件夹下,删除 /bin 和 /gen 目录
3)     在 Test 目录下创建一个名为 android.mk的文件,内容如下:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(call all-subdir-Java-files)
LOCAL_PACKAGE_NAME := Test
include $(BUILD_PACKAGE) 
4)     打开文件 build/target/product/${Project}.mk (其中 ${Project} 表示工程名)或者是在build/target/product/core.mk文件 或者是 device/mediatek/productname/device.mk,因各自公司而易
将 Test 添加到 PRODUCT_PACKAGES 里面。
5)     重新 build 整个工程



2、无源码的apk  且带OS库文件
1)     在 packages/apps 下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例
2)     将 Test.apk 放到 packages/apps/Test 下面
3)     在  packages/apps/Test 下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_CERTIFICATE := PRESIGNED
include $(BUILD_PREBUILT)
4)     打开文件 build/target/product/${Project}.mk (其中 ${Project} 表示工程名)或者是在build/target/product/core.mk文件 或者是 device/mediatek/productname/device.mk,因各自公司而易
将 Test 添加到 PRODUCT_PACKAGES 里面。
5)     将从Test.apk解压出来的 so库拷贝到alps/vendor/mediatek/${Project}/artifacts/out/target/product/${Project}/system/lib/目录下,若无 so 库,则去掉此步;
6)     重新 build 整个工程
注:Google在KK上修改protection Level为System的permission控管机制
如果App使用System Level的permission,需要預置到/system/priv-app底下 (原在/system/app)。



3、无源码apk可以卸载但是恢复出厂设置时不能恢复
1)     在 packages/apps 下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例
2)     将 Test.apk 放到 packages/apps/Test 下面;
3)     在  packages/apps/Test 下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_CERTIFICATE := PRESIGNED
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)
include $(BUILD_PREBUILT)
4)     打开文件 build/target/product/${Project}.mk (其中 ${Project} 表示工程名)或者是在build/target/product/core.mk文件 或者是 device/mediatek/productname/device.mk,因各自公司而易
将 Test 添加到 PRODUCT_PACKAGES 里面。
5)     重新 build 整个工程
注意:这个比不能卸载的多了一句
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)


4、无源码apk可以卸载恢复出场设置时能恢复
在packages/apps下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例:
1)     将Test.apk 放到 packages/apps/Test 下面;
2)     在packages/apps/Test下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_CERTIFICATE := PRESIGNED
LOCAL_MODULE_PATH := $(TARGET_OUT)/vendor/operator/app
include $(BUILD_PREBUILT) 4)     打开文件 build/target/product/${Project}.mk (其中 ${Project} 表示工程名)或者是在build/target/product/core.mk文件 或者是 device/mediatek/productname/device.mk,因各自公司而易

将 Test 添加到 PRODUCT_PACKAGES 里面
4)     重新 build 整个工程
device\mediatek\common\device.mk,将 Test 添加到 PRODUCT_PACKAGES 里面。
PRODUCT_PACKAGES += Test
若需要apk作为32bit的apk运行,则需要在Android.mk中定义
LOCAL_MULTILIB :=32
其中要注意的有:LOCAL_CERTIFICATE
LOCAL_CERTIFICATE := PRESIGNED  //适用于app已经签名的
LOCAL_CERTIFICATE := platform   //试用于app没有签名的
一定要区分清楚,不然会报错


快速合入客户APP 到系统镜像文件system.img中

在有些情况下 我们只是要合入某APK到System.img中(预制到系统中) 文件,然后刷系统调试一下该APP,最快的方法就是:

(1)将该APK  文件解压,提取 lib文件(直接复制 lib 文件),

(2)进入你要合入该APP的系统APP生成路径(如:system/app/   system/priv-app)目下,新建一个与APK文件名相同的文件夹,将该APK 文件与提取出来的 lib文件 放入此文件班夹下即可,

(3)另外需将so库文件复制一份到out目录下项目文件夹下的system/lib,要不然手机系统system/lib下无os库文件

 (4)执行 make snod 重新打包生成新的system.img文件 就OK

(备注)如果在第三步执行打包过程中异常了,则需要进入alps\vendor\mediatek\proprietary\frameworks\base\data\etc\pms_sysapp_removable_system_list.txt

将该APP的包名加入此文件中,


#################完整可用的示例 -- 不可卸载,无源码,不带OS库文件的
# APKNAME-只需要修改的你的APK文件名字参数APKNAME,直接可用
LOCAL_PATH := $(call my-dir)

my_archs := arm x86
my_src_arch := $(call get-prebuilt-src-arch, $(my_archs))

include $(CLEAR_VARS)
LOCAL_MODULE := APKNAME
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_TAGS := optional
LOCAL_BUILT_MODULE_STEM := package.apk
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
#LOCAL_PRIVILEGED_MODULE :=
LOCAL_CERTIFICATE := PRESIGNED
#LOCAL_OVERRIDES_PACKAGES :=
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
#LOCAL_REQUIRED_MODULES :=
LOCAL_MODULE_TARGET_ARCH := $(my_src_arch)
include $(BUILD_PREBUILT)

#######################无源码,不可卸载,带OS库文件的
#APKNAME  只需要修改APKNAME参数即可使用

LOCAL_PATH := $(call my-dir)

my_archs := arm arm64
my_src_arch := $(call get-prebuilt-src-arch, $(my_archs))

include $(CLEAR_VARS)
LOCAL_MODULE := APKNAME
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_TAGS := optional
LOCAL_BUILT_MODULE_STEM := package.apk
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
#LOCAL_PRIVILEGED_MODULE :=
LOCAL_CERTIFICATE := PRESIGNED
#LOCAL_OVERRIDES_PACKAGES :=
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk

LOCAL_PREBUILT_JNI_LIBS := \
	lib/$(my_src_arch)/libXXXX.so \
	lib/$(my_src_arch)/libXXXXX.so

LOCAL_MODULE_TARGET_ARCH := $(my_src_arch)
include $(BUILD_PREBUILT)

上面的带OS库文件的必须将项目中的lib目录的下两文件名修改成arm和arm64(如果要系统位数区别的库),

不能沿用apk解压中的文件名称

否则会报错误:

ninja: error: 'packages/apps/apkname/lib/arm64/libIxxx.so', needed by 'out/target/product/a/system/app/apkname/lib/arm64/libIxxx.so', missing and no known rule to make it

  • 2
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值