打印
[仿真]

DSP烧录到Flash中去了,仿真可运行,拔掉仿真器,开电重启不能运行

[复制链接]
3863|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
nuanyiv5|  楼主 | 2016-7-8 17:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
初接触DSP,遇到了问题,望各位大神能帮我分析一下问题,不胜感激。一、问题描述:
1、F28335用CCS4仿真;
2、共两块一样的板子,第一块无论仿真或者拔掉仿真器单机运行都可以正常运行;
3、第二块复制的板子,仿真可以正常运行;然后退出仿真模式,但是仿真器不拔,板子也能正常运行;最后板子断电,拔掉仿真器(两端都拔掉了),然后上电重启,程序不能正常运行;


二、曾经测试以及尝试过的解决办法(以下均为单机运行测试):
1、电源用到5v,3.3v,1.8v,分别测得实际是4.75v,3.25v,1.77v,电源应该是没有问题的;
2、reset 电路测试,上电后reset引脚为高电平,因为采用的是TPS3823专用复位芯片,没有设置手动复位,所以至于有没有正常复位,不是很好判断,所以我采用上电后在地和reset引脚之间用导线手动连接了一下,模拟手动复位后断开,然后软件还是米有正常工作,所以我判断应该不是复位电路的问题(不知道这里的测试方法可靠不哈,如果有问题,望大神提出指正意见)
3、晶振采用33.3333MHZ有源晶振,示波器测试频率正常;
4、是否成功下载到FLASH检查:工程文件中有F28335.cmd文件,DSP2833x_CodeStartBranch.asm,下载时显示擦除flash section后显示load成功,且第一块板子同样的方法单机能够从正常运行,应该是成功下载到Flash中了吧!5、上电引导是否正确:通过资料得知DSP的Flash启动过程如下:
(1)首先硬件配置GPIO84~87上拉为1,即处于Flash启动过程。检查我的84~87引脚全部为高电平。
(2)当DSP复位后,会从复位向量0x3FFFC0处取得复位向量,并跳转到InitBoot处开始执行,InitBoot会读GPIO84~87的值发现全为1判断为Flash启动方式。
(3)然后会跳到0x33FFF6处执行。
总的来说就是:Reset(0x3fffc0)—>initBoot()—>判断启动方式—>codestart(0x33fff6)—>_c_int00—>main函数

我的工程的cmd文件中有如下代码:
MEMORY
{
PAGE 0 :
BEGIN : origin = 0x33FFF6, length = 0x000002 /* Boot to M0 will go here */
...
}
SECTIONS
{...
codestart : > BEGIN PAGE = 0
...}

我的 DSP2833x_CodeStartBranch.asm里面有如下代码:
code_start:
    .if WD_DISABLE == 1
        LB wd_disable       ;Branch to watchdog disable code
    .else
        LB _c_int00         ;Branch to start of boot.asm in RTS library
    .endif
如果说这两个文件是正确的而且复位成功的话,应该能直接引导到main函数执行程序,可是事实上程序好像并没有进入主程序运行.

三、以上方法都检查过,还是找不到原因所在,真是抓狂啊,求高手指导还有可能是什么问题啊?谢谢,非常感谢,感激涕零,重要的事情说三遍,嘿嘿!

相关帖子

沙发
伍戈123| | 2016-7-8 22:31 | 只看该作者
我这两天也在学DSP,用的是2812,也是用CCS4,遇到跟你一样的问题,我的解决是,库文件问题,你替换一下库文件,可以到TI官网找。或者找开发板自带的例程中的库文件替代你现在用的库文件。

使用特权

评论回复
板凳
伍戈123| | 2016-7-8 22:34 | 只看该作者
还有就是BIOS的.cmd内容是否有问题,参考官网或例程中的内容。在一个是硬件设置,2812是下载到flash中必须SCITXDA口为1才行

使用特权

评论回复
地板
nuanyiv5|  楼主 | 2016-7-9 18:42 | 只看该作者
伍戈123 发表于 2016-7-8 22:31
我这两天也在学DSP,用的是2812,也是用CCS4,遇到跟你一样的问题,我的解决是,库文件问题,你替换一下库 ...

你好,请问库文件的选择有什么标准吗?我之前用的是rts2800_fpu32,如果将所有库文件所在的地址导入CCS可以吗?

使用特权

评论回复
5
nuanyiv5|  楼主 | 2016-7-9 18:49 | 只看该作者
伍戈123 发表于 2016-7-8 22:34
还有就是BIOS的.cmd内容是否有问题,参考官网或例程中的内容。在一个是硬件设置,2812是下载到flash中必须S ...

你好,请问BIOS的cmd文件需要注意哪些地方的正确性,我用的TI的,需要改动吗?关于硬件设置,我的F28335是要求84、85、86、87引脚要为高电平

使用特权

评论回复
6
aresc| | 2016-7-9 19:43 | 只看该作者
感觉象是硬件问题,因为如果是软件不行,那另一块板子没道理能正常运行。检查一下复位电路相关的,比如有没有虚焊,等等。

使用特权

评论回复
7
nuanyiv5|  楼主 | 2016-7-10 09:48 | 只看该作者
nuanyiv5 发表于 2016-7-9 18:49
你好,请问BIOS的cmd文件需要注意哪些地方的正确性,我用的TI的,需要改动吗?关于硬件设置,我的F28335 ...

感谢直回答我的问题的人,毕竟第一次发帖,昨天把问题解决了,我对自己甚是无语,之前我说电源是没问题的,可是就在昨天发现我的内核电源1.8V,从5V分出后是没问题的,可是接了一个电感之后供给DSP后低到了1.5V,所以导致DSP上电不能正常工作,我之前测得是电感的另一端,测错了。虽然很不应该犯这个错误,但是因为这个错误对DSP各种问题的认识和了解更加加深了,也学习到了一些新的东西,姑且这样安慰自己吧!
总结:
1、事实印证我之前的推测是正确的,是硬件出的问题,因为一样的程序,软件配置,在同样设计的两块板子上一个正常一个不能运行,大对数情况下应该是硬件的问题;
2、硬件出问题后,先检查电源,直接测试DSP端的电源输入;再有就是晶振是否起振,复位电路是否正确,这些是程序能正常运行的基本要求
3、关于FLASH下载,按我的了解就是保证工程中添加的是flash对应的cmd文件,且保证硬件相应引脚为jump to flash时应该有的电平状态(一般参见所使用芯片的boot room文件,即上电引导相关文件),应该就可以正常下载到flash中了,下载到flash的过程中一般可以看见分为两个过程,第一个过程是erase flash section,第二个是load,不报错的话应该就下载成功了,断电程序也会保存在芯片中

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

主题

5

帖子

0

粉丝