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

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

3天内不再提示

玩转先楫CANFD外设系列之二:CAN外设的接收过滤器详解

先楫半导体HPMicro 2023-08-24 08:20 次阅读

一、背景

在实际应用中,CAN总线上的数据,对于某些CAN节点来说,可能需要的数据并不多,希望收到的数据是自己关心的即可,不必要的数据过滤同时也可以减少中断的次数,减轻CPU负荷,也可以节省数据记录设备中的存储空间。

从上篇文章《[玩转先楫CANFD外设系列之一]轻松搞起CANFD》中可知道,先楫的CANFD包括了CAN和MCAN。其中HPM6700/HPM6400/HPM6300系列产品用的是CAN,而HPM6200系列使用的是MCAN。本文统称HPM6700/HPM6400/HPM6300系列产品的CANFD为CAN。

本文阐述CAN外设,MCAN外设不在本文阐述范围内。

CAN有16组独立的筛选器,并没有所谓的列表和掩码模式的过滤器组。每个筛选器都是独立,只要任意一组的筛滤器器满足条件则能被接收。配置也极其简单,只需要配置ID CODE和对应的匹配MASK位等寄存器则照样可以实现所谓的列表和掩码方式。

f57f33ee-4213-11ee-8e12-92fbcf53809c.png

二、实现流程

对于筛选器来说,CAN可操作的寄存器很少,只需要三个寄存器即可实现筛选ID的效果。分别对应的名称是ACF_XXX后缀。

f5994a72-4213-11ee-8e12-92fbcf53809c.png


(一)ID筛选

寄存器上主要操作ACFCTRL和ACF的CODE_MASK位(一共有29位,满足标准帧和扩展帧)。

接收匹配MASK的位基于IDCODE来进行匹配。选择哪个筛选器通过ACFCTRL寄存器的ACFADR配置,一共4bit,也就是16个筛选器。

f5ada724-4213-11ee-8e12-92fbcf53809c.png


在can_set_filter这个API中,对于筛选器的选择,可以这么参考。


f5c6fa9e-4213-11ee-8e12-92fbcf53809c.png


由于IDCODE和MASK共用一个寄存器也就是ACF的CODE_MASK,在配置的时候需要选择的是IDCODE还是MASK。这里需要用到ACFCTRL的SELMASK位。然后依次进行对CODE_MASK赋值。

需要注意的是:

在CAN外设当中,当MASK对应的位为0的时候,必须于IDCODE对应的位进行匹配比较,当为1的时候则忽视。

f5d96594-4213-11ee-8e12-92fbcf53809c.png

f60272b8-4213-11ee-8e12-92fbcf53809c.png

同样在can_set_filter这个API也是这么操作。

f631b2bc-4213-11ee-8e12-92fbcf53809c.png

需要注意的是:IDCODE和MASK的时候,必须是在CAN复位模式下才能设置。

f66368ac-4213-11ee-8e12-92fbcf53809c.png

在can的sample当中,注释也特别提醒。

f68c1c0c-4213-11ee-8e12-92fbcf53809c.png


(二)标准帧和扩展帧筛选

每个筛选器还可以对标准帧和扩展帧进行筛选,主要是通过ACF寄存器的AIDEE和AIDE位进行配置。

这里描述的大概可以这样理解:

AIDEE=0AIDE=x(不关心)接收标准帧和扩展帧

AIDEE=1 AIDE=0 只接收标准帧

AIDEE=1 AIDE=1 只接收扩展帧

f6bc208c-4213-11ee-8e12-92fbcf53809c.png

在can_set_filter这个API中,也是通过判断can_filter_id_mode_t枚举进行判断筛选。

f6ebafa0-4213-11ee-8e12-92fbcf53809c.png


(三)筛选器组的启用和禁用

在手册中,每个筛选器都可以单独启用和禁用。主要通过ACF_EN配置。

f70189d8-4213-11ee-8e12-92fbcf53809c.png


(四)实现列表和掩码模式效果

从上面的配置可知道:

列表模式:

IDCODE配置为需要接收的ID号,MASK配置为0,那么该筛选器就可以实现只接收一个ID的列表方式,比如:

标准帧下,IDCODE=0x21,MASK=0(全部比较)。那么该筛选器只能筛选ID为0x21这个ID。


掩码模式:

DCODE配置为需要接收的ID号,MASK配置需要比较的位,那么该筛选器就可以实现只接收一个ID的掩码方式,比如:

标准帧下,IDCODE=0x100,MASK=0x700。需要匹配的位是第十位到第八位,其他的位都不做关心,那么接收的ID范围就是0x100~0x1ff

f732d04c-4213-11ee-8e12-92fbcf53809c.png


三、代码实现

在hpm_sdk的can这个sample当中,有个测试项目就是筛选器测试,对应的是board_can_filter_test这个函数。这里使用的是内部环回模式,可以不用接外置PHY即可测试。

在函数的开头注释就说到两个注意点,开发者在开发的时候需要注意。

f74548f8-4213-11ee-8e12-92fbcf53809c.png

1、CAN的筛选器只能在CAN复位模式下配置,建议使用can_init这个API,通过传参代入筛选器参数,can_init这个API自动处理。否则需要需要调用can_set_filter这个API,则需要先调用can_reset进行复位。这时候也同样需要重新设置下波特率。


2、can_filter_config_t结构体的mask成员,1代表在IDCODE对应的位忽视,0代表该位将于IDCODE比较匹配。

这个测试同样实现了类似所谓掩码模式和列表模式。


掩码模式:

f7894602-4213-11ee-8e12-92fbcf53809c.png

f7ced1cc-4213-11ee-8e12-92fbcf53809c.png

log可以看到:

f80ab7e6-4213-11ee-8e12-92fbcf53809c.png

列表模式:

在sample当中,16个筛选器的mask都设置为0,也就是必须与idcode的所有位匹配才接收。

f81a1538-4213-11ee-8e12-92fbcf53809c.png

同样也是发送ID为0~2048的2048个消息帧,应该只能收到16个ID帧。分别是以下

f86a4bac-4213-11ee-8e12-92fbcf53809c.png


四、总结

1、HPM6700/HPM6400/HPM6300系列产品的CAN长达16个过滤组,如果需要更多的过滤组,可以选择HPM6200等是MCAN外设,比如hpm6200的MCAN,标准帧可以达到128个过滤组。


2、HPM6700/HPM6400/HPM6300系列产品的CAN过滤组设置相对简单易用。


3、HPM6700/HPM6400/HPM6300系列产品的CAN过滤组的IDCODE和MASK只能在CAN复位模式下配置。建议每次配置过滤组直接调用can_init这个API。

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

    关注

    30

    文章

    5042

    浏览量

    117768
  • CAN
    CAN
    +关注

    关注

    56

    文章

    2472

    浏览量

    459363
  • 总线
    +关注

    关注

    10

    文章

    2716

    浏览量

    87232
  • 过滤器
    +关注

    关注

    1

    文章

    407

    浏览量

    19010
收藏 人收藏

    评论

    相关推荐

    请问如何在CAN通信中的每个CAN消息对象中添加过滤器

    如何在CAN通信中的每个CAN消息对象中添加过滤器
    发表于 01-18 07:59

    前置过滤器的使用寿命有多长?

    前置过滤器的使用寿命有多长? 前置过滤器的使用寿命有多长,这是一个相对而言的概念,因为它的使用寿命取决于多个因素。下面将详细介绍前置过滤器的使用寿命以及影响因素。 一、什么是前置过滤器
    的头像 发表于 12-11 11:38 531次阅读

    springboot过滤器和拦截器哪个先执行

    Spring Boot是一个用于构建Java应用程序的开发框架,它提供了许多功能和工具来简化开发和部署过程。其中两个重要的功能是过滤器和拦截器。本文将详细介绍Spring Boot过滤器和拦截器
    的头像 发表于 12-03 15:00 729次阅读

    AT32F系列CAN过滤器使用

    AT32F系列 CAN过滤器使用演示AT32F系列CAN过滤器的使用方法。
    发表于 10-27 06:44

    stm8s208的can过滤器怎么设置?

    stm8s208 的 can 过滤器怎么设置?
    发表于 10-26 08:13

    如何设置AT32F4xx系列CAN过滤器

    AT32F4系列CAN过滤器配置方法
    发表于 10-23 08:01

    TSMaster几种过滤器的对比及使用

    TSMaster的4种过滤器://硬件过滤器:可以在硬件端针对数据位进行筛选过滤,硬件过滤。在硬件端阻止接收一部分不需要的报文,留更多带宽对
    的头像 发表于 10-21 08:21 1264次阅读
    TSMaster几种<b class='flag-5'>过滤器</b>的对比及使用

    如何使用M460系列微控制器接收和打印CANFD信息

    应用:此示例代码使用 M460 系列微控制器接收并打印CANFD公共汽车上的所有信息。 BSP 版本: M460_Series_BSP_CMSIS_V3.00.001.001 硬件
    发表于 08-29 07:55

    CAN外设接收过滤器设置

    数据记录设备中的存储空间。     从上篇文章《[玩转先楫CANFD外设系列之一]轻松搞起CANFD》中可知道,先楫的
    的头像 发表于 08-24 09:03 1038次阅读
    <b class='flag-5'>CAN</b><b class='flag-5'>外设</b>的<b class='flag-5'>接收过滤器</b>设置

    玩转先楫CANFD外设系列之一:轻松搞起CANFD

    一、概述先楫的CANFD外设,有两个CANFD的IP,其中HPM6700系列,HPM6400系列、HPM6300
    的头像 发表于 08-02 08:20 1337次阅读
    <b class='flag-5'>玩转</b>先楫<b class='flag-5'>CANFD</b><b class='flag-5'>外设</b><b class='flag-5'>系列</b>之一:轻松搞起<b class='flag-5'>CANFD</b>

    聊聊布隆过滤器

    布隆过滤器是一个精巧而且经典的数据结构。
    的头像 发表于 06-30 10:03 365次阅读
    聊聊布隆<b class='flag-5'>过滤器</b>

    NUC230 CAN总线如何配置过滤器和掩码?

    有用过新塘单片机的小伙伴吗,第一次用新塘的单片机,CAN总线配置过滤器和掩码不知如何配置,有用过的,指点一下
    发表于 06-27 06:01

    CAN模块的接收过滤是如何编写的?

    我现在使用NUC131芯片,按电梯例程进行了调试,收、发都已OK。 现在想问下,CAN模块的接收过滤是如何编写的?例程里没有这块内容。 我查了CAN.C的库函数,有一个: int32_t
    发表于 06-13 07:28

    过滤器模式是指什么?

    过滤器模式是指通过构造一系列不同的标准实现类,通过这些标准实现类把目标对象(通常是多个)按照对应的标准进行过滤,从而得到想要的对象(或对象组)。
    的头像 发表于 06-01 14:32 970次阅读
    <b class='flag-5'>过滤器</b>模式是指什么?

    一文解析布隆过滤器设计原理

    布隆过滤器 是一个很长的二进制向量 和一系列随机映射函数 ,用于检索一个元素是否在一个集合中 。 它的空间效率 和查询时间 都远远超过一般的算法 ,但是有一定的误判率 (函数返回 true , 意味着元素可能存在,函数返回 false ,元素必定不存在)。
    发表于 05-12 11:14 402次阅读
    一文解析布隆<b class='flag-5'>过滤器</b>设计原理