【经验】雅特力MCU AT32F435/437xx系列GPIO使用指南
本文介绍雅特力MCU AT32F435/437xx系列GPIO使用及配置。
GPIO特性
最大封装(144pin)具有116个多功能双向的I/O口;
所有I/O口都可以映射到16个外部中断;
绝大部分I/O口可容忍5V输入信号;
所有I/O口均为快速I/O,寄存器存取速度最高fAHB;
I/O引脚的外设功能可以通过一个特定的操作来开启写保护,以避免意外的写入I/O寄存器;
每个GPIO引脚都可以由软件配置成输出(推挽或开漏)、输入(带或不带上拉或下拉)或复用的外设功能端口;
可选的每个I/O口的电流推动/吸入能力;
端口位设置/清除寄存器(GPIOx_SCR)和端口位清除寄存器(GPIOx_CLR)为GPIOx_ODT寄存器提供位访问能力。
GPIO
GPIO在复位期间和刚复位后,复用功能未开启,大部分I/O端口被配置成浮空输入模式。当作为输出配置时,写到输出数据寄存器(GPIOx_ODT)上的值会输出到相应的I/O引脚。可以以推挽模式或开漏模式(仅低电平被驱动,高电平表现为高阻)使用输出驱动器。
输入数据寄存器(GPIOx_IDT)在每个AHB时钟周期捕捉I/O引脚上的数据。所有GPIO引脚有一个内部弱上拉和弱下拉,它们被激活或断开有赖于GPIOx_PULL寄存器的值。
图1. I/O端口位的基本结构

表1. I/O端口位配置表

GPIO toggle
AT32F435/437提供的I/O口均为快速I/O,寄存器存取速度最高为fAHB,所以可以看到在主频为240MHz时,GPIO翻转频率能够轻松达到120MHz:
图2. I/O翻转速度

IO引脚的5V or 3.3V容忍
标准3.3V容忍引脚(TC)
所有振荡器和USB_OTG用到的引脚都是标准3.3V容忍引脚。
PC14/PC15(LEXT_IN/OUT)
PH0/PH1(HEXT_IN/OUT)
PA11/PA12(OTGFS1_D-/D+)
PB14/PB15(OTGFS2_D-/D+)
表2. TC引脚示例

带模拟功能5V容忍引脚(FTa)
ADC占用端口为带模拟功能5V容忍引脚。
PA0–PA7,PB0–PB1,PC0–PC5,PF3–PF10
FTa引脚设置为输入浮空、输入上拉、或输入下拉时,具有5V电平容忍特性;设置为模拟模式时,不具5V电平容忍特性,此时输入电平必须小于VDD+0.3V
表3. FTa引脚示例

带20mA吸入能力5V容忍引脚(FTf)
部分I2C可提供带20mA吸入能力的5V容忍引脚。
表4. FT引脚示例

5V容忍引脚(FT)其余的GPIO都为5V容忍引脚。
表5. FT引脚示例

IOMUX
I/O复用功能输入/输出
大多数外设共享同一个GPIO引脚(比如PA0,可作为TMR2_CH1/TMR2_EXT/TMR5_CH1/TMR8_EXT/I2C2_SCL/USART2_CTS)
而对某个具体的GPIO引脚,在任意时刻只有一个外设能够与之相连
某些外设功能还可以重映射到其他引脚,从而使得能同时使用的外设数量更多
选择每个端口线的有效复用功能之一是由两个寄存器来决定的,分别是GPIOx_MUXL和GPIOx_MUXH复用功能寄存器。可根据应用的需求用这两寄存器连接复用功能模块到其他引脚。
表6. 通过GPIOA_AFR寄存器配置端口A的复用功能

表7. 通过GPIOB_AFR寄存器配置端口B的复用功能

表8. 通过GPIOF_AFR寄存器配置端口C的复用功能

表9. 通过GPIOF_AFR寄存器配置端口D的复用功能

表10. 通过GPIOF_AFR寄存器配置端口E的复用功能

表11. 通过GPIOF_AFR寄存器配置端口F的复用功能

表12. 通过GPIOF_AFR寄存器配置端口G的复用功能

表13. 通过GPIOF_AFR寄存器配置端口H的复用功能

特殊I/O
调试复用引脚
在复位时,和复位后不像其他GPIO一样处于浮空输入状态,而是处于AF模式
PA13:JTMS/SWDIO,AF上拉
PA14:JTCK/SWCLK,AF下拉
PA15:JTDI,AF上拉
PB3:JTDO/SWO,AF浮空
PB4:JNTRST,AF上拉
振荡器复用引脚
振荡器关闭的状态下(复位后的默认状态),相关引脚可用作GPIO
振荡器使能状态下,相应引脚的GPIO配置无效
振荡器处于bypass模式(使用外部时钟源)时,HEXT_IN/LEXT_IN为振荡器时钟输入引脚,HEXT_OUT/LEXT_OUT可做GPIO使用
电池供电域引脚
电池供电域引脚包括PC13、PC14以及PC15。电池供电域由VDD或VBAT引脚供电,当VDD主 电源被切断时,电池供电域自动切换至VBAT引脚供电,以保障ERTC正常工作。
当电池供电域由VDD供电时,PC13可以作为通用I/O口、TAMPER引脚、ERTC校准时钟、ERTC闹钟或秒输出,PC14和PC15可以用于GPIO或LEXT引脚。(PC13至PC15作为I/O口的速度必须限制在2MHz以下,最大负载为30pF,而且这些I/O口绝对不能当作电流源)。
当电池供电域由VBAT供电时,PC13可以作为TAMPER引脚、ERTC闹钟或秒输出,PC14和PC15只能用于LEXT引脚。
GPIO固件驱动程序API
Artery提供的固件驱动程序包含了一系列固件函数来管理GPIO的下列功能:
GPIO寄存器复位
初始化配置
读取输入端口或某个输入引脚
读取输出端口或某个输出引脚
设置或清除某个引脚的输出
锁定引脚
引脚的复用功能配置
输出模式
GPIO提供了两种不同类型的输出模式分别是,推挽输出以及开漏输出,下面是输出模式的配置示例:

输入模式
GPIO提供了三种不同类型的输入模式分别是,浮空输入、上拉输入以及下拉输入,下面是输入模式的配置示例:

模拟模式
当需要使用ADC或COMP通道作为输入时,需要将相应的引脚配置为模拟模式,下面是模拟模式的配置示例:

复用模式
1、不论使用何种外设模式,都必须将I/O配置为复用功能,之后系统才能正确使用I/O(输入或输出)。
2、I/O引脚通过复用器连接到相应的外设,该复用器一次只允许一个外设的复用功能(IOMUX)连接到I/O引脚。这样便可确保共用同一个I/O引脚的外设之间不会发生冲突。每个I/O引脚都有一个复用器,该复用器具有16路复用功能输入/输出(MUX0到MUX15),可通过gpio_pin_mux_config()函数对这些引脚进行配置:—复位后,所有I/O都会连接到系统的复用功能0(MUX_0)—通过配置MUX0到MUX15可以映射外设的复用功能
3、除了这种灵活的I/O复用架构之外,各外设还具有映射到不同I/O引脚的复用功能,这可以针对不同器件封装优化外设I/O功能的数量;例如,可将USART2_TX引脚映射到PA2或PA14引脚上。
4、配置过程:—使用gpio_pin_mux_config()函数将引脚连接到所需的外设复用功能,例如配置PA0作为TMR2_EXT输入gpio_pin_mux_config(GPIOA,GPIO_PINS_SOURCE0,GPIO_MUX_1);—使用gpio_init()函数配置I/O引脚:-通过以下方式配置复用功能模式下的所需引脚
gpio_init_struct.gpio_mode=GPIO_MODE_MUX;-通过以下成员选择类型、上拉/下拉和驱动能力gpio_pull、gpio_out_type和gpio_drive_strength成员
根据上述配置过程,下面将介绍几种外设的常用配置示例。
USART I/O复用模式配置

TMR I/O复用模式配置

I2C I/O复用模式配置

案例 LED翻转
功能简介
通过系统时钟延时来对LED进行翻转。
资源准备
1) 硬件环境:对应产品型号的AT-START BOARD
2) 软件环境:project\at_start_f437\examples\gpio\led_toggle
软件设计
1) 配置流程
配置系统时钟;
初始化延时函数和LED;
翻转LED。
2) 代码介绍
main函数代码描述

LED翻转代码描述

实验效果
上电运行会看到LED2、LED3和LED4以间隔200ms时间交替的进行翻转。
案例SWJTAG接口复用
功能简介
对SWJTAG接口的I/O进行复用。
资源准备
3) 硬件环境:对应产品型号的AT-START BOARD
4) 软件环境:project\at_start_f437\examples\gpio\swjtag_mux
软件设计
3) 配置流程
配置系统时钟;
初始化延时函数;
配置SWJTAG接口的复用和USART2初始化。
4) 代码介绍
main函数代码描述

SWJ配置代码描述

实验效果
将PA13接示波器,PA14接入串口打印工具;
程序运行过程中PA13每隔500ms会翻转一次,表示jtms/swdio引脚已被用为GPIO使用;
PA14接入串口打印工具后,每隔500ms会看到USART2_TX打印主循环执行次数。
- |
- +1 赞 0
- 收藏
- 评论 0
本文由ll转载自AT32 MCU 雅特力科技公众号,原文标题为:AT32讲堂045 | 雅特力AT32F435/437xx GPIO使用指南,本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。
相关推荐
【经验】Jlink使用KEIL下载/Debug雅特力MCU的配置方法
2022-06-30 - 设计经验 Jlink使用KEIL下载/Debug雅特力MCU的配置方法使用雅特力MCU进行开发,很多用户手里只有Jlink,对于Jlink使用KEIL下载/Debug雅特力MCU的配置方法不太了解。本文介绍可以使用KEIL下载/Debug的步骤设置。
【经验】雅特力MCU如何在Keil中将函数或变量编译到指定地址
2021-06-03 - 设计经验 在使用雅特力MCU AT32F403A,AT32F421,AT32F413,AT32F415做软件编程中,有时会有将函数或者变量加载到固定的Flash地址,本文介绍2种将变量或函数编译到指定地址的方法。
【经验】雅特力MCU AT32F435/437如何使用ADC控制器
2023-01-05 - 设计经验 ADC控制器的功能极其强大,包括但不限于:时钟及状态、分辨率及采样转换、自校准、基本模式、不同优先权的通道、多种独立的触发源、数据后级处理、转换中止、过采样器、电压监测、中断及状态事件、多种转换数据的获取方式、联动多ADC的主从模式。本文通过功能细节介绍和众多案例帮助大家了解ADC控制器的功能和使用指南。
雅特力AT32 MCU赋能低空经济新生态,推动无人机应用创新发展
2025-03-24 - 应用方案 在无人机智能化发展的浪潮中,雅特力AT32 MCU正发挥着核心驱动力的作用,凭借其卓越的性能、丰富的外设接口和完善的开发生态,为无人机飞控、电调和云台等核心部件提供了强大的算法支撑和功能拓展,赢得了众多无人机企业和方案商的青睐,是目前开源社区最热门的MCU之一。
【经验】雅特力AT32 MCU如何使用OTA通过USART实现对固件的在线升级更新
2022-04-28 - 设计经验 雅特力AT32 MCU如何使用OTA通过USART对固体在线升级更新?OTA(空中下载技术)是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后便于通过预留的通信口,对产品中的固件程序进行更新升级。
AT32 MCU IAR Package V2发行说明
2021年7月1日 - 开发环境(软件/固件) 该资料为AT32 MCU IAR Package的版本更新记录,记录了从V2.0.0至V2.2.6的版本更新内容。主要更新包括:增加对多个AT32系列MCU的支持,如AT32M412/416、AT32A423、AT32F490等;更新SVD文件、ddf文件、ProbeScript文件等;修正了一些型号的配置问题。
雅特力 - MCU软件包,AT32 MCU IAR PACKAGE V2,嵌入式系统开发
【经验】雅特力MCU产品JLink、JFlash操作指南
2021-09-19 - 设计经验 本文主要介绍雅特力MCU产品如何使用第三方Segger公司的JLlink软件包,使用JFlash操作MCU内部Flash,检查、读写flash内容,编程烧录。
【经验】 雅特力AT32 MCU Printf的功能使用方法
2022-05-26 - 设计经验 内容概述本文档主要介绍雅特力AT32 MCU在Keil和IAR两种工程环境下的printf功能使用方法。其共包含6种方法,各方法的具体用法在具体内容中描述。
AT32讲堂 | 解析雅特力AT32 MCU HICK时钟校准
2024-09-29 - 设计经验 AT32系列MCU内部都有提供适合运行的内部高速时钟(HICK),在25℃下,其典型值频率8MHz的精度由工厂校准到±1%,在-40到105℃,该内部高速时钟的精度达到±2.5%,可见精度会受到温度的影响。为了降低环境温度对精度造成的影响,用户可在运行时间隙调用校准程序来进行校准。
【经验】解析雅特力AT32系列MCU RTC入门指南
2023-04-25 - 设计经验 RTC计数逻辑位于电池供电域,内部为一个32位递增计数器,只要电池供电域有电,RTC便会一直运行,不受系统复位以及VDD掉电影响。本文雅特力将为大家介绍AT32系列MCU的RTC入门指南。
【经验】如何使用雅特力AT32 MCU主机库快速开发USB相关应用
2023-01-18 - 设计经验 本文主要介绍雅特力MCU AT32 USB主机库的结构和库的使用方法,AT32 USB支持全速和低速,不支持USB2.0高速设备。这里库的作用是用来管理USB外设和实现USB的基本协议,使开发者能够更快的上手开发。
雅特力基于AT32 MCU的多功能一体机应用方案,凭借高效数据处理能力和快速的响应效率,打造高速“芯”机
2024-01-31 - 应用方案 雅特力高效能AT32F435/F437系列MCU具有高效数据处理能力,以ARM® Cortex®-M4为内核,最高主频288MHz,支持最高4032KB Flash和高达512KB SRAM,内建FPU、DSP和各种复杂外设,供客户灵活运用,如双QSPI、双OTG、DVP和多种通信接口,且XMC支持SDRAM、SRAM、PSRAM等存储器拓展。
【经验】雅特力AT32 MCU将Jlink引脚用做GPIO的方法
2021-03-27 - 设计经验 使用雅特力AT32 MCU时,PA14/PA15/PB3/PB4主功能是JTAG功能,就是说在上电后,这几个引脚分别是JTCK/JTDI/JTDO/NJTRST功能。本文介绍雅特力AT32 MCU将Jlink引脚用做GPIO的方法。
【经验】雅特力AT32 MCU SDIO入门指南
2023-03-26 - 设计经验 雅特力AT32 MCU的主机模块(SDIO)在AHB外设总线和多媒体卡(MMC)、SD存储卡、SDIO卡间提供了操作接口。本文中雅特力将为大家介绍AT32 MCU SDIO入门指南。
如何进行雅特力AT32 MCU HOGP开发?
2024-01-03 - 设计经验 HOGP(HID over GATT)是由Bluetooth SIG维护的蓝牙配置文件规范,通过低功耗蓝牙实现HID的配置文件并作为与计算器之间的接口,消除HID中对电线或物理连接的需求。本文将为您介绍雅特力AT32 MCU HOGP开发。
电子商城
服务市场
可定制显示屏的尺寸0.96”~15.6”,分辨率80*160~3840*2160,TN/IPS视角,支持RGB、MCU、SPI、MIPI、LVDS、HDMI接口,配套定制玻璃、背光、FPCA/PCBA。
最小起订量:1000 提交需求>
现货市场
登录 | 立即注册
提交评论