之前遇到奇怪的問題:
串口中斷處理函數(shù)中加了溢出中斷處理:
if(USART_GetITStatus(USART1,USART_IT_ORE) != RESET) //產(chǎn)生溢出中斷
{
Utemp = USART_ReceiveData(USART1); //扔掉接收的數(shù)據(jù)
USART_ClearITPendingBit(USART1, USART_IT_ORE); //清溢出中斷標(biāo)志位
}
參考手冊ISR寄存器:
位 3 ORE: 溢出錯誤
在RXNE=1 的的條件下(也就是上次數(shù)據(jù)還沒有讀走),串口接收寄存器又接收好
了一個字節(jié)的數(shù)據(jù)并準備往RDR 寄存器去轉(zhuǎn)移的時候,會由硬件將這個位置1。
由軟件向USART_ICR 寄存器的ORECF 位寫1,可以清除這個標(biāo)志。
如果USART_CR1 寄存器中的RXNEIE 位或EIE 位是1,就會產(chǎn)生中斷請求。
0: 沒有溢出錯誤
1: 檢測到溢出錯誤
CR1中的RXNEIE已經(jīng)使能,實際溢出發(fā)生時keil中觀察ORE的確被置位為1。
然鵝,,,,,,,,
就算ORE置位為1,這個if語句也不通過。。。。。
后來網(wǎng)上找到這句話:
“ORE中斷只能使用USART_GetFlagStatus(USART1, USART_FLAG_ORE) 讀到(沒有使能USART_IT_ERR中斷時)”
驚奇的發(fā)現(xiàn)還有USART_GetFlagStatus可以用!
USART_GetITStatus(USART1,USART_IT_ORE)這個函數(shù)在USART_IT_ERR未使能時并不能正確ORE的正確狀態(tài)!!!!!!
可以使用USART_GetFlagStatus(USART1,USART_FLAG_ORE)讀取,或者初始化時使能USART_IT_ERR。關(guān)于USART_IT_ERR在庫函數(shù)中的定義:
(##) USART_IT_ERR: specifies the interrupt source for Error interrupt (Frame error, noise error, overrun error)
補充一下這倆函數(shù)的區(qū)別(看庫函數(shù)更直接):
IT主要就是與中斷相關(guān)的,檢查USART中斷產(chǎn)生與否,當(dāng)USART發(fā)送完成后會有USART_IT_TC中斷,因此可以用來判斷,而USART_GetFlagStatus是USART標(biāo)志位設(shè)置與否,其中就有發(fā)送完成標(biāo)志位USART_Flag_TC所以也可用來判斷。而最終都是操作ISR寄存器