完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
本帖最后由 一只耳朵怪 于 2018-6-25 11:36 编辑
大家新年好!请教个主机重启后的PCIe重新建链问题。 我想实现主机重启后,dsp 6670自动恢复PCIe连接,解决方法有以下2个: 1、在主循环while(1)里,循环检测DEBUG0寄存器的LSSM_STATE位,如果不为0x11,则触发Hard Reset,重新启动EEPROM中的IBL代码,在该代码中进行PCIe的初始化。这种方法能实现自动建链。但我感觉这样效率有点低。 2、另一种方法是开启PCIe的PCIEXpress_PM_INT中断,主机重启时,会触发该中断,然后在中断服务程序里进行PCIe的初始化(包括pcie powerDown)或触发Hard Reset。该方法有个问题,即主机重启后,不能完成建链,需要主机再重启一次才能完成链路的建立。 我发现PCIEXpress_PM_INT中断触发的时间有点晚,即错过了主机枚举PCIE设备的时间。通过测试,LSSM_STATE!=0x11的时间要比PCIEXpress_PM_INT中断早,差不多早200us左右。 为什么会出现上述情况呢?硬件情况如下:2个dsp 6670通过PCIE switch与主机相连。 |
|
相关推荐
3个回答
|
|
问题解决了。采用Keystone1 软件开发包中的pcie初始化代码就好了。
|
|
|
|
Helsin, 很高兴得知问题得到解决,也非常感谢分享解决问题的方法! 我还有一个问题请教,PCIEXpress_PM_INT中断触发的时间还是有200us的时延吗? 您是如何测量到这个时间的? 多谢! Jane |
|
|
|
Sabrina_cc 发表于 2018-6-25 03:23 Jane Lu,你好,我采用以下代码: 在main函数里: cnt = 0; cnt_en = 1; while(1) [ LSSM_STATE = *pDEBUG0 & 0x001F; if (LSSM_STATE != 0x11) [ if (cnt_en == 1) [ cnt++; ] ] ] 在中断服务函数里: void pcie_isr() [ //清中断 cnt_en = 0; ] |
|
|
|
只有小组成员才能发言,加入小组>>
TMS320F28377D:新做了以377d为芯片的板子,上电后芯片复位引脚出现方波请问如何解决?
1888 浏览 0 评论
TPS55340通电后输入端保险丝烧断,芯片输入和GND之间短路
3641 浏览 4 评论
5027 浏览 0 评论
请问如何用DM368对RGB格式的图片数据进行编码生成JPEG格式图片?
1732 浏览 1 评论
9353 浏览 8 评论
CC3100BOOST使用CC3200lunchXL进行烧录
664浏览 2评论
707浏览 1评论
TMS320F28034: 利用C2prog通过SCI给TMS320F28034烧录程序,出现错误提示:Bootloading... failed (invalid echo)!
668浏览 1评论
1186浏览 1评论
求DLPC350 Programmer’s Guide User's Guide 中文版说明书
1189浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-4-19 10:34 , Processed in 0.482969 second(s), Total 45, Slave 40 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号