MT7688 SPI 控制器的诡异之处:
在SPI接口的设备驱动中进行发数的过程中利用示波器查看发送数据的SDA和SCL发现,数据总是在发送的过程中右移了一位,比如发送的数据是0xaa 二进制为10101010,然而在示波器中读出的数据为11010101.
现将解决方法及过程记录下来分享给大家:
在判定完自己的驱动无误的情况下,这个问题一直无法解决,最后老大的各种刺激,无奈从底层开始逐个理一遍吧,
(1)我的第一直觉就是控制器驱动写的有问题,可问题是板载的flash也是用的同一个spi控制器啊,那就好好看看吧,结果发现.........
SPI控制器驱动在 drivers/spi/目录下的spi-mt7621.c
static int mt7621_spi_probe(struct platform_device *pdev)
在此probe函数中向spi协议层注册操作函数
457 master->setup = mt7621_spi_setup;//初始化speed 458 master->transfer_one_message = mt7621_spi_transfer_one_message;//此函数供上层调用 459 master->bits_per_word_mask = SPI_BPW_MASK(8); 460 master->dev.of_node = pdev->dev.of_node; 461 master->num_chipselect = 3;//最大支持片选重点跟踪 mt7621_spi_transfer_one_message函数,设备驱动调用spi_sync等函数时其实就是调用此函数进行传输数据.
static int mt7621_spi_transfer_one_message(struct spi_master *master, 371 struct spi_message *m) 372 { 373 struct spi_device *spi = m->spi; 374 int cs = spi->chip_select; 375 376 if (cs) 377 return mt7621_spi_transfer_full_duplex(master, m); 378 return mt7621_spi_transfer_half_duplex(master, m); 379 }注意注意,在此函数函数中就暴漏出来了马脚,由于此SPI控制器支持两个CS片选,板载的flash使用的CS0也就是0号片选,所以当flash驱动写数据时,cs=0,此时走的是半双工模式,而我们使用的是CS1,所以走的是全双工这条线,随后发现全双工模式写的是多么的渣渣啊,所以大胆的屏蔽掉全双工模式,两个片选都走半双工模式,本来打算改写一下全双工模式,可是项目用不上这全双工,再加上项目时间紧所以就先放一放吧.
更改后的代码为:
static int mt7621_spi_transfer_one_message(struct spi_master *master, 371 struct spi_message *m) 372 { 373 struct spi_device *spi = m->spi; 374 int cs = spi->chip_select; 375 376 // if (cs) 377 // return mt7621_spi_transfer_full_duplex(master, m); 378 return mt7621_spi_transfer_half_duplex(master, m); 379 }
至此就改好了SPI控制器驱动了.