找回密码
 注册
关于网站域名变更的通知
查看: 398|回复: 3
打印 上一主题 下一主题

STM32的GPIO结构图分析

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2018-10-16 14:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 mm58690 于 2018-10-16 14:53 编辑
9 d" L; G1 V* @) O$ u
5 ]. @1 g" K1 j+ m
1、STM32的GPIO结构图
GPIO共有8中设置模式:输入浮空、输入上拉、输入下拉、模拟输入、开漏输出、推挽式输出、推挽式复用功能,开漏复用功能,共4种输入,2种输入,2种复用功能。

3 Q/ P, `; S2 K; V2 v1 c
2、模式说明
, B, x0 c4 s+ \; \+ e1 Z; B( {; C
①浮空输入
图中施密特触发器是开启的,IO口的状态可以直接送到输入寄存器中,CPU可以直接读取输入寄存器;
在上图中,阴影的部分处于不工作状态,尤其是下半部分的输出电路,实际上是与端口处于隔离状态。
黄色的高亮部分显示了数据传输通道,外部的电平信号通过左边编号1的IO端口进入STM32,经过编号2的施密特触发器的整形送入编号3的输入数据寄存器,在输入数据寄存器的另一端编号4,CPU可以随时读出IO端口的电平状态。

8 K- j1 p- L# `
②上拉输入
上图是STM32的GPIO带上拉输入模式的配置。与前面的浮空输入模式相比,仅仅是在数据通道上部,接入了一个上拉电阻,根据STM32的数据手册,这个上拉电阻阻值介于30K~50K。
同样,CPU可以随时在输入数据寄存器的另一端,读出IO端口的电平状态。
; Q: c6 i5 [: I  m$ `0 b- j# B
③下拉输入

( v6 R. O, N3 G. G
④模拟输入
施密特触发器是关闭的,信号直接到ADC输入;
STM32的模拟输入通道的配置则更加简单,信号从左边编号1的端口进入,从右边编号2的一端直接进入ADC模块。
这里我们看到所有的上拉、下拉电阻和施密特触发器,均处于断开状态,因此输入数据寄存器将不能反映端口上的电平状态,也就是说,模拟输入配置下,CPU不能在输入数据寄存器上读到有效的数据。
  E5 ^/ z' W  [0 l) _5 p6 A* f1 t
⑤开漏输出模式
当CPU在编号1端通过“位设置/清楚寄存器”或“输出数据寄存器”写入数据后,该数据位通过编号2的输出控制电路传送到编号4的IO端口。
) T2 C  t2 {; D4 P& y- L$ f
- J9 Q* Y" Q4 X. k: C
如果CPU写入的是逻辑1,则编号3的N-MOS管将处于关闭状态,此时IO端口的电平将由外部的上拉电阻决定,如果CPU写入的是逻辑0,则编号3的N-MOS管将处于开启状态,此时IO端口的电平被编号3的N-MOS管拉到了VSS的零电位。
. H0 U5 g& `4 G2 z) @
在上图的上半部,施密特触发器处于开启状态,这意味着CPU可以在“输入数据寄存器”的另一端,随时监控IO端口的状态;通过这个特性,还实现了虚拟的IO端口双向通信,只要CPU输出逻辑1,由于编号3的N-MOS管处于关闭状态,IO端口的电平将完全由外部电路决定,因此,CPU可以在“输入数据寄存器”读到外部电路的信号,而不是它自己输出的逻辑1。

2 j/ }9 G0 y; O7 t, C$ b2 ~' }
GPIO口的输出模式下,有3种输出速度可选(2MHz、10MHz和50MHz),这个速度是指GPIO口驱动电路的响应速度,而不是输出信号的速度,输出信号的速度与程序有关(芯片内部在IO口的输出部分安排了多个响应速度不同的输出驱动电路,用户可以根据自己的需要选择合适的驱动电路)。通过选择速度来选择不同的输出驱动模块,达到最佳的噪声控制和降低功耗的目的。高频的驱动电路,噪声也高,当不需要高的输出频率时,请选用低频驱动电路,这样非常有利于提高系统的EMI性能。当然如果要输出较高的频率的信号,但却选用了较低频率的驱动模块,很可能会得到失真的输出信号。

; ?! r7 z$ L- P8 h7 S% A$ X1 y
⑥开漏输出复用功能

/ Z1 x5 {! l: {, s
⑦推挽输出模式
" N" U6 ^& p) |4 H+ Y+ k8 G
⑧推挽复用输出模式

6 ]' P7 p- ?8 i( H% a
GPIO推挽复用输出模式,编号2的输出控制电路的输入,与复用功能的输出端相连,此时输出数据寄存器被从输出通道断开了,并和片上外设的输出信号连接。我们将GPIO配置成复用输出功能后,如果外设没有被激活,那么它的输出将不确定,其它部分与前述模式一致,包括对“输入数据寄存器”的读取。

% w# P$ E" I$ D! A# f( h  G  |
3、应用场合
0 R1 q9 n$ u" E, t
①上拉输入、下拉输入可以用来检测外部信号;例如,按键等;

6 J9 h" }$ V5 o* l1 B/ @+ [/ _
②浮空输入模式,由于输入阻抗较大,一般把这种模式用于标准通信协议的I2C、USART的接收端;
6 R& S9 `( d$ ^8 ^2 D  `3 i( p2 Y7 ^
③普通推挽输出模式一般应用在输出电平为0和3.3V的场合。而普通开漏输出模式一般应用在电平不匹配的场合,如需要输出5V的高电平,就需要在外部一个上拉电阻,电源为5V,把GPIO设置为开漏模式,当输出高阻态时,由上拉电阻和电源向外输出5V电平。

: ?3 K, i' y' k0 D: c1 N5 D$ T, }
④对于相应的复用模式,则是根据GPIO的复用功能来选择,如GPIO的引脚用作串口的输出,则使用复用推挽输出模式。如果用在IC、SMBUS这些需要线与功能的复用场合,就使用复用开漏模式。

9 T. e- {8 k0 L6 l6 Y
⑤在使用任何一种开漏模式时,都需要接上拉电阻。
% H! a0 h7 D6 d. ^4 Z$ Y

该用户从未签到

4#
发表于 2019-2-27 15:29 | 只看该作者
学习一下,谢谢分享; @0 g6 K% ]. j0 x5 I4 S
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-6-21 06:44 , Processed in 0.078125 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表