当前位置: 首页 > news >正文

GPIO的内部结构与功能解析

一、GPIO总体结构

 总体构成

1.APB2(外设总线)

APB2总线是微控制器内部连接CPU与外设(如GPIO)的总线,负责CPU对GPIO寄存器的读写访问,支持低速外设通信

2.寄存器

控制GPIO的配置(输入/输出模式、上拉/下拉等)和状态读取(输入电平、输出电平等)

3.驱动器

GPIO驱动器负责将寄存器中设置的电平信号转换为实际的电压输出,驱动外部负载。同时,驱动器也对输入信号进行缓冲和整形,确保信号稳定传输到输入寄存器,有着数据预处理作用

二、内部构造

某一个端口内部的结构  

1.保护二级管

二极管具有单项导通性,在输入情况下,当引脚电平低于Vss,Vss与引脚之间二极管导通,防止从GPIO内部汲取电流,同理,当引脚电平高于Vdd,引脚与Vdd之间二极管导通,防止GPIO内部电流过载。

2.上拉电阻和下拉电阻

为了解决引脚悬空导致输入电平不确定的状态,以接上拉电阻为例,可以保证默认输入电压为高电平,为什么呢,因为GPIO内部的等效电阻非常大,与上拉电阻串联,根据串联分压可以知道电阻的压降很小,所以输入等价于固定在高电平。那么为什么需要接上拉电阻呢,直接去掉不行吗?我的理解是:如果去掉上拉电阻,那么当输入引脚为0,那么输入驱动器内部的Vdd与输入引脚之间就短路,进而可能会导致元器件损坏。

3.施密特触发器(如图中肖特基触发器,翻译错误)

用于对输入电压进行整型,提高输入的稳定性,图中输入到输入寄存器中的某一位,如下图所示,只有电压低于下线low或者高于上线low才会变化。同时由于片上外设ADC需要接受模拟量,因此可以在施密特触发器整型之前获取输入的模拟量。

 4.端口输出

 输入设置如下,经过二路选择器来选择输出的是GPIOx寄存器的指定比特位or复用功能信号。位设置/清楚寄存器可以用来操作寄存器中的某一位,而不影响其他位(输出数据寄存器只能整体读写)。输出控制,根据输出寄存器的位信息,当输出低电平,P-MOS导通,N-MOS截止,输出高电平,反之输出低电平。

GPIO的八种工作模式 

1.浮空输入、上拉输入、下拉输入

三种输入方式在于是否连接上拉电阻和下拉电阻,这种模式下输出控制断开,只进行输入。当引脚悬空时,浮空输入电平不确定,上拉输入电平默认高电平,下拉输入电平默认低电平。

 2.模拟输入

模拟输入时,不连接上拉电阻和下拉电阻。

3.开漏/推挽输出

当P-MOS无效,N-MOS有效,就是开漏输出,这时候高电平为高阻态,这可以兼容不同的部件的高电平电压值,把高电平值交给连接的部件决定(上拉输入)。同时输出情况下,可以保持正常读的功能,感知输出值,但是输入情况下不能输出,可能因为防止输出高电平,输入低电平导致短路。

 4.复用开漏/推挽输出

只不过复用的输出,引脚的电平是由片上外设所决定的。

http://www.lqws.cn/news/109999.html

相关文章:

  • 普中STM32F103ZET6开发攻略(四)
  • .Net Framework 4/C# 初识 C#
  • C#面试问题81-100
  • RabbitMQ如何保证消息可靠性
  • C++实现图形化2048小游戏
  • web第八次课后作业--分层解耦
  • 【刷机】从pixel刷回miui12的过程记录
  • JS语法笔记
  • Office文档图片批量导出工具
  • 如何安装huaweicloud-sdk-core-3.1.142.jar到本地仓库?
  • Microsoft前后端不分离编程新风向:cshtml
  • SoloSpeech - 高质量语音处理模型,一键提取指定说话人音频并提升提取音频清晰度和质量 本地一键整合包下载
  • 博客操作规范
  • 书籍在其他数都出现k次的数组中找到只出现一次的数(7)0603
  • 【最新版】西陆洗车系统源码全开源+uniapp前端+搭建教程
  • 接口自动化测试之pytest 运行方式及前置后置封装
  • 【AI学习从零至壹】基于深度学习的⽂本分类任务
  • 红外遥控器接收实验:Simulink应用层开发
  • Unity Shader编程】之高级纹理
  • Lua和JS的继承原理
  • SAP学习笔记 - 开发20 - 前端Fiori开发 Nest View(嵌套视图) ,Fragment(片段)
  • 吞咽与营养并重:进行性核上性麻痹的饮食之道
  • 什么是“音节”?——语言构成的节拍单位
  • FreeRTOS,其历史争议、兼容性、生态、未来展望
  • MYSQL索引详解及索引优化、分析
  • MyBatis常用注解全解析:从基础CRUD到高级映射
  • RL中的熵机制:策略熵坍缩分析与协方差正则化方法
  • 【FreeRTOS#1】多任务处理任务调度器任务状态
  • 【计算机网络 第8版】谢希仁编著 第六章应用层 题型总结1 编码
  • 队列的讲解:C++队列的使用