STM32 CANFD波特率计算器

C代码定义:

typedef struct _DataRate
{
    uint32_t DataRate;
    uint32_t DataPrescaler; /*!< Specifies the value by which the oscillator frequency is
                                              divided for generating the data bit time quanta.
                                              This parameter must be a number between 1 and 32             */

    uint32_t DataSyncJumpWidth; /*!< Specifies the maximum number of time quanta the FDCAN
                                              hardware is allowed to lengthen or shorten a data bit to
                                              perform resynchronization.
                                              This parameter must be a number between 1 and 16             */

    uint32_t DataTimeSeg1; /*!< Specifies the number of time quanta in Data Bit Segment 1.
                                              This parameter must be a number between 1 and 32             */

    uint32_t DataTimeSeg2; /*!< Specifies the number of time quanta in Data Bit Segment 2.
                                              This parameter must be a number between 1 and 16             */
} DataRate_t;


const DataRate_t DataRateMaps[] =//从上位机那边复制过来
{
            { 125000,12,8,69,10 }, //125KBps:prescaler:12,clk:10Mhz,ts1:69,ts2:10,samplePoint:87.50%
        { 250000,6,8,69,10 }, //250KBps:prescaler:6,clk:20Mhz,ts1:69,ts2:10,samplePoint:87.50%
        { 500000,10,8,20,3 }, //500KBps:prescaler:10,clk:12Mhz,ts1:20,ts2:3,samplePoint:87.50%
        { 1000000,5,8,20,3 }, //1000KBps:prescaler:5,clk:24Mhz,ts1:20,ts2:3,samplePoint:87.50%
        { 2000000,1,8,51,8 }, //2000KBps:prescaler:1,clk:120Mhz,ts1:51,ts2:8,samplePoint:86.67%
        { 3000000,1,8,34,5 }, //3000KBps:prescaler:1,clk:120Mhz,ts1:34,ts2:5,samplePoint:87.50%
        { 4000000,1,8,25,4 }, //4000KBps:prescaler:1,clk:120Mhz,ts1:25,ts2:4,samplePoint:86.67%
        { 5000000,1,8,20,3 }, //5000KBps:prescaler:1,clk:120Mhz,ts1:20,ts2:3,samplePoint:87.50%
        { 6000000,1,8,16,3 }, //6000KBps:prescaler:1,clk:120Mhz,ts1:16,ts2:3,samplePoint:85.00%
        { 8000000,1,8,12,2 }, //8000KBps:prescaler:1,clk:120Mhz,ts1:12,ts2:2,samplePoint:86.67%
};

上位机计算波特率的代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CanSamplePointCal
{
    class Fuck_Autosar
    {
        static void Main(string[] args)
        {
            int busclk = 120 * 1000 * 1000;//外设总线频率
            int prescaler_min = 1, prescaler_max = 512, prescaler = prescaler_min;

            int sjw_min = 1, sjw_max = 128, sjw = sjw_min;
            int ts1_min = 2, ts1_max = 256, ts1 = ts1_min;
            int ts2_min = 2, ts2_max = 128, ts2 = ts2_min;
            double samplePoint_min = 60.0 / 100.0d, samplePoint_max = 87.5 / 100.0d;//采样点设置
            int NominalSyncJumpWidth = 8;
            int need_can_baudrate = 500* 1000;
            
            for (prescaler = prescaler_min; prescaler <= prescaler_max; prescaler++)
            {
                if ((busclk % prescaler) != 0)
                    continue;
                for (sjw = sjw_min; sjw <= sjw_max; sjw++)
                {
                    for (ts1 = ts1_min; ts1 <= ts1_max; ts1++)
                    {
                        for (ts2 = ts2_min; ts2 <= ts2_max; ts2++)
                        {
                            
                            var clk = busclk / prescaler;

                            if ((clk % (1 + ts1 + ts2)) != 0)
                                continue;
                            var br = clk / (1 + ts1 + ts2);

                            var sp = (1.0d + ts1) / (1.0d + ts1 + ts2);
                            if (
                                (br == need_can_baudrate)
                                && (sp >= samplePoint_min)
                                    && (sp <= samplePoint_max)
                                    )
                            {
                                string clkstr = clk >= (1000 * 1000) ? $"{clk / (1000 * 1000d)}Mhz" : $"{clk / 1000d}Khz";
                                string code = $"{{ {br},{prescaler},{NominalSyncJumpWidth},{ts1},{ts2} }},";
                                Console.WriteLine($"{code} //{need_can_baudrate / 1000}KBps:prescaler:{prescaler},clk:{clkstr},ts1:{ts1},ts2:{ts2},samplePoint:{sp:P}");
                            }
                        }
                    }
                }
            }
            
            Console.WriteLine("End!");
            Console.ReadLine();

        }
    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: stm32can波特率计算器是一款用于计算CAN总线的波特率的工具。它基于ST公司生产的STM32微控制器开发,并且具有精准和可靠的特点,在CAN总线应用领域有着广泛的应用。 在使用stm32can波特率计算器时,首先需要选择使用的STM32系列型号,然后输入所配置的系统时钟频率、预分频系数、时间段1和时间段2的长度,即可计算出相应的波特率。同时,该计算器还能够对所配置的参数进行校验,确保所计算的波特率符合CAN总线的要求。 使用stm32can波特率计算器可以有效地提高CAN总线的稳定性和可靠性,避免因波特率不匹配而导致的通信故障。此外,由于该工具基于STM32微控制器开发,因此它还具有其他扩展功能,例如可以集成到用户的应用程序中,实现更灵活的应用需求。 总之,stm32can波特率计算器是一款非常实用的工具,为CAN总线的应用开发提供了便利和安全的保证。 ### 回答2: STM32CAN波特率计算器是一款方便的工具,可以帮助开发人员计算CAN总线上通信速率的工具。在CAN总线应用中,波特率是非常重要的,对于CAN总线的性能和通信质量都有很大的影响。使用这个工具可以方便地计算出适合具体应用的波特率。 在使用该工具前,需要输入自己所使用的晶振频率和波特率,才能计算出CAN消息的帧率。可以根据用户输入的数据自动计算并显示需要的寄存器的值,以便用户可以直接用于CAN总线通信。因此,该工具不仅可以节省开发人员的时间,同时也可以极大地减少快速原型设计中的错误。 总体来说,STM32CAN波特率计算器是一个十分实用的工具,在进行CAN通信开发中起到了非常重要的作用。通过使用该工具,可以方便简单地计算出正确的波特率,从而实现更高效的CAN总线通信,提高开发效率和产品质量。 ### 回答3: STM32CAN波特率计算器是一种基于STMicroelectronics公司的STM32单片机的工具,用于计算CAN总线通信的波特率。在CAN总线通信中,波特率是指设定的数据传输速率,通常用位每秒(bps)或千位每秒(kbps)表示。波特率的正确设置对CAN总线通信的可靠性和稳定性至关重要。 STM32CAN波特率计算器可以帮助用户准确计算CAN总线通信的波特率,并提供一些实用的功能。用户只需输入所需的波特率、时钟频率等参数,工具即可自动计算出满足要求的最佳参数设置。此外,工具还可以根据所选的芯片型号和CAN总线标准自动生成预设参数,方便用户快速进行参数配置。 STM32CAN波特率计算器还具有一些高级功能,例如位定时计算、采样点计算等。这些功能可以帮助用户更精确地调整CAN总线通信的参数,以满足不同的应用需求。此外,工具还可以生成详细的报告,包括波特率计算结果、设置参数和建议等信息,方便用户参考和保存记录。 总之,STM32CAN波特率计算器是一种功能强大、易于使用的工具,可以帮助用户轻松计算CAN总线通信的波特率,并提供一些实用的功能和报告。无论是初学者还是专业领域的专家,都可以从中得到帮助和提高。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值