DSPwilliam hill官网
直播中

nuanyi

8年用户 5经验值
擅长:处理器/DSP
私信 关注

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

初接触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函数执行程序,可是事实上程序好像并没有进入主程序运行.

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

回帖(7)

nuanyi

2016-7-10 09:50:05
昨天把问题解决了,我对自己甚是无语,之前我说电源是没问题的,可是就在昨天发现我的内核电源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,不报错的话应该就下载成功了,断电程序也会保存在芯片中
举报

疯君狂言

2016-7-11 22:08:35
楼主好样的
举报

徐周

2016-7-12 14:48:59
钻研的精神值得学习
举报

伊布先生

2016-7-15 14:52:30
查错思路总结的很好,赞一个
举报

simple_tengk

2016-7-15 15:12:04
引用: nuanyi 发表于 2016-7-10 09:50
昨天把问题解决了,我对自己甚是无语,之前我说电源是没问题的,可是就在昨天发现我的内核电源1.8V,从5V分出后是没问题的,可是接了一个电感之后供给DSP后低到了1.5V,所以导致DSP上电不能正常工作,我之前测得是电感的另一端,测错了。虽然很不应该犯这个错误,但是因为这个错误对DSP各种问题的认识和了解更加加深了,也 ...

应该那不叫电感吧,电感好像对电压影响不是太大。你那个元器件应该叫做磁珠吧?
举报

电子微创意

2016-11-27 15:45:28
鼓励楼主这种分享精神
举报

master_

2017-2-13 11:56:31
什么电感,压降那么大
举报

更多回帖

发帖
×
20
完善资料,
赚取积分