CH573 串口发送和接收中断

UART1_ByteTrigCfg(UART_1BYTE_TRIG);

UART1_INTCfg(ENABLE,RB_IER_RECV_RDY);

UART1_INTCfg(ENABLE,RB_IER_THR_EMPTY);

PFIC_EnableIRQ(UART1_IRQn);


串口如上配置,死活发送和接收中断都进不了,例子里面全是查询方式和阻塞发送不实用啊。   

    /* 配置串口1:先配置IO口模式,再配置串口 */
    GPIOA_SetBits(GPIO_Pin_9);
    GPIOA_ModeCfg(GPIO_Pin_8, GPIO_ModeIN_PU);      // RXD-配置上拉输入
    GPIOA_ModeCfg(GPIO_Pin_9, GPIO_ModeOut_PP_5mA); // TXD-配置推挽输出,注意先让IO口输出高电平
    UART1_DefInit();


    UART1_ByteTrigCfg(UART_7BYTE_TRIG);
    trigB = 7;
    UART1_INTCfg(ENABLE, RB_IER_RECV_RDY | RB_IER_LINE_STAT);
    PFIC_EnableIRQ(UART1_IRQn);


__attribute__((interrupt("WCH-Interrupt-fast")))
__attribute__((section(".highcode")))
void UART1_IRQHandler(void)
{
    volatile uint8_t i;

    switch(UART1_GetITFlag())
    {
        case UART_II_LINE_STAT: // 线路状态错误
        {
            UART1_GetLinSTA();
            break;
        }

        case UART_II_RECV_RDY: // 数据达到设置触发点
            for(i = 0; i != trigB; i++)
            {
                RxBuff[i] = UART1_RecvByte();
                UART1_SendByte(RxBuff[i]);
            }
            break;

        case UART_II_RECV_TOUT: // 接收超时,暂时一帧数据接收完成
            i = UART1_RecvString(RxBuff);
            UART1_SendString(RxBuff, i);
            break;

        case UART_II_THR_EMPTY: // 发送缓存区空,可继续发送
            break;

        case UART_II_MODEM_CHG: // 只支持串口0
            break;

        default:
            break;
    }
}


请问解决了吗,我现在也被堵塞住了



CH573是提供了串口例程参考的,可以直接使用进行验证。

如使用默认程序出现问题,可具体描述一下,我们这里会进行检查。

image.png


你好,我想做不带缓存配置的发送和接收,有案例吗


https://www.wch.cn/bbs/thread-93591-1.html

见上。


只有登录才能回复,可以选择微信账号登录