当前位置: 首页 > news >正文

STM32F1 HAL库笔记2_HAL 系统驱动程序

1、HAL 固件驱动程序 API 

1.1、如何使用此驱动程序

        通用 HAL 驱动程序包含一组通用的 API,PPP 外设驱动程序可以使用这些 API 来开始使用 HAL。HAL 包含两个 API 类别: • 常见的 HAL API • 服务 HAL API

 1.2、初始化和去初始化函数

        本节提供的功能:

        • 初始化闪存接口、NVIC 分配和初始时钟配置。它还会在需要超时时初始化 systick,并在启用时初始化备份域。

        • 去初始化 HAL 的公共部分。

        • 将时基源配置为具有 1ms 时基和专用的 Tick 中断优先级。

        – 默认情况下,SysTick 计时器用作时基源,但用户最终可以实现他正确的时基源(例如通用计时器或其他时间源),请记住,时基持续时间应保持 1 毫秒,因为PPP_TIMEOUT_VALUEs是以毫秒为基础定义和处理的。

        – 时基配置函数 HAL_InitTick()在程序开始时由 HAL_Init()自动调用,或在 clock 配置的任何时间由 HAL_RCC_ClockConfig()自动调用。

        – 时基源配置为以固定的时间间隔生成中断。如果从外设 ISR 进程调用 HAL_Delay() ,则必须小心,Tick 中断行必须具有比外设中断更高的优先级(数值较低)。否则,调用方 ISR 进程将被阻止。

        ― 影响时基配置的函数被声明为 __weak 以便在用户文件中有其他实现的情况下进行覆盖。        

        本节包含以下 API:

HAL_Init()
HAL_DeInit()
HAL_MspInit()
HAL_MspDeInit()
HAL_InitTick()

1.3、HAL 控制功能

        本节提供的功能:

        • 提供以毫秒为单位的时钟周期值

        • 提供以毫秒为单位的阻塞延迟

        • 暂停时基源中断

        • 恢复时基源中断

        • 获取 HAL API 驱动程序版本

        • 获取设备标识符

        • 获取设备修订标识符

        • 在睡眠模式下启用/禁用调试模块

        • 在停止模式下启用/禁用调试模块

        • 在待机模式下启用/禁用调试模块

        本节包含以下 API:

HAL_IncTick()
HAL_GetTick()
HAL_GetTickPrio()
HAL_SetTickFreq()
HAL_GetTickFreq()
HAL_Delay()
HAL_SuspendTick()
HAL_ResumeTick()
HAL_GetHalVersion()
HAL_GetREVID()
HAL_GetDEVID()
HAL_GetUIDw0()
HAL_GetUIDw1()
HAL_GetUIDw2()
HAL_DBGMCU_EnableDBGSleepMode()
HAL_DBGMCU_DisableDBGSleepMode()
HAL_DBGMCU_EnableDBGStopMode()
HAL_DBGMCU_DisableDBGStopMode()
HAL_DBGMCU_EnableDBGStandbyMode()
HAL_DBGMCU_DisableDBGStandbyMode()

1.4、功能详细说明

HAL_Init

函数名称: HAL_StatusTypeDef HAL_Init(void) 
函数说明: 该函数用于初始化HAL Library;它必须是要在主程序中执行的第一条指令(在调用任何其他 HAL 函数之前),它会执行以下操作:配置 Flash 预取。
返回值:   HAL:状态
说明:     SysTick 用作 HAL_Delay()函数的时基,应用程序需要确保 SysTick 时基始终设置为 1 毫秒才能进行正确的 HAL 操作。

HAL_DeInit

函数名称: HAL_StatusTypeDef HAL_DeInit(void) 
函数描述: 此函数取消初始化 HAL 的公共部分并停止 systick。
返回值:   HAL:状态 
备注:     此函数是可选的

HAL_MspInit

函数名称: void HAL_MspInit(void)
函数说明: 初始化 MSP
返回值:   无

HAL_MspDeInit

函数名称: void HAL_MspDeInit(void) 
函数描述: 去初始化MSP
返回值:   无

HAL_InitTick

函数名称: HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
函数说明: 该函数用于配置时基的来源。
参数:	  TickPriority:时钟周期中断优先级。
返回值:   HAL: 状态 
备注: • 此函数在 HAL_Init()复位后在程序开始时自动调用,或在 HAL_RCC_ClockConfig()重新配置时钟时随时自动调用。• 在默认实现中,SysTick 计时器是时基的来源。它用于以固定的时间间隔生成中断。如果从外设 ISR 进程调用 HAL_Delay(),则必须小心,SysTick 中断必须具有比外设中断更高的优先级(数值较低)。否则,调用方 ISR 进程将被阻止。该函数被声明为 __weak 以在用户文件中有其他实现的情况下被覆盖。

HAL_IncTick

函数名称: void HAL_IncTick(void)
函数说明: 调用此函数以递增用作应用程序时基的全局变量 “uwTick”。
返回值:   无
注释:    • 在默认实现中,此变量在 SysTick ISR 中每 1 毫秒递增一次。• 此函数被声明为 __weak 以在用户文件中存在其他实现时被覆盖。

HAL_Delay

函数名称: void HAL_Delay(uint32_t delay) 
函数说明: 此函数根据变量递增提供最小延迟(以毫秒为单位)。
参数:     Delay:指定延迟时间长度(以毫秒为单位)。
返回值:  无
注释: • 在默认实现中,SysTick 计时器是时基的来源。它用于以 uwTick 递增的固定时间间隔生成中断。• 此函数被声明为 __weak 以在用户文件中存在其他实现时被覆盖。

HAL_GetTick

函数名称: uint32_t HAL_GetTick(void)
函数描述: 提供以毫秒为单位的刻度值。
返回值:   tick: 值 
备注:    此函数被声明为 __weak,以便在用户文件中的其他实现的情况下被覆盖。

HAL_GetTickPrio

函数名称: uint32_t HAL_GetTickPrio(void)
函数说明: 此函数返回 tick 优先级。
返回值:   tick: priority

HAL_SetTickFreq

函数名称: HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef 频率)
函数描述: 设置新的时钟周期频率
返回值:  状态:

HAL_GetTickFreq

函数名称: HAL_TickFreqTypeDef HAL_GetTickFreq(void) 
函数描述: 返回时钟周期频率。
返回值:  tick:以 Hz 为单位的周期 

HAL_SuspendTick

函数名称: void HAL_SuspendTick(void) 
函数描述: 暂停 Tick 增量。
返回值:   无:
注释: • 在默认实现中,SysTick 计时器是时基的来源。它用于以固定的时间间隔生成中断。一旦 HAL_SuspendTick()被调用,SysTick 中断将被禁用,因此 Tick 增量被暂停。• 此函数被声明为 __weak 以在用户文件中存在其他实现时被覆盖。

HAL_ResumeTick

函数名称: void HAL_ResumeTick(void) 
函数说明: 恢复 Tick 增量。
返回值:  无
注释: • 在默认实现中,SysTick 计时器是时基的来源。它用于以固定的时间间隔生成中断。一旦 HAL_ResumeTick()被调用,SysTick 中断将被启用,因此 Tick 增量恢复。• 此函数被声明为 __weak 以在用户文件中存在其他实现时被覆盖。

HAL_GetHalVersion

函数名称: uint32_t HAL_GetHalVersion(void) 
函数描述: 返回 HAL 修订版。
返回值: • 版本:0xXYZR(每个小数点为 8 位,R 代表 RC)

HAL_GetREVID

函数名称: uint32_t HAL_GetREVID(void) 
函数描述: 返回设备修订标识符。
返回值: • 设备:修订标识符 

HAL_GetDEVID 

函数名称: uint32_t HAL_GetDEVID(void) 
函数描述: 返回设备标识符。
返回值: • 设备:标识符 

HAL_GetUIDw0 

函数名称: uint32_t HAL_GetUIDw0(void) 
函数说明: 返回唯一设备标识符的第一个字(基于 96 位的 UID) 
返回值: • 设备:标识符 

HAL_GetUIDw1

函数名称: uint32_t HAL_GetUIDw1(void) 
函数说明: 返回唯一设备标识符的第二个字(基于 96 位的 UID) 
返回值: • 设备: 标识符 

HAL_GetUIDw2

函数名称: uint32_t HAL_GetUIDw2(void) 
函数说明: 返回唯一设备标识符的第三个字(基于 96 位的 UID) 
返回值: • 设备:标识符 

HAL_DBGMCU_EnableDBGSleepMode 

函数名称: void HAL_DBGMCU_EnableDBGSleepMode(void) 
函数描述: 在 SLEEP 模式下启用调试模块。
返回值: • 无

HAL_DBGMCU_DisableDBGSleepMode

函数名称: void HAL_DBGMCU_DisableDBGSleepMode(void) 
函数说明: 在睡眠模式下禁用调试模块  
注意:在器件 STM32F10xx8 和 STM32F10xxB、STM32F101xC/D/E 和 STM32F103xC/D/E、STM32F101xF/G 和 STM32F103xF/G STM32F10xx4 和 STM32F10xx6 调试寄存器 DBGMCU_IDCODE 和 DBGMCU_CR只能在调试模式下访问(在正常模式下用户软件无法访问)。
返回值: • 无

HAL_DBGMCU_EnableDBGStopMode

函数名称: void HAL_DBGMCU_EnableDBGStopMode(void) 
函数说明: 在停止模式下启用调试模块 
注意:在设备 STM32F10xx8 和 STM32F10xxB、STM32F101xC/D/E 和 STM32F103xC/D/E、STM32F101xF/G 和 STM32F103xF/G STM32F10xx4 和 STM32F10xx6 调试寄存器 DBGMCU_IDCODE 和 DBGMCU_CR 只能在调试模式下访问(在正常模式下用户软件无法访问)。
返回值: • 无

HAL_DBGMCU_DisableDBGStopMode 

函数名称: void HAL_DBGMCU_DisableDBGStopMode(void) 
函数说明: 在停止模式下禁用调试模块 
注意:在设备 STM32F10xx8 和 STM32F10xxB、STM32F101xC/D/E 和 STM32F103xC/D/E 上,STM32F101xF/G 和 STM32F103xF/G STM32F10xx4 和 STM32F10xx6 调试寄存器 DBGMCU_IDCODE 和 DBGMCU_CR 只能在调试模式下访问(在正常模式下用户软件无法访问)。
返回值: • 无

HAL_DBGMCU_EnableDBGStandbyMode

函数名称: void HAL_DBGMCU_EnableDBGStandbyMode(void) 
功能描述: 在待机模式下启用调试模块 
注意:在器件 STM32F10xx8 和 STM32F10xxB、STM32F101xC/D/E 和 STM32F103xC/D/E、STM32F101xF/G 和 STM32F103xF/G STM32F10xx4 和 STM32F10xx6 调试寄存器 DBGMCU_IDCODE 和 DBGMCU_CR 只能在调试模式下访问(用户无法访问)软件处于正常模式)。
返回值: • 无

HAL_DBGMCU_DisableDBGStandbyMode 

函数名称: void HAL_DBGMCU_DisableDBGStandbyMode(void) 
函数说明: 在待机模式下禁用调试模块 
注意:在设备 STM32F10xx8 和 STM32F10xxB、STM32F101xC/D/E 和 STM32F103xC/D/E、STM32F101xF/G 和 STM32F103xF/G STM32F10xx4 和 STM32F10xx6 调试寄存器 DBGMCU_IDCODE 和 DBGMCU_CR 只能在调试模式下访问(在正常模式下用户软件无法访问)。
返回值: • 无

2、HAL 固件驱动程序定义

2.1、 在调试模式下冻结和解冻外设

__HAL_DBGMCU_FREEZE_TIM2
__HAL_DBGMCU_UNFREEZE_TIM2
__HAL_DBGMCU_FREEZE_TIM3
__HAL_DBGMCU_UNFREEZE_TIM3
__HAL_DBGMCU_FREEZE_TIM4
__HAL_DBGMCU_UNFREEZE_TIM4
__HAL_DBGMCU_FREEZE_TIM5
__HAL_DBGMCU_UNFREEZE_TIM5
__HAL_DBGMCU_FREEZE_TIM6
__HAL_DBGMCU_UNFREEZE_TIM6
__HAL_DBGMCU_FREEZE_TIM7
__HAL_DBGMCU_UNFREEZE_TIM7
__HAL_DBGMCU_FREEZE_WWDG
__HAL_DBGMCU_UNFREEZE_WWDG
__HAL_DBGMCU_FREEZE_IWDG
__HAL_DBGMCU_UNFREEZE_IWDG
__HAL_DBGMCU_FREEZE_I2C1_TIMEOUT
__HAL_DBGMCU_UNFREEZE_I2C1_TIMEOUT
__HAL_DBGMCU_FREEZE_I2C2_TIMEOUT
__HAL_DBGMCU_UNFREEZE_I2C2_TIMEOUT
__HAL_DBGMCU_FREEZE_CAN1
__HAL_DBGMCU_UNFREEZE_CAN1
__HAL_DBGMCU_FREEZE_CAN2
__HAL_DBGMCU_UNFREEZE_CAN2
__HAL_DBGMCU_FREEZE_TIM1
__HAL_DBGMCU_UNFREEZE_TIM1
__HAL_DBGMCU_FREEZE_TIM9
__HAL_DBGMCU_UNFREEZE_TIM9
__HAL_DBGMCU_FREEZE_TIM10
__HAL_DBGMCU_UNFREEZE_TIM10
__HAL_DBGMCU_FREEZE_TIM11
__HAL_DBGMCU_UNFREEZE_TIM11

相关文章:

STM32F1 HAL库笔记2_HAL 系统驱动程序

1、HAL 固件驱动程序 API 1.1、如何使用此驱动程序 通用 HAL 驱动程序包含一组通用的 API,PPP 外设驱动程序可以使用这些 API 来开始使用 HAL。HAL 包含两个 API 类别: • 常见的 HAL API • 服务 HAL API 1.2、初始化和去初始化函数 本节提供的功能&a…...

el-table实现当内容过多时,el-table显示滚动条,页面不显示滚动条

估计有不少小伙伴在开发公司的ERP使用el-table都会遇到这么一个问题,就是产品经理提出,页面不出现滚动条,因为不美观。但是当el-table内容过多,超过页面的宽度时候,页面就会有滚动条。那应该如何解决呢?能不能让滚动条…...

Java面试篇基础部分-Java中的异常以及异常处理

导语   在实际的开发过程中,往往会遇到各种各样的编程异常,如何处理这些异常,直接会影响到整个程序和系统的稳定性,如果不能在合适的地方抛出合适的异常或者是对异常进行捕获。那么就会影响到整个程序的运行。所以如何处理异常,是作为每个开发者来说必不可少的开发技能。…...

win11 MySQL的坑

最近升级了系统,导致以前的安装的两个版本MySQL服务无法启动,只能在mysql的bin目录,执行mysqld --console才能启动,mysqld都无法启动, 所幸进行了数据库初始化,这次在MySQL的bin目录执行 mysqld或者mysqld …...

stm32单片机个人学习笔记1(简单介绍)

前言 本篇文章属于stm32单片机(以下简称单片机)的学习笔记,来源于B站教学视频。下面是这位up主的视频链接。本文为个人学习笔记,只能做参考,细节方面建议观看视频,肯定受益匪浅。 STM32入门教程-2023版 细…...

python中@staticmethod、@classmethod用法

1、类的基础介绍 类对象:定义的类就是类对象 类属性:定义在__init__ 外部的变量 类方法:定义在类中,且被classmethod 装饰的方法 实例对象:类对象实例化后就是实例对象 实例属性:定义在__init__内部带…...

Harmony Next 文件命令操作(发送、读取、媒体文件查询)

查询文件位置 hdc shell mediatool query IMG_20240902_204224.jpg 输出示例 拉取文件 hdc file recv /storage/cloud/100/files/Photo/4/IMG_1725281044_036.jpg aa.jpg 发送文件 hdc file send aa.jpg /storage/media/100/local/files/Docs/Download/ab.jpg 下载目录位置…...

Go语言中的链表与双向链表实现

链表基础 链表是一种由有限元素组成的数据结构,其中每个元素至少使用两个内存空间:一个存储实际数据,另一个存储指向下一个元素的指针,从而形成一个元素序列构成链表。链表的第一个元素称为头结点,而最后一个元素通常…...

开始一个WPF项目时的记忆重载入

目前在工业软件的UI开发方案选择中,WPF仍然是一个重要的选项。 但是其固有的复杂性,对于像我这样,并不是一直在从事界面开发的人来说,每次重启,都需要一两天的适应的时间。所以这里稍微写一个笔记。 还是老办法&…...

用go语言实现树和哈希表算法

算法复杂度 判断一个算法的效率通常基于其计算复杂度,这主要与算法访问输入数据的次数有关。计算机科学中常用大O表示法来描述算法的复杂度。例如,O(n)的算法只需访问一次输入数据,因此优于O(n)的算法,后者则优于O(n)的算法&…...

基于SpringBoot+Vue+MySQL的校园健康驿站管理系统

系统展示 用户前台界面 管理员后台界面 系统背景 本文设计并实现了一个基于SpringBoot后端、Vue前端与MySQL数据库的校园健康驿站管理系统。该系统旨在通过数字化手段,全面管理学生的健康信息,包括体温监测、疫苗接种记录、健康状况申报等,为…...

深入理解MATLAB中的事件处理机制

在MATLAB中,事件处理机制是一种强大的工具,它允许对象之间的交互和通信。这种机制基于观察者设计模式,其中一个对象(观察者)监听另一个对象(发布者)的状态变化。当发布者的状态发生变化时&#…...

线程--线程同步

这里写目录标题 同步概念线程同步概念数据混乱原因 互斥量原理锁的注意事项1、cpu时间轮片2、建议锁总结 使用锁来管理线程同步问题产生主要函数init、destorylock、unlock代码注意事项(锁的粒度) try锁死锁出现原因图解 读写锁特性图解函数总览init、de…...

【QT】Qt窗口

欢迎来到Cefler的博客😁 🕌博客主页:折纸花满衣 🏠个人专栏:QT 目录 👉🏻菜单栏设置👉🏻QToolBar练习 👉🏻QStausBar👉🏻Q…...

场外个股期权怎么给股票加杠杆?

今天期权懂带你了解场外个股期权怎么给股票加杠杆?场外期权交易通过向证券公司支付一定额度的股票期权费,然后买入大额的股票持仓,从而实现的杠杆交易。 买入看涨期权 操作:支付权利金购买看涨期权。 杠杆作用: 期…...

【Docker部署ELK】(7.15)

1、拉取镜像 docker pull docker.elastic.co/elasticsearch/elasticsearch:7.15.0 docker pull docker.elastic.co/kibana/kibana:7.15.0 docker pull docker.elastic.co/logstash/logstash:7.15.02、配置文件(解压资源到D盘DOCKER目录下) 2.1 配置文件…...

UE4_后期处理_后期处理材质及后期处理体积一

后期处理效果 在渲染之前应用于整个渲染场景的效果。 后期处理效果(Post-processing effect)使美术师和设计师能够对影响颜色、色调映射、光照的属性和功能进行组合选择,从而定义场景的整体外观。要访问这些功能,可以将一种称为…...

【PyQt6 应用程序】基于QtDesigner做一个用户登录页面

在当今的软件开发领域,用户界面(UI)设计和后端编程是创建现代、互动应用程序的两大重要组成部分。尤其是在开发具有用户登录功能的应用程序时,不仅要注重外观和用户体验的设计,还要确保后端逻辑的安全性和可靠性。 本文将介绍如何使用PyQt6框架结合UI设计,实现一个简单而…...

Ollama—87.4k star 的开源大模型服务框架!!

这一年来,AI 发展的越来越快,大模型使用的门槛也越来越低,每个人都可以在自己的本地运行大模型。今天再给大家介绍一个最厉害的开源大模型服务框架——ollama。 项目介绍 Ollama 是一个开源的大语言模型(LLM)服务工具…...

MySQL表的操作与数据类型

目录 前言 一、表的操作 1.创建一个表 2.查看表的结构 3.修改表 4.删除一个表 二、 MySQL的数据类型 0.数据类型一览: 1.整数类型 2.位类型 3.小数类型 4.字符类型 前言 在MySQL库的操作一文中介绍了有关MySQL库的操作,本节要讲解的是由库管理的结构——…...

pkNX:定制宝可梦游戏体验的全能编辑工具指南

pkNX:定制宝可梦游戏体验的全能编辑工具指南 【免费下载链接】pkNX Pokmon (Nintendo Switch) ROM Editor & Randomizer 项目地址: https://gitcode.com/gh_mirrors/pk/pkNX 你是否曾想过在宝可梦游戏中拥有独一无二的精灵阵容?是否希望调整训…...

AI-AGENT概念解析 - LLM任务训练

**问题:LLM大模型是否针对写作,做PPT,编写程序,拆解任务这些输入参数,用同一个大模型需要训练为不同的模型结构或参数化的权重矩阵去适应那些不同的提示词输入参数? 对于不同的任务类型(写作、做…...

别再为‘file must be a file‘报错头疼了!手把手教你用Apifox搞定Dify文件上传接口

深度解析Dify文件上传接口:从报错排查到Apifox高效调试实战 当你正在为Dify AI应用集成文件上传功能时,是否曾在Apifox中反复遭遇file must be a file的报错而束手无策?这种看似简单的接口调试背后,隐藏着文件传输机制、参数组合…...

Gauge常见问题解决:10个典型错误及修复方法

Gauge常见问题解决:10个典型错误及修复方法 【免费下载链接】gauge Light weight cross-platform test automation 项目地址: https://gitcode.com/gh_mirrors/ga/gauge Gauge作为一款轻量级跨平台测试自动化工具,在使用过程中可能会遇到各种错误…...

UE5 GAS调试技巧:巧用ASC的‘Attribute Test’面板,5分钟搞定角色属性配置与验证

UE5 GAS高效调试指南:利用Attribute Test面板快速验证角色属性配置 在虚幻引擎5的游戏开发中,Gameplay Ability System (GAS)作为构建复杂角色能力与属性的核心框架,其调试效率直接影响着RPG类项目的开发进度。本文将深入探讨如何利用Ability…...

别再纠结了!手把手教你根据团队规模和技术栈选对存储方案(Ceph vs MinIO实战对比)

技术选型实战:Ceph与MinIO的团队适配决策框架 当技术负责人面对存储方案选型时,往往陷入"功能强大"与"简单易用"的两难抉择。我曾见证过一家50人规模的AI创业公司,因盲目选择Ceph导致三个月后不得不重构基础设施——他们…...

使用Yolo 11进行定制化图像识别全流程

全流程预览 Label Studio标注 → 导出YOLO格式 → 编写data.yaml → 拆分数据集 → 模型训练 → 预测部署步骤工具/技术产出物数据标注Label Studio标注好的图片数据导出YOLO with imagesimages/ labels/配置文件data.yaml数据集配置数据拆分Python脚本train/val/test模型训练…...

Bongo-Cat-Mver:实时键盘动画工具的创新应用与实践指南

Bongo-Cat-Mver:实时键盘动画工具的创新应用与实践指南 【免费下载链接】Bongo-Cat-Mver An Bongo Cat overlay written in C 项目地址: https://gitcode.com/gh_mirrors/bo/Bongo-Cat-Mver 在直播、教学和演示场景中,如何让观众清晰感知键盘操作…...

重构AI训练数据管理流程:BooruDatasetTagManager如何提升图像标签标注效率83%

重构AI训练数据管理流程:BooruDatasetTagManager如何提升图像标签标注效率83% 【免费下载链接】BooruDatasetTagManager 项目地址: https://gitcode.com/gh_mirrors/bo/BooruDatasetTagManager 在AI模型训练的数据准备阶段,图像标签管理是决定模…...

AI智能体应用工程师:少数人掌握的高薪未来,你离入场还有多远

AI智能体应用工程师 — 国家战略人才项目|企业刚需资质—国务院发布关于实施“人工智能”行动。文中指出:到2027年,率先实现人工智能与6大重点领域广泛深度融合,新一代智能体终端、智能体等应用普及率超过70%。 各地省政府于2025年市级“A1产业”专项基金…...