zynq调试记录

调试记录

ddr测试

在新板卡制作完成,回来进行上电运行程序测试的时候,有可能会出现程序运行异常的情况,这时候我们可以首先使用SDK里面的dram测试工程先测试,保证ddr测试通过后,在进行下面的开发工作。

启动模式设置

zynq的启动模式是通过读取外部IO口的状态来设置的,如下表:
在这里插入图片描述

这里就引入了一个问题,烧写程序时候需要用到j-tag,但是启动程序需要用到其他的配置模式,调试阶段或者后期产品维护的时候就需要修改硬件(增加按键/拨码开关)的方式来满足不同的使用模式。那么怎么能够不修改硬件满足所有的使用环境呢?
我发现,在sdk生成的fsbl工程中,有一句话是去读取外部io状态的,通过这段程序来判断我们需要使用哪种模式,那不如我就做两个fsbl文件,并且控制这两个文件不读取io状态而是通过指定特定的模式,最后修改代码,屏蔽掉读取io状态部分即实现了想要的功能,修改的地方如下:

BootModeRegister = Xil_In32(BOOT_MODE_REG);
//BootModeRegister &= BOOT_MODES_MASK;
BootModeRegister = JTAG_MODE;

屏蔽的部分既是驱动读取到的io模式,我们指定BootModeRegister 为 JTAG_MODE就可以在外部io设置为spiflash启动的时候,通过j-tag烧写固件,固件中使用的fsbl我们打开屏蔽的代码段,便可正常通过spiflash启动。


有问题可以相互讨论,我也是小白,微信 yucaohua001

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值