EEPROM读写控制器学习小结

    

   花了近两三个星期,从夏宇闻的书中一行行敲下代码,然后再在questasim仿真器下进行修改、编译和仿真。出现了很多错误,一一改正,学到了不少东西,由于记性太烂,过后即忘,逼着自己写下自己从中学到的知识点,以及一些自己的心得。

 

EEPROM行为模型:

1.       首先用verilog编写出eeprom的行为模型,因为我们在这里主要是设计读写控制器,eeprom只是仿真时需要的,所以只需要编写出其行为模型。我们可以用延时控制语句,事件控制语句。

2.       EEPROM有一个输入端口scl,和一个双向端口sda。

3.       EEPROM中的寄存器有地址寄存器(address),控制字节寄存器(ctrl_byte),数据字节寄存器(data_byte),以及状态寄存器,还有一个outflag寄存器,控制sda的双向端口特性。

4.       由于其不必综合,我们首先将其中的所有寄存器、存储单元都初始化。

EEPROM的读写时序是这样的:

Ø  scl作为串行的时钟信号在时钟为高电平时,如果检测到sda的上升沿,开始启动。

Ø  之后sda在低电平时给其赋值,在scl高电平到来时其已经稳定,并且在scl高电平期间保持不变。所以可在@posedgescl时将sda的值赋给eeprom中的地址或者数据寄存器。

Ø  写EEPROM用到shift_in这个任务,这个任务有输出shift,需要注意的是只有当任务全部执行完,输出才会传递到参

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: STM32 I2C读写EEPROM跨页写是指在使用STM32的I2C总线与EEPROM进行通信时,当需要写入的数据跨越了EEPROM的页边界时的处理方式。EEPROM是一种可擦写非易失性存储器,通常将数据按页(page)进行存储,每页包含固定数量的字节。 当需要向EEPROM中的一个页写入数据时,可以使用I2C总线发送一组连续的写入命令。但当需要跨页写入数据时,就需要分为多个步骤来完成: 1. 发送写入命令:首先,通过I2C总线发送一个写入命令,指定要写入的EEPROM地址。 2. 写入数据至页边界:将将要写入的数据按页边界切割,将数据的第一部分写入EEPROM的当前页。 3. 切换至下一页:如果需要写入的数据跨越了页边界,就需要切换到下一页。通过I2C总线发送一个新的写入命令,指定下一页的地址。 4. 写入剩余数据:将剩余的数据写入新的页中。 需要特别注意的是,在跨页写入时,需要保持I2C总线的稳定。在切换页的过程中,可能会出现一些延迟。为了确保稳定性,可以在发送写入命令之后,等待一段时间,以确保EEPROM已切换到新的页。 总结起来,STM32 I2C读写EEPROM跨页写,需要将要写入的数据按页边界切割,并在切换页时保持I2C总线的稳定性。 ### 回答2: STM32是一种微控制器,具有许多输入/输出接口(I/O接口),其中包括IIC(Inter-Integrated Circuit)接口。EEPROM(Electrically Erasable Programmable Read-Only Memory)是一种常用的非易失性存储器。 在STM32中,使用IIC读写EEPROM可以通过跨页写的方式实现。跨页写是一种技术,允许在一次传输中向EEPROM的多个页中连续写入数据。具体步骤如下: 1. 配置STM32的IIC接口模块。首先,需要设置相关寄存器以启用IIC接口,并配置通信速率和其他参数。 2. 初始化EEPROM。在进行IIC读写之前,需要初始化EEPROM。这可能包括发送一些特定的命令和设置寄存器。 3. 选择写入的页。要进行跨页写,需要选择要写入的起始页。可以使用特定的命令和地址选择页。在接收到页选择命令后,EEPROM将准备好接收数据。 4. 传输数据。将待写入的数据传输到IIC接口,并将其发送到EEPROM。在跨页写操作中,数据会自动从一个页传输到下一个页。可以通过循环迭代来传输更多数据。 5. 等待写入完成。在数据传输完毕后,需要等待EEPROM完成写入操作。通常,EEPROM会有一个内部标志位来指示写入是否完成。可以通过查询此标志位来等待写入操作的完成。 6. 关闭IIC接口。在完成读写操作后,需要关闭IIC接口,以便其他设备可以使用该接口。 请注意,具体的实现细节可能会因不同的STM32系列和EEPROM型号而有所不同。因此,建议参考相应的STM32和EEPROM芯片的数据手册,以获取更详细的信息和代码示例。 ### 回答3: IIC(Inter-Integrated Circuit)是一种串行通信协议,常被用来连接微控制器与外部设备。在STM32微控制器中,使用IIC总线可以实现对EEPROM(Electrically Erasable Programmable Read-Only Memory)的读写操作。 对于EEPROM的跨页写操作,即在写入数据时,需要跨越EEPROM的页边界进行写入。通常,EEPROM内部的数据存储以页为单位分割,每一页包含多个字节的数据。当写入数据时,如果需要跨越页边界,就需要对两个相邻页的数据进行处理。 在使用STM32的IIC读写EEPROM进行跨页写操作时,可以按照以下步骤进行: 1. 初始化IIC总线和相关的引脚设置,确保正确连接STM32和EEPROM。 2. 设置EEPROM的读写地址,确定要写入的页和具体的地址。 3. 将待写入的数据按照页的边界进行分割,分为需要写入的第一个页和第二个页的数据。 4. 先发送写入第一个页数据的命令,同时发送第一个页数据的地址和数据。 5. 等待IIC总线的传输完成,并确认写入第一个页数据是否成功。 6. 如果写入第一个页数据成功,再发送写入第二个页数据的命令,同时发送第二个页数据的地址和数据。 7. 等待IIC总线的传输完成,并确认写入第二个页数据是否成功。 8. 在每一步操作完成后,需要根据EEPROM的ACK信号来判断是否写入成功。 在进行EEPROM的跨页写操作时,需要注意以下几点: - 需要保证跨页写入的数据长度不超出一个页的容量。 - 写入数据时需要正确设置地址,并按照页的边界进行分割。 - 在写入数据后,需要通过确认ACK信号来验证写入是否成功。 - 需要正确处理IIC总线的通信协议,包括起始位、地址位、数据位和停止位等。 总结来说,使用STM32的IIC总线读写EEPROM时,可以通过合适的设置和使用跨页写操作来实现对EEPROM数据读写

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值