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 寄存器如何使能一个外设时钟,改寄存器的描述如下图所示:
我们从上图可以看到 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 终结者光盘资料 |