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]);
}
}
} 展开
#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]);
}
}
} 展开
2个回答
展开全部
先说几个小问题
你定义的是
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++;
}
这是我以前写的一个串口中断的测试程序,你看看吧,我是用开发板测试的
你定义的是
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的本子上都没问题了现在,还是要谢谢大家~
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询