嵌入式系统设计(STM32)第3讲讲课稿.ppt
《嵌入式系统设计(STM32)第3讲讲课稿.ppt》由会员分享,可在线阅读,更多相关《嵌入式系统设计(STM32)第3讲讲课稿.ppt(69页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、嵌入式系统设计(STM32)第3讲GPIO的功能的功能(1)最基本的功能是可以驱动)最基本的功能是可以驱动LED、产生、产生PWM、驱动蜂鸣器等。、驱动蜂鸣器等。(2)具有单独的位设置或位清除,编程简单。端口配置好后,只需)具有单独的位设置或位清除,编程简单。端口配置好后,只需GPIO_SetBits(GPIOx,GPIO_Pin_x)就可以实现对就可以实现对GPIOx的的Pinx位为高位为高电平;电平;GPIO_ResetBits(GPIOx,GPIO_Pin_x)就可以实现对就可以实现对GPIOx的的Pinx位为低电平。位为低电平。(3)具有外部中断)具有外部中断/唤醒能力,端口配置成输入
2、模式时,具有外部中断能力。唤醒能力,端口配置成输入模式时,具有外部中断能力。(4)具有复用功能,复用功能的端口兼有)具有复用功能,复用功能的端口兼有I/O功能等。功能等。(5)软件重新映射)软件重新映射I/O复用功能:为了使不同器件封装的外设复用功能:为了使不同器件封装的外设I/O功能的数量功能的数量达到最优,可以把一些服用功能重新映射到其他一些引脚上。这可以通过达到最优,可以把一些服用功能重新映射到其他一些引脚上。这可以通过软件配置到相应的寄存器来完成。软件配置到相应的寄存器来完成。(6)GPIO口的配置具有锁定机制。当配置好口的配置具有锁定机制。当配置好GPIO口后,在端口位上执行了口后,
3、在端口位上执行了锁定(锁定(LOCK),可以通过程序锁住配置组合,在下一次复位之前,将不),可以通过程序锁住配置组合,在下一次复位之前,将不能再更改端口位的配置。能再更改端口位的配置。3.1GPIO结构结构nI/O端口位的基本结构图端口位的基本结构图钳位保护二极管钳位保护二极管nGPIO内部具有钳位保护二极管,其作用是防止从内部具有钳位保护二极管,其作用是防止从外部管脚外部管脚Pin输入的电压过高或者过低。输入的电压过高或者过低。nVDD正常供电是正常供电是3.3V。如果从。如果从Pin输入的信号(假输入的信号(假设任何输入信号都有一定的内阻)电压超过设任何输入信号都有一定的内阻)电压超过VD
4、D加上二极管加上二极管D1的导通压降(假定在的导通压降(假定在0.6V左右),左右),则二极管则二极管D1导通,会把多于的电流引到导通,会把多于的电流引到VDD,而,而真正输入到内部的信号电压不会超过真正输入到内部的信号电压不会超过3.9V。n同理,如果从同理,如果从Pin输入的信号电压比输入的信号电压比GND还低,则还低,则由于二极管由于二极管D2的作用,会把实际输入内部的信号的作用,会把实际输入内部的信号电压钳制在电压钳制在0.6V左右。左右。对于对于GPIO的配置种类有的配置种类有8种之多:种之多:n(1)GPIO_Mode_AIN模拟输入模拟输入n(2)GPIO_Mode_IN_FLO
5、ATING 浮空输入浮空输入n(3)GPIO_Mode_IPD 下拉输入下拉输入n(4)GPIO_Mode_IPU 上拉输入上拉输入n(5)GPIO_Mode_Out_OD 开漏输出开漏输出n(6)GPIO_Mode_Out_PP推挽输出推挽输出n(7)GPIO_Mode_AF_OD 复用开漏输出复用开漏输出n(8)GPIO_Mode_AF_PP复用推挽输出复用推挽输出浮空输入(高阻输入)浮空输入(高阻输入)输入模式的结构比较简单,就是一个带有施输入模式的结构比较简单,就是一个带有施密特触发输入(密特触发输入(Schmitt-triggeredinput)的三态缓冲器(的三态缓冲器(U1),并
6、具有很高的输入等),并具有很高的输入等效阻抗。效阻抗。施密特触发输入的作用是能将缓慢变化的或施密特触发输入的作用是能将缓慢变化的或者是畸变的输入脉冲信号整形成比较理想的者是畸变的输入脉冲信号整形成比较理想的矩形脉冲信号。矩形脉冲信号。执行执行GPIO管脚读操作时,在读脉冲管脚读操作时,在读脉冲(ReadPulse)的作用下会把管脚()的作用下会把管脚(Pin)的当前电平状态读到内部总线上的当前电平状态读到内部总线上(InternalBus)。)。在不执行读操作时,外部管脚与内部总线之在不执行读操作时,外部管脚与内部总线之间是隔离的。间是隔离的。推挽输出推挽输出执行执行GPIO管脚写操作时,在写
7、管脚写操作时,在写脉冲(脉冲(WritePulse)的作用下,数)的作用下,数据被锁存到据被锁存到Q和和/Q。T1和和T2构成构成CMOS反相器,反相器,T1导通或导通或T2导通时都表现出较低的阻导通时都表现出较低的阻抗,但抗,但T1和和T2不会同时导通或同时不会同时导通或同时关闭,最后形成的是推挽输出。关闭,最后形成的是推挽输出。开漏输出开漏输出开漏输出只有下拉晶体管开漏输出只有下拉晶体管T1而没有上拉晶体而没有上拉晶体管。同样,管。同样,T1实际上也是多组可编程选择的实际上也是多组可编程选择的晶体管。开漏输出的实际作用就是一个开关,晶体管。开漏输出的实际作用就是一个开关,输出输出“1”时断
8、开、输出时断开、输出“0”时连接到时连接到GND。开漏输出结构没有内部上拉,因此在实际应开漏输出结构没有内部上拉,因此在实际应用时通常都要外接合适的上拉电阻(通常采用时通常都要外接合适的上拉电阻(通常采用用4.710k)。)。开漏输出能够方便地实现开漏输出能够方便地实现“线与线与”逻辑功能,逻辑功能,即多个开漏的管脚可以直接并在一起使用,即多个开漏的管脚可以直接并在一起使用,并统一外接一个合适的上拉电阻,就自然形并统一外接一个合适的上拉电阻,就自然形成成“逻辑与逻辑与”关系。关系。开漏输出的另一种用途是能够方便地实现不开漏输出的另一种用途是能够方便地实现不同逻辑电平之间的转换(如同逻辑电平之间
9、的转换(如3.3V到到5V之间),之间),只需外接一个上拉电阻,而不需要额外的转只需外接一个上拉电阻,而不需要额外的转换电路。换电路。输入配置输入配置当当I/O端口配置为输入时:端口配置为输入时:输出缓冲器被禁止输出缓冲器被禁止施密特触发输入被激活施密特触发输入被激活根据输入配置根据输入配置(上拉,下拉或浮动上拉,下拉或浮动)的不同,弱上拉和的不同,弱上拉和下拉电阻被连接下拉电阻被连接出现在出现在I/O脚上的数据在每个脚上的数据在每个APB2时钟被采样到输入时钟被采样到输入数据寄存器数据寄存器对输入数据寄存器的读访问可得到对输入数据寄存器的读访问可得到I/O状态状态输入浮空输入浮空/上拉上拉/
10、下拉配置图下拉配置图输出配置输出配置当当I/O端口被配置为输出时:端口被配置为输出时:n输出缓冲器被激活输出缓冲器被激活开漏模式:输出寄存器上的开漏模式:输出寄存器上的0激活激活N-MOS,而输出寄存器上的,而输出寄存器上的1将端口置于高阻状态将端口置于高阻状态(P-MOS从不被激活从不被激活)。推挽模式:输出寄存器上的推挽模式:输出寄存器上的0激活激活N-MOS,而输出寄存器上的,而输出寄存器上的1将激活将激活P-MOS。n施密特触发输入被激活施密特触发输入被激活n弱上拉和下拉电阻被禁止弱上拉和下拉电阻被禁止n出现在出现在I/O脚上的数据在每个脚上的数据在每个APB2时钟被采样到输入数据寄时
11、钟被采样到输入数据寄存器存器n在开漏模式时,对输入数据寄存器的读访问可得到在开漏模式时,对输入数据寄存器的读访问可得到I/O状态状态n在推挽模式时,对输出数据寄存器的读访问得到最后一次写在推挽模式时,对输出数据寄存器的读访问得到最后一次写的值。的值。I/O端口位的输出配置图端口位的输出配置图返回返回3.2GPIO寄存器寄存器每个每个GPI/O端口有:端口有:n两个两个32位配置寄存器位配置寄存器(GPIOx_CRL,GPIOx_CRH),n两个两个32位数据寄存器位数据寄存器(GPIOx_IDR,GPIOx_ODR),n一个一个32位置位位置位/复位寄存器复位寄存器(GPIOx_BSRR),n
12、一个一个16位复位寄存器位复位寄存器(GPIOx_BRR)n一个一个32位锁定寄存器位锁定寄存器(GPIOx_LCKR)。GPIO端口的每个位可以由软件分别配置成多种模式。端口的每个位可以由软件分别配置成多种模式。必须以字必须以字(32位位)的方式操作这些外设寄存器。的方式操作这些外设寄存器。GPIOx_BSRR和和GPIOx_BRR寄存器允许对任何寄存器允许对任何GPIO寄存器的读寄存器的读/更改的独立访问,这样,在读和更改访问之更改的独立访问,这样,在读和更改访问之间产生间产生IRQ时不会发生危险。时不会发生危险。3.2GPIO寄存器寄存器nCRL端口配置低寄存器端口配置低寄存器nCRH端
13、口配置高寄存器端口配置高寄存器nIDR端口输入数据寄存器端口输入数据寄存器nODR端口输出数据寄存器端口输出数据寄存器nBSRR端口位设置端口位设置/复位寄存器复位寄存器nBRR端口位复位寄存器端口位复位寄存器nLCKR端口配置锁定寄存器端口配置锁定寄存器nEVCR事件控制寄存器事件控制寄存器nMAPR复用重映射和调试复用重映射和调试nEXTICR外部中断线路外部中断线路0-15配置寄存器配置寄存器端口配置低寄存器端口配置低寄存器GPIOx_CRL)(x=A.E)复位值:复位值:0 x44444444CNFy1:0:端口:端口x配置位配置位(y=07)(Portxconfigurationbi
14、ts)MODEy1:0:端口:端口x的模式位的模式位(y=07)(Portxmodebits)端口位配置表端口位配置表n复位期间和刚复位后,复用功能未开启,复位期间和刚复位后,复用功能未开启,I/O端口被配置端口被配置成成浮空输入模式浮空输入模式(CNFx1:0=01b,MODEx1:0=00b)。输出模式位 端口配置高寄存器端口配置高寄存器(GPIOx_CRH)(x=A.E)复位值:复位值:0 x44444444CNFy1:0:端口:端口x配置位配置位(y=815)(Portxconfigurationbits)MODEy1:0:端口:端口x的模式位的模式位(y=815)(Portxmode
15、bits)端口输入数据寄存器端口输入数据寄存器(GPIOx_IDR)(x=A.E)复位值:复位值:0 x0000XXXXnIDRy15:0IDRy15:0:端口输入数据:端口输入数据(y=015)(Port input data)(y=015)(Port input data)n这些位为只读并只能以字这些位为只读并只能以字(16(16位位)的形式读出。的形式读出。n读出的值为对应读出的值为对应I/OI/O口的状态。口的状态。端口输出数据寄存器端口输出数据寄存器(GPIOx_ODR)(x=A.E)复位值:复位值:0 x00000000nODRy15:0:端口输出数据:端口输出数据(y=015)(
16、Portoutputdata)n这些位可读可写并只能以字这些位可读可写并只能以字(16位位)的形式操作。的形式操作。n注:对注:对GPIOx_BSRR(x=AE),可以分别地对各个,可以分别地对各个ODR位位进行独立的设置进行独立的设置/清除。清除。端口位设置端口位设置/清除寄存器清除寄存器(GPIOx_BSRR)复位值:复位值:0 x00000000nBRy:BRy:清除端口清除端口x x的位的位y(y=015)(Port x Reset bit y)y(y=015)(Port x Reset bit y)这些位只能这些位只能写入并只能以字写入并只能以字(16(16位位)的形式操作。的形式操
17、作。n0 0:对对应的:对对应的ODRyODRy位不产生影响,位不产生影响,1 1:清除对应的:清除对应的ODRyODRy位为位为0 0 nBSy:BSy:设置端口设置端口x x的位的位y y。n0 0:对对应的:对对应的ODRyODRy位不产生影响,位不产生影响,1 1:设置对应的:设置对应的ODRyODRy位为位为1 1n注:如果同时设置了注:如果同时设置了BSyBSy和和BRyBRy的对应位,的对应位,BSyBSy位起作用。位起作用。端口位清除寄存器端口位清除寄存器(GPIOx_BRR)复位值:复位值:0 x00000000nBRy:清除端口清除端口x的位的位y(y=015)(Portx
18、Resetbity)n这些位只能写入并只能以字这些位只能写入并只能以字(16位位)的形式操作。的形式操作。n0:对对应的:对对应的ODRy位不产生影响,位不产生影响,n1:清除对应的:清除对应的ODRy位为位为0端口配置锁定寄存器端口配置锁定寄存器(GPIOx_LCKR)复位值:复位值:0 x00000000n当执行正确的写序列设置了位当执行正确的写序列设置了位16(LCKK)时,该寄存器用时,该寄存器用来锁定端口位的配置。来锁定端口位的配置。n位位15:0用于锁定用于锁定GPIO端口的配置。在规定的写入操作期端口的配置。在规定的写入操作期间,不能改变间,不能改变LCKy15:0。当对相应的端
19、口位执行了。当对相应的端口位执行了LOCK序列后,在下次系统复位之前将不能再更改端口位序列后,在下次系统复位之前将不能再更改端口位的配置。的配置。n每个锁定位锁定控制寄存器每个锁定位锁定控制寄存器(CRL,CRH)中相应的中相应的4个位。个位。nLCKy:端口端口x的锁位的锁位y(y=015)(PortxLockbity)。这些位可读可写但只能在这些位可读可写但只能在LCKK位为位为0时写入。时写入。n0:不锁定端口的配置,:不锁定端口的配置,1:锁定端口的配置:锁定端口的配置端口配置锁定寄存器格式端口配置锁定寄存器格式GPIO寄存器结构nGPIO寄存器结构,寄存器结构,GPIO_TypeDe
20、f 和和AFIO_TypeDef,在文件在文件“stm32f10 x_map.h”中定义如下:中定义如下:寄存器编程举例寄存器编程举例voidLED_Init(void)RCC-APB2ENR|=1CRL&=0X00000000;GPIOE-CRL|=0X33333333;/PE.0-PE.7推挽输出推挽输出GPIOE-ODR|=0 xFF;/PE.0-PE.7输出高电平输出高电平APB2外设时钟使能寄存器外设时钟使能寄存器(RCC_APB2ENR)复位值:复位值:0 x00000000nIOPEEN(位位6):IO端口端口E时钟使能时钟使能(I/OportEclockenable)由软件置由
21、软件置1或清或清0n0:IO端口端口E时钟关闭;时钟关闭;1:IO端口端口E时钟开启。时钟开启。n/点亮灯点亮灯nGPIOC-ODR=0 xfffffffe;/点亮点亮1个灯个灯nGPIOC-BSRR=0 x00030000;/点亮点亮2个灯个灯nGPIOC-BRR=0 x000C;n/GPIO_ResetBits(GPIOC,GPIO_Pin_2);n/GPIO_Write(GPIOC,0 xffff);n/GPIO_WriteBit(GPIOC,GPIO_Pin_3,Bit_RESET);n/熄灭灯熄灭灯nGPIOC-ODR=0 xffffffff;nGPIOC-BSRR=0 x00000
22、003;nGPIOC-BSRR=0 x0000000C;n/GPIO_SetBits(GPIOC,GPIO_Pin_2);n/GPIO_Write(GPIOC,0 xfff0);n/GPIO_WriteBit(GPIOC,GPIO_Pin_3,Bit_SET);返回返回3.3GPIO函数函数nGPIO_DeInit将外设将外设GPIOx寄存器重设为缺省值寄存器重设为缺省值nGPIO_AFIODeInit将复用功能(重映射事件控制和将复用功能(重映射事件控制和EXTI设置)重设为缺省值设置)重设为缺省值nGPIO_Init根据根据GPIO_InitStruct中指定的参数初始化外设中指定的参数初
23、始化外设GPIOx寄存器寄存器nGPIO_StructInit把把GPIO_InitStruct中的每一个参数按缺省值填入中的每一个参数按缺省值填入nGPIO_ReadInputDataBit读取指定端口管脚的输入读取指定端口管脚的输入nGPIO_ReadInputData读取指定的读取指定的GPIO端口输入端口输入nGPIO_ReadOutputDataBit读取指定端口管脚的输出读取指定端口管脚的输出nGPIO_ReadOutputData读取指定的读取指定的GPIO端口输出端口输出nGPIO_SetBits设置指定的数据端口位设置指定的数据端口位nGPIO_ResetBits清除指定的数
24、据端口位清除指定的数据端口位nGPIO_WriteBit设置或者清除指定的数据端口位设置或者清除指定的数据端口位nGPIO_Write向指定向指定GPIO数据端口写入数据数据端口写入数据nGPIO_PinLockConfig锁定锁定GPIO管脚设置寄存器管脚设置寄存器nGPIO_EventOutputConfig选择选择GPIO管脚用作事件输出管脚用作事件输出nGPIO_EventOutputCmd使能或者失能事件输出使能或者失能事件输出nGPIO_PinRemapConfig改变指定管脚的映射改变指定管脚的映射nGPIO_EXTILineConfig选择选择GPIO管脚用作外部中断线路管脚用
25、作外部中断线路函数GPIO_DeInit n功能功能:将外设:将外设GPIOx寄存器重设为缺省值。寄存器重设为缺省值。n函数原形函数原形:voidGPIO_DeInit(GPIO_TypeDef*GPIOx)nGPIOx:x可以是可以是A,B,C,D或者或者E,来选择,来选择GPIO外设。外设。n被调用函数:被调用函数:RCC_APB2PeriphResetCmd()n例:例:/*ResetstheGPIOAperipheralregisterstotheirdefaultresetvalues*/GPIO_DeInit(GPIOA);函数GPIO_AFIODeInit n功能描述:将复用功能
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 系统 设计 STM32 讲课
限制150内