在学习IIC的时候碰到了这么两条代码
//IO方向设置
#define MPU_SDA_IN() {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)8<<28;}
#define MPU_SDA_OUT() {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)3<<28;}
这其实是在操作寄存器
首先了解下各个符号的用处
STM32学习②寄存器操作端口模式
STM32学习②寄存器操作端口模式
这是原子哥的解释。
CRH CRL是两个控制端口寄存器
比如GPIOA
A0-A7操作的是CRL寄存器
A8-A15操作的是CRH寄存器
实例:
1.上图是B7,所以我们操作的是CRL。
2.GPIOB->CRL&=0X0FFFFFFF;这句话的意思是将B7的四位清零。
3.GPIOB->CRL|=(u32)8<<28; 这句话的意思是设置B7的四位的值。
所以要该引脚的话,只需要注意
1.是CRL还是CRH
2.清零的引脚是否正确
3.是否正确设置了你改的那个脚的值

相关文章:

  • 2021-06-05
  • 2022-12-23
  • 2021-05-11
  • 2021-06-22
  • 2021-06-02
  • 2022-12-23
  • 2021-11-24
  • 2021-08-16
猜你喜欢
  • 2022-01-22
  • 2022-12-23
  • 2021-05-30
  • 2021-07-30
  • 2022-12-23
  • 2021-12-25
  • 2021-10-22
相关资源
相似解决方案