完善资料让更多小伙伴认识你,还能领取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; ] |
|
|
|
只有小组成员才能发言,加入小组>>
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
567 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1018 浏览 1 评论
657 浏览 0 评论
普中科技F28335开发板每次上电复位后数码管都会显示,如何熄灭它?
493 浏览 1 评论
1015 浏览 0 评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
117浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
90浏览 14评论
在使用3254进行录音的时候出现一个奇怪的现象,右声道有吱吱声,请教一下,是否是什么寄存器设置存在问题?
104浏览 13评论
TLV320芯片内部自带数字滤波功能,请问linein进来的模拟信号是否是先经过ADC的超采样?
99浏览 12评论
TPA6304-Q1: TPA6304 两片公用一组I2C的话,其中一片配置不成功怎么办
125浏览 10评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-5 05:10 , Processed in 1.043391 second(s), Total 83, Slave 67 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号