STM32-GPIO學(xué)習(xí)筆記
端口配置寄存器(32位,共兩個(gè),CRL和CRH)
本文引用地址:http://cafeforensic.com/article/201611/320439.htm數(shù)據(jù)寄存器(32位,共兩個(gè),IDR和ODR)
置位/復(fù)位寄存器(32位,一個(gè),BSRR)
復(fù)位寄存器(16位,一個(gè),BRR)
鎖存寄存器(32位,一個(gè),LCKR)
常用的IO寄存器只有四個(gè),即CRL、CRH、IDR、ODR,他們分別是設(shè)置IO口工作狀態(tài)和輸入/輸出數(shù)據(jù)的,其中CRL和CRH共2個(gè)32位寄存器控制16個(gè)IO口的狀態(tài)(CRL和CRH完全一樣,只是CRL控制的是低8位輸出口GPIOx(0:7),CRH控制的是高八位GPIOx(8:15)),即每四位控制一個(gè)IO口狀態(tài)(高2位CNF,低2位MODE),寄存器情況如圖所示:
常用的狀態(tài)配置:
0X0 模擬輸入模式(ADC用)0X3 推挽輸出模式 (作輸出口用50Mhz速率)
0X8 上/下拉輸入模式 (作輸入口用)
0XB 復(fù)用輸出 (作IO口的第二功能50Mhz速率) 注意:這個(gè)是第二功能即復(fù)用輸出功能
舉例:
我們甚至PORTC的11位位上拉輸入,12位為推挽輸出,代碼如下:
GPIO->CRH&=0XFFF00FFF; //清除原來的設(shè)置,不影響其他位
GPIO->CRH|=0X00038000; //PC11輸入,PC12輸出
GPIO->ODR=1<<11; //PC11上拉IDR 輸入數(shù)據(jù)寄存器,只使用了低16位,只讀寄存器,同理,ODR也只使用了低16位,位可讀寫寄存器。
IDR寄存器描述如圖:
STM32和AVR單片機(jī)IO口的比較:
補(bǔ)充遇到的一個(gè)問題:http://www.openedv.com/posts/list/0/378.htm#94993
SPI 讀寫W2516 引腳配置問題 |
PA5-SCLK;PA6-MISO;PA7-MOSI;
第二行中,為什么PA6 也配置為推挽輸出呢? PA6 不是應(yīng)該配置為輸入嗎 ?
為什么最后還有用GPIOA->ODR|=0X7<<5 配置為上拉呢? ODR寄存器不是只有在輸入模式設(shè)置上拉或者下拉時(shí)才用嗎 ?
原子的解答:
1,請注意,這里是復(fù)用輸出.在復(fù)用功能下面,輸入輸出的方向,完全由內(nèi)部控制.不需要你的程序處理.2,配置為上拉,是常用的設(shè)置,這樣設(shè)置的好處,就是可以讓你的IO處于一個(gè)電平,而很多時(shí)候,外設(shè)默認(rèn)的電平就是高電平的.所以設(shè)置為高,是有道理的.
復(fù)用功能下,操作ODR是不能輸出的!但是ODR是可以操作的,可以設(shè)置上拉。
評(píng)論