自定义串口波特率

int UARTAutoBaud(unsigned long *pulRatio){
    long lPulse, lValidPulses,LTEmp, lTotal;
    volatile long lDelay;
    // 配置systICk,将其值设定为最大值;
    HWREG(NVIC_ST_RELOAD) = 0xffffffff;
    HWREG(NVIC_ST_CTRL) = NVIC_ST_CTRL_CLK_SRC| NVIC_ST_CTRL_ENABLE;
    // 打开引脚的边沿触发中断
    HWREG(GPIO_PORTA_BASE + GPIO_O_IBE) = UART_RX;
    // 使能UART RXD引脚边沿触发中断
    HWREG(NVIC_EN0) = 1;
    // 采集引脚边沿中断,两个字节的边沿
    while(g_ulTickIndex < MIN_EDGE_COUNT)
    {}

    // 计算systick采样下来的值,对溢出进行处理
    for(lPulse = 0; lPulse < (MIN_EDGE_COUNT - 1); lPulse++){
        lTemp = (((long)g_pulDataBuffer[lPulse] - (long)g_pulDataBuffer[lPulse + 1]) & 0x00ffffff);
        g_pulDataBuffer[lPulse] = lTemp;
    }
    // 此循环计算两个连续脉冲之间的宽度
    for(lPulse = 0; lPulse < (MIN_EDGE_COUNT - 1); lPulse++){
        // 精确计算两个连续脉冲之间的宽度
        lTemp = (long)g_pulDataBuffer[lPulse];
        lTemp -= (long)g_pulDataBuffer[lPulse + 1];
        if(lTemp < 0) {
            lTemp *= -1;
        }
        // 验证两个边沿的脉宽是否正确,其算法如下:
        // abs(Pulse[n] - Pulse[n + 1]) < Pulse[n + 1] / PULSE_DETECTION_MULT
        // 或者
        // PULSE_DETECTION_MULT * abs(Pulse[n] - Pulse[n + 1]) < Pulse[n + 1]
        if((lTemp * PULSE_DETECTION_MULT) < (long)g_pulDataBuffer[lPulse + 1]) {
            lTotal += (long)g_pulDataBuffer[lPulse];
            lValidPulses++;
        }
        else{
            lValidPulses = 0;
            lTotal = 0;
        }

        // 7个有效脉冲,就可以计算UART串口速率

        if(lValidPulses == 7) {
            // 将最后一个脉冲加入计数器,并计算波特率
            lTotal += (long)g_pulDataBuffer[lPulse];
            *pulRatio = lTotal >> 1;

            // 返回成功标识
            return(0);
        }
    }

    // 检测失败
    return(-1);
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值