第二天(SPI通信及OLED的使用)

第二天(SPI通信及OLED的使用),第1张

配置步骤:

1. 通过SPI_CR1寄存器的BR[2:0]位定义串行时钟波特率。

2. 选择CPOL和CPHA位,定义数据传输和串行时钟间的相位关系(见图212)。

3. 设置DFF位来定义8位或16位数据帧格式。

4. 配置SPI_CR1寄存器的LSBFIRST位定义帧格式。

5. 如果需要NSS引脚工作在输入模式,硬件模式下,在整个数据帧传输期间应把NSS脚连接到高电平;在软件模式下,需设置SPI_CR1寄存器的SSM位和SSI位。如果NSS引脚工作在输出模式,则只需设置SSOE位。

6. 必须设置MSTR位和SPE位(只当NSS脚被连到高电平,这些位才能保持置位)。

注:在这个配置中,MOSI引脚是数据输出,而MISO引脚是数据输入。

ZSF

求SPI的SSD1306在linux下的测试程序理解SPI的驱动框架,还是从最基本的三个入口点触发,platform_device,platform_bus,platform_driver。

其中内核一提供给platform_bus,platform_driver在spi_s3c24xx_gpio.c和spi_s3c24xxc.c中,其中spi_s3c24xx_gpio.c用于IO模拟SPI (本例讨论的是IO模拟SPI),spi_s3c24xxc.c用于s3c24xx的硬件SPI。因此,我们需要动手写一个platform_device。

看看spi_s3c24xx_gpio.c做了些什么。

static int s3c2410_spigpio_probe(struct platform_device *dev)

{

... ...

/* [cgw]: 分配一个SPI主机 */

master = spi_alloc_master(&dev->dev, sizeof(struct s3c2410_spigpio))

... ...

sp = spi_master_get_devdata(master)

platform_set_drvdata(dev, sp)

/* [cgw]: 分配与spi硬件相关的配置,如指定哪些IO为MISO,MOSI,SCLK,CS,SPI工作模式,最大时钟等等 */

/* copy in the plkatform data */

sp->info = dev->dev.platform_data

/* [cgw]: 提供实现SPI各种模式的时序的基本方法,和CS的激活方法 */

/* setup spi bitbang adaptor */

sp->bitbang.master = spi_master_get(master)

sp->bitbang.chipselect =


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存