DAC详解_什么是DAC

(3) 2024-06-18 18:12

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说
DAC详解_什么是DAC,希望能够帮助你!!!。

文章目录

  • 前言
    • 数字/模拟转换(DAC)
  • 一、DAC简介
  • 二、DAC主要特征
  • 三、DAC功能描述
    • 使能DAC通道
    • 使能DAC输出缓存
    • DAC数据格式
    • DAC转换
    • DAC输出电压
    • 选择DAC触发
    • DMA请求
    • 噪声生成
    • 三角波生成
  • 四、双DAC通道转换
    • 不使用波形发生器的独立触发
    • 使用相同LFSR的独立触发
    • 使用不同LFSR的独立触发
    • 产生相同三角波的独立触发
    • 产生不同三角波的独立触发
    • 同时软件启动
    • 不使用波形发生器的同时触发
    • 使用相同LFSR的同时触发
    • 使用不同LFSR的同时触发
    • 使用相同三角波发生器的同时触发
    • 使用不同三角波发生器的同时触发
  • 五、DAC寄存器
    • DAC控制寄存器(DAC_CR)
    • DAC软件触发寄存器(DAC_SWTRIGR)
    • DAC通道 1 的 12 位右对齐数据保持寄存器(DAC_DHR12R1)
    • DAC通道 1 的 12 位左对齐数据保持寄存器(DAC_DHR12L1)
    • DAC通道 1 的 8 位右对齐数据保持寄存器(DAC_DHR8R1)
    • DAC通道 2 的 12 位右对齐数据保持寄存器(DAC_DHR12R2)
    • DAC通道 2 的 12 位左对齐数据保持寄存器(DAC_DHR12L2)
    • DAC通道 2 的 8 位右对齐数据保持寄存器(DAC_DHR8R2)
    • 双DAC的 12 位右对齐数据保持寄存器(DAC_DHR12RD)
    • 双DAC的 12 位左对齐数据保持寄存器(DAC_DHR12LD)
    • 双DAC的 8 位右对齐数据保持寄存器(DAC_DHR8RD)
    • DAC通道 1 数据输出寄存器(DAC_DOR1)
    • DAC通道 2 数据输出寄存器(DAC_DOR2)
    • DAC寄存器映像

前言

数字/模拟转换(DAC)

小容量产品是指闪存存储器容量在16K至32K字节之间的STM32F101xx、STM32F102xx和STM32F103xx微控制器。

中容量产品是指闪存存储器容量在64K至128K字节之间的STM32F101xx、STM32F102xx和STM32F103xx微控制器。

大容量产品是指闪存存储器容量在256K至512K字节之间的STM32F101xx和STM32F103xx微控制器。

互联型产品是指STM32F105xx和STM32F107xx微控制器。
本节内容只适用于大容量的STM32F101xx和STM32F103xx产品。

一、DAC简介

数字/模拟转换模块(DAC)是12位数字输入,电压输出的数字/模拟转换器。DAC可以配置为8位 或12位模式,也可以与DMA控制器配合使用。DAC工作在12位模式时,数据可以设置成左对齐或右对齐。DAC模块有2个输出通道,每个通道都有单独的转换器。在双DAC模式下,2个通道可以独立地进行转换,也可以同时进行转换并同步地更新2个通道的输出。DAC可以通过引脚输入参考电压VREF+以获得更精确的转换结果。

二、DAC主要特征

2个DAC转换器:每个转换器对应1个输出通道
8位或者12位单调输出
12位模式下数据左对齐或者右对齐
同步更新功能
噪声波形生成
三角波形生成
双DAC通道同时或者分别转换
每个通道都有DMA功能
外部触发转换
输入参考电压VREF+182/754

单个DAC通道的框图如下图,下表给出了引脚的说明。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第1张

三、DAC功能描述

使能DAC通道

将DAC_CR寄存器的ENx位置’1’即可打开对DAC通道x的供电。经过一段启动时间tWAKEUP,DAC通道x即被使能。

注意: ENx位只会使能DAC通道x的模拟部分,即便该位被置’0’,DAC通道x的数字部分仍然工作。

使能DAC输出缓存

DAC集成了2个输出缓存,可以用来减少输出阻抗,无需外部运放即可直接驱动外部负载。每个DAC通道输出缓存可以通过设置DAC_CR寄存器的BOFFx位来使能或者关闭。

DAC数据格式

根据选择的配置模式,数据按照下文所述写入指定的寄存器:
● 单DAC通道x,有3种情况:
─ 8位数据右对齐:用户须将数据写入寄存器DAC_DHR8Rx[7:0]位(实际是存入寄存器DHRx[11:4]位)
─ 12位数据左对齐:用户须将数据写入寄存器DAC_DHR12Lx[15:4]位(实际是存入寄存器DHRx[11:0]位)
─ 12位数据右对齐:用户须将数据写入寄存器DAC_DHR12Rx[11:0]位(实际是存入寄存器DHRx[11:0]位)

根据对DAC_DHRyyyx寄存器的操作,经过相应的移位后,写入的数据被转存到DHRx寄存器中(DHRx是内部的数据保存寄存器x)。随后,DHRx寄存器的内容或被自动地传送到DORx寄存器,或通过软件触发或外部事件触发被传送到DORx寄存器。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第2张
● 双DAC通道,有3种情况:
─ 8位数据右对齐:用户须将DAC通道1数据写入寄存器DAC_DHR8RD[7:0]位(实际是存入寄存器DHR1[11:4]位),将DAC通道2数据写入寄存器DAC_DHR8RD[15:8]位(实际是存入寄存器DHR2[11:4]位)
─ 12位数据左对齐:用户须将DAC通道1数据写入寄存DAC_DHR12LD[15:4]位(实际是存入寄存器DHR1[11:0]位),将DAC通道2数据写入寄存器DAC_DHR12LD[31:20]位(实际是存入寄存器DHR2[11:0]位)
─ 12位数据右对齐:用户须将DAC通道1数据写入寄存DAC_DHR12RD[11:0]位(实际是存入寄存器DHR1[11:0]位),将DAC通道2数据写入寄存器DAC_DHR12RD[27:16]位(实际是存入寄存器DHR2[11:0]位)

根据对DAC_DHRyyyD寄存器的操作,经过相应的移位后,写入的数据被转存到DHR1和DHR2寄存器中(DHR1和DHR2是内部的数据保存寄存器x)。随后,DHR1和DHR2的内容或被自动地传送到DORx寄存器,或通过软件触发或外部事件触发被传送到DORx寄存器。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第3张

DAC转换

不能直接对寄存器DAC_DORx写入数据,任何输出到DAC通道x的数据都必须写入DAC_DHRx寄存器(数据实际写入DAC_DHR8Rx、DAC_DHR12Lx、DAC_DHR12Rx、DAC_DHR8RD、DAC_DHR12LD、或者DAC_DHR12RD寄存器)。如果没有选中硬件触发(寄存器DAC_CR1的TENx位置’0’),存入寄存器DAC_DHRx的数据会在一个APB1时钟周期后自动传至寄存器DAC_DORx。如果选中硬件触发(寄存器DAC_CR1的TENx位置’1’),数据传输在触发发生以后3个APB1时钟周期后完成。一旦数据从DAC_DHRx寄存器装入DAC_DORx寄存器,在经过时间tSETTLING之后,输出即有效,这段时间的长短依电源电压和模拟输出负载的不同会有所变化。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第4张

DAC输出电压

数字输入经过DAC被线性地转换为模拟电压输出,其范围为0到VREF+。
任一DAC通道引脚上的输出电压满足下面的关系:
DAC输出 = VREF x (DOR / 4095)。

选择DAC触发

如果TENx位被置1,DAC转换可以由某外部事件触发(定时器计数器、外部中断线)。配置控制位TSELx[2:0]可以选择8个触发事件之一触发DAC转换。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第5张
每次DAC接口侦测到来自选中的定时器TRGO输出,或者外部中断线9的上升沿,最近存放在寄存器DAC_DHRx中的数据会被传送到寄存器DAC_DORx中。在3个APB1时钟周期后,寄存器DAC_DORx更新为新值。如果选择软件触发,一旦SWTRIG位置’1’,转换即开始。在数据从DAC_DHRx寄存器传送到DAC_DORx寄存器后,SWTRIG位由硬件自动清’0’。

注意:

  1. 不能在ENx为’1’时改变TSELx[2:0]位。
  2. 如果选择软件触发,数据从寄存器DAC_DHRx传送到寄存器DAC_DORx只需要一个APB1时钟周期。

DMA请求

任一DAC通道都具有DMA功能。2个DMA通道可分别用于2个DAC通道的DMA请求。如果DMAENx位置’1’,一旦有外部触发(而不是软件触发)发生,则产生一个DMA请求,然后DAC_DHRx寄存器的数据被传送到DAC_DORx寄存器。在双DAC模式下,如果2个通道的DMAENx位都为’1’,则会产生2个DMA请求。如果实际只需要一个DMA传输,则应只选择其中一个DMAENx位置’1’。这样,程序可以在只使用一个DMA请求,一个DMA通道的情况下,处理工作在双DAC模式的2个DAC通道。DAC的DMA请求不会累计,因此如果第2个外部触发发生在响应第1个外部触发之前,则不能处理第2个DMA请求,也不会报告错误。

噪声生成

可以利用线性反馈移位寄存器(Linear Feedback Shift Register LFSR)产生幅度变化的伪噪声。设置WAVE[1:0]位为’01’选择DAC噪声生成功能。寄存器LFSR的预装入值为0xAAA。按照特定算法,在每次触发事件后3个APB1时钟周期之后更新该寄存器的值。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第6张
设置DAC_CR寄存器的MAMPx[3:0]位可以屏蔽部分或者全部LFSR的数据,这样的得到的LSFR值与DAC_DHRx的数值相加,去掉溢出位之后即被写入DAC_DORx寄存器。如果寄存器LFSR值为0x000,则会注入’1’(防锁定机制)。 将WAVEx[1:0]位置’0’可以复位LFSR波形的生成算法。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第7张

三角波生成

可以在DC或者缓慢变化的信号上加上一个小幅度的三角波。设置WAVEx[1:0]位为’10’选择DAC的三角波生成功能。设置DAC_CR寄存器的MAMPx[3:0]位来选择三角波的幅度。内部的三角波计数器每次触发事件之后3个APB1时钟周期后累加1。计数器的值与DAC_DHRx寄存器的数值相加并丢弃溢出位后写入DAC_DORx寄存器。在传入DAC_DORx寄存器的数值小于MAMP[3:0]位定义的最大幅度时,三角波计数器逐步累加。一旦达到设置的最大幅度,则计数器开始递减,达到0后再开始累加,周而复始。将WAVEx[1:0]位置’0’可以复位三角波的生成。
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第8张

四、双DAC通道转换

在需要2个DAC同时工作的情况下,为了更有效地利用总线带宽,DAC集成了3个供双DAC模式使用的寄存器:DHR8RD、DHR12RD和DHR12LD,只需要访问一个寄存器即可完成同时驱动2个DAC通道的操作。

对于双DAC通道转换和这些专用寄存器,共有11种转换模式可用。这些转换模式在只使用一个DAC通道的情况下,仍然可通过独立的DHRx寄存器操作。

不使用波形发生器的独立触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为不同值,分别配置2个DAC通道的不同触发源;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生DAC通道1触发事件时,(延迟3个APB1时钟周期后)寄存器DHR1的值传入寄存器DAC_DOR1。
当发生DAC通道2触发事件时,(延迟3个APB1时钟周期后)寄存器DHR2的值传入寄存器
DAC_DOR2。

使用相同LFSR的独立触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为不同值,分别配置2个DAC通道的不同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为”01”,并设置MAMPx[3:0]为相同的LFSR屏蔽值;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生DAC通道1触发事件时,具有相同屏蔽的LFSR1计数器值与DHR1寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新LFSR1计数器。
当发生DAC通道2触发事件时,具有相同屏蔽的LFSR2计数器值与DHR2寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

使用不同LFSR的独立触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为不同值,分别配置2个DAC通道的不同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为”01”,并设MAMPx[3:0]为不同的LFSR屏蔽值;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或者DHR8RD)。

当发生DAC通道1触发事件时,按照MAMP1[3:0]所设屏蔽的LFSR1计数器值与DHR1寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新LFSR1计数器。
当发生DAC通道2触发事件时,按照MAMP2[3:0]所设屏蔽的LFSR2计数器值与DHR2寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

产生相同三角波的独立触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为不同值,分别配置2个DAC通道的不同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为”1x”,并设MAMPx[3:0]为相同的三角波幅值;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生DAC通道1触发事件时,相同的三角波幅值加上DHR1寄存器的值,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新DAC通道1三角波计数器。
当发生DAC通道2触发事件时,相同的三角波幅值加上DHR2寄存器的值,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新DAC通道2三角波计数器。

产生不同三角波的独立触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为不同值,分别配置2个DAC通道的不同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为’1x’,并设MAMPx[3:0]为不同的三角波幅值。
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生DAC通道1触发事件时,MAMP1[3:0]所设的三角波幅值加上DHR1寄存器数值,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新DAC通道1三角波计数器。
当发生DAC通道2触发事件时,MAMP2[3:0]所设的三角波幅值加上DHR2寄存器数值,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新DAC通道2三角波计数器。

同时软件启动

按照下列过程设置DAC工作在此转换模式:
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

在此配置下,一个APB1时钟周期后,DHR1和DHR2寄存器的数值即被分别传入DAC_DOR1和DAC_DOR2寄存器。

不使用波形发生器的同时触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为相同值,分别配置2个DAC通道使用相同触发源;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生触发事件时,(延迟3个APB1时钟周期后)DHR1和DHR2寄存器的数值分别传入DAC_DOR1和DAC_DOR2寄存器。

使用相同LFSR的同时触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为相同值,分别配置2个DAC通道使用相同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为”01”,并设MAMPx[3:0]为相同的LFSR屏蔽值;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD);

当发生触发事件时,MAMP1[3:0]所设屏蔽的LFSR1计数器值与DHR1寄存器的数值相加,(延迟3个APB1时钟周期后)结果传入DAC_DOR1寄存器,然后更新LFSR1计数器。
同样,MAMP1[3:0]所设屏蔽的LFSR2计数器值与DHR2寄存器的数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

使用不同LFSR的同时触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’;
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为相同值,分别配置2个DAC通道使用相同触发源;
● 设置2个DAC通道的WAVEx[1:0]位为’01’,并设MAMPx[3:0]为不同的LFSR屏蔽值;
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生触发事件时,具有相同屏蔽的LFSR1计数器值与DHR1寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新LFSR1计数器。
同时,具有相同屏蔽的LFSR2计数器值与DHR2寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

使用相同三角波发生器的同时触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’:
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为相同值,分别配置2个DAC通道使用相同触发源。
● 设置2个DAC通道的WAVEx[1:0]位为’1x’,并设MAMPx[3:0]为相同的三角波幅值。
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生触发事件时,相同的三角波幅值与DHR1寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新LFSR1计数器。
同时,相同的三角波幅值与DHR2寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

使用不同三角波发生器的同时触发

按照下列顺序设置DAC工作在此转换模式:
● 分别设置2个DAC通道的触发使能位TEN1和TEN2为’1’:
● 通过设置TSEL1[2:0]和 TSEL2[2:0]位为相同值,分别配置2个DAC通道使用相同触发源。
● 设置2个DAC通道的WAVEx[1:0]位为’1x’,并设MAMPx[3:0]为不同的三角波幅值。
● 将双DAC通道转换数据装入所需的DHR寄存器(DHR12RD、DHR12LD 或DHR8RD)。

当发生触发事件时,MAMP1[3:0]所设的三角波幅值与DHR1寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR1,然后更新LFSR1计数器。同时,MAMP2[3:0]所设的三角波幅值与DHR2寄存器数值相加,(延迟3个APB1时钟周期后)结果传入寄存器DAC_DOR2,然后更新LFSR2计数器。

五、DAC寄存器

必须以字(32位)的方式操作这些外设寄存器。

DAC控制寄存器(DAC_CR)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第9张

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第10张
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第11张

DAC软件触发寄存器(DAC_SWTRIGR)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第12张
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第13张

DAC通道 1 的 12 位右对齐数据保持寄存器(DAC_DHR12R1)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第14张

DAC通道 1 的 12 位左对齐数据保持寄存器(DAC_DHR12L1)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第15张

DAC通道 1 的 8 位右对齐数据保持寄存器(DAC_DHR8R1)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第16张
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第17张

DAC通道 2 的 12 位右对齐数据保持寄存器(DAC_DHR12R2)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第18张

DAC通道 2 的 12 位左对齐数据保持寄存器(DAC_DHR12L2)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第19张

DAC通道 2 的 8 位右对齐数据保持寄存器(DAC_DHR8R2)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第20张

双DAC的 12 位右对齐数据保持寄存器(DAC_DHR12RD)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第21张

双DAC的 12 位左对齐数据保持寄存器(DAC_DHR12LD)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第22张

双DAC的 8 位右对齐数据保持寄存器(DAC_DHR8RD)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第23张
DAC详解_什么是DAC_https://bianchenghao6.com/blog__第24张

DAC通道 1 数据输出寄存器(DAC_DOR1)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第25张

DAC通道 2 数据输出寄存器(DAC_DOR2)

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第26张

DAC寄存器映像

DAC详解_什么是DAC_https://bianchenghao6.com/blog__第27张

今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

上一篇

已是最后文章

下一篇

已是最新文章

发表回复