




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、STM32 GPIO使 用 操作步骤: 1. 使能GPIO对应的外设时钟 例如:/使能GPIOA GPIOB GPIOC寸应的外设时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB| RCC_APB2Periph_GPIOC , ENABLE); 2. 声明一个 GPIO_InitStructure 结构体 例如: GPIO_InitTypeDef GPIO_InitStructure; 3. 选择待设置的GPIO管脚 例如:/*选择待设置的GPIO第7、8、9管脚位,中间加“ 符号*/ GPIO_Init
2、Structure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9; 4. 设置选中GPIO管脚的速率 例如:/*设置选中GPIO管脚的速率为最高速率2MHz */ GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz; / 最高速率 2MHz 5. 设置选中GPIO管脚的模式 例如:/*设置选中GPIO管脚的模式为开漏输出模式*/ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD; / 开漏输出模式 6. 根据 GPIO_InitStructure 中指定的
3、参数初始化外设 GPIOX 例如: /* 根据 GPIO_InitStructure 中指定的参数初始化外设 GPIOC */ GPIO_Init(GPIOC, 7. 其他应用 例: 将端口 GPIOA 的第 10、 15脚置 1(高电平) GPIO_SetBits(GPIOA, GPIO_Pin_10 | GPIO_Pin_15); 例: 将端口 GPIOA 的第 10、 15脚置 0(低电平) GPIO_ResetBits(GPIOA, GPIO_Pin_10 | GPIO_Pin_15); GPIO寄存器: 寄存器 描述 CRL 端口配置低寄存器 CRH 端口配置高寄存器 IDR 端口输
4、入数据寄存器 ODR 端口输出数据寄存器 BSRR 端口位设置 /复位寄存器 BRR 端口位复位寄存器 LCKR 端口配置锁定寄存器 EVCR 事件控制寄存器 MAPR 复用重映射和调试 I/O 配置寄存器 EXTICR 外部中断线路 0-15配置寄存器 GPIO 库函数: 描述 函数名 GPIO_DeInit 将外设GPIOx寄存器重设为缺省值 GPIO_AFIODeInit 将复用功能(重映射事件控制和 EXTI 设置)重设为缺省值 GPIO_Init根据GPIO_InitStruct中指定的参数初始化外设GPIOx寄存器 GPIO_Structl nit把GPIOn itStruct中的
5、每一个参数按缺省值填入 GPIO_ReadInputDataBit GPIO_ReadInputData 读取指定端口管脚的输入 读取指定的GPIO端口输入 GPIO_ReadOutputDataBit GPIO_ReadOutputData GPIO_SetBits GPIO_ResetBits GPIO_WriteBit GPIO_Write GPIO_PinLockConfig GPIO_EventOutputConfig GPIO_EventOutputCmd GPIO_PinRemapConfig GPIO_EXTILineConfig 读取指定端口管脚的输出 读取指定的GPIO端口
6、输出 设置指定的数据端口位 清除指定的数据端口位 设置或者清除指定的数据端口位 向指定GPI O数据端口写入数据 锁定GPI O管脚设置寄存器 选择GPI O管脚用作事件输出 使能或者失能事件输出 改变指定管脚的映射 选择GPIO管脚用作外部中断线路 库函数: 函数 GPIO_DeInit 功能描述:将外设 GPIOx 寄存器重设为缺省值 例: GPIO_DeInit(GPIOA); 函数 GPIO_AFIODeInit 功能描述:将复用功能(重映射事件控制和 EXTI 设置)重设为缺省值 例: GPIO_AFIODeInit(); 函数 GPIO_Init 功能描述:根据 GPIO_Init
7、Struct 中指定的参数初始化外设 GPIOx 寄存器 例: GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, GPIO_InitTypeDef structure GPIO_InitTypeDef 定义于文件 “ stm32f10 x_gpi
8、o.h”: typedef struct u16 GPIO_Pin; GPIOSpeed_TypeDef GPIO_Speed; GPIOMode_TypeDef GPIO_Mode; GPIO_InitTypeDef; GPIO_Pin 该参数选择待设置的 GPIO 管脚,使用操作符“ | ”可以一次选中多个管脚。可 以使用下表中的任意组合。 GPIO_Pin_None: 无管脚被选中 GPIO_Pin_x: 选中管脚 x( 0-15) GPIO_Pin_All : 选中全部管脚 GPIO_Mode_IPD :下拉输入 GPIO_Speed GPIO_Speed: 用以设置选中管脚的速率。
9、GPIO_Speed_10MHz: 最高输出速率 10MHz GPIO_Speed_2MHz: 最高输出速率 2MHz GPIO_Speed_50MHz: 最高输出速率 50MHz GPIO_Mode GPIO_Mode: 用以设置选中管脚的工作状态。 GPIO_Mode_AIN : 模拟输入 GPIO_Mode_IN_FLOATING : 浮空输入 GPIO_Mode_IPU:上拉输入 GPIO_Mode_Out_OD : 开漏输出 GPIO_Mode_Out_PP: 推挽输出 GPIO_Mode_AF_OD : 复用开漏输出 GPIO_Mode_AF_PP: 复用推挽输出 函数 GPIO_
10、StructInit 功能描述:把 GPIO_InitStruct 中的每一个参数按缺省值填入 例: GPIO_InitTypeDef GPIO_InitStructure; GPIO_StructInit( GPIO_InitStruct : GPIO_Pin:GPIO_Pin_All GPIO_Speed:GPIO_Speed_2MHz GPIO_Mode:GPIO_Mode_IN_FLOATING 函数 GPIO_ReadInputDataBit 功能描述:读取指定端口管脚的输入 例: u8 ReadValue; ReadValue = GPIO_ReadInputDataBit(GPI
11、OB, GPIO_Pin_7); 函数 GPIO_ReadInputData 功能描述:读取指定的 GPIO 端口输入 例: u16 ReadValue; ReadValue = GPIO_ReadInputData(GPIOC); 函数 GPIO_ReadOutputDataBit 功能描述:读取指定端口管脚的输出 例: u8 ReadValue; ReadValue = GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_7); 函数 GPIO_ReadOutputData 功能描述:读取指定的 GPIO 端口输出 例: u16 ReadValue; ReadVa
12、lue = GPIO_ReadOutputData(GPIOC); 函数 GPIO_SetBits 功能描述:置位指定的数据端口位 例: 将端口 GPIOA 的第 10、15 脚置 1(高电平) GPIO_SetBits(GPIOA, GPIO_Pin_10 | GPIO_Pin_15); 函数 GPIO_ResetBits 功能描述:清除指定的数据端口位 例: 将端口 GPIOA 的第 10、15脚置 0(低电平) GPIO_ResetBits(GPIOA, GPIO_Pin_10 | GPIO_Pin_15); 函数 GPIO_WriteBit 功能描述:设置或者清除指定的数据端口位 例:
13、 GPIO_WriteBit(GPIOA, GPIO_Pin_15, Bit_SET); 函数 GPIO_Write 功能描述:向指定 GPIO 数据端口写入数据 例: GPIO_Write(GPIOA, 0 x1101); 函数 GPIO_PinLockConfig 功能描述:锁定 GPIO 管脚设置寄存器 例: GPIO_PinLockConfig(GPIOA, GPIO_Pin_0 | GPIO_Pin_1); 函数 GPIO_EventOutputConfig 功能描述:选择 GPIO 管脚用作事件输出 例: GPIO_EventOutputConfig(GPIO_PortSource
14、GPIOE, GPIO_PinSource5); GPIO_PortSource GPIO_PortSource用以选择用作事件输出的 GPIO端口。 函数 GPIO_EventOutputCmd 功能描述:使能或者失能事件输出 例: GPIO_EventOutputConfig(GPIO_PortSourceGPIOC, GPIO_PinSource6); GPIO_EventOutputCmd(ENABLE); 函数 GPIO_PinRemapConfig 功能描述:改变指定管脚的映射 例: GPIO_PinRemapConfig(GPIO_Remap_I2C1, ENABLE); 一.G
15、PIO概述 1、共有 8 种模式,可以通过编程选择: 1. 浮空输入 2. 带上拉输入 3. 带下拉输入 4. 模拟输入 5. 开漏输出 ( 此模式可实现 hotpower 说的真双向 IO) 6. 推挽输出 7. 复用功能的推挽输出 8. 复用功能的开漏输出 模式 7 和模式 8 需根据具体的复用功能决定。 2、专门的寄存器(GPIOx_BSRR和GPIOx_BRR实现对GPIO 口的原子操作,即回避了设置 或清除 I/O 端口时的“读 -修改-写”操作, 使得设置或清除 I/O 端口的操作不会被中断处理 打断而造成误动作。 3、每个GPIO口都可以作为外部中断的输入,便于系统灵活设计。 4
16、、 I/O 口的输出模式下,有 3种输出速度可选(2MHz、10MHz和50MHz),这有利于噪声 控制。这个速度是指 I/O 口驱动电路的响应速度而不是输出信号的速度, 输出信号的速度与 程序有关(芯片内部在 I/O 口的输出部分安排了多个响应速度不同的输出驱动电路,用户可 以根据自己的需要选择合适的驱动电路) 。通过选择速度来选择不同的输出驱动模块, 达到 最佳的噪声控制和降低功耗的目的。 高频的驱动电路, 噪声也高, 当不需要高的输出频率时, 请选用低频驱动电路, 这样非常有利于提高系统的 EMI 性能。当然如果要输出较高频率的信 号,但却选用了较低频率的驱动模块,很可能会得到失真的输出
17、信号。 4.1 各种借口的措施: 4.1.1对于串口,假如最大波特率只需 115.2k,那么用2M的GPIO的引脚速度就够了, 既省电也噪声小。 4.1.2对于I2C接口,假如使用 400k波特率,若想把余量留大些,那么用2M的GPIO 的引脚速度或许不够,这时可以选用10M的GPIO引脚速度。 4.1.3对于SPI接口,假如使用18M或9M波特率,用10M的GPIO的引脚速度显然不 够了,需要选用 50M的GPIO的引脚速度。 4.2 GPIO口设为输入时,输出驱动电路与端口是断开,所以输出速度配置无意义。 4.3 在复位期间和刚复位后,复用功能未开启, I/O 端口被配置成浮空输入模式。
18、4.4 所有端口都有外部中断能力。为了使用外部中断线,端口必须配置成输入模式。 4.5 GPIO口的配置具有上锁功能,当配置好GPIO口后,可以通过程序锁住配置组合,直到 下次芯片复位才能解锁。 5、所有I/O 口兼容CMOS TTL,多数I/O 口兼容5V电平。 6、大电流驱动能力:GPIO 口在高低电平分别为 0.4V和VDD-0.4V时,可以提供或吸收 8mA电流;如果把输入输出电平分别放宽到1.3V和VDD-1.3V时,可以提供或吸收 20mA电 流。 7、具有独立的唤醒 I/O 口。 8、很多 I/O 口的复用功能可以重新映射。 9. GPIO 口的配置具有上锁功能,当配置好GPIO
19、 口后,可以通过程序锁住配置组合, 直到下次芯片复位才能解锁。此功能非常有利于在程序跑飞的情况下保护系统中其他的设 备,不会因为某些 I/O 口的配置被改变而损坏如一个输入口变成输出口并输出电流。 二推挽结构 一般是指两个三极管分别受两互补信号的控制 , 总是在一个三极管导通的时候另一个截 止. 要实现线与需要用 OC(open collector) 门电路 . 如果输出级的有两个三极管, 始终处 于一个导通、 一个截止的状态, 也就是两个三级管推挽相连, 这样的电路结构称为推拉式电 路或图腾柱( Totem- pole )输出电路(可惜,图无法贴上)。当输出低电平时,也就是下 级负载门输入低
20、电平时,输出端的电流将是下级门灌入T4;当输出高电平时,也就是下级 负载门输入高电平时,输出端的电流将是下级门从本级电源经T3、 D1 拉出。这样一来, 输出高低电平时, T3 一路和 T4 一路将交替工作, 从而减低了功耗, 提高了每个管的承 受能力。又由于不论走哪一路,管子导通电阻都很小,使RC常数很小,转变速度很快。因 此,推拉式输出级既提高电路的负载能力,又提高开关速度。供你参考。 推挽电路是两个参数相同的三极管或MOSFET以推挽方式存在于电路中,各负责正负半周的 波形放大任务 , 电路工作时,两只对称的功率开关管每次只有一个导通,所以导通损耗小效 率高。 输出既可以向负载灌电流,也
21、可以从负载抽取电流 三开漏电路 在电路设计时我们常常遇到开漏 (open drain )和开集( open collector )的概 念。所谓开漏电路概念中提到的“漏”就是指MOSFET勺漏极。同理,开集电路中的“集” 就是指三极管的集电极。开漏电路就是指以MOSFET勺漏极为输出的电路。一般的用法是会 在漏极外部的电路添加上拉电阻。完整的开漏电路应该由开漏器件和开漏上拉电阻组成。 组成开漏形式的电路有以下几个特点: 1. 利用 夕卜部电路的驱动能力,减少IC内部的驱动。当IC内部MOSFE导通时,驱 动电流是从外部的 VCC流经R pull-up , MOSFE到GND IC内部仅需很下的
22、栅极驱动电 流。如图 1。 2. 可以将多个开漏输出的 Pin ,连接到一条线上。 形成 “与逻辑” 关系。 如图 1, 当PIN_A、PIN_B、PIN_C任意一个变低后,开漏线上的逻辑就为0 了。这也是I2C,SMBus 等总线判断总线占用状态的原理。 3. 可以利用改变上拉电源的电压, 改变传输电平。 如图 2, IC 的逻辑电平由电源 Vcc1 决定,而输出高电平则由 Vcc2 决定。 这样我们就可以用低电平逻辑控制输出高电平逻辑了。 4. 开漏 Pin 不连接外部的上拉电阻, 则只能输出低电平 (因此对于经典的 51 单片机的 P0 口而言,要想做输入输出功能必须加外部上拉电阻,否则
23、无法输出高电平逻辑)。 5. 标准的开漏脚一般只有输出的能力。 添加其它的判断电路, 才能具备双向输入、 输 出的能力。 应用中需注意: 1. 开漏和开集的原理类似, 在许多应用中我们利用开集电路代替开漏电路。 例如, 某输入 Pin 要求由开漏电路驱动。 则我们常见的驱动方式是利用一个三极管组成开集电路来 驱动它,即方便又节省成本。如图 3。 2. 上拉电阻 R pull-up 的 阻值 决定了 逻辑电平转换的沿的速度 。阻值越大, 速度越低功耗越小。反之亦然。 Push-Pull输出就是一般所说的推挽输出,在CMOSI路里面应该较CMO输出更合适, 应为在CMOSI面的push pull输
24、出能力不可能做得双极那么大。输出能力看IC内部输出 极N管P管的面积。和开漏输出相比,push pull的高低电平由IC的电源低定,不能简单 的做逻辑操作等。push pull是现在CMOSI路里面用得最多的输出级设计方式。 at91rm9200 GPIO 模拟 I2C 接口时注意! 四.OC OD 集电极开路门 ( 集电极开路 OC 或源极开路 OD) open-drain 是漏极开路输出的意思,相当于集电极开路 (open-collector) 输出,即 ttl 中 的集电极开路(0C )输出。一般用于线或、线与,也有的用于电流驱动。 open-drain 是对mos管而言,open-co
25、llector是对双极型管而言,在用法上没啥区别。 开漏形式的电路有以下几个特点: 1. 利用外部电路的驱动能力, 减少 IC 内部的驱动。 或驱动比芯片电源电压高的负载 . 2. 可以将多个开漏输出的 Pin ,连接到一条线上。通过一只上拉电阻,在不增加任何 器件的情况下,形成“与逻辑”关系。 这也是I2C , SMBus等总线判断总线占用状态的原理。 如果作为图腾输出必须接上拉电阻。 接容性负载时, 下降延是芯片内的晶体管, 是有源驱动, 速度较快;上升延是无源的外接电阻,速度慢。如果要求速度高电阻选择要小,功耗会大。 所以负载电阻的选择要兼顾功耗和速度。 3. 可以利用改变上拉电源的电压,改变传输电平。例如加上上拉电阻就可以提供 TTL/CM OSt平输出等。 4. 开漏 Pin 不连接外部的上拉电阻,则只能输出低电平。一般来说,开漏是用来连接 不同电平的器件,匹配电平用的。 5. 正常的CMOS俞出级是上、下两个管子,把上面的管子去掉就是OPEN-DRAINT
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030年睡衣产业行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年特种车行业风险投资发展分析及运作模式与投资融资研究报告
- 2025-2030年牛肉行业市场深度分析及发展前景与投资战略研究报告
- 2025-2030年灭火系统产业市场深度分析及前景趋势与投资研究报告
- 2025-2030年洗碗机行业风险投资发展分析及投资融资策略研究报告
- 2025-2030年汽车锻压设备行业市场发展分析及前景趋势与投资管理研究报告
- 2025-2030年水资源开发产业市场深度分析及前景趋势与投资研究报告
- 2025-2030年民宿产业市场发展分析及前景趋势与投资战略研究报告
- 2025-2030年植物防脱洗发液行业市场发展分析及投资前景研究报告
- 2025-2030年杂志广告行业市场深度调研及趋势前景与投融资研究报告
- 人流手术报告单
- 水利工程建设标准强制性条文实施计划
- 2024年陕西汉水电力实业有限责任公司招聘笔试参考题库含答案解析
- 脑卒中患者的药物管理确保正确用药避免风险
- 小学综合实践《我们的传统节日》说课稿
- 《蚁群算法》课件
- 关于厂房的出售知识讲座
- 新课标下识字教学的方法与实践
- 【瑞幸咖啡财务分析报告(附财务报表)5300字(论文)】
- 基于深度学习的语音分离技术研究
- JGT475-2015 建筑幕墙用硅酮结构密封胶
评论
0/150
提交评论