历史上的今天
今天是:2025年04月15日(星期二)
2018年04月15日 | TQ2440移植u-boot-2010.06-rc1---1调试的思路
2018-04-15 来源:eefocus
硬件:
开发板: TQ2440
仿真器: openJtag
软件:
系统: XP + vmware虚拟ubuntu_10.10
编译: ubuntu_10.10下/opt/EmbedSky/crosstools_3.4.5_softfloat/gcc-3.4.5-glibc-2.3.6/arm-linux/bin/
调试环境: XP + eclipse + OpenOCD_GUI
u-boot版本: u-boot-2010.06-rc1
一. 调试环境
用openjtag调试与烧到nand_flash中运行基本相同,就是有两点不一样: 一是跳过了memory初始化过程 二是跳过了从flash中读取数据到内存
1.1 用openjtag调试时,需要把arch/arm/cpu/arm920t/start.S中的
#ifndef CONFIG_SKIP_LOWLEVEL_INIT
#if 0
bl cpu_init_crit
#endif
#endif
cpu_init_crit注掉。
1.2 同时在 board/samsung/smdk2410/config.mk 中将改TEXT_BASE为:
TEXT_BASE=0x33000000
这会导致arch/arm/cpu/arm920t/start.S跳过从nand_flash中读取uboot到memory的过程。
因为当前运行地址为0x33000000, 程序的链接地址TEXT_BASE=0x33000000
程序的加载地址与运行地址是相等的, 所以
adr r0, _start /* r0 <- current position of code */
ldr r1, _TEXT_BASE /* test if we run from flash or RAM */
cmp r0, r1 /* don't reloc during debug */
beq clear_bss
都是在memory中,就不执行从nand_flash中读取uboot了.
1.3 在config.mk中
153 DBGFLAGS= -g3 # -DDEBUG
154 OPTFLAGS= -O0 #-fomit-frame-pointer
说明:
1. -glevel:
Level 1输出最少量的信息,仅够在不打算调试的程序段内backtrace.包括函数和外
部变量的描述,但是 没有局部变量和行号信息.
Level 3包含更多的信息,如程序中出现的所有宏定义.当使用-g3选项的时候,某些
调试器支持 宏扩展.
2. 将-Os改为-O0:
不去掉-Os,如果在调试时,函数会乱跳,但还不是出错的乱跳,出现这种令人抓乱的情况时,就需要考虑是不是优化的太多了,把-Os改为-O0重新编译一下就ok了!
1.4 但是对于1.3中改DBGFLAGS= -g3,会引起u-boot.lds生成不正常
需要在Makefile中做一点小小的处理,将CPPFLAGS中的-g3替换成-g,生成新的CPPFLAGS
273 TEMPCPPFLAG=$(subst g3,g, $(CPPFLAG))
368 $(obj)u-boot.lds: $(LDSCRIPT)
369 $(CPP) $(TEMPCPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$^ >$@
1.5 重新编译之后,将虚拟机中的u-boot复制到windows下的目录里,就可以利用openjtag在eclipse里面进行单步调试了.(具体的设置方法请参见)
二.测试代码:
网上有很多移植的教程,按照教程一步步来做肯定会移植好u-boot的,但是如果在移植过程中出现了错误如何定位呢?下面给出一些测试代码来验证功能是否正常.
1. 测试内存正常的代码
/*write 0x12345678 to 0x30000000*/
ldr r0, =0x30000000
ldr r1, =0x12345678
str r1, [r0]
/*read from 0x30000000 && compare*/
ldr r2, =0x30000000
ldr r0, [r2]
cmp r1, r0
bne ledon
deadloop:
b deadloop
ledon:
ldr r0, =0x56000010
ldr r1, =0x15400
str r1, [r0]
ldr r0, =0x56000014
ldr r1, =0x160
str r1, [r0]
deadloop2:
b deadloop2
使用说明: u-boot移植过程中,一般要进行memory初始化,初始化好memory之后,拿上面这一段代码测试一下。如果led灯亮,说明有错误。
思路: 向内存的起始地址0x30000000写一个数0x12345678,然后读取出来,若相等,则说明memory初始化正常。
注意:arm好像没有直接读取内存到寄存器的指令,mov r3, #0 然后再用ldr ldr r3, [r3]
2. 测试nand flash 读写正常
SMDK2410 # nand write 0x30000000 0x40000 0x10000
NAND write: device 0 offset 0x40000, size 0x10000
65536 bytes written: OK
SMDK2410 # nand read 0x30000000 0x40000 0x100
NAND read: device 0 offset 0x40000, size 0x100
256 bytes read: OK
SMDK2410 # md.b 0x30000000 0x10
30000000: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ................
需要用到u-boot的命令(nand read 与 nand write 和md)
nand write: 将数据从memory的0x30000000长度0x10000写入到nand的0x40000处
nand read: 将数据从nand的0x40000长度为0x10000写入到memory的0x30000000处
md.b : 按字节显示memory的0x30000000长度为0x10的数据
史海拾趣
|
【一个快速查找datasheet 的小工具来自datasheet5.com】 本帖最后由 paulhyde 于 2014-9-15 04:21 编辑 一个很好的下载datasheet的小工具,避免大赛的时候到处找资料 不到1M,但功能超强,基本所有的资料都可以下载到哦 datasheet5.com … 查看全部问答> |
|
写了个SHELL,如下: #!/bin/bash hello=\"$(dirname ./configure)\" echo $hello 运行结果为:空行 在终端下输入 hello=\"$(dirname ./configure)\" echo $hello 运行结果为:. 奇怪的是:shell下结果是错误的,终端下是正确的 ...… 查看全部问答> |
|
一段时间没用,结果再用的时候提示 下面图片的情况 error:simulator failed to initialize before timeout 重装也没有用:(郁闷死了 是什么原因啊? [s:6]… 查看全部问答> |
|
参考手册 表37 带刹车功能的互补输出通道 OCx 和 OCxN 的控制位中 当MOE,OSSI,OSSR,CCxE,CCxNE = 1,X,0,0,0时,OCx=CCxP, OCxN=CCxNP ...… 查看全部问答> |
|
刚开始学些,有个问题总没有搞清楚,请教各位大侠。 <<<<< >>>>>>> 部分为不清楚的地方,恳请指教一下。多谢了 #include<msp430x14x.h> /* REGISTER: BCSCTL1 XT2OFF XTS DIVA.1 DIVA.0 ...… 查看全部问答> |
|
中断出来的PWM怎么没有时间差啊 祈求各位大神帮助#include <msp430x14x.h>#include <math.h>#define uint unsigned int#define uchar unsigned char #define ulong unsigned long#define keyin (P1IN & 0x ...… 查看全部问答> |
|
STM32F0-Discovery是ST意法半导体公司推出的最新一款开发板探索套件。Discovery探索套件是ST开发的系列低成本开发评估板,通常集成了微控制器的最小系统和板载的仿真工具,形成一个完整的开发平台。这次收到的STM32F0-Discovery是最新的基于ARM Cor ...… 查看全部问答> |




