MT7688 SPI 数据移位问题 SPI控制器驱动更改 openwrt(linux-3.18.29)

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 }

随后重新编译内核就OK,记得刷机哦....

至此就改好了SPI控制器驱动了.

你可能感兴趣的:(SPI,openwrt,GPIO,MT7688)