fix all board compile for v3.0

fix all board compile for v3.0
This commit is contained in:
supowang
2021-08-11 16:30:15 +08:00
parent 1f694e2156
commit 8253a953bd
615 changed files with 96466 additions and 80894 deletions

View File

@@ -1,344 +0,0 @@
# QmkQuick Makefile
## 1. 介绍
### Qmk 是什么
[qmk](../../qmk) 是TencentOS的一个Makefile编译框架。
### Qmk 的特点
- 使用简单任意目录均可make支持帮助`make help`
- 支持Makefile调试任何 目录`make BP= dm`打印Makefile 的所有变量值。
- 支持编译调试, `make V=1``Make V=2`
- 支持宏扩展调试。`make E=1`
- 目录分离。源码,编译产物目录分离。
- 入门简单,新源码目录 Makefile 拷贝即可使用;
- 多架构支持。支持多种 MCU ARCH、多种CC工具链
- 模板化。多种场景的Makefile拷贝即用;
- 配置化。board-pack提供mcu/arch/bsp等编译时参数、目录的配置
- 耦合低。跟源码目录结构的耦合低;
- 子目录单独make支持。支持子目录编译.a静态库
## TencentOS的make编译
### TencentOS的整体make
```shell
# 进入board目录支持qmk的board
cd board/TencentOS_tiny_EVB_MX_Plus/GCC-QMK
# 本目录编译
make
# 查看帮助
make help
```
TencentOS的整体编译过程是
- 先编译静态库
3.`board/`下的顶级Makefile开始该Makefile 确定了BP 。
3. Makefile 通过 `make -C BP=`访问各个目录BP用于选择`qmk/board-pack`下的一个`bp.xxx`作为编译参数集合。
3. `make -C BP=` 进入 `arch/` `kernel/` `platform/vendor_bsp`等需要的目录。
3. make进入各个目录根据`BP`,生成对应的`.a`静态库,如访问 `arch/`, 生成`libarch.a`具备编译哪些arch/下的源码文件由`board-pack`确定。
3. make递归访问其他源码目录目录的`节点Makefile`通过BP渲染`include Make.tpl`模板生成。
3. 依据目录的`节点Makefile`,生成`libxxx.a`
3. 各个源码目录节点,依次生成`.a`静态库文件,均位于 `build/`目录下 。
- 再链接
3. make 回到 `board/`的顶级Makefile。
3. 需要链接生成`elf`的目录通过`include Make.exec`
3. 编译本目录及其子目录下所有源文件,生成`.o`文件。
3. 根据 `LD_A_FILES``LD_L_LISTS`进行链接。
3. 整体链接完成,生成文件位于`build/`目录下。
### TecentOS的子目录make
```shell
# 进入某包含Makefile的目录
cd kernel/
# 本目录编译使用Linux_Posix作为Board-Pack
make BP=Linux_Posix
# 本目录编译使用TencentOS_tiny_EVB_MX_Plus作为Board-Pack
make BP=TencentOS_tiny_EVB_MX_Plus
# 查看帮助
make help
```
单目录的编译过程是:
3. make访问本目录读取本目录Makefile根据命令行`make BP=xxx`的BP选择`mk/board-pack`
3. 根据BP选择的构建参数。
3. 使用ar进行打包.a 文件放在`build/`目录。
3. 构建完成。
## Qmk 的概念
### generic-Makefile(mk/generic)
`qmk/generic/Make.tpl` 属于这类。
又称全局通用型Makefile模板。位于 `mk/generic)`
要求对所有board、所有gcc-toolchain、cpu、arch、bsp适用。
所以一般只包含通用的规则。
| 模板文件 |说明|
| :-------- |:------|
|[Make.tpl](../../qmk/generic/Make.tpl) | 一个目录或者多个目录编译成`.a`的通用模板 |
|[Make.exec](../../qmk/generic/Make.exec) | 多个`.a`链接成 `elf`,生成`.bin`的通用模板 |
|[Make.lib](../../qmk/generic/Make.lib) | 处理多个`.o`生成`.a`的通用模板|
|[Make.subdirs](../../qmk/generic/Make.subdirs) | 处理 make递归进入多个subdir make的通用模板|
|[Make.depend](../../qmk/generic/Make.depend) | 处理 一个`.o`依赖多个`.h`,的规则模板 |
|[Make.debug](../../qmk/generic/Make.debug) | 用于调试Makefile的模板|
|[Make.tools](../../qmk/generic/Make.debug) | 用于屏蔽在多种OS使用qmksed、等基础shell/cli命令路径不同 |
### boardpack-Makefile(mk/board-pack)
`board-pack/bp.TencentOS_tiny_EVB_MX_Plus` 属于这类。
又称板级Makefile模板。是一个硬件产品工程开发过程中在编译时的参数抽象文件。
位于mk/board-pack 的 bp.${BP}属于board配置型Makefile需要确定工具链mcuarch、board、bsp等方面的编译时参数集合。
嵌入式应用开发工程师主要修改这部分Makefile。
### srctree-Makefile
`kernel/Makefile` `arch/Makefile` 都属于这类。
又称节点Makefile位于各个源码目录的 Makefile。多个board都适用的Makefile属于源码节点配置型Makefile。
不能包含archboard级别的编译参数。
### link-Makefile
`board/TencentOS_tiny_EVB_MX_Plus/GCC-QMK/app_tencent_os_mqtt/Makefile` 属于这类。
## Qmk 的使用
### 当前目录所有.c编译成一个.a库
`这类Makefile编写参考 osal/posix/Makefile`
复制粘贴 以下 Makefile 内容到源码目录 Makefile。
无需修改。
>
>3. 注意`TREE_LIB_ENABLE=0`,cc和ar时只搜索当前目录源码不包含子目录
>
>3. 注意`lib=`,表示链接后的库名使用目录名;
>3. 有特别的CFLAG请根据情况配置 `CFGFLAGS`
>3. 注意板级的编译参数请配置到pack-Makefile否则会导致其他pack编译报错.
```Makefile
###################################################################
#automatic detection QTOP and LOCALDIR
CUR_DIR := $(patsubst %/,%,$(dir $(realpath $(firstword $(MAKEFILE_LIST)))))
TRYQTOP := $(shell if [ -n "$$QTOP" ] ; then\
echo $$QTOP;\
else\
cd $(CUR_DIR); while /usr/bin/test ! -d qmk ; do \
dir=`cd ../;pwd`; \
if [ "$$dir" = "/" ] ; then \
echo Cannot find QTOP in $(firstword $(MAKEFILE_LIST)) 1>&2; \
exit 1; \
fi ; \
cd $$dir; \
done ; \
pwd; \
fi)
QTOP ?= $(realpath ${TRYQTOP})
ifeq ($(QTOP),)
$(error Please run this in a tree)
endif
LOCALDIR = $(patsubst %/,%,$(subst $(realpath $(QTOP))/,,$(CUR_DIR)))
####################################################################
TREE_LIB_ENABLE=0
lib=
subdirs=
CFGFLAGS += -I$(CUR_DIR)/include
include ${QTOP}/qmk/generic/Make.tpl
```
### 某目录及其子目录的所有.c编译成一个.a库
`这类Makefile编写参考 kernel/Makefile`
复制粘贴 以下 Makefile 内容到源码目录 Makefile。
无需修改。
有特别的CFLAG请根据情况配置 `CFGFLAGS`
>
>3. 注意`TREE_LIB_ENABLE=1`,cc和ar时会递归搜索源码包含当前目录及其子目录。
>
>3. 注意`lib=`,表示链接后的库名使用目录名;
>3. 注意板级的编译参数请配置到pack-Makefile否则会导致其他pack编译报错.
>
```Makefile
###################################################################
#automatic detection QTOP and LOCALDIR
CUR_DIR := $(patsubst %/,%,$(dir $(realpath $(firstword $(MAKEFILE_LIST)))))
TRYQTOP := $(shell if [ -n "$$QTOP" ] ; then\
echo $$QTOP;\
else\
cd $(CUR_DIR); while /usr/bin/test ! -d qmk ; do \
dir=`cd ../;pwd`; \
if [ "$$dir" = "/" ] ; then \
echo Cannot find QTOP in $(firstword $(MAKEFILE_LIST)) 1>&2; \
exit 1; \
fi ; \
cd $$dir; \
done ; \
pwd; \
fi)
QTOP ?= $(realpath ${TRYQTOP})
ifeq ($(QTOP),)
$(error Please run this in a tree)
endif
LOCALDIR = $(patsubst %/,%,$(subst $(realpath $(QTOP))/,,$(CUR_DIR)))
####################################################################
TREE_LIB_ENABLE=1
lib=
subdirs=
CFGFLAGS += -I${QTOP}/kernel/core/include
CFGFLAGS += -I${QTOP}/kernel/evtdrv/include
CFGFLAGS += -I${QTOP}/kernel/hal/include
CFGFLAGS += -I${QTOP}/kernel/pm/include
include ${QTOP}/qmk/generic/Make.tpl
```
### 当前目录进入所有子目录、进入指定目录编译
`这类Makefile编写参考 platform/Makefile`
复制粘贴 以下 Makefile 内容到源码目录 Makefile。
无需修改。
有特别的CFLAG请根据情况配置 `CFGFLAGS`
>注意` subdirs=`为空,默认会进入所有子目录。
> 如果需要指定子目录请给`subdirs`赋值。
>
```Makefile
###################################################################
#automatic detection QTOP and LOCALDIR
CUR_DIR := $(patsubst %/,%,$(dir $(realpath $(firstword $(MAKEFILE_LIST)))))
TRYQTOP := $(shell if [ -n "$$QTOP" ] ; then\
echo $$QTOP;\
else\
cd $(CUR_DIR); while /usr/bin/test ! -e qmk ; do \
dir=`cd ../;pwd`; \
if [ "$$dir" = "/" ] ; then \
echo Cannot find QTOP in $(firstword $(MAKEFILE_LIST)) 1>&2; \
exit 1; \
fi ; \
cd $$dir; \
done ; \
pwd; \
fi)
QTOP ?= $(realpath ${TRYQTOP})
ifeq ($(QTOP),)
$(error Please run this in a tree)
endif
LOCALDIR = $(patsubst %/,%,$(subst $(realpath $(QTOP))/,,$(CUR_DIR)))
####################################################################
TREE_LIB_ENABLE=0
lib=
subdirs=
include ${QTOP}/qmk/generic/Make.tpl
```
### 新增一个 board-pack支持新的board
参考 `mk/board-pack/`下的各个文件。
参考 `qmk/board-pack/bp.TencentOS_tiny_EVB_MX_Plus`
board-pack 是对 board 在编译时的一个抽象。
一个board 确定了 MCU、 arch、工具链把这些编译时参数写成一个bp.xxx。
新整一个board-pack的步骤
- qmk/board-pack/目录下新建一个bp.xxx.
- 在bp.xxx定义以下变量
注意 CFGFLAGS 需要包括 cpu、arch、board 等类型的FLAG。
赋值建议用`+=`,不允许用 `:=`。注意 可以引用`QTOP``BLDROOT`变量,不建议引用其他`qmk/generic/`模板的变量。
| Makefile变量名 | 变量赋值举例 | 变量说明 |
| :-------- | ------ | :--------------------- |
| CROSS_COMPILE | CROSS_COMPILE =arm-none-eabi- | 工具链前缀 |
| CC | CC = $(CROSS_COMPILE)gcc | 工具链 |
| CXX | CXX = $(CROSS_COMPILE)g++ | 工具链 |
| LD | LD = $(CROSS_COMPILE)ld | 工具链 |
| ARFLAGS | ARFLAGS = -rc | 工具链 |
| STRIP | STRIP = $(CROSS_COMPILE)strip| 工具链 |
| CFGFLAGS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | 对CFLAGS、CXXFLAGS 进行增加 |
| ARCH_LSRCS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | board-pack对应的arch/源码,`make -C arch/时需要编译的源码绝对路径或相对于QTOP的相对路径 |
| BSP_LSRCS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | board-pack对应的board/bsp源码 |
| PLATFORM_VENDOR_BSP_LSRCS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | board-pack对应的vendor_bsp 源码,`make -C platform/vendor_bsp时需要编译的源码 |
| PLATFORM_VENDOR_BSP_LSRCS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | board-pack对应的vendor_bsp 源码,`make -C platform/vendor_bsp时需要编译的源码 |
| PLATFORM_HAL_LSRCS | 参考`bp.TencentOS_tiny_EVB_MX_Plus` | board-pack对应的 hal 源码,`make -C platform/hal时 |
## Qmk 的模板的内置变量
| 变量名 |赋值| 变量值说明 | 值举例 |
| :-------- |:------|:------ |:------- |
|AR |bp中赋值| 工具链 | "arm-none-eabi-ar"|
|ARCH_LSRCS|bp中赋值| 进入arch/需要编译的源码绝对路径或相对于QTOP的源码路径 | "/root/democode/TencentOS-tiny/arch/arm/arm-v7m/cortex-m4/gcc/port_c.c /root/democode/TencentOS-tiny/arch/arm/arm-v7m/cortex-m4/gcc/port_s.S /root/democode/TencentOS-tiny/arch/arm/arm-v7m/common/tos_fault.c /root/democode/TencentOS-tiny/arch/arm/arm-v7m/common/tos_cpu.c /root/democode/TencentOS-tiny/arch/arm/arm-v7m/cortex-m4/gcc/port_c.c /root/democode/TencentOS-tiny/arch/arm/arm-v7m/cortex-m4/gcc/port_s.S /root/democode/TencentOS-tiny/arch/arm/arm-v7m/common/tos_fault.c /root/democode/TencentOS-tiny/arch/arm/arm-v7m/common/tos_cpu.c "|
|ARFLAGS |bp中赋值 | 工具链参数|ar 参数,含义见`ar --help`| "-rc"|
|BLDDIR |禁止赋值|标识.o等编译产物所在的目录跟源码LOCALDIR有关| "/root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/arch"|
|BLDROOT |禁止赋值 | 标识编译产物位置目录。| "/root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos"|
|BLD_SUFFIX|禁止赋值 |编译产物位置目录的后缀名 | | ".tos"|
|BOBJS |禁止赋值 | 所有OBJ集合绝对路径 | "/root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/arch/arm/arm-v7m/cortex-m4/gcc/port_c.o /root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/arch/arm/arm-v7m/cortex-m4/gcc/port_s.o /root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/arch/arm/arm-v7m/common/tos_fault.o /root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/arch/arm/arm-v7m/common/tos_cpu.o"|
|CC | bp中赋值 |"arm-none-eabi-gcc"|
|CROSS_COMPILE | 工具链 | "arm-none-eabi-"|
|CURDIR |禁止赋值|标识当前Makefile 所在的目录 | "/root/democode/TencentOS-tiny/arch"|
|CUR_DIR |禁止赋值|标识当前Makefile 所在的目录 | "/root/democode/TencentOS-tiny/arch"|
|CUR_MK_NODE_DIR |禁止赋值|标识当前Makefile 所在的目录 | "/root/democode/TencentOS-tiny/arch"|
|CXX |bp中赋值| "arm-none-eabi-g++"|
|LD |bp中赋值| "arm-none-eabi-ld"|
|LDFLAGS |bp中赋值 | " "|
|LOBJS |禁止赋值|OBJ文件集合相对路径相对于当前Makefile目录 | "arm/arm-v7m/cortex-m4/gcc/port_c.o arm/arm-v7m/cortex-m4/gcc/port_s.o arm/arm-v7m/common/tos_fault.o arm/arm-v7m/common/tos_cpu.o"|
|LOCALDIR |禁止赋值|源码目录位置相对路径相对于QTOP | "arch"|
|LSRCS |禁止在bp中赋值可以在src-Makefile赋值|编译源代码文件集合相对路径相对于当前Makefile目录或者绝对路径 | "arm/arm-v7m/cortex-m4/gcc/port_c.c arm/arm-v7m/cortex-m4/gcc/port_s.S arm/arm-v7m/common/tos_fault.c arm/arm-v7m/common/tos_cpu.c "|
|QTOP |禁止赋值|源码一级目录| "/root/democode/TencentOS-tiny"|
|RANLIB |bp中赋值 | "arm-none-eabi-ranlib"|
|STRIP |bp中赋值| "arm-none-eabi-strip"|
|TREE_LIB_ENABLE |src-Makefile赋值非0 表示编译所有子目录源码| LSRCS是否把子目录源码 | "0"|
|lib |不建议赋值|`.a`库名变量,默认目录名| "libarch"|
|targetlib |禁止赋值| "/root/democode/TencentOS-tiny/build/TencentOS_tiny_EVB_MX_Plus.arm-none-eabi-gcc.tos/libarch.a"|
## qmk的 make 命令行参数
```shell
make help
```
### make V=1 E=1
```shell
# verbose打印编译时的命令
make V=1
# 调试头文件包含,宏扩展时很有用,会在生成`.o`文件的同时生成`.i`预处理文件
make E=1
```
```shell
# verbose打印链接时的库搜索过程
make V=2
make V=3
```
## 调试Makefile
```shell
#进入含Makefile的目录
make BP=TencentOS_tiny_EVB_MX_Plus dm
```
## Qmk 后续