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

在MT7688的SPI接口驱动中遇到数据右移一位的异常,通过示波器观察到实际发送数据与预期不符。在确认驱动无误后,深入分析SPI控制器驱动代码,发现drivers/spi/spi-mt7621.c中的mt7621_spi_probe函数存在问题。修改该函数后,成功解决了SPI数据移位的问题,确保了SPI控制器的正常工作。
摘要由CSDN通过智能技术生成

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 
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值