FPGA技术:学习IIC协议的五种状态

时间:2025-11-01  作者:Diven  阅读:0

二. IIC简介

FPGA技术:学习IIC协议的五种状态

IIC协议分为主机和从机,所有的请求都是由主机发出,从机进行响应,从机是没有办法对主机进行读或写的。IIC协议共有两根线,数据线SDA和时钟线SCL,两根线就可以完成所有的通信请求,简直是太给力了。

三. IIC协议

终于到了IIC协议的部分。IIC协议简单来说,共有五种状态,这五种状态的有序组合就组成了完整的IIC通信,学习IIC协议,就是学习这五种状态。

空闲态:  SCL 和 SDA 都为高电平,不进行通信的时候。

起始态:在SCL为高电平的时候,将SDA拉低,主机通知从机,开始进行通信。

数据传输态:数据传输态,又可以分为读和写两个部分,过程都是一样的,就合在一起了,都是在SCL为低电平的时候,SDA将数据发送,在SCL为高电平的时候,将数据接收。

(非)应答态:数据传输态完成后,必须接一个应答态或者非应答态,为了确定对方接收到了数据。在SCL为高电平的时候,检测到SDA为低电平,则为应答,否则为非应答。

停止态:一次数据传输完成,由主机发起,在SCL为高电平的时候,SDA由低电平变成高电平。

了解了这五种状态后,接下来就要学习如何使用这五种状态来进行读写操作了。

(一)  IIC写操作

下面就是一个完整的写操作,共包含三次数据传输态,第一次发送的是从机地址 + 0,第二次发送的是寄存器的地址,第三次写的是数据,写入寄存器中的数据。从机地址一般为7bit,与另外一bit共同组成8bit,0表示写,1表示读。

(二)IIC读操作

读操作要比写操作复杂一点,需要的状态多一些。一共有五个数据传输态,状态图如下了。

上面的流程图都是对从机的地址为7位以及从机的寄存器地址为8位的操作。

四. Verilog代码实现

有了上面的各个状态中,SDA和SCL的变换关系,以及读写的序列,就可以很方便的来写程序啦。

1. 当然离不开状态机,根据上面叙述的五种状态,编写状态机,状态机中,将数据传输态分成了读和写两种状态。有了各个状态,操作SDA和SCL两根线不是易如反掌嘛!

localparam IIC_IDLE = 6'b000_001; localparam IIC_START = 6'b000_010; localparam IIC_WRDATA = 6'b000_100; localparam IIC_RDDATA = 6'b001_000; localparam IIC_ACK = 6'b010_000; localparam IIC_STOP = 6'b100_000; 

2. 状态机的跳转条件如下,跳转条件和上面叙述的一样。单独看这个有点难懂,有些变量不明白其具体含义,可以结和仿真图形和完整代码进行理解。

always @(*)begin case(state) IIC_IDLE: if(IICWriteReq == 1'b1 || IICReadReq == 1'b1) next_state <= IIC_START; else next_state <= IIC_IDLE; IIC_START: if(IICCnt == (IIC_Pre * 'd2)) next_state <= IIC_WRDATA; else next_state <= IIC_START; IIC_WRDATA: if(IICBitCnt == 'd8 && IICCnt == IIC_Pre /4 && iicCLK == 1'b0) next_state <= IIC_ACK; else next_state <= IIC_WRDATA; IIC_RDDATA: if(IICBitCnt == 'd8 && IICCnt == IIC_Pre /4 && iicCLK == 1'b0) next_state <= IIC_ACK; else next_state <= IIC_RDDATA; IIC_ACK: if(IICACKStopCnt == 'd1 && IICCnt == IIC_Pre /4 && iicCLK == 1'b0) if(IICSendBytes == 'd3) if(IICWriteReq == 1'b1) next_state <= IIC_STOP; else next_state <= IIC_RDDATA; else if(IICSendBytes == 'd2 && IICReadReq == 1'b1) next_state <= IIC_START; else if(IICSendBytes == 'd4) next_state <= IIC_STOP; else next_state <= IIC_WRDATA; else next_state <= IIC_ACK; IIC_STOP: if(IICACKStopCnt == 'd1 && IICCnt == IIC_Pre/4 && iicCLK == 1'b1) next_state <= IIC_IDLE; else next_state <= IIC_STOP; default: next_state <= IIC_IDLE; endcaseend

各个部分实现的详细代码,就不列举出来啦,代码总计280多行,也不算多。通过本IIC模块,可以驱动OV5640摄像头,MPU6050模块和0.96寸OLED屏幕等等,后续会基于此模块,来驱动这些外设。

五. testbeach编写

还是按照流程走,编写完模块后,进行一下仿真,还真有错误,幸亏仿真了,哈哈哈。

`timescale 1ns/1psModule testbench(); reg clk; reg rst; wire SDA; wire SCL; reg IICWriteReq; reg IICReadReq; wire IICWriteDone; wire IICReadDone; always # 50 clk = ~clk; initial begin clk = 1'b1; rst = 1'b1; IICWriteReq = 1'b0; IICReadReq = 1'b1; #100 rst = 1'b0; #100 rst = 1'b1; end always@(posedge clk) if(IICReadDone == 1'b1) IICReadReq <= 1'b0; else IICReadReq <= IICReadReq;IIC_Driver IIC_DriverHP( .sys_clk (clk), .rst_n (rst), .IICSCL (SCL), .IICSDA (SDA), .IICSlave ('h1234), .IICWriteReq (IICWriteReq), .IICWriteDone (IICWriteDone), .IICWriteData ('h5a), .IICReadReq (IICReadReq), .IICReadDone (IICReadDone), .IICReadData ());endModule

编辑:黄飞

猜您喜欢

蜂鸣片是应用于电子设备中的声音发声元件,主要用于提示、警报和音效等功能。根据不同的工作原理和结构,蜂鸣片可以分为几种主要类型。压电蜂鸣片是最常见的,利用压电效应...
2024-11-12 00:00:00

电子电路中,电阻器是非常重要的元件。不仅用于限制电流,还用于电压分配、信号采样等多种用途。在众多电阻器中,采样电阻和合金电阻是两种常见的类型。虽然在某些应用中可...
2025-04-19 07:01:13

通用二极管是应用于电子电路中的半导体器件,其主要功能是允许电流在一个方向上流动,而阻止在反方向上流动。由于其独特的特性,通用二极管在各种应用中发挥着重要作用。本...
2025-04-06 23:31:39

生物医学仪器是指用于医疗、临床和生物研究领域的各种设备和工具。这些仪器的主要功能是辅助医生进行诊断、治疗和监测患者的健康状况。生物医学仪器的种类繁多,包括但不限...
2008-12-20 00:00:00

安装和使用监控摄像头时,电源适配器和接头规格是常常被忽视的细节。选择错误的电源适配器或接头可能导致摄像头无法正常工作,甚至造成安全隐患。为了帮助您避免这些问题,...
2024-05-05 00:00:00

贴片电阻阻值选择是否合适,取决于具体应用场景。30Ω的贴片电阻本身并没有好坏之分,关键在于是否符合电路设计的要求。一般来说,我们会根据电路中需要的分压、限流或阻...
2024-11-29 10:25:54

防撞条是保护车辆和墙体的重要配件,市面上有多种类型,功能和材质各异。防撞条根据材质可分为橡胶、塑料和金属三种。橡胶防撞条柔软耐磨,适合室内使用,能够有效吸收冲击...
2009-06-10 00:00:00

还在为识别贴片电阻上的数字编码而烦恼吗?这款贴片电阻对照表软件将成为你的得力助手!它提供免费下载和安装,无需注册,即可轻松查询各种尺寸贴片电阻的阻值。软件界面简...
2024-11-26 11:29:23

冲击套筒是机械维修和汽车保养中不可少的工具,了解其区别对于选择合适的产品非常重要。冲击套筒的材质有所不同,常见的有铬钒钢和铬钨钢,前者适合一般用途,而后者则更耐...
2020-10-18 00:00:00

锁具箱是专门用于存放和管理各种锁具的实用工具箱。通常由坚固的材料制成,具有防水、防尘和抗撞击的特性,确保锁具在各种环境下的安全存放。锁具箱内部设计合理,配有多个...
2024-05-20 00:00:00