十二、u-boot 调试--串口修改

  uboot 烧写进 norflash 进行调试

12.1 烧写后 串口不使能

  内存不能使能

  遍历代码,可以发现,在SDRAM 初始化之前,我们并没有设置时钟,但是SDRAM初始化后,我们已经开始用内存控制器了,这是不合理的,操作器件之前,我们必须把时钟给初始化。

  在源代码中,内存控制器初始化之前,并没有进行时钟的设置。加上时钟的设置。

  内存控制器的时钟 为MPLL,我们要把 MPLL 的初始化放入到 start.S 中进行初始化,取消board_init_f 执行的链表 init_sequence_f 的 board_early_init_f 函数中对MPLL 的设置即可。

  源代码的时钟的设置在 board_init_f 执行的链表 init_sequence_f 的 board_early_init_f 函数中,我们要把这些代码移动到 _start.S 中执行,在内存控制器初始化之前。

12.1.1 修改 start.S 中的代码

  

12.1.2 注释掉 jz2440.c 对MPLL 的设置

  board_early_init_f 中

  

12.1.3 编译烧写

  

12.2 调试方法

  打开 openjtag 工具:

  

扫描二维码关注公众号,回复: 118432 查看本文章

  点击 connect,然后点击 telnet,进入 telent 中运行:

  reset halt,

  

  halt

  

  读写前 4个 字节 ,与 uboot.bin 的二进制进行对比:

    

  uboot.bin 中的字节:

  

  可以看出读取的数据是正确的。

  从 step 0 开始执行,一步一步 查看数据是否正确:

  

  这样运行很慢,我们也可以将 uboot 文件进行 objdump 转码成 uboot.dis 文件,然后设置断点。

  在 board_init_f_alloc_reserve 这里设置断点,因为执行完了内存控制器初始化后,就开始执行此函数:

  uboot.dis  文件中的地址:

  

  

  我们在 0008444 那里设置一个硬件断点:

  

  然后  resume 继续执行:

  

  可以看出在 0x00008444 处暂停了,此时 内存已经初始化完了,应该是可以访问内存的。

  读内存:mdw 0x30000000

  

  写内存:mww 0x30000000 0x12345678,写完之后读取内存 mdw 0x30000000

  

12.1.2

  

    

  

猜你喜欢

转载自www.cnblogs.com/kele-dad/p/8998992.html