串口中断发送与接收.docVIP

  • 19
  • 0
  • 约3.3千字
  • 约 5页
  • 2016-08-23 发布于河南
  • 举报
串口中断发送与接收

串口中断接收与发送 以前一直写串口程序都是发送一个字符,然后等待TI=1时再发另一个字符,觉得这样很浪费时间,因为在波特率为9600时,每发一个字符差不多要1ms的时间;接收则接收一个字符即存入数组,直到有结束标志出现,后来发现这种做法很局限,因为在与一些串口设备通讯时,返回的数据很难以最后一个字符为结束标志符。 于是现在重新变换了一下串口发送(接收)的思路: 发送:中断只管发送,程序把要发送的数组写入缓存然后触发发送信号,剩下的则由中断处理,当识别到结束标志时,发送完毕,及置位发送完毕标志。 接收:中断只管接收并存入缓存,程序每循环一次则检测一次缓存是否有数据变化,若有则读缓存,若无则跳过。在读完最后一个缓存字符之后若n(设n=100)次循环检测缓存再无变化,则认为一组数据发送完毕。 程序流程图如下所示: 于是写了如下程序。 /************************************************ 串口中断接收(发送)数据 单片机接收完一组数据后将其再从串口发回 串口测试直接可运行 ************************************************/ #includereg52.h #includeintrins.h #includestring.h #define uchar unsigned char #define uint unsigned int sbit Rxd=P1^0; //接收脚(模拟串口) sbit Txd=P1^1; //发送脚 #define RST 0x01 #define NEW 0x02 //新短信标志 #define CMGR 0x03 //读短信标志 #define BEGIN 0x04 //仪表数据开始读 #define STOP 0x05 //仪表数据结束读 #define NEXT 0x06 //准备读短信内容 #define NEXTBEGIN 0x07 //开始读短信 #define START 0x08 //开始读发送短信的手机号码 #define TRUE 0x09 //准备读号码,也作为新短信读取后的标志 #define FALSE 0x0a //没有新短信 uchar xdata table_send[140]; //发送缓存 uchar SendLength=0; uchar xdata table_receive[32]; //接收缓存 uchar ReceiveLength=0; uchar xdata table_dat[100]=Hello world!\n; //数据存储 uchar DatLength=0; //数据长度标志 uchar SendFlag=0; //发送状态标志 uchar ReadMark=0; //读取串口数据记录的位置(书签) uchar ReadFlag; //读串口标志 uint EndFlag=250; //计数250 void init_serial1(); //串口初始化为方式1:9600,n,8,1 void send_listtable(uchar *list); //串口发送一个字符串 void receive_listtable(); //串口缓存接收 void main() //主程序 { uint j=1000; while(j--); //开启程序时先等待一会(一直还没明白为什么要这样,不然下完程序后第一次发送出错) init_serial1(); //串口初始化 send_listtable(table_dat); //先试发一串数据 while(1) { receive_listtable(); //读缓存 if(ReadFlag==STOP) //读取完一组数据 { ReadFlag=RST; send_listtable(table_dat); //将读取的数据发回串口(调试用) } } } void init_serial1() { SendFlag=STOP; ReadFlag=RST; TMOD|=0X20; //开启串口收发设置 TH1=0XFD; //波特率9600 TL1=0XFD; SM0=0; SM1=1; //方式1,10位异步收发 REN=1; //数据接收允许 RI=0; TI=0; TR1=1; ES=1; EA=1; } void send_listtable(u

文档评论(0)

1亿VIP精品文档

相关文档