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