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对应输入模式。(下面的红圈圈)
原图:
新手笔记,不知道有没有错误,希望大佬指点。