完善资料让更多小伙伴认识你,还能领取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; ] |
|
|
|
只有小组成员才能发言,加入小组>>
344 浏览 1 评论
539 浏览 2 评论
NA555DR VCC最低电压需要在5V供电,为什么用3.3V供电搭了个单稳态触发器也使用正常?
783 浏览 3 评论
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
655 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1138 浏览 1 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
73浏览 29评论
237浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
261浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
208浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
67浏览 13评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-26 03:34 , Processed in 1.045976 second(s), Total 81, Slave 65 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号