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

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

3天内不再提示

芯教程丨平头哥助力昊芯HX2000系列芯片CAN网络通信

中科昊芯 2022-09-19 10:20 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

随着能源日益短缺,科技的日趋智能化,复杂高效的多机控制,已日趋成为当今社会迅速发展的必然需求。昊芯顺应时代要求,推出适用于高精度工业自动化运动控制的新版HXS320F28034数字信号处理器DSP,其CAN模块以Mailbox信箱MBOXn控制与传输数据,实现DSP之间的控制指令高效收发,可更有效助力于工程师实现高效的多DSP控制指令收发,广泛应用于电动汽车、风力发电、轨道交通、机器人等高复杂度控制领域。

e675d328-35dd-11ed-9ade-dac502259ad0.png

自平头哥半导体有限公司的剑池集成开发环境(简称“CDK”)支持HX2000系列芯片调试以来,本期以USB_CAN通信收发实例讲解CAN网络通信功能。

HX2000系列CAN模块原理如下图,通过CANMC[CCR]使能进入初始化配置模式,等待CANMC[CCE]置高写入CANBTC位配置波特率;等待CANMC[CCE]拉低,完成初始化;

通过Mailbox邮箱MBOXn.MSGCTRL的RTR位配置远程传输请求,TPL位配置MBOXn传输优先级,DLC位配置传输0~8个字节,传输过程如下:

1.CAN总线通过CAN传输芯片向CAN发送数据,使能CANRIOC[RXFUNC]打开接收线,接收来自GPIOMUX所定义CANRX接收引脚上的数据,装载到缓冲区Receive Buffer;

2.通过CANMD[MDn]配置Mailbox邮箱MBOXn为接收,使能CANME[MEn]打开邮箱MBOXn,接收来自缓冲区中的数据;

3.全局中断标志的设置取决于CANGIM寄存器中GIL位的设置。如果设置了该位,则全局中断在CANGIF1寄存器中设置位;否则,在CANGIF0寄存器中设置。通过CANMIM[MIMn]配置接收掩码中断使能;通过CANMIL[MILn]配置,将MBOXn接收中断,映射到中断ECAN0INTA或ECAN1INTA;使能CANGIM[I0EN/I1EN]打开中断信号,MBOXn接收到数据时,将产生一个接收中断,使CANGIF0/1[MIV0/1]中相应接收邮箱MBOXn的邮箱号置位;通过PIE响应CPU执行接收中断程序:

(1)置位CANRMP[RMPn]挂起MBOXn邮箱,以防止瞬间接收到多组数据;

(2)通过CANGIF0/1[MIV0/1],确认接收到数据邮箱为MBOXn,并读取接收的数据;

(3)置位CANRMP[RMPn]清除邮箱MBOXn挂起状态,准备接收下一组数据。

e6a6ec88-35dd-11ed-9ade-dac502259ad0.jpg

e6c4780c-35dd-11ed-9ade-dac502259ad0.jpg

4.通过CANMD[MDn]配置另一Mailbox邮箱MBOXn为发送,使能CANME[MEn]打开发送邮箱,使能CANTRS[TRSn]启动发送邮箱,发送数据到缓冲区 Transmit Buffer;

5.使能CANTIOC[TXFUNC]打开发送线,通过GPIOMUX所定义CANTX发送引脚将缓冲区Transmit Buffer数据发送到CAN总线。

由此设计通过USB_CAN分析仪将昊芯HXS320F28034芯片与上位机软件通讯实例:采用昊芯HXS320F28034芯片、CAN收发器与USB_CAN分析仪,通过USB_CAN网络调试上位机软件,向CPU发送任意一组数据,CPU接收所发送的数据,硬件连接如下图所示:

e6ed3e04-35dd-11ed-9ade-dac502259ad0.jpg

基于以上分析,在CDK上开发CAN通信程序,代码包括:CAN的GPIO配置、初始化参数配置、CAN发送程序与接收中断服务程序,主程序调用执行。主要代码如下:

1.intmain(void)
2.{
3.InitSysCtrl();//系统时钟初始化
4.CAN_Init();//CAN的初始化参数配置
5.InitECanaGpio();//CAN的Gpio引脚配置
6.EALLOW;
7.ECanaRegs.CANMIM.bit.MIM0=1;//打开接收掩码,接收到数据触发中断
8.ECanaRegs.CANMIL.bit.MIL0=0;//选择EcanA中断0
9.ECanaRegs.CANGIM.bit.I0EN=1;//使能中断0
10.PieVectTable.ECAN0INTA=&eCanRxIsr;//CANA0接收中断入口
11.EDIS;
12.PieCtrlRegs.PIEIER9.bit.INTx5=1;//使能ECAN1中断
13.IER|=M_INT9;//EnableCPUINT9
14.EINT;
15.while(1){
16.CAN_Tx();//发送数据
17.}
18.return0;
19.}

其中,CAN的初始化参数配置代码为:

1.voidCAN_Init()
2.{
3.volatilestructECAN_REGSECanaShadow;
4.EALLOW;
5./*配置RX与TX引脚*/
6.ECanaShadow.CANTIOC.all=P_ECanaRegs->CANTIOC.all;
7.ECanaShadow.CANTIOC.bit.TXFUNC=1;
8.P_ECanaRegs->CANTIOC.all=ECanaShadow.CANTIOC.all;
9.ECanaShadow.CANRIOC.all=P_ECanaRegs->CANRIOC.all;
10.ECanaShadow.CANRIOC.bit.RXFUNC=1;
11.P_ECanaRegs->CANRIOC.all=ECanaShadow.CANRIOC.all;
12./*清RMPn,GIFn位*/
13.P_ECanaRegs->CANRMP.all=0xFFFFFFFF;
14./*清中断标志*/
15.P_ECanaRegs->CANGIF0.all=0xFFFFFFFF;
16.P_ECanaRegs->CANGIF1.all=0xFFFFFFFF;
17.
18./*初始化配置,写入CAN波特率*/
19.ECanaShadow.CANMC.all=P_ECanaRegs->CANMC.all;
20.ECanaShadow.CANMC.bit.CCR=1;//SetCCR=1
21.P_ECanaRegs->CANMC.all=ECanaShadow.CANMC.all;
22.ECanaShadow.CANES.all=P_ECanaRegs->CANES.all;
23.do
24.{
25.ECanaShadow.CANES.all=P_ECanaRegs->CANES.all;
26.}while(ECanaShadow.CANES.bit.CCE!=1);//WaitforCCEbittobeset..
27.//Bitrate=SYSCLKOUT/2/{(BRP+1)*[(TSEG1+1)+(TSEG2+1)+1,
28.//TSEG1≥3,TSEG2≥2
29.ECanaShadow.CANBTC.bit.BRPREG=2;
30.ECanaShadow.CANBTC.bit.TSEG2REG=4;
31.ECanaShadow.CANBTC.bit.TSEG1REG=13;
32.P_ECanaRegs->CANBTC.all=ECanaShadow.CANBTC.all;
33.ECanaShadow.CANMC.all=P_ECanaRegs->CANMC.all;
34.ECanaShadow.CANMC.bit.CCR=0;//SetCCR=0
35.P_ECanaRegs->CANMC.all=ECanaShadow.CANMC.all;
36.ECanaShadow.CANES.all=P_ECanaRegs->CANES.all;
37.do
38.{
39.ECanaShadow.CANES.all=P_ECanaRegs->CANES.all;
40.}while(ECanaShadow.CANES.bit.CCE!=0);//WaitforCCEbittobecleared..
41.
42./*屏蔽所有信箱寄存器*/
43.//RequiredbeforewritingtheMSGIDs
44.P_ECanaRegs->CANME.all=0;
45./*配置MBOX1的MSGID*/
46.P_ECanaMboxes->MBOX1.MSGID.all=0x00040000;
47.P_ECanaMboxes->MBOX0.MSGID.all=0x00040000;
48./*配置MBOX1/MBOX0的传输字节为2*/
49.ECanaMboxes.MBOX1.MSGCTRL.bit.DLC=0x2;
50.ECanaMboxes.MBOX0.MSGCTRL.bit.DLC=0x2;
51./*配置MBOX0为接收,MBOX1为发送*/
52.ECanaRegs.CANMD.bit.MD0=1;
53.ECanaRegs.CANMD.bit.MD1=0;
54./*使能MBOX0andMBOX1*/
55.ECanaRegs.CANME.bit.ME0=1;
56.ECanaRegs.CANME.bit.ME1=1;
57.//挂起接收邮箱,以触发接收中断
58.if(ECanaRegs.CANRMP.bit.RMP0==0)
59.{
60.ECanaRegs.CANRMP.bit.RMP0=1;
61.}
62.EDIS;
63.return;
64.}

CAN的发送程序代码为:

1.voidCAN_Tx(void)
2.{
3.//等待MBOX0接收成功,读取消息
4.while(ECanaRegs.CANRMP.bit.RMP0!=1){}
5.ECanaMboxes.MBOX1.MDL.byte.BYTE0=(receive_data&0xff);
6.ECanaMboxes.MBOX1.MDL.byte.BYTE1=((receive_data>>8)&0xff);
7.
8.ECanaRegs.CANTRS.bit.TRS1=1;//发送MBOX1数据到MBOX0
9.}

CDK上开发CAN通信收发程序,其编译结果为:

e703b9e0-35dd-11ed-9ade-dac502259ad0.jpg

编译通过后,就可以开始调试了,调试后,可通过USB_CAN网络通信软件,查看发送与接收到的数据如下图:

e72a0f14-35dd-11ed-9ade-dac502259ad0.jpg

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

    关注

    18

    文章

    6318

    浏览量

    139570
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    微双芯片助力广汽铂GT攀登版正式下线

    微车规级芯片再迎重大应用突破 —— 近日,搭载RK3588M 智能座舱主控芯片与 RK2118M 音频 DSP 芯片的广汽铂 GT -
    的头像 发表于 11-21 15:18 474次阅读

    喜讯|RISC-V DSP荣获“中国”RISC-V生态推广奖

    11月14日,2025“中国”集成电路产业促进大会暨第二十届“中国”优秀产品征集评选结果在珠海横琴正式揭晓。车规级RISC-VDSP芯片
    的头像 发表于 11-18 09:01 1328次阅读
    喜讯|<b class='flag-5'>昊</b><b class='flag-5'>芯</b>RISC-V DSP荣获“中国<b class='flag-5'>芯</b>”RISC-V生态推广奖

    微逻辑类IC电平转换系列芯片助力网络传输

    IC转换系列芯片助力网络传输,开启高效通信,同时凭借其在模拟芯片领域的深厚技术积累,为
    的头像 发表于 11-11 15:39 871次阅读
    力<b class='flag-5'>芯</b>微逻辑类IC电平转换<b class='flag-5'>系列</b><b class='flag-5'>芯片</b><b class='flag-5'>助力</b><b class='flag-5'>网络</b>传输

    【作品合集】中科Core_DSC280025C开发板测评

    中科Core_DSC280025C开发板测评作品合集 产品介绍: Core_DSC280025C核心板使用了HXS320F28025CRISC-V DSP
    发表于 09-18 10:52

    微推出NSR926X系列车规级SBC系统基础芯片

    微全新推出的NSR926X系列车规级SBC系统基础芯片,集成了三路低压差稳压器(LDO)、四路高边驱动(HSS)、LIN收发器及带部分网络(Partial Networking,
    的头像 发表于 08-08 15:28 2036次阅读
    纳<b class='flag-5'>芯</b>微推出NSR926X<b class='flag-5'>系列</b>车规级SBC系统基础<b class='flag-5'>芯片</b>

    【中科Core_DSC280025C开发板试用体验】---LED闪烁灯

    中科Core_DSC280025C开发板试使用了HXS320F28025CRISC-VDSP芯片,该
    发表于 08-07 11:51

    新闻|亮相第五届RISC-V中国峰会,共绘开源芯片新纪元

    的突破性进展。本次峰会汇聚了全球RISC-V领域的顶尖企业、研究机构和开源社区,共同探讨RISC-V技术的创新与应用。产品线全覆盖峰会上,展示了HX2000系列家族
    的头像 发表于 07-28 18:30 685次阅读
    <b class='flag-5'>芯</b>新闻|<b class='flag-5'>昊</b><b class='flag-5'>芯</b>亮相第五届RISC-V中国峰会,共绘开源<b class='flag-5'>芯片</b>新纪元

    【中科Core_DSC280025C开发板试用体验】+3.DSP基础外设调试(含源码)

    。大致了解了官方工程的是框架和架构。我也参考了官方提供的hx2000-examples-master 例程代码。 例程里面的代码,用的库还是官方早期版本的,所以,的库后期肯定还会继续迭代。为了避免后期
    发表于 07-13 16:07

    【中科Core_DSC280025C开发板试用体验】+1.开箱之浮点计算对比

    笼统,还是看手册比较细致。 当然参考例程也是有的。 另外,也可以在立创商城上能看到中科的DSP芯片某些型号也有上架的,价格也并不算高。 所以经过前期的一系列准备后,我觉得可以
    发表于 06-29 10:01

    平头羽阵芯片助力菜鸟打造高性价比RFID数字供应链解决方案

    6月16日,在菜鸟与平头半导体联合举办的“智启链动,领未来”活动上,菜鸟发布了使用平头羽阵芯片
    的头像 发表于 06-17 19:19 957次阅读
    <b class='flag-5'>平头</b><b class='flag-5'>哥</b>羽阵<b class='flag-5'>芯片</b><b class='flag-5'>助力</b>菜鸟打造高性价比RFID数字供应链解决方案

    平头镇岳510芯片的QoS技术解析

    针对上述需求,平头存储技术团队凭借深度软硬件协同设计,通过IOPS一致性、带宽分配、时延控制三个核心技术构建了全场景的QoS保障体系,为金融交易、视频流媒体、AI训练等关键业务提供"性能零波动"的存储体验。
    的头像 发表于 04-29 09:16 2868次阅读
    <b class='flag-5'>平头</b><b class='flag-5'>哥</b>镇岳510<b class='flag-5'>芯片</b>的QoS技术解析

    加速高关税下国产替代!携全自研RISC-V DSP家族亮相上海慕尼黑电子展

    现场直击2025年4月15日-17日,上海新国际博览中心N5馆356展位前人头攒动,中科展台上陈列的Haawking-HX2000系列RISC-VDSP持续吸引专业观众驻足。作为全
    的头像 发表于 04-18 09:01 1666次阅读
    加速高关税下国产替代!<b class='flag-5'>昊</b><b class='flag-5'>芯</b>携全自研RISC-V DSP家族亮相上海慕尼黑电子展

    智多晶LWIP网络通信系统介绍

    在物联网蓬勃兴起的当下,嵌入式设备的网络通信能力如同为其插上了腾飞的翅膀,使其能够自由穿梭于信息的浩瀚海洋。而 LWIP,宛如一位身姿矫健的轻骑兵,在资源有限的嵌入式系统中飞驰,轻松完成各种复杂的网络通信任务。西安智多晶微电子有限公司的LWIP
    的头像 发表于 04-10 16:27 1670次阅读
    智多晶LWIP<b class='flag-5'>网络通信</b>系统介绍

    中科DSP产品及公司信息

    这一开放的指令集架构,中科成功研发出多个系列的DSP产品,并构建了一个完善的处理器生态系统。中科DSP广泛应用于工业控制、电机驱动、
    发表于 04-07 09:16

    喜讯!点亮华东服务新地标,杭州办开业大吉!

    杭州办公室开业啦!为了积极响应战略发展的业务需求,进一步拓宽当地服务版图。2024年
    的头像 发表于 12-17 17:33 973次阅读
    喜讯!点亮华东服务新地标,<b class='flag-5'>昊</b><b class='flag-5'>芯</b>杭州办开业大吉!