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。
急需你们的帮助,感谢感谢!!