(9.5)--5 GPIO接口的应用单片机原理与应用.ppt
《(9.5)--5 GPIO接口的应用单片机原理与应用.ppt》由会员分享,可在线阅读,更多相关《(9.5)--5 GPIO接口的应用单片机原理与应用.ppt(72页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 5.1GPIO的硬件结构和功能的硬件结构和功能 5.2 GPIO寄存器寄存器5.3 GPIO库函数库函数5.4 库函数与寄存器的关系库函数与寄存器的关系5.5 应用实例应用实例第第5章章GPIO原理及应用原理及应用 本章学习的知识点本章学习的知识点 关键要从接口的关键要从接口的外部电气特性外部电气特性、内部工作原内部工作原理理和和应用编程应用编程的方法几个方面来掌握:的方法几个方面来掌握:掌握接口的外部掌握接口的外部引脚功能及电气特性引脚功能及电气特性,以便将它和其,以便将它和其 它外设相连;它外设相连;掌握接口的掌握接口的工作方式工作方式及工作特点,以便选择适合于用及工作特点,以便选择适合
2、于用 户要求的工作方式;户要求的工作方式;掌握接口的掌握接口的控制字控制字(写写)和状态字和状态字(读读),它将决定接口的,它将决定接口的 工作方式及工作特点;工作方式及工作特点;掌握接口的掌握接口的寻址和寄存器寻址和寄存器的读写控制方法;的读写控制方法;掌握接口的掌握接口的初始化编程初始化编程。5.1GPIO硬件硬件结结构和功能构和功能多种功能的双向多种功能的双向IO:多多组组端口(端口(PA、PB、PC、PD、PE、PF、PG)每个端口共每个端口共16位位标标准准IO口可承受口可承受5V电压电压IO口可吸口可吸纳纳25mA电电流流可配置可配置输输出速度达到出速度达到50MHz多达多达16路
3、模路模拟输拟输入入 stm32f10 x_gpio.c文件中的GPIOvoid GPIO_DeInit(GPIO_TypeDef*GPIOx)/*Check the parameters*/assert_param(IS_GPIO_ALL_PERIPH(GPIOx);if(GPIOx=GPIOA)RCC_APB2PeriphResetCmd(RCC_APB2Periph_GPIOA,ENABLE);RCC_APB2PeriphResetCmd(RCC_APB2Periph_GPIOA,DISABLE);else if(GPIOx=GPIOB)RCC_APB2PeriphResetCmd(RCC
4、_APB2Periph_GPIOB,ENABLE);RCC_APB2PeriphResetCmd(RCC_APB2Periph_GPIOB,DISABLE);else if(GPIOx=GPIOG)RCC_APB2PeriphResetCmd(RCC_APB2Periph_GPIOG,ENABLE);RCC_APB2PeriphResetCmd(RCC_APB2Periph_GPIOG,DISABLE);GPIO外部引脚 5.1.1GPIO硬件结构硬件结构GPIO端口的内部结构:八种工作模式八种工作模式 1.1.浮空浮空输入模式输入模式2.2.上拉上拉输入模式输入模式3.3.下拉下拉输入模式输
5、入模式4.4.模拟模拟输入模式输入模式5.5.开漏开漏输出模式输出模式6.6.推挽推挽输出模式输出模式7.7.复用开漏复用开漏输出模式输出模式8.8.复用推挽复用推挽输出模式输出模式 5.1.2复用功能复用功能复用功能复用功能IO口功能口功能中断、中断、TIM、UART等第等第2功能功能注意设置注意设置配置该引脚配置该引脚输入输出模式输入输出模式如果有多个复用功能模块对应同一个引脚,仅如果有多个复用功能模块对应同一个引脚,仅可使能其中之一,其它模块保持可使能其中之一,其它模块保持非使能非使能状态状态 例如要使用例如要使用STM32F103VBT6的的47、48脚的脚的USART3功能,则需要配
6、置功能,则需要配置47脚为复用推挽输出或复用开漏输出,配置脚为复用推挽输出或复用开漏输出,配置48脚为某种输入模式,同时脚为某种输入模式,同时使能使能USART3并保持并保持I2C的的非使能非使能状态状态。5.1.3GPIO输入功能输入功能 述述u 输入电路部分输入电路部分 浮空输入:浮空输入:是指在电路内部既不接上拉电阻(外接是指在电路内部既不接上拉电阻(外接VDD)又)又不接下拉电阻(外接不接下拉电阻(外接VSS)的输入模式,是一个带有施密特触发)的输入模式,是一个带有施密特触发输入的输入的三态缓冲器三态缓冲器,由于它具有很高的直流输入等效阻抗,所以,由于它具有很高的直流输入等效阻抗,所以
7、在使用标准的在使用标准的通信协议(如通信协议(如I2C,USART)时,将时,将I/O口配置成这口配置成这种工作模式,在执行种工作模式,在执行I/O读操作时,将引脚当前电平状态读到内读操作时,将引脚当前电平状态读到内部总线上。部总线上。上拉输入:上拉输入:是指在电路是指在电路内部接上拉电阻内部接上拉电阻的输入模式,再经过的输入模式,再经过施密特触发器转换为施密特触发器转换为0,1电平信号。电平信号。下拉输入:下拉输入:和上拉输入原理相同,只是在电路内部接了和上拉输入原理相同,只是在电路内部接了下拉下拉电阻。电阻。模拟输入:模拟输入:是指不经过内部上拉或下拉,也不经过施密特触是指不经过内部上拉或
8、下拉,也不经过施密特触发器输入模式,它可以直接把发器输入模式,它可以直接把输入的电压信号输入的电压信号传给片上外设模块传给片上外设模块 5.1.4GPIO输出功能输出功能推挽输出推挽输出推挽输出的基本功能推挽输出的基本功能 通用推挽输出通用推挽输出 复用推挽输出复用推挽输出 开漏输出开漏输出开漏输出的基本功能开漏输出的基本功能 通用开漏输出通用开漏输出 复用开漏输出复用开漏输出 u输出电路部分输出电路部分 推推挽挽输输出出:是是指指线线路路经经过过P-MOSP-MOS(PositivePositive)和和N-N-MOS(Negative)MOS(Negative)管管组组成成的的单单元元电电
9、路路,在在输输出出高高电电平平(3.3v3.3v)时时,P-MOSP-MOS负责灌电流。在输出低电平(负责灌电流。在输出低电平(0v0v)时)时N-MOSN-MOS负责拉电流负责拉电流。开开漏漏输输出出:是是指指线线路路只只经经过过了了N-MOS而而没没有有接接负负责责灌灌电电流流的的P-MOS管管的的输输出出模模式式。在在输输出出1时时断断开开(此此时时相相当当于于高高阻阻态态),在输出,在输出0时由时由N-MOS拉低拉低。复复用用开开漏漏/推推挽挽输输出出:这这两两种种输输出出模模式式的的原原理理与与普普通通输输出出模模式相同,只不过这两种输出模式常用于特定的场合式相同,只不过这两种输出模
10、式常用于特定的场合。(1)推挽输出的基本功能)推挽输出的基本功能(2)通用推挽输出)通用推挽输出(3)复用推挽输出)复用推挽输出(4)开漏输出的基本功能)开漏输出的基本功能(2)通用开漏输出)通用开漏输出(3)复用开漏输出)复用开漏输出 5.1.5GPIO速度选择速度选择I/O口的口的输输出模式下,有出模式下,有3种种输输出速度可出速度可选选,分,分别别为为2MHz、10MHz和和50MHz是指是指I/O口口驱动电驱动电路路的的响响应应速度速度而不是而不是输输出信号的出信号的速度速度通通过选择过选择速度来速度来选择选择不同的不同的输输出出驱动驱动模模块块,达到,达到最佳的最佳的噪声控制噪声控制
11、和和降低功耗降低功耗的目的。高的目的。高频驱动电频驱动电路噪声也高,当不需要高的路噪声也高,当不需要高的输输出出频频率率时时,请选请选用用低低频驱动电频驱动电路,路,这样这样有利于提高系有利于提高系统统的的EMI(电磁电磁干扰干扰)性能。性能。5.1.6钳位功能钳位功能-0.6V,3.9 小结输出模式输出模式 输出信号来自输出信号来自 推挽或开漏推挽或开漏 输出带宽输出带宽 通用开漏输出通用开漏输出 输出数据寄存器输出数据寄存器 开漏开漏 可选:可选:2MHz10MHz50MHz通用推挽输出通用推挽输出 推挽推挽 开漏复用输出开漏复用输出 片上外设片上外设 开漏开漏 推挽复用输出推挽复用输出
12、推挽推挽 表5-1 GPIO输出模式 小结表5-2 GPIO输入模式 输入模式输入模式 输入信号去向输入信号去向 上拉或下上拉或下拉拉 施密特触发器施密特触发器 模拟输入模拟输入 片上模拟外设片上模拟外设ADC 无无 关闭关闭 浮空输入浮空输入 输入数据寄存器或片输入数据寄存器或片上外设上外设 无无 激活激活 下拉输入下拉输入 输入数据寄存器或片输入数据寄存器或片上外设上外设 下拉下拉 激活激活 上拉输入上拉输入 输入数据寄存器或片输入数据寄存器或片上外设上外设 上拉上拉 激活激活 5.2GPIO寄存器寄存器 表表1GPIO相关寄存器功能相关寄存器功能寄存器寄存器 功能功能 GPIOx_CRL
13、 低位配置寄存器用来设置端口低低位配置寄存器用来设置端口低8位的工作模式位的工作模式 GPIOx_CRH 用来设置端口高用来设置端口高8位工作模式位工作模式 GPIOx_IDR 如果端口被配置成输入端口,可以从如果端口被配置成输入端口,可以从GPIOx_IDR相应位读数据相应位读数据 GPIOx_ODR 如果端口被配置成输出端口,可以从如果端口被配置成输出端口,可以从GPIOx_ ODR相应位读或写数据相应位读或写数据 GPIOx_BSRR 通过该寄存器可以对端口数据输出寄存器通过该寄存器可以对端口数据输出寄存器GPIOx_ODR每一位进行置每一位进行置1和复位操作和复位操作 GPIOx_BR
14、R 通过该寄存器可以对端口数据输出寄存器通过该寄存器可以对端口数据输出寄存器GPIOx_ODR每一位进行复位操作每一位进行复位操作 GPIOx_LCKR 当执行正确的写序列设置了位当执行正确的写序列设置了位16(LCKK)时,该时,该寄存器用来锁定端口位的配置寄存器用来锁定端口位的配置 STM32每个每个IO端口有端口有7个寄存器个寄存器来控制来控制,分别是:分别是:CRL和和CRH:配置模式的配置模式的2个个32位的位的端口配置寄存端口配置寄存器,器,控制着每个控制着每个IO口的模式及输出速率;口的模式及输出速率;IDR和和ODR:32位的位的数据寄存器数据寄存器;BSRR:32位的位的置位
15、置位/复位寄存器复位寄存器;BRR:16位的位的复位寄存器复位寄存器;LCKR:32位的位的锁存寄存器锁存寄存器;端口低配置寄存器端口低配置寄存器CRL的描述,如下图所示:的描述,如下图所示:端口低配置寄存器端口低配置寄存器CRH的描述,如下图所示:的描述,如下图所示:端口位配置表端口位配置表配置模式配置模式CNF1CNF0MODE1:0PxODR寄存寄存器器通用输出通用输出推挽推挽00011011参照下表参照下表0或或1开漏开漏10或或1复用功能复用功能输出输出推挽推挽10任意任意开漏开漏1任意任意输入输入模拟输入模拟输入0000任意任意输入浮空输入浮空1任意任意输入下拉输入下拉100输入上
16、拉输入上拉1输出模式位表输出模式位表MODE1:0含义含义00保留保留01最大输出速率最大输出速率10MHz10最大输出速率最大输出速率2MHz11最大输出速率最大输出速率50MHz IDR只用了低只用了低16位。位。该寄存器为只读寄存器,并且只能该寄存器为只读寄存器,并且只能以以16位的形式读出。该寄存器各位的描述如下图所示:位的形式读出。该寄存器各位的描述如下图所示:IDR-输入数据寄存器输入数据寄存器 ODR是一个端口输出数据寄存器,只用了低是一个端口输出数据寄存器,只用了低16位位。该寄存器虽然为可读写,但是从该寄存器读出来的数该寄存器虽然为可读写,但是从该寄存器读出来的数据都是据都是
17、0。只有写是有效的。其作用就是控制端口的输。只有写是有效的。其作用就是控制端口的输出。该寄存器的各位描述如下图所示:出。该寄存器的各位描述如下图所示:ODR-ODR-输出数据寄存器输出数据寄存器 5.3GPIO库库函数函数 GPIO完整的固件库完整的固件库stm32f10 x_gpio.c是用是用C语语言言编编写的写的GPIO的的驱动驱动源程序文件源程序文件stm32f10 x_gpio.cstm32f10 x_gpio.hgpio的的头头文件,包含函数定文件,包含函数定义义以及函数使用以及函数使用的的变变量量stm32f10 x_gpio.h文件文件 1、GPIO_Init()函数名 GPI
18、O_Init函数原形 voidGPIO_Init(GPIO_TypeDef*GPIOx,GPIO_InitTypeDef*GPIO_InitStruct)功能描述 根据根据GPIO_InitStruct中指定的参数初始化外设中指定的参数初始化外设GPIOx寄存器寄存器输入参数1 GPIOx:x可以是可以是A,B,C,D或者或者E,来选择,来选择GPIO外设外设输入参数2 GPIO_InitStruct:指向结构:指向结构GPIO_InitTypeDef的指的指针,包含了外设针,包含了外设GPIO的配置信息的配置信息输出参数 无 返回值 无 先决条件 无 被调用函数 无 5.4库库函数和寄存器的
19、关系函数和寄存器的关系1.GPIO_Configuration(void)分析分析voidGPIO_Configuration(void)GPIO_InitTypeDefGPIO_InitStructure;(1)GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4;(2)GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;(3)GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;(4)GPIO_Init(GPIOA,&GPIO_InitStructure);(5)库函数和寄存器的关系库函
20、数和寄存器的关系1.GPIO_Configuration(void)分析 void GPIO_Configuration(void)GPIO_InitTypeDef GPIO_InitStructure;(1)GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4;(2)GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;(3)GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;(4)GPIO_Init(GPIOA,&GPIO_InitStructure);(5)1 10 0GPIOA_CR
21、L,0 x40010800地址,赋值0 xXXX3 XXXX GPIO_Init(GPIOA,&GPIO_InitStructure)语句语句(5)是一个函数调用,即调用是一个函数调用,即调用GPIO_Init函数,函数,并提供给该函数并提供给该函数2个参数,分别为个参数,分别为GPIOA和和&GPIO_InitStructure,其中,其中&GPIO_InitStructure表示结构体变量表示结构体变量GPIO_InitStructure的地址,而的地址,而GPIOA则在则在“stm32f10 x.h”文件中找到定义:文件中找到定义:#defineGPIOA(GPIO_TypeDef*)G
22、PIOA_BASE)GPIOA_BASE=0 x40000000+0 x10000+0 x0800 GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4 此句是一个赋值语句此句是一个赋值语句,把,把GPIO_Pin_4赋给赋给GPIO_InitStructure结构体中的成员结构体中的成员GPIO_Pin,可以在可以在“stm32f10 x_gpio.h”文件中找到对文件中找到对GPIO_Pin_4做的宏定义:做的宏定义:#defineGPIO_Pin_4(u16)0 x0010)此句的本质是将此句的本质是将16位数位数0 x0010赋给赋给GPIO_InitStruc
23、ture结构体中的成员结构体中的成员GPIO_Pin。GPIOSpeed_TypeDef 在“stm32f10 x_gpio.h”文件中找到对GPIOSpeed_TypeDef的定义:typedef enum GPIO_Speed_10MHz=1,GPIO_Speed_2MHz,GPIO_Speed_50MHzGPIOSpeed_TypeDef;GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz 语句语句(3)将将GPIO_Speed_50MHz赋给赋给GPIO_InitStructure结构体中的成员结构体中的成员GPIO_Speed,但注意到此处但
24、注意到此处GPIO_Speed_50MHz只是一个枚举变量只是一个枚举变量,按照按照GPIOSpeed_TypeDef的设置其值为的设置其值为3。GPIOMode_TypeDef/*Configuration Mode enumeration-*/typedef enum GPIO_Mode_AIN =0 x0,GPIO_Mode_IN_FLOATING=0 x04,GPIO_Mode_IPD =0 x28,GPIO_Mode_IPU =0 x48,GPIO_Mode_Out_OD =0 x14,GPIO_Mode_Out_PP =0 x10,GPIO_Mode_AF_OD =0 x1C,GP
25、IO_Mode_AF_PP =0 x18GPIOMode_TypeDef;/定义定义GPIO管脚管脚 的的 工作模式工作模式工作模式:用低工作模式:用低4位位 区分。区分。输输 入入输输 出出输入、输出判断:高输入、输出判断:高4位为位为1-输出,否则为输入。输出,否则为输入。GPIOMode_TypeDefp输入浮空:输入浮空:IN_FLOATINGp输入上拉:输入上拉:IPU(InPush-Up)p输入下拉输入下拉:IPD(InPush-Down)p模拟输入模拟输入:AIN(AnalogIn)p开漏输出:开漏输出:Out_OD (Open Drain Output)p推挽式输出推挽式输出:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 9.5-5 GPIO接口的应用单片机原理与应用 9.5 GPIO 接口 应用 单片机 原理
限制150内