STM32H750外设ADC之不连续转换数据模式

2024-04-29 10:20

本文主要是介绍STM32H750外设ADC之不连续转换数据模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

概述

1 常规组模式

1.1 模式功能实现

1.2 范例-1

1.3 范例-2

1.4 注意点

2 注入组模式

2.1 功能实现

2.2 范例

2.3 注意点


概述

本文主要讲述STM32H750外设ADC之不连续转换数据模式,该转换模式可工作常规组模式和注入组模式两种情况。笔者对两者做了详细的分析,并列举了其中使用的主要寄存器,还介绍了与之相关的bit位的功能。

1 常规组模式

1.1 模式功能实现

可将 ADCx_CFGR 寄存器中的 DISCEN 位置 1 来使能此模式。

位 16 DISCEN:常规通道的不连续模式 (Discontinuous mode for regular channels)
此位由软件置 1 和清零,用于使能/禁止常规通道的不连续模式。
0:禁止常规通道的不连续模式
1:使能常规通道的不连续模式


注:

1)不能同时使能不连续模式和连续模式:禁止同时将 DISCEN 和 CONT 位置 1。
2)不能同时使用自动注入模式和不连续模式:当 JAUTO 置 1 时, DISCEN 和 JDISCEN 位必须通过软件保持清零状态。仅当 ADSTART=0 时(这可确保当前未进行任何常规转换),才允许通过软件对此位执行写操作。如果使能了双重模式( ADCx_CCR 寄存器的 DAMDF 位不等于零),则从 ADC 的 DISCEN 位不再可写,其内容与主 ADC 的 DISCEN 位相等。

该模式用于转换含有 n (n ≤ 8) 个转换的短序列(子组),该短序列是在 ADCx_SQRy 寄存器中选择的转换序列的一部分。

可通过写入 ADCx_CFGR 寄存器中的 DISCNUM[2:0] 位来指定 n 的值。

位 19:17 DISCNUM[2:0]: 不连续采样模式通道计数 (Discontinuous mode channel count)
软件将写入这些位,用于定义在接收到外部触发后于不连续采样模式下转换的常规通道数。
000: 1 个通道
001: 2 个通道
...
111: 8 个通道


注: 仅当 ADSTART=0 时(这可确保当前未进行任何常规转换),才允许通过软件对这些位执行写操作。如果使能了双重模式(ADCx_CCR 寄存器的 DAMDF 位不等于零),则从 ADC 的 DISCNUM[2:0]位不再可写,其内容与主 ADC 的 DISCNUM[2:0] 位相等。
 

出现外部触发时,将启动在 ADCx_SQR 寄存器中选择的接下来 n 个转换,直到序列中的所有转换均完成为止。通过 ADCx_SQR1 寄存器中的 L[3:0] 位定义总序列长度。

位 3:0 L[3:0]: 常规通道序列长度 (Regular channel sequence length)
通过软件写入这些位可定义常规通道转换序列中的转换总数。
0000: 1 次转换
0001: 2 次转换
...
1111: 16 次转换


注: 仅当 ADSTART=0 时(这可确保当前未进行任何常规转换),才允许通过软件对这些位
执行写操作。
 

1.2 范例-1

DISCEN=1, n = 3,要转换的通道 = 1、 2、 3、 6、 7、 8、 9、 10、 11

DISCEN=1:使能常规通道的不连续模式

ADCx_SQR1 中L[3:0] = 3: 3 次转换


– 第一次触发:转换的通道为 1、 2、 3(每次转换时都生成 EOC 事件)。
– 第二次触发:转换的通道为 6、 7、 8(每次转换时都生成 EOC 事件)。
– 第三次触发:转换的通道为 9、 10、 11(每次转换时都生成 EOC 事件),并会在通道 11 转换

完成后生成 EOS 事件。
– 第四次触发:转换的通道为 1、 2、 3(每次转换时都生成 EOC 事件)。
– ...
 

1.3 范例-2

DISCEN=0,要转换的通道 = 1、 2、 3、 6、 7、 8、 9、 10、 11

DISCEN=0:禁止常规通道的不连续模式

– 第一次触发:转换整个序列:通道 1、然后是通道 2、 3、 6、 7、 8、 9、 10 和 11。每次转换都会生成 EOC 事件,最后一次转换还会生成 EOS 事件。
– 所有后续触发事件都将重启整个序列

1.4 注意点

1)在不连续模式下转换常规组时,不会出现翻转(序列最后一个子组的转换次数少于 n 次)。转换完所有子组后,下一个触发信号将启动第一个子组的转换。在上述示例中,第四次触发重新转换了第一个子组中的通道 1、 2 和 3。

2)不能同时使能不连续模式和连续模式。如果同时使能两种模式(即 DISCEN=1、 CONT=1),
ADC 会认定连续模式已禁止并继续执行相关操作。
 

2 注入组模式

2.1 功能实现

可将 ADCx_CFGR 寄存器中的 JDISCEN 位置 1 来使能此模式。

位 20 JDISCEN: 注入通道的不连续采样模式 (Discontinuous mode on injected channels)
通过软件将该位置 1 和清零可使能/禁止注入通道的不连续采样模式。
0:禁止注入通道的不连续采样模式
1:使能注入通道的不连续采样模式

注: 仅当 JADSTART=0 时(这可确保当前未进行任何注入转换),才允许通过软件对此位执行写操作。不能同时使用自动注入模式和不连续模式:当 JAUTO 置 1 时, DISCEN 和 JDISCEN 位必须通过软件保持清零状态。如果使能了双重模式( ADCx_CCR 寄存器的 DAMDF 位不等于零),则从 ADC 的 JDISCEN位不再可写,其内容与主 ADC 的 JDISCEN 位相等
 

在出现外部注入触发事件之后,该模式会逐通道转换在 ADCx_JSQR 寄存器中选择的序列,相当于不连续模式下常规通道“n”固定为 1 的情况。

出现外部触发时,将启动在 ADCx_JSQR 寄存器中选择的下一个通道转换,直到序列中的所
有转换均完成为止。通过 ADCx_JSQR 寄存器中的 JL[1:0] 位定义总序列长度。

2.2 范例

JDISCEN=1,要转换的通道 = 1、 2、 3

JDISCEN=1:使能注入通道的不连续采样模式

– 第一次触发:转换通道 1(生成 JEOC 事件)
– 第二次触发:转换通道 2(生成 JEOC 事件)
– 第三次触发:转换通道 3 并生成 JEOC 事件和 JEOS 事件
– ...

2.3 注意点

1)转换完所有注入通道后,下一个触发信号将启动第一个注入通道的转换。在上述示例中,第 4 次触发重新转换了第 1 个注入通道。

2)不能同时使用自动注入模式和不连续模式:当 JAUTO 置 1 时, DISCEN 和 JDISCEN 位必须通过软件保持清零状

位 25 JAUTO: 注入组自动转换 (Automatic injected group conversion)
通过软件将该位置 1 和清零可在常规组转换后分别使能/禁止注入组自动转换。
0:禁止注入组自动转换
1:使能注入组自动转换

注: 仅当 ADSTART=0 且 JADSTART=0 时(这可确保当前未进行常规转换、也未进行注入转换),才允许通过软件对此位执行写操作。如果使能了双重模式( ADCx_CCR 寄存器的 DAMDF 位不等于零),则从 ADC 的 JAUTO 位不再可写,其内容与主 ADC 的 JAUTO 位相等。

这篇关于STM32H750外设ADC之不连续转换数据模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945827

相关文章

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左