SPI
芯片名称与内核版本
芯片名称 | 内核版本 |
---|---|
采用 Linux 4.4 的所有芯片 | Linux 4.4 |
采用 Linux 4.19 及以上内核的所有芯片 | Linux 4.19 及以上内核 |
前言
概述
本文介绍 Linux SPI 驱动原理和基本调试方法。
读者对象
本文档主要适用于以下工程师:
- 技术支持工程师
- 软件开发工程师
1. Rockchip SPI 功能特点
1.1 SPI 接口速率
芯片名称 | Master Mode 接口最高速率 | Slave Mode 接口最高速率 |
---|---|---|
RK3506 | 50MHz | 50MHz |
RV1106B/RV1103B | 50MHz | 33MHz |
RK3576 | 50MHz | 33MHz |
RK3562 | 50MHz | 33MHz |
RK3528 | 50MHz | 33MHz |
RV1106/RV1103 | 50MHz | 33MHz |
RK3588 | 50MHz | 33MHz |
RV1126/RV1109 | 50MHz | 16MHz |
RK3568 | 50MHz | 33MHz |
RK1808 | 50MHz | 16MHz |
RK3308 | 50MHz | 16MHz |
其他芯片平台 | 50MHz | 16MHz |
说明:
- 接口最高速率为理论速率,受设备走线 PCB 质量影响,以实测为准。
- 部分平台由于 PLL 策略原因无法准确分频到上限值,实际以最大分频值为准。
2. 内核软件
2.1 代码路径
drivers/spi/spi.c
:SPI 驱动框架drivers/spi/spi-rockchip.c
:RK SPI 各接口实现drivers/spi/spi-rockchip-slave.c
:RK SPI slave 各接口实现drivers/spi/spidev.c
:创建 SPI 设备节点,用户态使用drivers/spi/spi-rockchip-test.c
:SPI 测 试驱动,需要手动添加到 Makefile 编译Documentation/spi/spidev_test.c
:用户态 SPI 测试工具
2.2 SPI 设备配置 —— RK 芯片作 Master 端
内核配置
Device Drivers --->
[*] SPI support --->
<*> Rockchip SPI controller driver
DTS 节点配置
&spi1 {
status = "okay";
// assigned-clocks = <CLK_SPI1>; // 默认不用配置,CLK_SPIn 请从 soc 对应的 dtsi 里确认
// assigned-clock-rates = <200000000>; // 默认不用配置,SPI 设备工作时钟值
// dma-names; // 默认不用配置,关闭 DMA 支持,仅支持 IRQ 传输
// rockchip,poll-only; // 默认不用配置,开启后强制使用 CPU 传输,仅支持 master mode 下配置
// rx-sample-delay-ns = <10>; // 默认不用配置,读采样延时,详细参考 “常见问题”“延时采样时钟配置方案” 章节
// rockchip,autosuspend-delay-ms = <500>; // 默认不用配置,Runtime PM autosuspend 延时,详细参考 “SPI 传输速率及 CPU 负载优化”
// rockchip,rt; // 默认不用配置,将 spi 数据传输进程放到 SCHED_FIFO 类中,其优先级为 50
spi_test@10 {
compatible = "rockchip,spi_test_bus1_cs0"; // 与驱动对应的名字
reg = <0>; // 片选 0 或者 1
spi-cpha; // 设置 CPHA = 1,不配置则为 0
spi-cpol; // 设置 CPOL = 1,不配置则为 0
spi-lsb-first; // IO 先传输 lsb
spi-max-frequency = <24000000>; // spi clk 输出的时钟频率,不超过 50M
status = "okay"; // 使能设备节点
};
};
说明:
spi-max-frequency
是 SPI 的输出时钟,由 SPI 工作时钟spiclk assigned-clock-rates
内部分频后输出,由于内部至少 2 分频,所以关系是spiclk assigned-clock-rates >= 2 * spi-max-frequency
。- 假定需要 50MHz 的 SPI IO 速率,可以考虑配置(记住内部分频为偶数分频)
spi_clk assigned-clock-rates = <100000000>
,spi-max-frequency = <50000000>
,即工作时钟 100MHz(PLL 分频到一个不大于 100MHz 但最接近的值),然后内部二分频最终 IO 接近 50MHz。 spiclk assigned-clock-rates
不要低于 24M,否则可能有问题。