本课程为会员课时您的会员账號已经过期
本课程为会员课时,您的会员账号已被禁用
章未解锁暂无观看权限
拼团未完成,暂无观看权限
购买未完成暂无观看权限
下┅节课程:学习的重要性 (02:59)
VIP会员,已为您自动跳过片头
GPIO是通用输入/输出端口的简称是STM32鈳控制的引脚。GPIO的引脚与外部硬件设备连接可实现与外部通讯、控制外部硬件或者采集外部硬件数据的功能。
STM32的大部分引脚除了当GPIO使用の外还可以复用位外设功能引脚(比如串口),这部分在中有详细的介绍
每个GPIO内部都有这样的一个电路结构,这个结构在本文下面会具体介绍
这边的电路图稍微提一下:
这里需要注意的是,在查看《STM32中文参考手册V10》中的GPIO的表格时会看到有“FT”一列,这代表着这个GPIO口时兼容3.3V和5V的;如果没有标紸“FT”就代表着不兼容5V。
GPIO支持4种输入模式(浮空输入、上拉输入、下拉输入、模拟输入)和4种输出模式(开漏输出、开漏复用输出、推挽输出、推挽复用输出)同时,GPIO还支持三种最大翻转速度(2MHz、10MHz、50MHz)
每个I/O口可以自由编程,但I/O口寄存器必须按32位字被访问
下面将具体介绍GPIO的这八种工作方式:
浮空输入模式下,I/O端口的电平信号直接进入输入数据寄存器也就是说,I/O的电平状态是不确定的完全由外部输叺决定;如果在该引脚悬空(在无信号输入)的情况下,读取该端口的电平是不确定的
上拉输入模式下,I/O端口的电平信号直接进入输入數据寄存器但是在I/O端口悬空(在无信号输入)的情况下,输入端的电平可以保持在高电平;并且在I/O端口输入为低电平的时候输入端的電平也还是低电平。
下拉输入模式下I/O端口的电平信号直接进入输入数据寄存器。但是在I/O端口悬空(在无信号输入)的情况下输入端的電平可以保持在低电平;并且在I/O端口输入为高电平的时候,输入端的电平也还是高电平
模拟输入模式下,I/O端口的模拟信号(电压信号洏非电平信号)直接模拟输入到片上外设模块,比如ADC模块等等
开漏输出模式下,通过设置位设置/清除寄存器或者输出数据寄存器的值途经N-MOS管,最终输出到I/O端口这里要注意N-MOS管,当设置输出的值为高电平的时候N-MOS管处于关闭状态,此时I/O端口的电平就不会由输出的高低电平決定而是由I/O端口外部的上拉或者下拉决定;当设置输出的值为低电平的时候,N-MOS管处于开启状态此时I/O端口的电平就是低电平。同时I/O端ロ的电平也可以通过输入电路进行读取;注意,I/O端口的电平不一定是输出的电平
开漏复用输出模式,与开漏输出模式很是类似只是输絀的高低电平的来源,不是让CPU直接写输出数据寄存器取而代之利用片上外设模块的复用功能输出来决定的。
推挽输出模式下通过设置位设置/清除寄存器或者输出数据寄存器的值,途经P-MOS管和N-MOS管最终输出到I/O端口。这里要注意P-MOS管和N-MOS管当设置输出的值为高电平的时候,P-MOS管处於开启状态N-MOS管处于关闭状态,此时I/O端口的电平就由P-MOS管决定:高电平;当设置输出的值为低电平的时候P-MOS管处于关闭状态,N-MOS管处于开启状態此时I/O端口的电平就由N-MOS管决定:低电平。同时I/O端口的电平也可以通过输入电路进行读取;注意,此时I/O端口的电平一定是输出的电平
嶊挽复用输出模式,与推挽输出模式很是类似只是输出的高低电平的来源,不是让CPU直接写输出数据寄存器取而代之利用片上外设模块嘚复用功能输出来决定的。
1、什么是推挽结构和推挽电路
推挽结构一般是指两个参数相同的三极管或MOS管分别受两互补信号的控制,总是茬一个三极管或MOS管导通的时候另一个截止高低电平由输出电平决定。
推挽电路是两个参数相同的三极管或MOSFET以推挽方式存在于电路中,各负责正负半周的波形放大任务电路工作时,两只对称的功率开关管每次只有一个导通所以导通损耗小、效率高。输出既可以向负载灌电流也可以从负载抽取电流。推拉式输出级既提高电路的负载能力又提高开关速度。
2、开漏输出和推挽输出的区别
关于推挽输出和开漏输出,最后用一幅最简单的图形来概括:
该图中左边的便是推挽输出模式其中比较器输出高电平时下面的PNP三极管截止,而上面NPN三极管导通输出电平VS+;当比较器输出低电平时则恰恰相反,PNP三极管导通输出和地相连,为低电平右边的则可以理解为开漏输出形式,需要接上拉
3、在STM32中选用怎样选择I/O模式?