Xilinx SDK程序Debug无法在main函数入口处停住解决

  1. 问题描述:
    采用的芯片是ZYNQ7020,设计好逻辑程序,导出hdf文件后在Xilinx SDK中调试软件程序。采用Debug的方式,发现程序不能在main函数入口停下,且暂停程序时,程序跑飞。
  2. 定位过程
    遇到这个问题,首先在Debug Configuration中配置将stop at program entry这个选项选上,这会让你的程序从软件的第一句开始执行,也就是中断向量表的位置,见下下图。然后可以单步跟踪程序看是在哪里跑飞导致没有进去main函数的。
    Xilinx SDK程序Debug无法在main函数入口处停住解决
    文章图片

    Xilinx SDK程序Debug无法在main函数入口处停住解决
    文章图片

    在我的程序中进行了这样的调试之后,发现第一步就跑飞了!这说明是ZYNQ中的PS最小系统的问题,也就是ARM配置的问题。主要包括:时钟频率的设置,复位,以及DDR配置(Debug时程序是运行在DDR上的)。所以回头去检查ZYNQ中PS系统的配置,ps7_init.html有比较清晰的网页化配置描述,通过与之前正确的版本对比,发现我把PS即ARM的参考时钟设置为33.33MHz了,正确的设置应该是50MHz。修改之后,程序在Debug的时候可以顺利在main函数处停住。
  3. 总结与思考
    程序没有在main函数入口处停住,其实是程序一句也没正常执行过,发现这一点很重要。

    推荐阅读