STM32-标准库-GPIO-API函数

news2025/6/3 10:12:47

1.void GPIO_DeInit(GPIO_TypeDef* GPIOx);

@简明

清除GPIOx的外围寄存器下所有引脚的配置,

恢复到默认配置状态(即上电初始值)

@参数

GPIOx:其中x可以是(A..G)来选择GPIO外设。

@返回值

None


void GPIO_DeInit(GPIO_TypeDef* GPIOx);

(1)通常用于以下场景:

动态切换外设功能前清除残留配置。

系统低功耗模式下减少 GPIO 漏电流。

错误恢复时强制重置 GPIO 状态。

(2)注意事项

复位操作依赖时钟

1.必须确保 GPIO 时钟已使能:复位操作需通过 RCC 寄存器完成,

        若 GPIO 时钟未开启(例如调用 RCC_APB2PeriphClockCmd(GPIOx_CLOCK, DISABLE)),否则GPIO_DeInit() 将无效

2.复位后不会自动关闭时钟需手动禁用以降低功耗(若不再使用)

2.void GPIO_AFIODeInit(void);

@简明

将复用功能(重映射、事件控制和EXTI配置)寄存器取消复用功能,恢复默认状态值。

@参数

None

@返回值

None


void GPIO_AFIODeInit(void);

(1)注意事项

复位范围 :

影响所有 AFIO 相关配置

复用功能重映射(如 USART、SPI 引脚重映射)

外部中断线(EXTI)与 GPIO 引脚的绑定关系

事件输出功能(GPIO_EventOutputConfig)的配置

调试端口(如 SWJ/JTAG)的引脚分配(可能影响调试器连接)

外设依赖风险

复用功能失效:

若 GPIO 用于外设重映射(如 USART1 重映射到 PB6/PB7),复位后需重新配置。

中断丢失

若 EXTI 中断依赖 AFIO 配置(如 GPIO_EXTILineConfig),复位后需重新绑定引脚并配置 NVIC

调试接口影响

默认状态下,调试端口(SWJ/JTAG)可能被禁用或重新分配,导致调试器断开连接

3.void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct);

@简明

用来初始化GPIO引脚的配置,比如设置模式、速度、上下拉等。

@参数

@参数1

GPIOx:其中x可以是(A..G)来选择GPIO外设。

@参数2

GPIO_InitStruct:指向GPIO_InitTypeDef结构的指针,该结构包含指定GPIO外围设备的配置信息。

@返回值

None


void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct);

(1)参数2:GPIO_InitStruct

GPIO_InitStruct

GPIO_Pin

引脚编号(位掩码,如 GPIO_Pin_0 | GPIO_Pin_1)。

GPIO_Mode

引脚模式(输入/输出/复用/模拟)

输入模式

GPIO_Mode_AIN /* 模拟输入模式 /

GPIO_Mode_IN_FLOATING / 浮空输入 /

GPIO_Mode_IPD / 下拉输入模式 /

GPIO_Mode_IPU / 上拉输入模式 */

输出模式

GPIO_Mode_Out_OD /* 开漏输出 /

GPIO_Mode_Out_PP / 推挽输出 /

GPIO_Mode_AF_OD / 复用开漏输出/

GPIO_Mode_AF_PP / 复用推挽输出 */

GPIO_Speed

输出速度(低速/中速/高速)

GPIO_Speed_10MHz = 1,

GPIO_Speed_2MHz,

GPIO_Speed_50MHz

GPIO_OType

输出类型(推挽/开漏)

GPIO_PuPd

上下拉电阻配置(无/上拉/下拉)

(2)适用场景

初始化 GPIO 引脚为输入(如按键检测)

配置引脚为输出(如控制 LED)。

设置复用功能(如 USART、SPI 通信)

模拟模式(如 ADC/DAC 信号采集)

4.void GPIO_StructInit(GPIO_InitTypeDef* GPIO_InitStruct)

@简明

该函数用于快速初始化 GPIO 配置结构体,避免手动赋值的冗余操作,

通常在自定义配置前调用,确保未显式设置的参数具有合理的默认值。

@参数

GPIO_InitStruct

成员

默认值

说明

GPIO_Pin

GPIO_Pin_None

无引脚被选中。

GPIO_Mode

GPIO_Mode_IN

浮空输入模式。

GPIO_Speed

GPIO_Speed_2MHz

低速模式(2MHz)。

GPIO_OType

GPIO_OType_PP

推挽输出(仅在输出模式下有效)。

GPIO_PuPd

GPIO_PuPd_NOPULL

无上下拉电阻。

@返回值


void GPIO_StructInit(GPIO_InitTypeDef* GPIO_InitStruct)

(1)注意事项

  • 必须显式覆盖默认值:调用 GPIO_StructInit 后,需手动设置目标参数(如 GPIO_PinGPIO_Mode),否则配置无效。
GPIO_InitTypeDef GPIO_InitStruct; 

GPIO_StructInit(&GPIO_InitStruct); // 初始化默认值 

GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5; // 覆盖引脚

GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT; // 覆盖模式

GPIO_Init(GPIOA, &GPIO_InitStruct);
  • 默认模式的风险

               -默认的浮空输入模式(GPIO_Mode_IN可能导致引脚电平不稳定,需根据实际需求调整。

               -默认低速模式(GPIO_Speed_2MHz可能不适用于高频信号(如 SPI 通信)

  • 与 GPIO_Init 的配合

               -GPIO_StructInit 仅初始化结构体,不会配置硬件寄存器,需后续调用 GPIO_Init 生效。

  • 多引脚配置优化

               -若需重复配置不同引脚,可复用同一结构体,避免重复初始化:

GPIO_InitTypeDef GPIO_InitStruct;  
GPIO_StructInit(&GPIO_InitStruct);  

// 配置 PA5 为输出  
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5;  
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT;  
GPIO_Init(GPIOA, &GPIO_InitStruct);  

// 配置 PA6 为输入  
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;  
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;  
GPIO_Init(GPIOA, &GPIO_InitStruct);  

5.uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

@简明

读取指定的输入端口引脚。

适用范围:适用于按键检测、传感器信号读取等场景。

@参数

参数1

GPIOx

GPIO 端口

参数2

GPIO_Pin

引脚编号

@返回值

Bit_SET(1):引脚为高电平。

Bit_RESET(0):引脚为低电平。


uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

6.uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);

@简明

读取指定的GPIO输入数据端口。

@参数

GPIOx

GPIOx:其中x可以是(A..G)来选择GPIO外设。

@返回值

16位数据,每一位对应一个GPIO引脚的状态

{

0=低电平,

1=高电平

}


uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);

(1)注意事项

依赖条件

仅读取配置为输入模式​(如 GPIO_Mode_IN)的引脚状态,输出模式引脚的值可能无效

输入模式有效性

仅在GPIO配置为输入模式(如浮空输入、上拉/下拉输入)时,返回值才有意义。

(2)位操作技巧

// 检查第n位是否为高电平 
if (GPIO_ReadInputData(GPIOA) & (1 << n)) { 

    /* 逻辑处理 */ 

}

7.uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

简明

读取指定GPIO端口的单个输出引脚的当前设置状态

及(高/低电平),返回0或1。

参数

GPIOx

GPIOx:其中x可以是(A..G)来选择GPIO外设。

GPIO_Pin

指定要读取的端口位。

返回值

uint8_t:0(低电平)或1(高电平)。


uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

(1)注意事项

依赖条件

仅对配置为输出模式​(如推挽、开漏)的引脚有效,

输入模式引脚的结果无意义。

典型应用场景

验证输出引脚的配置状态(如确认LED是否被设置为点亮、检查信号是否已发送)。

8.uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx);

@简明

读取指定GPIO端口的所有输出引脚的当前设置状态(高/低电平),返回16位无符号整数。

@参数

GPIOx:

GPIO端口(如GPIOA、GPIOB等)。

@返回值

uint16_t:16位数据,每一位对应一个GPIO引脚的输出状态(0=低电平,1=高电平)。


uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx);

(1)注意事项

依赖条件

仅对配置为输出模式​(如推挽、开漏)的引脚有效,

输入模式引脚的状态不会被反映。

典型应用场景

批量读取输出引脚状态(如LED阵列控制、并行总线数据发送后验证状态)。

结束语

以上就是对STM32-标准库-GPIO-API函数的一个总结。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2394618.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作

Java 文件操作 和 IO&#xff08;4&#xff09;-- Java文件内容操作&#xff08;2&#xff09;-- 字符流操作 文章目录 Java 文件操作 和 IO&#xff08;4&#xff09;-- Java文件内容操作&#xff08;2&#xff09;-- 字符流操作观前提醒&#xff1a;1. Java中操作文件的简单介…

使用摄像头推流+VLC软件拉流

一、作用 使用摄像头创建rtsp链接&#xff0c;并使用VLC软件拉流显示。 二、步骤 1、安装FFmpeg库 下载地址&#xff1a;https://ffmpeg.org/download.htmlFFmpeg库的下载参考之前的博客&#xff0c;下载Win64版本即可&#xff1a;https://blog.csdn.net/beijixingcd/artic…

XCUITest 是什么

XCUITest&#xff08;全称 Xcode UI Test&#xff09;是苹果官方提供的 iOS/macOS UI 自动化测试框架&#xff0c;集成在 Xcode 开发工具中&#xff0c;专门用于测试 Swift/Objective-C 开发的应用程序。 1. XCUITest 的核心特点 ✅ 官方支持&#xff1a;苹果原生框架&#xf…

灌水论坛系统总体设计文档

一、实验题目 灌水论坛系统 二、实验目的 旨在通过一个相对完整且功能丰富的Web应用实例&#xff0c;全面地实践和巩固Web开发所需的各项核心技术和工程方法&#xff0c;从而提升其综合应用能力和解决实际开发问题的能力。它不仅仅是完成一个软件&#xff0c;更是一个学习、…

Mac M1编译OpenCV获取libopencv_java490.dylib文件

Window OpenCV下载地址 https://opencv.org/releases/OpenCV源码下载 https://github.com/opencv/opencv/tree/4.9.0 https://github.com/opencv/opencv_contrib/tree/4.9.0OpenCV依赖 brew install libjpeg libpng libtiff cmake3 ant freetype构建open CV cmake -G Ninja…

使用 Let‘s Encrypt 和 Certbot 为 Cloudflare 托管的域名申请 SSL 证书

一、准备工作 1. 确保域名解析在 Cloudflare 确保你的域名 jessi53.com 和 www.jessi53.com 的 DNS 记录已经正确配置在 Cloudflare 中&#xff0c;并且状态为 Active。 2. 安装 Certbot 在你的服务器上安装 Certbot 和 Cloudflare 插件。以下是基于 Debian/Ubuntu 和 Cent…

微信小程序关于截图、录屏拦截

1.安卓 安卓&#xff1a; 在需要禁止的页面添加 onShow() {if (wx.setVisualEffectOnCapture) {wx.setVisualEffectOnCapture({visualEffect: hidden,complete: function(res) {}})}},// 页面隐藏和销毁时需要释放防截屏录屏设置onHide() {if (wx.setVisualEffectOnCapture) {w…

基于51单片机的音乐盒键盘演奏proteus仿真

地址&#xff1a; https://pan.baidu.com/s/1tZCAxQQ7cvyzBfztQpk0UA 提取码&#xff1a;1234 仿真图&#xff1a; 芯片/模块的特点&#xff1a; AT89C52/AT89C51简介&#xff1a; AT89C51 是一款常用的 8 位单片机&#xff0c;由 Atmel 公司&#xff08;现已被 Microchip 收…

【unity游戏开发——编辑器扩展】EditorUtility编辑器工具类实现如文件操作、进度条、弹窗等操作

注意&#xff1a;考虑到编辑器扩展的内容比较多&#xff0c;我将编辑器扩展的内容分开&#xff0c;并全部整合放在【unity游戏开发——编辑器扩展】专栏里&#xff0c;感兴趣的小伙伴可以前往逐一查看学习。 文章目录 前言一、确认弹窗1、确认弹窗1.1 主要API1.2 示例 2、三按钮…

Android之ListView

1&#xff1a;简单列表(ArrayAdapter) 1&#xff1a;运行的结果&#xff1a; 2&#xff1a;首先在MyListView里面创建一个按钮&#xff0c;点击的时候进行跳转。 这里让我吃惊的是&#xff0c;Button里面可以直接设置onClick .java里面的方法。 也即是点击这个按钮之后就会去…

《Spring Cloud Gateway 快速入门:从路由到自定义 Filter 的完整教程》​

1.网关介绍 在前面的学习中&#xff0c;我们通过Eureka和Nacos解决了辅助注册&#xff0c;使用Spring Cloud LoadBalance解决了负载均衡的问题&#xff0c;使用OpenFeign解决了远程调用的问题。 但是当前的所有微服务的接口都是直接对外暴露的&#xff0c;外部是可以直接访问…

第3节 Node.js 创建第一个应用

Node.js 非常强大&#xff0c;只需动手写几行代码就可以构建出整个HTTP服务器。事实上&#xff0c;我们的Web应用以及对应的Web服务器基本上是一样的。 在我们创建Node.js第一个"Hello, World!"应用前&#xff0c;让我们先了解下Node.js应用是由哪几部分组成的&…

我们来学mysql -- “数据备份还原”sh脚本

数据备份&还原 说明执行db_backup_cover.sh脚本 说明 环境准备&#xff1a;来源数据库(服务器A)&#xff1b;目标数据库(服务器B)dbInfo.sh脚本记录基本信息 来源库、目标库的ip、port及执行路径 # MySQL 客户端和 mysqldump 的路径 MYSQL_CLIENT"/work/oracle/mysql…

【排序算法】快速排序详解--附详细流程代码

快速排序算法 介绍 快速排序&#xff08;Quick Sort&#xff09;是一种高效的分治排序算法&#xff0c;由英国计算机科学家 Tony Hoare 于 1960 年提出。它是实际应用中最常用的排序算法之一。快速排序的基本思想是&#xff1a;选择一个"基准"&#xff08;pivot&am…

解决各个系统报错TDengine:no taos in java.library.path问题

windows 系统解决办法 在本地上安装一个TD的Windows客户端&#xff0c;注意安装的客户端版本一定要和服务端TD版本完全一致。&#xff08;或者将 C:\TDengine\driver\taos.dll 拷贝到 C:\Windows\System32\ 目录下&#xff09; 客户端各个历史版本下载链接&#xff1a;TDengin…

java helloWord java程序运行机制 用idea创建一个java项目 标识符 关键字 数据类型 字节

HelloWord public class Hello{public static void main(String[] args) {System.out.print("Hello,World!");} }java程序运行机制 用idea创建一个java项目 建立一个空项目 新建一个module 注释 标识符 关键字 标识符注意点 数据类型 public class Demo02 {public st…

免费文本转语音工具体验:祈风TTS使用

简介&#xff1a;语音生成的另一种方式 现在很多人通过视频记录生活&#xff0c;表达观点。拍摄剪辑不难&#xff0c;配音成了常见难题。部分人对自己的声音不够自信&#xff0c;也有人在特定场景下不便出声。文本转语音工具可以成为解决方案。 常见的TTS&#xff08;Text To…

JS和TS的区别

JavaScript 与 TypeScript 的主要区别和特性对比 1. 基础定义 JavaScript 是一种动态、弱类型的编程语言&#xff0c;广泛应用于前端开发以及通过 Node.js 扩展到后端开发。TypeScript 则是 JavaScript 的超集&#xff0c;它在 JavaScript 的基础上添加了静态类型系统和其他增…

Python实现P-PSO优化算法优化BP神经网络分类模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 随着人工智能技术的快速发展&#xff0c;神经网络在分类任务中展现了强大的性能。BP&#xff08;Back Propagation&…

Linux --进度条小程序更新

这里使用随机数来模拟下载量&#xff0c;来实现一个下载进度更新的小程序 main.c 的代码&#xff0c;其中downlod这个函数使用的是函数指针&#xff0c;如果有多个进度条函数可以传入进行多样化的格式下载显示&#xff0c;还需要传入一个下载总量&#xff0c;每次"下载以…