![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图1](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777a14110.jpeg)
HPM知识库
本栏目是先楫 MCU 开发的「一站式技术参考库」! 每周上新,为HPM开发者提供全维度的技术文档、问题解决方案、开发指南与实战教程,了解更多,请访问https://kb.hpmicro.com/
前言
在引脚资源紧张、但对传输带宽要求不高的嵌入式场景中,我们往往希望用更少的引脚完成 SPI 通信。
先楫半导体旗下全系MCU内置的 SPI 控制器,除了标准的SPI全双工模式,还支持 单线双向半双工 工作模式——仅用 MOSI 这一根数据线,就能完成命令、地址、数据的发送与接收。
参考示例
本文基于 先楫 HPM SDK 中的以下官方示例编写,可直接参考运行:
samples/drivers/spi/dma/master/ | |
samples/drivers/spi/dma/slave/ |
两个示例需配合使用(一块板子跑 Master,另一块跑 Slave),通过 mosi_bidir = true 开启单线双向半双工通信。
实现原理
硬件层面
SPI 控制器内部通过一个 mosi_bidir 控制位将 MOSI 引脚配置为双向 I/O:
- 写阶段:MOSI 作为输出,驱动数据到总线上。
- 读阶段:MOSI 切换为输入,从总线上采样数据。
pinmux上只需要初始化MOSI即可
传输模式
trans_mode 决定了一次 SPI 帧中读写阶段的顺序。SDK 支持的模式包括:
spi_trans_write_only:纯写spi_trans_read_only :纯读spi_trans_write_read :先写后读spi_trans_read_write :先读后写spi_trans_write_dummy_read :先写 → Dummy 周期 → 后读spi_trans_read_dummy_write :先读 → Dummy 周期 → 后写
单线半双工模式下,以上模式均可使用。示例中改使用为 spi_trans_write_read / spi_trans_read_write,读写方向切换由硬件自动完成。
代码配置
关键参数:mosi_bidir
mosi_bidir 默认为 false(关闭),即标准 4 线全双工模式。要开启 MOSI 单线双向半双工,只需将其设为 true:
// 默认为 false,需显式开启
format_config.common_config.mosi_bidir = true;Master 端(先写后读)
// 文件:samples/drivers/spi/dma/master/src/spi.c
spi_master_get_default_format_config(&format_config);
format_config.common_config.data_len_in_bits = 8; // 8 位数据
format_config.common_config.mosi_bidir = true; // ★ MOSI 双向
format_config.common_config.data_merge = false;
format_config.common_config.mode = spi_master_mode;
format_config.common_config.cpol = spi_sclk_high_idle;
format_config.common_config.cpha = spi_sclk_sampling_even_clk_edges;
spi_format_init(TEST_SPI, &format_config);
spi_master_get_default_control_config(&control_config);
control_config.common_config.trans_mode = spi_trans_write_read;
// 先写数据 → 读取从机数据(读写之间硬件自动插入方向切换周期)
control_config.common_config.data_phase_fmt = spi_single_io_mode;
control_config.common_config.tx_dma_enable = true;
control_config.common_config.rx_dma_enable = true;Slave 端(先读后写)
// 文件:samples/drivers/spi/dma/slave/src/spi.c
spi_slave_get_default_format_config(&format_config);
format_config.common_config.data_len_in_bits = 8;
format_config.common_config.mosi_bidir = true; // ★ MOSI 双向(同样设置)
format_config.common_config.data_merge = false;
format_config.common_config.mode = spi_slave_mode;
format_config.common_config.cpol = spi_sclk_high_idle;
format_config.common_config.cpha = spi_sclk_sampling_even_clk_edges;
spi_format_init(TEST_SPI, &format_config);
spi_slave_get_default_control_config(&control_config);
control_config.common_config.trans_mode = spi_trans_read_write;
// 先接收数据 → 发送数据(读写之间硬件自动插入方向切换周期)
control_config.common_config.data_phase_fmt = spi_single_io_mode;
control_config.common_config.tx_dma_enable = true;
control_config.common_config.rx_dma_enable = true;注意:
Master 和 Slave 使用相反的传输模式(一个 Write→Read,另一个 Read→Write),才能完成双向数据交换。
实验验证
测试环境
spi_sclk_high_idle | |
spi_sclk_sampling_even_clk_edges | |
逻辑分析仪波形
![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图3](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777a7c10a.png)
串口输出结果
收发 128 字节 完全一致,错误计数为 0,验证了单线双向半双工通信的正确性。
适用场景 & 注意事项
适用场景
引脚数受限的传感器互联 需要减少连接器 pin 数的板间通信 半双工协议兼容 一对多星型拓扑(每个从设备仅用 3 根线:SCLK + MOSI + CS)
注意事项
trans_mode 必须互补(写→读 vs 读→写) |
总结
先楫 SPI 的 mosi_bidir 单线双向半双工功能,可以在不牺牲 SPI 协议灵活性的前提下,将引脚数从 4 根减少到 3 根(SCLK + MOSI + CS),对于引脚资源紧张的应用非常有价值。
配合 DMA 搬运,即使是单线模式也能获得不错的整体吞吐率。只需一行配置 mosi_bidir = true,就能让 MOSI 同时扮演"发球员"和"接球员"的角色,实现高效、可靠的双向通信。
![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图4](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777ab820f.jpeg)
先楫半导体
“先楫半导体”(HPMicro)是一家致力于高性能嵌入式解决方案的半导体公司,产品覆盖微控制器及其配套的开发工具和生态系统。公司总部坐落于上海市浦东软件园区,并在天津、苏州和深圳均设立分公司,入选2025年福布斯亚洲Top100最具潜力的企业榜单。先楫半导体以产品质量为本,所有产品均通过严格的可靠性测试。目前已经量产八大系列高性能通用MCU产品,产品性能及通用性领先国际同类产品并通过AEC-Q100认证。公司已完成ISO9001质量管理和ISO 26262/IEC61508功能安全管理体系双认证,全力服务中国乃至全球的工业自动化、机器人、能源和汽车市场。更多信息,请访问 https://hpmicro.com/
![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图5](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777b0929a.png)
![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图6](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777b8252c.jpeg)
![HPM知识库 | [SPI] 单线双向半双工通信功能详解和实践图7](https://xtechcon-static.oss-cn-chengdu.aliyuncs.com/xtimes/xtimes/images/2026-06-25/6a3c777bf1a19.jpeg)