我有两个PIC32MX微控制器,它们通过带有芯片选择的1.53MHz的SPI bus连接。我无法使我的从属端中断服务程序正确传输数据。作为一个测试案例,我让主设备每10 ms发送两个字节(0x01,0x00)。从机应接收0x01命令ID,并在主机发送第二个字节(虚拟0x00)时以0x02响应。在PIC32上实现SPI从器件ISR?
理想情况下,每个传输应该看起来像这样。
主从
0×01 0×00
0×00 0×02
我真的不知道从哪里开始从中断虽然。我使用名为airsysTx的fifo缓冲区来保存下次主服务器发出请求时需要移出的数据。从设备从主设备接收到0x01就好了,当它从设备上写入0x02到FIFO缓冲区。我不知道如何对中断进行编码,以确保正确传输。我在下面的代码是一个好的开始,但它是错误的。建议?
/*******************************************************************************
* Interrupt service routine for SPI3 interrupts from Air MCU.
* The user's code at this vector should perform any application specific
* operations and MUST clear the SPI3 interrupt flags before exiting.
******************************************************************************/
void __ISR(_SPI_3_VECTOR, ipl7) _SPI3Interrupt()
{
BYTE MasterCMD;
SET_D1();//Set debug LED
// RX INTERRUPT
if(IFS0bits.SPI3RXIF) // receive data available in SPI3BUF Rx buffer
{
MasterCMD = SPI3BUF;
if(AirCMD == 0x01)
{
airsysTxFlush();
airsysTxWrite(0x02);
}
}
//Transmit data if needed.
if(SPI3STATbits.SPITBE)
{
if(!airsysTxIsEmpty())
{
SPI3BUF = airsysTxRead();
}
else
{
//Else write 0 to the tx buffer to clear the spi shift reg
SPI3BUF = 0x00;
}
}
IFS0bits.SPI3RXIF = 0;
IFS0bits.SPI3TXIF = 0;
IFS0bits.SPI3EIF = 0;
SPI3STATbits.SPIROV = 0;// clear the Overflow
CLEAR_D1();//CLEAR Debug LED
} // end ISR
这段代码实际上是传递是这样的:
理想的每次传输应该是这样的。
主从
0×01 0×02
0×00 0×01
确实。当你得到RX标志或从机选择时,开始铲除数据已经太迟了,除非你所做的只是在数据寄存器发生单次写入时。当主控制器决定取数据时,数据应该已经在SPI数据寄存器中可用。 – Lundin 2012-04-25 13:20:47