72285|90

66

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

STM32GPIO的十大优越功能综述 [复制链接]

前几天Hotpower邀请大家讨论一下GPIO的功能、性能和优缺点(STM32的GPIO很强大~~~),等了几天没见太多人发言,但综合来看提到了3点:1)真双向IO,2)速度快,3)寄存器功能重复。关于第3点有说好,有说多余的,见仁见智。

下面我就在做个抛砖引玉,根据ST手册上的内容,简单地综述一下GPIO的功能:
一、共有8种模式,可以通过编程选择:
  1. 浮空输入
  2. 带上拉输入
  3. 带下拉输入
  4. 模拟输入
  5. 开漏输出——(此模式可实现hotpower说的真双向IO)
  6. 推挽输出
  7. 复用功能的推挽输出
  8. 复用功能的开漏输出
模式7和模式8需根据具体的复用功能决定。

二、专门的寄存器(GPIOx_BSRR和GPIOx_BRR)实现对GPIO口的原子操作,即回避了设置或清除I/O端口时的“读-修改-写”操作,使得设置或清除I/O端口的操作不会被中断处理打断而造成误动作。

三、每个GPIO口都可以作为外部中断的输入,便于系统灵活设计。

四、I/O口的输出模式下,有3种输出速度可选(2MHz、10MHz和50MHz),这有利于噪声控制。

五、所有I/O口兼容CMOS和TTL,多数I/O口兼容5V电平。

六、大电流驱动能力:GPIO口在高低电平分别为0.4V和VDD-0.4V时,可以提供或吸收8mA电流;如果把输入输出电平分别放宽到1.3V和VDD-1.3V时,可以提供或吸收20mA电流。

七、具有独立的唤醒I/O口。

八、很多I/O口的复用功能可以重新映射,见:你知道吗?STM32上很多管脚功能可以重新映射

九、GPIO口的配置具有上锁功能,当配置好GPIO口后,可以通过程序锁住配置组合,直到下次芯片复位才能解锁。此功能非常有利于在程序跑飞的情况下保护系统中其他的设备,不会因为某些I/O口的配置被改变而损坏——如一个输入口变成输出口并输出电流。

十、输出模式下输入寄存器依然有效,在开漏配置模式下实现真正的双向I/O功能。


我这里总结的不一定全面,请各位补充,并讨论各种功能在实际应用中的优缺点,谢谢。
此帖出自stm32/stm8论坛

最新回复

                                 版主分析的很全啊  详情 回复 发表于 2010-12-12 19:47
点赞 关注
 

回复
举报

101

帖子

0

TA的资源

一粒金砂(中级)

沙发
 

有些不放心~~俺要做实验证实才放心~~~

十、输出模式下输入寄存器依然有效,在开漏配置模式下实现真正的双向I/O功能。
此帖出自stm32/stm8论坛
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

板凳
 

就知道你会追过来,另一贴子中有一张图

                                 可以看到输入和输出是两条不同的路径。
此帖出自stm32/stm8论坛
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

4
 

哈哈~~~文盲看图更快些,搞清楚了~~~谢谢!!!

                                  
此帖出自stm32/stm8论坛
 
 
 

回复

65

帖子

0

TA的资源

一粒金砂(初级)

5
 

俺再劳驾香主一下:有开漏且上拉的输出模式吗???

                                 这样俺就不用外挂上拉电阻了~~~
此帖出自stm32/stm8论坛
 
 
 

回复

67

帖子

0

TA的资源

一粒金砂(初级)

6
 

不好意思,STM32没有开漏且上拉的输出模式

                                 只能用外挂上拉电阻了,好在价钱不贵,嘿嘿~~~
此帖出自stm32/stm8论坛
 
 
 

回复

94

帖子

0

TA的资源

一粒金砂(中级)

7
 

开漏且上拉的输出模式

开漏且上拉的输出模式是不支持的:
STM32英文版Rev.2参考手册,第5.1.8 "Output configuration"写清楚了:
The weak pull-up and pull-down resistors are disabled
此帖出自stm32/stm8论坛
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

8
 

呵呵,很强大~ 很和谐~ 收藏!

                                  
此帖出自stm32/stm8论坛
 
 
 

回复

92

帖子

0

TA的资源

一粒金砂(初级)

9
 

没有开漏且上拉的输出模式,那么IIC操作需要加上拉电阻吗

                                 没有开漏且上拉的输出模式,那么IIC操作需要加上拉电阻吗?不方便啊。可要小心了。
此帖出自stm32/stm8论坛
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

10
 

开漏双向IO在模拟串行通信和IO自检方面的优势

8031的准双向IO的成功,也支持了它能在业界存活的时间更长,当然AT89C51
是后继者中最大的功臣~~~

准双向IO实际就是带上拉功能的开漏输出且能读写的双向IO,它在速度允许时,

几乎可以模拟任何串行接口,特别是将SPI接口的MISO和MOSI短接变为单线双向

接口SIO.

虽然它的拉电流很小,但对保护IO不受损坏起到了关键的作用.

如果大家都是这种准双向的IO接口,那么大家线与又有谁害怕IO被毁呢???

所以这种准双向IO的优点就可以实现IO的自检,在配合下面的"电路"即可实现

IO不怕接VCC,不怕接地,不怕混线,不怕断线(过孔未沉铜)~~~

即可在一片IO上用铁棍"弹钢琴"~~~

"电路"

V---自恢复保险---+----LDO----MCU---IO <---搞破坏(VCC,GND,...)
                 |                 
            瞬态拟制器
                 |
                GND
相关链接:https://bbs.eeworld.com.cn/club/bbs/showEssence.asp?id=6439&page=3
此帖出自stm32/stm8论坛
 
 
 

回复

86

帖子

0

TA的资源

一粒金砂(初级)

11
 

还是大叔的理论水平高,一个开漏双向IO就能整出篇文章来

                                 好!
此帖出自stm32/stm8论坛
 
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

12
 

哈哈~~~抓把铁纱撒在芯片上也平安无事,不知敢在STM32上做实

                                 哈哈~~~俺现在没这个胆~~~
此帖出自stm32/stm8论坛
 
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

13
 

非典~~~~~~~~

                                  
此帖出自stm32/stm8论坛
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

14
 

H大叔以后可以做个STM32的板子试试 呼呼



电源这块得好好考虑

向往不怕短路的板子
此帖出自stm32/stm8论坛
 
 
 

回复

85

帖子

0

TA的资源

一粒金砂(初级)

15
 

晕...开漏且能读IO状态,那个不叫“真”双向IO吧?叫“准”

                                  
此帖出自stm32/stm8论坛
 
 
 

回复

67

帖子

0

TA的资源

一粒金砂(初级)

16
 

倒塌了.10楼那句提到"真"双向了???"准"字不老少~~~00学会报复

                                 长大了~~~
此帖出自stm32/stm8论坛
 
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

17
 

本来打算OD输出5V呢

                                 最后发现上不去,内部的ESD二极管强制拉下来了
此帖出自stm32/stm8论坛
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

18
 

哈哈~~~俺说楼主的,没说10楼的~~~

                                 你看楼主的第5条,写的就是真双向嘛。
此帖出自stm32/stm8论坛
 
 
 

回复

63

帖子

0

TA的资源

一粒金砂(初级)

19
 

看到LS的LS说的,发现我刚才开的主题是白问了

5V容忍似乎办不到了

大概和STR71X一样,只有I2C管脚能5V容忍了
此帖出自stm32/stm8论坛
 
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

20
 

谢谢17楼的实验

首先我们会做相应试验看看是否所有管脚都是如此还是个别管脚,然后还要与设计师沟通已证实实验现象。按照我的理解开漏输出应可通过外部上拉产生有别于芯片供电电压的电平,但如果确如17楼所说输出电平“被内部的ESD二极管强制拉下来”,这确实是个遗憾。

我会进一步证实这一现象。


关于5V容忍的问题,这个一个被动的概念,即把5V电压输入到相应管脚,该管脚能够承受这个电压并正确地识别逻辑"0"和"1";是否能够输出5V不属于“5V容忍的问题”。
此帖出自stm32/stm8论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表