0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

CW32L083模拟电压比较器的使用

武汉芯源半导体有限公司 2022-12-20 14:44 次阅读

CW32L083 内部集成 2 个模拟电压比较器(VC),用于比较两路模拟输入电压,并将比较结果从引脚输出。两路信号的正端支持8路外部模拟输入,负端既支持外部输入,也支持内部电压基准等四种内部电压参考。比较结果输出具有滤波功能、迟滞窗口功能,以及极性选择。支持比较中断,可用于低功耗模式下唤醒 MCU

模拟电压比较器主要特性

• 双路模拟电压比较器 VC1、VC2

• 内部64阶电阻分压器

• 多达8路外部模拟信号输入

• 4路片内模拟输入信号

- 内置电阻分压器输出电压

- 内置温度传感器输出电压

- 内置1.2V基准电压

- ADC参考电压

• 可选择输出极性

• 支持迟滞窗口比较功能

• 可编程滤波器和滤波时间

• 3种中断触发方式,可组合使用

- 高电平触发

- 上升沿触发

- 下降沿触发

• 支持低功耗模式下运行,中断唤醒 MCU

下图为模拟电压比较器的功能框图:

pYYBAGOhWPyALXJEAANS13DYdI4770.jpg

VC模拟电压比较器将两路模拟信号比较时可配置多种参数,如VC1_CR0.EN和VC1_CR0.HYS位分别控制VC使能及VC迟滞窗口配置。VC1_CR0.POL控制输出结果极性,后端还有窗口比较功能配置及数字滤波模块的配置。

VC1、VC2 的正负端输入选择,由控制寄存器 VCx_CR0 的 INP、INN 位域选择,如下表所示:

poYBAGOhWPuAa6drAAGx6s8FHMI172.jpg

模拟电压比较器支持 8路外部模拟信号输入,用户必须将对应 GPIO端口配置为模拟功能(GPIOx_ANALOG.PINy = 1)。模拟电压比较器支持将比较结果从引脚输出,用户必须将对应 GPIO 端口配置为数字输出,同时选择功能复用。VC1、VC2 支持的输入输出引脚如下表所示:

pYYBAGOhWPuAd_SoAAJJNh9DzBg778.jpg

模拟电压比较器还具有延迟/响应时间配置,从VC使能或VC的正负两端输入电压变化,到电压比较器输出正确比较结果的时间,被定义为比较器的延迟/响应时间。延迟/响应时间由控制寄存器 VCx_CR0 的 RESP 位域配置,响应时间值从200ns到20μs四档可调。

模拟电压比较器可进行输出极性选择,由控制寄存器VCx_CR0的POL位域设置,POL为1,即正端大于负端时VCx输出低电平;POL为0,正端大于负端时VCx输出高电平。

模拟电压比较器具有数字滤波功能,电压比较器内置的数字滤波器,用于对电压比较器的输出信号进行数字滤波,由控制寄存器VCx_CR1的FLTEN位域控制,FLTEN为1使能数字滤波,FLTEN为0禁止数字滤波。

模拟电压比较器支持迟滞功能,使用迟滞功能后,比较器的输出结果不会随输入信号的变化而立即翻转,而是在两路输入信号的偏移值高于或低于迟滞阈值电压后才发生翻转。迟滞阈值电压由控制寄存器VCx_CR0的HYS位域决定,配置为00时,没有迟滞;配置为01时迟滞窗口大约10mV;配置为10时,迟滞窗口大约为20mV;配置为11时,迟滞窗口大约30mV。

模拟电压比较器支持窗口比较功能,可将VC1和VC2的比较结果进行异或操作后输出,由控制寄存器VCx_CR0的WINDOW位域使能。WINDOW为1时,VCx_OUTW信号为 VC1_OUTP信号与VC2_OUTP 信号的异或值;WINDOW为0时,VCx_OUTW信号与VCx_OUTP 信号电平相同。

模拟电压比较器支持BLANK窗口功能,在保持VCx模块工作的同时,如果想暂时停止电压比较功能,或者为避免某些应用系统(比如电机控制)中,被监测信号短时间的合理波动造成电压比较器的输出电平发生不必要的翻转,本芯片的电压比较器增加了BLANK窗口功能,即当指定的外部触发条件启动BLANK窗口时,在设定的BLANK窗口期内,不进行电压比较,电压比较器的输出电平保持当前电平状态。BLANK窗口期之后,电压比较器恢复正常工作。BLANK窗口持续时间,由控制寄存器 VCx_CR1的BLANKFLT位域配置。BLANK窗口的触发启动条件,由控制寄存器VCx_CR1的 BLANKCH1B、BLANKCH2B、BLANKCH3B位域配置,分别由ATIM的CH1B、CH2B、CH3B上升沿触发启动BLANK窗口。

CW32L083 的电压比较器支持在低功耗模式下工作,比较中断可将芯片从低功耗模式下唤醒。设置控制寄存器 VCx_CR0 的 IE 位域为 1,使能 VCx 中断,产生中断时状态寄存器 VCx_SR 的中断标志位 INTF 会 被硬件置 1,用户可以向 INTF 位写 0,清除中断标志。

设置控制寄存器 VCx_CR1 的 HIGHIE、RISEIE、FALLIE 位域,可选择不同的中断触发方式:

• HIGHIE 为 1,VCx_OUT 输出信号高电平触发中断

• RISEIE 为 1,VCx_OUT 输出信号上升沿触发中断

• FALLIE 为 1,VCx_OUT 输出信号下降沿触发中断

根据上述内容介绍以下例程,通过VC模块输出信号的上升沿/下降沿触发中断功能。

//VC I/O初始化

void VC_PortInit(void)

{

GPIO_InitTypeDef GPIO_InitStructure = {0};

//打开GPIO时钟

REGBITS_SET( CW_SYSCTRL->AHBEN, SYSCTRL_AHBEN_GPIOA_Msk );

//打开VC时钟

REGBITS_SET( CW_SYSCTRL->APBEN2, SYSCTRL_APBEN2_VC_Msk );

//set PA11 as output

GPIO_InitStructure.Pins = GPIO_PIN_11;

GPIO_InitStructure.Mode = GPIO_MODE_OUTPUT_PP;

GPIO_Init(CW_GPIOA, &GPIO_InitStructure);

//set PA11 as VC output

PA11_AFx_VC1OUT();

//set PA00 as VC1_CH0 P-INPUT

PA00_ANALOG_ENABLE();

//set PA01 as VC1_CH1 N-INPUT

PA01_ANALOG_ENABLE();

}

int main(void)

{

VC_InitTypeDef VC_InitStruct = {0};

VC_BlankTypeDef VC_BlankStruct = {0};

VC_OutTypeDef VC_OutStruct = {0};

//LED初始化

LED_Init();

//配置测试IO口

VC_PortInit();

//VC通道初始化

VC_InitStruct.VC_InputP = VC_InputP_Ch0;//将VC正端输入为PA00的输入信号

VC_InitStruct.VC_InputN = VC_InputN_Bgr1P2; //将VC负端输入设置为内部1.2V基准电压

VC_InitStruct.VC_Hys = VC_Hys_10mV;//将VC迟滞功能配置为10mV

VC_InitStruct.VC_Resp = VC_Resp_High;//VC反应速度为高速

VC_InitStruct.VC_FilterEn = VC_Filter_Enable;//VC数字滤波模块开启

VC_InitStruct.VC_FilterClk = VC_FltClk_RC150K;//VC数字滤波时钟为150KHz的RC振荡器

VC_InitStruct.VC_FilterTime = VC_FltTime_4095Clk;//VC的数字滤波时间配置为滤波小于4095个时钟信号

VC_InitStruct.VC_Window = VC_Window_Disable;//VC窗口比较功能关闭

VC_InitStruct.VC_Polarity = VC_Polarity_Low;

VC1_ChannelInit(&VC_InitStruct);

//VC Blank窗口初始化

VC1VC2_BlankInit(&VC_BlankStruct);

VC1_BlankCfg(&VC_BlankStruct);

//VC输出连接初始化

VC1VC2_OutInit(&VC_OutStruct);

VC1_OutputCfg(&VC_OutStruct);

//VC中断设置

VC1_ITConfig(VC_IT_FALL | VC_IT_RISE, ENABLE);

VC1_EnableIrq(VC_INT_PRIORITY);

VC1_ClearIrq();

VC1_EnableChannel();

while (1)

{

if(gFlagIrq)

{

PC03_TOG();

gFlagIrq = FALSE;

}

}

}

//LED I/O初始化

void LED_Init(void)

{

GPIO_InitTypeDef GPIO_InitStructure = {0};

//打开GPIOC时钟

REGBITS_SET(CW_SYSCTRL->AHBEN, SYSCTRL_AHBEN_GPIOC_Msk);

GPIO_InitStructure.Pins = GPIO_PIN_2 | GPIO_PIN_3;

GPIO_InitStructure.Mode = GPIO_MODE_OUTPUT_PP;

GPIO_Init(CW_GPIOC, &GPIO_InitStructure);

//LED的初始状态为灭

PC02_SETLOW();

PC03_SETLOW();

}

//VC1的中断服务函数

void VC1_IRQHandler(void)

{

VC1_ClearIrq();

gFlagIrq = TRUE;

}

实验现象

使用电源向PA00输入电压,PA11被复用为VC1的比较结果输出引脚,当电压大于1.2V时, PA11输出高电平,当PA00输入电压小于1.2V时,PA11输出低电平,而当PA00的输入电压由1.2V以下变为1.2V以上或者从1.2V以上变为1.2V以下,LED的状态会发生翻转。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6011

    文章

    44153

    浏览量

    624391
  • mcu
    mcu
    +关注

    关注

    146

    文章

    16211

    浏览量

    345511
收藏 人收藏

    评论

    相关推荐

    请问如何优化CW32L083微控制的功耗?

    在进行低功耗设计时,如何优化CW32L083系列微控制的功耗?
    发表于 01-17 07:16

    CW32L083系列微控制的ADC和DAC模块要如何使用?怎么配置?

    如何配置和使用CW32L083系列微控制的ADC和DAC模块?
    发表于 01-17 06:08

    CW32L083如何实现AUTOTRIM时钟校准?

    CW32L083如何实现AUTOTRIM时钟校准?
    的头像 发表于 11-07 17:17 342次阅读
    <b class='flag-5'>CW32L083</b>如何实现AUTOTRIM时钟校准?

    CW32L083的UART单线半双工模式介绍

    CW32L083的UART单线半双工模式介绍
    的头像 发表于 10-24 17:49 642次阅读
    <b class='flag-5'>CW32L083</b>的UART单线半双工模式介绍

    CW32L083VxTx StartKit用户使用手册

    按照下列步骤配置 CW32L083VxTx StartKit 评估板: 1. 确认评估板上跳线帽的位置(参见表 5-1 跳线配置); 2. 连接 CW-DAPLINK 调试,确认主机端驱动程序已经
    发表于 09-15 07:07

    CW32L083 StartKit软件包分享

    CW32L083 StartKit软件包
    发表于 09-15 07:00

    CW32L083用户手册

    CW32L083核心是32位ARM®Cortex®-M0+微处理,最大寻址空间为4GB。芯片的内置程序存储、数据存储、外围设备和端口寄存
    发表于 09-14 07:02

    CW32L083产品介绍

    CW32L083是一款基于eFlash的单芯片低功耗微控制,集成了ARM®Cortex®-M0+ 核心,主频高达64MHz,高速嵌入式存储(高达256K字节的FLASH和 高达24K字节
    发表于 09-14 06:41

    CW32L083微控制数据手册

    定时以及一组高级控制 PWM 定时CW32L083 可以在 -40° C 到 85° C 的温度范围内工作,供电电压宽达 1.65V ~ 5.5V。支持 Sleep 和 Deep
    发表于 09-14 06:27

    CW32L083微处理器用户手册

    CW32L083 内核为 32 位的 ARM® Cortex®-M0+ 微处理,最大寻址空间为 4GB。芯片内置的程序存储、数据存储、各外设及端口寄存
    发表于 09-14 06:09

    32位低功耗微控制器CW32L083简介

    摘要:在嵌入式系统设计中,设计师需要特别考虑低功耗,因为这类系统通常用于移动设备和便携产品,其电源供应有限,主要依赖电池供电。因此,设计师必须仔细考虑各个细节,以减少功耗,延长电池寿命。为此,绝大多数芯片都提供了低功耗模式。以CW32L083为例,这是一款32位低功耗微控制器。
    发表于 09-13 09:20 533次阅读
    32位低功耗微控制器<b class='flag-5'>CW32L083</b>简介

    基于CW32L083评估板的简易低功耗功能测试

    使用CW32L083的评估板完成简易低功耗例程实验。
    的头像 发表于 08-28 14:16 506次阅读
    基于<b class='flag-5'>CW32L083</b>评估板的简易低功耗功能测试

    CW32L083串口中断+定时器实现不定长数据接收

    CW32L083 用串口中断加定时器中断实现串口的不定长数据的接收,特别适用于AT指令的接收。
    的头像 发表于 07-12 09:00 1303次阅读
    <b class='flag-5'>CW32L083</b>串口中断+定时器实现不定长数据接收

    CW32L083移植驱动st7735 TFT屏

    CW32L083上驱动ST7735屏
    的头像 发表于 07-04 19:16 1202次阅读
    <b class='flag-5'>CW32L083</b>移植驱动st7735 TFT屏

    移植RT-Thread nano到CW32L083

    移植RT-Thread Nano到CW32L083开发板上,并成功运行。
    的头像 发表于 07-03 09:04 2.2w次阅读
    移植RT-Thread nano到<b class='flag-5'>CW32L083</b>