一特点:

-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. Linux下查找进程,kill进程

    1. ps命令用来查找linux运行的进程,常用命令: ps aux | grep 进程名:  eg:ps aux | grep admin 查找admin的进程 或者 ps -ef | grep j ...

  2. BaseServlet优化Servlet,实现类似struts2的一些简单效果

    package cn.itcast.web.servlet; import java.io.IOException; import javax.servlet.ServletException; im ...

  3. fscanf和fgets用法

    首先要对fscanf和fgets这两个文件函数的概念有深入的了解,对于字符串输入而言这两个函数有一个典型的区别是: fscanf读到空格或者回车时会把空格或回车转化为/(字符串结束符)而fgets函数 ...

  4. 基于OpenCV的面部交换

    需要装python库 OpenCV dlib docopt(根据打开方式选择是否装) # -*- coding: UTF-8 #本电脑试运行 命令 python F:\python_project\s ...

  5. ACM学习历程—HDU 5317 RGCDQ (数论)

    Problem Description Mr. Hdu is interested in Greatest Common Divisor (GCD). He wants to find more an ...

  6. WPF Background的设置有坑

    今天帮忙同事解决在后台绑定时,动态更改控件(Grid)的Background. 有个陷阱,C#有2个命名空间有Brush和Color, 分别为System.Drawing和System.Window. ...

  7. ExecutorService和CompletionService区别

    ExecutorService和CompletionService区别: ExecutorService:一直习惯自己维护一个list保存submit的callable task所返回的Future对 ...

  8. 错误: 实例 "ahwater-linux-core" 执行所请求操作失败,实例处于错误状态。: 请稍后再试 [错误: Exceeded maximum number of retries. Exceeded max scheduling attempts 3 for instance 7c1609c9-9d0f-4836-85b3-cefd45f942a7. Last exception: [u

    错误: 实例 "ahwater-linux-core" 执行所请求操作失败,实例处于错误状态.: 请稍后再试 [错误: Exceeded maximum number of ret ...

  9. JavaScript高级程序设计学习笔记第八章--BOM

    1.间歇调用和超时调用: 超时调用:需要使用 window 对象的 setTimeout()方法,它接受两个参数:要执行的代码和以毫秒表示的时间(即在执行代码前需要等待多少毫秒).其中,第一个参数可以 ...

  10. You have configured this virtual machine to use a 64-bit guest operating system. However, 64-bit

    vm虚拟机 问题:You have configured this virtual machine to use a 64-bit guest operating system.  However, ...