有没有人用过SD3088这个芯片,

2019-08-23 16:04发布

我看了半天编出来的程序感觉不对啊!写进去的值也不对,我想问这个芯片是自己会走时间的对吧》?那怎样才能让他走时?是供电了就走时还是要写什么数据进去?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
8条回答
a295055641
2019-08-23 23:27
#include "i2c.h"
#include "delay.h"
#include "stm32f2xx.h"
#include "sys.h"
//////////////////////////////////////////////////////////////////////////////////         
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//Mini STM32开发板
//IIC 驱动函数          
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2010/6/10
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 正点原子 2009-2019
//All rights reserved
//////////////////////////////////////////////////////////////////////////////////           

//初始化IIC
void IIC_Init(void)
{                                             
        GPIO_InitTypeDef GPIO_InitStructure;
        //RCC->APB2ENR|=1<<4;//先使能外设IO PORTC时钟
           RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);  //A时钟使能
            RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC,ENABLE);  //C时钟使能
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
        //GPIO_InitStructure.GPIO_Mode =GPIO_Mode_AF;  
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;        //推挽输出
                GPIO_InitStructure.GPIO_OType = GPIO_OType_OD;
                    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

                GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
        //GPIO_InitStructure.GPIO_Mode =GPIO_Mode_AF;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;  //推挽输出
GPIO_InitStructure.GPIO_OType = GPIO_OType_OD;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
                    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
        GPIO_Init(GPIOC, &GPIO_InitStructure);
  //GPIO_SetBits(GPIOA,GPIO_Pin_8);
       
        //GPIO_SetBits(GPIOC,GPIO_Pin_9);
        //GPIO_ResetBits(GPIOA,GPIO_Pin_8);
        IIC_SCL1;
        IIC_SDA1;
IIC_SDA0;
}
//产生IIC起始信号
void IIC_Start(void)
{
        //SDA_OUT();     //sda线输出
        GPIO_SetBits(GPIOC,GPIO_Pin_9);//IIC_SDA=1;                    
        GPIO_SetBits(GPIOA,GPIO_Pin_8);//IIC_SCL=1;
delay_mms(2);
        GPIO_ResetBits(GPIOC,GPIO_Pin_9);//IIC_SDA=0;//START:when CLK is high,DATA change form high to low
        delay_mms(2);
        GPIO_ResetBits(GPIOA,GPIO_Pin_8);//IIC_SCL=0;//钳住I2C总线,准备发送或接收数据
}          
//产生IIC停止信号
void IIC_Stop(void)
{
        //SDA_OUT();//sda线输出
        GPIO_ResetBits(GPIOA,GPIO_Pin_8);//IIC_SCL=0;
                GPIO_ResetBits(GPIOC,GPIO_Pin_9);//IIC_SDA=0;//STOP:when CLK is high DATA change form low to high
        delay_mms(2);
                GPIO_SetBits(GPIOA,GPIO_Pin_8);//IIC_SCL=1;
                GPIO_ResetBits(GPIOC,GPIO_Pin_9);//IIC_SDA=1;//发送I2C总线结束信号
delay_mms(2);                                                          
}
//等待应答信号到来
//返回值:1,接收应答失败
//        0,接收应答成功
u8 IIC_Wait_Ack(void)
{
        u8 ucErrTime=0;
        //SDA_IN();      //SDA设置为输入  
        IIC_SDA1;delay_mms(2);          
        IIC_SCL1;delay_mms(2);         
        while(READ_SDA)
        {
                ucErrTime++;
                if(ucErrTime>250)
                {
                        IIC_Stop();
                        return 0;
                }
        }
        IIC_SCL0;//时钟输出0           
        return 1;  
}
//产生ACK应答
void IIC_Ack(void)
{
GPIO_ResetBits(GPIOA,GPIO_Pin_8);
        //SDA_OUT();
GPIO_ResetBits(GPIOC,GPIO_Pin_9);
delay_mms(2);
GPIO_SetBits(GPIOA,GPIO_Pin_8);
//delay_mms(2);
GPIO_ResetBits(GPIOA,GPIO_Pin_8);
}
//不产生ACK应答                    
void IIC_NAck(void)
{
                GPIO_ResetBits(GPIOA,GPIO_Pin_8);
        //SDA_OUT();
        GPIO_SetBits(GPIOC,GPIO_Pin_9);
        delay_mms(2);
GPIO_SetBits(GPIOA,GPIO_Pin_8);
        delay_mms(2);
GPIO_ResetBits(GPIOC,GPIO_Pin_9);
}                                                                              
//IIC发送一个字节
//返回从机有无应答
//1,有应答
//0,无应答                          
void IIC_Send_Byte(u8 txd)
{                        
    u8 t;   
  //SDA_OUT();             
    IIC_SCL0;//拉低时钟开始数据传输
    for(t=0;t<8;t++)
    {              
        //IIC_SDA((txd&0x80)>>7);
                        switch ((txd&0x80)>>7)
                                {        case 0: IIC_SDA0;  break;
                                  case 1:   IIC_SDA1;   break;
               }       
        txd<<=1;           
                delay_mms(2);   //对TEA5767这三个延时都是必须的
                IIC_SCL1;
                        delay_mms(2);
                IIC_SCL0;       
        delay_mms(2);
    }         
        }
//读1个字节,ack=1时,发送ACK,ack=0,发送nACK   
u8 IIC_Read_Byte(void)
{
        unsigned char i,receive=0;
        //SDA_IN();//SDA设置为输入
    for(i=0;i<8;i++ )
        {
        IIC_SCL0;
              delay_mms(2);
                IIC_SCL1;
        receive<<=1;
        if(READ_SDA)receive++;   
        delay_mms(2);
    }                                         
   IIC_SCL0;
    return receive;
}


u8 I2CReceiveByte(void)      //数据从高位到低位//
{
        int i=8;
        u8 ddata=0;
        SDA_IN()        ;                //设置SDA为输入(其它类型的单片机需要配置IO输入输出寄存器)
        while(i--)
        {
                ddata<<=1;      //数据从高位开始读取
                IIC_SCL0;
                delay_mms(20);
                IIC_SCL1;
                delay_mms(20);        //从高位开始 ddata|=SDA;ddata<<=1
                if(READ_SDA)
                {
                        ddata|=0x01;
                }
        }
        IIC_SCL0;
        return ddata;
}






u8 I2CWriteOneByte(unsigned char DeviceAddress,unsigned char add, unsigned char date)
{               
        //if(!IIC_Start())return 0;
        IIC_Start();  
        IIC_Send_Byte(DeviceAddress);      
        IIC_Wait_Ack();   
        IIC_Send_Byte(add);                //设置写地址      
        IIC_Wait_Ack();       
        IIC_Send_Byte(date);                //写数据
        IIC_Wait_Ack();       
        IIC_Stop();
        return        1;
}





u8 WriteTimeOn(void)
{               
        if(!I2CWriteOneByte(0x64,0x10,0x80))return 0;
        I2CWriteOneByte(0x64,0x0f,0xff);
        return        1;
}

/******写SD30XX禁止程序******/
u8 WriteTimeOff(void)
{               
        if(!I2CWriteOneByte(0x64,0x0f,0x7b))return 0;
        I2CWriteOneByte(0x64,0x10,0);
        return        1;
}











一周热门 更多>