IIC

  特点

    1、Inter-Integrated Circuit,内部集成总线,半双工

    2、短距离传输,有应答,速度较慢

    3、SDA双向数据线,SCL时钟线

    4、可以挂载多个设备,IIC设备有固化地址,传输值等于IIC固化地址,对应设备作出响应

  基本过程

    初始空闲:SDA和SCL均为高电平(具有上拉电阻)

    起始位:SCL高电平期间,SDA下降沿

    寻址:主机发送8位数据,前7位为从机地址,后一位表示数据方向,1为读,0为写,对应从机响应,SDA线拉低

    传输:SCL高电平,数据写入从机;故SDA的数据需要在SCL低电平器件完成数据发送

    响应:从机接收到8位数据后,第9个周期拉低SDA电平,表示从机接到数据产生应答

    终止位:SCL高电平期间,SDA上升沿

SPI

  特点

    1、Serial Peripheral Interface,串行外设接口,全双工

    2、短距离传输,无应答,速度块

    3、4根线(或3根线单向传输)MISO(master input slave output)、MOSI(master output slave input)、SCLK(serial clk时钟)、CS(chip select片选、从设备使能)

    4、可以挂载多个设备,每个设备片选都接入主设备,通信时需使其有效

  工作模式

    CPOL(时钟极性)和CPHA(时钟相位)

    CPOL配置SCLK的电平出于哪种状态时是空闲态或者有效态(0:空闲低电平 1:空闲高电平)

    CPHA配置数据采样是在第几个边沿(0:采样第一沿,发送第二沿)

    :CPOL=0,CPHA=0:空闲态时,SCLK处于低电平,数据采样是在第1个边沿,所以数据采样(即读取发送的数据)是在上升沿,数据发送(即将数据放在输出线上)是在下降沿。

  基本过程

    主设备上升(下降沿)输出,从设备下降(上升沿)读取,即一个时钟周期完成一次传输

    SCLK由主设备产生(使得spi不像其他串行设备按字节发送,可以比特发送)

    可以同时输入输出(全双工)

    利用移位寄存器实现

UART

  特点

    1、Universal Asynchronous Receiver/Transmitter,异步收发传输器,全双工

    2、较长距离传输,有奇偶校验

    3、RX接收,TX发送

  基本过程

    起始位:起始高,发送数据前拉低一个时钟周期表示起始

    数据位:5-8位(有校验),9位(无校验)

    校验位:奇偶校验(奇:校验位使传输内容中1的个数为奇数 偶:使1的个数为偶数)

    停止位:将信号线从低电平变为高电平至少两个周期

IIC、SPI、UART协议总结的更多相关文章

  1. 通信方案软件设计(环形动态申请内存,支持USART+IIC+SPI+CAN协议

    1 <STM32进阶之串口环形缓冲区实现>中讲得比较清楚(链接) 2 amobbs中讲的方法有点复杂,以下是链接和参考源码: 通信方案软件设计(环形动态申请内存,支持USART+IIC+S ...

  2. 【转载】IIC SPI UART串行总线

    一.SPISPI(Serial Peripheral Interface,串行外设接口)是Motorola公司提出的一种同步串行数据传输标准,在很多器件中被广泛应用. 接口SPI接口经常被称为4线串行 ...

  3. 关于I2C和SPI总线协议【转】

    关于I2C和SPI总线协议 IICvs SPI 现今,在低端数字通信应用领域,我们随处可见IIC (Inter-Integrated Circuit) 和 SPI (Serial Peripheral ...

  4. SPI总线协议及SPI时序图详解

    SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接口.SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚 ...

  5. 基于FPGA的UART协议实现(通过线性序列机)

    //////////////////2018/10/15 更新源代码: 实现uart这东西其实早就写了,不过不太完善,对于一个完美主义者来说,必须解决掉它. 1.什么是UART?        通用异 ...

  6. SPI总线协议及SPI时序图详解【转】

    转自:https://www.cnblogs.com/adylee/p/5399742.html SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接 ...

  7. MicroBlaze核的串行接口实验:SPI UART

    reference : https://blog.csdn.net/weixin_42413559/article/details/80720566 串行接口:SPI UART XPS->SDK ...

  8. UART协议总结

    之前一直使用UART作为单片机之间以及和计算机的简单通信,但一直没有研究过该协议的内部原理.今天刚买了一个逻辑分析仪,于是使用该分析仪对UART数据进行分析,以便更好的理解UART协议原理. UART ...

  9. 【转】SPI总线协议

    SPI总线协议 By Xiaomin | April 17, 2016| 技术 概述 SPI(Serial Peripheral Interface)总线是主要应用于嵌入式系统内部通信的串行同步传输总 ...

  10. UART协议详解

    UART(Universal Asynchronous Receiver/Transmitter)是一种异步全双工串行通信协议,由Tx和Rx两根数据线组成,因为没有参考时钟信号,所以通信的双方必须约定 ...

随机推荐

  1. 联赛模拟测试18 A. 施工 单调队列(栈)优化DP

    题目描述 分析 对于 \(Subtask\ 1\),可以写一个 \(n^3\) 的 \(DP\),\(f[i][j]\) 代表第 \(i\) 个建筑高度为 \(j\) 时的最小花费,随便转移即可 时间 ...

  2. Nginx常见错误解决办法

    报错: nginx: [error] CreateFile() "C:\mytools\nginx-1.8.1/logs/nginx.pid" failed (2: The sys ...

  3. 记录Spring Boot 2.3.4.RELEASE版注解方式实现AOP和通知的执行顺序

    1.advice 按照以下的顺序执行 输出结果:(正常和异常) 说明:Spring boot 2.3.4.RELEASE 版本使用的AOP是spring-aop-5.2.9.RELEASE,AOP的通 ...

  4. 更换Centos的yum源

    1.备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 2.下载新的CentOS-Base ...

  5. vscode自定义插件安装位置

    vscode的插件默认安装位置在: C:\Users\用户名\.vscode\extensions 如果不想将插件安装在C盘,可以自定义一个目标位置存储,使用如下: 右键快捷方式,在原本的目标后加入- ...

  6. Git操作文件的时候手贱了,怎么恢复?

    我们在使用git的过程当中很难避免的一点就是手贱,因为人嘛总有犯错疏忽的时候,有时候一不小心就操作错了.我也经常遇到这种情况,所以这时候对git的了解和掌握就非常重要,即使操作错了,我们也可以通过gi ...

  7. 图解git,用手绘图带你理解git中分支的原理和应用

    大家好,今天我们来聊git当中一个非常非常重要的特性,就是branch. git branch可以说是git当中最重要的概念了,甚至没有之一.因为git最重要的使用场景就是协同开发,大家一起在一个项目 ...

  8. Python使用psycopg2模块操作PostgreSQL

    https://blog.csdn.net/pcent/article/details/78643611

  9. H5页面字体设置

    H5页面不支持 MicrosoftYaHei(微软雅黑)别傻傻的设置微软雅黑字体了 如果一定要微软雅黑操作如下 @font-face 定义为微软雅黑字体并存放到 web 服务器上,在需要使用时被自动下 ...

  10. 常用的实现Javaweb页面跳转的方式

    我们有两大种方式来实现页面跳转:1.JS(javascript):2.jsp跳转 先说jsp(金j三s胖p):1.转发:request.getRequestDispatcher("1.jsp ...