你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM8S105K6使用串口中断发送,如何清发送完成中断TXE?

[复制链接]
gaobingquan 提问时间:2020-8-27 10:22 /
STM8S105K6使用串口中断发送,如何清发送完成中断TXE?找了一个例程
INTERRUPT_HANDLER(UART2_TX_IRQHandler, 20){        // 写操作自动清中断,因此可以不用显式清中断      
       UART2_ClearITPendingBit(UART2_IT_TXE);                 
       // 从写缓冲中写出1字节        UART2_SendData8(writ_buffer[writ_idx++]);        
     // 全部写完、关写中断、置写完成标志(同步化处理)      
      if( writ_idx == writ_len ) {                UART2_ITConfig(UART2_IT_TXE, DISABLE);                writ_ok = 1;        }
}
----------------------------------------------------------------------------------------------------------------------------------
这个例程使用UART2_ClearITPendingBit(UART2_IT_TXE); 来清发送完成中断,会导致进入断言while(1)循环void assert_failed(u8* file, u32 line)
查看UART2_ClearITPendingBit函数说明,发现该函数不能请TXE和TC中断,给出的解决方案是UART2_SendData8() or UART2_SendData9(),写数据的方式。单带来的问题是,实际发送数据时,我的最后一个字节发送完了怎么办,没发清中断标志,又无数可发??
----------------------------------------------------------------------------------------------------------------------------------

/**
  * @brief  Clears the UART2 pending flags.
  * @param  UART2_IT specifies the pending bit to clear
  *         This parameter can be one of the following values:
  *         - UART2_IT_LBDF:  LIN Break detection interrupt
  *         - UART2_IT_LHDF:  LIN Header detection interrupt
  *         - UART2_IT_RXNE: Receive Data register not empty interrupt.
  * @note
  *         - PE (Parity error), FE (Framing error), NE (Noise error),
  *           OR (OverRun error) and IDLE (Idle line detected) pending bits are
  *           cleared by software sequence: a read operation to UART2_SR register
  *           (UART2_GetITStatus()) followed by a read operation to UART2_DR register
  *           (UART2_ReceiveData8() or UART2_ReceiveData9()).
  *            
  *         - RXNE pending bit can be also cleared by a read to the UART2_DR
  *           register (UART2_ReceiveData8() or UART2_ReceiveData9()).
  *              
  *         - TC (Transmit complete) pending bit can be cleared by software
  *           sequence: a read operation to UART2_SR register
  *           (UART2_GetITStatus()) followed by a write operation to UART2_DR
  *           register (UART2_SendData8()or UART2_SendData9()).
  *               
  *         - TXE pending bit is cleared only by a write to the UART2_DR register
  *           (UART2_SendData8() or UART2_SendData9()).
  * @retval None
  */
void UART2_ClearITPendingBit(UART2_IT_TypeDef UART2_IT)



-------------------------------------------------------------------------------------------------------------------------------------------

收藏 评论4 发布时间:2020-8-27 10:22

举报

4个回答
kate2005_chen 回答时间:2020-8-27 13:49:19
给一段stm32的发送中断程序,供参考:
                if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET)
                {   
                        /* Write one byte to the transmit data register */
                        USART_SendData(USART1, usart_user_1.send_buff[TxCounter1++]);

                        if(TxCounter1 == usart_user_1.send_num )
                        {
                                /* Disable the USART2 Transmit interrupt */
                                USART_ITConfig(USART1, USART_IT_TXE, DISABLE);
                                TxCounter1 = 0;
                        }
                }               
gaobingquan 回答时间:2020-9-3 14:48:00
明白了,谢谢,就是发最后一个数后,关闭发送完成中断,不让它产生TXE。下次发时再打开。
gaobingquan 回答时间:2020-9-3 14:48:50
TC中断可以操作寄存器直接清,我使用TC中断发送,不用TXE,效果也很好
butterflyspring 回答时间:2020-9-4 10:06:41
TC中断是等上一个数据发送完成后才产生,理论上稍稍慢一点,但是不影响串口发送速度,那么用起来也很顺手的
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版