51单片机与PC机模拟通信的问题,求高手指教啊。。

前几天写了个单片机与PC机通过proteus模拟通信的程序,51发数据包给PC时,调试助手能正确接受显示,但调试助手发给51时接受就不对了,例如我发给0XDD0X010X... 前几天写了个单片机与PC机通过proteus模拟通信的程序,51发数据包给PC时,调试助手能正确接受显示,但调试助手发给51时接受就不对了,例如我发给0XDD 0X01 0X0A 0XEE 0X0B时,单片机接受数字接受的却是:0XDD 0X44 0X20 0XEE 0X64.第一次写这种程序就遇到问题啦,求高手解决啊……
#include<reg52.h>
#include"intrins.h"
#define uchar unsigned char
#define uint unsigned int
#define SERIAL_BEGIN 0XDD
#define SERIAL_END 0XEE
uchar Recivetem[5];
uchar Revcnt;
bit RevOKflag;
void delayms(uchar z)
{
uchar p;
while(z--)
for(p=124;p>0;p--);
}
void Init_chuankou()
{
TMOD=0x20;
SCON|=0x40;
REN=1;
TH1=0xfd;
TL1=0xfd;
EA=1;
ES=1;
TR1=1;
}
void serialsend(uchar pdat)
{
TI=0;
SBUF=pdat;
while(!TI);
delayms(1);
TI=0;
}
void Ursendat(uchar addr,uchar dat)
{
uchar sendnum,CRCnum;
CRCnum=addr^dat;
serialsend(SERIAL_BEGIN);
serialsend(addr);
serialsend(dat);
serialsend(SERIAL_END);
serialsend(CRCnum);
}
void SerialRdisr() interrupt 4
{
if(RI)
{
ES=0;
RI=0;
Recivetem[Revcnt]=SBUF;
if(++Revcnt>5)
{
Revcnt=0;
RevOKflag=1;
}
ES=1;
}
/*switch(Revcnt)
{
case 1: if(rdata!=SERIAL_BEGIN) Revcnt=0;
break;
case 4: if(rdata!=SERIAL_END) Revcnt=0;
break;
case 5: Revcnt=0;
if(rdata!=Recivetem[1]^Recivetem[2])
Ursendat(0xFF,0XFF);
else RevOKflag=1;
break;
}*/
}
void main()
{
Init_chuankou();
//Ursendat(0x03,0x0a);
while(1)
{
if(RevOKflag)
{
RevOKflag=0;
Ursendat(Recivetem[1],Recivetem[2]);
}
}
}
展开
 我来答
lizhefeng321
2012-02-22 · 超过15用户采纳过TA的回答
知道答主
回答量:57
采纳率:0%
帮助的人:48.3万
展开全部
先说几个小问题
你定义的是
uchar Recivetem[5];
而在中断中的
Recivetem[Revcnt]=SBUF;
if(++Revcnt>5)
若进入if的条件是Recivetem[Revcnt]=Recivetem[5],跟你定义的溢出了
所以你应该定义
uchar Recivetem[6];

楼上说的ES=0 ES=1去不去无所谓,反正都已经进入中断了

程序有些没看懂,你想到达的效果也没太看懂

#include "reg52.h"
#include "1602.h"

#define uchar unsigned char
#define uint unsigned int

uchar a=0x30,b=0,flag,p[],i=0,k=0;

void init()
{
TMOD=0x20;
TH1=0xF3;
TL1=0xF3;
TR1=1;
SCON=0x50;
PCON=0x80;
ES=1;
EA=1;
}

void main()
{
init();
LcdInit();
Disp1Char(3,1,a);
while(1)
{
if(flag)
{
flag=0;
ES=0;
Disp1Char(b-1,0,p[i]);
SBUF=p[i];
i++;
while(!TI);
TI=0;
ES=1;
}
Disp1Char(4,1,i+0x30);
}
}

void lee() interrupt 4
{
RI=0;
p[i]=SBUF;
flag=1;
b++;
}

这是我以前写的一个串口中断的测试程序,你看看吧,我是用开发板测试的
追问
现在解决了,你说的问题都是在我调试的时候写错了if(++Revcnt>=5),我本意就是要5字节的,我开始写的那段程序其实是中断里注释的那部分,还有一楼的ES中断,其实我是想写EA的。。——!现在发现自己太不小心了。其实最大的问题是在我w7机子上的虚拟串口不太好用,换在我XP的本子上都没问题了现在,还是要谢谢大家~
960310983
2012-02-22 · TA获得超过352个赞
知道小有建树答主
回答量:867
采纳率:0%
帮助的人:210万
展开全部
在进入串口中断,执行中断服务程序的时候不要关闭串行口中断,因为51是双缓冲的,不用担心接收的时间问题,再说了,单片机的中断也不能中断与自己等级相同的中断啊
你把串口中断服务程序里面的开始的ES=0 和最后的ES=1去掉试试,
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式