MT7688 坑爹的 SPI Master 半双工全双工问题

MTK的东西便宜是真的便宜,好用也相对比较好用,但是总有那么几个地方,让人用着心里就窝火,就MT76x8来说,第一个窝火的地方就是启动跳线选择,非得把串口用作启动跳线,导致调试起来非常麻烦,第二个就是本文要说的SPI问题,此问题分析和测试了很久,主要是关于spi 半双工和全双工的问题。

首先,来看下datesheet关于SPI Master的描述:

一共就这么几个寄存器:

关于半双工和全双工的描述在SPI_MASTER的BIT10

仅仅只有more_buf_mode=1时,全双工才有效;

关于more_buf_mode的描述如下:

即当more_buf_mode = 0时,spi控制器的传输数据域最多有2个字节,等于1时,最多有8个字节;此处为什么写传输数据域,不是最多发送字节数,继续看关于more_buf_mode的描述

等于0,即只能工作于半双工模式;等于1,可以选择半双工,也可以全双工;此处我们只分析1的情况,因为0传输的数据是在太少了;

等于1 及 半双工时:SPI_OP_ADDR 寄存器也用作了数据寄存器,加上D0-D8几个,一共9个寄存器,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值