新聞中心

GPIO的操作

作者: 時(shí)間:2016-11-25 來(lái)源:網(wǎng)絡(luò) 收藏
一、對(duì)IO的單個(gè)引腳操作,采用宏定義較為方便
(1)對(duì)單個(gè)IO的單個(gè)引腳基本操作,下面采用宏定義的例子
#defineDS18B20_BIT GPIO_Pin_2//宏定義GPIO_Pin_2引腳新名為DS18B20_BIT,也可以為其他名稱
#defineDS18B20_PORT GPIOC////宏定義GPIOC端口新名為DS18B20_PORT,也可以為其他名稱
#defineREAD_DS18B20() GPIO_ReadInputDataBit(DS18B20_PORT,DS18B20_BIT)//讀取端口DS18B20_PORT的DS18B20_BIT位狀態(tài)GPIO_ReadInputDataBit()為庫(kù)函數(shù),不用自己寫(xiě)
#define DIR_1WIRE_IN() {DS18B20_PORT->CRL&=0xFFFFF0FF;DS18B20_PORT->CRL|=0x00000400;}//設(shè)置DS18B20_PORT的第2個(gè)IO引腳為輸入模式,CRL寄存器僅能設(shè)置端口的低8個(gè)引腳,高8個(gè)用CRH,詳見(jiàn)手冊(cè)113頁(yè)
#define DIR_1WIRE_OUT() {DS18B20_PORT->CRL&=0xFFFFF0FF;DS18B20_PORT->CRL|=0x00000300;}////設(shè)置DS18B20_PORT的第2個(gè)IO引腳為輸出模式
#defineCLR_OP_1WIRE() GPIO_ResetBits(DS18B20_PORT,DS18B20_BIT)//設(shè)置端口DS18B20_PORT的DS18B20_BIT位為0
#defineSET_OP_1WIRE() GPIO_SetBits(DS18B20_PORT,DS18B20_BIT)//設(shè)置端口DS18B20_PORT的DS18B20_BIT位為1
(2)設(shè)置端口IO方向
1)其中設(shè)置端口方向輸入的方式為a或b
a)
DIR_1WIRE_IN()
b)
GPIO_InitTypeDefGPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;//此處有其他參數(shù)可以選擇,參見(jiàn)固件庫(kù)說(shuō)明和手冊(cè)說(shuō)明
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;//此處有其他參數(shù)可以選擇,參見(jiàn)固件庫(kù)說(shuō)明和手冊(cè)說(shuō)明
GPIO_Init(DS18B20_PORT,&GPIO_InitStructure);

2)其中設(shè)置端口方向輸出的方式為a或b
a)
DIR_1WIRE_OUT()
b)
GPIO_InitTypeDefGPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_Init(DS18B20_PORT,&GPIO_InitStructure);
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為輸入
GPIO_InitTypeDefGPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_5|GPIO_Pin_3;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;//此處有其他參數(shù)可以選擇,參見(jiàn)固件庫(kù)說(shuō)明和手冊(cè)說(shuō)明
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;//此處有其他參數(shù)可以選擇,參見(jiàn)固件庫(kù)說(shuō)明和手冊(cè)說(shuō)明
GPIO_Init(DS18B20_PORT,&GPIO_InitStructure);
(2)對(duì)某個(gè)IO端口的多位讀取
如果對(duì)某個(gè)IO端口的多位讀取,這幾個(gè)IO已經(jīng)設(shè)置成輸入
則采用GPIO_ReadInputData(DS18B20_PORT);//讀取端口DS18B20_PORT
然后采用與或形式得到對(duì)應(yīng)的若干位
例如想獲得PIN_2的數(shù)據(jù),可以采用
result1=GPIO_ReadInputData(DS18B20_PORT);//參見(jiàn)庫(kù)函數(shù)stm32f10x_gpio.c
result2=result1&DS18B20_BIT;
其他依次類推,或者簡(jiǎn)單的,讀取最低的兩位1,0端口數(shù)據(jù)
result2=result1&0x3;//

(3)設(shè)置同一端口的多個(gè)IO設(shè)置輸出方向和模式
設(shè)置端口IO的多個(gè)引腳為輸入,如果程序中一直為輸出,則在程序初始化時(shí)設(shè)置一次即可
GPIO_InitTypeDefGPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_5|GPIO_Pin_3;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_Init(DS18B20_PORT,&GPIO_InitStructure);

(4)向某個(gè)端口的若干個(gè)引腳寫(xiě)數(shù)據(jù)
如果向某個(gè)端口的若干個(gè)引腳寫(xiě)數(shù)據(jù),這幾個(gè)IO已經(jīng)設(shè)置成輸出,
則先采用與或的形式把需要操作的若干位置成對(duì)應(yīng)形式,不需操作的位保持原來(lái)不變
1)例如向端口的引腳5,3寫(xiě)數(shù)據(jù)1,1
則為
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;其他引腳不變

2)例如向端口的引腳5,3寫(xiě)數(shù)據(jù)1,0
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)如果程序中某端口的若干引腳即作為輸入有又作為輸出
如果先輸入再輸出,則是(1)(2)(3)(4)的順序
如果先輸出再輸入,則是(4)(3)(2)(1)的順序


關(guān)鍵詞: GPIO引腳操作宏定

評(píng)論


技術(shù)專區(qū)

關(guān)閉