WDS1期第9课 uboot 1 之make配置文件和Makefile部分内容

重新编译uboot的过程:

1. tar xjf u-boot-1.1.6.tar.bz2    解压
2. cd u-boot-1.1.6/                到目录下
3. patch -p1 < ../u-boot-1.1.6_jz2440.patch  打补丁 
4. make 100ask24x0_config                    配置make
5. make                                      make

分析Makefile,找到100ask24x0_config:

100ask24x0_config	:	unconfig
	@$(MKCONFIG) $(@:_config=) arm arm920t 100ask24x0 NULL s3c24x0

第一个MKCONFIG在这里定义:
MKCONFIG := $(SRCTREE)/mkconfig,第二个解析为:
100ask24x0
所以相当于:
mkconfig 100ask24x0 arm arm920t 100ask24x0 NULL s3c24x0

打开mkconfig文件,以下分析mkconfig

[ "${BOARD_NAME}" ] || BOARD_NAME="$1"
[ $# -lt 4 ] && exit 1
[ $# -gt 6 ] && exit 1

如果BOARD_NAME为空,则BOARD_NAME赋值为第一个参数($1 100ask24x0),$0 $1 $2 $3分别表示命令顺序的字符,如$0为mkconfig。再往下,如果参数小于4个则退出,如果参数大于6个则退出。

# Create link to architecture specific headers
if [ "$SRCTREE" != "$OBJTREE" ] ;

在Makefile中BUILD_DIR没有值

OBJTREE		:= $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR))
SRCTREE		:= $(CURDIR)

所以$SRCTREE = $OBJTREE,在mkconfig中将执行下面:

else
	cd ./include
	rm -f asm
	ln -s asm-$2 asm

其中删除asm,建立新的软件接asm链接到asm-arm。加入在源码里边写include <asm-i386/type.h>/<asm-arm/type.h>修改麻烦,这样就直接在编译时临时配置就可以,在源码里只需要写include <asm/type.h>。编译配置参数指定arm,链接之后就是asm就是asm-arm。
在这里插入图片描述
删除 asm-arm/arch文件夹:

rm -f asm-$2/arch

如果第6个参数为空 或者 等于NULL,不满足,第六个参数为s3c24x0

if [ -z "$6" -o "$6" = "NULL" ] ; then
	ln -s ${LNPREFIX}arch-$3 asm-$2/arch
else
	ln -s ${LNPREFIX}arch-$6 asm-$2/arch
ln -s ${LNPREFIX}arch-$6 asm-$2/arch
LNPREFIX没有定义,所以解析为:
ln -s arch-s3c24x0 asm-arm/arch
为arch-s3c24x0创建软链接为asm-arm/arch

在这里插入图片描述
继续往下走,条件成立删除,然后创建软链接:
ln -s proc-armv asm-arm/proc

if [ "$2" = "arm" ] ; then
	rm -f asm-$2/proc
	ln -s ${LNPREFIX}proc-armv asm-$2/proc

在这里插入图片描述

#Create include file for Make

>新建一个文件config.mk,>>追加内容,

echo "ARCH   = $2" >  config.mk
echo "CPU    = $3" >> config.mk
echo "BOARD  = $4" >> config.mk

如果第5个参数存在并且不等于NULL,追加第5个参数到config.mk文件
如果第6个参数存在并且不等于NULL,追加第6个参数到config.mk文件

[ "$5" ] && [ "$5" != "NULL" ] && echo "VENDOR = $5" >> config.mk

[ "$6" ] && [ "$6" != "NULL" ] && echo "SOC    = $6" >> config.mk

config.mk文件的内容如下:
在这里插入图片描述

# Create board specific header file

前面APPEND=no,>新建config.h文件,追加内容到config.h

if [ "$APPEND" = "yes" ]	# Append to existing config file
then
	echo >> config.h
else
	> config.h		# Create new config file
fi
echo "/* Automatically generated - do not edit */" >>config.h
echo "#include <configs/$1.h>" >>config.h

config.h文件的内容如下:
在这里插入图片描述以上生成的两个配置文件在Makefile中都会用到。

前面分析配置文件,以下分析编译的过程

在Makefile中会导出config.mk中的变量,通过这些变量来配置交叉编译工具等等:

# load ARCH, BOARD, and CPU configuration
include $(OBJTREE)/include/config.mk
export	ARCH CPU BOARD VENDOR SOC
...
...
ifeq ($(ARCH),arm)
CROSS_COMPILE = arm-linux- 

CPU= arm920t

OBJS  = cpu/$(CPU)/start.o

BOARDDIR BOARD

LIBS  = lib_generic/libgeneric.a
LIBS += board/$(BOARDDIR)/lib$(BOARD).a
LIBS += cpu/$(CPU)/lib$(CPU).a

为了得到u-boot.bin,需要依赖u-boot(elf格式),

ALL = $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map $(U_BOOT_NAND)

all:		$(ALL)

$(obj)u-boot.hex:	$(obj)u-boot
		$(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@

$(obj)u-boot.srec:	$(obj)u-boot
		$(OBJCOPY) ${OBJCFLAGS} -O srec $< $@

$(obj)u-boot.bin:	$(obj)u-boot
		$(OBJCOPY) ${OBJCFLAGS} -O binary $< $@

$(obj)u-boot.img:	$(obj)u-boot.bin
		./tools/mkimage -A $(ARCH) -T firmware -C none \
		-a $(TEXT_BASE) -e 0 \
		-n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \
			sed -e 's/"[	 ]*$$/ for $(BOARD) board"/') \
		-d $< $@

$(obj)u-boot.dis:	$(obj)u-boot
		$(OBJDUMP) -d $< > $@

而u-boot(elf格式),LD链接,LDFLAGS链接的一些参数,__OBJS所有的.o文件。在make的最后命令就是链接命令,所以在make之后可以查看最终到解析的内容。

$(obj)u-boot:		depend version $(SUBDIRS) $(OBJS) $(LIBS) $(LDSCRIPT)
		UNDEF_SYM=`$(OBJDUMP) -x $(LIBS) |sed  -n -e 's/.*\(__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
		cd $(LNDIR) && $(LD) $(LDFLAGS) $$UNDEF_SYM $(__OBJS) \
			--start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \
			-Map u-boot.map -o u-boot

解析到链接的输出内容如下,:

UNDEF_SYM=`arm-linux-objdump -x 
lib_generic/libgeneric.a 
board/100ask24x0/lib100ask24x0.a 
cpu/arm920t/libarm920t.a cpu/arm920t/s3c24x0/libs3c24x0.a lib_arm/libarm.a 
fs/cramfs/libcramfs.a fs/fat/libfat.a fs/fdos/libfdos.a 
fs/jffs2/libjffs2.a fs/reiserfs/libreiserfs.a fs/ext2/libext2fs.a 
net/libnet.a disk/libdisk.a 
rtc/librtc.a 
dtt/libdtt.a 
drivers/libdrivers.a drivers/nand/libnand.a drivers/nand_legacy/libnand_legacy.a drivers/usb/libusb.a drivers/sk98lin/libsk98lin.a 
common/libcommon.a |sed  -n -e 's/.*\(__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
	
cd /media/xxxxx/DA18EBFA09C1B27D/韦东山/修改加笔记/uboot相关/u-boot-1.1.6 && 
arm-linux-ld -Bstatic 
-T /media/xxxxx/DA18EBFA09C1B27D/韦东山/修改加笔记/uboot相关/u-boot-1.1.6/board/100ask24x0/u-boot.lds 
-Ttext 0x33F80000  
$UNDEF_SYM 
cpu/arm920t/start.o \
		--start-group lib_generic/libgeneric.a board/100ask24x0/lib100ask24x0.a 
cpu/arm920t/libarm920t.a cpu/arm920t/s3c24x0/libs3c24x0.a
lib_arm/libarm.a fs/cramfs/libcramfs.a 
fs/fat/libfat.a fs/fdos/libfdos.a fs/jffs2/libjffs2.a fs/reiserfs/libreiserfs.a fs/ext2/libext2fs.a 
net/libnet.a disk/libdisk.a 
rtc/librtc.a dtt/libdtt.a 
drivers/libdrivers.a drivers/nand/libnand.a drivers/nand_legacy/libnand_legacy.a drivers/usb/libusb.a drivers/sk98lin/libsk98lin.a 
common/libcommon.a --end-group  \
		-Map u-boot.map -o u-boot
		
arm-linux-objcopy --gap-fill=0xff -O srec u-boot u-boot.srec
arm-linux-objcopy --gap-fill=0xff -O binary u-boot u-boot.bin

总结上面的一堆,链接文件 就是依赖链接脚本(.lds) 和 原材料(.a)。
查看这些原材料(库)是怎么组织起来的,顺序是什么,需要查看链接脚本u-boot-1.1.6/board/100ask24x0/u-boot.lds,

SECTIONS
{
	. = 0x00000000; 

当前地址为0,在链接的结果中看到-Ttext 0x33F80000,所以相加等于0x33F80000,之后的代码放到内存的0x33F80000,依次放cpu/arm920t/start.o的代码段(.text),board/100ask24x0/boot_init.o (.text)和其他所有文件的代码段*(.text),所有文件的只读数据段*(.rodata),(.data)数据段,(.u_boot_cmd)等等
在这里插入图片描述由上分析可知,从内存0x33F80000首先运行的是cpu/arm920t/start.S,然后是board/100ask24x0/boot_init.o,然后分析start.o就可以知道uboot的大概流程。

总结:

  1. cpu/arm920t/start.S
  2. 链接地址board/100ask24x0/u-boot.lds 和 0x33F80000

uboot根目录下的文件config.mk ,

LDFLAGS += -Bstatic -T $(LDSCRIPT) -Ttext $(TEXT_BASE) $(PLATFORM_LDFLAGS)

EXT_BASE在board/100ask24x0/config.mk

TEXT_BASE = 0x33F80000

可以通过修改board/100ask24x0/config.mk中的TEXT_BASE来改变uboot的地址,
0x33F80000是64MSDRAM的最上面往回512k的地址,若uboot超过512k需要往下修改TEXT_BASE的值;若自己的SDRAM不是64M也需要修改。
内存0x30000000 ~ 0x34000000 共 64M(0x4000000),
最上端512k(0x80000),所以0x34000000-0x80000=0x33F80000

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值