电工技术基础_电工基础知识_电工之家-电工学习网

欢迎来到电工学习网!

ds1302时钟芯片万年历电路图

2017-07-03 17:02分类:电子技术 阅读:

 

DS1302 是美国DALLAS公司推出的一种高功用、低功耗、带RAM的实不时钟电路,它能够对年、月、日、周日、时、分、秒进行计时,具有闰年抵偿功用,作业电压为2.5V~5.5V。选用三线接口与CPU进行同步通讯,并可选用突发办法一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个31×8的用于暂时性寄存数据的RAM寄存器。DS1302是DS1202的晋级商品,与DS1202兼容,但添加了主电源/后备电源双电源引脚,一起供给了对后备电源进行涓细电流充电的才调。
DS1302的引脚摆放,其间Vcc1为后备电源,VCC2为主电源。在主电源封闭的状况下,也能坚持时钟的接连作业。DS1302由Vcc1或Vcc2两者中的较大者供电。当Vcc2大于Vcc1+0.2V时,Vcc2给DS1302供电。当Vcc2小于Vcc1时,DS1302由Vcc1供电。X1和X2是振动源,外接32.768kHz晶振。RST是复位/片选线,经过把RST输入驱动置高电平来主张悉数的数据传送。RST输入有两种功用:首要,RST接通操控逻辑,容许地址/指令序列送入移位寄存器;其次,RST供给接连单字节或多字节数据传送的办法。当RST为高电往常,悉数的数据传送被初始化,容许对DS1302进行操作。假定在传送进程中RST置为低电平,则会接连这次数据传送,I/O引脚变为高阻态。上电作业时,在Vcc>2.0V之前,RST有必要坚持低电平。只需在SCLK为低电往常,才调将RST置为高电平。I/O为串行数据输入输出端(双向),后边有具体阐明。SCLK为时钟输入端。 下图为DS1302的引脚功用图


花了几块钱买了个山寨的1302模块,姑息着能够用,
可是模块上的sclk,io,RST这3个脚没有上拉电阻,自个加上去了,汗!
不加上拉电阻,闪现的时钟很简略发作过失
好了不多说,贴代码
本程序只闪现时刻,没有年份和月份...
#include "my51.h"
#include "smg.h"
#include "ds1302.h"
void main() //ds1302闪现时钟
{
ds1302_initSet();//初始化
//ds1302_stop(); 停掉1302,进入省电办法
while(1)
{
ds1302_readRTC();_nop_(); //读取时钟数据
displaySMG(ds1302_processTimeData());//处理数据并送数码管闪现
}
}
#ifndef _DS1302_H
#define _DS1302_H
#include "my51.h"
sbit rst=P3^4; //片选总线
sbit sda=P3^5; //数据总线
sbit scl=P3^6; //时钟线
extern u8 data smgWela[7]; //数码管闪现参数
extern u8 data timeData[7]; //年,周,月,日,时,分,秒的初值
//void ds1302_setUnCharger() //充电操控,阻遏充电
//void ds1302_stop() ; //暂停ds1302,进入超低功耗办法
u8* ds1302_processTimeData(); //处理时钟数据,送给数码管闪现
void ds1302_readRTC(); //读取悉数时钟数据的BCD码
void ds1302_initSet() ; //设置初始化数据
u8 ds1302_readData(u8 addr); //从ds1302读一个字节,读的时分会先写地址
void ds1302_writeByte(u8 dat); //写一个字节
void ds1302_writeData(u8 addr,u8 dat); //向指定地址寄存器写数据
#endif
#include "ds1302.h"
data u8 timeData[7]={10,6,4,17,11,20,55};
code u8 writeAddr[7]={0x8c,0x8a,0x88,0x86,0x84,0x82,0x80};//写年周月日时分秒寄存器地址指令
code u8 readAddr[7]={0x8d,0x8b,0x89,0x87,0x85,0x83,0x81};//读的指令地址
void ds1302_writeData(u8 addr,u8 dat) //向指定地址寄存器写数据
{
rst=0; _nop_();
scl=0; _nop_();
rst=1; _nop_();
ds1302_writeByte(addr); //先写入地址
ds1302_writeByte(dat);
rst=0;_nop_(); //封闭
sda=1; //开释
scl=1;
}
void ds1302_writeByte(u8 dat) //写一个字节
{
u8 i=0;
for(i=0;i>=1;
scl=1;_nop_(); //上升沿写入一位
}
}
u8 ds1302_readData(u8 addr) //从ds1302读一个字节,读的时分会先写地址
{
u8 i,value=0;
rst=0;_nop_();
scl=0;_nop_();
sda=1;_nop_();
rst=1;_nop_();
ds1302_writeByte(addr); //先写入要读的地址
_nop_();
sda=1;_nop_();
for(i=0;i>=1;
scl=0;_nop_(); //下降沿开端后获取有用数据
if(sda) //读数据
{
value|=0x80;//高电平手动置位保存数据,
} //低电平数据value最高位默许现已是0
scl=1; //为下一次读取数据做预备
}
rst=0;
return value;
}
void ds1302_initSet() //设置初始化数据
{
u8 i,j;
for(i=0;i> 4;//获取高4位
smgWela[3]=timeData[5]& 0x0f;
smgWela[2]=timeData[5]>> 4;
smgWela[1]=timeData[4]& 0x0f;
smgWela[0]=timeData[4]>> 4;
smgWela[6]=0xf5; //0xf5是小数点的方位
return smgWela;
}
/*
void ds1302_stop() //暂停ds1302
{
ds1302_writeData(0x8e,0x00); //铲除写维护
ds1302_writeData(writeAddr[6],0x80); //暂停ds1302,进入超低功耗办法
ds1302_writeData(0x8e,0x80); //使能写维护
} */
/*
void ds1302_setUnCharger() //充电操控,阻遏充电
{
ds1302_writeData(0x8e,0x00); //铲除写维护
ds1302_writeData(0x90,0x5c); //阻遏充电,下降功耗
ds1302_writeData(0x8e,0x80); //使能写维护
}*/
#ifndef _51SMG_H_
#define _51SMG_H_
#include "my51.h"
sbit dula =P2^6; //段选锁存器操控 操控笔段
sbit wela =P2^7; //位选锁存器操控 操控方位
extern u8 data smgWela[7]; //榜首位到第六位,终究一个是小数点方位操控
#define dark 0x11//在段中,0x11是第17号元素,0x00是低电平,数码管不亮,即table[17]
#define dotDark 0xff//小数点全暗
void displaySMG(u8* pWela); //数码管闪现函数,参数是数组指针
#endif
#include "smg.h"
#include "my51.h"
static u8 code table[]= { //0~F外加小数点和空输出的数码管编码
0x3f , 0x06 , 0x5b , 0x4f , // 0 1 2 3
0x66 , 0x6d , 0x7d , 0x07 , // 4 5 6 7
0x7f , 0x6f , 0x77 , 0x7c , // 8 9 A B
0x39 , 0x5e , 0x79 , 0x71 , // C D E F
0x80 , 0x00 ,0x40 // . 空 负号 空为第17号元素
};
/* 由于此表只能一次闪现一个小数点,故已注释掉,仅供查询
例如想要榜首个和第六个数码管小数点一起点亮,
则施行 pWela->dot = 0xfe & 0xdf 即可
u8 code dotTable[]={ //小数点方位,某一方位0时,小数点亮
0xff , //全暗
0xfe , 0xfd , 0xfb , //1 2 3
0xf7 , 0xef , 0xdf //4 5 6
};*/
u8 data smgWela[7]={0,0,0,0,0,0,0}; //榜首位到第六位,终究一个是小数点方位操控
//P0口的数码管位选操控锁存器只用了低6位,咱们保存高2位的数据,留作它用
void displaySMG(u8* pWela)
{
u8 i=0;
//操控6位数码管闪现函数,不闪现的位用参数dark
u8 preState=P0|0x3f; //保存高2位状况,其间最高位是ADC0804的片选信号
wela=0;dula=0;_nop_();//先断定数据,避免吴亮及位选锁存器高2位数据被改动
P0=0; //由于数码管是共阴极的,阳极送低电平,灯不亮
dula=1;_nop_();
dula=0; //段选数据清空并断定
P0=preState; //共阴极数码管是阴极置高不亮,低6方位1,高2位保存
wela=1;_nop_(); //注:wela和dula上电默许为1
wela=0; //位选断定,初始保存高2位的数据,低6方位高不亮
for(i=0;i<6;i++) //闪现6位数码管
{
P0=table[pWela]|(((1<<i) & pWela[6])?0x00:0x80);
dula=1;_nop_(); //送段数据,叠加小数点的闪现,0x00点亮小数点
dula=0;
P0=preState&~(1<<i); //不影响高2位数据,低6位是数码管位选,低电平有用
wela=1; _nop_(); //送位选号
wela=0;
delayms(1); //稍作延时,让灯管亮起来
{ //消除叠影及误亮,阴极置1不亮,低6方位1,高2位保存并断定
P0=preState;
wela=1; _nop_();
wela=0;
}
}
}

上一篇:空心变压器是啥?空心变压器原边等效电路

下一篇:51单片机开发心得

相关推荐

电工推荐

    电工技术基础_电工基础知识_电工之家-电工学习网
返回顶部