
浅析STM32之GPIO寄存器(CRL/CRH)配置 一、前言8 x( \/ R% A4 E! x1 | GPIO的配置可以说是STM单片机的一大特色,通过GPIO的配置我们可以进行多种不同模式的输入和输出,并且进行配置的方式也有多种,一般我们在使用的过程中可能大多数都是通过库函数来进行配置的,这样确实也比较方便,但有时候我们也不难免会使用寄存器进行配置,代码可能会更加简洁,所以掌握寄存器的配置对我们来说也很重要。 9 V; S( k& B8 k I0 _" e2 H8 ? 特别是在进行IIC的数据引脚输入输出配置时寄存器的作用十分重要 二、寄存器配置分析
在stm32单片机中我们可以发现,单片机的引脚分成了很多组GPIOA~GPIOE,并且每一组中又有0-15共16个引脚,每个IO口由4bit位来控制,那么一组IO就需要16*4 = 64bit,但我们使用的是32位的单片机,所以又将64Bit分成了两部分,高32bit又GPIOX_CRH寄存器来配置,低32bit由GPIOX_CRLj寄存器来进行配置.对应的引脚CRL为0到7CRH为8到15。3 |# B" E. B x0 S 1 \+ o0 g( W" \ 下面是官方数据手册的内容 GPIOX_CRL 3 W' A% `, [" T' U! J6 k5 z6 D! c ![]() , q# F w$ q3 z7 ? GPIOX_CRH' s; [9 o1 T! l* V h! s ![]() 从上面我们可以看出不管是GPIOX_CRL还是GPIOX_CRH每个IO都是由CNF[1:0]和MODE[1:0]两部分进行配置选择的,其中MODE[1:0]是进行配置输入还是输出一般00为输入 11为输出。CNF[1:0]则配合MODE[1:0]进行具体的模式配置。
三、代码解析6 ] b, j/ \9 C/ D; j8 B1 b GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=8<<28; 首先我们从0x0FFFFFFF这句代码中可以看出我们是进行GPIO_Pin_7配置,先将7引脚Io的控制位清零其余的位保持不变,8 ----->1000 为CNF[1:0] 为10 上拉MODE[1:0] 为00输入则将引脚配置成上拉输入模式 8 << 28 可以看成 1111 1111 1111 1111 1111 1111 1111 1000 左移28位则变成了1000 1111 1111 1111 1111 1111 1111 1111,可以看出就是GPIO_Pin_7引脚进行配置了上拉输入模式。0 s) D7 O7 J% p1 V 0 v7 R3 A2 ^( ]" e. ] 同理, h8 W$ G) o! D1 H; [ # U" B* t+ y; @! w GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=3<<28;, m- f5 f; m! S* O" ^ 首先从0X0FFFFFFF这句代码我们是进行GPIO_Pin_7配置,先将7引脚Io控制位清零其余位保持不变,3------>0011为CNF[1:0] 为00推挽,MODE[1:0]为11输出则将相应的引脚配置成推挽输出,3<<28可以看出1111 1111 1111 1111 1111 1111 1111 0011 左移28位后变成了0011 1111 1111 1111 1111 1111 1111 1111,正好是将GPIO_Pin_7设置成了推挽输出模式 ————————————————6 J' T( i9 ]( l& h& |; U 版权声明:@slow-walker |
Keil下的STM32N6之RAM运行工程配置说明
【STM32MP257-DK】01开发板开箱、ST MPU 生态资源使用、环境搭建以及镜像更新
兔哥的初代M33【002】-H503Nucleo 内部flash操作
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
兔哥的杂谈【002】——如何性价比更高地去编译STM32
汇编浮点库qfplib移植STM32F769I-DISCO开发板与硬件浮点运算性能测试对比
【经验分享】基于STM32使用HAL库实现USB组合设备CDC+MSC
FreeRTOS学习笔记2