GPIO的操作
(1)對(duì)單個(gè)IO的單個(gè)引腳基本操作,下面采用宏定義的例子
#define
#define
#define
#define DIR_1WIRE_IN() {DS18B20_PORT->CRL
#define DIR_1WIRE_OUT() {DS18B20_PORT->CRL
#define
#define
(2)設(shè)置端口IO方向
1)
a)
DIR_1WIRE_IN()
b)
GPIO_InitTypeDef
2)
a)
DIR_1WIRE_OUT()
b)
GPIO_InitTypeDef
3)使用DIR_1WIRE_IN()和DIR_1WIRE_OUT() 時(shí)這兩個(gè)函數(shù)在設(shè)置對(duì)應(yīng)端口時(shí),應(yīng)根據(jù)DS18B20_BIT的對(duì)應(yīng)位設(shè)置與或的參數(shù)。上面例子因?yàn)槭菍?duì)DS18B20_PORT的DS18B20_BIT位操作,DS18B20_BIT實(shí)際對(duì)應(yīng)Pin_2即第2個(gè)引腳,所以修改位置為倒數(shù)第3個(gè)f處(倒數(shù)第3個(gè)f為Pin_2對(duì)應(yīng)位置,倒數(shù)第1個(gè)f為Pin_0對(duì)應(yīng)位置)
3)如果讀取IO,先設(shè)置為輸入模式,再讀取
DIR_1WIRE_IN()
READ_DS18B20()
即實(shí)現(xiàn)了讀取DS18B20_PORT端口的DS18B20_BIT的數(shù)據(jù)
(4)如果設(shè)置為輸出狀態(tài),在先設(shè)置輸出模式,在向外輸出
DIR_1WIRE_OUT()
輸出1則為SET_OP_1WIRE()
輸出0則為CLR_OP_1WIRE()
(5)如果先設(shè)置為輸出,輸出1,再設(shè)置為輸入,讀取輸入,則為
DIR_1WIRE_OUT()
輸出1則為SET_OP_1WIRE()
DIR_1WIRE_IN()
READ_DS18B20()
(6)如果先設(shè)置為輸出,輸出1,再設(shè)置為輸入,讀取輸入,則為
DIR_1WIRE_IN()
READ_DS18B20()
DIR_1WIRE_OUT()
輸出1則為SET_OP_1WIRE()
二、對(duì)同一端口的多個(gè)IO一塊操作
(1)設(shè)置同一端口的多個(gè)IO設(shè)置輸入方向和模式
設(shè)置端口IO的多個(gè)引腳為輸入,如果程序中一直為輸入,則在程序初始化時(shí)設(shè)置一次即可
例如設(shè)置DS18B20_PORT端口的引腳5,3為輸入
(2)對(duì)某個(gè)IO端口的多位讀取
則采用GPIO_ReadInputData(DS18B20_PORT);//讀取端口DS18B20_PORT
然后采用與或形式得到對(duì)應(yīng)的若干位
例如想獲得PIN_2的數(shù)據(jù),可以采用
result1=GPIO_ReadInputData(DS18B20_PORT);
result2=result1&DS18B20_BIT;
其他依次類(lèi)推,或者簡(jiǎn)單的,讀取最低的兩位1,0端口數(shù)據(jù)
result2=result1&0x3;//
(3)設(shè)置同一端口的多個(gè)IO設(shè)置輸出方向和模式
設(shè)置端口IO的多個(gè)引腳為輸入,如果程序中一直為輸出,則在程序初始化時(shí)設(shè)置一次即可
(4)向某個(gè)端口的若干個(gè)引腳寫(xiě)數(shù)據(jù)
如果向某個(gè)端口的若干個(gè)引腳寫(xiě)數(shù)據(jù),這幾個(gè)IO已經(jīng)設(shè)置成輸出,
則先采用與或的形式把需要操作的若干位置成對(duì)應(yīng)形式,不需操作的位保持原來(lái)不變
則為
result1=GPIO_ReadOutputData(DS18B20_PORT);//讀取DS18B20_PORT的輸出數(shù)據(jù),參見(jiàn)庫(kù)函數(shù)stm32f10x_gpio.c,手冊(cè)參見(jiàn)115頁(yè)
result2=0x0028;//設(shè)置引腳5,3為1,1
result1&=0xffd7;//引腳5,3先清零,同時(shí)獲取其他引腳的原始狀態(tài)
result1=result1|result2;//設(shè)置引腳5,3為1,1
result1=GPIO_ReadOutputData(DS18B20_PORT);//讀取DS18B20_PORT的輸出數(shù)據(jù),參見(jiàn)庫(kù)函數(shù)stm32f10x_gpio.c,手冊(cè)參見(jiàn)115頁(yè)
result2=0x0020;//設(shè)置引腳5,3為1,0,此處注意與上面的區(qū)別
result1&=0xffd7;//引腳5,3先清零,同時(shí)獲取其他引腳的原始狀態(tài)
result1=result1|result2;//設(shè)置引腳5,3為1,0
(5)如果程序中某端口的若干引腳即作為輸入有又作為輸出
如果先輸入再輸出,則是
如果先輸出再輸入,則是
評(píng)論