spi_mt7621.c的函数mt7621_spi_set_cs的实现很奇怪,此函数的功能是设置片选信号,但实际上是设置MT7621_SPI_POLAR的内容,查手册,MT7621_SPI_POLAR的功能是定义片选信号是低有效还是高有效。所以,表面上看,似乎实现的功能不大对。但实际上是对的,原因如下:
首先,CS都应该是低电平有效的。初始化时,SPI_MASTER寄存器的rs_slave_sel被设置为7:
master |= 7 << 29;
那就意味着,CS0到CS6都没有被选中,这样,SPI master控制器将CS0和CS1都设置为高(缺省为低电平有效)。然后,需要选中CS1有两种方法:1,设置rs_slave_sel为1。2,设置MT7621_SPI_POLAR,将CS1变为高电平有效。这样,因为rs_slave_sel被设置为7,意味着CS1没有被选中,由于CS1是高电平有效,SPI master控制器就将CS1变为低电平,而这正好“选中”了CS1。