第1章 GPIO介绍及基础使用

第一章 GPIO介绍及基础使用

1. GPIO简介

GPIO,全称为 「General-Purpose Input/Output」,即通用输入/输出端口。

它是微控制器、微处理器和某些其他集成电路上的一个引脚,可以由软件控制其输入或输出状态。

GPIO 为开发者提供了一种简单、灵活的方式来控制硬件设备或与外部设备进行通信。

2. GPIO使用示例

2.1 硬件说明

2.1.1 LED

GPIO 章节我们将使用 LED 和 按键 作为案例,而作为案例那我们就需要了解其具体的应用电路,了解应如何通过 GPIO 操控 LED 和按键

主要器件为 LED3,这是一个将三个颜色的灯融合到一起的彩灯器件,三个颜色分别为 R(红色red)、G(绿色green)、B(蓝色blue)。

R127、R128、R129 为LED灯的限流电阻,通常跟LED搭配,防止LED灯电路上的电流过大,导致LED灯烧毁。放置的阻值通常在 220Ω ~ 10KΩ。在原理图中,三个不同颜色的LED灯限流电阻分别用了不同的阻值,是因为 LED 灯颜色材料的不同其消化的电流也不同,为了让三个颜色的LED灯亮度一致,经过实测发现使用 3KΩ、4.3KΩ、9.1KΩ 时,通过肉眼观察,发现亮度基本一致。

R130、R131 是上拉电阻。主要的功能就是让LED灯在上电未驱动的情况下,默认是灭的。因为 LED 的正极是高电平,负级也因为接入了上拉电阻导致其也是高电平,高电平和高电平无法形成压差产生电流,而没有电流,灯就不会亮。只有当 RGB-B 或 RGB-G 为低电平时,LED 灯才会亮。

2.1.2 按键

在开发板的原理图中,一共有三个按键,分别是RST、BOOT、KEY按键。

其中 RST 是芯片复位功能按键,不能通过软件的方式去控制该按键,当按键按下时,芯片的 XRSN 引脚将会接入 GND,导致芯片将会自动复位重新工作。其中 R58 和 C76 组成了上电复位电路。R58是一个上拉电阻,让 XRSN 引脚上电时为高电平。C76是一个 100nF 的小电容,根据电容的原理可知道,电容其实就是一个电池,电容在上电时会保持一个很短暂的导通现象,所以上电的瞬间,XRSN 通过电容变成了低电平进行复位;当电容充满电后,电容隔开了直流,XRSN 不再是低电平。这样就实现了上电复位功能。

BOOT 是特殊按键,它接到了 GPIO24 引脚,该引脚和 GPIO32 引脚是用于设置启动模式的特殊引脚。通过这两个引脚,可以设置四种模式,具体见下图:

开发板硬件上,默认将 GPIO24 和 GPIO32 引脚通过上拉电阻 R55 和 R56 接到了高电平,这样启动模式就是从 Flash 中启动,我们的代码就是烧录到 Flash 中。如果你要从 SCI 串口启动,则按住 BOOT 键,再上电即可。

KEY 按键就是用户的可以操控的按键,将 GPIO27 引脚接入了这个按键,通过按键接到 GND。采用的检测方式是通过给按键的一端接入低电平,一端接入 GPIO。在没有按下按键时,因为上拉电阻 R137 的存在,导致一直处在高电平;当按键按下时,上拉电阻失效,GPIO27 引脚将被变为低电平的 GND。这样高低电平的变化,就可以让开发板检测到按键的状态。

2.2 CCS工程

2.2.1 CCS&syscfg配置

2.2.2 用户代码

while(1)

{

if( GPIO_readPin(User_KEY) == 0 )

{

GPIO_writePin(User_LED, 0);

}

else

{

GPIO_writePin(User_LED, 1);

}

}

3. GPIO相关函数介绍

序号

函数名称

功能

1

void GPIO_setInterruptType(GPIO_ExternalIntNum extIntNum, GPIO_IntType intType)

设置中断类型

2

GPIO_IntType GPIO_getInterruptType(GPIO_ExternalIntNum extIntNum)

获取中断类型

3

void GPIO_enableInterrupt(GPIO_ExternalIntNum extIntNum)

使能外部中断

4

void GPIO_disableInterrupt(GPIO_ExternalIntNum extIntNum)

失能外部中断

5

uint16_t GPIO_getInterruptCounter(GPIO_ExternalIntNum extIntNum)

获取外部中断计数器的值

6

uint32_t GPIO_readPin(uint32_t pin)

读取指定引脚上的值

7

uint32_t GPIO_readPinDataRegister(uint32_t pin)

读取指定引脚的数据寄存器值

8

void GPIO_writePin(uint32_t pin, uint32_t outVal)

将一个值写入指定引脚

9

void GPIO_togglePin(uint32_t pin)

指定引脚的值进行翻转

10

uint32_t GPIO_readPortData(GPIO_Port port)

读取指定端口上的数据

11

uint32_t GPIO_readPortDataRegister(GPIO_Port port)

读取存储在GPIO数据寄存器中的值

12

void GPIO_writePortData(GPIO_Port port, uint32_t outVal)

将一个值写入指定端口

13

void GPIO_setPortPins(GPIO_Port port, uint32_t pinMask)

将指定端口上的所有指定引脚配置为特定状态

14

void GPIO_clearPortPins(GPIO_Port port, uint32_t pinMask)

清除指定端口上的所有指定引脚

15

void GPIO_togglePortPins(GPIO_Port port, uint32_t pinMask)

翻转指定端口上的所有指定引脚

16

void GPIO_lockPortConfig(GPIO_Port port, uint32_t pinMask)

锁定指定端口上指定引脚的配置

17

void GPIO_unlockPortConfig(GPIO_Port port, uint32_t pinMask)

解锁指定端口上指定引脚的配置

18

void GPIO_commitPortConfig(GPIO_Port port, uint32_t pinMask)

对指定端口上的指定引脚的锁存配置进行设置

19

void GPIO_setDirectionMode(uint32_t pin, GPIO_Direction pinIO)

设置指定引脚的方向和模式

20

GPIO_Direction GPIO_getDirectionMode(uint32_t pin)

获取指定引脚上的方向和模式

21

void GPIO_setInterruptPin(uint32_t pin, GPIO_ExternalIntNum extIntNum)

为指定的外部中断配置引脚

22

void GPIO_setPadConfig(uint32_t pin, uint32_t pinType)

设置指定引脚的引脚类型

23

uint32_t GPIO_getPadConfig(uint32_t pin)

获取指定引脚的引脚类型

24

void GPIO_setQualificationMode(uint32_t pin, GPIO_QualificationMode qualification)

设置指定引脚的限定模式

25

GPIO_QualificationMode GPIO_getQualificationMode(uint32_t pin)

获取指定引脚的限定模式

26

void GPIO_setQualificationPeriod(uint32_t pin, uint32_t divider)

配置指定GPIO输入信号滤波采样周期

27

void GPIO_setControllerCore(uint32_t pin, GPIO_CoreSelect core)

设置指定引脚在指定核心上运行

28

void GPIO_setAnalogMode(uint32_t pin, GPIO_AnalogMode mode)

设置指定引脚的模拟模式

29

void GPIO_setPinConfig(uint32_t pinConfig)

设置指定引脚的复用功能通常是复用于GPIO外设

比较常用的功能函数已经加粗表示。具体的代码,请见库中的 gpio.h。在原版的文件中每一个功能函数都有进行英文注释,如果需要中文版注释,请看下方的机翻代码:

//###########################################################################

//

// 文件: gpio.h

//

// 标题: C28x GPIO驱动

//

//###########################################################################

//

// C2000Ware版本 v5.04.00.00

//

// 版权所有 (C) 2024 德州仪器公司 - http://www.ti.com

//

// 允许以源代码和二进制形式重新分发和使用(无论是否修改),需满足以下条件:

//

// 源代码的再分发必须保留上述版权声明、本条件列表及以下免责声明。

//

// 二进制形式的再分发必须在文档和/或其他提供的材料中复制上述版权声明、

// 本条件列表及以下免责声明。

//

// 未经事先书面许可,不得使用德州仪器公司或其贡献者名称来推广衍生自本软件的产品。

//

// 本软件按"原样"提供,版权持有人和贡献者不承担任何明示或默示的担保,

// 包括但不限于对适销性和特定用途适用性的默示担保。在任何情况下,版权持有人或

// 贡献者均不对任何直接、间接、偶然、特殊、惩戒性或后果性损害(包括但不限于

// 替代商品或服务采购、使用损失、数据或利润损失或业务中断)承担责任。

// $

//###########################################################################

#ifndef GPIO_H

#define GPIO_H

//*****************************************************************************

//

// 若使用C++编译器,确保本头文件中的所有定义具有C语言绑定

//

//*****************************************************************************

#ifdef __cplusplus

extern "C"

{

#endif

//*****************************************************************************

//

//! \addtogroup gpio_api GPIO

//! @{

//

//*****************************************************************************

#include

#include

#include "inc/hw_gpio.h"

#include "inc/hw_memmap.h"

#include "inc/hw_types.h"

#include "inc/hw_xint.h"

#include "cpu.h"

#include "xbar.h"

#include "debug.h"

//*****************************************************************************

//

// 驱动函数内部使用的寄存器访问宏定义(不适用于应用代码)

// 除以2是针对C28x的字访问特性

//

//*****************************************************************************

#define GPIO_CTRL_REGS_STEP ((GPIO_O_GPBCTRL - GPIO_O_GPACTRL) / 2U)

#define GPIO_DATA_REGS_STEP ((GPIO_O_GPBDAT - GPIO_O_GPADAT) / 2U)

#define GPIO_DATA_READ_REGS_STEP ((GPIO_O_GPBDAT_R - GPIO_O_GPADAT_R) / 2U)

#define GPIO_GPxCTRL_INDEX (GPIO_O_GPACTRL / 2U)

#define GPIO_GPxQSEL_INDEX (GPIO_O_GPAQSEL1 / 2U)

#define GPIO_GPxMUX_INDEX (GPIO_O_GPAMUX1 / 2U)

#define GPIO_GPxDIR_INDEX (GPIO_O_GPADIR / 2U)

#define GPIO_GPxAMSEL_INDEX (0x00000014U / 2U) // GPAAMSEL保留地址

#define GPIO_GPxPUD_INDEX (GPIO_O_GPAPUD / 2U)

#define GPIO_GPxINV_INDEX (GPIO_O_GPAINV / 2U)

#define GPIO_GPxODR_INDEX (GPIO_O_GPAODR / 2U)

#define GPIO_GPxGMUX_INDEX (GPIO_O_GPAGMUX1 / 2U)

#define GPIO_GPxCSEL_INDEX (GPIO_O_GPACSEL1 / 2U)

#define GPIO_GPxLOCK_INDEX (GPIO_O_GPALOCK / 2U)

#define GPIO_GPxCR_INDEX (GPIO_O_GPACR / 2U)

#define GPIO_GPxDAT_INDEX (GPIO_O_GPADAT / 2U)

#define GPIO_GPxSET_INDEX (GPIO_O_GPASET / 2U)

#define GPIO_GPxCLEAR_INDEX (GPIO_O_GPACLEAR / 2U)

#define GPIO_GPxTOGGLE_INDEX (GPIO_O_GPATOGGLE / 2U)

#define GPIO_GPxDAT_R_INDEX (GPIO_O_GPADAT_R / 2U)

#define GPIO_MUX_TO_GMUX (GPIO_O_GPAGMUX1 - GPIO_O_GPAMUX1)

#ifndef DOXYGEN_PDF_IGNORE

//*****************************************************************************

//

// 可传递给GPIO_setPadConfig()的引脚类型参数及GPIO_getPadConfig()返回值

//

//*****************************************************************************

#define GPIO_PIN_TYPE_STD 0x0000U //!< 推挽输出或浮空输入

#define GPIO_PIN_TYPE_PULLUP 0x0001U //!< 输入上拉使能

#define GPIO_PIN_TYPE_INVERT 0x0002U //!< 输入极性反转

#define GPIO_PIN_TYPE_OD 0x0004U //!< 开漏输出

#endif

//*****************************************************************************

//

//! 可传递给GPIO_setDirectionMode()的方向模式参数及GPIO_getDirectionMode()返回值

//

//*****************************************************************************

typedef enum

{

GPIO_DIR_MODE_IN, //!< 引脚配置为GPIO输入

GPIO_DIR_MODE_OUT //!< 引脚配置为GPIO输出

} GPIO_Direction;

//*****************************************************************************

//

//! 可传递给GPIO_setInterruptType()的中断类型参数及GPIO_getInterruptType()返回值

//

//*****************************************************************************

typedef enum

{

GPIO_INT_TYPE_FALLING_EDGE = 0x00, //!< 下降沿中断

GPIO_INT_TYPE_RISING_EDGE = 0x04, //!< 上升沿中断

GPIO_INT_TYPE_BOTH_EDGES = 0x0C //!< 双沿中断

} GPIO_IntType;

//*****************************************************************************

//

//! 可传递给GPIO_setQualificationMode()的滤波模式参数及返回值

//

//*****************************************************************************

typedef enum

{

GPIO_QUAL_SYNC, //!< 同步SYSCLK

GPIO_QUAL_3SAMPLE, //!< 3采样滤波

GPIO_QUAL_6SAMPLE, //!< 6采样滤波

GPIO_QUAL_ASYNC //!< 无同步

} GPIO_QualificationMode;

//*****************************************************************************

//

//! 可传递给GPIO_setAnalogMode()的模拟模式参数

//

//*****************************************************************************

typedef enum

{

GPIO_ANALOG_DISABLED, //!< 数字模式

GPIO_ANALOG_ENABLED //!< 模拟模式

} GPIO_AnalogMode;

//*****************************************************************************

//

//! 可传递给GPIO_setControllerCore()的核心选择参数

//

//*****************************************************************************

typedef enum

{

GPIO_CORE_CPU1, //!< 选择CPU1作为控制核心

GPIO_CORE_CPU1_CLA1 //!< 选择CPU1的CLA1作为控制核心

} GPIO_CoreSelect;

//*****************************************************************************

//

//! 可传递给端口操作函数的端口标识

//

//*****************************************************************************

typedef enum

{

GPIO_PORT_A = 0, //!< GPIO端口A

GPIO_PORT_B = 1, //!< GPIO端口B

GPIO_PORT_C = 2, //!< GPIO端口C

GPIO_PORT_G = 6, //!< GPIO端口G

GPIO_PORT_H = 7, //!< GPIO端口H

} GPIO_Port;

//*****************************************************************************

//

//! 外部中断编号(用于相关中断函数参数)

//

//*****************************************************************************

typedef enum

{

GPIO_INT_XINT1, //!< 外部中断1

GPIO_INT_XINT2, //!< 外部中断2

GPIO_INT_XINT3, //!< 外部中断3

GPIO_INT_XINT4, //!< 外部中断4

GPIO_INT_XINT5 //!< 外部中断5

} GPIO_ExternalIntNum;

//*****************************************************************************

//

// API函数原型

//

//*****************************************************************************

//*****************************************************************************

//

//! \internal

//! 检查引脚编号是否有效

//!

//! 注意:此函数反映设备最大封装下的最高GPIO编号。

//! 具体封装的有效引脚范围请参考数据手册。

//!

//! \return 布尔值表示引脚是否有效

//

//*****************************************************************************

#ifdef DEBUG

static inline bool

GPIO_isPinValid(uint32_t pin)

{

return((pin <= 81U) || ((pin >= 208U) && (pin <= 215U)) ||

((pin >= 224U) && (pin <= 253U) && (pin != 243U) &&

(pin != 246U) && (pin != 250U)));

}

#endif

//*****************************************************************************

//

//! 设置指定外部中断的触发类型

//!

//! \param extIntNum 外部中断编号

//! \param intType 中断触发类型

//!

//! 此函数为指定外部中断配置触发机制:

//! - GPIO_INT_TYPE_FALLING_EDGE 下降沿触发

//! - GPIO_INT_TYPE_RISING_EDGE 上升沿触发

//! - GPIO_INT_TYPE_BOTH_EDGES 双沿触发

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_setInterruptType(GPIO_ExternalIntNum extIntNum, GPIO_IntType intType)

{

HWREGH(XINT_BASE + (uint16_t)extIntNum) =

(HWREGH(XINT_BASE + (uint16_t)extIntNum) & ~XINT_1CR_POLARITY_M) |

(uint16_t)intType;

}

//*****************************************************************************

//

//! 获取外部中断的触发类型

//!

//! \param extIntNum 外部中断编号

//!

//! \return 返回GPIO_setInterruptType()描述的枚举值之一

//

//*****************************************************************************

static inline GPIO_IntType

GPIO_getInterruptType(GPIO_ExternalIntNum extIntNum)

{

return((GPIO_IntType)((uint16_t)(HWREGH(XINT_BASE + (uint16_t)extIntNum) &

XINT_1CR_POLARITY_M)));

}

//*****************************************************************************

//

//! 使能指定外部中断

//!

//! \param extIntNum 外部中断编号

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_enableInterrupt(GPIO_ExternalIntNum extIntNum)

{

HWREGH(XINT_BASE + (uint16_t)extIntNum) |= XINT_1CR_ENABLE;

}

//*****************************************************************************

//

//! 禁用指定外部中断

//!

//! \param extIntNum 外部中断编号

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_disableInterrupt(GPIO_ExternalIntNum extIntNum)

{

HWREGH(XINT_BASE + (uint16_t)extIntNum) &= ~XINT_1CR_ENABLE;

}

//*****************************************************************************

//

//! 获取外部中断计数器值

//!

//! \param extIntNum 外部中断编号

//!

//! 注意:计数器以SYSCLKOUT速率时钟

//!

//! \return 返回外部中断计数器值

//

//*****************************************************************************

static inline uint16_t

GPIO_getInterruptCounter(GPIO_ExternalIntNum extIntNum)

{

ASSERT(extIntNum <= GPIO_INT_XINT3);

return((HWREGH(XINT_BASE + XINT_O_1CTR + (uint16_t)extIntNum)));

}

//*****************************************************************************

//

//! 读取指定引脚的电平值

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 返回指定引脚的数据寄存器值

//

//*****************************************************************************

static inline uint32_t

GPIO_readPin(uint32_t pin)

{

volatile uint32_t *gpioDataReg;

ASSERT(GPIO_isPinValid(pin));

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((pin / 32U) * GPIO_DATA_REGS_STEP);

return((gpioDataReg[GPIO_GPxDAT_INDEX] >> (pin % 32U)) & (uint32_t)0x1U);

}

//*****************************************************************************

//

//! 读取指定引脚的数据寄存器值

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 返回指定引脚的数据寄存器值

//

//*****************************************************************************

static inline uint32_t

GPIO_readPinDataRegister(uint32_t pin)

{

volatile uint32_t *gpioDataReg;

ASSERT(GPIO_isPinValid(pin));

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATAREAD_BASE) +

((pin / 32U) * GPIO_DATA_READ_REGS_STEP);

return((gpioDataReg[GPIO_GPxDAT_R_INDEX] >> (pin % 32U)) & (uint32_t)0x1U);

}

//*****************************************************************************

//

//! 设置指定引脚的输出值

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param outVal 要写入的值(0或1)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_writePin(uint32_t pin, uint32_t outVal)

{

volatile uint32_t *gpioDataReg;

uint32_t pinMask;

ASSERT(GPIO_isPinValid(pin));

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((pin / 32U) * GPIO_DATA_REGS_STEP);

pinMask = (uint32_t)1U << (pin % 32U);

if(outVal == 0U)

{

gpioDataReg[GPIO_GPxCLEAR_INDEX] = pinMask;

}

else

{

gpioDataReg[GPIO_GPxSET_INDEX] = pinMask;

}

}

//*****************************************************************************

//

//! 翻转指定引脚的电平

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_togglePin(uint32_t pin)

{

volatile uint32_t *gpioDataReg;

ASSERT(GPIO_isPinValid(pin));

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((pin / 32U) * GPIO_DATA_REGS_STEP);

gpioDataReg[GPIO_GPxTOGGLE_INDEX] = (uint32_t)1U << (pin % 32U);

}

//*****************************************************************************

//

//! 读取指定端口的数据

//!

//! \param port 端口标识(如GPIO_PORT_A)

//!

//! \return 返回端口各引脚状态(位0对应引脚0,依此类推)

//

//*****************************************************************************

static inline uint32_t

GPIO_readPortData(GPIO_Port port)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((uint32_t)port * GPIO_DATA_REGS_STEP);

return(gpioDataReg[GPIO_GPxDAT_INDEX]);

}

//*****************************************************************************

//

//! 读取指定端口的数据寄存器值

//!

//! \param port 端口标识(如GPIO_PORT_A)

//!

//! \return 返回端口数据寄存器值(位0对应引脚0,依此类推)

//

//*****************************************************************************

static inline uint32_t

GPIO_readPortDataRegister(GPIO_Port port)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATAREAD_BASE) +

((uint32_t)port * GPIO_DATA_READ_REGS_STEP);

return(gpioDataReg[GPIO_GPxDAT_R_INDEX]);

}

//*****************************************************************************

//

//! 设置指定端口的输出值

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param outVal 要写入的值(位0对应引脚0,依此类推)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_writePortData(GPIO_Port port, uint32_t outVal)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((uint32_t)port * GPIO_DATA_REGS_STEP);

gpioDataReg[GPIO_GPxDAT_INDEX] = outVal;

}

//*****************************************************************************

//

//! 置位指定端口的引脚

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(置位对应引脚)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_setPortPins(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((uint32_t)port * GPIO_DATA_REGS_STEP);

gpioDataReg[GPIO_GPxSET_INDEX] = pinMask;

}

//*****************************************************************************

//

//! 清除指定端口的引脚

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(清除对应引脚)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_clearPortPins(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((uint32_t)port * GPIO_DATA_REGS_STEP);

gpioDataReg[GPIO_GPxCLEAR_INDEX] = pinMask;

}

//*****************************************************************************

//

//! 翻转指定端口的引脚

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(翻转对应引脚)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_togglePortPins(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIODATA_BASE) +

((uint32_t)port * GPIO_DATA_REGS_STEP);

gpioDataReg[GPIO_GPxTOGGLE_INDEX] = pinMask;

}

//*****************************************************************************

//

//! 锁定指定端口的引脚配置

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(锁定对应引脚)

//!

//! 注意:此函数锁定引脚复用、方向等配置寄存器,不影响引脚值修改

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_lockPortConfig(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIOCTRL_BASE) +

((uint32_t)port * GPIO_CTRL_REGS_STEP);

EALLOW;

gpioDataReg[GPIO_GPxLOCK_INDEX] |= pinMask;

EDIS;

}

//*****************************************************************************

//

//! 解锁指定端口的引脚配置

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(解锁对应引脚)

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_unlockPortConfig(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIOCTRL_BASE) +

((uint32_t)port * GPIO_CTRL_REGS_STEP);

EALLOW;

gpioDataReg[GPIO_GPxLOCK_INDEX] &= ~pinMask;

EDIS;

}

//*****************************************************************************

//

//! 提交锁定配置(永久锁定)

//!

//! \param port 端口标识(如GPIO_PORT_A)

//! \param pinMask 引脚掩码(锁定对应引脚)

//!

//! 注意:调用后GPIO_lockPortConfig()和GPIO_unlockPortConfig()将不再有效

//!

//! \return 无

//

//*****************************************************************************

static inline void

GPIO_commitPortConfig(GPIO_Port port, uint32_t pinMask)

{

volatile uint32_t *gpioDataReg;

gpioDataReg = (uint32_t *)((uintptr_t)GPIOCTRL_BASE) +

((uint32_t)port * GPIO_CTRL_REGS_STEP);

EALLOW;

gpioDataReg[GPIO_GPxCR_INDEX] |= pinMask;

EDIS;

}

//*****************************************************************************

//

//! 设置引脚方向和模式

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param pinIO 方向模式(输入/输出)

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setDirectionMode(uint32_t pin, GPIO_Direction pinIO);

//*****************************************************************************

//

//! 获取引脚方向模式

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 返回GPIO_setDirectionMode()描述的枚举值之一

//

//*****************************************************************************

extern GPIO_Direction

GPIO_getDirectionMode(uint32_t pin);

//*****************************************************************************

//

//! 设置外部中断引脚

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param extIntNum 外部中断编号

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setInterruptPin(uint32_t pin, GPIO_ExternalIntNum extIntNum);

//*****************************************************************************

//

//! 设置引脚电气特性

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param pinType 引脚类型(标准/上拉/开漏/反相等)

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setPadConfig(uint32_t pin, uint32_t pinType);

//*****************************************************************************

//

//! 获取引脚电气特性配置

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 返回GPIO_setPadConfig()描述的位域组合

//

//*****************************************************************************

extern uint32_t

GPIO_getPadConfig(uint32_t pin);

//*****************************************************************************

//

//! 设置引脚输入滤波模式

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param qualification 滤波模式

//!

//! 要设置滤波采样周期,需使用GPIO_setQualificationPeriod()

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setQualificationMode(uint32_t pin, GPIO_QualificationMode qualification);

//*****************************************************************************

//

//! 获取引脚滤波模式

//!

//! \param pin 引脚编号(如GPIO34对应34)

//!

//! \return 返回滤波模式枚举值

//

//*****************************************************************************

extern GPIO_QualificationMode

GPIO_getQualificationMode(uint32_t pin);

//*****************************************************************************

//

//! 设置引脚滤波周期

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param divider 分频系数(1或2-510之间的偶数)

//!

//! 注意:此函数配置8个引脚的共享滤波周期寄存器

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setQualificationPeriod(uint32_t pin, uint32_t divider);

//*****************************************************************************

//

//! 设置引脚控制核心

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param core 控制核心选择

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setControllerCore(uint32_t pin, GPIO_CoreSelect core);

//*****************************************************************************

//

//! 设置引脚模拟模式

//!

//! \param pin 引脚编号(如GPIO34对应34)

//! \param mode 模拟模式使能/禁用

//!

//! 注意:此参数同时适用于AIO和GPIO

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setAnalogMode(uint32_t pin, GPIO_AnalogMode mode);

//*****************************************************************************

//

//! 配置GPIO引脚的复用功能

//!

//! \param pinConfig 引脚配置值(仅使用GPIO_#_????预定义值)

//!

//! 此函数配置选择外设功能的引脚复用器。每个GPIO引脚同一时间只能关联一个

//! 外设功能,且每个外设功能应只关联一个GPIO引脚(尽管许多外设功能可以

//! 映射到多个GPIO引脚)。

//!

//! 可用映射关系定义在中。

//!

//! \return 无

//

//*****************************************************************************

extern void

GPIO_setPinConfig(uint32_t pinConfig);

//*****************************************************************************

//

// 关闭Doxygen分组

//! @}

//

//*****************************************************************************

//*****************************************************************************

//

// 结束C++编译器的C语言绑定段

//

//*****************************************************************************

#ifdef __cplusplus

}

#endif

#endif // GPIO_H