Loading [MathJax]/jax/output/CommonHTML/fonts/TeX/AMS-Regular.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Android.mk的用法和基础 && m、mm、mmm编译命令「建议收藏」

Android.mk的用法和基础 && m、mm、mmm编译命令「建议收藏」

作者头像
全栈程序员站长
发布于 2022-09-01 08:34:31
发布于 2022-09-01 08:34:31
4.8K03
代码可运行
举报
运行总次数:3
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

(BUILD_STATIC_JAVA_LIBRARY)则是编译出jar包。 B,编译静态库的模板: #Test Static

一个Android.mk file用来向编译系统描述你的源代码。具体来说:该文件是GNU Makefile的一小部分,会被编译系统解析一次或多次。你可以在每一个Android.mk file中定义一个或多个模块。每个模块属下列类型之一: 1)APK程序,一般的Android程序,编译打包生成apk文件 2)JAVA库,java类库,编译打包生成jar文件 3) C\C++应用程序,可执行的C\C++应用程序 4)C\C++静态库,编译生成C\C++静态库,并打包成.a文件 5)C\C++共享库, 编译生成共享库(动态链接库),并打包成.so, 有且只有共享库才能被安装/复制到您的应用软件(APK)包中。 (1)先看一个简单的例子:一个简单的”hello world”,比如下面的文件: sources/helloworld/helloworld.c sources/helloworld/Android.mk 相应的Android.mk文件会像下面这样: ———- cut here ——————

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE
:= helloworld
LOCAL_SRC_FILES := helloworld.c
include $(BUILD_SHARED_LIBRARY)

——— cut here —————— 我们来解释一下这几行代码: 1,LOCAL_PATH := ( CLEAR_VARS),CLEAR_VARS由编译系统提供((可以在 android 安装目录下的/build/core/config.mk 文件看到其定义,为 CLEAR_VARS:=

此处虽没用到其他常用的还有:

5,LOCAL_C_INCLUDES:可选变量,表示头文件的搜索路径。默认的头文件的搜索路径是LOCAL_PATH目录。示例:LOCAL_C_INCLUDES := sources/foo或LOCAL_C_INCLUDES := $(LOCAL_PATH)/../foo

6,TARGET_ARCH:目标 CPU平台的名字;TARGET_PLATFORM:Android.mk 解析的时候,目标 Android 平台的名字;TARGET_ARCH_ABI:暂时只支持两个 value,armeabi 和 armeabi-v7a

7,LOCAL_STATIC_LIBRARIES: 表示该模块需要使用哪些静态库,以便在编译时进行链接。

8,LOCAL_SHARED_LIBRARIES: 表示模块在运行时要依赖的共享库(动态库),在链接时就需要,以便在生成文件时嵌入其相应的信息。

9,LOCAL_LDLIBS: 编译模块时要使用的附加的链接器选项。

10,LOCAL_ARM_MODE: 默认情况下, arm目标二进制会以 thumb 的形式生成(16 位),你可以通过设置这个变量为 arm如果你希望你的 module 是以 32 位指令的形式

11,LOCAL_CFLAGS: 可选的编译器选项,在编译 C 代码文件的时候使用。比如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ifeq ($(BACKCAR_DATA_SOURCE), GPIO)
	CFLAGS += -DGPIO_ENABLE
endif

在C代码中就可以用

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#ifdef GPIO_ENABLE
    *prStatu = BCWaitProtocolFromGPIO();
#endif

12,include $(call all-subdir-makefiles):返回一个位于当前’my-dir’路径的子目录中的所有Android.mk的列表。

(2)在Android中生成本地程序或者库,这些程序和库与其所在路径没有任何关系,只和它们的Android.mk文件有关系。Android.mk和普通的Makefile有所不同,它具有统一的写法,主要包含一些系统公共的宏。在一个Android.mk中可以生成多个可执行程序、动态库和静态库。 A,编译C/C++应用程序的模板: #Test Exe LOCAL_PATH := (CLEAR_VARS) LOCAL_SRC_FILES:= main.c LOCAL_MODULE:= test_exe #LOCAL_C_INCLUDES := #LOCAL_STATIC_LIBRARIES := #LOCAL_SHARED_LIBRARIES := include (BUILD_PACKAGE)则是编译出一个apk,include(BUILD_STATIC_JAVA_LIBRARY)则是编译出jar包。 B,编译静态库的模板: #Test Static (call my-dir) include (CLEAR_VARS) LOCAL_SRC_FILES:= / helloworld.c LOCAL_MODULE:= libtest_static #LOCAL_C_INCLUDES := #LOCAL_STATIC_LIBRARIES := #LOCAL_SHARED_LIBRARIES := include (BUILD_STATIC_LIBRARY) 一般的和上面相似,BUILD_STATIC_LIBRARY表示编译一个静态库.a文件。静态库不会复制到的APK包中,但是能够用于编译共享库。 C,编译动态库的模板: #Test Shared Lib LOCAL_PATH := (CLEAR_VARS) LOCAL_SRC_FILES:= / helloworld.c LOCAL_MODULE:= libtest_shared TARGET_PRELINK_MODULES := false #LOCAL_C_INCLUDES := #LOCAL_STATIC_LIBRARIES := #LOCAL_SHARED_LIBRARIES := include

TARGET_OUT_SHARED_LIBRARIES:表示out/target/product/xxxx/system/lib

TARGET_OUT_APPS:表示out/target/product/xxxx/system/app

ANDROID_PRODUCT_OUT:out/target/product/xxxx/

TARGET_OUT_JAVA_LIBRARIES:out/target/product/xxxx/system/framework

PRODUCT_OUT:out\target\product\xxxxxxx\

TARGET_COPY_OUT_PRODUCT:system

TARGET_OUT_PRODUCT:out/target/product/xxxx/system

(4)Android.mk中的宏定义控制

比如一个文件夹的Android.mk如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ifeq ($(strip $(TARGET_BOARD_PLATFORM_GPU)), mali400)
LOCAL_PATH := $(call my-dir)

ifeq ($(strip $(TARGET_BOARD_PLATFORM)),rkpx2)
ifeq ($(strip $(TARGET_PRODUCT)),rkpx2)

    include $(CLEAR_VARS)
    LOCAL_PREBUILT_LIBS := hwcomposer.rk30board.so
    LOCAL_MODULE_TAGS := optional
    LOCAL_MODULE_PATH := $(TARGET_OUT_SHARED_LIBRARIES)/hw
    include $(BUILD_MULTI_PREBUILT)

    include $(CLEAR_VARS)
    LOCAL_PREBUILT_LIBS := gralloc.rk30board.so
    LOCAL_MODULE_TAGS := optional
    LOCAL_MODULE_PATH := $(TARGET_OUT_SHARED_LIBRARIES)/hw
    include $(BUILD_MULTI_PREBUILT)

endif
endif

endif

在对应的项目.mk中配置TARGET_BOARD_PLATFORM_GPU := mali400,或者其它值,就可以起开关作用

(5)Android.mk中运行shell命令

取一个片段,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ifeq ($(MTK_SENSOR_SUPPORT),yes)
LOCAL_PATH := $(call my-dir)

ifeq ($(CUSTOM_KERNEL_MAGNETOMETER), )
$(shell rm -f $(PRODUCT_OUT)/system/etc/permissions/android.hardware.sensor.compass.xml)
endif
ifeq ($(CUSTOM_KERNEL_ACCELEROMETER), )
$(shell rm -f $(PRODUCT_OUT)/system/etc/permissions/android.hardware.sensor.accelerometer.xml)
endif

普通的.mk一样

(6)Android.mk中 filter 和 filter-out 的用法

举一个例子比较直观:

filter (VARIANTS)) 判断变量VARIANTS中是否包含word1和 word2,如果包含就把VARIANTS中包含的word1和word2之外的过滤掉。示例: VARIANTS := mon tue wed thu fri sat sun DAY := (VARIANTS)) (DAY)) 输出结果为:sat sun

filter-out (VARIANTS)) 判断变量VARIANTS中是否包含word1和 word2,如果包含就把VARIANTS中包含的word1和word2过滤掉,其余的全部保留。示例: VARIANTS := mon tue wed thu fri sat sun DAY := (VARIANTS)) (DAY)) 输出结果为: mon tue wed thu fri =================m、mm、mmm编译命令======================

android源码目录下的build/envsetup.sh文件,描述编译的命令 – m: Makes from the top of the tree. – mm: Builds all of the modules in the current directory. – mmm: Builds all of the modules in the supplied directories.

所以要想使用这些命令,首先需要在android源码根目录执行build/envsetup.sh 脚本设置环境。 m:编译所有的模块 mm:编译当前目录下的模块,当前目录下要有Android.mk文件 mmm:编译指定路径下的模块,指定路径下要有Android.mk文件

下面举个例子说明,假设我要编译android下的\hardware\libhardware_legacy\power模块,当前目录为源码根目录,方法如下: 1、. build/envsetup.sh 2、mmm hardware/libhardware_legacy/power/ 或者 : 1、. build/envsetup.sh 2、cd hardware/libhardware_legacy/power/ 3、mm

m没有试过。默认上述两个编译命令,只编译发生变化的文件。如果要编译模块的所有文件,需要-b选项,例如mm -b或者mmm -b

make命令,也可以用来编译。如果是include (BUILD_EXECUTABLE)或者include

参考原文:http://hubingforever.blog.163.com/blog/static/171040579201152185542166/

参考原文:http://blog.163.com/zz_forward/blog/static/212898222201442873435471/

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/140968.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Babel原理
Babel是什么?我们为什么要了解它? 1. 什么是babel ? Babel 是一个 JavaScript 编译器。他把最新版的javascript编译成当下可以执行的版本,简言之,利用babel就
null仔
2020/02/28
1.2K0
Babel原理
一文助你搞懂 AST
抽象语法树(Abstract Syntax Tree)简称 AST,是源代码的抽象语法结构的树状表现形式。webpack、eslint 等很多工具库的核心都是通过抽象语法书这个概念来实现对代码的检查、分析等操作。今天我为大家分享一下 JavaScript 这类解释型语言的抽象语法树的概念
coder_koala
2020/06/22
2.7K1
使用 AST 实现 babel 插件编写
抽象语法树 (Abstract Syntax Tree) 是源代码语法结构的⼀种抽象表示,以树状描述编程语⾔的语法结构,每个节点表示源代码中的⼀种结构。AST常用于代码语法检查、⻛格检查、格式化、代码提示、混淆压缩、自动补全等,还可以用来优化代码结构,如 webpack 以及 CommonJS、AMD、CMD、UMD等代码规范之间的转化等。
CS逍遥剑仙
2022/08/01
1.3K0
假如面试官问你Babel的原理该怎么回答
简单地说,Babel 能够转译 ECMAScript 2015+ 的代码,使它在旧的浏览器或者环境中也能够运行。
loveX001
2022/10/10
2970
掌握 AST,轻松落地关键业务「技术创作101训练营」
如果你查看目前任何主流的项目中的 devDependencies,我们不会在生产环境用到,但是它们在开发过程中充当着重要的角色。归纳一下有:javascript转译、代码压缩、css预处理器、elint、pretiier,postcss等。所有的上述工具,不管怎样,都建立在了AST这个巨人的肩膀上,都是 AST 的运用:
奋飛
2020/09/20
1.1K0
掌握 AST,轻松落地关键业务「技术创作101训练营」
编译原理工程实践—05使用babel操作AST实现代码转换
babel 是一个 JavaScript 编译器,使用 babel 可以随心所欲地转化和操作 AST,实现对代码的分析、优化、变更等。可以在 https://esprima.org/demo/parse.html 体验转换查看 js 代码的词法、语法和AST。
CS逍遥剑仙
2025/05/12
710
手把手带你走进Babel的编译世界
谈及 Babel,必然离不开 AST。有关 AST 这个知识点其实是很重要的,但由于涉及到代码编译阶段,大多情况都是由各个框架内置相关处理,所以作为开发(使用)者本身,往往会忽视这个过程。希望通过这篇文章,带各位同学走进 AST,借助 AST 发挥更多的想象力。
PHP开发工程师
2022/03/24
5830
手把手带你走进Babel的编译世界
【Babel】293- 初学 Babel 工作原理
已经9102了,我们已经能够熟练地使用 es2015+ 的语法。但是对于浏览器来说,可能和它们还不够熟悉,我们得让浏览器理解它们,这就需要 Babel。
pingan8787
2019/07/25
4640
【Babel】293- 初学 Babel 工作原理
AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解
Javascript就像一台精妙运作的机器,我们可以用它来完成一切天马行空的构思。
Nealyang
2019/09/29
2.4K1
AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解
【Web技术】780- AST 实现函数错误自动上报
之前有身边有人问我在错误监控中,如何能实现自动为函数自动添加错误捕获。今天我们来聊一聊技术如何实现。先讲原理:在代码编译时,利用 babel 的 loader,劫持所有函数表达。然后利用 AST(抽象语法树) 修改函数节点,在函数外层包裹 try/catch。然后在 catch 中使用 sdk 将错误信息在运行时捕获上报。如果你对编译打包感兴趣,那么本文就是为你准备的。
pingan8787
2020/11/19
9870
【Web技术】780- AST 实现函数错误自动上报
JS代码之混淆
抽象语法树(Abstract Syntax Tree),简称 AST,初识 AST 是在一门网页逆向的课程,该课程讲述了 js 代码中混淆与还原的对抗,而所使用的技术便是 AST,通过 AST 能很轻松的将 js 源代码混淆成难以辨别的代码。同样的,也可以通过 AST 将其混淆的代码 还原成执行逻辑相对正常的代码。
愧怍
2022/12/27
22.5K0
JS代码之混淆
babel源码详解-v1.7.8
继续打开 github 看一下最初的版本的 babel 是怎么实现的,了解它的基本原理。
windliang
2022/09/23
7280
babel源码详解-v1.7.8
阿里面试官:如何给所有的async函数添加try/catch?
后来花了一些时间整理了下思路,那么如何实现给所有的async函数添加try/catch呢?
coder_koala
2022/11/28
1.1K0
阿里面试官:如何给所有的async函数添加try/catch?
探索:怎样将单个vue文件转换为小程序所需的四个文件(wxml, wxss, json, js)
比如JavaScript在执行之前,会经过词法分析和语法分析两个步骤之后,得到一个抽象语法树。
极乐君
2019/09/08
5.2K0
AST 与前端工程化实战
AST 是一个非常基础但是同时非常重要的知识点,我们熟知的 TypeScript、babel、webpack、vue-cli 都是依赖 AST 进行开发的。本文将通过 AST 与前端工程化的实战向大家展示 AST 的强大以及重要性。
用户1462769
2019/09/17
1.3K0
AST 与前端工程化实战
【编译技术】:解读 Babel AST Format——06
The Babel parser generates AST according to Babel AST format. It is based on ESTree spec with some deviations.
WEBJ2EE
2020/11/05
4830
【编译技术】:解读 Babel AST Format——06
前端插件机制剖析及业界案例分析
导语 如果你的工具型面对的对象有很丰富的场景需求,或者不想再为频繁的增减需求而频繁迭代,是时候考虑为你的系统设计一款插件系统。 插件机制 插件机制: Core-Plugin 架构的组成 Core:基础功能,提供插件运行的环境,管理插件的注册与卸载(可拔插)以及运行,也即管理插件的生命周期。 PluginApi:插件运行的接口,由 Core 抽象出来的接口。(颗粒度尽可能小) Plugin:每个插件都是一个独立的功能模块。 Core-Plugin 模式的好处,总结几点: 提高扩展性; 减少因功能改变而引起的
用户1097444
2022/06/29
7540
前端插件机制剖析及业界案例分析
创建 AST 节点写法示例
AST (Abstract Syntax Tree(抽象语法树)) 是源代码语法结构的一种抽象表示。不了解 AST 的,可以看这篇文章。
前端GoGoGo
2020/04/02
2.3K0
前端工程师需要了解的 Babel 知识
在前端圈子里,对于 Babel,大家肯定都比较熟悉了。如果哪天少了它,对于前端工程师来说肯定是个噩梦。Babel 的工作原理是怎样的可能了解的人就不太多了。
桃翁
2019/09/24
4730
前端工程师需要了解的 Babel 知识
【编译技术】:解读 Babel AST Format——05
The Babel parser generates AST according to Babel AST format. It is based on ESTree spec with some deviations.
WEBJ2EE
2020/11/05
1.5K1
【编译技术】:解读 Babel AST Format——05
推荐阅读
相关推荐
Babel原理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验