一特点:

-20~70度,SPI/I2C接口,1.2 V to 4.2 V ,可编程看门狗,时钟输出以便校准,闹钟输出,时间戳输出。低功耗高精度,电源切换,中断输出。

SPI接口和I2C接口硬件接法:IFS和BSS连接则是I2C接法。

时间戳输出:/TS低电平输入引脚当信号到来时将时间信息存到时间戳寄存器,此时通过接口可读出的时间即为此事件发生时的时间。

闹钟输出:当前时间不断与设置的闹钟时间比较,匹配时产生标志,使能中断时通过/INT输出。

电源切换:在VDD和Vbat上加系统电压和电池电压,内部可实现自动切换;也可将VCC和电池分别通过二极管连接到VDD上,此时Vbat一定要接地,并且软件电源管理的3位设置为111

电池低电压输出:当低电压检测使能时,当电池电压低到一定值时则事件输出

/*------------------------filename.h------------------------------------*/

#ifndef __PCF2129_I2C_H
#define __PCF2129_I2C_H
/* head include ------------------------------------------------------------*/
# include "stm32f10x.h"
/* Exported types ------------------------------------------------------------*/

typedef struct
{
    unsigned char ucSLA;            //  从机地址(这是7位纯地址,不含读写控制位)
    unsigned char  ulAddr;           //  数据地址
    unsigned char *pcData;                   //  指向收发数据缓冲区的指针
    unsigned char usSize;          //  收发数据长度
} tI2CM_DEVICE;
typedef struct
{
  unsigned char   s;         // 秒
  unsigned char   m;         // 分
  unsigned char   h;         // 小时
  unsigned char   d;         // 日
  unsigned char   wd;        // 星期
  unsigned char   mm;        // 月
  unsigned char   y;        // 年
} dt_dat;

/* Exported constants --------------------------------------------------------*/
/*I2C实时时钟接口
SCL                PD7
SDA                PD6
INT             PD5*/

/* Exported macro ------------------------------------------------------------*/

//  定义pcf2129(NXP RTC,I2C接口)
#define  PCF2129_SLA            0xA2                     //  定义PCF2129的器件地址

//#define  PCF2129_S              (u8)0x02            //  定义PCF2129的秒寄存器地址    
//#define  PCF2129_M              (u8)0x03            //  定义PCF2129的分寄存器地址    
//#define  PCF2129_H              (u8)0x04            //  定义PCF2129的小时寄存器地址  
//#define  PCF2129_D              (u8)0x05            //  定义PCF2129的天寄存器地址    
//#define  PCF2129_W              (u8)0x06            //  定义PCF2129的星期寄存器地址  
//#define  PCF2129_Mo             (u8)0x07            //  定义PCF2129的月寄存器地址    
//#define  PCF2129_Y              (u8)0x08            //  定义PCF2129的年寄存器地址低位
                                      
#define  PCF2129_S              (u8)0x03            //  定义PCF2129的秒寄存器地址     
#define  PCF2129_M              (u8)0x04            //  定义PCF2129的分寄存器地址     
#define  PCF2129_H              (u8)0x05            //  定义PCF2129的小时寄存器地址   
#define  PCF2129_D              (u8)0x06            //  定义PCF2129的天寄存器地址     
#define  PCF2129_W              (u8)0x07            //  定义PCF2129的星期寄存器地址   
#define  PCF2129_Mo             (u8)0x08            //  定义PCF2129的月寄存器地址     
#define  PCF2129_Y              (u8)0x09            //  定义PCF2129的年寄存器地址低位

//#define Second_alarm     0x0a
//#define Minute_alarm     0x0b
//#define Hour_alarm       0x0c
//#define Day_alarm        0x0d
//#define Weekday_alarm    0x0e
//#define CLKOUT_ctl       0x0f
//#define Watchdg_tim_ctl  0x10
//#define Watchdg_tim_val  0x11
//#define Timestp_ctl      0x12
//#define Sec_timestp      0x13
//#define Min_timestp      0x14
//#define Hour_timestp     0x15
//#define Day_timestp      0x16
//#define Mon_timestp      0x17
//#define Year_timestp     0x18
//#define Aging_offset     0x19
//#define Internal_reg     0x1a

/* Exported functions --------------------------------------------------------*/

void PCF2129_Init(void);                                                                                              
void PCF2129_GetTime(void );
void PCF2129_SetTime(dt_dat *date_time);
#endif //__PCF2129_I2C_H

//******************************file.c*************************************************
  * @file         file.c    
  * @author  
  * @version
  * @date    
  * @brief   This file contains the headers of the xx handlers.
  ******************************************************************************
  * @attention
  *
  *
  *******************************************************************************/
  /* Includes ------------------------------------------------------------------*/
#include "PCF2129.h"
#include "myiic.h"
//#include "stm32f10x_pwr.h"
//#include "stm32f10x_bkp.h"

/* extern variables prototypes------------------------------------------------*/
/* extern function prototypes ------------------------------------------------*/
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
#define BCD_TO_HEX(bcd) ((((bcd)>>4)*10)+((bcd)&0x0F))
#define HEX_TO_BCD(hex) ((((hex)/10)<<4)+((hex)%10))
/* Private variables ---------------------------------------------------------*/
u8 databuff[0x1c]={0};
dt_dat dt;
tI2CM_DEVICE PCF2129 = {PCF2129_SLA,      //  从机地址为PCF2129  
                                                0x00,             //  数据地址为0x00
                                                databuff,         //  指向收发数据缓冲区的指针
                                                10};              //  突发发送10个字节数据;

/* Private function prototypes -----------------------------------------------*/

/* Private functions ---------------------------------------------------------*/
/*******************************************************************************
--- @brief  
--- @param  None
--- @retval None
--- @note
*******************************************************************************/

static void IIC_Bus_write(u8 dev_addr, u8 reg_addr, u8 *reg_data, u8 cnt)
{
    u8 stringpos = 0;
    IIC_Start();
    //1表示无应答
    if(IIC_Send_Byte(dev_addr)== 1)
    {
        IIC_Stop();
    return;
    }    
    //发送设备地址+写信号
    if(IIC_Send_Byte(reg_addr)== 1)
    {
        IIC_Stop();
    return;
    }    
    //内部寄存器地址,
    //IIC_Wait_Ack();
    for (stringpos = 0; stringpos < cnt; stringpos++)
    {
        if(IIC_Send_Byte(reg_data[stringpos])== 1)
        {
            IIC_Stop();
            return;
        }
        //内部寄存器数据,
        //IIC_Wait_Ack();
    }
    IIC_Stop();
    //发送停止信号
}
void IIC_Bus_Read(u8 dev_addr, u8 reg_addr, u8 *reg_data, u8 cnt)
{
    u8 stringpos = 0;
    IIC_Start();
    //起始信号
    if(IIC_Send_Byte(dev_addr)== 1)
    {
        IIC_Stop();
    return;
    }    
    //发送设备地址+写信号
    if(IIC_Send_Byte(reg_addr)== 1)
    {
        IIC_Stop();
    return;
    }    
    //发读命令
    IIC_Start();
    if(IIC_Send_Byte(dev_addr+1)== 1)
    {
        IIC_Stop();
    return;
    }        
    //发送设备地址+读信号
    
    for (stringpos = 0; stringpos < cnt; stringpos++)
    {
        if(stringpos != cnt -1)
            reg_data[stringpos]=IIC_Read_Byte(1);
        else            
            reg_data[stringpos]=IIC_Read_Byte(0);        
    }
    //IIC_NAck(); //最后一个字节读完发信号
    //IIC_Send_Ack(1);    
    IIC_Stop();    //停止信号
}

//  对tI2CM_DEVICE结构体变量设置与数据收发相关的成员(数据地址、数据缓冲区、数据大小)
void I2CM_DeviceDataSet(tI2CM_DEVICE *pDevice, unsigned char ulAddr,
                                               unsigned char  *pcData,
                                               unsigned char usSize)
{
    pDevice->ulAddr = ulAddr;
    pDevice->pcData = pcData;
    pDevice->usSize = usSize;
}

/*******************************************************************************
--- @brief  初始化
--- @param  None
--- @retval None
--- @note
*******************************************************************************/
extern void delay_us(u32 nus);
void PCF2129_Init(void)
{
    u8 x = 0;    
    IIC_Init();    
//    if (BKP_ReadBackupRegister(BKP_DR1) != 0xA6A6)
//    {
//        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);
//    //后备域解锁
//    PWR_BackupAccessCmd(ENABLE);
//    //备份寄存器模块复位
//        BKP_DeInit();    
//        
//        dt.s = 0;
//        dt.m = 40;
//        dt.h = 9;//12小时格式,真正的小时是&0X0F,其它2位是AMPM;或者4小时模式
//        dt.d = 7;//
//        dt.wd = 6;
//        dt.mm =1 ;
//        dt.y = 17;/*0~99*/
//        PCF2129_SetTime(&dt);
//            //配置完成后,向后备寄存器中写特殊字符0xA5A5
//        BKP_WriteBackupRegister(BKP_DR1, 0xA6A6);
//    }
//    else
//    {

////若后备寄存器没有掉电,则无需重新配置RTC
//        //这里我们可以利用RCC_GetFlagStatus()函数查看本次复位类型
//        if (RCC_GetFlagStatus(RCC_FLAG_PORRST) != RESET)
//        {
//                //这是上电复位
//        }
//        else if (RCC_GetFlagStatus(RCC_FLAG_PINRST) != RESET)
//        {
//                //这是外部RST管脚复位
//        }
//        //清除RCC中复位标志
//        RCC_ClearFlag();
//    }

PCF2129_GetTime();
    if((dt.y ==0)&&(dt.mm ==0)&&(dt.wd ==0)&&(dt.d ==0)&&(dt.h ==0)&&(dt.m ==0)&&(dt.s ==0))
    {
        delay_us(2000000);/*2017.03.13初始化时如果读时间失败,重复操作2次以判断是否初始化过,中间间隔2S*/
        PCF2129_GetTime();
        if((dt.y ==0)&&(dt.mm ==0)&&(dt.wd ==0)&&(dt.d ==0)&&(dt.h ==0)&&(dt.m ==0)&&(dt.s ==0))
        {
            dt.s = 0;
            dt.m = 0;
            dt.h = 0;//12小时格式,真正的小时是&0X0F,其它2位是AMPM;或者4小时模式
            dt.d = 1;//
            dt.wd = 1;
            dt.mm =1 ;
            dt.y = 17;/*0~99*/
            PCF2129_SetTime(&dt);
        }
    }
    for (x=0; x < 7; x++)  //  清空数据缓冲区
        databuff[x+2] = 0;                                                
}
/*******************************************************************************
--- @brief  读取时间
--- @param  None
--- @retval None
--- @note
*******************************************************************************/
void PCF2129_GetTime(void )
{    
    u8 x = 0;
    for (x=0; x < 7; x++)  //  清空数据缓冲区
        databuff[x+2] = 0;
    I2CM_DeviceDataSet(&PCF2129,  
                       0x02,
                       &databuff[2],
                       7);     
    IIC_Bus_Read(PCF2129.ucSLA, PCF2129.ulAddr, PCF2129.pcData, PCF2129.usSize);    
    dt.s = BCD_TO_HEX(databuff[PCF2129_S -1] & 0x7f);
    dt.m = BCD_TO_HEX(databuff[PCF2129_M -1] & 0x7f);
    dt.h = BCD_TO_HEX(databuff[PCF2129_H -1] & 0x1f);//12小时格式,真正的小时是&0X0F,其它2位是AMPM;或者4小时模式
    dt.d = BCD_TO_HEX(databuff[PCF2129_D -1] & 0x3f);//
    dt.wd = BCD_TO_HEX(databuff[PCF2129_W -1] & 0x07);
    dt.mm = BCD_TO_HEX(databuff[PCF2129_Mo -1] & 0x1f);
    dt.y = BCD_TO_HEX(databuff[PCF2129_Y -1] & 0x7f);/*0~99*/

}
/*******************************************************************************
--- @brief  设置时间
--- @param  None
--- @retval None
--- @note
*******************************************************************************/
void PCF2129_SetTime(dt_dat *date_time)
{

databuff[0] = 0;    
  databuff[1] = 0;    
  databuff[2] |= (7<<5);/*2017.03.13 14:57功耗管理 单独VDD供电。*/
    databuff[PCF2129_S]     = HEX_TO_BCD(date_time->s);  
    databuff[PCF2129_M]     = HEX_TO_BCD(date_time->m);  
    databuff[PCF2129_H]     = HEX_TO_BCD(date_time->h);  
    databuff[PCF2129_D]     = HEX_TO_BCD(date_time->d);  
    databuff[PCF2129_W]     = HEX_TO_BCD(date_time->wd); /*PAD没有传相关参数,如果需要该参数,需要增加函数实现。*/
    databuff[PCF2129_Mo] = HEX_TO_BCD(date_time->mm);
    databuff[PCF2129_Y]  = HEX_TO_BCD(date_time->y);  
//    databuff[10] = 0x80;             //秒报警控制及报警值设置。
//  databuff[15] = 0x06;       //  设置CLKOUT为1Hz
//  databuff[19] = 0x0C;       //  晶振老化补偿设为-4ppm    
    I2CM_DeviceDataSet(&PCF2129,  
                       0x0,
                       &databuff[0],
                       10);
    IIC_Bus_write(PCF2129.ucSLA, PCF2129.ulAddr, PCF2129.pcData, PCF2129.usSize);    
    //  定义I2C主机结构体:设置CLKOUT为1Hz    
//  I2CM_DeviceDataSet(&PCF2129,
//                     0x0F,
//                     &databuff[15],
//                     1);
//  
//  IIC_Bus_write(PCF2129.ucSLA, PCF2129.ulAddr, PCF2129.pcData, PCF2129.usSize);
//    //  定义I2C主机结构体:设置晶振老化补偿设为-4ppm
//  I2CM_DeviceDataSet(&PCF2129,  
//                       0x19,
//                       &databuff[19],
//                       1);
//  IIC_Bus_write(PCF2129.ucSLA, PCF2129.ulAddr, PCF2129.pcData, PCF2129.usSize);     
}

RTC-IC-PCF2129的更多相关文章

  1. 转(Delphi 新窑洞):使用delphi 开发多层应用(十七)使用RTC web 服务器返回JSON

    RTC作为delphi 的最专业的web 应用服务器,如果客户端要使用JSON 的话,那么使用RTC 应该也是一种 非常好的选择.下面我们做一个使用RTC web 服务器返回数据库JSON 的例子. ...

  2. RTC实时时间系统学习笔记(一)---------------UART串口

    临近研三了,自己倾向于要找数字IC方面的工作,苦于教研室的项目一直都是调板子调板子调板子,真正用到FPGA的很少,,本着"工欲善其事必先利其器"的原则,在网上搜寻如何自学FPGA, ...

  3. 使用delphi 开发多层应用(十六)使用XMLRPC 实现basic4android 远程调用RTC服务(讲述了RTC的特点,其底层通讯协议是自己封装SOCK 库,与kbmmw 的适合场合不完全一样)

        RealThinClient (以下简称RTC) 也是一款delphi 多层开发的框架,由于其底层通讯协议是自己封装SOCK 库,抛弃了 大家诟病的indy,因此表现的非常稳定,效率也非常高, ...

  4. [Linux] RTC 读写指令及测试程序

    CPU:RK3288 系统:Linux IC:hym8563 在 Linux 系统中,指令 date 和 hwclock 都可以读写时间 date:读写系统时间,写时间需要管理员权限 hwclock: ...

  5. STM32F746的RTC使用

    1.RTC模块采用低速晶振外接始终:32.768KHz,如下图所示 2.配置RTC模块: 其中,Fck_apre.Fck_spre始终上配置不容易理解, 如果想得到1Hz的始终频率,则需要将PERDI ...

  6. 同步降压DC-DC转换IC——XC9264

    设计一个12V转3.3V,输出电流30mA的电源电路,由于项目对转化效率要求较高,所以不能采用低压差线性稳压LDO的方案.经过对比,TOREX的XC9264效率在此转化条件下效率可做到85%以上,比M ...

  7. [nRF51822] 10、基础实验代码解析大全 · 实验15 - RTC

    一.实验内容: 配置NRF51822 的RTC0 的TICK 频率为8Hz,COMPARE0 匹配事件触发周期为3 秒,并使能了TICK 和COMPARE0 中断. TICK 中断中驱动指示灯D1 翻 ...

  8. RTC时钟

    1.设置时间之前取消备份区域(BKP)写保护 主要有两部分组成 1.用来和APB1总线对接,对其进行读写操作 2. 预分频模块:在RTC_CR设置相应的允许,位每个TR_CLK周期中RTC产生一个中断 ...

  9. IC解密DS2431芯片解密DS2432、DS2433解密多少钱?

    IC解密DS2431芯片解密DS2432.DS2433解密多少钱? DS24系列可成功芯片解密的型号: DS2430A | DS2431 | DS2432 | DS2433 | DS2434 | DS ...

  10. S3C2440上RTC时钟驱动开发实例讲解(转载)

    嵌入式Linux之我行,主要讲述和总结了本人在学习嵌入式linux中的每个步骤.一为总结经验,二希望能给想入门嵌入式Linux的朋友提供方便.如有错误之处,谢请指正. 共享资源,欢迎转载:http:/ ...

随机推荐

  1. centos7搭建mysql-5.7.22主从复制

    mysql7.7.22主从复制 本项目是根据真实环境搭建编写出文档,文档中的目录也是根据自己公司环境所创建.公司原来是一台服务器搭建的数据库(5.7.22),由于业务的扩展需要搭建一台从服务器,减轻主 ...

  2. intent实现Activity之间跳转的各种传值

    一.在Activity之间传递String类型的数据 传递 @Override public void onClick(View v) { String num1 = firstNum.getText ...

  3. asterisk ss7 ${CALLERID(rdnis)}变量为空问题

    asterisk 1.8.16+chan_ss7 version 2.1.1b ${CALLERID(rdnis)}变量取不到信息问题,解决 编辑 funcs/func_callerid.c chan ...

  4. POJ2657Comfort(扩展欧几里得基础)

    A game-board consists of N fields placed around a circle. Fields are successively numbered from1 to ...

  5. Python 实现「食行生鲜」签到领积分

    用过食行生鲜的同学应该知道,每天可以在食行生鲜签到,签到可以领到 20 积分,在购物时可以抵 2 毛钱.钱虽少,但是积少成多,买菜时可以抵扣一两块钱还是不错的. 今天我们就用 Python 来实现自动 ...

  6. MySQL学习_计算用户支付方式占比_20161104

    计算用户支付方式占比 SELECT b.*#根据城市ID 年月排序 FROM ( SELECT a.* FROM ( #纵向合并 SELECT b1.ID,a1.城市,a1.收款方式,DATE_FOR ...

  7. CentOS 6.6 搭建Zabbix 3.0.3 过程

    分享CentOS 6.6下搭建Zabbix 3.0.3 的过程,希望都大家有所帮助. 环境安装 系统环境: # cat /etc/RedHat-release CentOS release 6.6 ( ...

  8. 水题 等差数列HDU 5400 Arithmetic Sequence

    主要是要知道它对于等差数列的定义,单个数也可以作为等差数列且一定满足题意,另外就是要算清楚区间与区间的关系,考虑两大类情况,一种是d1区间和d2区间连在一起,另外一种情况就是其余情况. #includ ...

  9. Django admin有用的自定义功能

    引用园友 无名小妖 的博客 https://www.cnblogs.com/wumingxiaoyao/p/6928297.html 写的很好,但是博客园不能转载,不过我已经点赞了~

  10. Eclipse+Maven

    http://www.cnblogs.com/alunchen/p/5632497.html