关于单片机串口中断问题,请教。

2020-02-05 09:04发布

本帖最后由 lidakemaki 于 2012-6-15 09:45 编辑

大家好,如题。

不知道大家有没有遇到一种情况,就是单片机做“中转站”,把接收到的数据再发出去。

当然我知道可以用扫描的方法实现。

但是今天我试验了,用中断的方法,大意是接收到一组数据后,在接收中断中直接调用2个处理数据的函数,数据处理完毕,又在接收中断里,启动了发送中断。我这样试验后,发现时不时的会死机,而且有时数据处理明显不正确(因为处理后的结果都一样了!)。

请问,确实不能这样写吗?


其实我想问的问题是:

在单片机中,接收中断里调用2个函数,处理数据,并且在接收中断没有退出的情况下,申请发送中断。这样的做法,会不会造成单片机“死机”和函数处理数据不正确(数据结果一定)(函数一定是没问题的,因为我拿出中断来执行,数据都OK)
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
25条回答
lcw_swust
2020-02-06 00:00
本帖最后由 lcw_swust 于 2012-6-15 10:01 编辑

//FIFO工作模式
#define DTYPE INT16S
//数据类型

//--------------------------------------------------
//全局变量定义定义
//--------------------------------------------------
DTYPE quebuf[QUESIZE];
INT8U que_count=0;//队列元素计数
INT8U que_front=0;//队头
INT8U que_rear=0;//队尾
//--------------------------------------------------
//写队列
//①当头尾指针相等时,队列为空。
//②在非空队列里,队头指针始终指向队头元素,尾指针始终指向队尾元素的下一位置。
//--------------------------------------------------
void QueWrite(DTYPE din)
{
que_count++;
quebuf[que_rear]=din;
que_rear=(que_rear+1)%QUESIZE;//可写成que_rear++;if(que_rear>=QUESIZE)que_rear=0;

}
//--------------------------------------------------
//读取队列
//--------------------------------------------------
DTYPE QueRead(void)
{
DTYPE ret;
  //FIFO模式
que_count--;
ret=quebuf[que_front];
que_front=(que_front+1)%QUESIZE;;//可写成que_front++;if(que_front>=QUESIZE)que_front=0;
return ret;
}
//--------------------------------------------------
//队列满(返回1)
//--------------------------------------------------
INT8U QueFull(void)
{
return (que_count==QUESIZE);
}
//--------------------------------------------------
//队列空(返回1)
//--------------------------------------------------
INT8U QueEmpt(void)
{
return (que_count==0);
}


串口中断里:
  if(QueFull()==0)QueWrite(drx);//FIFO未满,则写入串口数据

主循环里
  if(QueEmpt()==0)dtx=QueRead();//FIFO未空,则读取数据

一周热门 更多>