基于NiosII的I2C总线接口的实现

最新更新时间:2012-04-12来源: 互联网关键字:NiosII  I2C总线  接口 手机看文章 扫描二维码
随时随地手机看文章

本文提出采用"NiosⅡ+AT24C02"设计方案,在介绍AT24C02A芯片主要特性和分析I2C通信协议原理基础上,重点介绍Nios Ⅱ与AT24C02A之间接口电路的设计方法,包括接口电路的寄存器定义、逻辑功能模块设计和驱动程序的编写三个方而的内容,利用嵌入式逻辑分析仪(SigalTap Ⅱ Logic Analyzer)来分析接口信号时序,分析结果表,本接口所产生的读写时序满足I2C的通信协议要求,验证了设计的正确性。

  1 AT24C02A芯片简介

  AT24C02A芯片,是由ATMEL公司生产的基于I2C总线型的串行电可擦除的可编程存储器(EEPROM),内部含有2Kbit的存储单元,是通过二根线(SDL与SCL)与外部I2C控制器交换数据。

  AT24C02A芯片的主要特性如下:

  低电压和标准电压操作

  -2.7(VCC=2.7V至5.5V)

  -1.8(VCC=1.8V至5.5V)

  片内存储容量为256×8 bit(2K)

  2线串行接口

  施密特触发器,过滤输入的噪声抑制

  双向数据传输协议

  100 kHz(1.8V、2.5V、2.7V)和400 kHz(5V)兼容性

  写保护引脚的硬件数据保护。

  2 I2C通信协议

  2.1 I2C通信协议简介

  AT24C02A器件采用成本低廉的I2C(Inter integrat-ed Circuit)总线通信协议,SDA和SCL均为双向I/O线,通过上拉电阻接正电源。当总线空闲时,两根线都是高电平。连接总线的器件的输出级必须是集电极或漏极开路的。I2C总线的数据传送速率在标准工作方式下为100kbit/s,在快速方式下,最高传送速率可达400kbit/s。

  在数据传送过程中,必须确认数据传送的开始和结束信号(也称启动和停止信号)。当时钟线SCL为高电平时,数据线SDA由高电平跳变为低电平则定义为"开始"信号;当SCL为高电平时,SDA由低电平跳变为高电平则定义为"结束"信号。开始和结束信号都由主器件产生。在开始信号以后, 总线即被认为处于忙状态;在结束信号以后的一段时间内,总线被认为是空闲状态。

  在I2C总线开始信号后,依次送出器件地址和数据,I2C总线上每次传送的数据字节数不限,但每一个字节必须为8位,而且每个传送的字节后面必须跟一个认可位(第9位),也叫应答位(ACK)。从器件的响应信号结束后,SDA线返回高电平,进入下一个传送周期。

  

I2C通信协议的时序图
2.2 AT24C02A器件读写时序

  一个写功能要求一个8位数据字地址随设备地址字和acknowledgement(承认)。在这个地址的收据之上,EEPROM将再响应由一个0且时钟在第一个8位数据字。随着8位数据字的收据,EEPROM将输出一个0且寻址设备,例如一个微控制器,必须指定带停止条件的写时序。在这个时间EEPROM进入一个internally-timed(内部定时)写时序,tWR,对于非易失性内存。所有输入关闭在这个鞋周期之间且EEPROM将不响应直到写完成(关系Figure 2)。

  读功能被初始化与写功能相同由外部的读/写选择位在设备地址字被设置为1。有三个读功能:当前地址读取,随机地址读取和顺序读取。

  当前地址读取:内部数据字地址计数器包含最后一个地址访问在最后一个读或写功能期间,以1递增。这个地址保持有效在芯片电源提供工作期间。地址“折返”在读来自于最后内存页到第一页的第一个字节期间。这个地址“折返”在写来自于当前页的最后一个字节到同样页的第一个字节期间。

  图2为写(读)AT24C02A器件中指定地址存储单元的数据帧格式,图2(a)为写操作的帧格式,(b)为读操作帧格式。要想把一个字节数据发送到器件中(或从器件中读取一个字节数据)除了给出具体的地址信息之外,还要给出该器件的控制信息:首先由控制器发出“启动”信号,启动I2C总线的通信,然后发送一个控制字节,前7位为器件的片选地址,最后1位为读写控制位,“0”表示写,“1”表示读。当传完控制字节之后,挂在I2C总线的所有的器件比较控制字节片选地址(前7位)是否与自已的物理地址一致,如一致,则发一个应答信号。控制器接收到应答信号之后,再发器件内部存储单元地址和其他的信息。

  

写

 

  3 AT24C02A读写控制接口设计

  3.1 寄存器组定义

  为了实现NiosⅡI能与外部设备进行交换数据,首先要在AT24C08读写控制接口中定义寄存器,包括数据寄存器、状态寄存器和控制寄存器。表4-1AT24C02A读写控制器内部寄存器定义的情况:STate_Re为此接口电路的状态寄存器,最低位有效,用来表示接口电路的状态,“1”表示接口处于“忙”状态中,此时表示接口正处于读写外部设备(AT24C02A)中,不能对此控制接口进行操作,只到接口处于“0”状态时为止;Address_Re为数据寄存器,用于存放NiosⅡ要访问AT24C02A器件内部单元的地址数据;CONtrol_Re为控制寄存器,控制着接口电路启动或停止,“1”为启动,“0”停止;Data_Re为数据寄存器,用于存放传输的数据;Con_r/w_Re为控制寄存器,控制数据的传输方向,高电平为读(输入),低电平为写(输出)。

  

1AT24C02A读写控制器内部寄存器定义的情况

 

  3.2 逻辑功能模块设计

  在接口电路中,除了定义接口电路的寄存器组之外,还要利用硬件描述语言来描述接口电路要实现的功能,即逻辑功能模块的设计。接口电路要完成的主要功能是,用接口电路产生如图3所示的时序,成功读写外部存储器件。在本设计中,采用了有限状态机来实现这一功能,图3为本设计的各个状态之间转换状态图:当NiosⅡ要交换数据时,首先要读State_Re的值,并判定电路是否为“空闲”状态,只有状态机处在空闲状态,才允许进行一次读写操作,并修改状态寄存器的值为“忙”状态;当完成一次读写操作时,修改状态寄存器的值为“闲”状态。

  

读写控制接口读写操作状态转移
4 在NiosⅡIDE环境中软件设计

  打开NiosⅡEDS,并点击new菜单建立工程文件,在IDE环境中完成接口电路驱动程序编写。驱动程序主要的任务,是判断接口电路所处的状态,当接口电路处于“闲”状态时,设置好接口电路中的寄存器中的值,并启动一次读写操作。图4为驱动程序的算法流程图。

  

软件算法流程图

 

  5 测试结果

  为了验证设计的正确性,对以上设计进行测试。在测试的过程中,可以利用嵌入式逻辑分析仪(SigalTapⅡLogic Analyzer)来分析信号时序,打开工程文件,点击File菜单,为本设计新建一个矢量波形文件(Vectorwaveform File),把要测试的信号添加到此文件中来,并设置好相关参数,保存并编译系统,然后把系统的配制文件下载到EP1C6Q240C8可编程器件中等待调试,最后,在:NiosⅡ的ID E中,把驱动程序下载到可编程器件中,并在QuartusⅡ软件中打开矢量波形文件,观察被测信号的时序,图5为接口电路把数据为“11111111”写到地址为“10101010”单元中的时序图。从图可以看出,启动时序、数据传输时序和停止时序都满足I2C通信协议要求,验证了本接口电路的正确性。

  

接口电路把数据为

 

  6 结束语

  本文在讨论了I2C通信协议的基础上,重点介绍了AT24C02A读写接口电路设计方法,包括接口电路的寄存器定义、逻辑功能模块设计和驱动程序的编写,并利用嵌入式逻辑分析仪(SigalTapⅡLogic Analyzer)对本接口电路进行测试,测试结果表明,本设计满足设计要求,并在实际电路中得到应用。

关键字:NiosII  I2C总线  接口 编辑:神话 引用地址:基于NiosII的I2C总线接口的实现

上一篇:TS61158现场总线介绍
下一篇:Piccolo USB工具

推荐阅读最新更新时间:2023-10-12 20:38

基于USB接口的锂离子电池充电电路设计与实现
锂离子电池及USB接口概述 锂离子(Li-ion)电池,简称锂电池,是近年来逐渐普及使用的一种新型电池,具有体积小、重量轻、容量大(能量密度高)、自放电率低以及无记忆效应等优点,但同时它也有一些致命的缺陷:对充电、放电的要求比较苛刻,不能过充和过放,否则容易造成不可逆转性损坏,在短路、过充等极端情况下还有可能发生爆炸,产生危险。 一般锂电池单节标称电压为316~317V,充电时,一般要求采用限压限流法,首先恒流充电,即电流一定,充电电流按国家标准规定的低倍率充电是0.2C(仲裁充电制式),最大不超过1C;而电池电压随着充电过程逐步升高,当电池端电压达到终止电压412±0105V时,应改恒流充电为恒压小电流(约011C)充电,这个
[电源管理]
基于USB<font color='red'>接口</font>的锂离子电池充电电路设计与实现
新一代数字多媒体接口的架构及应用
  视频电子标准组织(VESA)不久前正式发布了DisplayPort标准的1.0版本。VESA对这个标准有着宏伟的蓝图,即一统纷繁复杂的数字多媒体接口标准领域。 在DisplayPort之前,数字多媒体接口标准经历了多次纷争,逐渐形成了外部连接(Box-to-Box)与内部连接(Chip-to-Chip)两块相互独立的阵地。在外部连接方面,PC已有DVI;而CE方面也有方兴未艾的HDMI;至于内部连接则是约定俗成的标准——LVDS。既然DisplayPort力求一统,那它究竟有哪些先进之处呢?下面,分别从链路层、物理层、内外部接头三方面来详细阐述DisplayPort的技术特点,最后结合PC和CE应用来论述它的优势。
[嵌入式]
USB接口的虚拟仪器设计与实现
引言 USB技术的先进性使得设计者在PC外设开发中首选USB接口,而在现有虚拟仪器开发平台如LabWindows/CVI中并没有提供直接支持USB接口的函数库,基于这种情况,笔者利用FTDI公司的FT232AM完成RS232和USB之间的接口转换,然后再对USB接口实现间接的数据读写。 2 硬件设计 2.1 FT232AM简介 FT232AM是FTDI公司提供的USB-RS232转换器,它可以在RS232和USB接口之间非常容易地建立可靠连接。通过USB接口的即插即用和热插拔性能给RS232的外围设备提供非常容易使用的环境,并提供高达115 kb/s的传输速率(如果电平转换器选用MAX3245CAI,则传输速率可达
[嵌入式]
MSP430编程器仿真器以及JTAG、SBW、BSL接口的区别
对于51系统来说,很容易理解编程器和仿真器。 通俗的说,仿真器是用来调试仿真的,编程器是用来批量生产时对MCU进行烧写目标代码的。 对于MSP430来说,无论仿真还是烧写程序一般可以通过:JTAG、SBW、BSL接口进行。JTAG、SBW接口可以用于仿真接口,BSL接口不能用于仿真。而编程器则三种接口都支持。 所以并不能说JTAG只支持仿真不支持编程,这是概念错误,JTAG仅仅是一种接口协议而已。 下面简单描述一下三种接口的区别: 1、JTAG是边界扫描技术,其在430内部有逻辑接口给JTAG使用,内部有若干个寄存器连接到了430的内部数据地址总线上,所以可以用JTAG访问430内部的所有资源,包括对FLASH的读写操作。所
[单片机]
DDS芯片AD9850的工作原理及其与单片机的接口
1 AD9850简介 随着数字技术的飞速发展,用数字控制方法从一个参考频率源产生多种频率的技术,即直接数字频率合成(DDS)技术异军突起。美国AD公司推出的高集成度频率合成器AD9850便是采用DDS技术的典型产品之一。 AD9850 采用先地蝗CMOS工艺,其功耗在3.3V供电时仅为155mW,扩展工业级温度范围为-40~80℃,采用28脚SSOP表面封装形式。AD9850的引脚排列如图1所示,图2为其组成框图。图2中层虚线内是一个完整的可编程DDS系统,外层虚线内包含了AD9850的主要组成部分。 AD9850 内含可编程DDS系统和高速比较器,能实现全数字编程控制的频率合成。可编程DDS系统的核心是相位累加器
[单片机]
DDS芯片AD9850的工作原理及其与单片机的<font color='red'>接口</font>
MCS-51单片机与CPLD/FPGA接口逻辑设计
在功能上,单片机与大规模CPLD有很强的互补性。单片机具有性能价格比高、功能灵活、易于人机对话、良好的数据处理能力潍点;CPLD/FPGA则具有高速、高可靠以及开发便捷、规范等优点。以此两类器件相结合的电路结构在许多高性能仪器仪表和电子产品中仍将被广泛应用。本文就单片机与CPLD/FPGA的接口方式作一简单介绍,希望对从事单片机和CPLD/FPGA研发的朋友能有所启发。 单片机与CPLD/FPGA的接口方式一般有两种,即总线方式与独立方式,分别说明如下: 一、总线方式 单片机以总线方式与CPLD/FPGA进行数据与控制信息通信有许多优点。 (1)速度快。如图一所示,其通信工作时序是纯硬件行为,对于MCS-51单片机,只需一条单字节
[应用]
DP来势凶猛,HDMI在便携市场寻求安慰
  2008年将是DisplayPort(简称DP)技术进入飞速发展的一年。在2008年的CES展上,采用最新DisplayPort技术的计算机主板、显示器、芯片等产品在DisplayPort 区集中进行了展示,预示着支持DP标准的产品在2008年开始集中上市,未来几年在PC数字接口市场将快速上涨。终端用户接触最直接的DP产品是支持DP接口的主板、显卡以及计算机显示器,而在LCD 面板上采用DP取代LVDS的应用进程也在加速。 李秀东:DP接口给用户感觉更友好,这种美妙的心理恰是市场需求的体现。   “DP接口给用户感觉更友好,这种美妙的心理恰是市场需求的体现。”硅谷
[焦点新闻]
汽车LVDS接口保护电路图
LVDS(英文全称:Low-Voltage Differential Signaling),中文叫:低电压差分信号,是一种低功耗、低误码率、低串扰和低辐射的差分信号技术,被广泛应用于串行高速数据通讯场合。低电压差分信号(LVDS)技术核心是采用极低的电压摆幅高速差动传输数据,能够实现点对点或一点对多点的连接,为汽车应用提供了可靠的视频接口。很多汽车厂商都会利用LVDS技术去实现车上的高速图像传输。 都知道,汽车工作环境比较恶劣,为此,在设计高速低电压差分信号(LVDS)接口系统时,应选用正确的电路保护元件免受瞬态威胁并满足现代汽车的安全性和可靠性。事实证明,在 LVDS 差分线路上,选用瞬态电压抑制TVS/ESD二极管,可以在上
[嵌入式]
汽车LVDS<font color='red'>接口</font>保护电路图
小广播
最新模拟电子文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved