ZYNQ_project:IIC_EEPROM
EEPROM简介:
EEPROM(Electrically Erasable Progammable Read Only Memory, E2PROM)是指带电可擦可编程只读存
储器,是一种常用的非易失性存储器(掉电数据不丢失), E2PROM 有多种类型的产品,我们领航者 ZYNQ
开发板上使用的是 ATMEL 公司生产的 AT24C 系列的 AT24C64 这一型号。 AT24C64 具有高可靠性,可对所
存数据保存 100 年,并可多次擦写,擦写次数达一百万次。
它的存储容量:256页每页32个字节。256 x 32 = 8192 (byte字节)
8192 x 8 = 65536(bit比特)
65536 / 1024 = 64 (Kbit)。。。。所以是AT24C系列,64Kbit存储容量。
AT24C64 采用两线串行接口的双向数据传输协议——I2C 协议实现读写操作,所以我们有必要了
解一下 I2C 协议。
IIC协议简介:
简单,双向,二线制总线标准。多用于主机与从机在数据量不大且短距离的(主从)通信。
主机启动总线,并产生时钟用于传送数据,此时任何接收数据的器件均被认为是从机。
IIC总线由数据线SDA和时钟线SCL构成通信线路,各种iic通信器件并联在总线上,通过器件地址识别器件(与器件通信前先要找到这个器件,发地址,等响应,找到对应要通信的从设备)。
IIC总线物理结构拓扑原理结构图:
图中的 I2C_SCL 是串行时钟线, I2C_SDA 是串行数据线,由于 I2C 器件一般采用开漏结构与总线相连,
所以 I2C_SCL 和 I2C_SDA 均需接上拉电阻,也正因此,当总线空闲时,这两条线路都处于高电平状态,当
连到总线上的任一器件输出低电平,都将使总线拉低,即各器件的 SDA 及 SCL 都是“线与”关系。
I2C 总线支持多主和主从两种工作方式,通常工作在主从工作方式,我们的开发板就采用主从工作方式。
在主从工作方式中,系统中只有一个主机,其它器件都是具有 I2C 总线的外围从机。在主从工作方式中,主
机启动数据的发送(发出启动信号)并产生时钟信号,数据发送完成后,发出停止信号。
IIC的协议层
仔细观察图 33.1.2 可知 IIC 协议的整体时序由四个部分构成,上图中分别使用①、②、③、④进行区
分。
图中①: 总线空闲状态, 在 I2C 器件开始通信(传输数据)之前,串行时钟线 SCL 和串行数据线 SDA
线由于上拉的原因处于高电平状态,此时 I2C 总线处于空闲状态。
图中②: 起始信号, 如果主机(此处指 FPGA)想开始传输数据,只需在 SCL 为高电平时将 SDA 线拉
低,产生一个起始信号。
图中③: 数据传输状态, 主机可以向从机写数据,也可以读取从机输出的数据,数据的传输由双向数据
线(SDA)完成。
图中④: 停止状态, 当数据传输完成,主机只需产生一个停止信号,告诉从机数据传输结束,停止信号
的产生是在 SCL 为高电平时, SDA 从低电平跳变到高电平,从机检测到停止信号后,停止接收数据,并且
I2C 总线跳转回总线空闲状态。
数据传输的具体时序:
scl为高时,sda产生下降沿,产生起始信号。(告诉从机,要开始数据通信了)。
在scl为低时,sda可以改变数据;scl为高时,sda数据保持;
8bit数据一组,也就需要8个时钟周期;
第九个时钟周期:主机释放总线,从机控制总线产生应答位0.若为高,则说明无应答,这组数据是无效的传输。
scl为高时,sda产生上升沿,表示停止信号。(主机结束与从机的通信)
器件地址:
当多个 I2C 器件挂接在总线上时,怎样才能与我们想要传输数据的器件进行通信。这就涉及到了器件地址(也称从机地址, SLAVE ADDRESS)。
有两种器件地址:7bit全都是固定的,与部分bit固定,部分bit可编程。
AT24C64,起始位+1010+A2A1A0.最低三位可编程。
WR位为0,表示主机要进行写操作,1表示读操作。
IIC 读写时序
写时序:(字节写和页写)
字节写:
主机发送完字地址,从机正确应答后就把内部的存储单元地址指针指向该单元。如果读写控制位 R/W位为“0”即写命令,从机就处于接收数据的状态,此时,主机就开始写数据了,写数据可分为单次写(对于 E2PROM 而言,称为字节写)和连续写(对于 E2PROM 而言,称为页写)。下面我们先分别介绍 E2PROM的单次写与连续写。
从左上角开始按行往右看。
(1)主机先产生开始标志信号:scl == 1 sda产生下降沿。
(2)然后发送器件地址(MSB~LSB高位在前)最后一位是读写控制标志位,读写控制信号位,0写;1读。
(3)然后从机产生应答位。
(4)然后发送字地址(存储器的存储空间的地址,相当于指针,相当于门牌号(学过C语言的都应该不陌生))由于AT24C64,存储空间为64Kbit,8bit只能表示256byte(2的8次方 = 256)(256x8/1024 == 2Kbit).
64Kbit : 64x1024/8= 8192
2的13次方,才能表示完8192个数据。
iic以字节传数据,所以AT24C64要用两字节的字地址。
从机指针指向对应的字地址,准备接收数据。
每传递一字节数据后从机会在下一个时钟周期产生应答位。(主机释放总线,从机拉低总线)
(5)然后从机产生应答位。
(6)然后主机开始发送数据:8bit数据位,
(7)然后从机产生应答位。
(8)然后主机产生停止信号,结束位。
页写:
接下来我们开始介绍 E2PROM 的连续写(页写)时序:
(1)主机产生起始信号。
(2)主机发送器件地址+指令bit。
(3)从机应答。
(4)主机发送第一个字节,从机应答。第二个字节,从机应答。
(5)传递一字节的数据,高位在前。
(6)从机产生应答位。每(正确)传递一字节数据,从机就会给出应答位。
(7)主机发送停止信号。
两者的区别在于发送完一字节数据后,是发送结束信号还是继续发送下一字节数据,如果发送的是结束信号,就称为单次写,如果继续发送下一字节数据,就称为连续写。
要注意的是, 所有 I2C 设备均支持单字节数据写入操作,但只有部分 I2C 设备支持页写操作,对于
AT24C64 的页写,是不能发送超过一页的单元容量的数据的,而 AT24C64 的一页的单元容量为 32Byte,当
写完一页的最后一个单元时,地址指针指向该页的开头,如果再写入数据,就会覆盖该页的起始数据。
读时序:
I2C 写时序介绍完毕后,接下来我们开始 I2C 读时序部分的介绍。根据一次读操作读取数据量的多少,
读操作可分为随机读操作和顺序读操作。
读数据有三种方式:当前地址读,随机读,连续读。
当前地址读方式:
当前地址读是指在一次读或写操作后发起读操作。由于 I2C 器件在读写操作后,其内部的地址指针自动加一,因此当前地址读可以读取下一个字地址的数据。也就是说上次读或写操作的单元地址为 02 时,当前地址读的内容就是地址 03 处的单元数据。
(1)主机发送起始信号。
(2)主机发送器件地址+读命令(1).
(3)从机发送响应信号,从机应答。
(4)从机发送数据8bit,高位在前。
(5)主机非应答,高电平无应答信号.
(6)主机发送停止信号。
随机读取方式:
并不随机,指定地址并读取一字节数据。
(1)主机发送起始信号。
(2)主机发送器件地址+写指令(0).原因是,接下来是要写入字地址(存储器的地址),所以是写指令。从机产生应答位。
(3)主机发送第一字节地址,从机产生应答位。
(4)主机发送第二字节地址,从机产生应答位。
(5)主机发送起始信号。又一次发送起始信号。
(6)主机发送期间地址+读指令(1).从机产生应答位。
(7)从机发送8bit数据。主机产生无应答位。
(8)主机发送停止信号。
需要注意理解的是随机地址读在发送完器件地址和字地址后,竟然又发送起始信号和器件地址,而且第一次发送器件地址时后面的读写控制位为“ 0”,也就是写命令,第二次发送器件地址时后面的读写控制位为“1”,也就是读。为什么会有这样奇怪的操作呢?这是因为我们需要使从机内的存储单元地址指针指向我们想要读取的存储单元地址处,所以首先发送了一次Dummy Write 也就是虚写操作,只所以称为虚写,是因为我们并不是真的要写数据,而是通过这种虚写操作使地址指针指向虚写操作中字地址的位置,等从机应答后,就可以以当前地址读的方式读数据了。
当前地址读下的连续读:
当前地址读和随机读都是一次读取一个字节,连续读是将当前地址读或随机读的主机非应答改成应答,表示继续读取数据。
(1)主机发送起始信号。
(2)主机发送器件地址+读命令(1),从机产生应答信号。
(3)从机发送8bit数据,主机产生应答信号(0).
(4)从机发送下一字节数据,主机产生应答信号(0).
.................
(5)从机发送下一字节数据,主机产生无应答信号(1).
(6)主机发送停止信号。
随机地址连续读:
有当前地址连续读,当然也有随机地址连续读,随机地址连续读是在图 33.1.10 随机地址读时序的基础上,主机非应答改成应答,表示继续读取数据。
(1)主机发送起始信号。
(2)主机发送器件地址+写指令(0).原因是”虚写“。从机产生应答位。
(3)主机发送第一字节地址,从机产生应答位。
(4)主机发送第二字节地址,从机产生应答位。
(5)主机发送起始信号。又一次发送起始信号。
(6)主机发送期间地址+读指令(1).从机产生应答位。
(7)从机发送8bit数据。主机产生应答位(0)。
(8)从机发送下一字节的8bit数据。主机产生应答位(0)。
................
(10)从机发送8bit数据。主机产生无应答位。
(11)主机发送停止信号。
总结:
所以器件地址为1010_000
实验任务:
本节的实验任务是先向 E2PROM(AT24C64)的存储器地址 0 至 255 分别写入数据 0~255;写完之后再读取存储器地址 0~255 中的数据,把读到的数据通过串口发送给上位机,验证数据正确否。
明天完成部分
模块框图:
时序图:
代码:
仿真:
相关文章:

ZYNQ_project:IIC_EEPROM
EEPROM简介: EEPROM(Electrically Erasable Progammable Read Only Memory, E2PROM)是指带电可擦可编程只读存 储器,是一种常用的非易失性存储器(掉电数据不丢失), E2PROM 有多种类型的产品,我…...
Leetcode 2940. Find Building Where Alice and Bob Can Meet
Leetcode 2940. Find Building Where Alice and Bob Can Meet 1. 解题思路2. 代码实现3. 算法优化 题目链接:2940. Find Building Where Alice and Bob Can Meet 1. 解题思路 这一题本质上又是限制条件下求极值的问题,算是我最不喜欢的题目类型之一吧…...

C++ 泛型编程,函数模版和类模版
1.泛型编程 泛型编程:编写与类型无关的通用代码,是代码复用的一种手段。模板是泛型编程的基础 就比如说活字印刷术,就是提供一个模具,然后根据模具来印刷出不同的字。 泛型编程跟着类似,提供一个模版,根据这…...

【封装UI组件库系列】封装Button图标组件
封装UI组件库系列第四篇封装Button按钮组件 🌟前言 🌟封装Button组件 1.分析封装组件所需支持的属性与事件 支持的属性: 支持的事件: 2.创建Button组件 🌟封装功能属性 type主题颜色 plain是否朴素 loading等…...

windows系统mobaxterm远程执行linux上ssh命令
命令如下 start "" "%~dp0\MobaXterm_Personal_23.4.exe" -newtab "sshpass -p root ssh root192.168.11.92 mkdir 33" -p 是密码 左边是用户名,右边是服务器ip 后面跟的是服务器上执行的命令 第一次执行的时候要设置mobaxt…...

debian 12 配置
1. 修改apt源 修改apt源为http版本 # 默认注释了源码镜像以提高 apt update 速度,如有需要可自行取消注释 deb http://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm main contrib non-free non-free-firmware # deb-src http://mirrors.tuna.tsinghua.edu.cn/d…...

AIGC创作系统ChatGPT网站源码、支持最新GPT-4-Turbo模型、GPT-4图片对话能力+搭建部署教程
一、AI创作系统 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统,支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI…...
Vue 中简易封装网络请求(Axios),包含请求拦截器和响应拦截器
Vue 中简易封装网络请求(Axios),包含请求拦截器和响应拦截器 axios简介 Axios 是一个基于 promise 的网络请求库,可以用于浏览器和 node.js Axios官方中文文档 特性 从浏览器创建 XMLHttpRequests从 node.js 创建 http 请求支…...

git提交报错error: failed to push some refs to ‘git url‘
1.产生错误原因 想把本地仓库提交到远程仓库,报错信息如下 git提交报错信息 error: src refspec master does not match any error: failed to push some refs to git url 错误原因: 我们在创建仓库的时候,都会勾选“使用Reamdme文件初始化…...
【Python】(自定义函数)模块的相对路径导入
是我以前写的老文章的升级版,本质上使用exec和sys.path实现相对路径导入。 RelativeImport: __version__1.1.0 __author__Ls_Janimport os import sys import inspectdef RelativeImport(module,*args):#模块导入module为模块所在路径(模块名不需要.py后…...

巧妙之中见真章:深入解析常用的创建型设计模式
设计模式之创建型设计模式详解 一、设计模式是什么?二、模板方法2.1、代码结构2.2、符合的设计原则2.3、如何扩展代码2.4、小结 三、观察者模式3.1、代码结构3.2、符合的设计原则3.3、如何扩展代码3.4、小结 四、策略模式4.1、代码结构4.2、符合的设计原则4.3、如何…...

Selenium切换窗口、框架和弹出框window、ifame、alert
一、切换窗口 #获取打开的多个窗口句柄 windows driver.window_handles #切换到当前最新打开的窗口 driver.switch_to.window(windows[-1]) #最大化浏览器 driver.maximize_window() #刷新当前页面 driver.refresh() 二、切换框架frame 如存在以下网页: <htm…...

QT linux下应用程序打包
一、应用程序app 1、应用程序的pro文件 2、 程序工作函数 3、app的UI界面 二、动态库lib 1、Lib类头文件 2、.cpp文件 三、对应用程序和动态库进行构建 1、对动态库进行qmake,然后进行构建 2、对应用程序进行qmake,然后进行构建 3、查看构建目录 四、编写脚本 …...

Java高级技术(单元测试)
一,概括 二,junit 三,案例 (1),实验类 package com.bilibili;public class Name {public static void main(String name) {if (name null){System.out.println("0");return;}System.out.print…...

leetCode 1080.根到叶路径上的不足节点 + 递归 + 图解
给你二叉树的根节点 root 和一个整数 limit ,请你同时删除树中所有 不足节点 ,并返回最终二叉树的根节点。假如通过节点 node 的每种可能的 “根-叶” 路径上值的总和全都小于给定的 limit,则该节点被称之为 不足节点 ,需要被删除…...

C++基础 -10- 类
类的格式 public:公共成员 类外可访问 protected:保护成员 类外不可访问 private:私有成员 类外不可访问 class base {public:int a;protected:int b;private:int c;};...

【软件测试】性能测试相关指标
性能测试 了解性能测试相关指标 1.什么是做性能测试 1.1 生活中遇到的软件性能问题 软件用着用着就不能用了,一看热搜,发现该软件的服务器崩崩溃了。 1.2 性能测试定义 测试人员借助性能测试工具,模拟系统在不同场景下,对应…...
Leetcode 2943. Maximize Area of Square Hole in Grid
Leetcode 2943. Maximize Area of Square Hole in Grid 1. 解题思路2. 代码实现 题目链接:2943. Maximize Area of Square Hole in Grid 1. 解题思路 这一题的话其实横轴和竖轴可以分开来独立考察,因为两者互不影响,我们最终的答案一定是两…...
qt 简单了解QHBoxLayout QVBoxLayout QFormLayout水平,垂直,表单布局管理器.
QHBoxLayout水平布局,QVBoxLayout垂直布局,QFormLayout表单布局管理器,是常用的布局管理器,是用代码编写应用界面必不可少的功能类. 1.tips 这里值得注意的是,2个单选按钮(QRadioButton)同时放进一个水平布局管理器(QHBoxLayout)中,相当于放进了一个分组器中,此时,2个单选按钮…...

springboot中4级配置文件优先级
springboot中4级配置文件优先级...

RocketMQ延迟消息机制
两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数,对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后…...

从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...
FFmpeg 低延迟同屏方案
引言 在实时互动需求激增的当下,无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作,还是游戏直播的画面实时传输,低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架,凭借其灵活的编解码、数据…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...

【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...
JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案
JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停 1. 安全点(Safepoint)阻塞 现象:JVM暂停但无GC日志,日志显示No GCs detected。原因:JVM等待所有线程进入安全点(如…...

学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2
每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...

均衡后的SNRSINR
本文主要摘自参考文献中的前两篇,相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程,其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt 根发送天线, n r n_r nr 根接收天线的 MIMO 系…...