当前位置: 代码迷 >> 单片机 >> STM32 串口通信罗致hard fault 产生
  详细解决方案

STM32 串口通信罗致hard fault 产生

热度:625   发布时间:2016-04-28 14:51:53.0
STM32 串口通信导致hard fault 产生
硬件:

STM32F103VE

实现过程:
串口中断接收的数据采用 全局变量来接收,然后再main 循环处理串口接收数据。
上位机每次发送8个字节给STM32开发板,即消息处理中的case 'o'的情况。
现象:

1.当全局变量分配为400个字节时,开发板能够处理5次上位机消息。
2.当全局变量分配为200个字节时,开发板能够处理17次上位机消息。
3.当全局变量分配为100个字节时,开发板能够处理26次上位机消息。

检查了代码没有内存泄露的情况。请高手帮忙检查一下代码。谢谢!

追加一个问题:

在主函数中的while循环中,如果不加上count>7 这个判断条件  硬件错误中断也会直接发生。

请问有没有更好的办法在主函数来处理中断上来的消息。最好能给一个相对较完整的代码演示。谢谢!
主循环函数:


u8 *usart_buff;
u32 count=0;
int main(void)
{
   u16 i=0,j=0,icnt=0;
   RCC_Configuration(); //系统时钟初始化
   GPIO_Configuration();//端口初始化
   USART_Configuration();
   NVIC_Configuration();
   usart_buff=(u8*)malloc(PC_MSG_LEN);
   BuffSet(usart_buff,0x0,PC_MSG_LEN);
  
   while(1)
   {     
    if(!USART_GetFlagStatus(USART1,USART_FLAG_RXNE)&&count>7)
{
  MessageProcess();

}
   }
}


消息处理函数:

extern unsigned int count;
extern u8* usart_buff;

void  MessageProcess(void)
{
MSGINFO* msg_info=(MSGINFO*)malloc(sizeof(MSGINFO));
msg_info=GetMsgInfo(usart_buff);
 switch(msg_info->command)
 {

case 'o':
printf("o\n");
break;
 default:
  break;
 }
 free(msg_info);
count=0;
BuffSet(usart_buff,0x0,PC_MSG_LEN);
}

void BuffSet(unsigned char* buff,unsigned char vaule, unsigned int length)
{
unsigned char* temp=buff;
int i=0;
for(i=0;i<length;i++)
{
*temp=vaule;
temp++;
}
}
MSGINFO* GetMsgInfo(u8 * buff)
{
u32 i =0,j=0,temp=0;
MSGINFO* msginfo= (MSGINFO*)malloc(sizeof(MSGINFO));
unsigned int sum;
//printf("MessageProcess\r\n");
msginfo->command=0;
msginfo->data_start_addr=0;
msginfo->length=0;
while(buff[i++]==0xaa && i<count)
{
temp=i-1;

//printf("length = 0x%x\r\n",length);
sum =GetChecksum(&buff[temp],msginfo->length+1+1+2);
   // printf("sum = 0x%x\r\n",sum);
if(VerifyChksum(sum,&buff[msginfo->length+1+1+2]))
{
   msginfo->length =GetLength(&buff[temp+2]);
   msginfo->command = buff[temp+1];
   return  msginfo;
}
else
{
 return 0;
}
}
return 0;
}



中断接收函数:


void USART1_IRQHandler(void)
{
   if(USART_GetITStatus(USART1,USART_IT_RXNE)!=RESET)
   {

usart_buff[count++]=USART_ReceiveData(USART1);
   }
}


------解决思路----------------------
在函数
MSGINFO* GetMsgInfo(u8 * buff)
{
    u32 i =0,j=0,temp=0;
    MSGINFO* msginfo= (MSGINFO*)malloc(sizeof(MSGINFO));
    unsigned int sum;
    //printf("MessageProcess\r\n");
    msginfo->command=0;
    msginfo->data_start_addr=0;
    msginfo->length=0;
    while(buff[i++]==0xaa && i<count)
    {
        temp=i-1;
         
        //printf("length = 0x%x\r\n",length);
        sum =GetChecksum(&buff[temp],msginfo->length+1+1+2);
       // printf("sum = 0x%x\r\n",sum);
        if(VerifyChksum(sum,&buff[msginfo->length+1+1+2]))
        {
           msginfo->length =GetLength(&buff[temp+2]);
           msginfo->command = buff[temp+1];
           return  msginfo;
        }
        else
        {
             return 0;
        }
    }
    return 0;
}
MSGINFO* msginfo= (MSGINFO*)malloc(sizeof(MSGINFO));你这个地方malloc有free吗?
  相关解决方案