基于STM32和DS1302設(shè)計的時鐘程序
#ifndef __DS1302_H
#define __DS1302_H
#include "stm32f10x.h"
extern u8 d[7]; //依次為年,周,月,日,時,分,秒
extern u8 disp[14];//依次為年[0]【1】;周[2]【3】;月[4]【5】
//***********************日[6]【7】;時[8]【9】;分[10]【11】;秒[12]【13】
void ds1302d_convert(void); //如果用低disp[];必須在read_time();后調(diào)用此函數(shù);
void ds1302set_time(void); //對時函數(shù)
void ds1302read_time(void); //讀取時間
#endif /* __STM32F10x_IT_H */
DS1302——C程序
時 間:11—5-4
標 注:用到了 PA_3—5,PA3_5位控制為依次sclk---GPIOa3,io----GPIOa4,res----GPIOa5
已在函數(shù)中將他們以寄存器形式配置,注再出再次配置PA時
不應(yīng)在配置這些口;
在主函數(shù)中需將PA使能。
頭函數(shù):#include"ds1302.h"
函 數(shù):在ds1302.h中有列舉;
返回值:無;
/*************************
// ds1302,定時,
**************************/
//#include
#include"stm32f10x.h"
#include"ds1302.h"
/***************************/
//sbit sclk=P1^6; GPIOa3
//sbit io=P3^5; GPIOa4
//sbit res=P1^7; GPIOa5
/***************************/
u8 write_add[7]={0x8c,0x8a,0x88,0x86,0x84,0x82,0x80};//讀地址
u8 read_add[7]={0x8d,0x8b,0x89,0x87,0x85,0x83,0x81};//寫地址
/**************************/
u8 settime[7]={11,4,2,23,13,54,11};//年,周,月,日,時,分,秒
u8 d[7];
u8 disp[14];
void delayms(unsigned short time)//nms
{
unsigned short i, j;
for(; time > 0; time--){
for(j = 0; j 10; j++){
for(i = 0; i 1000; i++);
}
}
}
void writeds1302_dat(u8 dat)
{
u8 i;
for(i=0;i8;i++)
{
GPIOA->ODR=0xffef; //GPIOA->ODR=04;
GPIOA->ODR=0xfff7; //GPIOA->ODR=03; //sclk=0;
if(dat0x01)
GPIOA->ODR|=14; //io=dat0x01;
dat=dat>>1;
GPIOA->ODR|=13; //sclk=1;
}
}
/***********************/
void write_ds1302_byte(u8 add,u8 dat)
{
GPIOA->ODR=0xffdf;//GPIOA->ODR=05; //res=0;????????????
delayms(1); //_nop_();
GPIOA->ODR=0xfff7;//GPIOA->ODR=03; //sclk=0;
delayms(1); //_nop_();
GPIOA->ODR|=15; //GPIOA->ODR|=15; //res=1;
delayms(1); //_nop_();
writeds1302_dat(add);
writeds1302_dat(dat);
GPIOA->ODR=0xffdf;//GPIOA->ODR=05; //res=0;
delayms(1); //_nop_();
}
/***************************/
u8 read_ds1302_byte(u8 dat)
{
u8 i,temp;
GPIOA->ODR=0xffdf;//GPIOA->ODR=05; //res=0;
delayms(1); //_nop_();
GPIOA->ODR=0xfff7;//GPIOA->ODR=03;//sclk=0;
delayms(1); //_nop_();
GPIOA->ODR|=15; //res=1;
delayms(1); //_nop_();
for(i=0;i8;i++)
{
GPIOA->ODR=0xffef;//GPIOA->ODR=0;
GPIOA->ODR=0xfff7;//GPIOA->ODR=03; //sclk=0;
if(dat0x01)
GPIOA->ODR|=14; //io=dat0x01;
dat=dat>>1;
GPIOA->ODR|=13; //sclk=1;
}
for(i=0;i8;i++)
{
temp=temp>>1;
GPIOA->ODR=0xfff7;//GPIOA->ODR=03; //sclk=0;
if(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_4))
temp=temp|0x80;
GPIOA->ODR|=13; //sclk=1;
}
GPIOA->ODR=0xffdf;//GPIOA->ODR=05; //res=0;
delayms(1); //_nop_();
return temp;
}
//**************************
void dat_pros()
{
u8 i,temp;
for(i=0;i7;i++)
{
temp=settime[i]/10;
settime[i]=settime[i]%10+temp*16; //*************trans to BCD
}
}
評論