找回密码
 注册
关于网站域名变更的通知
查看: 306|回复: 2
打印 上一主题 下一主题

全志T507实现SPI转CAN-全程详解

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-2-10 14:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
# r9 t# b: G4 e, j
全志T507处理器本身不支持CAN功能,那有什么方法可以实现CAN功能呢?
8 \8 {4 g% A# o9 a& J我们已知FETT507-C核心板是支持SPI接口的,但底板没有引出该接口,所以小编打算通过引脚复用方式,复用出SPI接口并做成SPI转CAN,来实现CAN功能。5 O4 ~& H) _: }# |1 b4 t1 }2 W
本文所采用的方法是通过添加MCP2515驱动及配置,实现SPI转CAN功能。
) M% J9 q" ^4 a5 {1 i. S5 d一、选择引脚5 e/ e* \' ^& m5 {, U  b( y
首先确认要使用的引脚,由于飞凌嵌入T507开发板默认没有配置SPI,因此既要选用于SPI功能的引脚,也要选择用于can模块的中断引脚。3 c8 _, p3 s  j- i7 n& K5 v! s
SPI需要CS0、CLK、MOSI、MISO四个引脚,can模块需要一个中断引脚。中断引脚可以随便使用一个具有中断功能的引脚。打开硬件资料中的飞凌嵌入式T507核心板引脚复用对照表,先确认哪些引脚可以用做SPI,我们搜索SPI可以找到两组引脚0 c$ z) H0 n  @7 p1 L0 c3 d. |
因为PC3、PC4和启动相关这里不考虑使用SPI0,我们用SPI1,SPI1使用的引脚默认为音频接口使用的引脚,音频将不能使用。所以我们的中断引脚也从音频使用的引脚中选择,我们选择PH9(用户可根据实际情况选择具有中断功能的引脚)。
' B% G8 `' \5 I. _: I+ |6 a4 s: T; K

: Y( B" s% C4 b; k6 @' C; r+ @* a我们需要的引脚已经确定了(加粗的5个引脚),现在进行软件修改
3 R+ z8 f3 t& m- H- T% l- G二、相关设备首先查看设备树,本次使用到的设备树如下:
' r( a; r) c& D/ Y* p" Pkernel/linux-4.9/arch/ARM64/boot/dts/sunxi/OKT507-C-Common.dtsi( L; {' `. ?! K8 k+ h- G$ G; q- m
kernel/linux-4.9/arch/arm64/boot/dts/sunxi/sun50iw9p1.dtsi
" \9 J+ z6 u* f# j( k) C- Y/ Nkernel/linux-4.9/arch/arm64/boot/dts/sunxi/sun50iw9p1-pinctrl.dtsi
: M+ x* g5 q) B$ c" `* R& R1 wkernel/linux-4.9/arch/arm64/boot/dts/sunxi/sun50iw9p1-clk.dtsi7 S* p4 r  m1 H8 a' O$ I/ O
三、去掉所选引脚原有配置从核心板引脚功能复用表格可以看到,选用的引脚原本配置的功能:
# ?1 ~8 y; B- f  {1 U
. r2 l3 q8 {9 H$ V
sun50iw9p1-pinctrl.dtsi搜索PH5引脚,可以看到ahub_daudio3_pins_a和ahub_daudio3_pins_b是用于音频,在设备树路径使用grep"ahub_daudio3_pins_a" ./ -nr指令可以查到,在sun50iw9p1.dtsi里有调用:) J" R0 O" X8 Y% [4 Z$ |4 Q5 K
" e3 T2 H1 x% K# y  O
打开sun50iw9p1.dtsi,可以看到在ahub_daudio3节点有调用,将status设置为disabled(默认即为disablded状态)
) ~1 R* {9 F' c& K5 h
, A2 y2 r$ V2 e% \9 {! \
这个设备树里设置的disabled,继续查找该设备树的上级设备树:OKT507-C-Common.dtsi。OKT507-C-Common.dtsi有做开启设置,需要将ahub_daudio3关掉,status= "disabled"。PH5、PH6、PH7、PH8、PH9的占用都解除了。3 j& ~4 k+ Q( M7 T! v
# {! H9 i9 G, D' x
四、配置SPI14.1使能SPI1配置搜索SPI1相关内容,在sun50iw9p1.dtsi中可以看到, y# d* ^- P) m: u2 ^

, C$ a$ J! {- U+ U) V; D; ]这个是对SPI1的注册,将status改为okay,这里对相关引脚和时钟做了配置。; o" Y8 z  q+ _. I

( v  `; d) Q$ c: O1 o+ ^) y; h4.2 SPI1的时钟及引脚配置
时钟:我们通过查看sun50iw9p1-clk.dtsi可以看到clk_pll_periph0和clk_spi1的内容,我们使用默认配置即可。这里不再贴图,可自行查看  i# x! ~2 U* j* S0 k& c' Q
引脚:我们查看sun50iw9p1-pinctrl.dtsi可以看到spi1_pins_a、spi1_pins_b和spi1_pins_c的内容,使用引脚为PH5、PH6、PH7、PH8。% \. M3 r$ \0 I
: X1 M9 M3 Y3 e# x' ~8 S
五、配置SPI转CAN设备5.1 添加设备在OKT507-C-Common.dtsi中SPI0节点后添加SPI转CAN相关节点,添加内容如下:
) X2 K3 q& X6 W7 S4 Fspi1: spi@05011000 {  pinctrl-0 = <&spi1_pins_a &spi1_pins_b>;  pinctrl-1 = <&spi1_pins_c>;  spi_slave_mode = <0>;  status = "okay";    can0: can@0 {      compatible = "microchip,mcp2515";      pinctrl-names = "default";      pinctrl-0 = <&mcp2515_int>;      reg = <0>;      spi-max-frequency = <1000000>;      clocks = <&clk_osc8m>;      interrupt-parent = <&pio>;      interrupts = <PH 9 IRQ_TYPE_LEVEL_LOW>;      status = "okay";    };};其中中断引脚配置,请根据实际配置的引脚进行修改。
  G% g2 F1 \& \' \5.2 时钟配置我们在注册can的时候用到了时钟和中断引脚,前边关掉音频时PH9已经可以使用了,但是我们用到的8M时钟clk_osc8m还没有注册。
* B& R+ _1 p- `2 f. g5 Z' V, ?打开sun50iw9p1-clk.dtsi,添加clk_osc8m到clk_osc48m下边
  }8 @0 d. N6 x' v; w4 }clk_osc8m: osc8m {  #clock-cells = <0>;  compatible = "allwinner,fixed-clock";  clock-frequency = <8000000>;  clock-output-names = "osc8m";};如果是选择24M晶振,也可注册clk_osc24m,clock-frequency改为240000003 W3 u! v" @' N1 U5 Y
5.3 中断引脚配置在OKT507-C-Common.dtsi中添加,在该设备树中搜索:pio:pinctrl@0300b000,将以下配置添加到该节点里边。$ n3 [- i: M( {$ x! s( w1 l& H
mcp2515_int: can0@0 {  allwinner,pins = "PH9";  allwinner,pname = "mcp2515_int";  allwinner,function = "irq";  allwinner,muxsel = <6>;  allwinner,drive = <1>;  allwinner,pull = <0>;};5.4 mcp2515驱动配置到此,我们在设备树中的修改已经完成接下来,我们添加mcp2515驱动配置,驱动位于kernel/linux-4.9/drivers/net/can/spi/,可以看到mcp251x.c,我们可以打开该目录里的Makefile文件,Makefile文件中已经配置了CONFIG_CAN_MCP251X
- W3 k0 ]( n! m4 O/ y8 P2 d7 M; a进入kernel/linux-4.9目录中,执行如下命令:4 _" [: M+ x  U6 H4 K4 x' f
make sun50iw9p1smp_longan_defconfigmake menuconfig ARCH=arm64进入图形配置界面,我们添加mcp2515的编译,每一级目录选如下选项:
  • Networking support  --->  <*>CAN bus subsystem support  --->    CAN Device Drivers  --->      CAN SPI inteRFaces  --->        <*> Microchip MCP251x SPI CAN controllers前边括号里的内容通过空格键修改,“*”是编译进内核,“M”是编译成模块,空的是不编译。此处需要编译进内核% o3 ?4 b; ~. @5 o: B
    修改完成后按Esc键退出,最后选yes保存配置为.config。$ h: B) u. P: ?9 u; B, U
    修改完成,按照手册编译源码,生成镜像0 U$ c& q* p" y* n
    注:
    ) ]( a* u/ g1 z6 I3 c6 Y4 C7 O
      % h" z3 y* P. p$ {* }9 c) s9 b, u
             
    • 配置menuconfig后保存为.config,使用./build.sh kernel单步编译内核,会使用该.config
        j# g* M8 H; S( j( r) \       
    • 若使用./build.sh进行全编译,会重新把sun50iw9p1smp_longan_defconfig加载为.config,之前的配置将不生效。因此通过menuconfig修改完后,保存的.config要做好备份,在全编译前需要将文件,将其重命名为 sun50iw9p1smp_longan_defconfig,并替换kernel/linux-4.9/arch/arm64/configs下的同名文件* _5 d/ j# a4 P0 M1 V1 b$ ^
    六、CAN测试将编译好的镜像烧录到核心板中,并将资料里的相关测试工具:ip、cansend和candump拷贝到T507开发板根目录。
      X( w; K/ W; z8 p硬件接好SPI转CAN模块,与PC机接好,使用USB转CAN插在电脑上" i. O, U; ?  q) _% H4 Q2 A: `% _- f
    启动T507开发板执行以下程序进行测试:! v; |& x% U; b
    ifconfig can0 down/ip link set can0 up type can bitrate 125000 triple-sampling onifconfig can0 up/cansend can0 123#12345678     //发送数据/candump can0                  //接收数据七、硬件修改方法在飞凌嵌入式T507开发板上移植使用SPI转CAN模块! t( X. E( Y6 L, _, p
    首先要在T507开发板上去掉C132/U18这两个器件,之后通过飞线的方式将SPI转CAN的模块连接至T507开发板,连接方式如下:; S, U9 P+ j3 r' q
    : a* ^: y/ F, ?& i& \9 j. R) v
    SPI转CAN的5V主供电可以通过音频芯片正下方的R194和R199上获得,位置如下图:7 t/ m( v$ K1 R0 q7 d3 h! O

    2 d6 L" ~* C) Z$ M# b) b" a- B( w, Z0 V0 l
  • 该用户从未签到

    2#
    发表于 2022-2-10 17:22 | 只看该作者
    讲解的很完善很全面
  • TA的每日心情
    郁闷
    2025-3-25 15:59
  • 签到天数: 36 天

    [LV.5]常住居民I

    3#
    发表于 2022-2-11 15:56 | 只看该作者
    我觉得你是实现了SPI接口的复用配置,并没有在T507处理器上实现CAN,没有外置MCP2515啥也干不了。。。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-23 15:34 , Processed in 0.156250 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表