OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3361|回复: 3

stm32F429 HAL库串口例程【实验3】中不能正常使用被注释的函数USART1_IRQHandler

[复制链接]

2

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2019-5-14
在线时间
19 小时
发表于 2019-8-3 21:42:34 | 显示全部楼层 |阅读模式
1金钱

实验3例程usart.c使用的是在串口中断函数USART1_IRQHandler中调用HAL_UART_IRQHandler,测试没有问题。
usart.c文件最下面有直接在USART1_IRQHandler中处理中断控制的版本(被注释了)。把上面的USART1_IRQHandler和HAL_UART_IRQHandler注释后改用下面的版本串口就接收不到发送的数据了,其他代码完全没有改动,感觉非常奇怪,查了半天资料不知道错在哪里……

//void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
//{
//        if(huart->Instance==USART1)//如果是串口1
//        {
//                if((USART_RX_STA&0x8000)==0)//接收未完成
//                {
//                        if(USART_RX_STA&0x4000)//接收到了0x0d
//                        {
//                                if(aRxBuffer[0]!=0x0a)USART_RX_STA=0;//接收错误,重新开始
//                                else USART_RX_STA|=0x8000;        //接收完成了
//                        }
//                        else //还没收到0X0D
//                        {       
//                                if(aRxBuffer[0]==0x0d)USART_RX_STA|=0x4000;
//                                else
//                                {
//                                        USART_RX_BUF[USART_RX_STA&0X3FFF]=aRxBuffer[0] ;
//                                        USART_RX_STA++;
//                                        if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收数据错误,重新开始接收          
//                                }                 
//                        }
//                }

//        }
//}
//
////串口1中断服务程序
//void USART1_IRQHandler(void)                       
//{
//        u32 timeout=0;
//        u32 maxDelay=0x1FFFF;
//#if SYSTEM_SUPPORT_OS                 //使用OS
//        OSIntEnter();   
//#endif
//       
//        HAL_UART_IRQHandler(&UART1_Handler);        //调用HAL库中断处理公用函数
//       
//        timeout=0;
//    while (HAL_UART_GetState(&UART1_Handler) != HAL_UART_STATE_READY)//等待就绪
//        {
//         timeout++;////超时处理
//     if(timeout>maxDelay) break;               
//        }
//     
//        timeout=0;
//        while(HAL_UART_Receive_IT(&UART1_Handler, (u8 *)aRxBuffer, RXBUFFERSIZE) != HAL_OK)//一次处理完成之后,重新开启中断并设置RxXferCount为1
//        {
//         timeout++; //超时处理
//         if(timeout>maxDelay) break;       
//        }
//#if SYSTEM_SUPPORT_OS                 //使用OS
//        OSIntExit();                                                                                           
//#endif
//}
//#endif       


/*下面代码我们直接把中断控制逻辑写在中断服务函数内部。
说明:采用HAL库处理逻辑,效率不高。*/
///*


//串口1中断服务程序
void USART1_IRQHandler(void)                       
{
        u8 Res;
#if SYSTEM_SUPPORT_OS                 //使用OS
        OSIntEnter();   
#endif
        if((__HAL_UART_GET_FLAG(&UART1_Handler,UART_FLAG_RXNE)!=RESET))  //接收中断(接收到的数据必须是0x0d 0x0a结尾)
        {
        HAL_UART_Receive(&UART1_Handler,&Res,1,1000);
                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;//接收数据错误,重新开始接收          
                                }                 
                        }
                }                    
        }
        HAL_UART_IRQHandler(&UART1_Handler);       
#if SYSTEM_SUPPORT_OS                 //使用OS
        OSIntExit();                                                                                           
#endif
}
#endif       



最佳答案

查看完整内容[请看2#楼]

对照后面实验【28】485的实验,发现是前面开启中断的方式不对。 不用://HAL_UART_Receive_IT(&UART1_Handler, (u8 *)aRxBuffer, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量(使用回调函数处理中断需要调用该函数) 应该是:__HAL_UART_ENABLE_IT(huart,UART_IT_RXNE); //开启接收中断 但是我遇到了另一个问题,为什么485实验里面有__HAL_UART_DISABLE_IT(huart ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
67
金钱
67
注册时间
2019-5-14
在线时间
19 小时
 楼主| 发表于 2019-8-3 21:42:35 | 显示全部楼层
对照后面实验【28】485的实验,发现是前面开启中断的方式不对。
不用://HAL_UART_Receive_IT(&UART1_Handler, (u8 *)aRxBuffer, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量(使用回调函数处理中断需要调用该函数)
应该是:__HAL_UART_ENABLE_IT(huart,UART_IT_RXNE);                //开启接收中断

但是我遇到了另一个问题,为什么485实验里面有__HAL_UART_DISABLE_IT(huart,UART_IT_TC)这行代码,没有搞清楚这个的意义,旁边也没有注解……
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2019-8-4 01:37:05 | 显示全部楼层
shelter 发表于 2019-8-3 22:16
对照后面实验【28】485的实验,发现是前面开启中断的方式不对。
不用://HAL_UART_Receive_IT(&UART1_Hand ...

看名字就知道了禁止发送完成中断。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

9

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2019-3-4
在线时间
5 小时
发表于 2019-8-15 11:35:49 | 显示全部楼层
你好,请问你的例程在哪下载
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 05:36

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表