嵌入式控制系统原理及设计PPT课件(共25单元)GPIO端口.pptxVIP

嵌入式控制系统原理及设计PPT课件(共25单元)GPIO端口.pptx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
嵌入式控制系统原理及设计第5章 嵌入式系统接口技术5.2 GPIO端口嵌入式控制系统原理及设计5.2.1 GPIO端口简介STM32F10x微处理器的GPIO内部电路如图5.9所示,每个GPIO引脚都可由软件配置成:浮空输入模式、上拉输入模式、下拉输入模式、模拟输入模式、开漏输出模式、推挽输出模式、复用开漏输出模式和复用推挽输出模式,共计8种。嵌入式控制系统原理及设计5.2.2 GPIO寄存器配置和使用GPIO端口是通过其寄存器实现的。GPIO端口寄存器包括端口配置低寄存器(GPIOx_CRL)、端口配置高寄存器(GPIO_CRH)、端口输入寄存器(GPIOx_IDR)、端口输出寄存器(GPIOx_ODR)、端口位设置/清除寄存器(GPIOx_BSRR)、端口位清除寄存器(GPIOx_BRR)、端口锁定寄存器(GPIOx_LCKR),其中x为A~G。嵌入式控制系统原理及设计5.2.2 GPIO寄存器(1)端口配置寄存器(GPIOx_CRL和GPIOx_CRH)STM32每个GPIO端口有两个32位的配置寄存器,CRL控制端口的低八位,SRH控制端口的高八位。嵌入式控制系统原理及设计5.2.2 GPIO寄存器例如:要设置GPIOC的第4位端口为最高50MHz频率的推挽输出,第15位端口为上拉下拉输入模式,则应该设置如下:GPIOC-CRL的CNF4[1:0]为00,GPIOC-CRL的MODE4[1:0]为11。GPIOC-CRH的CNF7[1:0]为00,GPIOC-CRH的MODE7[1:0]为11。因此,利用C语言编程如下:GPIOC-CRL=0xFFF0FFFF; //清除对位4的设置GPIOC-CRL|=0 //写位4的设置为0011GPIOC-CRH=0x0FFFFFFF; //清除对位7的设置GPIOC-CRH|=0 //写位7的设置为0011嵌入式控制系统原理及设计5.2.2 GPIO寄存器端口输入数据寄存器(GPIOx_IDR)和端口输出数据寄存器(GPIOx_ODR)嵌入式控制系统原理及设计5.2.2 GPIO寄存器例如:将刚才设置的GPIOC第4位设置为1,编程如下:GPIOC_ODR|=14; //将GPIOC_ODR寄存器的第4位设置为1。如果使得GPIOC第4位再输出低电平,编程如下:GPIOC_ODR=(~(14)); //将GPIOC_ODR寄存器的第4位设置为0。嵌入式控制系统原理及设计5.2.2 GPIO寄存器(3)端口位设置/清除寄存器(GPIOx_BSRR)GPIOx_BSRR用于设置某一特定引脚的输出电平,而保持其他引脚输出不变,其结构如图5.13所示。嵌入式控制系统原理及设计5.2.2 GPIO寄存器例如:将GPIOC的第4位端口输出为低电平,第5位端口输出高电平,编程如下:GPIOC-BSRR=0嵌入式控制系统原理及设计5.2.2 GPIO寄存器(4)端口位清除寄存器(GPIOx_BRR)GPIOx_BRR用于清除某一特定引脚,而保持其他引脚输出不变,其结构如图5.14所示。嵌入式控制系统原理及设计5.2.2 GPIO寄存器(5)端口锁定寄存器(GPIOx_LCKR)当执行正确的字序列设置了位16(LCKK)时,LCKR用于锁定端口位的配置,其结构如图5.15所示。在字序列写入过程中,LCKR[15:0]的值必须保持不变。当已完成某个端口位的LOCK序列写入后,端口的数值将无法改变,除非重启。嵌入式控制系统原理及设计5.2.3 GPIO库函数GPIO的设置与使用可以直接对寄存器进行操作,但使用此方法必须对STM32内部的存储器映射、寄存器操作十分熟悉。本节介绍另一种使用库函数的方法,该方法利用ST公司提供的函数库,可以快速进行嵌入式系统的软件开发。GPIO寄存器组的结构体GPIO_TypeDef定义在库文件stm32f10x.h中,因此必须让使用库函数的C文件包含“stm32f10x_gpio.h”和“stm32f10x_rcc.h”。嵌入式控制系统原理及设计5.2.3 GPIO库函数void GPIO_Init(GPIO_TypeDef * GPIOx, GPIO_InitTypeDef * GPIO_InitStruct)功能描述:根据GPIO_InitStruct中指定的参数初始化外设GPIOx的寄存器。参数说明:GPIOx:GPIO端口,x可以是A,B,…,G。GPIO_InitStruct:指向结构GPIO_InitTypeDef的指针,包含了外设GPIO的配置信息。该结构体定义如下:typedef struct //定义于文件“stm32f10x_gpio.h”{

您可能关注的文档

文档评论(0)

139****1983 + 关注
实名认证
文档贡献者

副教授、一级建造师持证人

从事职业教育近20年,高级职称。

领域认证该用户于2023年06月21日上传了副教授、一级建造师

1亿VIP精品文档

相关文档