mtk平台adc学习笔记
以下是针对 MTK平台ADC驱动开发 的学习笔记整理,重点涵盖硬件架构、软件驱动框架和关键代码实现,适用于嵌入式Linux/Android系统开发人员:
一、硬件基础
-
ADC控制器
- MTK SoC内置多路ADC,通常为12-bit精度,支持差分/单端输入模式。
- 关键参数:
- 采样率:典型值 500Ksps(不同平台有差异)
- 输入电压范围:0V ~ 1.8V 或 0V ~ 3.3V(需查数据手册)
- 通道数:8~16路(如MT6765支持12通道)
-
信号通路
传感器 → 外部RC滤波 → MTK ADC引脚 (AUX_INx) → 内部多路复用器 → ADC核心 → APB总线
二、Linux驱动框架
MTK ADC驱动基于 Linux IIO子系统 实现:
drivers/iio/adc/mt6370_adc.c # PMIC内置ADC示例
drivers/iio/adc/mtk_auxadc.c # SoC内置ADC主驱动
关键结构体
struct mtk_auxadc_device {
void __iomem *reg_base;
struct clk *adc_clk;
struct mutex lock;
};
struct iio_dev *indio_dev; // IIO设备核心结构
三、设备树(DTS)配置
&auxadc {
compatible = "mediatek,mt6577-auxadc";
reg = <0x11001000 0x1000>; // AUXADC寄存器基址
clocks = <&clk26m>; // 时钟源
clock-names = "main";
#io-channel-cells = <1>; // 每个通道独立标识
};
/* 使用ADC通道示例 */
bat_thermistor {
compatible = "mediatek,bat_therm";
io-channels = <&auxadc 0>; // 使用通道0
io-channel-names = "batt_therm";
};
四、驱动核心流程
1. 通道初始化
static const struct iio_chan_spec mtk_auxadc_channels[] = {
AUXADC_CHANNEL(0, "CH0"), // 通道0:电池电压
AUXADC_CHANNEL(1, "CH1"), // 通道1:充电电流
};
2. 数据采集函数
static int mtk_auxadc_read_raw(struct iio_dev *indio_dev,...){
// 启动转换
writel(MTK_AUXADC_CON_V | MTK_AUXADC_CON1_CHANNEL(channel),
base + MTK_AUXADC_CON1);
// 等待转换完成 (超时机制)
while (timeout--) {
if (readl(base + MTK_AUXADC_STA) & BIT_ADC_DONE)
break;
}
// 读取ADC原始值
*val = readl(base + MTK_AUXADC_DAT0) & MTK_AUXADC_DATA_MASK;
return IIO_VAL_INT;
}
五、校准处理
MTK ADC需校准以减少误差:
// 应用校准系数(通常存放在NVRAM)
raw_value = read_adc_channel(0);
calibrated_value = (raw_value - offset) * slope / 1000 + temp_offset;
提示:校准参数通过工厂测试写入,存储在
/persist/adc_calib.bin
六、用户空间访问
-
通过sysfs读取:
cat /sys/bus/iio/devices/iio\:device0/in_voltage0_raw # 通道0原始值 -
通过IIO API读取(推荐):
int fd = open("/dev/iio:device0", O_RDONLY); ioctl(fd, IIO_GET_EVENT_FD_IOCTL, &event_fd);
七、常见问题解决
-
ADC采样值跳变
- 检查PCB布局:模拟信号远离高频线路
- 增加RC滤波(e.g., 10KΩ + 100nF)
-
转换超时错误
- 确认ADC时钟是否使能:
clk_prepare_enable(adc->adc_clk); - 检查DTS中clock配置是否正确
- 确认ADC时钟是否使能:
-
精度不足
- 开启多次采样取平均:
for(int i=0; i<4; i++) sum += read_adc(); adc_value = sum / 4;
- 开启多次采样取平均:
八、关键寄存器映射
| 寄存器偏移 | 名称 | 功能描述 |
|---|---|---|
| 0x0000 | AUXADC_CON0 | ADC全局控制 |
| 0x0008 | AUXADC_CON1 | 通道选择/启动转换 |
| 0x0100 | AUXADC_DAT0 | 通道0数据寄存器 |
| 0x0214 | AUXADC_STA | 状态寄存器(BIT_ADC_DONE) |
九、扩展功能
-
温度传感器接入
通过AUXADC读取NTC电阻值,需在驱动中实现查表法:static const int bat_temp_table[] = { /* -20℃ */ 125000, /* -10℃ */ 85000, /* 0℃ */ 60000, // 根据实际NTC B值表填充 }; -
充电电流检测
连接电流检测电阻至ADC,计算算法:current_ma = (adc_value * 1800 / 4096) / (0.1 * 1000); // 0.1Ω采样电阻
完整代码示例:
? MTK AUXADC驱动参考实现(官方GitHub仓库)
建议结合具体平台数据手册(如《MT6765_Datasheet》第12章)和实际硬件原理图进行调试。
Nucleo平台sleep和deepsleep模式的学习资料
本笔记以 Nucleo-F103RB 为平台,基于mbed平台的C语言开发,是一个系列课程,欢迎大家下载
ADC学习笔记(二)
使用和处理信息,就需要将模拟量转换为数字量,并传送到微控制器或微处理器。 那么ADC转换是如何实现的呢? 这是一个什么样的过程? 阅读下面的笔记,你一定会对模数转换器有更全面、更系统的了解。
2023-02-09 12:21:17
MSP430 G2553 学习笔记--ADC模块
MSP430 G2553 学习笔记--ADC模块(通信电源技术是省刊吗)-文档为MSP430 G2553
资料下载
李勇
2021-09-18 16:20:31
cortex_m3_stm32嵌入式学习笔记16之ADC资料下载
电子发烧友网为你提供cortex_m3_stm32嵌入式学习笔记16之ADC资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文
资料下载
吴湛
2021-04-28 08:44:11
ADC学习笔记(一)
信息,就需要将模拟量转换为数字量,并传送到微控制器或微处理器。那么ADC转换是如何实现的呢?这是一个什么样的过程?阅读下面的笔记,你一定会对模数转换器有更全面、更系统的了解。
2023-02-09 12:09:19
Arduino学习笔记
1.前言 近段时间,博主陆续更新了ESP8266学习笔记,主要开发平台是Arduino。但是,对于很多无基础的初学者来说,甚至不了解Ard
换一换
- 如何分清usb-c和type-c的区别
- 中国芯片现状怎样?芯片发展分析
- vga接口接线图及vga接口定义
- 芯片的工作原理是什么?
- 华为harmonyos是什么意思,看懂鸿蒙OS系统!
- 什么是蓝牙?它的主要作用是什么?
- ssd是什么意思
- 汽车电子包含哪些领域?
- TWS蓝牙耳机是什么意思?你真的了解吗
- 什么是单片机?有什么用?
- 升压电路图汇总解析
- plc的工作原理是什么?
- 再次免费公开一肖一吗
- 充电桩一般是如何收费的?有哪些收费标准?
- ADC是什么?高精度ADC是什么意思?
- EDA是什么?有什么作用?
- dtmb信号覆盖城市查询
- 苹果手机哪几个支持无线充电的?
- type-c四根线接法图解
- 华为芯片为什么受制于美国?
- 怎样挑选路由器?
- 元宇宙概念股龙头一览
- 锂电池和铅酸电池哪个好?
- 什么是场效应管?它的作用是什么?
- 如何进行编码器的正确接线?接线方法介绍
- 虚短与虚断的概念介绍及区别
- 晶振的作用是什么?
- 大疆无人机的价格贵吗?大约在什么价位?
- 苹果nfc功能怎么复制门禁卡
- 单片机和嵌入式的区别是什么
- amoled屏幕和oled区别
- 复位电路的原理及作用
- BLDC电机技术分析
- dsp是什么意思?有什么作用?
- 苹果无线充电器怎么使用?
- iphone13promax电池容量是多少毫安
- 芯片的组成材料有什么
- 特斯拉充电桩充电是如何收费的?收费标准是什么?
- 直流电机驱动电路及原理图
- 传感器常见类型有哪些?
- 自举电路图
- 通讯隔离作用
- 苹果笔记本macbookpro18款与19款区别
- 新斯的指纹芯片供哪些客户
- 伺服电机是如何进行工作的?它的原理是什么?
- 无人机价钱多少?为什么说无人机烧钱?
- 以太网VPN技术概述
- 手机nfc功能打开好还是关闭好
- 十大公认音质好的无线蓝牙耳机
- 元宇宙概念龙头股一览