完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
void FIQ_Handler(void) /*__irq*/ { if(FIQSTA I2C0_SLAVE) { if(I2C0SSTA 0x08) //receive IRQ { i2cbuffer[num++] = I2C0SRX; for(i=0;i<100;i++); } }}int main(void){ SYSInit(); GPIOInit(); I2CInit(); FIQ = FIQ_Handler; FIQEN = 0x200; while(1) { }}
核心接收测试代码是这样的,主机我换过3种不同型号的开发板,通过I2C和aduc7026通信,连续发送N byte,aduc7026这边的现象都是一样,所以排除主机这边的问题。主机设置的I2C时钟频率是100K,aduc7026从机这边设置的系统时钟是41.78M。 现象描述:以上贴的从机代码是可以正确接收主机数据的,您也看到了,在中断服务程序里只能加入一个for循环做延迟,才能保证及时并且反复的进入中断从接收寄存器中取数。(这个是为啥?) 更严重的现象是,whie(1)循环内,加入任何操作,即使是个普通赋值都会影响I2C的数据接收,通过仿真器在线调试,如果在while(1)加入任何代码,主机发送N byte,从机只会响应一次中断;如果将while(1)里的代码全部删除,就会响应N次中断。 这个现象已经困扰我一周多了,从编译环境到硬件到软件反复的在查,没发现根源,求助!是否aduc7026做I2C slave有特殊设置?还有是否能给我一份你们aduc7026的工程,因为不知道是否是因为我的keil工程设置有问题,我的编译仿真环境是keil 4.6+ulink2。 急需你们的帮助,感谢感谢!! |
|
相关推荐
1个回答
|
|
根据提供的代码片段,该代码似乎用于处理I2C从设备的FIQ(快速中断请求)处理程序。
该代码检查I2C0_SLAVE中断是否被触发。如果是,则检查I2C0SSTA寄存器是否包含值0x08。 如果条件为true,则表示已发生接收IRQ。在这种情况下,执行块内部的代码。代码似乎将接收到的数据(I2C0SRX)存储到一个名为“i2cbuffer”的数组中,并递增计数器变量“num”。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
503 浏览 0 评论
求助一下关于51系列单片机的Timer0的计时问题,TH0、TL0+1的时间是怎么算的?
1756 浏览 1 评论
【RA-Eco-RA4E2-64PIN-V1.0开发板试用】开箱+Keil环境搭建+点灯+点亮OLED
1183 浏览 0 评论
【敏矽微ME32G070开发板免费体验】使用coremark测试敏矽微ME32G070 跑分
1053 浏览 0 评论
【敏矽微ME32G070开发板免费体验】开箱+点灯+点亮OLED
1287 浏览 2 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12022 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-23 22:43 , Processed in 0.614049 second(s), Total 73, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号