专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
有没有人用过SD3088这个芯片,
2019-08-23 16:04
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
1645
8
1048
我看了半天编出来的程序感觉不对啊!写进去的值也不对,我想问这个芯片是自己会走时间的对吧》?那怎样才能让他走时?是供电了就走时还是要写什么数据进去?
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
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;
}
加载中...
查看其它8个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#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;
}
一周热门 更多>