FreeModbus中定时器周期usTimerT35_50us的计算方式

usTimerT35_50us

        /* If baudrate > 19200 then we should use the fixed timer values
         * t35 = 1750us. Otherwise t35 must be 3.5 times the character time.
         */
        if( ulBaudRate > 19200 )
        {
            usTimerT35_50us = 35;       /* 1800us. */
        }
        else
        {
            /* The timer reload value for a character is given by:
             *
             * ChTimeValue = Ticks_per_1s / ( Baudrate / 11 )
             *             = 11 * Ticks_per_1s / Baudrate
             *             = 220000 / Baudrate
             * The reload for t3.5 is 1.5 times this value and similary
             * for t3.5.
             */
            usTimerT35_50us = ( 7UL * 220000UL ) / ( 2UL * ulBaudRate );
        }
        if( xMBPortTimersInit( ( USHORT ) usTimerT35_50us ) != TRUE )
        {
            eStatus = MB_EPORTERR;
        }

计算方法

  1. usTimerT35_50us:50us的倍数,定时器的传入参数,假设设定为40,那么定时器的定时周期即为40*50us=2ms,所以定时器初始化部分需要提前设计好定时周期为50us*传入参数
  2. 波特率大于19200,那么定时器周期固定为1750us = 35*50us
  3. 波特率小于等于19200时
  4. 11 = 1起始位+8数据位+1奇偶校验位+1停止位
  5. 1个字节传送所需时间,charTime=(11*1000/baudRate)ms
  6. 假设波特率为19200,charTime=11*1000/19200=0.57ms
  7. 3.5个字符需要的时间,3.5*charTime=2ms
  8. 即定时器周期需要设定为2ms,传入参数即为usTimerT35_50us=2ms/50us=40
  9. FreeModubs作者变种出一个巧妙的公式
  10. usTimerT35_50us = (7UL * 220000UL ) / (2UL * ulBaudRate )
  11. 检验公式,ulBaudRate 代入19200
  12. 可得usTimerT35_50us = 40
  13. Bingo
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在GD32上使用FreeModbus库,需要配置一个定时器来驱动Modbus协议栈。以下是配置步骤: 1. 确定使用哪个定时器。可以使用任何一个定时器,但建议使用高级定时器,因为它们具有更好的精度和灵活性。 2. 在启用定时器之前,需要先启用相应的时钟。例如,如果使用定时器2,则需要启用定时器2的时钟: ``` RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); ``` 3. 配置定时器的基本参数,例如时钟频率、预分频器、计数器模式等。以下是一个示例代码: ``` TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_TimeBaseStructure.TIM_Period = 1000; //周期为1ms TIM_TimeBaseStructure.TIM_Prescaler = 72; //预分频器为72(时钟频率为72MHz) TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseStructure.TIM_RepetitionCounter = 0; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); ``` 4. 启用定时器断。在Modbus,需要使用定时器断来触发Modbus协议堆栈的轮询。以下是一个示例代码: ``` NVIC_InitTypeDef NVIC_InitStructure; NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; //定时器2断 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); //启用定时器2更新断 ``` 5. 在定时器断处理程序调用Modbus协议堆栈的轮询函数。以下是一个示例代码: ``` void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { TIM_ClearITPendingBit(TIM2, TIM_IT_Update); //调用Modbus协议堆栈的轮询函数 eMBPoll(); } } ``` 6. 最后,在main函数启动定时器。以下是一个示例代码: ``` TIM_Cmd(TIM2, ENABLE); ``` 这样就完成了定时器的配置,Modbus协议堆栈现在应该能够正常工作了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七七云享

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值