几个串口通信协议的整理

一、UART

UART是一个大家族,其包括了RS232、RS499、RS423、RS422和RS485等接口标准规范和总线标准规范。它们的主要区别在于其各自的电平范围不相同。

嵌入式设备中常常使用到的是TTL、TTL转RS232的这种方式。常用的就三根引线:发送线TX、接收线RX、电平参考地线GND。

1.1 电路示意图

img

1.2 通信协议

将传输数据的每个字符一位接一位地传输。

https://img-blog.csdn.net/20170719232822650” alt=”串口数据传输示意图.png” title=”” />

起始位:先发出一个逻辑”0”的信号,表示传输字符的开始。

数据位:紧接着起始位之后。数据位的个数可以是4、5、6、7、8等,构成一个字符。通常采用ASCII码。

奇偶校验位:数据位加上这一位后,使得“1”的位数应为偶数(偶校验)或奇数(奇校验),以此来校验资料传送的正确性。

停止位:它是一个字符数据的结束标志。可以是1位、1.5位、2位的高电平。

空闲位:处于逻辑“1”状态,表示当前线路上没有资料传送。

波特率:数据传输的速率。有以下几个档位:300、600、1200、2400、4800、9600、19200、38400、43000、56000、57600、115200.当然也可以自定义。在数据传输和接收双方,需要预先统一波特率,以便正确的传输数据。

二、I2C 总线

2.1 电路示意图

I²C (Inter-Integrated Circuit)。其拥有一根数据线SDA和一根时钟线SCL。其总线通过上拉电阻与电源相连接。每个接到I2C总线上的器件都有唯一的地址。其中,主动发起操作的一方为主机,另外一方为从机。

IIC 总线

2.2 数据传输

当没有数据传输的时候,两根总线都为高电平;当采集IIC上的数据时,其时钟线SCL必须是高电平且SDA的数据必须保持稳定不变—将SDA的电平与SCL的高电平进行“与”操作后,以便确定SDA上是1还是0;在SCL为低电平的时候,SDA上的数据可以进行跳变。

数据传输开始时,需要发送一个起始信号;数据传输结束后,需要发送一个终止信号;每8bit数据传输结束,都需要一个ACK。起止信号都有Master发出,而ACK则可能由Master或者SLAVE来发出。数据的传输采用大端传输。

开始信号:SCL为高电平,SDA的电平由高跳到低表示开始信号。

终止信号:SCL为高电平,SDA的电平由低跳到高表示终止信号。
IIC时序

2.3 数据协议

IIC数据协议

2.4 I2C读写流程

I2C读写流程

I2C写寄存器的标准流程.png

I2C读寄存器的标准流程.png

三、SPI总线

SPI(Serial Peripheral Interface)是一种串行串行同步通讯协议,由一个主设备和一个或多个从设备组成。其拥有四根(类)硬脚引线,分别为 SDI(串行数据输入),SDO(串行数据输出),SCK(串行移位时钟),CS(片选)。因为一个主设备可以挂多个从设备,则通过片选引脚对从设备进行选择。从设备的工作时钟则是来自于主设备的SCK线。

3.1 电路示意图

SPI总线

3.2 数据的传输

SPI在数据传输的时候,需要确定两件事情:其一,数据是在时钟的上升沿采集还是下降沿采集;其二,时钟的初始(空闲)状态是为高电平还是低电平。而I2C的空闲状态,时钟线为高电平;数据采集的时候,时钟线也为高电平。但SPI给出了更自由的方式。

CPOL:时钟极性, 表示 SPI 在空闲时, 时钟信号是高电平还是低电平。

CPHA:时钟相位, 表示 SPI 设备是在 SCK 管脚上的时钟信号变为上升沿时触发数据采样, 还是在时钟信号变为下降沿时触发数据采样。

那么,SPI CPOL有两种可能,CPHA有两种可能,则SPI数据传输就有四种可能—按照标准的说法,SPI数据传输就有四种模式。

SPI数据传输就有四种模式

SPIMode0.png

SPIMode2.png

这里写图片描述

3.3 SPI读写

SPI在硬件设计上采用的双数据线制,根据设计,在SPI通信过程中,主从设备之间会形成一个数据环形链路—也即是,主设备向从设备写一次数据,从设备就会回一次数据(至于该从设备回复的数据是否有效,则另当别论—如果有效,主设备就把它读入;如果无效,则丢弃即可)。

SPI主从连接.png

SPI读写.png

模拟电赛方向电路设计,方案设计等等锁相环,通信类:模电、数电的内容得掌握。会一些基本的通信协议如UART通信,最好也会FPGA,因为处理速度快。如果需要做高频,那么对画电路板要求很高。不过这个电路板跟电源类的板子画风完全不一样。同时也必须对电力电子、模电等基础知识掌握的好,以及有大量的工程实战经验。这个走不了捷径,只有在不断的做和总结中才能真正号类题目主要信号产生,调理,采样,显示,处理等,个人觉得这类题目比较容易上手,题目一般会要求系统由多个模块拼接成,又多个测试点,考察点。所以这类题目,就不是简单的实现题目要求功能了,信号类题目都是指标题,也就是最后获奖的关键在于谁的指标更好,是的,更好。 你以为你的指标已将超发挥部分三倍开外了,止不住会有队伍就是能做到超发挥指标的十倍开外。准备这类题目,首先一些基本的单元电路要比较熟悉,比如,滤波电路,放大电路,检波电路等,信号处理的题目大致就是一些基本单元电路的组合。所以,个人觉得,前期先花些时间和精力把常用的基本的单元电路先熟悉一下。接着就要注重系统的搭建与调试,有些问题光搭单个电路是反映不出来的的,系统搭起来一调就会发现很多问题,把握到底是什么在系统中影响着我们所关注的指标。这样多练几道题目就差不多了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值