三、IIC总线协议——2、AT24C02

2024-08-30 16:28
文章标签 协议 总线 iic at24c02

本文主要是介绍三、IIC总线协议——2、AT24C02,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、AT24C02介绍

        EEPROM是一种掉电后数据不丢失的储存器,常用来存储一些配置信息,在系统重新上电时就可以加载。

        AT24C02是一个2K bit的EEPROM存储器,使用IIC通信方式。

        A0/1/2 : 设备地址决定引脚。、

        WP : 写保护引脚。

        SCL : 时钟线。

        SDA : 数据线。

                                                        图1 AT24C02接线图

        24C02由32页(page)组成且每页8Byte:

                                                         图2 AT24C02内存示意图

AT24C02通讯地址:不可编程部分(1010),可编程部分(由硬件管脚A0/1/2决定),

数据传输方向(读数据‘1’,还是写数据‘0’)

AT24C02,写操作地址:0xA0。读操作地址:0xA1。

二、AT24C02读写时序

1、AT24C02支持的读写操作     

        ①写操作

        AT24C02支持字写模式页写模式

        字写模式就是一个地址一个数据进行写入。

        页写模式就是连续写入数据。只需要写一个地址,连续写入数据时地址会自增,但存在页的限制,超出一页时,超出数据覆盖原先写入的数据。

        ②读操作

        AT24C02支持当前地址读模式随机地址读模式顺序读模式

        当前读模式是基于上一次读/写操作的最后位置继续读出数据。

        随机地址读模式是指定地址读出数据。

        顺序读模式是连续读出数据。

2、AT24C02写时序波形图

        地址和方向(DEVICE ADDRESS):IIC总线上设备的地址,选中哪一个设备,以及读还是写。

        内存地址(WORD ADDRESS):被选中IIC总线上的设备中的地址。及AT24C02中的地址。

        数据内容(DATA):由主机发出数据,向WORD ADDRESS地址写入数据。

        注意:EEPROM比较慢,必须等到10ms后再写下一个字节

3、AT24C02读时序

        数据内容(DATA):由从机(AT24C02)发出,该数据为写时的写入的地址(WORD         ADDRESS)

        最后主机发出的应答信号

        ack(应答信号),连续读,当一个数据读完之后,继续读下一个地址的数据。

        nack(非应答信号),只读当前写入地址的数据。

三、AT24C02驱动步骤

1、IIC配置步骤

        ①使能SCL和SDA对应时钟,__HAL_RCC_GPIOB_CLK_ENABLE()

        ②设置GPIO工作模式,SDA开漏/SCL推挽输出模式,使用HAL_GPIO_Iint初始化。

        ③编写基本信号,起始信号、停止信号、应答信号

        ④编写读和写函数,iic_read_byte、iic_send_byte

        ⑤注意:发送完成,主机释放SDA,留给从机发送信号。

2、为什么IIC总线,SDA建议用开漏模式?

        IIC的SDA脚既要作为输出,又要作为输入,用开漏输出模式,很好地实现输出输入共用,避免IO模式频繁切换带来的麻烦。

        输出时:主机(MCU)输出0,实现低电平发送。

                      主机,输出1(实际不起作用),由外部上拉电阻上拉,实现高电平发送。

        输入时:主机(MCU)设置输出1状态,此时因为MCU无法输出1,相当于释放了SDA脚,此时外部器件可以主动拉低SDA脚/释放SDA脚(同样上拉电阻提供“输出1的功能”),实现SDA脚的高低电平变化。

        由于开漏输出模式下,MCU还是可以读取IDR状态寄存器,来获取引脚高低电平,因此MCU读取IDR,即可获得SDA脚的高低电平状态,从而实现输入检测。

3、AT24C02驱动配置步骤

        ①初始化IIC接口

        ②编写写入/读取一个字节数据函数,遵循时序流程编写

        ③编写,连续读和连续写函数,在②的基础上进行实现

这篇关于三、IIC总线协议——2、AT24C02的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121333

相关文章

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。