搜索
查看: 1352|回复: 4

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

[复制链接]

该用户从未签到

10

主题

36

帖子

2

蝴蝶豆

中级会员

最后登录
2022-9-14
发表于 2020-8-27 10:22:07 | 显示全部楼层 |阅读模式
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)



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

回复

使用道具 举报

该用户从未签到

1

主题

9

帖子

0

蝴蝶豆

新手上路

最后登录
2020-8-28
发表于 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;
                        }
                }               
回复 支持 反对

使用道具 举报

该用户从未签到

10

主题

36

帖子

2

蝴蝶豆

中级会员

最后登录
2022-9-14
 楼主| 发表于 2020-9-3 14:48:00 | 显示全部楼层
明白了,谢谢,就是发最后一个数后,关闭发送完成中断,不让它产生TXE。下次发时再打开。
回复 支持 反对

使用道具 举报

该用户从未签到

10

主题

36

帖子

2

蝴蝶豆

中级会员

最后登录
2022-9-14
 楼主| 发表于 2020-9-3 14:48:50 | 显示全部楼层
TC中断可以操作寄存器直接清,我使用TC中断发送,不用TXE,效果也很好
回复 支持 反对

使用道具 举报

该用户从未签到

3

主题

1306

帖子

929

蝴蝶豆

版主

最后登录
2021-3-31
发表于 2020-9-4 10:06:41 | 显示全部楼层
TC中断是等上一个数据发送完成后才产生,理论上稍稍慢一点,但是不影响串口发送速度,那么用起来也很顺手的
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /3 下一条

Archiver|手机版|小黑屋|论坛-意法半导体STM32/STM8技术社区

GMT+8, 2024-4-28 17:52 , Processed in 1.171338 second(s), 33 queries .

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.

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