//口程序(C51)
/*通信协议:第1字节,MSB为1,为第1字节标志,第2字节,MSB为0,为非第一字节标志,其余类推……,最后一个字节为前几个字节后7位的异或校验和。
测试方法:可以将串口调试助手的发送框写上 95 10 20 25,并选上16进制发送,接收框选上16进制显示,如果每发送一次就接收到95 10 20 25,说明测试成功。
*/
//这是一个单片机C51串口接收(中断)和发送例程,可以用来测试51单片机的中断接收和查询发送
#include <reg51.h>
#include <string.h>
#define INBUF_LEN 4 //数据长度
unsigned char inbuf1[INBUF_LEN];
unsigned char checksum,count3;
bit read_flag=0;
void init_serialcomm(void);
void send_char_com(unsigned char ch);
void send_string_com(unsigned char *str,unsigned int strlen);
void serial ();
void init_serialcomm(void)
{
SCON = 0x50; //SCON: 方式1, 8-bit UART
TMOD |= 0x20; //TMOD: timer 1,方式2, 8-bit 自动重装
PCON |= 0x80; //SMOD=1;
TH1 = 0xF4; //波特率:4800 11.0592MHz
IE |= 0x90; //开中断
TR1 = 1; //开定时器1
// TI=1;
}
//向串口发送一个字符
void send_char_com(unsigned char ch)
{
SBUF=ch;
while(TI==0);
TI=0;
}
//向串口发送一个字符串,strlen为该字符串长度
void send_string_com(unsigned char *str,unsigned int strlen)
{
unsigned int k=0;
do
{
send_char_com(*(str + k));
k++;
} while(k < strlen);
}
//串口接收中断函数
void serial () interrupt 4 using 3
{
if(RI)
{
unsigned char ch;
RI = 0;
ch=SBUF;
if(ch>127)
{
count3=0;
inbuf1[count3]=ch;
checksum= ch-128;
}
else
{
count3++;
inbuf1[count3]=ch;
checksum ^= ch;
if( (count3==(INBUF_LEN-1)) && (!checksum) )
{
read_flag=1; //如果串口接收的数据达到INBUF_LEN个,且校验没错,
//就置位取数标志
}
}
}
}
main()
{
init_serialcomm(); //初始化串口
while(1)
{
if(read_flag) //如果取数标志已置位,就将读到的数从串口发出
{
read_flag=0; //取数标志清0
send_string_com(inbuf1,INBUF_LEN);
}
}
}
-
引用 netwell 2008/9/16 11:29:20 发表于2楼的内容
-
-
-
-
zhangym0501 | 当前状态:在线
总积分:373 2025年可用积分:0
注册时间: 2007-01-17
最后登录时间: 2013-07-04
-
-
zhangym0501 发表于 2008/9/18 22:12:19
引用 zhangym0501 2008/9/18 22:12:19 发表于3楼的内容
-
-
引用 txax 2008/9/24 14:45:15 发表于4楼的内容