以前常直接调用接口函数来使用,但这一次需要自己实现这些硬件的基本程序,发现对于SPI还是没有真正理解。做的过程中遇到了一些小问题,思考并记录下来。
SPI是由发送驱动时钟线工作的,在发送的同时,有数据移位进入接收寄存器,至少在STM8和STM32上是这样。
所以无论是进行读或写,实际上硬件都操作了硬件中的发送和接收寄存器。
所以这中间,对于底层SPI而言只需要一个函数就可以实现数据接收与发送。
但是对于具体操作的芯片而言要具体问题具体分析。
写数据的过程可能差不多,
但是读的过程可能会千差万别。
在读的时候,发送什么数据,可能是他们之间最大的差别。
还有一个是时钟,SPI时钟的设置需要符合操作新芯片的时序。这个是由具体芯片的时序决定的。
即:什么时间数据应该稳定,什么时间允许数据变化,需要读取多少个字节。在读取结束后,时钟线应该处于低电平还是高电平。
当操作结束后,需要进行的就是禁止芯片的SPI,这个时候操作基本是类似的。首先判断发送是否结束,判断是否忙碌,如果都符合就禁止芯片的SPI。