
浅析STM32之GPIO寄存器(CRL/CRH)配置! U6 X& z& |, }1 P1 N1 i 一、前言9 F! b( }& k' Z% A/ _7 T GPIO的配置可以说是STM单片机的一大特色,通过GPIO的配置我们可以进行多种不同模式的输入和输出,并且进行配置的方式也有多种,一般我们在使用的过程中可能大多数都是通过库函数来进行配置的,这样确实也比较方便,但有时候我们也不难免会使用寄存器进行配置,代码可能会更加简洁,所以掌握寄存器的配置对我们来说也很重要。 & P: V2 y, B* t/ k r0 d3 y 特别是在进行IIC的数据引脚输入输出配置时寄存器的作用十分重要 8 d; f u: O- g$ ^0 ` 二、寄存器配置分析( Q ~5 u' ~0 u$ I* q
" K( V: j# F! T d! @# j 在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。" |& S7 f3 ?+ X' O5 y- J: l 6 \# m1 G# a3 H E g 下面是官方数据手册的内容 GPIOX_CRL ![]() 3 p6 z- u* q0 A% T0 w GPIOX_CRH. y% T! l) a8 a ] 1 X: f8 n, H0 \7 y2 t0 F3 x ![]() 从上面我们可以看出不管是GPIOX_CRL还是GPIOX_CRH每个IO都是由CNF[1:0]和MODE[1:0]两部分进行配置选择的,其中MODE[1:0]是进行配置输入还是输出一般00为输入 11为输出。CNF[1:0]则配合MODE[1:0]进行具体的模式配置。
三、代码解析 GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=8<<28;% V! I6 d2 a6 O( \8 t$ U 首先我们从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引脚进行配置了上拉输入模式。. _- e; r- u# O/ [" |, m- R 同理 GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=3<<28; h% Q& v" P( ]- G+ a+ ~ 首先从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设置成了推挽输出模式. i' i; ~( C# x( Z: n3 c ————————————————$ }0 O# [; c5 }. m% V! u' w3 p 版权声明:@slow-walker |
Keil下的STM32N6之RAM运行工程配置说明
实战经验 | Keil工程使用NEAI库的异常问题
【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