14-Linux gpio模拟spi

14-Linux gpio模拟spi,第1张

首先是spidev,要在/dev/下面产生设备文件,需要spidev的支持

使用的是gpio模拟spi,gpio模拟spi的时序原理是bitbang文件实现的,所以这个也需要打开,如果是在openwrt下动态加载的话就是如下两个配置

如果是直接内核的话是如下两个

跟I2C的arch层一样,主要是devices的添加和board_info的添加,如下

对于platform_add_devices,因为是使用spi_gpio,所以name是"spi_gpio"这样才可以与driver里面的spi_gpio相互匹配probe到。

因为SPI是可以一个总线上面挂多个,然后通过片选脚CS进行硬件切换,所以这变有个num_chipselect需要设置,如果有2个设置就设置2,一个设备就设置1,这边设置好之后,后面board_info也要有对应的个数,而且片选引脚需要不同。

I2C是通过每个设备有自己不同的地址,通过地址来进行软件切换。

对于board_info使用的是spidev,drivers/spi/spidev.c文件,该文件的内容是注册一个spidev驱动。该驱动是一个字符设备驱动。

如果设备与驱动匹配,那么就会执行spidev_probe()的内容。在spidev_probe()函数中会调用device_create()成功后在 /dev 目录下就会生成 spidev 相关的设备节点。

这边有几个参数要注意:

调试过程想看一些细节的debug信息可以打开内核的动态debug信息,这个在以前的print system里面有

printk的等级设置成8.

开始

定位到是 spi_gpio_request 的时候报错

后面就将zkernel/3.10.49/arch/mips/mtk/ziroom/zrmt7628.c里面GPIO的信息调整下, 因为SPI的引脚和LED的引脚号一样 ,内核不知道哪里会检测到。

修改后打印如下:

之后在/dev/下面就生成了spidev1.0的设备

有了/dev/spidev1.0设备之后,就可以在应用成 *** 作改设备收发数据。

在drivers/spi/spidev.c里面已经封装好了ioctl的对应接口,根据这些接口就可以测试使用。

在Documentation/spi/spidev_test.c下面有个应用层的实例,打开看下就清除了。

$(cc) spidev_test.c -o spidev_test生成可执行文件spidev_test

然后拷贝到板子上,将MOSI和MISO短接就可以测试回环数据是否正常。

有逻辑分析仪的接上logic看波形就更加直观。

gpio模拟SPI:

https://blog.csdn.net/luckywang1103/article/details/70145870

在ARM Linux下使用GPIO模拟SPI时序详解:

https://blog.csdn.net/yangzheng_yz/article/details/50470577

linux SPI驱动:

https://www.cnblogs.com/xuyh/category/903809.html

你好:

MISO=1;是吧MISO这个脚置为输入。

byte |= MISO是吧byte的最低位或上MISO接收到的电平数据。

这是吧byte的最低位赋值,但是上边有一句byte = (byte <<1)这样吧byte左移一位,下次再赋值时,byte的最低位就是新的一个数据了。

不懂的回复。

希望我的回答能帮助到你。

专利名称:一种提高软件方式spi通信速率的方法

技术领域:

本发明涉及一种提高软件方式SPI通信速率的方法,尤其适用于时钟速率有上限或产品芯片已经选定,电路结构不易改变的系统。

背景技术:

SPI接口的全称是‘、erial Peripheral Interface”,意为串行外围接口,是一种高速、全双工、同步的通信总线,并且连线简单,节省电路空间,近年来得到了非常广泛的应用。目前SPI通信中,有很大一部分应用是主机采用软件的方式(即通过GPI0(通用输入输出)端口产生高低电平)模拟SPI通信协议与从设备进行通信。尤其是一些比较低端的通用单片机控制器芯片MCU中常常不集成SPI模块,主机用软件方式模拟SPI端口的应用方式就更为普遍。图1是目前普遍采用的软件方式SPI方法的示意图,目前普遍采用的软件方式SPI 通信是首先将待发送SPI通信数据通过CPU逐位比较的方式转换成串行数据(0/1),然后根据串行数据在GPIO端口产生SPI通信需要的时钟驱动和数据驱动(GPI0端口翻转),这整个过程需要在CPU控制下完成,占用了大量CPU资源。这种方法方便可行,省去了对控制器集成SPI模块的要求也降低了硬件成本,缩短了开发周期。但是由于通过软件方式模拟SPI通信在GPIO端口上产生翻转需要花费大量的CPU处理时间,系统最快通信速率受限于系统工作频率和CPU处理性能,通信速度很难提高,成为这种应用方式的瓶颈。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8061304.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存