mcp7940N与PIC18F24K40的接口
我正在尝试将PIC18F24k40设备连接到CP7940 N RTC设备。我已经为100khz频率配置了8mhz和RTC设备。我已经用arduino uno板测试了我的硬件,它工作得很好。但我用的是pic单片机,用mcc生成库。 在下面的代码中,我可以显示min=20和sec=10,但sec参数没有增加。我使用DS1307/DS3233/PC8563 RTC设备尝试的类似硬件工作正常,我可以使用逻辑分析仪获得SDA/SCL脉冲 对于下面的代码,我不会得到任何响应,但它显示了我在i2c从机地址中写入的内容 有人能帮我找出什么应该被读取的格式来获得rtc最小值和秒数吗mcp7940N与PIC18F24K40的接口,c,pic,i2c,C,Pic,I2c,我正在尝试将PIC18F24k40设备连接到CP7940 N RTC设备。我已经为100khz频率配置了8mhz和RTC设备。我已经用arduino uno板测试了我的硬件,它工作得很好。但我用的是pic单片机,用mcc生成库。 在下面的代码中,我可以显示min=20和sec=10,但sec参数没有增加。我使用DS1307/DS3233/PC8563 RTC设备尝试的类似硬件工作正常,我可以使用逻辑分析仪获得SDA/SCL脉冲 对于下面的代码,我不会得到任何响应,但它显示了我在i2c从机地址中写
#include "mcc_generated_files/mcc.h"
#include"mcc_generated_files/examples/i2c1_master_example.h"
int sec;
int min;
int hour;
int date;
int month;
int year;
int day;
int temp=0;
int r_data;
#define Seg1 0x01
#define Seg2 0x02
#define Seg3 0x04
#define Seg4 0x08
#define Seg5 0x10
#define Seg6 0x20
unsigned char Flag_Update=0;
void Delay(unsigned int k) {
unsigned int j;
for(j=0; j<k; j++);
}
void SetSeg(unsigned short data, unsigned short segno)
{
switch(data) {
case 0:
PORTB = 0x3F;
break;
case 1:
PORTB = 0x06;
break;
case 2:
PORTB = 0x5B;
break;
case 3:
PORTB = 0x4F;
break;
case 4:
PORTB = 0x66;
break;
case 5:
PORTB = 0x6D;
break;
case 6:
PORTB = 0x7D;
break;
case 7:
PORTB = 0x07;
break;
case 8:
PORTB = 0x7F;
break;
case 9:
PORTB = 0x6F;
break;
default :
PORTB = 0X00;
break;
}
if(segno==1) {
PORTA = Seg4;
}
if(segno==2) {
PORTA = Seg3;
}
if(segno==3) {
PORTA = Seg2;
}
if(segno==4) {
PORTA = Seg1;
}
if(segno==5) {
PORTC=0X00;
PORTC = 0x40;//DP2 fourth Segment
// PORTCbits.RC5=1;
}
if(segno==6) {
PORTC=0X00;
PORTC= 0x20;//DP2 third Segment
//PORTCbits.RC6=1;
}
if(segno==7) {
PORTA=0X00;
PORTA = Seg5; //DP2 Second Segment
// PORTAbits.RA4=1;
}
if(segno==8) {
PORTA=0X00;
PORTA = Seg6; //DP2 First Segment
// PORTAbits.RA5=1;
}
}
unsigned int bcdtodecimal(unsigned int bcd) {
unsigned int decimal;
decimal = (((bcd & 0xF0) >> 4) * 10) + (bcd & 0x0F);
return decimal;
}
void ISR_Routine(void) {
if(PIR0bits.TMR0IF==1) {
PIR0bits.TMR0IF = 0;
count= count+1;
if(count>=10) {
Flag_Update=1;
count=0;
LED=!LED;
}
}
}
void main(void) {
// Initialize the device
SYSTEM_Initialize();
INTCONbits.GIE=1;
INTCONbits.PEIE=1;
I2C1_Initialize();
I2C1_Write1ByteRegister(0x6F,0x00,0x10);//sec
I2C1_Write1ByteRegister(0x6F,0x01,0x20);//min
I2C1_Write1ByteRegister(0x6F,0x02,0x01);//Hour
I2C1_Write1ByteRegister(0x6F,0x03,0x01);
I2C1_Write1ByteRegister(0x6F,0x04,0x02);
I2C1_Write1ByteRegister(0x6F,0x05,0x03);
I2C1_Write1ByteRegister(0x6F,0x06,0x10);
I2C1_Write1ByteRegister(0x6F,0x07,0x48);
while (1)
{
sec=I2C1_Read1ByteRegister(0x6F,0x00);
min=I2C1_Read1ByteRegister(0x6F,0x01);
if(Flag_Update==1) {
SetSeg(min >> 4,4);
__delay_ms(5);
SetSeg(min & 0x0f,3);
__delay_ms(5);
SetSeg(sec >> 4,2);
__delay_ms(5);
SetSeg(sec & 0x0f,1);
__delay_ms(5);
Flag_Update = 0; //ready for next update
}
}
}
#包括“mcc_生成的文件/mcc.h”
#包括“mcc_生成的_文件/examples/i2c1_master_example.h”
国际秒;
int-min;
整小时;
国际日期;
整月;
国际年;
国际日;
内部温度=0;
int r_数据;
#定义Seg1 0x01
#定义SEG20x02
#定义Seg3 0x04
#定义Seg4 0x08
#定义Seg5 0x10
#定义Seg6 0x20
unsigned char Flag_Update=0;
无效延迟(无符号整数k){
无符号整数j;
对于(j=0;j>4)*10+(bcd&0x0F);
返回小数;
}
无效ISR_例程(无效){
if(PIR0bits.TMR0IF==1){
PIR0bits.TMR0IF=0;
计数=计数+1;
如果(计数>=10){
Flag_Update=1;
计数=0;
发光二极管=!发光二极管;
}
}
}
真空总管(真空){
//初始化设备
系统初始化();
INTCONbits.GIE=1;
INTCONbits.PEIE=1;
I2C1_初始化();
I2C1_由Teregister写入(0x6F,0x00,0x10);//秒
I2C1_由Teregister写入(0x6F,0x01,0x20);//最小值
I2C1_由Teregister写入(0x6F,0x02,0x01);//小时
I2C1_由Teregister写入(0x6F、0x03、0x01);
I2C1_由Teregister写入(0x6F、0x04、0x02);
I2C1_由Teregister写入(0x6F、0x05、0x03);
I2C1_由Teregister写入(0x6F、0x06、0x10);
I2C1_由Teregister写入(0x6F、0x07、0x48);
而(1)
{
sec=I2C1_读取字节寄存器(0x6F,0x00);
最小值=I2C1_读取1字节寄存器(0x6F,0x01);
如果(标志_更新==1){
设置组(最小值>>4,4);
__延迟时间(5);
设置组(最小值和0x0f,3);
__延迟时间(5);
设置组(第4.2节);
__延迟时间(5);
设定值(秒和0x0f,1);
__延迟时间(5);
Flag_Update=0;//准备好进行下一次更新
}
}
}
I2C1_Initialize()之间添加一些延迟由Teregister写入的代码>和I2C1_(0x6F,0x00,0x10)代码>假设10毫秒。有时I2C模块在初始化后需要一些延迟。大约是几微秒,但我个人建议是1毫秒或10毫秒
min=I2C1_Read1ByteRegister(0x6F,0x01)代码>在if(Flag_Update==1)
内,因为只有当您要在七段屏幕上显示时,才应阅读MCP7940N
使用变量监视
)检查变量min
和sec
是否已实际更新。。?如果这两个都使用实际实时正确更新,则检查您的SetSeg
功能