uboot版本号貌似与实际开发不相关,但是我现在遇到一个bug与版本号关联密切。
这个bug与《uboot
dm9000驱动故障》基本上是一样的,但是在上一篇博文中我没有详细说明。
bug发生现象:
将svn仓库代码通过git-svn下载到本地,然后编译,生成的u-boot-nand.bin通过sd卡烧写到开发板,然后重启开发板,
但是仅仅会重复显示如下信息:
U-Boot 2011.06-00000-gccc7fce-svn222 (May 28 2014 - 09:55:33)Hwgw6410CPU: [email protected]
Fclk = 533MHz, Hclk = 133MHz, Pclk = 66MHz (SYNC Mode)
Board: HWGW6410
DRAM: 128 MiB
之后如果在代码中任意一个源代码文件中添加一个空白字符并保存,然后编译,再通过sd卡烧写,重启开发板后
就能够正常执行uboot所有功能。
这两次生成的u-boot-nand.bin文件大小仅仅相差4个字节(分别为381708和381712个字节)
而这两个版本生成的u-boot-nand.bin惟一的差别就是版本号字符串这个地方不一样,本地编辑文件后未上传到svn仓库时,
其生成的uboot字符串前面这一部分内容如下:
U-Boot 2011.06-00000-gccc7fce-dirty-svn222
仅仅是字符串中多了-dirty这几个字符。
整个u-boot字符串生成过程如下。
在Makefile中:
$(VERSION_FILE):
@( localvers=‘$(shell $(TOPDIR)/tools/setlocalversion $(TOPDIR))‘ ; printf ‘#define PLAIN_VERSION "%s%s"\n‘ "$(U_BOOT_VERSION)" "$${localvers}" ; printf ‘#define U_BOOT_VERSION "U-Boot %s%s"\n‘ "$(U_BOOT_VERSION)" "$${localvers}" ; ) > [email protected]
@( printf ‘#define CC_VERSION_STRING "%s"\n‘ ‘$(shell $(CC) --version | head -n 1)‘ )>> [email protected]
@( printf ‘#define LD_VERSION_STRING "%s"\n‘ ‘$(shell $(LD) -v | head -n 1)‘ )>> [email protected]
@cmp -s [email protected] [email protected] && rm -f [email protected] || mv -f [email protected] [email protected]
Makefile中调用tools/setlocalversion生成localvers,然后根据将U_BOOT_VERSION和localvers串接起来生成PLAIN_VERSION和新的U_BOOT_BESION.
tools/setlocalversion代码如下:
#!/bin/sh
# Print additional version information for non-release trees.usage() {
echo "Usage: $0 [srctree]" >&2
exit 1
}cd "${1:-.}" || usage
# Check for git and a git repo.
if head=`git rev-parse --verify HEAD 2>/dev/null`; then
# Do we have an untagged version?
if git name-rev --tags HEAD | grep -E ‘^HEAD[[:space:]]+(.*~[0-9]*|undefined)$‘ > /dev/null; then
(git describe || git describe --tags || git describe --all --long) 2>/dev/null | awk -F- ‘{printf("-%05d-%s", $(NF-1),$(NF))}‘
fi# Are there uncommitted changes?
git update-index --refresh --unmerged > /dev/null
if git diff-index --name-only HEAD | grep -v "^scripts/package" | read dummy; then
printf ‘%s‘ -dirty
fi# Is this git on svn?
if git config --get svn-remote.svn.url >/dev/null; then
printf -- ‘-svn%s‘ "`git svn find-rev $head`"
fi
fi# Check for svn and a svn repo.
if rev=`svn info 2>/dev/null` ; then
rev=`echo "${rev}" | grep ‘^Revision‘ | awk ‘{print $NF}‘`
printf -- ‘-svn%s‘ $rev
fi# Check for any localversion-* files
printf ‘%s‘ "`cat localversion-* 2>/dev/null`"
在setlocalversion文件中根据svn和git的不同,生成不同的版本号字符串,详细过程可以自己分析。
得到U_BOOT_VERSION后,在arch/arm/lib/board.c中有下面的代码:
const char version_string[] =
U_BOOT_VERSION" (" U_BOOT_DATE " - " U_BOOT_TIME ")"CONFIG_IDENT_STRING;
该代码将U_BOOT_VERSION 以及日期时间以及CONFIG_IDENT_STRING都串接在一起就得到uboot版本号字符串。
我的bug修改方式是将Makefile中PLAIN_VERSION和U_BOOT_VERSION中的localvers删除掉,然后将include/configs/*6410*.h中的
CONFIG_IDENT_STRING字符串中添加一些内容,凑到以前能够成功的长度就可以了。
这个修改方法是有点挫的,但是因为对整个uboot机制的不熟悉,只能用这个方法来作为权宜之计了。