首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

硬件笔记(13)----扩展SPI协议

1、扩展SPI协议(Single/Dual/Qual/Octal SPI) 经典SPI协议被称为标准 SPI 协议(Standard SPI)或单 线 SPI 协议(Single SPI),其中的单线是指该...为了适应更高速率的通讯需求,半导体厂商扩展 SPI 协议,主要发展出了 Dual/Quad/Octal SPI 协议,加上标准 SPI 协议(Single SPI),这四种协议的主要区别是数据线的数量及通讯方式...,见下表: 协议 数据线数量及功能 通讯方式 Single SPI(标准SPI) 1根发送,1根接收 全双工 Dual SPI(双线SPI) 收发共用2根数据线 半双工 Qual SPI(四线SPI)...例如,标准 SPI(Single SPI)与双线 SPI(Dual SPI)都是两根数据线,但标准SPI(Single SPI)的其中一根数据线只用来发送,另一根数据线只用来接收,即全双工;而双线 SPI...(Dual SPI)的两根线都具有收发功能,但在同一时刻只能是发送或者是接收,即半双工,四线 SPI(Quad SPI)和 八线 SPI(Octal SPI)与双线 SPI(Dual SPI)类似,只是数据线量的区别

4.3K20

Linux SPI 驱动

二、SPI硬件接口设计 咱们学习SPI首先得SPI本身是什么开始看起,单纯看代码移植代码其实意义不大,咱们还是摆脱工具人的想法,从硬件接口出发探索整个SPI的设计实现的推导逻辑。...1) 硬件接口 SPI接口共有4根信号线,分别是:片选线、时钟线、串行输出数据线、串行输入数据线,SPI总线模型是一个环形总线结构,由ss(cs)、sck、sdi、sdo构成,其时序其主要是在sck的控制下...所以一个完整的SPI的工作流程应该如下: image.png 三、SPI时序图 在对SPI有了一个基础的硬件接口认知之后,接下来,我们看下SPI的时序图,学习了SPI的时序图有助于我们对这几个信号之间的协同工作更进一步的了解...四、指纹SPI设备驱动框架 在对硬件有了较高的基础理解后,其实代码主要就是开始对SPI的接口做的软件实现了。...代码部分均来自于linuxkernel开源代码https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/tree/?

18.2K12
您找到你想要的搜索结果了吗?
是的
没有找到

Linux中断机制:硬件处理,初始化和中断处理

来源: CSDN | phenix_lord的专栏 硬件处理 最近解决一个关于Linux中断的问题,把相关机制整理了一遍,记录在此。...针对X86中断控制器硬件linux对这些硬件初始化,在《interrupt in linux》中有很详细的描述。...内核关键数据结构和相关初始化 对X86 CPU,Linux内核使用全局idt_table来表达当前的IDT,该变量定义在traps.c gate_desc idt_table[NR_VECTORS]...(包括相关中断路由信息的初始化)的在《interrupt in linux》中有很详细的描述。...注意: 1、这里的r,也就是pirq_router,代表一种PIR硬件,全局配置pirq_routers中描述了当前支持的PIR,并在初始化的时候通过pirq_find_router获取了对应当前配置的

7.7K30

硬件SPI控制ST7789V「建议收藏」

1.利用硬件UART模拟SPI,实现9位数据发送 2.搭建一个数字逻辑电路,人为实现9位spi发送 3.发送两组8位SPI 二、具体操作 1.具体实现 总结 ---- 前言 这段时间闲着没事,决定自己做个手表玩玩...利用商家给的软件spi例程成功将屏幕点亮之后,尝试使用改为硬件spi的方式,加快屏幕的刷新速度但是尝试了多种方案后始终无法点亮,后来查看了例程和ST7789V的数据手册才发现。...发现这一问题后,通过上网查询资料以及和学长进行讨论等途径,大致确定了一下三种方案 1.利用硬件UART模拟SPI,实现9位数据发送 这一思路的来源是一篇博客,连接如下:https://www.cnblogs.com...所以我们可以通过搭建数字电路的方式,将一根信号线的高低,人为的模拟成9位SPI数据中的第一位,控制之后的8个数据位的含义位数据还是命令。后面8位数据使用标准硬件SPI发送模式。...经过测试,这方法配合硬件SPI可以实现ST7789V 9位SPI的控制。同时,由于F411的硬件SPI速度可以达到50M,虽然有40%的性能损失,但总体上还是可以接收的。

2.4K20

Linux SPI 开发指南

文章目录 Linux SPI 开发指南 1 前言 1.1 文档简介 1.2 目标读者 1.3 适用范围 2 模块介绍 2.1 模块功能介绍 2.2 相关术语介绍 2.2.1 硬件术语 2.2.2...1.3 适用范围 ​ 表 1-1: 适用产品列表 内核版本 驱动文件 Linux-4.9 spi-sunxi.c Linux-5.4 spi-sunxi.c 2 模块介绍 2.1 模块功能介绍 SPI...2.2 相关术语介绍 2.2.1 硬件术语 ​ 表 2-1: 硬件术语 术语 解释说明 SPI Serial Peripheral Interface,同步串行外设接口 2.2.2 软件术语 ​ 表...() • 函数原型:void spi_message_init(struct spi_message *m) • 功能描述:初始化一个 SPI message 结构,主要是清零和初始化 transfer...或者使用 Linux 自带的 spi 工具:在 tina/lichee/linux-5.4/tools 目录下, 运行如下命令: make spi 然后在 tina/lichee/linux-5.4/tools

8.8K80

05-HAL库硬件SPI点亮板载LCD屏幕

1、本节内容介绍 1.1、HAL库硬件SPI 在cubemx中的配置及注意事项; 1.2、HAL库SPI详解与结构介绍; 1.3、实现硬件SPI驱动板载ST7789显示屏,240*240像素; 源码地址...硬件原理图 先来看看LCD 硬件连接方式: STM32与LCD引脚对应关系: STM32 LCD PA5 SPI-CLK PA4 SPI_CS PA7 SPI_MOSI PA6 SPI_CS PB2...SPI_RST PE7 LEDK 2.2 cubemx中配置 LCD是挂在硬件SPISPI1上,CS引脚也挂在硬件SPI上,可以直接配置,不用再操心CS引脚的电平转换了,库函数内部自动完成。...配置硬件SPI1,LCD驱动秩序要MOSI即可,只发送数据,不接收 配置非常简单,以上就是全部,直接生成代码即可。...2.3 SPI配置代码解析 2.3.1 寄存器配置: 2.3.2 硬件引脚配置 整个过程虽然一行代码没写,但是配置过程考验的是你对SPI的理解,还是需要掌握,只是说现在有工具把重复的代码平台化了。

18110

ST7789 SPI LCD硬件垂直滚动功能的使用

理论上这样的实现比较耗资源,耗费CPU资源去操作SPI外设,耗费内存资源去存储显示数据,所以一直没有去做这件事。 今天在查看ST7789数据手册写论文时,偶然发现ST7789手册中: ? 咦?...原来我一直想做的功能,ST7789竟然硬件支持,研究研究如何实现,开干! 二、实现过程 1....准备工作 需要了解SPI驱动 ST7789的基本原理,可以参考我的这篇教程: STM32Cube-17 | 使用硬件SPI驱动TFT-LCD(ST7789) 2....首先发出的是0x33命令,接着发出的分别是TFA高8位、TFA低8位、VSA高8位、VSA低8位、BFA高8位、BFA低8位,根据这个格式,在LCD初始化代码的最后添加设置滚动显示区域的代码: /**...首先发出的是0x37命令,接着发出的分别是VSP高8位、VSP低8位,根据这个格式,在LCD初始化代码的最后添加设置滚动显示起始地址的代码: /** * @brief Set Vertical scroll

1.5K20

ST7789 SPI LCD硬件垂直滚动功能的使用

理论上这样的实现比较耗资源,耗费CPU资源去操作SPI外设,耗费内存资源去存储显示数据,所以一直没有去做这件事。 今天在查看ST7789数据手册写论文时,偶然发现ST7789手册中: ? 咦?...原来我一直想做的功能,ST7789竟然硬件支持,研究研究如何实现,开干! 二、实现过程 1....准备工作 需要了解SPI驱动 ST7789的基本原理,可以参考我的这篇教程: STM32Cube-17 | 使用硬件SPI驱动TFT-LCD(ST7789) 2....首先发出的是0x33命令,接着发出的分别是TFA高8位、TFA低8位、VSA高8位、VSA低8位、BFA高8位、BFA低8位,根据这个格式,在LCD初始化代码的最后添加设置滚动显示区域的代码: /**...首先发出的是0x37命令,接着发出的分别是VSP高8位、VSP低8位,根据这个格式,在LCD初始化代码的最后添加设置滚动显示起始地址的代码: /** * @brief Set Vertical scroll

2.8K21

Linux驱动之SPI子系统剖析

SPI硬件基本概念 SPI总线由四根通信线组成,全双工、主从方式串行同步通信,一次传输8bit,高位在前,低位在后。.../spi/spi_s3c24xx. c SPI设备驱动层:drivers/spi/spidev.c (内核提供的SPI通用设备驱动) Linux中的主从模式的总线子系统采用的是同一种分离思想,其分离的具体策略大同小异...spi_message 源码分析 由于子系统架构与I2C等总线类似,所以不会在一些重复部分展开,具体分析可以参考的Linux驱动之I2C子系统剖析中的分析方法。...completion, 用于IO的同步*/ 实例化SPI控制器后设置SPI的私有数据,然后初始化completion。...dev, "Failed to register SPI master\n"); goto err_register;weiyu } 这一段是跟具体硬件息息相关的,从获取平台资源开始,然后分别做了

4.3K10

FlySky-i6x源码-硬件初始化

配对 PPM信号的输入和输出 射频芯片,主要是集中在GPIOE上面 使用的定时器函数 这个是16KHz的定时器 生成PPM的 第六个定时器是设计用来阶段的发送协议的活动包 LCD控制的初始化...用到了位定义 接着是要初始化控制的引脚 下面是ADC 这里是单个寄存器位置的定义 断电储存的功能 和射频芯片之间是SPI链接 这个是执行AD的转换 转换完以后写入到一个数组里面...灯光的亮灭 BSRR是置位寄存器位置 这是屏幕的控制,都置位 LCD屏幕的数据发送函数 上下,OK,取消 SPI数据是一位一位的输出 DR是SPI的数据寄存器 SPI的状态...状态位的意思 单个的意思 SPI接收一个数据快 射频模块 https://www.st.com/en/microcontrollers-microprocessors/stm32f072vb.html

49031

Linux SPI-NAND 驱动开发指南

文章目录 Linux SPI-NAND 驱动开发指南 1 概述 1.1 编写目的 1.2 适用范围 1.3 相关人员 3 流程设计 3.1 体系结构 3.2 源码结构 3.3 关键数据定义 3.3.1...1.3 相关人员 Nand 模块开发人员,及应用开发人员等 2 术语、缩略语及概念 MTD:(Memory Technology device)是用于访问存储设备的 linux 子系统。...3.2 源码结构 kernel 源码目录:linux-5.4/drivers/mtd/awnand/spinand . ├── Kconfig ├── Makefile ├── physic │   ├...├── sunxi-core.c ├── sunxi-debug.c ├── sunxi-nftl-core.c └── sunxi-spinand.h 内核目录下 `-- include `-- linux...support ​ 图 4-5: spi-1 ​ 图 4-6: spi-2 Device Drivers->DMA Engine support ​ 图 4-7: DMA-1 ​ 图 4-8:

3.7K50

Linux内存初始化(下)

我们接着看linux初始化内存的下半部分,等内存初始化后就可以进入真正的内存管理了,初始化我总结了一下,大体分为三步: 物理内存进系统前 用memblock模块来对内存进行管理 页表映射 zone初始化...前两步在linux里分别对应如下操作: fixed map 加载dtb :Uboot会将kernel image和dtb拷贝到内存中,并且将dtb物理地址告知kernel 系统解析dtb里的内存参数:...对物理内存“划分”的初始化,包括node, zone, page frame,以及对应的数据结构。...「Linux是如何组织物理内存的?」...最后 至此linux对物理内存的初始化和虚拟地址和物理地址的映射关系算是告一段落,相信你已经知道 linux 虚拟寻址空间layout的来龙去脉,以及如何把物理内存通过node, zone, page

3K31

Linux的内存初始化

看了很多关于linux内存管理的文章还是云里雾里,听了很多关于linux内存管理的课程还是一头雾水。...这篇文章我们先来看下linux在启动过程中的初始化。 创建启动页表: 在汇编代码阶段的head.S文件中,负责创建映射关系的函数是create_page_tables。...fixmap区之early ioremap: 对于一些硬件需要在内存管理系统起来之前就要工作的,我们就可以使用这种机制来映射内存给这些硬件driver使用。...注意:如果想要在伙伴系统初始化之前进行设备寄存器的访问,那么可以考虑early IO remap机制。 至此我们已经知道dtb和early ioremap都是在fixmap区的,如下图: ?...系统内存的布局: 完成dtb的map之后,内核可以访问这一段的内存了,通过解析dtb中的内容,内核可以勾勒出整个内存布局的情况,为后续内存管理初始化奠定基础。

2.8K21
领券