标签:自带 不同 替换 upper 覆盖 UNC || compile lin
uboot 的版本号分三个级别:
这4个用.分隔开共同构成了最终的版本号。
Makefile 中的版本号最终生成了一个变量 UBOOTVERSION,这个变量记录了 Makefile 中配置的版本号。
include/version_autogenerated.h文件是编译过程中自动生成的一个文件,所以源目录中没有,但是编译过后的uboot中就有了。它里面的内容是一个宏定义,宏定义的值内容就是我们在Makefile中配置的uboot的版本号。
24-29行:
1 VERSION = 1 2 PATCHLEVEL = 1 3 SUBLEVEL = 6 4 EXTRAVERSION = 5 U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION) 6 VERSION_FILE = $(obj)include/version_autogenerated.h
obj 变量定义在后面, makefile 中若是有等号,则变量取用最后定义的,若是源码目录编译,没指定O的值的话,obj为空,则放在 include 文件夹下
HOSTARCH:主机CPU架构;HOST是主机,就是当前做开发用的CPU或电脑;ARCH是架构,表示CPU的架构。
HOSTOS:主机的操作系统
这两个变量是用 export 导出的环境变量,
uname 是shell 脚本命令 uname -m 命令是得到CPU的类型
uname -s 显示操作系统类型
sed -e:以选项中的指定的 cript 来处理输入的文本文件
tr命令可以对来自标准输入的字符进行替换、压缩和删除。
tr ‘[:upper:]‘ ‘[:lower:]‘:将大写字符转换为小写字符
31-42行
1 HOSTARCH := $(shell uname -m | 2 sed -e s/i.86/i386/ 3 -e s/sun4u/sparc64/ 4 -e s/arm.*/arm/ 5 -e s/sa110/arm/ 6 -e s/powerpc/ppc/ 7 -e s/macppc/ppc/) 8 9 HOSTOS := $(shell uname -s | tr ‘[:upper:]‘ ‘[:lower:]‘ | 10 sed -e ‘s/\(cygwin\).*/cygwin/‘) 11 12 export HOSTARCH HOSTOS
1 VENDOR= #表示开发商
U-boot 的编译过程可以支持向一个自己定义的路径生成最终的目标文件。这里提供两种方法:
命令行‘O=‘设置会覆盖环境变量BUILD_DIR的设置
如果都不采用上面两种方法,那么目标文件放到源码顶层目录,也就是U-BOOT顶层目录
代码 69 到 98行
1 ifdef O 2 ifeq ("$(origin O)", "command line") 3 BUILD_DIR := $(O) 4 endif 5 endif 6 7 ifneq ($(BUILD_DIR),) 8 saved-output := $(BUILD_DIR) 9 10 # Attempt to create a output directory. 11 $(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR}) 12 13 # Verify if it was successful. 14 BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd) 15 $(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist)) 16 endif # ifneq ($(BUILD_DIR),) 17 18 OBJTREE := $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR)) 19 SRCTREE := $(CURDIR) 20 TOPDIR := $(SRCTREE) 21 LNDIR := $(OBJTREE) 22 export TOPDIR SRCTREE OBJTREE 23 24 MKCONFIG := $(SRCTREE)/mkconfig 25 export MKCONFIG 26 27 ifneq ($(OBJTREE),$(SRCTREE)) 28 REMOTE_BUILD := 1 29 export REMOTE_BUILD 30 endif
100到110行,实现 编译目录和源代码目录不相同的时候执行 obj赋值,如果是在源码目录赋值,则 obj 和 src 都为空
1 # $(obj) and (src) are defined in config.mk but here in main Makefile 2 # we also need them before config.mk is included which is the case for 3 # some targets like unconfig, clean, clobber, distclean, etc. 4 ifneq ($(OBJTREE),$(SRCTREE)) 5 obj := $(OBJTREE)/ 6 src := $(SRCTREE)/ 7 else 8 obj := 9 src := 10 endif 11 export obj src
执行完毕后,将 obj src 值输出成环境变量,供 u-boot 其他文件中调用
总结:在默认编译下,OBJTREE和SRCTREE相等;在O=xx这种编译下OBJTREE和SRCTREE不相等。Makefile中定义这两个变量,其实就是为了记录编译后的.o文件往哪里放,就是为了实现O=xx的这种编译方式的。
代码在 92 93 行:
1 MKCONFIG := $(SRCTREE)/mkconfig 2 export MKCONFIG
Makefile中定义的一个变量(在这里定义,在后面使用),它的值就是我们源码根目录下面的mkconfig。这个mkconfig是一个脚本,这个脚本就是uboot配置阶段的配置脚本。
代码在 112 到 161 行:
1 ######################################################################### 2 # 此句判断有没有生成include/config.mk文件,有这个文件则makefile 认为是配置过了 make xxx_defconfig。 3 ifeq ($(OBJTREE)/include/config.mk,$(wildcard $(OBJTREE)/include/config.mk)) 4 5 # load ARCH, BOARD, and CPU configuration,包含 include/config.mk 文件 6 include $(OBJTREE)/include/config.mk 7 export ARCH CPU BOARD VENDOR SOC 8 9 ifndef CROSS_COMPILE 10 ifeq ($(HOSTARCH),ppc) 11 CROSS_COMPILE = 12 else 13 ifeq ($(ARCH),ppc) 14 CROSS_COMPILE = powerpc-linux- 15 endif 16 ifeq ($(ARCH),arm) 17 CROSS_COMPILE = arm-linux- 18 endif 19 ifeq ($(ARCH),i386) 20 ifeq ($(HOSTARCH),i386) 21 CROSS_COMPILE = 22 else 23 CROSS_COMPILE = i386-linux- 24 endif 25 endif 26 ifeq ($(ARCH),mips) 27 CROSS_COMPILE = mips_4KC- 28 endif 29 ifeq ($(ARCH),nios) 30 CROSS_COMPILE = nios-elf- 31 endif 32 ifeq ($(ARCH),nios2) 33 CROSS_COMPILE = nios2-elf- 34 endif 35 ifeq ($(ARCH),m68k) 36 CROSS_COMPILE = m68k-elf- 37 endif 38 ifeq ($(ARCH),microblaze) 39 CROSS_COMPILE = mb- 40 endif 41 ifeq ($(ARCH),blackfin) 42 CROSS_COMPILE = bfin-elf- 43 endif 44 ifeq ($(ARCH),avr32) 45 CROSS_COMPILE = avr32- 46 endif 47 endif 48 endif 49 50 export CROSS_COMPILE
标签:自带 不同 替换 upper 覆盖 UNC || compile lin
原文地址:https://www.cnblogs.com/kele-dad/p/8886934.html