按照原子的例子进行修改,应用到了一个标志位 USART_RX_STA,后来我在另一个函数中进行判断 if((USART_RX_STA&0x8000) == 1) ,//表示接收完成 但好像一直没有满足这个条件
//重定义fputc函数
int fputc(int ch, FILE *f)
{
/* USART1->SR;
USART_SendData(USART1, (uint8_t)ch);
while( USART_GetFlagStatus(USART1, USART_FLAG_TC) != SET);*/
USART1->DR=(u8) ch;
while(USART1->SR&(0X40)==0);
return (ch);
}
//中断服务函数
void USART1_IRQHandler(void) //串口1中断服务程序
{
u8 Res;
#if SYSTEM_SUPPORT_OS //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
OSIntEnter();
#endif
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收中断(接收到的数据必须是0x0d 0x0a结尾)
{
USART_ClearITPendingBit(USART1,USART_IT_RXNE); //清除中断标志
Res =USART_ReceiveData(USART1);//(USART1->DR); //读取接收到的数据
if((USART_RX_STA&0x8000)==0)//接收未完成
{
if(USART_RX_STA&0x4000)//接收到了0x0d
{
if(Res!=0x0a)USART_RX_STA=0;//接收错误,重新开始
else USART_RX_STA|=0x8000; //接收完成了
}
else //还没收到0X0D
{
if(Res==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收数据错误,重新开始接收
}
}
}
}
#if SYSTEM_SUPPORT_OS //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
OSIntExit();
#endif
}
//判断条件
if((USART_RX_STA&0x8000) == 1) // 接收完成
{
USART_RX_STA = 0 ; // 重置标志位
// if(strstr((char*)USART_RX_BUF , reply)) // 如果返回的字符串中包含有期望的返回值
if(strcmp((char*)USART_RX_BUF, reply) == 0)
{
return 1 ;
}
USART1_Send_String(USART_RX_BUF);
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
一周热门 更多>