当前位置:首页 > 嵌入式 > 嵌入式硬件

引 言

SPI 是英文Service Provider Interface的缩写。中文意思是服务提供商接口。满足某种服务标准的供应商提供的符合该标准的应用程序接口,SPI应该和该服务的API标准是兼容的,应用程序一般应该是基于API编写,除非是SPI中包含API中没有提供的功能而又必须使用。SPI的处理流程大同小异,以目前使用最多的SPI-4为例来说明SPI的原理。它在发送接口和接收接口都有各自的数据通道和流控状态信息通道,其数据通道和流控状态信息通道是独立的并且是点对点通信。数据是以包的形式发送,根据数据包中的内嵌地址可支持高达256个端口,以下分别说明基本协议及数据通道和流控状态信息的处理过程。

1 SPI串口通信格式

SPI接口协议要求接口设备按主一从方式进行配置,总线上可以连接多个可作为主机的控制器、具备SPI接口的输入/输出设备,但同一时间内总线上只能允许一个设备充当主机。通常,SPI接口包括4种信号:

MISO串行数据输入,也称主入从出。

MOSI 串行数据输出,也称主出从入。

SCK 串行时钟,由主机提供给从机。

SS 从机片选信号。

在时钟SCK的作用下,SPI主机发送寄存器的内容顺序移位输出给SPI从机。同时,SPI从机也将其数据寄存器的内容移位输出给主机。图1为其工作原理示意图。

2 基于ARM的SPI接口模拟

LPC2378是Philips公司生产的ARM7系列芯片。该芯片是一款支持实时仿真和嵌入式跟踪的16/32位 ARM7TDMI-S微控制器,具有三级流水线指令处理结构。LPC2378具有5个32位的GPIO端口。对GPIO口的控制可以通过操作以下GPIO 寄存器来实现:

FIODIR 快速GPIO端口方向控制寄存器;

FIOMASK 快速GPIO端口屏蔽寄存器;

FIOPIN 快速GPIO端口状态寄存器;

FIOSET 快速GPIO端口置位寄存器;

FIOCLR 快速GPIO端口清零寄存器。

SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。SPI有三个寄存器分别为:控制寄存器SPCR,状态寄存器SPSR,数据寄存器SPDR。外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCLK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。SPI接口是在CPU和外围低速器件之间进行同步串行数据传输,在主器件的移位脉冲下,数据按位传输,高位在前,低位在后,为全双工通信,数据传输速度总体来说比I2C总线要快,速度可达到几Mbps。

发送数据的实现代码如下:

GPIO模拟SPI接口接收数据的流程和发送的不同之处在于读取MISO信号而非设置MOSI电平。限于篇幅,对其不予赘述。接收数据的实现代码如下:

上述的发送和接收代码只是基本的实现,对于不同的SPI器件需要在每次操作后加入不同的延时以满足该器件信号建立和保持的时序要求。

3 对TLV5637的访问

TLV5637是TI公司一款双通道的10位电压输出D/A转换器件。该器件具有3个信号线:SCLK、DIN和CS,支持对TMS320系列的SPI,以及QSPI和Microwave串行端口的无缝连接。图3为TLV5637和SPI接口的连接示意图。

图4为TLV5637的时序图。如图所示,TLV5637的数据采样是在SCK时钟的上升沿发生,而且该器件只支持16位的数据格式。

可以看出,16位的数据包含两个部分:编程位和数据位。SPD为速度控制位,1表示快速,0表示慢速;PWR为功率控制位,1表示掉电模式,0表示工作模式;R1和R0为寄存器选择位。表1为TLV5637的寄存器写入选择表。

表1中的写控制寄存器即设置参考电压,数据位的低两位表示参考电压的相关信息。其中,“00”和“11”表示参考电压取自外部,“0l”表示参考电压为1.024 V,“10”表示参考电压为2.048 V。输出电压的幅度由下式决定:

CODE为所写入的电压数据值,REF为所设定的参考电压。此外,在写入电压数据时,12位的数据只保持高10位有效,低2位可以忽略。TLV5637的写函数如下:

经过验证,可以通过GPIO口模拟的SPI接口对TLV5637的输出电压进行精确设置,而且其输出满足系统的电压误差要求。

结 语

本文提出了利用ARM芯片LPC2378的GPIO接口来仿真SPI接口的方法,同时实现了对串行D/A转换芯片TLV5637的模拟SPI接口访问。该方法具有一定的普遍意义,只要稍加改动,便可以应用于各种类型的微处理器。



QICK

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

近日,Arm推出了Arm® Ethos™-U85神经网络处理器(NPU)和Arm Corstone™-320物联网参考设计平台,旨在满足海量的数据处理和大规模计算,加速推进边缘AI的发展进程。

关键字: ARM

随着科技的飞速发展,电子产品在我们日常生活中扮演着越来越重要的角色。而在这些电子产品中,接口作为连接设备与外部设备的桥梁,其重要性不言而喻。其中,Type-C接口作为一种新型的接口标准,因其独特的优势,逐渐成为了众多电子...

关键字: 电子产品 Type-C 接口

为了赶超云计算市场上的竞争对手,谷歌正试图通过定制的Arm服务器芯片降低云计算服务成本。

关键字: 谷歌 ARM 定制芯片

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

随着汽车软件数量爆发式的增长,整个行业都需要重新思考汽车产品的开发流程。为此,Arm推出了丰富的硬件IP、新的系统IP,以及全新的汽车计算与计算子系统产品路线图,旨在为各种汽车应用实现性能、功能安全、可扩展等方面的支持。

关键字: ARM 汽车电子

知名移动芯片设计公司ARM最近迈出重要一步,它正式推出汽车芯片设计。ARM推出的芯片设计方案名叫Neoverse,随同芯片一起推出的还有面向汽车制造商、汽车供应商的新系统。

关键字: ARM 汽车芯片 芯片

随着通用人工智能的发展,数据中心的计算需求逐步提高。针对多模态数据、大模型的推理和训练需要更高的算力支持,而随着算力提升与之而来的还需更关注在功耗方面的优化。对于头部云计算和服务厂商而言,针对专门用例提高每瓦性能变得至关...

关键字: ARM 服务器 AI Neoverse CSS

一直以来,riscv架构都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来riscv架构的相关介绍,详细内容请看下文。

关键字: riscv ARM riscv架构

最新消息报道,知情人士透露Arm近日裁掉了中国70多名软件工程师,并会将部分职位转移到中国以外的地区。Arm通过“全球服务”部门已经将支持其中国客户的工作外包给安谋科技,该部门曾经拥有约200名员工。

关键字: ARM 裁员

凭借着在个人计算机领域的广泛应用打下的坚实基础,X86自始至终统治着整个服务器生态。而这并不是业界希望看到的,因此Arm服务器被给予厚望。业界期盼Arm能够带来新的服务器CPU替代:打破一个同质化的数据中心架构,实现更高...

关键字: ARM 服务器 AI
关闭
关闭