震惊,ADC时钟频率不是84Mhz?

前言

单片机只能去处理数字量(0 / 1),但不能去处理一些多值数据(模拟电压值),如果需要处理模拟量,需要借助模数转换器(ADC)进行转换,把模拟量转换为MCU可以处理的离散数字量。

一、ADC时钟说明

由时钟树我们可知,ADC挂载在APB2上,那么它的频率本应该是84Mhz,但事实果真如此吗?其实不是的,因为ADC模数转换器的时钟频率会有一个限制 ,如果ADC超过限制频率运行的话,会导致ADC转换失败,所以需要利用ADC预分频器将ADC频率控制在限制范围内。

二、ADC频率限制范围

在这里插入图片描述

由芯片数据手册可知,ADC低速模式下的电压为1.8-2.4V,全速模式下的电压为2.4-3.6V,当处于全速运行模式,STM32F407VET6中的3个ADC最大频率可以设置为36Mhz,如果要选择36Mhz,我们可以通过ADC预分频器对APB2时钟频率进行分频,使其接近或者等于36Mhz。

三、ADC预分频器

在这里插入图片描述
由中文参考手册可知,ADC预分频器位于通用控制寄存器 (ADC_CCR)的16-17位,分别有2,4,6,8分频,假设我们选择4分频,则ADC的时钟频率为84 / 4 = 21Mhz

总结

当使用STM32的ADC时,ADC的时钟频率需要查数据手册和结合寄存器的位获得,并且每一个不同内核STM32芯片,fadc大都不一样。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值