痞子衡嵌入式:聊聊i.MXRT1xxx上的普通GPIO与高速GPIO差异及其用法
大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是i.MXRT上的普通GPIO与高速GPIO差异。
GPIO 可以说是 MCU 上最简单最常用的外设模块了,当一些原生功能外设接口模块不能满足项目设计要求时,我们常常会考虑使用 GPIO 来软件模拟实现相应功能,这时候 GPIO 本身性能就显得至关重要了。
在早期的 i.MXRT1015/1020/1024/1050 型号上,GPIO 都是普通性能(注意这里的普通其实相比一般低端 MCU 来说已经够性能优越了),考虑到 i.MXRT 是性能怪兽,需要配置更强的 GPIO,因此在后续的 i.MXRT1010/1060/1064/1160/1170 型号上,出现了 HSGPIO,今天痞子衡就跟大家聊一聊 GPIO 和 HSGPIO差异:
一、HSGPIO是什么?
HSGPIO 是 High-Speed GPIO 缩写,有时候也叫紧耦合 GPIO 或者单时钟周期 GPIO,简单说就是其模块(IP)时钟源速度高于普通 GPIO 时钟源,因此我们可以以更高频率访问其模块寄存器。下表列出了 i.MXRT 各型号上 HSGPIO 分布:
| 型号 | 普通GPIO | 高速GPIO |
|---|---|---|
| i.MXRT1010 | GPIO1、GPIO5 | GPIO2 |
| i.MXRT1060/1064 | GPIO1 - GPIO5 | GPIO6 - GPIO9 |
| i.MXRT1160/1170 | GPIO1 - GPIO13 | CM7_GPIO2、CM7_GPIO3 |
我们以 i.MXRT1060 为例,翻看其参考手册 CCM 时钟模块章节,可以看到普通 GPIO1-5 的时钟源是 IPG_CLK_ROOT、而高速 GPIO6-9 的时钟源则是 AHB_CLK_ROOT:
在 i.MXRT1060 上 IPG_CLK_ROOT 最高频率是 150MHz、而 AHB_CLK_ROOT 即内核频率,可到 600MHz,所以单从时钟源角度来看,HSGPIO 访问性能应是 GPIO 的四倍:
二、共享 PAD 设计
从芯片内部来说,GPIO 与 HSGPIO 模块是独立的,但是因为芯片外部引脚(PAD)资源有限,因此部分 HSGPIO 是与 GPIO 模块共享 PAD 的,最终 I/O 实际性能其实受限于同一个物理 PAD 特性。
我们以封装最简单的 i.MXRT1010 为例,下图最左侧列出了全部的 PAD,其中 GPIO_SD[13:0] 是 HSGPIO 专用引脚,而 GPIO[13:0]、GPIO_AD[14:0] 则是 GPIO 与 HSGPIO 复用引脚,当这些 GPIO/HSGPIO 复用引脚被配置为 GPIO 功能时,它们既可以映射到 GPIO1(普通GPIO),也可以映射到 GPIO2(HSGPIO):
- Note:如果已经将 GPIO_SD[13:0] 配置为了 GPIO2,则不要再将 GPIO[13:0] 配置为 HSGPIO,会发生冲突。
具体 GPIO 映射功能是由 IOMUXC_GPR26 寄存器来控制的(注意这是个软复位不置位的寄存器)。比如当 GPIO_11 被配置为了 GPIOMUX_IO11 功能时,那么 IOMUXC_GPR26[11] 决定了其映射关系:
IOMUXC_GPR26[11] = 0,则 GPIO_11 对应 GPIO1[11],为普通 GPIO
IOMUXC_GPR26[11] = 1,则 GPIO_11 对应 GPIO2[11],为 HSGPIO
下表列出了 i.MXRT 各型号上 GPIO/HSGPIO 切换控制关系:
| 型号 | PAD切换控制寄存器 | ALT功能名 | 对应切换GPIO |
|---|---|---|---|
| i.MXRT1010 | IOMUXC_GPR->GPR26 | GPIO_MUX | GPIO1与GPIO2 |
| i.MXRT1060/1064 | IOMUXC_GPR->GPR26 IOMUXC_GPR->GPR27 IOMUXC_GPR->GPR28 IOMUXC_GPR->GPR29 |
GPIO_MUX1 GPIO_MUX2 GPIO_MUX3 GPIO_MUX4 |
GPIO1与GPIO6 GPIO2与GPIO7 GPIO3与GPIO8 GPIO4与GPIO9 |
| i.MXRT1160/1170 | IOMUXC_GPR->GPR40、41 IOMUXC_GPR->GPR42、43 |
GPIO_MUX2 GPIO_MUX3 |
GPIO2与CM7_GPIO2 GPIO3与CM7_GPIO3 |
三、PAD 运行速度
前面讲了,不管是使能了普通 GPIO 还是 HSGPIO,最终都是由同一个物理 PAD 来输出信号,因此 I/O 实际性能最终受限于这个 PAD 最大运行速度。
继续以 i.MXRT1010 为例,每个 PAD 在 IOMUXC 模块里都有一个专门配置电气属性的寄存器 IOMUXC_SW_PAD_CTL_PAD_xxIO,选取 GPIO_11 的相应配置寄存器为例,组合其中 SRE、DSE、SPEED 位可以得到不同运行速度(具体组合值可在参考手册 GPIO 章节搜索 Operating Frequency 小节查看),不过我们能看到 PAD 最大运行速度是 200MHz:
在 i.MXRT1010 数据手册里,我们还可以看到更具体的 I/O 翻转时间测试:
四、HSGPIO 示例代码
基于上面的理论知识,我们改造一下 i.MXRT1010 SDK 里的 \driver_examples\gpio\led_output 例程,加入如下 HSGPIO 相关代码,同样可以达到闪烁 LED 灯的功能。
介绍了这么多,如果只是用 HSGPIO 控制小灯闪烁,似乎看不出性能差异,下一篇文章,痞子衡将用示波器为大家实测 GPIO 与 HSGPIO 极限翻转频率,再提前剧透一下,GPIO->DR_TOGGLE 和 GPIO->DR 寄存器实现 I/O 翻转效率还不一样哦。
bool is_normal_gpio = false;
int main(void)
{
BOARD_ConfigMPU();
BOARD_InitBootClocks();
/* Define the init structure for the output LED pin*/
gpio_pin_config_t led_config = {kGPIO_DigitalOutput, 0, kGPIO_NoIntmode};
CLOCK_EnableClock(kCLOCK_Iomuxc);
IOMUXC_SetPinMux(IOMUXC_GPIO_11_GPIOMUX_IO11, 0U);
if (is_normal_gpio)
{
// GPIO1
IOMUXC_GPR->GPR26 &= ~(1u << 11);
// Slow Slew Rate, 100MHz
IOMUXC_SetPinConfig(IOMUXC_GPIO_11_GPIOMUX_IO11, 0x70A0U);
GPIO_PinInit(GPIO1, 11, &led_config);
}
else
{
// GPIO2
IOMUXC_GPR->GPR26 |= (1u << 11);
// Fast Slew Rate, 200MHz
IOMUXC_SetPinConfig(IOMUXC_GPIO_11_GPIOMUX_IO11, 0x70F9U);
GPIO_PinInit(GPIO2, 11, &led_config);
}
while (1)
{
SDK_DelayAtLeastUs(100000, SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY);
if (is_normal_gpio)
{
//GPIO1->DR_TOGGLE = (1u << 11);
GPIO1->DR ^= (1u << 11);
__DSB();
}
else
{
//GPIO2->DR_TOGGLE = (1u << 11);
GPIO2->DR ^= (1u << 11);
__DSB();
}
}
}
至此,i.MXRT上的普通GPIO与高速GPIO差异痞子衡便介绍完毕了,掌声在哪里~~~
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、知乎主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:聊聊i.MXRT1xxx上的普通GPIO与高速GPIO差异及其用法的更多相关文章
- 痞子衡嵌入式:聊聊系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响. 软件看门狗模块(WDOG)在 MCU 应用里可以说是非常基础的功能模 ...
- 痞子衡嵌入式:实测i.MXRT1010上的普通GPIO与高速GPIO极限翻转频率
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT1010上的普通GPIO与高速GPIO极限翻转频率. 上一篇文章 <聊聊i.MXRT1xxx上的普通GPIO与高速GP ...
- 痞子衡嵌入式:聊聊i.MXRT1170双核下不同GPIO组的访问以及中断设计
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT1170双核下不同GPIO组的访问以及中断设计. 在双核 i.MXRT1170 下设计应用程序,有一个比较重要的考虑点就是外 ...
- 痞子衡嵌入式:利用i.MXRT1xxx系列ROM提供的FlexSPI driver API可轻松IAP
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT系列ROM中的FlexSPI驱动API实现IAP. 痞子衡的技术交流群里经常有群友提问: i.MXRT中的FlexSPI驱动 ...
- 痞子衡嵌入式:了解i.MXRTxxx系列ROM API及其与i.MXRT1xxx系列的差异
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRTxxx系列ROM API设计细节. 痞子衡之前写过两篇文章 <利用i.MXRT1xxx系列ROM提供的FlexSPI ...
- 痞子衡嵌入式:解锁i.MXRTxxx上FlexSPI模块自带的地址重映射(Remap)功能
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT三位数系列隐藏的FlexSPI Remap功能. 前段时间痞子衡写了一篇文章 <利用i.MXRT1060,1010上新 ...
- 痞子衡嵌入式:IVT里的不同entry设置可能会造成i.MXRT1xxx系列启动App后发生异常跑飞
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是IVT里的不同entry设置可能会造成i.MXRT1xxx系列启动App后发生异常跑飞问题的分析解决经验. 事情缘起恩智浦官方论坛上的一 ...
- 痞子衡嵌入式:系统时钟配置不当会导致i.MXRT1xxx系列下OTFAD加密启动失败
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是系统时钟配置不当会导致i.MXRT1xxx系列下OTFAD加密启动失败问题. 我们知道,i.MXRT1xxx家族早期型号(RT1050/ ...
- 痞子衡嵌入式:利用i.MXRT1xxx系列内部DCP引擎计算Hash值时需特别处理L1 D-Cache
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是利用i.MXRT1xxx系列内部DCP引擎计算Hash值时需特别处理L1 D-Cache. 关于i.MXRT1xxx系列内部通用数据协处 ...
随机推荐
- jmeter 录制排除模式
jmeter录制时,静态的资源不需要,可以在录制的时候直接排除. .*\.(bmp|css|js|gif|icov|jpeg|png|swf|woff|woff2|htm|html).* .*\.(j ...
- Selenium多浏览器并行测试
如果需要同时在IE.firefox.chrome进行测试,可以使用grid. Selenium Grid是一个智能代理服务器,允许Selenium测试将命令路由到远程Web浏览器实例.其目的是提供一种 ...
- c++ 的学习 第3集-默认参数
1.默认参数的意思就是 予以形参默认值 2. C++允许函数设置默认参数,在调用时可以根据情况省略实参.规则如下: 默认参数只能按照右到左的顺序 如果函数同时有声明.实现,默认参数只能放在函数声 ...
- oracle常见命令
1.权限 (1)系统权限 系统权限是指对数据库系统的权限和对象结构控制的权限. 如grant create session to 用户名 -赋予用户登录的权限 (2)对象权限 访问其它用户对象的权利 ...
- 三、mybatis多表关联查询和分布查询
前言 mybatis多表关联查询和懒查询,这篇文章通过一对一和一对多的实例来展示多表查询.不过需要掌握数据输出的这方面的知识.之前整理过了mybatis入门案例和mybatis数据输出,多表查询是在前 ...
- asp.net core 中配合响应 html5 的音视频播放流,以及文件下载
一.asp.net core 中配合响应 html5 的音视频播放流,以及文件下载 问题描述: 目前测试了在 Windows(谷歌浏览器).Android(系统浏览器.QQ.微信).iOS 三个系统不 ...
- mysql8.0.20安装教程,mysql下载安装教程8.0.20
mysql8.0.20下载安装教程 mysql8.0.20安装教程 mysql安装包+mysql学习视频+mysql面试指南视频教程 下载地址: 链接:https://pan.baidu.com/s ...
- Java-爬虫-小项目
爬取数据:(获取请求返回的页面信息,筛选出我们想要的数据就可以了!) 项目地址:https://gitee.com/zwtgit/java-reptile 导入依赖,写一个工具类 <depend ...
- 【DP】Educational DP Contest
这份 dp 题单的最后几题好难 orz. 前面的题比较简单,所以我会选取一些题来讲,其它的直接看代码理解吧 qwq. 传送门: https://atcoder.jp/contests/dp 全部 AC ...
- (googlechrome)未知错误导致安装失败,如果googlechrome....
https://jingyan.baidu.com/article/ea24bc39ffb699da63b33147.html#5827690-tsina-1-63512-fe183374908e7 ...