一起来搞定 ds1302
2016-05-16 15:18
316 查看
原文: http://bbs.elecfans.com/jishu_295866_1_1.html
最近在论坛看到很多同仁在研究ds1302这款时钟芯片,正巧公司项目上也用到这个,因为学习过程中遇到些问题,略有所悟。突然萌生一个想法,召集老鸟们过来一起吃透这款芯片,然后记录下来,留给后来的同学,希望他们能够获益,避免走一些弯路...以后也不会有那么多帖子来问ds1302问题。。。。
也希望高手们过来一起补充,一起讨论遇到的问题...更希望曾经研究过这款芯片的同学来分享学习ds1302遇到的 问题以及解决方法....总之,谨以绵薄之力为 后来要用的这款芯片的同学,提供参考。。。不胜感激!!
DS1302编程注意事项:
通信:
1、单片机通过三线与ds1302芯片进行数据通信:reset,
data, sclk,但并非I2C通信方式。
2、reset其实质相当于片选CE,两个作用:
a、选中芯片,开启ds1302移位寄存器,以进行数据传输,且整个数据传输过程中,需要保持为 高电平;
b、突发访问(多字节传输)模式下,通过拉低reset来结束本次突发访问模式。
需要注意必须保证在sclk拉低的前提前才能拉高reset(换言之,每次开始数据通信之前,必须sclk必须为低电平,那么sclk第一个边缘则一定为上升沿)。
3、data引脚应配置成可以双向通信的模式(例如:开漏输出,外接上拉电阻),在程序中应注意在单片机从接收ds1302数据之前,应拉高data,避免影响ds1302输出数据;
4、sclk 与 reset引脚,配置为普通输出模式即可。
5、ds1302时序:ds1302在sclk上升沿读取data数据,下降沿发布数据到data上。应注意在ds1302有数据输出时,输出数据开始位是紧接着命令发送字节的末尾的下降沿输出的。
操作:
1、任何写操作之前应先清除写保护bit(特别重要)。
2、ds1302应外接32768Hz晶振,但并非直接就能起振的 ,需要软件清除 秒寄存器的bit7 即CH Bit,晶振才能正常工作,从而驱动ds1302内部计数器,达到准确计时 的目的,若正常起振,则此时可以用示波器在晶振引脚处测出波形。
3、对于突发访问模式:即是在sclk的驱动下,可以一次对多个寄存器进行读写,但是均是从(ram或者时间/日历寄存器)地址0开始访问的。应注意若是突发模式下写 时钟/日历寄存器 ,则必须要求传输8字节数据,若是突发访问ram数据,则不需要限定字节数,可以通过拉低reset来结束本次突发访问。
4、ds1302的ram区域,掉电丢失,可以利用这种特性来检测ds1302是否为第一次上电,从而确定是否需要配置ds1302。
最近在论坛看到很多同仁在研究ds1302这款时钟芯片,正巧公司项目上也用到这个,因为学习过程中遇到些问题,略有所悟。突然萌生一个想法,召集老鸟们过来一起吃透这款芯片,然后记录下来,留给后来的同学,希望他们能够获益,避免走一些弯路...以后也不会有那么多帖子来问ds1302问题。。。。
也希望高手们过来一起补充,一起讨论遇到的问题...更希望曾经研究过这款芯片的同学来分享学习ds1302遇到的 问题以及解决方法....总之,谨以绵薄之力为 后来要用的这款芯片的同学,提供参考。。。不胜感激!!
DS1302编程注意事项:
通信:
1、单片机通过三线与ds1302芯片进行数据通信:reset,
data, sclk,但并非I2C通信方式。
2、reset其实质相当于片选CE,两个作用:
a、选中芯片,开启ds1302移位寄存器,以进行数据传输,且整个数据传输过程中,需要保持为 高电平;
b、突发访问(多字节传输)模式下,通过拉低reset来结束本次突发访问模式。
需要注意必须保证在sclk拉低的前提前才能拉高reset(换言之,每次开始数据通信之前,必须sclk必须为低电平,那么sclk第一个边缘则一定为上升沿)。
3、data引脚应配置成可以双向通信的模式(例如:开漏输出,外接上拉电阻),在程序中应注意在单片机从接收ds1302数据之前,应拉高data,避免影响ds1302输出数据;
4、sclk 与 reset引脚,配置为普通输出模式即可。
5、ds1302时序:ds1302在sclk上升沿读取data数据,下降沿发布数据到data上。应注意在ds1302有数据输出时,输出数据开始位是紧接着命令发送字节的末尾的下降沿输出的。
操作:
1、任何写操作之前应先清除写保护bit(特别重要)。
2、ds1302应外接32768Hz晶振,但并非直接就能起振的 ,需要软件清除 秒寄存器的bit7 即CH Bit,晶振才能正常工作,从而驱动ds1302内部计数器,达到准确计时 的目的,若正常起振,则此时可以用示波器在晶振引脚处测出波形。
3、对于突发访问模式:即是在sclk的驱动下,可以一次对多个寄存器进行读写,但是均是从(ram或者时间/日历寄存器)地址0开始访问的。应注意若是突发模式下写 时钟/日历寄存器 ,则必须要求传输8字节数据,若是突发访问ram数据,则不需要限定字节数,可以通过拉低reset来结束本次突发访问。
4、ds1302的ram区域,掉电丢失,可以利用这种特性来检测ds1302是否为第一次上电,从而确定是否需要配置ds1302。
相关文章推荐
- CentOS用户及用户组管理
- mysql数据库应用管理+乱码+字符集
- Eclipse 默认设置的换行长度
- 自定义圆形ImageView
- 各类BUG - 3 - iOS8UIWebView无法调起相册
- 正则表达式(一):php常用的正则匹配
- ACE框架整合记录2Tab插件-【完结】
- C#生成World文档
- ios5中UIViewController addChildViewController等新方法
- part1:7-Linux网络配置
- centos下redis的安装
- CentOS7实现RabbitMQ高可用集群
- RSA算法原理
- bat批处理访问n个网站
- 史上最强验证
- 如何让网页上的失效图片,显示默认缺省图片
- SpriteKit游戏Delve随机生成地牢地图一个Bug的修复
- SpriteKit游戏Delve随机生成地牢地图一个Bug的修复
- 自己动手实现SpringIoC
- 单例模式分析