关于51单片机串口通信 中断服务函数处理数据问题,希望前辈们可以帮忙看看,指点一二...在此表示感谢用的单片机是STC8A8K 在中断服务函数里 开了8个数组进行保存上位机发下来的8个数组,处理数据是在中断服务函数里处理的.用的是状态机的思想.开两个数组的时候没什么太大的问题,开了8个数组就卡死了.想请教一下前辈们怎么解决这个问题啊? 把数据处理放在主函数嘛? 还是重新定义一个函数呢? 我试了试,没能移植成功,希望前辈们能给点建议 晚辈不胜感激.
中断服务函数代码如下:(每个数组有两个帧头 一个帧尾)
void uart_ISR() interrupt 4
{unsigned int recv_data;
if(RI)
{ RI=0;
recv_data=SBUF;
switch(machine_step_0)
{//接收数据存入第1个数组
case 0:
if(recv_data==0xAA)
{machine_step_0=1;}
else
{machine_step_0=0;}
break;
case 1:
if(recv_data==0x55)
{machine_step_0=2;
recv_cnt_0=0;
}
else
{machine_step_0=0;}
break;
case 2:
if(recv_data!=0x0A)
{ recv_buf_0[recv_cnt_0]=recv_data;
recv_cnt_0++;
}
else
{
machine_step_0=3;
}
break;
//接收数据存入第2个数组
case 3:
if(recv_data==0xBB)
{
machine_step_0=4;
}
else
{
machine_step_0=0;
}
break;
case 4:
if(recv_data==0x44)
{
machine_step_0=5;
recv_cnt_1=0;
}
else
{
machine_step_0=0;
}
break;
case 5:
if(recv_data!=0x0B)
{
recv_buf_1[recv_cnt_1]=recv_data;
recv_cnt_1++;
}
else
{
machine_step_0=6;
}
break;
//接收数据存入第3个数组
case 6:
if(recv_data==0xCC)
{
machine_step_0=7;
}
else
{
machine_step_0=0;
}
break;
case 7:
if(recv_data==0x33)
{
machine_step_0=8;
recv_cnt_2=0;
}
else
{
machine_step_0=0;
}
break;
case 8:
if(recv_data!=0x0C)
{
recv_buf_2[recv_cnt_2]=recv_data;
recv_cnt_2++;
}
else
{
machine_step_0=9;
}
break;
//接收数据存入第4个数组
case 9:
if(recv_data==0xDD)
{
machine_step_0=10;
}
else
{
machine_step_0=0;
}
break;
case 10:
if(recv_data==0x22)
{
machine_step_0=11;
recv_cnt_3=0;
}
else
{
machine_step_0=0;
}
break;
case 11:
if(recv_data!=0x0D)
{
recv_buf_3[recv_cnt_3]=recv_data;
recv_cnt_3++;
}
else
{
machine_step_0=12;
}
break;
//接收数据存入第5个数组
case 12:
if(recv_data==0xEE)
{led=0;
machine_step_0=13;
}
else
{
machine_step_0=0;
}
break;
case 13:
if(recv_data==0x11)
{
machine_step_0=14;
recv_cnt_4=0;
}
else
{
machine_step_0=0;
}
break;
case 14:
if(recv_data!=0x0E)
{
recv_buf_4[recv_cnt_4]=recv_data;
recv_cnt_4++;
}
else
{
machine_step_0=15;
}
break;
//接收数据存入第6个数组
case 15:
if(recv_data==0xFF)
{
machine_step_0=16;
}
else
{
machine_step_0=0;
}
break;
case 16:
if(recv_data==0x55)
{
machine_step_0=17;
recv_cnt_5=0;
}
else
{
machine_step_0=0;
}
break;
case 17:
if(recv_data!=0x0F)
{
recv_buf_5[recv_cnt_5]=recv_data;
recv_cnt_5++;
}
else
{
machine_step_0=18;
}
break;
//接收数据存入第7个数组
case 18:
if(recv_data==0xAB)
{
machine_step_0=19;
}
else
{
machine_step_0=0;
}
break;
case 19:
if(recv_data==0x44)
{
machine_step_0=20;
recv_cnt_6=0;
}
else
{
machine_step_0=0;
}
break;
case 20:
if(recv_data!=0x1A)
{
recv_buf_6[recv_cnt_6]=recv_data;
recv_cnt_6++;
}
else
{
machine_step_0=21;
}
break;
//接收数据存入第8个数组
case 21:
if(recv_data==0xCD)
{
machine_step_0=22;
}
else
{
machine_step_0=0;
}
break;
case 22:
if(recv_data==0x33)
{
machine_step_0=23;
recv_cnt_7=0;
}
else
{
machine_step_0=0;
}
break;
case 23:
if(recv_data!=0x1B)
{
recv_buf_7[recv_cnt_7]=recv_data;
recv_cnt_7++;
}
else
{
recv_cnt_0=0;
recv_cnt_1=0;
machine_step_0=0;
recv_flag_0=1;
led1=0;
}
break;
default:break;
}}
if(TI)
{TI=0;}
}
|