0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

采用LPC1752读取AT24C08C的原理与实现方案

454398 ? 来源:一板网 ? 作者:admin ? 2020-10-24 11:18 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

1 简介

1.1 LPC1752及AT24C08C简介

LPC1752是NXP推出的一款Cortex M3的芯片,最高运行频率可达80M

AT24C08C是Atmel的一款I2C串行EEPROM,代替原来的型号AT24C08B及AT24C08A。共有8K(1024*8 bit)、1024字节的存储单元。可进行1百万次的写操作,数据可保存100年。

1.2 连接方式

AT24C08C是通过LPC1752的I2C2连接的,连接图如下:

图1 LPC1752连接图

1.3 AT24C08C设备地址

The 8K EEPROM only uses the A2 device address bit with the next twobits (P1, P0) being for memory page addressing. The A2 bit must compare to itscorresponding hardwired input pin. The A1 and A0 pins are not connected.

根据连接图可得知AT24C08的地址为0xA0。

图2 AT24C08CDevice Address

1.4 I2C运行时钟频率

主机模式下必须通过对I2SCLH和I2SCLL寄存器进行设置来选择合适的总线速率和占空比。I2SCLH定义SCL高电平所保持的PCLK_I2C周期数,I2SCLL定义SCL低电平的PCLK_I2C周期数。位频率由下面的公式得出(PCLK_I2C是外围总线APB的频率):

选用的I2SCLL和I2SCLH值必须确保得出的总线速率在I2C总线速率的范围之内。I2SCLL和I2SLH的值都必须大于或等于4。表1给出了根据PCLK_I2C频率和I2SCLL和I2SCLH值计算出来的I2C总线速率的示例。

表1 I2C时钟速率的实例

2 函数介绍

2.1 初始化函数i2c2_init

按照LPC1752用户手册(UM10360)中第三章的介绍进行初始化,步骤如下:

a)。 电源:在寄存器PCONP中置位PCI2C2。

b)。 时钟:在寄存器PCLK_SEL1中选择PCLK_I2C2。

c)。 引脚: 通过寄存器PINSEL0使能I2C2引脚。通过寄存器PINMODE来配置I2C2引脚模式。

d)。 时钟频率:向I2SCLH和I2SCLH寄存器加载频率值来定义串行时钟频率(主机模式)。

e)。 中断:在NVIC中置位I2C2_IRQn寄存器使能I2C2中断。

f)。 向寄存器I2CONSET写入0x40来置位I2EN位。

2.2 中断函数I2C2_IRQHandler

通过读取I2STAT寄存器的值判断I2C总线上的状态,并进行下一步操作。

中断函数只处理了主机接收模式与主机发送模式。

1)I2C进入主机进入发送起始条件时,串行中断标志(SI)置位,状态寄存器(I2STAT)中的状态代码为0x08。此时将从机地址和数据方向位(SLA+W)装入I2DAT,同时复位I2CON的STA,STO和SI。

2.3 I2C总线进入开始状态i2c2_start

可通过置位STA位进入主机发送模式。一旦总线空闲,I2C逻辑会马上测试I2C总线并产生一个起始条件。

2.4 I2C停止函数i2c2_stop:

I2C结束时发送停止条件并释放总线。

a)向I2CONSET写入0x14来置位STO和AA位;

b)向I2CONCLR写入0x08来清除SI标志;

2.5主机发送函数i2c2_write

启动主机发送功能,向从机发送数据,通过建立缓冲区、指针和数据计数然后发启起始条件便可执行主发送操作。

a)初始化主机数据计数器;

b)建立数据将被发送到的从机地址,并且添加写位;

c)向I2CONSET写入0x20来置位STA位;

d)在主发送缓冲区内建立要发送的数据;

e)初始化主机数据计数器来匹配正在发送的信息长度;

f)退出。

2.6主机接收函数 i2c2_read

启动主机接收功能,接收从机发出的数据。

通过建立缓冲区、指针和数据计数然后发启起始条件便可执行主接收操作。

a)初始化主机数据计数器;

b)建立数据将被发送到的从机地址,并且添加读位;

c)向I2CONSET写入0x20来置位STA位;

d)在主接收缓冲区内建立要发送的数据;

e)初始化主机数据计数器来匹配正在发送的信息长度;

f)退出。

3 测试

通过向0x00地址写入并回读固定数据验证有效性。

测试结果比较

第一次读取

第二次读取

经验证可以正常使用。
编辑:hfy

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5447

    浏览量

    125436
  • 存储单元
    +关注

    关注

    1

    文章

    66

    浏览量

    16493
  • EEPROM
    +关注

    关注

    9

    文章

    1094

    浏览量

    84106
  • Cortex M3
    +关注

    关注

    0

    文章

    7

    浏览量

    8710
  • LPC1752
    +关注

    关注

    0

    文章

    4

    浏览量

    3649
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    国产8通道24位ADC软硬件兼容ADS131E08电能计量方案

    国产8通道24位ADC软硬件兼容ADS131E08电能计量方案
    的头像 发表于 04-29 10:09 ?440次阅读
    国产8通道<b class='flag-5'>24</b>位ADC软硬件兼容ADS131E<b class='flag-5'>08</b>电能计量<b class='flag-5'>方案</b>

    PFD12-36S24B2(C)5 PFD12-36S24B2(C)5

    电子发烧友网为你提供AIPULNION(AIPULNION)PFD12-36S24B2(C)5相关产品参数、数据手册,更有PFD12-36S24B2(C)5的引脚图、接线图、封装手册、
    发表于 03-20 18:53
    PFD12-36S<b class='flag-5'>24</b>B2(<b class='flag-5'>C</b>)5 PFD12-36S<b class='flag-5'>24</b>B2(<b class='flag-5'>C</b>)5

    FD12-36S24A3(C)4 FD12-36S24A3(C)4

    电子发烧友网为你提供AIPULNION(AIPULNION)FD12-36S24A3(C)4相关产品参数、数据手册,更有FD12-36S24A3(C)4的引脚图、接线图、封装手册、中文
    发表于 03-20 18:50
    FD12-36S<b class='flag-5'>24</b>A3(<b class='flag-5'>C</b>)4 FD12-36S<b class='flag-5'>24</b>A3(<b class='flag-5'>C</b>)4

    FD6-36S24A3C3 FD6-36S24A3C3

    电子发烧友网为你提供AIPULNION(AIPULNION)FD6-36S24A3C3相关产品参数、数据手册,更有FD6-36S24A3C3的引脚图、接线图、封装手册、中文资料、英文资料,FD6-36S24A3C3真值表,FD6
    发表于 03-20 18:45
    FD6-36S<b class='flag-5'>24A3C</b>3 FD6-36S<b class='flag-5'>24A3C</b>3

    FD6-36D24A3(C) FD6-36D24A3(C)

    电子发烧友网为你提供AIPULNION(AIPULNION)FD6-36D24A3(C)相关产品参数、数据手册,更有FD6-36D24A3(C)的引脚图、接线图、封装手册、中文资料、英
    发表于 03-20 18:36
    FD6-36D<b class='flag-5'>24</b>A3(<b class='flag-5'>C</b>) FD6-36D<b class='flag-5'>24</b>A3(<b class='flag-5'>C</b>)

    FW2-24S15C3 FW2-24S15C3

    电子发烧友网为你提供AIPULNION(AIPULNION)FW2-24S15C3相关产品参数、数据手册,更有FW2-24S15C3的引脚图、接线图、封装手册、中文资料、英文资料,FW2-24S15C3真值表,FW2-
    发表于 03-20 18:30
    FW2-<b class='flag-5'>24S15C</b>3 FW2-<b class='flag-5'>24S15C</b>3

    FW2-24S15C FW2-24S15C

    电子发烧友网为你提供AIPULNION(AIPULNION)FW2-24S15C相关产品参数、数据手册,更有FW2-24S15C的引脚图、接线图、封装手册、中文资料、英文资料,FW2-24S15C真值表,FW2-
    发表于 03-19 18:58
    FW2-<b class='flag-5'>24S15C</b> FW2-<b class='flag-5'>24S15C</b>

    NN3-24S24C4N NN3-24S24C4N

    电子发烧友网为你提供AIPULNION(AIPULNION)NN3-24S24C4N相关产品参数、数据手册,更有NN3-24S24C4N的引脚图、接线图、封装手册、中文资料、英文资料,NN3-24S24C4N真值表,NN3-
    发表于 03-19 18:50
    NN3-<b class='flag-5'>24S24C</b>4N NN3-<b class='flag-5'>24S24C</b>4N

    NN3-12S24C3N NN3-12S24C3N

    电子发烧友网为你提供AIPULNION(AIPULNION)NN3-12S24C3N相关产品参数、数据手册,更有NN3-12S24C3N的引脚图、接线图、封装手册、中文资料、英文资料,NN3-12S24C3N真值表,NN3-12
    发表于 03-19 18:49
    NN3-12S<b class='flag-5'>24C</b>3N NN3-12S<b class='flag-5'>24C</b>3N

    FN2-24D24C3N FN2-24D24C3N

    电子发烧友网为你提供AIPULNION(AIPULNION)FN2-24D24C3N相关产品参数、数据手册,更有FN2-24D24C3N的引脚图、接线图、封装手册、中文资料、英文资料,FN2-24D24C3N真值表,FN2-
    发表于 03-19 18:49
    FN2-<b class='flag-5'>24D24C</b>3N FN2-<b class='flag-5'>24D24C</b>3N

    FN2-24D15C FN2-24D15C

    电子发烧友网为你提供AIPULNION(AIPULNION)FN2-24D15C相关产品参数、数据手册,更有FN2-24D15C的引脚图、接线图、封装手册、中文资料、英文资料,FN2-24D15C真值表,FN2-
    发表于 03-19 18:46
    FN2-<b class='flag-5'>24D15C</b> FN2-<b class='flag-5'>24D15C</b>

    FN2-24D15C3 FN2-24D15C3

    电子发烧友网为你提供AIPULNION(AIPULNION)FN2-24D15C3相关产品参数、数据手册,更有FN2-24D15C3的引脚图、接线图、封装手册、中文资料、英文资料,FN2-24D15C3真值表,FN2-
    发表于 03-19 18:46
    FN2-<b class='flag-5'>24D15C</b>3 FN2-<b class='flag-5'>24D15C</b>3

    FA10-220S24C2N3 FA10-220S24C2N3

    电子发烧友网为你提供AIPULNION(AIPULNION)FA10-220S24C2N3相关产品参数、数据手册,更有FA10-220S24C2N3的引脚图、接线图、封装手册、中文资料、英文资料,FA10-220S24C2N3真
    发表于 03-18 18:47
    FA10-220S<b class='flag-5'>24C</b>2N3 FA10-220S<b class='flag-5'>24C</b>2N3

    FA5-220D24C2N4 FA5-220D24C2N4

    电子发烧友网为你提供AIPULNION(AIPULNION)FA5-220D24C2N4相关产品参数、数据手册,更有FA5-220D24C2N4的引脚图、接线图、封装手册、中文资料、英文资料,FA5-220D24C2N4真值表,
    发表于 03-18 18:39
    FA5-220D<b class='flag-5'>24C</b>2N4 FA5-220D<b class='flag-5'>24C</b>2N4

    铁电存储器SF24C64对标FM24C64性能、应用和成本分析

    铁电存储器SF24C64对标FM24C64性能、应用和成本分析
    的头像 发表于 03-03 10:25 ?853次阅读
    铁电存储器SF<b class='flag-5'>24C</b>64对标FM<b class='flag-5'>24C</b>64性能、应用和成本分析