news 2026/3/18 15:30:04

【瑞萨RA × Zephyr评测】DAC-ADC测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【瑞萨RA × Zephyr评测】DAC-ADC测试

📝 调试笔记:Renesas RA 系列 DAC-ADC 闭环测试

硬件: Renesas FPB-RA6E2 (假设) + SSD1306 OLED
目标: 实现 DAC 输出三角波电压,并通过 ADC 实时采样读取,在屏幕和串口同步显示,验证数模转换的准确性。


1. 硬件连接与引脚定义

此实验的核心是闭环测试 (Loopback Test),需要物理连接输出与输入引脚。

功能软件通道 ID物理引脚 (Pin)信号定义接线说明
DAC 输出Channel 0P014Analog Out (DA0)用杜邦线连接到 P013
ADC 输入Channel 11P013Analog In (AN011)连接到 P014
OLED 显示SPI0P109/P111/etcSPI/GPIO依开发板屏幕接口连接

⚠️ 注意: 如果不短接 P014 和 P013,ADC 将测量悬空电压(通常是随机值),DAC 输出也无法被观测到。


2. 软件环境配置 (关键点)

2.1 Device Tree Overlay (app.overlay)

必须明确指定 ADC 和 DAC 的物理引脚绑定,并开启外设状态。

/* DAC 配置 */ &dac0 { status = "okay"; pinctrl-0 = <&dac0_default>; pinctrl-names = "default"; }; &pinctrl { /* DAC0_IVREF (DA0) -> P014 */ dac0_default: dac0_default { group1 { psels = <RA_PSEL(RA_PSEL_DAC, 0, 14)>; renesas,analog-enable; }; }; /* ADC0_AN11 -> P013 */ adc0_default: adc0_default { group1 { psels = <RA_PSEL(RA_PSEL_ADC, 0, 13)>; renesas,analog-enable; }; }; };

2.2 Kconfig 配置 (prj.conf)

确保启用了 DAC 驱动支持。

CONFIG_ADC=y CONFIG_DAC=y <-- 必须开启,否则 dac_dev 获取失败 CONFIG_DISPLAY=y CONFIG_SSD1306=y CONFIG_LOG=y

3. 代码逻辑分析

3.1 核心流程

程序采用简单的while(1)循环结构,实现了信号发生器示波器的双重功能。

  1. 波形生成: 使用step变量控制dac_set_val在 100 到 4000 之间往复增减,形成三角波
  2. DAC 输出: 调用dac_write_value将数字量转换为模拟电压。
  3. 稳定延时:k_busy_wait(1000)(1us) 给 DAC 电容充放电和电压稳定留出时间。
  4. ADC 采样: 调用adc_read读取 P013 引脚上的电压。
  5. 数据可视化: 计算差值,并通过 Log 和 OLED 刷新显示。

3.2 关键 API 变更记录 (踩坑点)

在 Zephyr 4.x 及更高版本中,DAC 的写入 API 发生了重大变化:

  • 旧版 API:dac_write(dev, &cfg_struct)
    • 需要定义结构体struct dac_write_cfg,包含通道、分辨率等信息。
  • 新版 API:dac_write_value(dev, channel, value)
    • 本程序使用此 API。直接传入通道号和数值,简化了调用过程,但导致旧例程编译报错。

4. 实验现象与数据分析

4.1 串口日志 (UART Output)

终端应显示如下数据流:

[00:05:32.618,000] <inf> dac_loopback_test: DAC Set: 2200 | ADC Read: 2132 | Diff: -68 [00:05:32.739,000] <inf> dac_loopback_test: DAC Set: 2300 | ADC Read: 2229 | Diff: -71 [00:05:32.860,000] <inf> dac_loopback_test: DAC Set: 2400 | ADC Read: 2324 | Diff: -76 [00:05:32.981,000] <inf> dac_loopback_test: DAC Set: 2500 | ADC Read: 2419 | Diff: -81 [00:05:33.102,000] <inf> dac_loopback_test: DAC Set: 2600 | ADC Read: 2514 | Diff: -86 [00:05:33.223,000] <inf> dac_loopback_test: DAC Set: 2700 | ADC Read: 2609 | Diff: -91 [00:05:33.344,000] <inf> dac_loopback_test: DAC Set: 2800 | ADC Read: 2704 | Diff: -96 [00:05:33.465,000] <inf> dac_loopback_test: DAC Set: 2900 | ADC Read: 2799 | Diff: -101 ...

4.2 屏幕显示 (OLED)

  • 文本行: 实时显示当前 DAC 设定值和 ADC 读取值。
  • 进度条: 两个矩形条同步伸缩。
    • 上方空心框:代表 DAC (发送端)。
    • 下方实心框:代表 ADC (接收端)。
    • 视觉效果: 两个进度条应该像影子一样紧密跟随,长度几乎一致。

5. 总结

本程序成功演示了 Renesas RA6E2 在 Zephyr RTOS 下的模拟外设控制。代码通过适配最新的驱动 API,建立了一个自发自收的测试系统,直观地展示了嵌入式系统中“数字-模拟-数字”的转换过程。、

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/16 0:20:50

java计算机毕业设计水铁联运系统设计 内河港口—铁路集装箱多式联运信息平台的设计与实现 基于SpringBoot的水运与铁路联合运输作业系统

计算机毕业设计水铁联运系统设计n01h19 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。一箱进口矿石从巴西启程&#xff0c;先漂洋过海抵达长江内河码头&#xff0c;再坐上货运列…

作者头像 李华
网站建设 2026/3/16 0:20:45

为什么顶尖物流企业都在部署仓储Agent?破解空间利用率瓶颈的关键答案

第一章&#xff1a;仓储Agent重构空间利用的底层逻辑在现代分布式仓储系统中&#xff0c;Agent驱动的空间管理机制正逐步替代传统静态分区策略。其核心在于通过动态感知、协同决策与实时调度&#xff0c;实现存储单元的弹性伸缩与高效布局。这一重构并非简单的算法优化&#xf…

作者头像 李华
网站建设 2026/3/16 0:20:49

中国具身智能三大路径:极限挑战、柔性操作、普惠赋能,竞合共生

当人形机器人行走于工厂&#xff0c;四足机器人攀爬于管道&#xff0c;一场关于机器智能如何落地的技术路线竞赛已悄然展开。2025年&#xff0c;中国具身智能领域融资规模呈现爆发式增长。在这片热土上&#xff0c;领军企业们并未遵循单一的发展模式&#xff0c;而是基于对市场…

作者头像 李华
网站建设 2026/3/15 19:32:04

AMAT 0020-21033 刀片

AMAT 0020-21033 刀片相关信息AMAT 0020-21033 是 Applied Materials&#xff08;应用材料公司&#xff09;生产的一款半导体设备刀片组件&#xff0c;通常用于晶圆加工设备中。这类刀片在半导体制造过程中用于切割、抛光或其他精密加工步骤。关键特性兼容性&#xff1a;该刀片…

作者头像 李华
网站建设 2026/3/18 10:44:09

毕业季必看!6款AI论文神器实测:真实参考文献、轻松搞定毕业论文

如果你是正在熬夜赶Deadline的毕业生... 如果你正盯着电脑屏幕发呆&#xff0c;被导师的“进度催命符”轰炸&#xff1b;如果你翻遍知网只为找几篇能用的参考文献&#xff0c;却被高昂的查重费压得喘不过气&#xff1b;如果你是囊中羞涩的大学生&#xff0c;或是怕延毕的研究生…

作者头像 李华