//和查询发送,另外我觉得发送没有必要用中断,因为程序的开销是一样的
#include
#include
#define INBUF_LEN 4 //数据长度
unsigned char inbuf1[INBUF_LEN];
unsigned char checksum,count3;
bit read_flag=0;
void init_serialcomm(void)
{
SCON = 0x50; //SCON: serail mode 1, 8-bit UART, enable ucvr
TMOD |= 0x20; //TMOD: timer 1, mode 2, 8-bit reload
PCON |= 0x80; //SMOD=1;
TH1 = 0xF4; //Baud:4800 fosc=11.0592MHz
IE |= 0x90; //Enable Serial Interrupt
TR1 = 1; // timer 1 run
// 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);
}
}
}
//-------------------------------------------------------------------
//crc:校验子程序
//开始地址指针ADRS,需校验字节数量SUM
//校验结果:高位CRCH,低位CRCL
//-------------------------------------------------------------------
void CCRC(unsigned char *ADRS,unsigned char SUM)
{
unsigned int data CRC; //校验码
unsigned char data i;
unsigned char data j;
CRC=0xFFFF;
for (i=0;i { CRC^=*ADRS; for (j=0;j<8;j++) { if ((CRC & 1)==1) { CRC>>=1; CRC^=0xA001; } else { CRC>>=1; } } ADRS++; } CRCH=CRC&0xFF; CRCL=CRC>>8; } //------------------------------------------------------------------- //其他程序调用例子 //校验数组前6位 //------------------------------------------------------------------- //。。。 unsigned char data RBuf[9]; //数据区 CCRC(&RBuf,6); //。。。 CRC差错检验法在PC 机与8031单片机串行通讯中的应用
摘 要 通过对不同校验方法的分析,介绍了一种适合PC机与8031单片 机通讯差错校验的CRC方法并给出了其实现的软件流程图。
上一篇:C51:串口通信接收与发送
下一篇:C51串口的SCON寄存器及工作方式
推荐阅读最新更新时间:2024-03-16 14:57