完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
前端时间遇到正常使用的串口一直卡死在USART_FLAG_ORE标志位处,有一定概率发生这个,但在发生后,就会一直进入中断。按照网上的方法做了清除标志位处理,但结果还是解决不了。
通过调试发现,中断一直进入这个地方 if(USART_GetFlagStatus(USART1,USART_FLAG_ORE) != RESET) { USART_ReceiveData(USART1); USART_ClearFlag(USART1,USART_FLAG_ORE); } 网上对此的说明很多,但都是指出了问题点,没有解决该问题。其实我理解中该问题的原因很简单,在你使能串口中断USART_ITConfig(USART1 , USART_IT_IDLE, ENABLE); USART_ITConfig(USART1 ,USART_IT_RXNE , ENABLE);时, 同时会半开启USART_FLAG_ORE中断,这种情况就是BUG,出现溢出会进入中断函数,但是却清除不掉标志位,因为你没有调用开启函数开启该中断。 所以解决办法就是我们必须在开启中断同时,开启错误中断 USART_ITConfig(USART1, USART_IT_ERR, ENABLE); 这个配置设置后就可以使用前面的清除标志位的函数了,不然清除标志位会失效。同时由于开启了该中断会导致其他错误标志位响应中断我们也需要清除标志位。以正确的处理的代码如下: void USART1_IRQHandler(void) //串口1中断服务程序 // { // uint8_t Clear = Clear; // if (USART_GetFlagStatus(USART1, USART_FLAG_FE) != RESET) { USART_ReceiveData(USART1); USART_ClearFlag(USART1, USART_FLAG_FE); } // if(USART_GetFlagStatus(USART1, USART_FLAG_PE) != RESET) { USART_ReceiveData(USART1); USART_ClearFlag(USART1, USART_FLAG_PE); } // // if(USART_GetFlagStatus(USART1,USART_FLAG_ORE) != RESET) // { // USART_ReceiveData(USART1); USART_ClearFlag(USART1,USART_FLAG_ORE); // } // if(USART_GetITStatus(USART1, USART_IT_IDLE) != RESET) // { // Clear=USART1->SR; // Clear=USART1->DR; // int IOT_Uart_Rec_Cnt = blen-DMA_GetCurrDataCounter(DMA1_Channel5); //USART2_IRQHandler DMA_Cmd(DMA1_Channel5, DISABLE );//关闭DMA // if(IOT_Uart_Rec_Cnt>0) // { // PushUartMsg1(IOT_Uart_Rec_Cnt); // } // USART_ClearITPendingBit(USART1,USART_IT_IDLE); // DMA_SetCurrDataCounter(DMA1_Channel5,blen);//重新计数 // DMA_Cmd(DMA1_Channel5, ENABLE); // } // } // 串口1的配置代码我也贴一下。 #define buff 10 #define blen 350 typedef struct { char DMA_Buffer[blen]; char RxBuffer[buff][blen]; char read; char write; char cnt; }uart_stack; uart_stack uart1 = {0}; void UART1_init(void)//调试 { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; DMA_InitTypeDef DMA_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_USART1, ENABLE); RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE); USART_DeInit(USART1); //复位串口1 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); USART_InitStructure.USART_BaudRate = 115200; USART_InitStructure.USART_WordLength = USART_WordLength_8b; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; /* Enable the USART1 Interrupt */ NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn ;//todo NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); USART_Init(USART1 , &USART_InitStructure); USART_ITConfig(USART1 , USART_IT_IDLE, ENABLE); USART_ITConfig(USART1, USART_IT_ERR, ENABLE); USART_DMACmd(USART1,USART_DMAReq_Rx,ENABLE); USART_Cmd(USART1 , ENABLE); //DMA配置 DMA_DeInit(DMA1_Channel5); DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)&USART1->DR; DMA_InitStructure.DMA_MemoryBaseAddr = (u32)uart1.DMA_Buffer; DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC; DMA_InitStructure.DMA_BufferSize = blen; DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte; DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte; DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; DMA_InitStructure.DMA_Priority = DMA_Priority_Low; DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; DMA_Init(DMA1_Channel5, &DMA_InitStructure); DMA_Cmd(DMA1_Channel5, ENABLE); } 关于STM32 5个串口初始化,前三个DMA操作,自制队列缓存机制,可以参考。 |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1752 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1611 浏览 1 评论
1052 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
721 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1666 浏览 2 评论
1927浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
712浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
562浏览 3评论
584浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
544浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-19 05:25 , Processed in 0.776928 second(s), Total 76, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号