完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
本帖最后由 一只耳朵怪 于 2018-6-19 15:18 编辑
Uint32 KeyStone_SRIO_wait_LSU_completion(Uint32 lsuNum, Uint32 transactionID, Uint32 contextBit) [ Uint32 uiStateIndex= LSU_state_index_table[lsuNum][transactionID]; Uint32 uiCompletionCode; do [ uiCompletionCode=(gpSRIO_regs->LSU_STAT_REG[uiStateIndex/8]>> ((uiStateIndex&7)*4))&0xF; ] while((uiCompletionCode&1) != contextBit); return (uiCompletionCode>>1); ] Int32 KeyStone_SRIO_DirectIO(Uint32 uiLocalAddress, Uint32 uiRemoteAddress, Uint32 uiDestID, Uint32 uiByteCount, Uint32 uiPort, Uint32 uiLSU_No, Srio_Ftype ftype,SRIO_Packet_Type packetType,Uint32 uiIdSize) [ SRIO_LSU_Transfer lsuTransfer; lsuTransfer.rioAddressMSB =0; lsuTransfer.rioAddressLSB_ConfigOffset = uiRemoteAddress; lsuTransfer.localDspAddress = uiLocalAddress; lsuTransfer.bytecount = uiByteCount; lsuTransfer.packetType = packetType; lsuTransfer.ftype = ftype; lsuTransfer.dstID = uiDestID; lsuTransfer.doorbellInfo= 0; lsuTransfer.waitLsuReady= 1; lsuTransfer.lsuNum= uiLSU_No; lsuTransfer.doorbellValid = 0; lsuTransfer.intrRequest = 0; lsuTransfer.supGoodInt = 0; lsuTransfer.priority = 0; lsuTransfer.outPortID = uiPort; lsuTransfer.idSize = uiIdSize; lsuTransfer.srcIDMap = 0; lsuTransfer.hopCount = 0; KeyStone_SRIO_LSU_transfer(&lsuTransfer); return KeyStone_SRIO_wait_LSU_completion(uiLSU_No, lsuTransfer.transactionID, lsuTransfer.contextBit); ] 请教高手,用DIRECTIO函数发送数据的时候,有的时候会在KeyStone_SRIO_wait_LSU_completion里面的do while循环里,不出来,代码如上面所示。请问这个大概是什么问题?但是有的时候他是可以发送数据的。有的时候就会死在里面。 还有一个问题,调用KeyStone_SRIO_DirectIO的时候,如果uiLocalAddress传入的是0xc000000就可以发送出去。而如果是0x860000,就不能发送,请问这是为什么?谢谢 |
|
相关推荐
4个回答
|
|
0x860000是DSP local地址不能直接用于DMA或外设传输,必须转换成global地址在用。参考代码如下:
/*convert local address to global address for DMA on multi-core DSP*/#define GLOBAL_ADDR(addr) ((Uint32)addr<0x1000000? (Uint32)addr+(0x10000000+DNUM*0x1000000): (Uint32)addr) lsuTransfer.localDspAddress = GLOBAL_ADDR(uiLocalAddress); |
|
|
|
lkjljljlj 发表于 2018-6-19 05:46 谢谢你的回答,现在我把地址变成全局地址,数据是可以发出去的。 现在的问题有,我在GPIO中断里,用SRIO送数据到FPGA,现在刚开始是可以发送的,运行一段时间之后。 程序死在下面的函数里,不出来, 请问大概是什么问题?有哪些寄存器,可以大致判断出问题 出在什么地方?谢谢 Uint32 KeyStone_SRIO_wait_LSU_completion(Uint32 lsuNum, Uint32 transactionID, Uint32 contextBit) [ Uint32 uiStateIndex= LSU_state_index_table[lsuNum][transactionID]; Uint32 uiCompletionCode; do [ uiCompletionCode=(gpSRIO_regs->LSU_STAT_REG[uiStateIndex/8]>> ((uiStateIndex&7)*4))&0xF; ] while((uiCompletionCode&1) != contextBit); return (uiCompletionCode>>1); ] |
|
|
|
阿什顿信道 发表于 2018-6-19 05:56 我觉得可能的原因有三个: 1. 硬件链路或对端故障,导致发送阻塞。 2. 发送太快,超过接口的吞吐量导致阻塞。 3. 调用这个等待函数是传进来的参数错误(软件BUG). |
|
|
|
可能是由于发送的次数太频繁导致。现在修改了,程序结构,没有出现该问题,谢谢大神的指导 |
|
|
|
只有小组成员才能发言,加入小组>>
NA555DR VCC最低电压需要在5V供电,为什么用3.3V供电搭了个单稳态触发器也使用正常?
694 浏览 3 评论
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
605 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1065 浏览 1 评论
757 浏览 0 评论
普中科技F28335开发板每次上电复位后数码管都会显示,如何熄灭它?
529 浏览 1 评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
171浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
133浏览 14评论
在使用3254进行录音的时候出现一个奇怪的现象,右声道有吱吱声,请教一下,是否是什么寄存器设置存在问题?
129浏览 13评论
TLV320芯片内部自带数字滤波功能,请问linein进来的模拟信号是否是先经过ADC的超采样?
126浏览 12评论
GD32F303RCT6配置PA4 ADC引脚,将PA2代替key功能,PA2连接时无法实现预期功能,为什么?
64浏览 10评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-28 19:07 , Processed in 0.818898 second(s), Total 53, Slave 47 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号