char fasong(char byte)
{
while (SPI_I2S_GetFlagStatus(SPI2, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI2, byte); // 这里发送
while (SPI_I2S_GetFlagStatus(SPI2, SPI_I2S_FLAG_RXNE) == RESET);
SPI_I2S_ReceiveData(SPI2); // 这里接收,然后被抛弃掉了
}
SPI虽然是全双工的,但由于是同步串口,只靠主机的时钟信号来启动收发过程,因此你发一个数,同时也收一个数
无论你是否想收数据。同样你想收一个数,也要发一个无效的数。
实际应用中,SPI都是按半双工使用的,做主的一方,发送一个数时,同时也收一个废数丢掉。收的时候,发一个废数,以启动时钟输出。而做从的一方,检测时钟,时钟有了,开始收数,如果有待发的数,同时把数据发出去。
{
while (SPI_I2S_GetFlagStatus(SPI2, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI2, byte); // 这里发送
while (SPI_I2S_GetFlagStatus(SPI2, SPI_I2S_FLAG_RXNE) == RESET);
SPI_I2S_ReceiveData(SPI2); // 这里接收,然后被抛弃掉了
}
SPI虽然是全双工的,但由于是同步串口,只靠主机的时钟信号来启动收发过程,因此你发一个数,同时也收一个数
无论你是否想收数据。同样你想收一个数,也要发一个无效的数。
实际应用中,SPI都是按半双工使用的,做主的一方,发送一个数时,同时也收一个废数丢掉。收的时候,发一个废数,以启动时钟输出。而做从的一方,检测时钟,时钟有了,开始收数,如果有待发的数,同时把数据发出去。