CRL,CRH寄存器


在移植ds18b20時看到這樣一段代碼

#define DS18B20_IO_IN()  {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=8<<12;}
#define DS18B20_IO_OUT() {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=3<<12;}

什么意思呢,然后查了一下手冊

發現CRL和CRH寄存器使用是基本相同的:都是配置端口工作模式,以CRH為例,一共有4個字節,從左往右依次配置PIN15---->PIN8,比如我要配置PIN8,那么我就需要關注

CRH的最右邊的4個比特,0xFFFF FFF0(0所代表的4個比特就是需要配置的)


如果你的端口號小於8,就配置CRL,比如PA2;大於等於8就配置CRH

然后回到上面那兩行代碼:先看第一行

GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=8<<12;

配置的CRH寄存器從又往左第4個,依次數過來,pin8,pin9,pin10,pin11,配置的是PB11腳,0代表什么呢,按照上圖的定義,表示復位后的模擬輸入模式

然后  GPIOB->CRH|=8<<12;   把8變成二進制就表示0100,01,表示浮空輸入,00表示輸入模式,<<12表示配置的PIN11引腳。

再看這一行:

{GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=3<<12;}

同樣先復位,然后3變成二進制就是0011,00,通用推挽輸出,11表示50mhz輸出模式

 

那么如果我們要配置PB2分別為模擬輸入和推挽輸出應該怎么做呢,

首先pb2應該配置CRL寄存器,其他和上面講的就一樣了

#define DS18B20_IO_IN()  {GPIOB->CRL&=0XFFFFF0FF;GPIOB->CRL|=8<<8;}
#define DS18B20_IO_OUT() {GPIOB->CRL&=0XFFFFF0FF;GPIOB->CRL|=3<<8;}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM