RK3588-CAN总线

发布时间:2023-06-10 阅读量:72662 来源: 我爱方案网 作者:

1. 简介

ArmSoM-W3 RK3588 开发板中已集成AN总线:


  • 专栏总目录

  • CAN (controller Area Network)

  • CAN BUS:控制器局域网络总线

  • 目前世界上绝大多数汽车制造厂商都采用CAN总线来实现汽车内部控制系统之间的数据通信。

  • RK3568/RK3588的CAN驱动文件:drivers/net/can/rockchip/rockchip_canfd.c


2. 内核配置


  • rockchip_linux_defconfig配置:

  • CONFIG_CAN=yCONFIG_CAN_DEV=yCONFIG_CAN_ROCKCHIP=yCONFIG_CANFD_ROCKCHIP=y


  • 内核配置:

  • cd kernelmake ARCH=arm64 menuconfigmake savedefconfig


  • 选择:Networking support —> CAN bus subsystem support ()—>CAN Device Drivers() —> Platform CAN drivers with Netlink support(*)


在这里插入图片描述

3. DTS 节点配置

3.1 主要参数:


  • interrupts =;
    转换完成,产生中断信号。

  • clock
    时钟属性,用于驱动开关clk,reset属性,用于每次复位总线。

  • pinctrl


3.2 公共配置 kernel-5.10/arch/arm64/boot/dts/rockchip/rk3588s.dtsi

can1: can@fea60000 {
           compatible = "rockchip,can-2.0";
           reg =<0x0 0xfea60000="" 0x0="" 0x1000="">;
           interrupts =;
           clocks = <&cru clk_can1="">, <&cru pclk_can1="">;
           clock-names = "baudclk", "apb_pclk";
           resets = <&cru srst_can1="">, <&cru srst_p_can1="">;
           reset-names = "can", "can-apb";
           pinctrl-names = "default";
           pinctrl-0 = <&can1m0_pins>;
           tx-fifo-depth =<1>;
           rx-fifo-depth =<6>;
           status = "disabled";
   };

  • compatible = “rockchip,can-1.0” ,rockchip,can-1.0用来匹配can控制器驱动。

  • compatible = “rockchip,can-2.0” ,rockchip,can-2.0用来匹配canfd控制器驱动。

  • assigned-clock-rates用来配置can的始终频率,如果CAN的比特率低于等于3M建议修改CAN时钟到100M,信号更稳定。高于3M比特率的,时钟设置200M就可以。

  • pinctrl配置:根据实际板卡连接情况配置can_h和can_l的iomux作为can功能使用。


3.3 板级配置 kernel-5.10/arch/arm64/boot/dts/rockchip/rk3588-armsom-w3.dts

/* can1 */ &can1 {
       status = "okay";
       assigned-clocks = <&cru clk_can1="">;
       assigned-clock-rates =<200000000>;
       pinctrl-names = "default";
       pinctrl-0 = <&can1m1_pins>;      //根据原理图配置 };

  • 由于系统根据上述dts节点创建的CAN设备只有一个,而第一个创建的设备为CAN0


4. 调试


  • 查询当前⽹络设备:

    ifconfig -a

  • CAN启动


  • ip link set can0 down   //关闭CAN

  • ip link set can0 type can bitrate 500000   //设置⽐特率500KHz

  • ip -details -statistics link show can0    //打印can0信息
    ip link set can0 up     //启动CAN

  • CAN发送

    cansend can0 123#DEADBEEF            //发送(标准帧,数据帧,ID:123,date:DEADBEEF)

  • cansend can0 123#R                            //发送(标准帧,远程帧,ID:123)

  •  cansend can0 00000123#12345678    //发送(扩展帧,数据帧,ID:00000123,date:DEADBEEF)

  • cansend can0 00000123#R                 //发送(扩展帧,远程帧,ID:00000123)

  • CAN接收

    candump can0       //candump can0



相关资讯
时钟芯片RTC原理介绍、晶振选型、应用场景

【小知识】时钟芯片一种高性能、低功耗、带RAM的实时时钟电路,英文名称:Real-time Clock/Calendar Chip(简称:RTC),可以对年、月、日、周日、时、分、秒进行计时,具有闰年补偿功能。采用IIC通信接口。

晶振起振检测四大核心方法:示波器、万用表、频率计实操指南

晶振作为电子设备的"心跳发生器",其起振状态直接决定系统能否正常运行。本文深度解析四种检测方法的实战要点:示波器法需规避探头电容引发的停振风险,万用表电压法需警惕芯片故障导致的误判,频率计通过波形特征精准锁定起振状态,而听声辨振实为认知误区——人耳可闻的异常声响反而暴露晶振缺陷。随着5G/新能源产业爆发式增长,国产晶振厂商正加速技术攻坚,保障起振检测的可靠性已成为行业刚需。

可编程晶振怎么改变频率

可编程晶振改变频率的核心原理是:通过内部集成的锁相环(PLL)和数字分频/倍频电路,对基础石英晶体产生的固定频率进行精密的数学运算(分频、倍频、分数分频),最终输出一个用户通过数字接口(如I²C、SPI)编程设定的目标频率。

巴克豪森准则:振荡器起振的相位与增益平衡艺术

晶振是电路中可以提供高度稳定时钟信号的元器件。通常一个系统共用一个晶振,便于各部分保持同步,一起“干大事”。比如在我们常用的计算机系统中,晶振可比喻为各板卡的“心跳”发生器,如果主卡的“心跳”出现问题,必定会使其他各电路出现故障。人体的心跳搏动,离不开血液。晶振也是一样,离不开电流。

从XTAL到OCXO:解析五大晶振类型及其技术皇冠

晶振自身产生时钟信号,为各种微处理芯片作时钟参考,晶振相当于这些微处理芯片的心脏,没有晶振,这些微处理芯片将无法工作。晶振的作用就是为系统提供基本的时钟信号。通常一个系统共用一个晶振,便于各部分保持同步。有些通讯系统的基频和射频使用不同的晶振,而通过电子调整频率的方法保持同步。晶振主要运用于单片机、DSP、ARM、PowerPC、CPLD/FPGA等CPU,以及PCI接口电路、CAN接口电路等通讯接口电路。