基于FPGA的I2C接口程序实现课程设计1.doc
《基于FPGA的I2C接口程序实现课程设计1.doc》由会员分享,可在线阅读,更多相关《基于FPGA的I2C接口程序实现课程设计1.doc(40页珍藏版)》请在三一办公上搜索。
1、郑州轻工业学院可编程数字系统设计 题 目 基于FPGA的I2C接口程序实现给予FPGA的I2C接口程序实现 摘 要串行扩展接口的发展是新一代单片机技术的显著特点,其中I2C 总线功耗低,结构简单,使用灵活,被广泛应用于视频、音像等各类设备中。本课题首先研究了IIC 总线的规范,简要介绍了Quartus 设计平台,以及FPGA 的设计流程。在此基础上,重点介绍了IIC 接口的总体设计方案,详细描述时序状态机的工作原理和Verilog HDL 语言的实现,以及在Quartus 平台上的时序仿真。本系统采用了自顶向下的设计方法,利用了Verilog HDL 语言的结构描述风格,把整个设计分成6 个模
2、块,时钟分频模块,寄存器组模块,数据接收模块,数据发送模块,输出缓冲模块,时序控制模块,顶层模块也采用语言描述。在Quartus平台上,实现系统的功能和仿真。关键词 现场可编程逻辑门阵列 IIC总线 状态机 时序仿真1.绪论 1.1 IIC总线的优点 作为一种串行总线,IIC总线虽没有并行总线的数据吞吐能力,但它具有如下优点:1、仅由两根信号线组成,节省了芯片I/O、节省PCB面积、节省成本等。 2、总线上可同时挂接多个器件,器件之间是靠不同的编址来区分的,而不需要附加的I/O线或地址译码部件。 3、总线可裁减性好。在原有总线连接的基础上可以随时新增或者删除器件。 4、总线电气兼容性好。IIC
3、总线规定器件之间以开漏I/O互联,这样,只要选取适当的上拉电阻就能轻易实现3V/5V逻辑电平的兼容,而不需要额外的转换。 5、支持多种通信方式。一主多从是最常见的通信方式。此外还支持双主机通信、多主机通信以及广播模式等等。 6、兼顾高低速通信。IIC总线标准传输速率为100kbit/s,在快速模式下为400 kbps,高速模式下为3.4Mbit/s。IIC总线的通信速率也可以低至几kbps以下,用以支持低速器件或者用来延长通信距离。 IIC总线带来的这些好处,得到了广大工程师的青睐。在通信,音/视频,智能仪表、工控领域都得到了应用。 1.2 课题的主要工作作为一款经典的串行通讯总线,IIC总线
4、接口IP核已被越来越广泛的集成到SoC中。本文通过用Verilog HDL语言在FPGA上实现一个IIC总线接口,它可作为IP核集成到SOC中。研究内容主要包括以下方面:1、深入研究IIC协议规范。 2、用Verilog HDL硬件描述语言设计基于FPGA的IIC总线接口,做到数据传输能够有序、有效地进行。 3、用Quartus软件对每一个模块进行编译生成单个电路模块。4、在Quartus平台上,对设计进行分析、综合、功能和时序仿真。 2 IIC总线协议研究 2.1 IIC总线概述 2.1.1 IIC总线简介 IIC总线支持任何IC生产过程,包括CMOS、NMOS、双极性,用两根信号线进行数据
5、传输串行数据线(SDA)和串行时钟线(SCL)。它允许若干兼容器件(如存储器、A/D和D/A转换器,以及LED、LCD驱动器等)共享总线。图2.1是IIC总线结构。 图2.1 典型的IIC总线结构 每个器件都有唯一的地址,而且都可以作为一个发送器或接收器,由器件的功能确定,。IIC总线上所有器件依靠SDA发送的地址信号寻址,不需要片选线。任何时刻总线只能由一个主器件控制,各从器件在总线空闲时启动数据传送,由IIC总线仲裁来决定哪个主器件控制总线。表2-1给出了IIC总线常用的术语定义。 表2-1 IIC总线术语定义 术语描述发送器发送数据到总线的器件接收器从总线接收数据的器件主机初始化发送产生
6、时钟信号和终止发送的器件从机被主机寻址的器件多主机同时有多于一个主机尝试控制总线但不破坏报文仲裁多主机同时尝试控制总线但只允许其中一个主机控制总线并使报文不被破坏的过程同步两个或多个器件同步时钟信号的过程2.1.2 IIC总线的电气特性与结构 在系统中,IIC总线的典型接法如图2.2所示,注意连接时需要共地。SDA和SCL都是双向线路,为了使总线上所有电路的输出能实现“线与”功能,各个IIC总线的接口电路的输出端必须是漏极开路或集电极开路结构,输出端必须接上拉电阻,上拉电阻一般取值310K。 图2.2 IIC总线的器件连接 开漏结构的好处是:1、当总线空闲时,这两条信号线都保持高电平,因各设备
7、都是开漏输出,上拉电阻,使SDA和SCL线都保持高电平,不会消耗电流。任一设备输出的低电平都使相应的总线信号线变低,即总线上的所有器件都达到高电子状态时,IIC总线才能达到高电平,从而使总线上的高速器件和慢速器件工作同步。 2、电气兼容性好。上拉电阻接5V电源就能与5V逻辑器件接口,上拉电阻接3V电源又能与3V逻辑器件接口。 3、因为是开漏结构,所以不同器件的SDA与SDA之间、SCL与SCL之可以直接相连,不需要额外的转换电路。 2.2 IIC总线的位传输 由于IIC总线的器件有不同种类的工艺,逻辑“0”或“1”的电平不是固定的。在IIC总线每传输一位数据就有一个时钟脉冲相对应,其逻辑“0”
8、或“1”的信号电平取决于该节点的正端电源Vdd的电压。 2.2.1 数据的有效性 IIC总线数据传输时,在时钟线高电平期间数据线上必须保持稳定的逻辑电平状态,高电平为数据1,低电平为数据0。只有在时钟线为低电平时,才允许数据线上的电平状态变化。如图2.3所示。 图2.3 IIC总线上的数据有效性 2.2.2 总线数据传输的起始和终止 IIC总线数据传输定义了两种时序状态,分别为起始信号和终止信号,如图2.4所示。 启始信号(START),当时钟线SCL保持高电平期间,SDA由高电平向低电平切换,表示开始传送数据,终止信号(STOP),当时钟线SCL保持高电平期间,SDA由低电平向高电平切换,表
9、示停止传送数据。 图2.4 IIC总线上的起始和终止信号 起始信号与终止信号都是由主控制器产生,当IIC总线出现起始信号时,总线进入“忙”状态,当IIC总线上出现结束信号时,总线进入“空闲”状态。挂接在IIC总线上的主从设备通过检测起始信号和结束信号判断总线的“忙”、“空闲”状态。由于IIC总线协议不定义优先级概念,因此任何新进程的开始必须等待当前进程的结束。使用硬件接口可以很容易地检测起始和结束信号,没有这种接口的微机必须以每时钟周期至少两次对SDA取样以检测这种变化。 2.2.3 总线信号的时序 为了保证IIC总线数据的可靠传送,对总线上的信号时序做了严格的规定,下面各图中对主要信号时序做
10、了定义。 图2.5 主机向从机发送一个字节的时序 图2.5所表示的是主机向从机发送一个字节的时序,主机向传送一个7位的地址,第8位是读/写位。在第9个时钟时,从机发出一个响应信号,接着传输8位的数据,相应地从机继续发送一个响应位,然后主机在时钟线保持高电平期间,拉高数据线,数据传输停止。 图2.6 主机向从机接收1个字节数据的时序 图2.6所表示的主机向从机接收一个字节的时序,前面8个时钟周期与发送时序相同,不同的是在传输8位数据后,由主机发送响应信号,然后启动停止信号。2.3 IIC总线上的数据传输 2.3.1总线的数据传输格式 图2.10所示的是一个完整的数据传输格式。按照规定,在起始条件
11、(S)之后,发送一个7位的从机地址。紧跟着的第8位是数据方向位(R/W),数据方向表明主控器和被控器的数据传输方向。0表示主控器发送数据(写),1表示请求接收数据(读)。数据传输一般由主机产生停止位(P)终止。在这种传输中,也可以有不同的读/写格式相结合。下面介绍3种传输格式, 1、主控制器写操作 主机-发送器向从机发送n个数据字节,方向不变。 注 1-7是地址位,8位是读写位,第9位是响应位 图2.10 完整的数据传输 2、主控制器读操作 在第一个字节后,主控制器立即读从控制器。在第一次响应后,主控制器,发送器变成了主控制器,接收器,从控制器,接收器变成了从控制器,发送器。第一次响应仍由从控
12、制器产生。之前发送了一个不响应信号(/A)的主机产生停止条件。 3、主控制器的读写操作 在数据传输过程中需要改变传输方向操作,这时起始条件和从控制器地址都会被重复,但R/W位取反,它的方向由寻址字节的方向位决定。如果主控制器接收器发送一个重复起始条件,它之前应该发送一个不响应的信号/A,每个字节后都跟着一个响应位,在序列中用A或/A模块表示。寻址字节只表明器件地址及传送方向,器件内部的n个数据地址可以在I2C总线数据操作格式中用第一个数据字节指定。I2C总线被控制器在接收到起始信号后都必须复位他们的总线逻辑,以便对将要开始的被控制器地址的传送进行预处理。 2.4重复起始条件 主机与从机进行通信
13、时,有时需要切换数据的收发方向。例如,访问某一具有I2C总线接口的EEPROM存储器时,主机先向存储器输入存储单元的地址信息,发送数据,然后再读取其中的存储内容,接收数据,。在切换数据的传输方向时,可以不必先产生停止条件再开始下次传输,而是直接再一次产生开始条件。I2C总线在已经处于忙的状态下,再一次直接产生起始条件的情况被称为重复起始条件。重复起始条件常常简记为Sr。正常的起始条件和重复起始条件在物理波形上并没有什么不同,区别仅仅是在逻辑方面。在进行多字节数据传输过程中,只要数据的收发方向发生了切换,就要用到重复起始条件。 数据传输的结束信号由主IIC发出。刚刚结束一个进程的用户有立即启动一
14、个新进程的优先权,该用户可以不发出结束信号而直接发出一个新的启动信号和另一个从IIC地址,从而不给其他用户申请总线的机会,以保持自己继续使用总线的权利。 3 设计环境和设计方法 3.1 设计环境 本文中IIC总线接口的设计是利用Altera公司的设计软件Quartus II,用Verilog HDL语言编程实现的。仿真部分采用Quartus II+Modelsim。 Quartus II软件是Altera提供的完整的多平台设计环境,可以轻易地满足特定地设计需求,是SOPC设计的综合性环境。 硬件描述语言(HDL)是一种形式化方法来描述数字电路和设计数字逻辑系统的语言,它是硬件设计人员与EDA工
15、具之间沟通的桥梁,其主要目的是用来编写设计文件,建立电子系统行为级的模拟类型。3.2用Verilog HDL设计可综合的状态机 基于状态机的设计要点: (1)一个完备的状态机应该具有初始状态和默认状态。当芯片加电或者复位后,状态机能够自动将所有的判断条件复位,并进入初始状态,起始状态是指电路复位后所处的状态,选择一个合理的起始状态将使整个系统更简捷高效。当转移条件不满足,或者状态发生突变时,状态机进入一个默认(default)状态,能保证逻辑不会陷入“死循环”,这是对状态机健壮性的一个重要要求,即自动恢复功能。在case语句的最后,不要忘了加上default分支语句,以避免锁存器的产生。 (3
16、)建模 用两条always语句对其建模比较好:一个always语句用于组合逻辑建模(既包括次态逻辑,也包括输出逻辑),一个always语句用于时序逻辑建模。组合逻辑建模采用阻塞式赋值,时序逻辑建模采用非阻塞式赋值。 (4)时序方式选择 根据触发条件的不同,时序逻辑电路可以分为异步时序和同步时序逻辑。在异步时序逻辑中触发条件很随意,任何时刻都有可能发生,所以记忆状态的触发器输出在任何时刻都有可能发生,而同步时序逻辑中表示状态的触发器输出只能在惟一确定的触发条件发生时刻改变,例如只能由时钟的上升沿或下降沿触发。同步时序逻辑的触发输入至少可以维持一个时钟周期后才会发生第二次触发,利用这一段时间,即在
17、下一次触发信号来到前,为电路的状态改变创造了一个稳定可靠的条件。因此,同步时序逻辑比异步时序逻辑具有更可靠、更简单的逻辑关系。 目前,综合工具只支持同步时序逻辑的设计,用Verilog设计可综合的状态机也都使用同步时序逻辑。实用的状态机都应设计为由唯一时钟边沿触发的同步运行方式。 4 IIC总线接口设计 IIC总线接口的设计是整个系统设计的关键之一,从本章起,开始介绍IIC总线接口的内部模块的设计。在接口模块设计中,主要介绍模块要实现的功能和设计的思路,并给出用Quartus软件对每一个模块编译生成的单个电路模块。 4.1 实现功能 本文主要通过是用Verilog HDL语言在FPGA上实现I
18、IC总线接口,该接口接收来自高速设备或片上总线的读写命令信号、地址信号、并行数据信号,并把它们转换为相应的串行信号发送到Slave器件中去,它还发送应答信号,以便让主器件来调节发送或接收数据的速度移配合从器件的接收,写,和发送,读,数据。鉴于IIC总线的规范,其接口主要完成的功能如下:1、具有软件可编程系统时钟频率 2、软件可编程响应位 3、启动/停止/重启/响应各种触发状态 4、支持系统扩展 5、仅支持时钟同步,不支持仲裁 6、随机读取总线数据和状态 接口定义了2个传输速度:标准模式100 Kbps 快速模式400 Kbps 4.2 IIC总线接口的顶层设计 为了实现和IIC器件的通讯,该I
19、IC接口一方面要通过数据总线与微处理器交换数据,接收来自微处理器的控制信号,命令与数据,实现IIC接口与微处理器的通讯,另一方面要通过IIC总线与IIC器件交换数据,发送IIC器件的数据和状态响应到微处理器,使它们之间能够进行通讯。 根据据总线接口要完成的功能,采用自上而下的设计方法,综合考虑,设计如下: 1、时钟分频模块,由于通常FPGA的系统外部时钟输入都很高,如50MHz,而IIC总线接口协议规定数据传输速率在标准模式下为100Kbit/s,快速模式下为400 kbit/s及高速模式下为3.4 Mbit/s。为了能产生正确的数据传输时序,需要一时钟分频器对输入时钟进行分频,然后再作为时序
20、控制器的时钟。通过该模块实现频率的可编程,产生总线工作时钟;2、 接收数据模块,接受来自微处理器的数据信号,同时输出一个使时序控制模块工作的触发信号,并反馈给处理器一个响应信号,告诉处理器,已经接收完数据; 3、时序控制模块,控制整个系统工作的时序,并把8位并行数据转换成串行4、发送数据模块,反馈总线的工作信息; 5、输出缓冲器,是一个三态的缓冲器,可为总线时钟和数据信号提供开漏极输出; 6、寄存器组,包括了3个寄存器,各部分的信息如表4-1所示。 表4-1 IIC总线接口寄存器 寄存器地址类型字地址寄存器00读/写数据寄存器01只读状态寄存器10只读外部处理器发送出控制信号和地址信号,不同的
21、地址信号指向不同的寄存器,进入不同的读写状态。当地址信号是00时,指向字地址寄存器,处理器进入读/写状态,把数据信号写入字地址寄存器或者从寄存器读出,当地址信号是01,10时,外部处理器分别读取数据寄存器和状态寄存器。 parameter w_add=2b00;/地址寄存器 parameter d_add=2b01;/数据寄存器 parameter s_add=2b10;/状态寄存器 按照设计的要求,需要8位数据线,2位地址线,时钟线,复位,使能信号线,读写命令线,还有反馈信息的响应线以及一位串行时钟线和一位串行数据线。其详细的输入输出接口信号及其功能如表4-2所示,l表示信号低电位有效,在整
22、个设计中都应用了这个规则,其中cs_l是芯片的使能信号,和clk信号是同步的,只有当它有效的时候,其它的地址、复位和命令信号才能启动。 表4-2 IIC总线接口信号表 端口方向描述clock输入处理器的时钟输入rst_1输入异步复位信号cs_1输入接口使能信号rd_wr_l输入读写控制命令addr1:0 输入地址选择信号data7:0 双向数据输入输出信号ack_l 输出反馈给处理器的响应信号scl_pin输出IIC总线的时钟信号sda_pin 双向IIC总线的数据信号综上所述,整个设计分为6个模块,时钟分频器、时序控制器、数据接收器、数据发送器、输出缓冲器、寄存器组。其结构如图4.1所示。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 FPGA I2C 接口 程序 实现 课程设计
链接地址:https://www.31ppt.com/p-2393571.html