5422|14

56

帖子

0

TA的资源

一粒金砂(高级)

楼主
 

帮忙看下我的DS1302程序哪里出问题了 [复制链接]

程序编译无错误无警告
问题是从不同寄存器读出来的数据显示出来貌似都是一样的,我不知道是哪个部分出问题了,是读还是写?
下面是程序
#include #include #include "Lcd.h" #define uchar unsigned char #define uint unsigned int sbit rst=P2^2; //复位线 sbit sclk=P2^0; //时钟线 sbit sda=P2^1; //数据线 sbit ACC0 = ACC^0; sbit ACC7 = ACC^7; uchar time_dat[7]={0x11,0x3,0x10,0x19,0x15,0x00,0x00}; //初始化 2011-10-19 15::00:00 uchar week[]={'M','o','n','T','u','e','W','e','d','T','h','r','F','r','i','S','a','t','S','u','n',}; //周一~日 void send_byte(uchar dt) //发送1字节 { uchar i; ACC=dt; //rst=0; //sclk=0; //rst=1; for(i=0;i<8;i++) { //if(dt&0x01) sda=1; //else sda=0; sda = ACC0; sclk=1; _nop_(); sclk=0; ACC=ACC>>1; } } uchar rec_byte(void) //读取1字节 { uchar i;//dt=0x00; for(i=0;i<8;i++) { sda=1; ACC = ACC >>1; /*相当于汇编中的 RRC */ ACC7 = sda; sclk=1; _nop_(); //F0=sda; //if(F0) dt=(dt|0x80)>>1; //else dt=dt>>1; sclk=0; } return ACC; } void send_1data(uchar dt,uchar address) // 指定寄存器写数据 { rst=0; sclk=0; rst=1; send_byte(address); send_byte(dt); sclk=1; rst=0; } uchar read_1data(uchar address) //指定寄存器读数据 { uchar dt; rst=0; sclk=0; rst=1; send_byte(address); dt=rec_byte(); sclk=1; rst=0; return dt; } // void d1302_init(void) //初始化,写入预订数据 { uchar p=0x80; uchar i; send_1data(0x00,0x8e); for(i=7;i>0;i--) { send_1data(time_dat[i-1],p); p=p+2; } send_1data(time_dat[6]&0x7f,0x80); send_1data(0x80,0x8e); } void Get_d1302(void) //读年月日星期时分秒数据 { uchar i; uchar p=0x81; for(i=7;i>0;i--) { time_dat[i-1]=read_1data(p); p=p+2; } } void time_display(void) //显示函数 { uchar i; uchar s[15]; Get_d1302(); s[0]='2'; s[1]='0'; s[4]='-'; s[7]='-'; s[2]=(time_dat[0]>>4)&0x0f; s[2]+=48; s[3]=time_dat[0]&0x0f ; s[3]+=48; s[5]=(time_dat[2]>>4)&0x0f ; s[5]+=48; s[6]=time_dat[2]&0x0f ; s[6]+=48; s[8]=(time_dat[3])>>4&0x0f; s[8]+=48; s[9]=time_dat[3]&0x0f; s[9]+=48; i=time_dat[1]-1; s[10]=' '; s[11]=week[i*3] ; s[12]=week[i*3+1] ; s[13]=week[i*3+2] ; s[14]='\0'; Lcdwrite_string(0,4,s); s[2]=s[5]=':'; s[8]='\0'; s[0]=(time_dat[4])>>4&0x0f; s[0]+=48; s[1]=(time_dat[4])&0x0f; s[1]+=48; s[3]=(time_dat[5])>>4&0x0f; s[3]+=48; s[4]=(time_dat[5])&0x0f ; s[4]+=48; s[6]=(time_dat[6])>>4&0x0f; s[6]+=48; s[7]=(time_dat[6])&0x0f; s[7]+=48; Lcdwrite_string(18,5,s); } 调了一天了出不来高手速度来围观啊。。。。

[ 本帖最后由 abo6016 于 2011-10-20 13:40 编辑 ]
此帖出自51单片机论坛

最新回复

受益匪浅啊  详情 回复 发表于 2011-10-26 04:23
点赞 关注
 

回复
举报

535

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 
调了才一天啊!就不想调了吗!呵呵!
此帖出自51单片机论坛
 
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

板凳
 

回复 沙发 小小白 的帖子

当然不是,只是这是目前做的小系统最后一个模块。。而且就这么点东西一天都么弄出来好挫折。。。。。不知道错误在哪。。
此帖出自51单片机论坛
 
 
 

回复

168

帖子

0

TA的资源

一粒金砂(高级)

4
 
读取1字节的sda=1;是什么意思?
初始化吗?可成了赋值了。
此帖出自51单片机论坛
 
个人签名逆水行舟,不进则退。
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

5
 

回复 4楼 wisology 的帖子

sbit sda=P2^1;        //数据线

上头有的,不是赋值,只是先拉高

[ 本帖最后由 abo6016 于 2011-10-20 13:49 编辑 ]
此帖出自51单片机论坛
 
 
 

回复

168

帖子

0

TA的资源

一粒金砂(高级)

6
 

回复 5楼 abo6016 的帖子

拉高设置一次就可以了吧,你每次都拉高?可能实现了赋值的功能。
此帖出自51单片机论坛
 
个人签名逆水行舟,不进则退。
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

7
 

回复 6楼 wisology 的帖子

终于弄出来了。。坑爹啊。。。帮我分析下原因
void send_byte(uchar dt) //发送1字节
{
uchar i;
ACC=dt;
//rst=0;
//sclk=0;
//rst=1;
for(i=0;i<8;i++)
{
//if(dt&0x01) sda=1;
//else sda=0;
sda = ACC0;
sclk=1;
_nop_();
sclk=0;
ACC=ACC>>1;
}这个函数中,for(i=0;i<8;i++)改为for(i=8;i>0;i--)他丫的就欢快的跑起来了啊。。。

有谁知道原因么
此帖出自51单片机论坛
 
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

8
 
原帖由 abo6016 于 2011-10-20 15:03 发表
终于弄出来了。。坑爹啊。。。帮我分析下原因
void send_byte(uchar dt) //发送1字节
{
uchar i;
ACC=dt;
//rst=0;
//sclk=0;
//rst=1;
for(i=0;i>1;
}这个函数中,for(i=0;i0;i--)他丫的就欢快的跑起来了啊 ...

终于找出原因了
刚看了下
ACC=dt;的汇编是mov a,r7;
然后如果i=0的话
汇编是 clr a; mov r7,a;
如果i=1的话
直接mov r7,1;

貌似我在自言自语;
恩,果然要学好汇编。
此帖出自51单片机论坛
 
 
 

回复

42

帖子

0

TA的资源

一粒金砂(初级)

9
 
也来学习一下,呵呵
此帖出自51单片机论坛
 
 
 

回复

7815

帖子

57

TA的资源

裸片初长成(中级)

10
 

回复 8楼 abo6016 的帖子

你确定一下人家串行位的发送顺序再说,......
此帖出自51单片机论坛
 
个人签名

强者为尊,弱者,死无葬身之地

 
 

回复

2751

帖子

0

TA的资源

裸片初长成(初级)

11
 

原帖由 abo6016 于 2011-10-20 15:56 发表 终于找出原因了刚看了下 ACC=dt;的汇编是mov a,r7; 然后如果i=0的话汇编是 clr a; mov r7,a; 如果i=1的话直接mov r7,1; 貌似我在自言自语;恩,果然要学好汇编。

 

不要直接用内部寄存器ACC那些

很容易出事的

此帖出自51单片机论坛
 
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

12
 
原帖由 David_Lee 于 2011-10-21 09:58 发表   不要直接用内部寄存器ACC那些 很容易出事的


其实我自己写的不是这样的,你也看到有些取消掉的代码,我这是调不出换开发板提供的示例程序里拷过来试试的
此帖出自51单片机论坛
 
 
 

回复

85

帖子

0

TA的资源

一粒金砂(中级)

13
 

回复 8楼 abo6016 的帖子

借问下lz用的是什么处理器,我怎么也没看明白,2种写法都是控制循环8次,i 跟送去寄存器的值没有任何关系啊~~
此帖出自51单片机论坛
 
 
 

回复

10

帖子

0

TA的资源

一粒金砂(初级)

14
 
受益匪浅啊
此帖出自51单片机论坛
 
 
 

回复

56

帖子

0

TA的资源

一粒金砂(高级)

15
 

回复 13楼 暖暖美少 的帖子

是STC89C52
有关系的,我后面也说了,在编译的时候,如果给I 赋0值,在汇编里是先CLR A,然后MOVE R7 A,但是因为之前把要发送的数据存储在ACC中,所以数据就丢失了,但是如果I是1开始的话,那么计数时是直接 MOVE R7 #1H,直接赋值的,所以才会出现这奇怪的现象,跟编译器有关,我用的是C51
此帖出自51单片机论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表