你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

Linux设备开发SPI对应的脚都被用咋办?

[复制链接]
gaosmile 发布时间:2020-12-4 22:00
[导读] 干过单片机的盆友或许都拿IO口对着时序模拟过SPI主控制器,在做嵌入式Linux设备开发时,发现SPI对应的脚都被用了,或者被当成别的用途了,这时候咋办?你或许会说我翻IO口写个字符驱动不就完了么?当然你可以这么做,然而并没有必要。自己写也挺麻烦且未必稳。憋慌!且看本文分解~SPI什么鬼?

SPI(Serial Peripheral Interface) 是一种嵌入式系统中应用广泛的同步串行通信、主从架构式总线接口。80年代由摩托罗拉开发,已成为事实标准。

要理解啥是SPI,先上图,一图胜千言:

微信图片_20201204215536.png

常见的SPI接口有这样几个引脚:

  • SCLK: 串行时钟,总是主端负责输出(Master)。总是由主端控制该信号,从端为输入采样。
  • MOSI:主出从入(Master Output Slave Input)。总是由主端控制该信号,从端为输入采样。
  • MISO:主入从出(Master Input Slave Output)。总是由从端控制该信号,主端为输入采样。
  • :从选择信号(Slave Select)。总是由主端控制该信号,从端为输入采样。& ~; g" ]5 u% d$ n, I

常见的两种总线连接方式,

方式一:独立片选# T- R3 K& v" Z; s8 [/ ^

微信图片_20201204215539.png

* T! o" j4 \! z# b: Q

每个从设备都有独立的片选引脚,主机同一时间段内,与一个从设备进行通信,也即选中一个从设备,其他线并接共用. x# d" q/ ^, {2 [3 S( f0 ^
方式二:菊花链
( V8 W+ q& I* o4 M0 ]! a0 I1 G

微信图片_20201204215543.png

SCK/CS共用,数据线入出环形链接,bit流在SCK时钟作用下击鼓传花,逐次移位传递。' J! S: F1 x: E7 h; J

Linux下SPI框架

一图胜千言,看看我画的图吧:

微信图片_20201204215547.png
  • spi.c 实现了SPI core的公共抽象,SPI core负责抽象所有控制器具有的公共功能代码,并同时为spi protocol驱动程序提供接口,例如spi_message,spi_transfer,spi_async等。
  • SPI controller:SPI控制器层实现不同芯片SPI控制器的差异性实现,完成数据的bit级别的收发控制实现,并最终控制其对应的总线。
  • SPI devie:实现设备驱动,负责从控制器收发数据,并实现应用协议的解析等。
  • SPI外设控制:逻辑电路层,负责底层的IO电路级控制。
  • SPI从设备:挂载在具体的SPI总线上的芯片,比如传感器、FLASH存储设备等。
    1 B: d) `' o, m6 R
GPIO SPI Master?

前面说自己拿GPIO对着SPI收发时序波形去实现SPI字符设备有点重新造砖的嫌疑,且造出的砖兼容性、稳定性往往都差强人意。辣么,Linux下不这么干,可以怎么干呢?

首先用下面命令打开内核配置界面,来瞅瞅:

make menuconfig
( E8 n7 b) C. e( m- ~

稍等那么一会儿,熟悉的界面就出来了:

微信图片_20201204215551.png

进入Device Drivers:

微信图片_20201204215555.png

进入到SPI support,按Y选择:

  • GPIO-based bitbanging SPI Master,这便是GPIO SPI主控制器的配置项
  • User mode SPI device driver support,这便是spidev设备驱动的配置项
    ! W, r9 H* r" |% C& r! I
微信图片_20201204215558.png

完事之后,一顿退出保存配置,记得保存配置,别配置了半天没存哈。. v% d6 |5 e3 y! {& q8 x% _8 u* j9 \3 `7 q& d

设备树配置

前面配置好了GPIO主控制器以及spidev设备驱动,然而如果直接编译,将内核部署到目标板上运行你发现啥也没有。那么还要做什么呢?你需要根据你的板子的情况配置哪些GPIO为SPI主控制对应的引脚!比如我用的ZYNQ,我这样配:

spi {6 G/ o8 d$ x+ H! v
compatible = "spi-gpio";
- l- w# ^( A" C! Y: d& @& b1 ~, s #address-cells = <0x1>;
3 \) t7 `% y  \' s; U! ~2 T% L ranges;
1 [$ W" ]1 |! d4 z' v8 L. I- a. c+ m* [2 d2 X7 ^$ m8 ]5 l
sck-gpios = <&gpio0 7 0>;
. O0 Q3 w1 l- X" l$ {; ~ miso-gpios = <&gpio0 11 0>;
7 a1 C- R; s: v( J  P) | mosi-gpios = <&gpio0 10 0>;* e" q. ]6 B2 S/ T- g% Q  p
cs-gpios = <&gpio0 12 0>;5 x0 M! d. h& L; U: X
num-chipselects = <1>;
( ^  C2 B5 O3 ?3 {/ n- i# k /* 从设备clients */; A# H* J% ]% L
    device_0@0 {6 g* i  w+ p/ T/ S
        compatible = "spidev";' O3 C* q9 _+ A) {; D
        reg = <0>;
4 c$ I. d: H( S( _. H7 w        spi-max-frequency = <500000>;# X: x* y9 @2 ]# U/ ~0 d% z
        #address-cells = <1>;* J, v' Q$ F+ c0 d! a& p2 ^
        #size-cells = <1>;% @" F% g+ }6 ~' _% [& ~
        spi-rx-bus-width = <1>;  x" E/ q* _  C! ~2 n
        spi-tx-bus-width = <1>;$ V" u  a$ h& D% v
        bits-per-word = <8>;
8 b& a% i/ p% U    };  q! _$ o  J. W+ }$ J: K+ {* |
};
6 e. L" {9 A- z$ P* D7 U' h

主控制器设备树:

  • compatible = "spi-gpio",这里兼容性表示使用GPIO的主控制器。编译时会自动编译spi-gpio.c
  • sck-gpios/miso-gpios/mosi-gpios/cs-gpios:为SPI对应的4个脚的配置,后面的则根据目标板进行设置。
  • num-chipselects:设置有几个片选
    ( Z1 G1 z1 r$ u

从设备设备树:

  • compatible = "spidev",这里设置spidev对应spidev.c的实现,当然你完全可以自己写个设备驱动,但是对于大部分应用而言没有必要,直接在用户空间实现应用协议不香么?
  • reg = <0>,括号里如果有多个从设备则依次增加
  • spi-max-frequency,设定spi频率,这里假定设置为500k
  • spi-rx-bus-width/spi-tx-bus-width,这里可选,如果是quad等设备则需要设置
  • bits-per-word:表示一个字节多少位
  • 另外spi-cpol/spi-cpha,则根据设备的SPI模式进行相应配置
  • spi-3wire:如果对应的设备是3线SPI设备,则可将该属性加上。1 R* D7 h) q& r" ]; H
部署测试

设备树配置好后,编译加载到目标板上,此时在/dev下就会出现相应的设备 ,比如这样:

微信图片_20201204215602.png

我配了好几个spidev,所以出现这么几个设备。

至于怎么从用户空间测试这些驱动,就是基本的文件open/read/write操作了,这里就不赘述了。

总结一下

本文梳理了一下在SPI受限的情况下,Linux中GPIO用做SPI控制器的方法及实现,不用敲一行代码就妥了。把该驱的芯片就驱起来了。这里一个小的tips:

当面临要写驱动的时候,先查查是否已经有现成的实现,鼓捣鼓捣就能用岂不是妙!

Linux发展至今,为啥能如此广泛应用,从这里也可见一斑。你大部分想到的需求,都基本给你造好了。拿来就用,一用就对!他不香么?


& N1 G- R, s# D4 Z3 [4 Z; j
收藏 评论0 发布时间:2020-12-4 22:00

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版