求助,51串口接收和回显
#include<reg52.h>#define uchar unsigned char
#define uint unsigned int
uchar flag;
uint a;
void main()
{
TMOD=0x20;//定时器为方式2
TH1=0xfd;//波特率为9600
TL1=0xfd;
PCON=0;
TR1=1;
REN=1;
SM0=0;
SM1=1;
EA=1;
ES=1;
while(1)
{
if(flag==1)
{
ES=0;
flag=0;
SBUF=a;
while(!TI);
TI=0;
ES=1;
}
}
}
void ser() interrupt 4
{
RI=0;
P0=SBUF;
a=SBUF;
flag=1;
}
我想从串口调试助手上直接发一个数到串口上点亮led灯,再把发送的数据直接回显到调试助手,但每次发送的数据都不是预期的,例如发aa就显示0x1e或其他的数,而且回显的数据也是时有时无,想得头都快爆了,求各位大侠指教!!!!!! 我也纠结了这个好久 - - 回复【楼主位】tuxingyulin
-----------------------------------------------------------------------
自顶一个,哪位大虾能帮忙解决一下啊,小弟感激不尽………… 前阵子一直没空,到这两天才有空上论坛,自己的问题已经解决了,主要是晶振的误差问题,因为自己的实验板是用12点多的晶振,误差比较大,而选择的波特率又较高,故导致传输的数据不对,用低一些的波特率就可以了,如2400的波特率,自顶一个,以供大家参考。 #include <reg52.h>
#include <string.h>
unsigned char g_ucRecBuff = {0};
unsigned int g_iRecNum=0;
bit bReadOver=0;
//sbit Speak =P1^2;
//向串口发送一个字符
void SendChar(unsigned char ch)
{
SBUF=ch;
while(TI==0);
TI=0;
}
//向串口发送一个字符串,strlen为该字符串长度
void SerialSend(unsigned char *str,unsigned int strlen)
{
unsigned int k=0;
do
{
SendChar(*(str + k));
k++;
} while(k < strlen);
}
/********************************************************************
* 名称 : Com_Int()
* 功能 : 串口中断子函数
* 输入 : 无
* 输出 : 无
***********************************************************************/
void Serial_Int(void) interrupt 4 using 3
{
ES = 0;
if(RI == 1) //当硬件接收到一个数据时,RI会置位
{
g_ucRecBuff = SBUF; //把从串口读出的数存到数组
RI = 0;
g_iRecNum++;
if(g_iRecNum == 20)
{
g_iRecNum = 0; //当com_dat = 21时,清0,防止数组溢出
bReadOver = 1;
}
}
ES = 1;
}
/********************************************************************
* 名称 : Com_Init()
* 功能 : 串口初始化,晶振11.0592,波特率9600,使能了串口中断
* 输入 : 无
* 输出 : 无
***********************************************************************/
void SerialInit(void)
{
TMOD = 0x20; //定时器工作在定时器1的方式2
PCON = 0x00; //不倍频
SCON = 0x50; //串口工作在方式1,并且启动串行接收
TH1 = 0xFd; //设置波特率 9600
TL1 = 0xFd;
TR1 = 1; //启动定时器1
ES = 1; //开串口中断
//EA = 1; //开总中断
g_iRecNum=0;
memset(g_ucRecBuff,0xff,sizeof(g_ucRecBuff));
bReadOver=0;
}
//返回接收到的字符
unsigned int GetRecDate(unsigned char *pucRec)
{
if(bReadOver)
{
memcpy(pucRec,g_ucRecBuff,20);
memset(g_ucRecBuff,0,sizeof(g_ucRecBuff));
bReadOver=0;
g_iRecNum=0;
return 1;
}
return 0;
} mark wanyhong2012 发表于 2011-12-27 10:46 static/image/common/back.gif
#include
#include
g_ucRecBuff = SBUF; //把从串口读出的数存到数组
RI = 0;
g_iRecNum++;
if(g_iRecNum == 20)
{
g_iRecNum = 0; //当com_dat = 21时,清0,防止数组溢出
bReadOver = 1;
}
这个对吗? 你怎么接受串口通信的 ?
页:
[1]