GPIOB CRH: Unlocking Its Potential

看原子哥的IIC.h文件看到这两个语句有点懵,去找了半天资料才懵懵懂懂,下面简单记录一下,以防下次又忘了

 就拿这个举例把~,GPIO一组有(0-15)一共16个

前(0-7)是底8位,写成CRL

后(8-15)是高8位,所以就写成CRH

#define SDA_IN()  {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)8<<28;}

8个F分别对应红圈圈的八个圈圈,有CNF0和M0DE0的圈圈对应着蓝色的F,依此对应。

GPIOB->CRL&=0X0FFFFFFF这个语句的意思:把用到的B7端口清0;

 #define SDA_IN()  {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)8<<28;}

28的意思是:因为一个F是4个二进制位,第7位所以是7*4=28。

8的意思:就是1000,10的对应上拉/下拉模式,00对应输入模式。(下面的红圈圈)

 

原图:

 

 新手笔记,不知道有没有错误,希望大佬指点

物联沃分享整理
物联沃-IOTWORD物联网 » GPIOB CRH: Unlocking Its Potential

发表评论