设为首页 加入收藏

TOP

明解STM32—GPIO理论基础知识篇之八种工作模式(一)
2023-07-23 13:28:48 】 浏览:43
Tags:明解 STM32 GPIO

一、引言

        在之前围绕STM32的GPIO的基本结构进行了介绍,图1为STM32的5V容忍的GPIO口内部基本结构图,图2为GPIO的基本结构中各个模块部分的概述。

        阅读GPIO基本结构的内容能够对GPIO的工作模式有更深的了解。正是由于GPIO的结构中包含了多样性的电路和模块,因此进行合理的配置组合,就可以使得GPIO应用在不同的工作模式下进行工作。?

图1 STM32的5V容忍的GPIO内部基本结构

 

图2 GPIO基本结构包含的功能概述


二、工作模式概述

        图3为STM32的GPIO工作模式概述图,从图中可以看出,GPIO端口的静态特征就是指芯片可供你选择的该GPIO的配置,只有通过对使用的GPIO端口进行合理的配置,那么才可以让GPIO处于某一种工作模式下实现合理的动态工作运行。

        下一节我们就结合GPIO的基本结构来对不同工作模式下端口的特征及运行方式进行进一步的分析。

 

 

图3 GPIO工作模式概述


三、工作模式详述

        接下来就对STM32的GPIO总共8种工作模式进行一个详细的介绍。

(1)、普通IO推挽输出

        图4是普通IO推挽输出。普通IO口推挽输出就是,对输出数据寄存器进行置0或置1操作,然后通过输出控制缓冲器对双MOS电路进行控制。IO电平输出的双MOS电路通路同时由PMOS和NMOS组成,当输出控制端输出为1时,上方PMOS导通,下方NMOS截止,电流方向为VDD->PMOS->输出端,对外部引脚输出高电平;当输出控制端输出为0时,上方PMOS截止,下方NMOS导通, 电流方向为VSS->NMOS->输出端,对外输出低电平。此时对输入数据寄存器的读访问可得到I/O状态。

        GPIO配置成输出模式时,可使用上拉、下拉或悬空模式。但此时由于输出模式时引脚电平连接到输出数据寄存器,而输出数据寄存器对应引脚的位为0,即引脚初始化后默认输出低电平,所以在这种情况下,上拉只能起到小幅提高输出电流能力,但不会影响引脚的默认状态。

?图4 普通IO推挽输出

(2)、普通IO开漏输出

        图5是普通IO开漏输出。普通IO开漏输出,就是在输出控制时,不使用双MOS电路中的PMOS,因此无法输出高电平,只有在输出低电平时,NMOS生效。开漏输出时,只有NMOS工作,这样输出数据寄存器可控制I/O输出高阻态或低电平。如果要输出高电平,则需要在芯片内部配置上拉电阻(弱上拉)或者在芯片IO外部连接上拉电阻。此时对输入数据寄存器的读访问可得到I/O状态。

        使用开漏输出时,可以实现以下功能:

        1)提高IO驱动能力。MCU的IO口对外驱动的能力很小,即使使用芯片内部的上拉电阻,由于内部上拉阻值很大,驱动能力也有限。因此使用开漏输出时,可以在IO口外部连接上拉电阻,此时驱动电流芯片由外部上拉电阻电源提供,这样提高驱动和带负载能力。

        2)电平转换。如MCU只能对外输出3.3v,但由于GPIO管脚是5v容忍的,输出高电平可以通过外部电源提供,外部电源如果是5v。此时可以对外输出5v。

        3)线与。多个开漏的引脚可以直接并在一起使用,统一接一个合适的上拉电阻,就可以实现“逻辑与”关系,即当所有引脚均输出高电平时,输出才为高电平,若任一引脚输出低电平,则输出低电平。?

图5 普通IO开漏输出

(3)、复用功能推挽输出

        图6是复用功能推挽输出。GPIO不仅仅可以用作普通的 IO 口输出,还可以作为芯片上其他外设的特殊功能引脚,有些引脚可能可以用作多种不同功能,这种就叫做GPIO的复用,具体用作哪种功能,需要根据使用进行相应的配置。使用成复用功能时,GPIO就不会经过输出数据寄存器输出,而是直接通过芯片上的具体外设功能电路输出到输出控制缓冲器。此时通过读输入数据寄存器可获取I/O实际状态,但一般直接用外设的寄存器来获取该数据信号。

        使用GPIO复用功能时,当配置成推挽输出,这样片上外设就可以输出高电平或者低电平,例如将GPIO配置成串口USART输出TXD管脚。

        需要注意的是,如果需要实现DAC模拟输出,那么也需要将管脚配置成复用功能,但是此时作为“模拟输出”功能,DAC的模拟信号输出就不经过双MOS管结构了,在GPIO结构框图的右下角处,模拟信号直接输出到引脚。

        用于复用功能时,可使用上拉、下拉或者浮空模式。在这种情况下,初始化后引脚默认输出低电平,上拉只起到小幅提高输出电流能力,并不会影响引脚的默认状态。

?

图6 复用功能推挽输出

(4)、复用功能开漏输出

        图7是复用功能开漏输出。复用功能开漏输出时,GPIO就不会经过输出数据寄存器输出,而是直接通过芯片上的具体外设功能电路输出到输出控制缓冲器。此时通过读输入数据寄存器可获取I/O实际状态,但一般直接用外设的寄存器来获取该数据信号。

        复用开漏输出的功能和普通IO开漏输出功能一致,因此GPIO用作复用功能管脚如果要输出高电平,则需要在芯片内部配置上拉电阻(弱上拉)或者在芯片IO外部连接上拉电阻。例如将GPIO配置成I2C信号线的时钟管脚SCL和数据管脚SDA。

?

图7 复用功能开漏输出

(5)、带上

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇What is UDS Service 0x10? 下一篇手把手教你基于luatos的4G(LTE Ca..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目