STM32 GPIO 详解

news2025/1/12 18:11:26

0. 实验平台

基于STM32F407ZG

1. GPIO 简介

1.1 简介

GPIO全称:General Purpose Input Output,即通用输入输出端口,一般用来采集外部器件的信息或者控制外部器件工作,即输入输出

1.2 STM32 的 GPIO 特点

  1. 不同型号,IO口数量可能不一样,可通过选型手册快速查询
  2. 快速翻转,每次翻转最快只需要两个时钟周期(F1最高速度可以到50Mhz)
  3. 每个IO口都可以做中断
  4. 支持 8 种工作模式(后面会详解)

1.3 STM32 的 GPIO 电气特性

  1. STM32 的工作电压:2 V ≤ VDD ≤ 3.6 V
  2. GPIO 的识别范围:COMS 端口:
    -0.3 V ≤ VIL ≤ 1.164 V
    1.833 V ≤ VIH ≤ 3.6 V
  3. 输出电流:单个 GPIO 最大 25mA

2. STM32F4 端口结构

STM32F1 系列与 F4 有细微的差别,但是原理都是互通的
下图可以在 STM32F4xx 手册中的 GPIO 章节找到
在这里插入图片描述

  1. 保护二极管,保护接入电路的电压不会超过可承受的范围
  2. 上下拉电阻,通常阻值在 30-50KΩ ,是一种弱上下拉(电流很小,不具备驱动能力)
  3. 施密特触发器,可以使得非方波信号转为方波信号
  4. P-MOS & N-MOS 管

下面会详解 施密特触发器 和 P-MOS & N-MOS 管

2.1 施密特触发器

施密特触发器就是一种整形电路,可以将非标准方波整形成方波,特点如下

  • 当输入电压高于正向阈值电压,输出为高;
  • 当输入电压低于负向阈值电压,输出为低;
  • 当输入在正负向阈值电压之间,输出不改变
    在这里插入图片描述

2.2 P-MOS & N-MOS 管

MOS 管是压控型元件,通过控制栅源电压( Vgs )来实现导通或关闭

在这里插入图片描述
在这里插入图片描述
其中,G是栅极,S是源极,D是漏极
对于 P-MOS:Vgs<0,导通
对于 N-MOS:Vgs>0,导通

3. GPIO 的 8 种工作模式

GPIO8 种模式特点及应用
输入浮空输入用,完全浮空,状态不定
输入上拉输入用,用内部上拉,默认是高电平
输入下拉输入用,用内部下拉,默认是低电平
模拟功能ADC、DAC
开漏输出软件 IIC 的 SDA、SCL 等
推挽输出驱动能力强,25mA,通用输出
开漏式复用功能片上外设功能(硬件 IIC 的 SDA、SCL 引脚等)
推挽式复用功能片上外设功能(SPI 的 SCK、MISO、MOSI引脚等)

3.1 输入浮空

电路状态:

  • 上拉 /下拉电阻断开
  • 施密特触发器打开
  • 输出被禁止。
  • P-MOS 和 M-MOS 管不导通

电路图:
在这里插入图片描述

适用场景: IO 口的电平完全是由外部电路决定。如果 IO 引脚没有连接其他的设备,那么检测其输入电平是不确定的。该模式可以用于检测外部引脚电平的情况(如按键,但是更常用的方法是设置为输入下拉或者上拉模式)

3.2 输入上拉

电路状态:

  • 上拉电阻接通
  • 下拉电阻断开
  • 施密特触发器打开
  • 输出被禁止
  • P-MOS 和 M-MOS 管不导通

电路图:
在这里插入图片描述
适用场景: IO 口的电平默认状态为高电平,但是外部有低电平输入的时候还是可以被读取到

3.3 输入上拉

电路状态:

  • 上拉电阻断开
  • 下拉电阻接通
  • 施密特触发器打开
  • 输出被禁止
  • P-MOS 和 M-MOS 管不导通

电路图:
在这里插入图片描述
适用场景: IO 口的电平默认状态为低电平,但是外部有高电平输入的时候还是可以被读取到

3.4 模拟功能

电路状态:

  • 上拉 /下拉电阻断开
  • 施密特触发器关闭
  • 输出被禁止
  • P-MOS 和 M-MOS 管不导通

电路图(更正:蓝色框中为输入部分):
在这里插入图片描述
适用场景: 该模式用于 ADC 采集或者 DAC 输出,或者低功耗下省电

3.5 开漏输出

电路状态:

  • 上拉 /下拉电阻根据寄存器的值决定是否导通
  • 施密特触发器打开
  • 可以通过数据寄存器访问 IO 状态
  • P-MOS 管始终不激活
  • 输出寄存器中输入 0 会激活 M-MOS 管

电路图(更正:蓝色框中为输入部分):

在这里插入图片描述
电路图解析:
开漏模式下,P-MOS 管是一直截止的,所以 P-MOS 管的栅极一直接 VSS。

如果输出数据寄存器设置为 0 时,经过“输出控制”的逻辑非操作后,输出逻辑 1 到 N-MOS 管的栅极,这时 N-MOS 管就会导通,使得 I/O 引脚接到 VSS,即输出低电平。

如果输出数据寄存器设置为 1 时,经过“输出控制器”的逻辑非操作后,输出逻辑 0 到 N-MOS 管的栅极,这时 N-MOS 管就会截止。因为 P-MOS 管是一直截止的,使得 I/O 引脚呈现高阻态,即不输出低电平,也不输出高电平。因此要 I/O 引脚输出高电平就必须接上拉电阻。这时可以接内部上拉电阻,或者接一个外部上拉电阻。由于内部上拉电阻的阻值较大,所以只是“弱上拉”。需要大电流驱动,需要接外部的上拉电阻。

此外,上拉电阻具有线与特性,即如果有很多开漏模式的引脚连在一起的时候,只有当所有引脚都输出高阻态,电平才为 1,只要有其中一个为低电平时,就等于接地,使得整条线路都为低电平 0。IIC 通信( IIC_SDA)就用到这个原理。

另外在开漏输出模式下,施密特触发器是打开的,所以 IO 口引脚的电平状态会被采集到输入数据寄存器中,如果对输入数据寄存器进行读访问可以得到 IO 口的状态。也就是说开漏输出模式下,我们可以对 IO 口进行读数据。

特点和适用场景:它只能输出低电平 Vss 或者高阻态,常用于软件 IIC 的 SDA、SCL 等

3.6 推挽输出

电路状态:

  • 上拉 /下拉电阻根据寄存器的值决定是否导通
  • 施密特触发器打开
  • 可以通过数据寄存器访问 IO 状态
  • P-MOS 管和 N-MOS 管通过输出寄存器的值来决定是否导通

电路图(更正:蓝色框中为输入部分):
在这里插入图片描述

电路图解析:

如果输出数据寄存器设置为 0 时,经过“输出控制”的逻辑非操作后,输出逻辑 1 到 P-MOS 管的栅极,这时 P-MOS管就会截止,同时也会输出逻辑 1 到 N-MOS 管的栅极,这时 N-MOS 管就会导通,使得 I/O 引脚接到引脚接到 VSS,即输出低电平。

如果输出数据寄存器设置为 1 时,经过“输出控制”的逻辑非操作后,输出逻辑 0 到到 N-MOS 管的栅极,这时 N-MOS 管就会截止,同时也会输出逻辑 0 到 P-MOS 管的栅极,这时 P-MOS 管就会导通,使得 I/O 引脚接到引脚接到 VDD,即输出高电平。

推挽输出模式下,P-MOS 管和 N-MOS 管同一时间只能有一个管 MOS 管是导通的。当引脚高低电平切换时,两个管子轮流导通,一个负责灌电流,一个负责拉电流,使其负载能力和开关速度都有很大的提高。

另外在推挽输出模式下,施密特触发器也是打开的,可以读取IO口的电平状态。由于推挽输出模式输出高电平时,是直接连接VDD ,所以驱动能力较强,可以做电流型驱动,驱动电流最大可达25mA。该模式也是最常用的输出模式。

特点和适用场景:可以输出最大 25mA 的电流,可以用来驱动一些外设如 LED 灯等

3.7 开漏式复用

电路状态:

  • 上拉 /下拉电阻根据寄存器的值决定是否导通
  • 施密特触发器打开
  • 可以通过数据寄存器访问 IO 状态
  • P-MOS 管始终不激活
  • 引脚的状态由外设决定, 0 会激活 M-MOS 管

电路图(更正:蓝色框中为输入部分):
在这里插入图片描述
适用场景:片上外设功能(硬件IIC 的SDA、SCL引脚等)

3.8 推挽式复用

电路状态:

  • 上拉 /下拉电阻根据寄存器的值决定是否导通
  • 施密特触发器打开
  • 可以通过数据寄存器访问 IO 状态
  • P-MOS 管和 N-MOS 管通过外设来决定是否导通

电路图(更正:蓝色框中为输入部分):
在这里插入图片描述
适用场景:片上外设功能(SPI 的SCK、MISO、MOSI引脚等)

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

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

相关文章

SpringBatch从入门到实战(五):执行上下文和单步骤重启

一&#xff1a;执行上下文 1.1 Job Context 作业上下文 JobContext 绑定 JobExecution 执行对象&#xff0c;为Job作业执行提供执行环境(上下文)。 1.2 Step Context 步骤上下文 StepContext 绑定 StepExecution 执行对象&#xff0c;为Step步骤执行提供执行环境(上下文)。 …

【剑指offer专项突破版】栈篇——“C“

文章目录 前言一、后缀表达式题目分析思路分析代码 二、小行星碰撞题目分析思路分析代码 三、每日温度题目分析思路分析代码 四、直方图最大矩形面积题目分析思路分析代码 五、矩阵中最大的矩形题目分析思路分析代码 总结 前言 剑指offer专项突破版&#xff08;力扣官网&#x…

IBM不藏私:深刻解析量子计算机的突破和机遇

​ 巴伐利亚科学部长Markus Blume在莱布尼茨超级计算中心与Dieter Kranzlmlle&#xff08;左&#xff09;一起观看量子计算机的部分构件。&#xff08;图片来源&#xff1a;网络&#xff09; 关于量子计算机的研究已进行了数十年&#xff0c;目前还尚未生产一台能够掀起计算革命…

Vue全家桶(一):Vue基础+Vue-Cli+Vue组件化+过渡动画

目录 1.Vue概述1.1 认识Vue1.2 Vue的两核心1.3 Vue的初体验1.4 Vue的生命周期 2. Vue-CLI (Command Line Interface)3. Vue基本使用3.1 传统开发模式对比3.2 Vue.js引入3.3 Vue.js 案例分析3.3.1 实例参数el、data、methods的写法 4. Vue模板语法4.1 插值语法 {{xxx}}4.2 指令语…

vue3+ts:shims-vue.d.ts

一、本文引子 uniapp&#xff08;3.8.4.20230531&#xff09; vue3 ts vite 项目 在搭建这个base项目的时候出现红素波浪线如图&#xff0c;代码运行正常&#xff0c;但是看起来很难受&#xff0c;于是各种查找&#xff0c;能找到的资料很少&#xff0c;可能和我提问不够准…

【备战秋招】每日一题:4月23日美团春招第一题:题面+题目思路 + C++/python/js/Go/java带注释

为了更好的阅读体检&#xff0c;为了更好的阅读体检&#xff0c;&#xff0c;可以查看我的算法学习博客第一题-申请奖学金 在线评测链接:P1245 题目内容 塔子哥是一个热爱学习的大学生&#xff0c;他的梦想是成为一名优秀的算法竞赛高手。为了实现自己的梦想&#xff0c;他需…

代理ip匿名原理及那些行业需要代理ip

互联网的高速发展&#xff0c;连带了代理ip也受到了更多人的使用&#xff0c;不同的行业都存在使用代理ip的情况&#xff0c;同时代理ip也以为匿名程度分成了高匿、普匿、透明代理&#xff0c;那么代理ip匿名的原理是什么呢&#xff1f;又有哪些行业需要代理ip呢&#xff1f;下…

flume环境配置-传输Hadoop日志(namenode或datanode日志)

解压文件 修改文件名 配置环境变量 执行flume-ng version 将flume-env.sh.template改名为flume-env.sh&#xff0c; 并修改其配置 启动Flume传输Hadoop日志 启动flume 解压文件 tar -zxvf apache-flume-1.9.0-bin.tar.gz -C /opt 修改文件名 mv apache-flume-1.9.0-b…

全面安全防护,加速企业创新发展——亚马逊云科技re:Inforce全球大会

亚马逊云科技re:Inforce 2023全球大会于当地时间2023年6月13日在美国加州安纳海姆拉开帷幕。在大会上&#xff0c;亚马逊云科技宣布推出十多项安全新服务及功能&#xff0c;下面就来一览本次大会的风采。 “Security is our top priority.” “安全是我们的首要优先级”&#…

Java 面向对象 | 详细知识图谱式讲解

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; ☢Java入门 基础知识&#xff1a;了解 Java 基本语法、面向对象编程&#xff08;OOP&#xff09;概念、流程控制语句、数据类型、方法等基础知识。可以通过 Java 编程…

Nodejs七、身份认证

零、文章目录 Nodejs七、身份认证 1、Web 开发模式 &#xff08;1&#xff09;目前主流的 Web 开发模式 基于服务端渲染的传统 Web 开发模式基于前后端分离的新型 Web 开发模式 &#xff08;2&#xff09;服务端渲染的 Web 开发模式 服务器发送给客户端的 HTML 页面&…

HBase Shell操作HBase进行预分区

本文将介绍如何使用HBase Shell操作HBase进行预分区。预分区是指在创建表的时候&#xff0c;指定表的初始分区点&#xff0c;从而使表的数据能够均匀地分布在多个RegionServer上&#xff0c;提高读写性能和负载均衡。本文将使用HBase Shell命令&#xff0c;创建不同的预分区表&…

Allure在自动化测试中的应用

目录 前言&#xff1a; 01Allure的简介及使用 1、应用场景 02Allure与Pytest结合 1、添加测试步骤 2、添加主要功能模块描述 3、添加严重等级 03Allure集成Jenkins 1、Jenkins介绍和安装 2、Jenkins安装allure插件 前言&#xff1a; Allure是一种流行的测试报告框架…

Floating UI 使用经验分享 - Dialog

上文&#xff1a;Floating UI 使用经验分享 - Popover 在本文中&#xff0c;我将分享如何使用 Floating UI 来创建另一种常见的浮动 UI 组件——Dialog&#xff08;对话框&#xff09;。Dialog 是一个浮动元素&#xff0c;显示需要立即关注的信息&#xff0c;他会出现在页面内…

5G NR基于码本的上行传输

上行传输受基站DCI调度&#xff0c;UE收到DCI信息后&#xff0c;根据PMI信息选择相应的码本。 在3GPP TS 38.211 6.3.1.5节中&#xff0c;定义了不同天线端口数和不同传输层数情况下的可选码本。下面截取了单层2天线端口码本和双层两天线端口码本。 gNB在什么情况下为UE选择什…

Python--序列

Python--序列 <font colorblue>一、定义<font colorblue>二、索引<font colorblue>1.从左往右的索引&#xff1a;索引值从0开始递增<font colorblue>2.从右往左的索引&#xff1a;从-1开始递减 <font colorblue>三、切片<font colorblue>四…

Unity3d_Cut\Clipping sphere\CSG(boolean)(裁剪模型重合部分)总结

1、https://liu-if-else.github.io/stencil-buffers-uses-in-unity3d/ 下载&#xff1a;https://github.com/liu-if-else/UnityStencilBufferUses 2、手动切割 Unity 模型切割工具,CSG,任意图案,任意切割_unity csg_唐沢的博客-CSDN博客 3、 Shader Unity Shader学习&#x…

【从删库到跑路】详细讲解MySQL的函数和约束作用

&#x1f38a;专栏【MySQL】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 大一同学小吉&#xff0c;欢迎并且感谢大家指出我的问题&#x1f970; 文章目录 &#x1f354;函数⭐字符串函数&#x1f388;字符串拼接函数&…

Python基础知识 数据容器

id() 函数是python 内置函数 返回 id() 函数返回对象的唯一标识符&#xff0c;标识符是一个整数。 a, b, c 20, 30 , 40 print(a,b,c) ## a20 b 30 c40 ## 跟ES6系列中的析构函数原理一样Python中 字符串不能通过 &#xff0c;把 数字等非字符串&#xff0c;进行拼接…

Redis从入门到精通【高阶篇】之底层数据结构链表包(listpacks)详解

文章目录 0.前言2. listpacks&#xff08;紧凑列表&#xff09;2. 源码解析3. 总结 0.前言 上个篇章回顾&#xff0c;我们上个章节我们学习了《Redis从入门到精通【高阶篇】之底层数据结构字典(Dictionary)详解》 本文将Redis底层数据结构 listpacks&#xff08;链表包&#…