94 .4 GPIO 时钟 时钟
如果使用 GPIO,我们必须要使能 GPIO 的时钟。i.MX6 ULL 的每个外设的时钟可以独立的使能,我们可以关闭不使用的外设时钟,可以达到节能的目的。如果使用某个外设,我们必须要打开对应的时钟。《I.MX6ULL 参考手册》的第 18 章“Clock Controller Module (CCM)”是关于 i.MX6ULL 时钟的讲解,我们可以看下该章节里面外设时钟的使能寄存器。跟外设时钟使能相关的寄存器有:
CCM_CCGR0
CCM_CCGR1
CCM_CCGR2
CCM_CCGR3
CCM_CCGR4
CCM_CCGR5
CCM_CCGR6
一共 7 个。我们来看下 CCM_CCGR0 寄存器如何使能一个外设时钟,改寄存器的描述如下图所示:
<ignore_js_op>
我们从上图可以看到 CCM_CCGR0 寄存器是 32 位的,每 2 位控制一个外设时钟,比如 bit1:bit0 控制aips_tz1 的时钟,两位的操作方式如下:
00 //所有模式下都关闭外设时钟
01 //只有在运行模式下打开外设时钟
10 //保留
11 //除了停止模式以外,其他所有模式下时钟都打开
如果我们要打开 aips_tz1 的外设时钟,需要设置 CCM_CCGR0 的 bit1 和 bit0 都为 1,也就是 CCM_CCGR0=3,如果关闭 aips_tz1 的外设时钟,CCM_CCGR0 的 bit1 和 bit0 都设置为 0。CCM_CCGR0-CCM_CCGR6 这 7 个寄存器的功能都是类似的,也是每两位控制一种外设的时钟,为了便于开发,我们在后面的例程里把所有的外设时钟都使能了。至此关于 GPIO 的操作我们可以总结成下面的步骤:
1.使能 GPIO 对应的时钟
2.设置 IOMUXC_SW_MUX_CTL_PAD_XX_XX 寄存器,把对应的 IO 设置成 GPIO 功能
3.设置 IOMUXC_SW_PAD_CTL_PAD_XX_XX 寄存器,设置 GPIO 的上拉下拉,以及驱动能力
4.设置输入还是输出,是否使用中断,以及默认的输出电平
9 95 .5 LED 原理分析 原理分析
i.MX6ULL 终结者开发板板载了一个 LED 灯,打开底板的原理图(光盘资料的“i.MX6UL 终结者光盘资料