CAN/CAN FD性能测试
测试环境
- STM32H750VB 480MHz
- FDCAN1 连接到 FDCAN2
- FDCAN1/FDCAN2 接收回调中直接转发
- 每秒统计回调中接收到的包数量
- 仲裁段配置为1Mbps,FD数据段配置为2.5Mbps
测试代码
STDIO::write_ = uart_cdc.write_port_;
constexpr uint32_t PACK_ID = 0x123;
constexpr CAN::Type PACK_TYPE = CAN::Type::STANDARD;
constexpr uint32_t PACK_NUM = 8;
static volatile uint32_t counter = 0, speed = 0;
void (*can_func)(bool, LibXR::STM32CANFD *, const CAN::ClassicPack &) =
[](bool, LibXR::STM32CANFD *can, const CAN::ClassicPack &pack)
{
can->AddMessage(pack);
counter++;
};
auto cb_can1 = CAN::Callback::Create(can_func, &fdcan1);
fdcan1.Register(cb_can1, PACK_TYPE);
auto cb_can2 = CAN::Callback::Create(can_func, &fdcan2);
fdcan2.Register(cb_can2, PACK_TYPE);
LibXR::CAN::ClassicPack pack;
pack.id = PACK_ID;
pack.type = PACK_TYPE;
for (uint32_t i = 0; i < PACK_NUM; i++)
{
fdcan1.AddMessage(pack);
}
while (true)
{
Thread::Sleep(1000);
speed = counter;
counter = 0;
XR_LOG_DEBUG("speed: %d", speed);
}
测试结果
负载按5%位填充计算
标准帧 8字节数据
8917包/s,每包108位,数据段的速率为0.57Mbps,平均总线负载接近100%
理想情况下,数据段的速率位64 / 108 * 1Mbps / 105% = 0.564Mbps
拓展帧 8字节数据
7401包/s,每包128位,数据段的速率为0.47Mbps,平均总线负载接近100%