0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【玩转多核异构】双核高速率CAN-FD评测——飞凌嵌入式

飞凌嵌入式 2023-02-17 11:34 次阅读

为了能够让更多的工程师朋友了解多核异构处理器飞凌嵌入式特别推出了【玩转多核异构】专题,帮助大家解决在多核异构处理器的开发过程中遇到的问题。【玩转多核异构】专题持续更新中,欢迎您的持续关注。

引言

凭借实时性、抗干扰性和安全性等优点,CAN2.0在工业及汽车行业得到了广泛应用,但其最高速率仅为1Mbit/s,每帧最多只能传输8字节的有效数据,报文中只有约50%的带宽用于有效数据传输。然而随着产业的发展,各种传感器控制器数量的增多,总线上的数据量也激增,这使得CAN2.0总线在传输速率和带宽方面的缺点暴露的更加明显,于是就诞生了CAN-FD。

CAN-FD在传输速率和带宽方面有了明显的提升,波特率可高达8Mbit/s,每帧可多达64字节有效数据,传输效率可提高至约80%,能够进一步提高总线的实时性,拓宽总线的数据带宽,提升总线的传输效率。

在飞凌嵌入式OKMX8MP-C开发板上有两路CAN-FD,小编今天就基于这款开发板以处理器的M核与A核各控制一路CAN-FD互相通信为例,从应用角度讲述M核和A核如何控制CAN-FD高速通信。

21d8671f54b8429ead9027e1b9f98bfb~noop.image?_iz=58558&from=article.pc_detail&x-expires=1677205373&x-signature=OtReypJ9%2BnJEL0stxADkVCq5%2F6Q%3DOKMX8MP-C开发板

飞凌嵌入式OKMX8MP-C开发板所搭载的NXP i.MX8M Plus处理器具备强悍的性能,集成4个主频最高可达1.8GHz(工业级主频为1.6GHz)Arm Cortex-A53多任务核和1个Cortex-M7实时核,不管是对数据的高速吞吐、处理,还是复杂的人机交互界面处理,都能从容应对。

一、M核CAN-FD

1. CAN-FD初始化

CAN-FD初始化主要包括总线时钟,管脚和相应寄存器的初始化。具体如下:

(1)CAN总线时钟:

现将CAN总线倍频到800MHz,再10分频到80MHz。

CLOCK_SetRootMux(kCLOCK_RootFlexCan1, kCLOCK_FlexCanRootmuxSysPll1); // 设置CAN1总线时钟为800MHz CLOCK_SetRootDivider(kCLOCK_RootFlexCan1, 2U, 5U); // 分频因子为2*5=10,设置CAN1总线时钟为80MHz

(2)管脚配置:

选择CAN1的发送管脚为32脚,接收管脚为34脚。

IOMUXC_SetPinMux(IOMUXC_SAI2_TXC_CAN1_RX, 0U); // CAN1 RX IOMUXC_SetPinMux(IOMUXC_SAI2_RXC_CAN1_TX, 0U); // CAN1 TX

(3)CAN波特率:

CAN-FD支持可变速率,即控制区和数据区的波特率可以不一致,控制区最大为1Mbit/s;数据区最大为8Mbit/s。后续程序根据总线时钟和设置的波特率,分配时段设置的seg1,seg2等数值。

pConfig->bitRate = 1000000U; // CAN-FD控制区波特率为1Mbit/s pConfig->bitRateFD = 8000000U; // CAN-FD数据区波特率为8Mbit/s

(4)CAN-FD使能:

除了使能CAN-FD,可变波特率也需要使能,否则数据区的最大速率和控制区的速率一样,最大为1Mbit/s。

base->MCR |= CAN_MCR_FDEN_MASK; // CAN-FD使能 fdctrl |= CAN_FDCTRL_FDRATE_MASK; // 可变波特率使能

(5)关闭自回环:

如果开启了自回环,那么CAN1数据会在芯片内回环,不会到外部管脚,在程序调试时可以排除外部端子的干扰,但真实应用时,需要关闭自回环,从外部管脚收发数据。

pConfig->enableLoopBack = false; // 不回环,使用外部管脚

(6)帧格式:

本次我们使用11位标准数据帧,小伙伴也在后续试试扩展帧。需要设置自己的ID,便于总线上其他设备识别。

mbConfig.format = kFLEXCAN_FrameFormatStandard; // 11位标准帧,非扩展帧 mbConfig.type = kFLEXCAN_FrameTypeData; // 数据帧 非远程帧 mbConfig.id = FLEXCAN_ID_STD(rxIdentifier); // 帧ID 用于区别总线中不同的设备

(7)接收过滤:

用户可设置接收过滤规则,这样就可以只接收特定帧ID的数据,减少应用处理的数据量。

rxIdentifier = 0; FLEXCAN_SetRxMbGlobalMask(EXAMPLE_CAN, FLEXCAN_RX_MB_STD_MASK(rxIdentifier, 0, 0));//接收所有ID数据

2. CAN-FD收发流程

本次测试M核做主站,CAN1先发送一帧包含64字节数据,A核CAN2收到,将64字节数据再次发送,M核CAN1接收。对比发送和接收的64字节数据是否一致。重复100次。

(1)CAN-FD发送数据:

EXAMPLE_CAN表示为CAN1,flexcanHandle为CAN实例,包含了发送接收回调函数,txXfer为要发送的64字节数据。

FLEXCAN_TransferFDSendNonBlocking(EXAMPLE_CAN, &flexcanHandle, &txXfer); // CAN-FD发送数据

(2)CAN-FD接收数据:

EXAMPLE_CAN表示为CAN1,flexcanHandle为CAN实例,包含了发送接收回调函数,rxXfer为接收的64字节数据。

FLEXCAN_TransferFDReceiveNonBlocking(EXAMPLE_CAN, &flexcanHandle, &rxXfer); // CAN-FD接收函数

(3)接收和发送数据对比:

for (j = 0U; j <= DLC; j++) // 对比收发数据,不一致打印 { if(txXfer.framefd->dataWord[j] != rxXfer.framefd->dataWord[j]) { LOG_INFO("Data mismatch !!! j=%d \r\n",j); } }

二、A核CAN-FD

A核设备树中保留CAN2,内核解析设备树在 /dev下生成can0。设置波特率后使能can0节点,应用程序中open函数打开接口,write函数发送数据,read函数接收数据。我们把CAN接口的示例已经作为一个跨平台的综合演示程序,小伙伴们可以直接加参数调用即可。

1. 分配节点

(1)M核独享CAN1,A核独享CAN2,修改设备树,在设备树OK8MP-C.dts中,删除CAN1设备节点,保留CAN2设备节点。编译新的设备树;

(2)将生成的OK8MP-C.dtbImage拷贝至开发板的 /run/media/mmcblk2p1/ 目录下,输入sync命令同步后重启开发板;

(3)通过A核串口输入命令uname -r ,显示内核版本,将 /lib/modbule目录下文件夹名称改为内核版本,这样才能自动加载模块生成can0节点,重启开发板。

5d2ed7af2ef241c49beef4ea049076a8~noop.image?_iz=58558&from=article.pc_detail&x-expires=1677205373&x-signature=SArW66WModoKg%2BRk6p3nwhjN2pE%3D

8360162841014592bab234e939d8dd8f~noop.image?_iz=58558&from=article.pc_detail&x-expires=1677205373&x-signature=FqLPD04wWmvLm9evJbJ4JYJll%2FM%3D

2. 演示Demo

进程名can_demo

使用方法:./can_demo设备名 [参数选项]… …

6fcdcabf67c64fb287ea2f341e4c86c2~noop.image?_iz=58558&from=article.pc_detail&x-expires=1677205373&x-signature=SktElvA9upyInbY9dcQ9Y8SoA9g%3D

本次测试接口为can0(对应开发板CAN2),控制区波特率为1Mbit/s,数据区最大为8Mbit/s,11位标准帧,不过滤帧ID,不主动发数据,不回环。因此命令为:

./can_demo can0-b 1000 -fd 8000。

三、程序验证

1. 硬件连接

使用杜邦线将CAN1和CAN2的can-H短接,同时将can-L短接,注意不要接反。

4285243ec7dc41e699c1e1702d7d6c5c~noop.image?_iz=58558&from=article.pc_detail&x-expires=1677205373&x-signature=2P7wbWUXTkaG10Uo86fxItMMWb8%3D

2. M核程序

修改uboot环境变量设置M核自启动,同时将M核程序forlinx_m7_tcm_firmware.bin;

放到/run/media/mmcblk2p1/目录下。详细操作可看上篇文章【玩转多核异构】M核程序的启动、编写和仿真——飞凌嵌入式。

3. A核程序

(1)使用串口Xmodem,网络FTP,SCP,U盘,TF卡等多种方式,将can_demo从电脑拷贝至核心板默认目录下,输入以下命令修改权限;

chmod 777 can_demo

(2)输入以下命令,A核应用程序can_demo将设置波特率后打开can0节点,等待M核发送的数据,再将接收的数据通过CAN2发送给M核。

./can_demo can0 -b 1000 -fd 8000

4. 实际测试

(1)OKMX8MP-C开发板重新上电后,M核程序启动,完成CAN1初始化后,在M核调试串口输出信息,等待按键;

(2)在A核调试串口输入以下命令,CAN2将处于接收的状态:

./can_demo can0 -b 1000 -fd 8000

(3)在M核串口按下键A或a,M核CAN1发送64字节数据,A核CAN2接收数据,并将接收的数据再次发送,M核CAN1接收后和发送数据对比,输出结果。循环100次;

(4)通过测试可以看到,依托i.MX8M Plus强大的性能,双核都以8Mbit/s的高速率发送大量数据,均没有出现异常。

以上就是小编为小伙伴带来的基于飞凌嵌入式OKMX8MP-C开发板双核控制CAN-FD的使用方法了,是不是感觉性能很强大呢?

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    4983

    文章

    18295

    浏览量

    288597
  • 通信
    +关注

    关注

    18

    文章

    5706

    浏览量

    134415
  • 开发板
    +关注

    关注

    25

    文章

    4437

    浏览量

    94084
  • 多核异构
    +关注

    关注

    0

    文章

    13

    浏览量

    5422
  • CANFD
    +关注

    关注

    0

    文章

    43

    浏览量

    4803
收藏 人收藏

    评论

    相关推荐

    回顾,嵌入式的第89届中国国际医疗器械博览会 (CMEF)之行

    嵌入式
    飞凌嵌入式
    发布于 :2024年04月26日 16:10:58

    Embedded World2024,嵌入式参展回顾#嵌入式

    行业资讯嵌入式
    飞凌嵌入式
    发布于 :2024年04月22日 15:51:28

    嵌入式 | CACLP 2024回顾

    嵌入式
    飞凌嵌入式
    发布于 :2024年03月22日 17:05:30

    如何使用DSLogic分析CAN/CAN-FD 信号?

    一文档介绍本文将一步步介绍如何使用DSLogic逻辑分析仪采集并分析CAN/CAN-FD信号,因为CAN信号的测量和CAN-FD的大致一样,所以下文以
    的头像 发表于 01-08 14:54 290次阅读
    如何使用DSLogic分析<b class='flag-5'>CAN</b>/<b class='flag-5'>CAN-FD</b> 信号?

    can和canfd的区别

    设计的时候,数据传输速率较低,最高只有1 Mbps。然而,CAN-FD通过增加负载大小并改进码率,大大提高了数据传输速度。CAN-FD支持的最高传输速率可达
    的头像 发表于 12-07 15:37 2439次阅读

    CAN收发器的正确系统级测试方法

    传统CANCAN-FD之间的主要区别在于灵活数据(FD)。在CAN-FD中,数据速率(即每秒传输的位数)比经典
    发表于 09-16 16:56 1049次阅读
    <b class='flag-5'>CAN</b>收发器的正确系统级测试方法

    应用指南—如何使用DSLogic分析CAN/CAN-FD信号?

    应用指南—如何使用DSLogic分析CAN/CAN-FD 信号?
    的头像 发表于 09-04 14:15 1205次阅读
    应用指南—如何使用DSLogic分析<b class='flag-5'>CAN</b>/<b class='flag-5'>CAN-FD</b>信号?

    专用R5F+A53,异构多核AM64x让工控“更实时”

    Cortex-R5F + Cortex-A53异构多核, 给工控带来何种意义? 创龙科技SOM-TL64x工业核心板搭载TI AM64x最新工业处理器,因其CortexR5F +
    发表于 08-23 15:34

    最适合CAN FD的共模滤波器

    振铃影响的CAN-FD应用进行了优化的产品。 关于振铃 振铃产生原因 最适合CAN FD的共模滤波器 支持CAN FD的CMC ACT121
    的头像 发表于 08-22 11:37 1547次阅读
    最适合<b class='flag-5'>CAN</b> <b class='flag-5'>FD</b>的共模滤波器

    嵌入式国产平台大盘点之瑞芯微系列

    “国产化”一词正在被越来越多的提及,有着越来越高的关注度,嵌入式也已与多家国内芯片原厂联合推出了数款国产化智能平台。为了帮助大家快速认识
    发表于 08-05 11:12

    CAN-FD协议有哪些车用

    以某车型为例,该项目已对CAN-FD网络进行了量产化应用,该项目基于电子电气功能架构搭建了集合多种车载网络协议的网络架构,集信息域、互联域、自动驾驶域、底盘动力域的多域融合的一汽新一代整车网络架构
    的头像 发表于 07-18 11:25 1049次阅读
    <b class='flag-5'>CAN-FD</b>协议有哪些车用

    航顺芯片提供ARM+RISC-V异构多核MCU

    航顺芯片作为IAR System合作伙伴,提供了ARM+RISC-V异构多核MCU硬件平台。“嵌入式多核系统可分为同构多核
    发表于 06-20 12:48 341次阅读
    航顺芯片提供ARM+RISC-V<b class='flag-5'>异构</b><b class='flag-5'>多核</b>MCU

    中国首颗ARM+RISC-V异构多核MCU伴随IAR在上海国际嵌入式展亮相

    ARM+RISC-V异构多核MCU硬件平台。“嵌入式多核系统可分为同构多核异构
    发表于 06-15 18:32

    专用M4F+四A53,异构多核AM62x让工业控制“更实时、更安全”

    的Cortex-M4F还能够引出丰富的接口资源,包括2个 8Mbps CAN-FD、2个SPI、UART、I2C、GPIO,满足各种有实时性要求的外设接入。 图2 Cortex-M4F引出
    发表于 06-15 17:18

    嵌入式受邀参加能源电子产业政策华北片区宣贯会

    、保定等一批特色产业聚集区,能源电子产业主营收入突破1500亿元。 ​ 编辑切换为居中 保定嵌入式技术有限公司(以下简称:
    发表于 05-11 15:33