4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-28 10:01:03 +08:00
2021-09-07 10:45:38 +08:00

1228 lines
73 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*******************************************************************************
* Copyright (C) 2018, Huada Semiconductor Co.,Ltd All rights reserved.
*
* This software is owned and published by:
* Huada Semiconductor Co.,Ltd ("HDSC").
*
* BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
* BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
*
* This software contains source code for use with HDSC
* components. This software is licensed by HDSC to be adapted only
* for use in systems utilizing HDSC components. HDSC shall not be
* responsible for misuse or illegal use of this software for devices not
* supported herein. HDSC is providing this software "AS IS" and will
* not be responsible for issues arising from incorrect user implementation
* of the software.
*
* Disclaimer:
* HDSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
* REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
* ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
* WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
* WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
* WARRANTY OF NONINFRINGEMENT.
* HDSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
* NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
* LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
* LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
* INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
* SAVINGS OR PROFITS,
* EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
* YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
* INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
* FROM, THE SOFTWARE.
*
* This software may be replicated in part or whole for the licensed use,
* with the restriction that this Disclaimer and Copyright notice must be
* included with each copy of this software, whether used in part or whole,
* at all times.
*/
/******************************************************************************/
/** \file gpio.h
**
** GPIO driver
** @link GPIO Group Some description @endlink
**
** - 2018-04-18
**
******************************************************************************/
#ifndef __GPIO_H__
#define __GPIO_H__
/*******************************************************************************
* Include files
******************************************************************************/
#include "hc32l196_ddl.h"
/* C binding of definitions if building with C++ compiler */
#ifdef __cplusplus
extern "C"
{
#endif
/**
*******************************************************************************
** \defgroup GpioGroup General Purpose I/O (GPIO)
**
**
******************************************************************************/
//@{
#define GPIO_GPSZ (0x40u)
/*******************************************************************************
* Global type definitions
******************************************************************************/
/**
*******************************************************************************
** \brief GPIO PORT类型定义
******************************************************************************/
typedef enum en_gpio_port
{
GpioPortA = 0x00u, ///< GPIO PORT A
GpioPortB = 0x40u, ///< GPIO PORT B
GpioPortC = 0x80u, ///< GPIO PORT C
GpioPortD = 0xc0u, ///< GPIO PORT D
GpioPortE = 0x1000u, ///< GPIO PORT E
GpioPortF = 0x1040u, ///< GPIO PORT F
}en_gpio_port_t;
/**
*******************************************************************************
** \brief GPIO PIN类型定义
******************************************************************************/
typedef enum en_gpio_pin
{
GpioPin0 = 0u, ///< GPIO PIN0
GpioPin1 = 1u, ///< GPIO PIN1
GpioPin2 = 2u, ///< GPIO PIN2
GpioPin3 = 3u, ///< GPIO PIN3
GpioPin4 = 4u, ///< GPIO PIN4
GpioPin5 = 5u, ///< GPIO PIN5
GpioPin6 = 6u, ///< GPIO PIN6
GpioPin7 = 7u, ///< GPIO PIN7
GpioPin8 = 8u, ///< GPIO PIN8
GpioPin9 = 9u, ///< GPIO PIN9
GpioPin10 = 10u, ///< GPIO PIN10
GpioPin11 = 11u, ///< GPIO PIN11
GpioPin12 = 12u, ///< GPIO PIN12
GpioPin13 = 13u, ///< GPIO PIN13
GpioPin14 = 14u, ///< GPIO PIN14
GpioPin15 = 15u, ///< GPIO PIN15
}en_gpio_pin_t;
/**
*******************************************************************************
** \brief GPIO 端口复用功能(AF-Alternate function)类型定义
** \note 具体功能及含义请参考用户手册GPIO复用表或下表
******************************************************************************/
typedef enum en_gpio_af
{
GpioAf0 = 0u, ///< GPIO功能
GpioAf1 = 1u, ///< GPIO AF1:复用功能1
GpioAf2 = 2u, ///< GPIO AF2:复用功能2
GpioAf3 = 3u, ///< GPIO AF3:复用功能3
GpioAf4 = 4u, ///< GPIO AF4:复用功能4
GpioAf5 = 5u, ///< GPIO AF5:复用功能5
GpioAf6 = 6u, ///< GPIO AF6:复用功能6
GpioAf7 = 7u, ///< GPIO AF7:复用功能7
}en_gpio_af_t;
///*||======||=============||=============||=============||=============||=============||=============||=============||*///
///*||PSEL || GpioAf1 || GpioAf2 || GpioAf3 || GpioAf4 || GpioAf5 || GpioAf6 || GpioAf7 ||*///
///*||======||=============||=============||=============||=============||=============||=============||=============||*///
///*||PA00 ||UART1_CTS ||LPUART1_TXD ||TIM0_ETR ||VC0_OUT ||TIM1_CHA ||TIM3_ETR ||TIM0_CHA ||*///
///*||PA01 ||UART1_RTS ||LPUART1_RXD ||TIM0_CHB ||TIM1_ETR ||TIM1_CHB ||HCLK_OUT ||SPI1_MOSI ||*///
///*||PA02 ||UART1_TXD ||TIM0_CHA ||VC1_OUT ||TIM1_CHA ||TIM2_CHA ||PCLK_OUT ||SPI1_MISO ||*///
///*||PA03 ||UART1_RXD ||TIM0_GATE ||TIM1_CHB ||TIM2_CHB ||SPI1_CS ||TIM3_CH1A ||TIM5_CHA ||*///
///*||PA04 ||SPI0_CS ||UART1_TXD ||PCA_CH4 ||TIM2_ETR ||TIM5_CHA ||LVD_OUT ||TIM3_CH2B ||*///
///*||PA05 ||SPI0_SCK ||TIM0_ETR ||PCA_ECI ||TIM0_CHA ||TIM5_CHB ||XTL_OUT ||XTH_OUT ||*///
///*||PA06 ||SPI0_MISO ||PCA_CH0 ||TIM3_BK ||TIM1_CHA ||VC0_OUT ||TIM3_GATE ||LPUART0_CTS ||*///
///*||PA07 ||SPI0_MOSI ||PCA_CH1 ||HCLK_OUT ||TIM3_CH0B ||TIM2_CHA ||VC1_OUT ||TIM4_CHB ||*///
///*||PA08 ||UART0_TXD ||TIM3_CH0A || || ||TIM1_GATE ||TIM4_CHA ||TIM3_BK ||*///
///*||PA09 ||UART0_TXD ||TIM3_CH1A ||TIM0_BK ||I2C0_SCL || ||HCLK_OUT ||TIM5_CHA ||*///
///*||PA10 ||UART0_RXD ||TIM3_CH2A ||TIM2_BK ||I2C0_SDA ||TIM2_GATE ||PCLK_OUT ||TIM6_CHA ||*///
///*||PA11 ||UART0_CTS ||TIM3_GATE ||I2C1_SCL || ||VC0_OUT ||SPI0_MISO ||TIM4_CHB ||*///
///*||PA12 ||UART0_RTS ||TIM3_ETR ||I2C1_SDA || ||VC1_OUT ||SPI0_MOSI ||PCNT_S0 ||*///
///*||PA13 ||IR_OUT ||UART0_RXD ||LVD_OUT ||TIM3_ETR ||RTC_1HZ ||PCNT_S1 ||VC2_OUT ||*///
///*||PA14 ||UART1_TXD ||UART0_TXD ||TIM3_CH2A ||LVD_OUT ||RCH_OUT ||RCL_OUT ||PLL_OUT ||*///
///*||PA15 ||SPI0_CS ||UART1_RXD ||LPUART1_RTS ||TIM0_ETR ||TIM0_CHA ||TIM3_CH1A || ||*///
///*||PB00 ||PCA_CH2 ||TIM3_CH1B ||LPUART0_TXD ||TIM5_CHB ||RCH_OUT ||RCL_OUT ||PLL_OUT ||*///
///*||PB01 ||PCA_CH3 ||PCLK_OUT ||TIM3_CH2B ||TIM6_CHB ||LPUART0_RTS ||VC2_OUT ||TCLK_OUT  ||*///
///*||PB02 ||LPTIM_TOG ||PCA_ECI ||LPUART1_TXD ||TIM4_CHA ||TIM1_BK ||TIM0_BK ||TIM2_BK ||*///
///*||PB03 ||SPI0_SCK ||TIM0_CHB ||TIM1_GATE ||TIM3_CH0A ||LPTIM_GATE ||XTL_OUT ||XTH_OUT ||*///
///*||PB04 ||SPI0_MISO ||PCA_CH0 ||TIM2_BK ||UART0_CTS ||TIM2_GATE ||TIM3_CH0B ||LPTIM_ETR ||*///
///*||PB05 ||SPI0_MOSI || ||TIM1_BK ||PCA_CH1 ||LPTIM_GATE ||PCNT_S0 ||UART0_RTS ||*///
///*||PB06 ||I2C0_SCL ||UART0_TXD ||TIM1_CHB ||TIM0_CHA ||LPTIM_ETR ||TIM3_CH0A ||LPTIM_TOG ||*///
///*||PB07 ||I2C0_SDA ||UART0_RXD ||TIM2_CHB ||LPUART1_CTS ||TIM0_CHB ||LPTIM_TOGN ||PCNT_S1 ||*///
///*||PB08 ||I2C0_SCL ||TIM1_CHA || ||TIM2_CHA ||TIM0_GATE ||TIM3_CH2A ||UART0_TXD ||*///
///*||PB09 ||I2C0_SDA ||IR_OUT ||SPI1_CS ||TIM2_CHA || ||TIM2_CHB ||UART0_RXD ||*///
///*||PB10 ||I2C1_SCL ||SPI1_SCK ||TIM1_CHA ||LPUART0_TXD ||TIM3_CH1A ||LPUART1_RTS ||UART1_RTS ||*///
///*||PB11 ||I2C1_SDA ||TIM1_CHB ||LPUART0_RXD ||TIM2_GATE ||TIM6_CHA ||LPUART1_CTS ||UART1_CTS ||*///
///*||PB12 ||SPI1_CS ||TIM3_BK ||LPUART0_TXD ||TIM0_BK || ||LPUART0_RTS ||TIM6_CHA ||*///
///*||PB13 ||SPI1_SCK ||I2C1_SCL ||TIM3_CH0B ||LPUART0_CTS ||TIM1_CHA ||TIM1_GATE ||TIM6_CHB ||*///
///*||PB14 ||SPI1_MISO ||I2C1_SDA ||TIM3_CH1B ||TIM0_CHA ||RTC_1HZ ||LPUART0_RTS ||TIM1_BK ||*///
///*||PB15 ||SPI1_MOSI ||TIM3_CH2B ||TIM0_CHB ||TIM0_GATE || || ||LPUART1_RXD ||*///
///*||PC00 ||LPTIM_GATE ||PCNT_S0 ||UART1_CTS ||UART2_RTS || || || ||*///
///*||PC01 ||LPTIM_TOG ||TIM5_CHB ||UART1_RTS ||PCNT_S0FO || ||UART2_CTS || ||*///
///*||PC02 ||SPI1_MISO ||LPTIM_TOGN ||PCNT_S1 ||UART2_RXD || || || ||*///
///*||PC03 ||SPI1_MOSI ||LPTIM_ETR ||LPTIM_TOGN ||PCNT_S1FO ||UART2_TXD || || ||*///
///*||PC04 ||LPUART0_TXD ||TIM2_ETR ||IR_OUT ||VC2_OUT || || || ||*///
///*||PC05 ||LPUART0_RXD ||TIM6_CHB ||PCA_CH4 || || || || ||*///
///*||PC06 ||PCA_CH0 ||TIM4_CHA ||TIM2_CHA ||LPTIM1_GATE || ||UART3_RXD || ||*///
///*||PC07 ||PCA_CH1 ||TIM5_CHA ||TIM2_CHB ||LPTIM1_ETR || ||UART3_TXD || ||*///
///*||PC08 ||PCA_CH2 ||TIM6_CHA ||TIM2_ETR ||LPTIM1_TOG || ||UART3_CTS || ||*///
///*||PC09 ||PCA_CH3 ||TIM4_CHB ||TIM1_ETR ||LPTIM1_TOGN || ||UART3_RTS || ||*///
///*||PC10 ||LPUART1_TXD ||LPUART0_TXD ||PCA_CH2 || || || || ||*///
///*||PC11 ||LPUART1_RXD ||LPUART0_RXD ||PCA_CH3 ||PCNT_S0FO || || || ||*///
///*||PC12 ||LPUART0_TXD ||LPUART1_TXD ||PCA_CH4 ||PCNT_S1FO || || || ||*///
///*||PC13 || ||RTC_1HZ ||TIM3_CH1B || || || || ||*///
///*||PC14 || || || || || || || ||*///
///*||PC15 || || || || || || || ||*///
///*||PD00 || ||SPI1_CS || || || || || ||*///
///*||PD01 || ||SPI1_SCK || || || || || ||*///
///*||PD02 ||PCA_ECI ||LPUART0_RTS ||TIM1_ETR || || || || ||*///
///*||PD03 ||UART1_CTS ||SPI1_MISO ||LPTIM1_TOG || || || || ||*///
///*||PD04 ||UART1_RTS ||SPI1_MOSI ||LPTIM1_TOGN || || || || ||*///
///*||PD05 ||UART1_TXD ||LPTIM1_GATE || || || || || ||*///
///*||PD06 ||UART1_RXD ||LPTIM1_ETR || || || || || ||*///
///*||PD07 ||UART1_TXD || || || || || || ||*///
///*||PD08 ||LPUART0_TXD || || || || || || ||*///
///*||PD09 ||LPUART0_RXD || || || || || || ||*///
///*||PD10 ||LPUART0_TXD || || || || || || ||*///
///*||PD11 ||LPUART0_CTS || || || || || || ||*///
///*||PD12 ||LPUART0_RTS ||UART2_RTS || || || || || ||*///
///*||PD13 ||UART2_RXD || || || || || || ||*///
///*||PD14 ||UART2_TXD || || || || || || ||*///
///*||PD15 || ||UART2_CTS || || || || || ||*///
///*||PE00 ||TIM1_CHA || || || || || || ||*///
///*||PE01 ||TIM2_CHA || || || || || || ||*///
///*||PE02 ||PCA_ECI || || || || || || ||*///
///*||PE03 ||PCA_CH0 || || || || || || ||*///
///*||PE04 ||PCA_CH1 || || || || || || ||*///
///*||PE05 ||PCA_CH2 || || || || || || ||*///
///*||PE06 ||PCA_CH3 || || || || || || ||*///
///*||PE07 ||TIM3_ETR ||LPTIM1_GATE || || || || || ||*///
///*||PE08 ||TIM3_CH0B ||LPTIM1_ETR || || || || || ||*///
///*||PE09 ||TIM3_CH0A ||LPTIM1_TOG || || || || || ||*///
///*||PE10 ||TIM3_CH1B ||LPTIM1_TOGN || || || || || ||*///
///*||PE11 ||TIM3_CH1A || || || || || || ||*///
///*||PE12 ||TIM3_CH2B ||SPI0_CS ||UART3_CTS || || || || ||*///
///*||PE13 ||TIM3_CH2A ||SPI0_SCK ||UART3_RTS || || || || ||*///
///*||PE14 ||TIM3_CH0B ||SPI0_MISO ||UART3_RXD || || || || ||*///
///*||PE15 ||TIM3_BK ||SPI0_MOSI ||UART3_TXD || || || || ||*///
///*||PF00 ||I2C0_SDA || ||UART1_TXD || || || || ||*///
///*||PF01 ||I2C0_SCL ||TIM4_CHB ||UART1_RXD || || || || ||*///
///*||PF02 || || || || || || || ||*///
///*||PF03 || || || || || || || ||*///
///*||PF04 || || || || || || || ||*///
///*||PF05 || || || || || || || ||*///
///*||PF06 ||I2C1_SCL ||LPUART1_CTS ||UART0_CTS || || || || ||*///
///*||PF07 ||I2C1_SDA ||LPUART1_RTS ||UART0_RTS || || || || ||*///
///*||PF09 ||TIM0_CHA || || || || || || ||*///
///*||PF10 ||TIM0_CHB || || || || || || ||*///
///*||PF11 || || || || || || || ||*///
///*||======||=============||=============||=============||=============||=============||=============||=============||*///
/**
*******************************************************************************
** \brief GPIO输入输出配置数据类型定义
******************************************************************************/
typedef enum en_gpio_dir
{
GpioDirOut = 0u, ///< GPIO 输出
GpioDirIn = 1u, ///< GPIO 输入
}en_gpio_dir_t;
/**
*******************************************************************************
** \brief GPIO端口上拉配置数据类型定义
******************************************************************************/
typedef enum en_gpio_pu
{
GpioPuDisable = 0u, ///< GPIO无上拉
GpioPuEnable = 1u, ///< GPIO上拉
}en_gpio_pu_t;
/**
*******************************************************************************
** \brief GPIO端口下拉配置数据类型定义
******************************************************************************/
typedef enum en_gpio_pd
{
GpioPdDisable = 0u, ///< GPIO无下拉
GpioPdEnable = 1u, ///< GPIO下拉
}en_gpio_pd_t;
/**
*******************************************************************************
** \brief GPIO端口输出驱动能力配置数据类型定义
******************************************************************************/
typedef enum en_gpio_drv
{
GpioDrvH = 0u, ///< GPIO高驱动能力
GpioDrvL = 1u, ///< GPIO低驱动能力
}en_gpio_drv_t;
/**
*******************************************************************************
** \brief GPIO端口开漏输出控制数据类型定义
******************************************************************************/
typedef enum en_gpio_od
{
GpioOdDisable = 0u, ///< GPIO开漏输出关闭
GpioOdEnable = 1u, ///< GPIO开漏输出使能
}en_gpio_od_t;
/**
*******************************************************************************
** \brief GPIO端口输入/输出值寄存器总线控制模式选择
******************************************************************************/
typedef enum en_gpio_ctrl_mode
{
GpioFastIO = 0u, ///< FAST IO 总线控制模式
GpioAHB = 1u, ///< AHB 总线控制模式
}en_gpio_ctrl_mode_t;
/**
*******************************************************************************
** \brief GPIO中断触发方式类型定义
******************************************************************************/
typedef enum en_gpio_irqtype
{
GpioIrqHigh = 0u, ///< GPIO高电平触发
GpioIrqLow = 1u, ///< GPIO低电平触发
GpioIrqRising = 2u, ///< GPIO上升沿触发
GpioIrqFalling = 3u, ///< GPIO下降沿触发
}en_gpio_irqtype_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary Function端口中断模式类型定义
******************************************************************************/
typedef enum en_gpio_sf_irqmode
{
GpioSfIrqDpslpMode = 1u, ///< Deep Sleep模式
GpioSfIrqActSlpMode = 0u, ///< Active/Sleep模式
}en_gpio_sf_irqmode_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionHCLK输出门控类型定义
******************************************************************************/
typedef enum en_gpio_sf_hclkout_g
{
GpioSfHclkOutDisable = 0u, ///< HCLK输出门控关闭
GpioSfHclkOutEnable = 1u, ///< HCLK输出门控使能
}en_gpio_sf_hclkout_g_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionHCLK输出分频选择类型定义
******************************************************************************/
typedef enum en_gpio_sf_hclkout_div
{
GpioSfHclkOutDiv1 = 0u, ///< HCLK
GpioSfHclkOutDiv2 = 1u, ///< HCLK/2
GpioSfHclkOutDiv4 = 2u, ///< HCLK/4
GpioSfHclkOutDiv8 = 3u, ///< HCLK/8
}en_gpio_sf_hclkout_div_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionPCLK输出门控类型定义
******************************************************************************/
typedef enum en_gpio_sf_pclkout_g
{
GpioSfPclkOutDisable = 0u, ///< PCLK输出门控关闭
GpioSfPclkOutEnable = 1u, ///< PCLK输出门控使能
}en_gpio_sf_pclkout_g_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionPCLK输出分频选择类型定义
******************************************************************************/
typedef enum en_gpio_sf_pclkout_div
{
GpioSfPclkOutDiv1 = 0u, ///< PCLK
GpioSfPclkOutDiv2 = 1u, ///< PCLK/2
GpioSfPclkOutDiv4 = 2u, ///< PCLK/4
GpioSfPclkOutDiv8 = 3u, ///< PCLK/8
}en_gpio_sf_pclkout_div_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionIR输出极性选择类型定义
******************************************************************************/
typedef enum en_gpio_sf_irpol
{
GpioSfIrP = 0u, ///< IR正向输出
GpioSfIrN = 1u, ///< IR反向输出
}en_gpio_sf_irpol_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionSSN通道类型定义
******************************************************************************/
typedef enum en_gpio_sf_ssnspi
{
GpioSpi0 = 0u, ///< SPI0 SSN
GpioSpi1 = 1u, ///< SPI1 SSN
}en_gpio_sf_ssnspi_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionSSN与外部时钟输入信号源选择类型定义
******************************************************************************/
typedef enum en_gpio_sf_ssn_extclk
{
GpioSfSsnExtClkH = 0u, ///< 高电平
GpioSfSsnExtClkPA03 = 1u, ///< PA03
GpioSfSsnExtClkPA04 = 2u, ///< PA04
GpioSfSsnExtClkPA06 = 3u, ///< PA06
GpioSfSsnExtClkPA08 = 4u, ///< PA08
GpioSfSsnExtClkPA09 = 5u, ///< PA09
GpioSfSsnExtClkPA12 = 6u, ///< PA12
GpioSfSsnExtClkPA15 = 7u, ///< PA15
GpioSfSsnExtClkPB01 = 8u, ///< PB01
GpioSfSsnExtClkPB02 = 9u, ///< PB02
GpioSfSsnExtClkPB05 = 10u, ///< PB05
GpioSfSsnExtClkPB06 = 11u, ///< PB06
GpioSfSsnExtClkPB09 = 12u, ///< PB09
GpioSfSsnExtClkPB10 = 13u, ///< PB10
GpioSfSsnExtClkPB12 = 14u, ///< PB12
GpioSfSsnExtClkPB14 = 15u, ///< PB14
}en_gpio_sf_ssn_extclk_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary Function定时器互联功能选择类型定义
** \note 具体功能及含义请参考用户手册GPIO辅助寄存器描述
******************************************************************************/
typedef enum en_gpio_sf
{
GpioSf0 = 0u, ///< SF0:PX_SEL的配置功能
GpioSf1 = 1u, ///< SF1:辅助功能1
GpioSf2 = 2u, ///< SF2:辅助功能2
GpioSf3 = 3u, ///< SF3:辅助功能3
GpioSf4 = 4u, ///< SF4:辅助功能4
GpioSf5 = 5u, ///< SF5:辅助功能5
GpioSf6 = 6u, ///< SF6:辅助功能6
GpioSf7 = 7u, ///< SF7:辅助功能7
}en_gpio_sf_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary Function定时器门控类型选择数据类型定义
******************************************************************************/
typedef enum en_gpio_sf_tim_g
{
GpioSfTim0G = 0u, ///<Tim0定时器GATE输入选择
GpioSfTim1G = 3u, ///<Tim1定时器GATE输入选择
GpioSfTim2G = 6u, ///<Tim2定时器GATE输入选择
GpioSfTim3G = 9u, ///<Tim3定时器GATE输入选择
GpioSfLpTim0G = 12u, ///<LPTim0定时器GATE输入选择
GpioSfLpTim1G = 38u, ///<LPTim1定时器GATE输入选择
}en_gpio_sf_tim_g_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary Function定时器ETR类型选择数据类型定义
******************************************************************************/
typedef enum en_gpio_sf_tim_e
{
GpioSfTim0E = 0u, ///<Tim0定时器ETR输入选择
GpioSfTim1E = 3u, ///<Tim1定时器ETR输入选择
GpioSfTim2E = 6u, ///<Tim2定时器ETR输入选择
GpioSfTim3E = 9u, ///<Tim3定时器ETR输入选择
GpioSfLpTim0E = 12u, ///<LPTim0定时器ETR输入选择
GpioSfLpTim1E = 41u, ///<LPTim1定时器ETR输入选择
}en_gpio_sf_tim_e_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary Function定时器捕获输入类型选择数据类型定义
******************************************************************************/
typedef enum en_gpio_sf_tim_c
{
GpioSfTim0CA = 0u, ///<Tim0定时器CHA输入选择
GpioSfTim1CA = 3u, ///<Tim1定时器CHA输入选择
GpioSfTim2CA = 6u, ///<Tim2定时器CHA输入选择
GpioSfTim3CA = 9u, ///<Tim3定时器CH0A输入选择
GpioSfTim3CB = 12u, ///<Tim3定时器CH0B输入选择
}en_gpio_sf_tim_c_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionPCA捕获选择数据类型定义
******************************************************************************/
typedef enum en_gpio_sf_pca
{
GpioSfPcaCH0 = 0u, ///<PCA_CH0捕获口输入选择
GpioSfPcaECI = 3u, ///<PCA ECI时钟输入选择
}en_gpio_sf_pca_t;
/**
*******************************************************************************
** \brief GPIO 辅助功能SF-Secondary FunctionPCNT脉冲输入选择数据类型定义
******************************************************************************/
typedef enum en_gpio_sf_pcnt
{
GpioSfPcntS0 = 0u, ///<PCNT_S0输入选择
GpioSfPcntS1 = 3u, ///<PCNT_S1输入选择
}en_gpio_sf_pcnt_t;
/**
*******************************************************************************
** \brief GPIO 端口配置结构体定义
******************************************************************************/
typedef struct
{
boolean_t bOutputVal; ///< 默认端口输出电平
en_gpio_dir_t enDir; ///< 端口方向配置
en_gpio_drv_t enDrv; ///< 端口驱动能力配置
en_gpio_pu_t enPu; ///< 端口上拉配置
en_gpio_pd_t enPd; ///< 端口下拉配置
en_gpio_od_t enOD; ///< 端口开漏输出配置
en_gpio_ctrl_mode_t enCtrlMode; ///< 端口输入/输出值寄存器总线控制模式配置
}stc_gpio_cfg_t;
/*******************************************************************************
* Global definitions——(GPIO 复用功能宏定义)
******************************************************************************/
///< GPIO 复用功能宏定义
///< GpioAf1
#define PA00_UART1_CTS (GpioPortA<<16u|GpioPin0 <<8u|GpioAf1)
#define PA01_UART1_RTS (GpioPortA<<16u|GpioPin1 <<8u|GpioAf1)
#define PA02_UART1_TXD (GpioPortA<<16u|GpioPin2 <<8u|GpioAf1)
#define PA03_UART1_RXD (GpioPortA<<16u|GpioPin3 <<8u|GpioAf1)
#define PA04_SPI0_CS (GpioPortA<<16u|GpioPin4 <<8u|GpioAf1)
#define PA05_SPI0_SCK (GpioPortA<<16u|GpioPin5 <<8u|GpioAf1)
#define PA06_SPI0_MISO (GpioPortA<<16u|GpioPin6 <<8u|GpioAf1)
#define PA07_SPI0_MOSI (GpioPortA<<16u|GpioPin7 <<8u|GpioAf1)
#define PA08_UART0_TXD (GpioPortA<<16u|GpioPin8 <<8u|GpioAf1)
#define PA09_UART0_TXD (GpioPortA<<16u|GpioPin9 <<8u|GpioAf1)
#define PA10_UART0_RXD (GpioPortA<<16u|GpioPin10<<8u|GpioAf1)
#define PA11_UART0_CTS (GpioPortA<<16u|GpioPin11<<8u|GpioAf1)
#define PA12_UART0_RTS (GpioPortA<<16u|GpioPin12<<8u|GpioAf1)
#define PA13_IR_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf1)
#define PA14_UART1_TXD (GpioPortA<<16u|GpioPin14<<8u|GpioAf1)
#define PA15_SPI0_CS (GpioPortA<<16u|GpioPin15<<8u|GpioAf1)
#define PB00_PCA_CH2 (GpioPortB<<16u|GpioPin0 <<8u|GpioAf1)
#define PB01_PCA_CH3 (GpioPortB<<16u|GpioPin1 <<8u|GpioAf1)
#define PB02_LPTIM_TOG (GpioPortB<<16u|GpioPin2 <<8u|GpioAf1)
#define PB03_SPI0_SCK (GpioPortB<<16u|GpioPin3 <<8u|GpioAf1)
#define PB04_SPI0_MISO (GpioPortB<<16u|GpioPin4 <<8u|GpioAf1)
#define PB05_SPI0_MOSI (GpioPortB<<16u|GpioPin5 <<8u|GpioAf1)
#define PB06_I2C0_SCL (GpioPortB<<16u|GpioPin6 <<8u|GpioAf1)
#define PB07_I2C0_SDA (GpioPortB<<16u|GpioPin7 <<8u|GpioAf1)
#define PB08_I2C0_SCL (GpioPortB<<16u|GpioPin8 <<8u|GpioAf1)
#define PB09_I2C0_SDA (GpioPortB<<16u|GpioPin9 <<8u|GpioAf1)
#define PB10_I2C1_SCL (GpioPortB<<16u|GpioPin10<<8u|GpioAf1)
#define PB11_I2C1_SDA (GpioPortB<<16u|GpioPin11<<8u|GpioAf1)
#define PB12_SPI1_CS (GpioPortB<<16u|GpioPin12<<8u|GpioAf1)
#define PB13_SPI1_SCK (GpioPortB<<16u|GpioPin13<<8u|GpioAf1)
#define PB14_SPI1_MISO (GpioPortB<<16u|GpioPin14<<8u|GpioAf1)
#define PB15_SPI1_MOSI (GpioPortB<<16u|GpioPin15<<8u|GpioAf1)
#define PC00_LPTIM_GATE (GpioPortC<<16u|GpioPin0 <<8u|GpioAf1)
#define PC01_LPTIM_TOG (GpioPortC<<16u|GpioPin1 <<8u|GpioAf1)
#define PC02_SPI1_MISO (GpioPortC<<16u|GpioPin2 <<8u|GpioAf1)
#define PC03_SPI1_MOSI (GpioPortC<<16u|GpioPin3 <<8u|GpioAf1)
#define PC04_LPUART0_TXD (GpioPortC<<16u|GpioPin4 <<8u|GpioAf1)
#define PC05_LPUART0_RXD (GpioPortC<<16u|GpioPin5 <<8u|GpioAf1)
#define PC06_PCA_CH0 (GpioPortC<<16u|GpioPin6 <<8u|GpioAf1)
#define PC07_PCA_CH1 (GpioPortC<<16u|GpioPin7 <<8u|GpioAf1)
#define PC08_PCA_CH2 (GpioPortC<<16u|GpioPin8 <<8u|GpioAf1)
#define PC09_PCA_CH3 (GpioPortC<<16u|GpioPin9 <<8u|GpioAf1)
#define PC10_LPUART1_TXD (GpioPortC<<16u|GpioPin10<<8u|GpioAf1)
#define PC11_LPUART1_RXD (GpioPortC<<16u|GpioPin11<<8u|GpioAf1)
#define PC12_LPUART0_TXD (GpioPortC<<16u|GpioPin12<<8u|GpioAf1)
#define PC13_1x (GpioPortC<<16u|GpioPin13<<8u|GpioAf1)
#define PC14_1x (GpioPortC<<16u|GpioPin14<<8u|GpioAf1)
#define PC15_1x (GpioPortC<<16u|GpioPin15<<8u|GpioAf1)
#define PD00_1x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf1)
#define PD01_1x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf1)
#define PD02_PCA_ECI (GpioPortD<<16u|GpioPin2 <<8u|GpioAf1)
#define PD03_UART1_CTS (GpioPortD<<16u|GpioPin3 <<8u|GpioAf1)
#define PD04_UART1_RTS (GpioPortD<<16u|GpioPin4 <<8u|GpioAf1)
#define PD05_UART1_TXD (GpioPortD<<16u|GpioPin5 <<8u|GpioAf1)
#define PD06_UART1_RXD (GpioPortD<<16u|GpioPin6 <<8u|GpioAf1)
#define PD07_UART1_TXD (GpioPortD<<16u|GpioPin7 <<8u|GpioAf1)
#define PD08_LPUART0_TXD (GpioPortD<<16u|GpioPin8 <<8u|GpioAf1)
#define PD09_LPUART0_RXD (GpioPortD<<16u|GpioPin9 <<8u|GpioAf1)
#define PD10_LPUART0_TXD (GpioPortD<<16u|GpioPin10<<8u|GpioAf1)
#define PD11_LPUART0_CTS (GpioPortD<<16u|GpioPin11<<8u|GpioAf1)
#define PD12_LPUART0_RTS (GpioPortD<<16u|GpioPin12<<8u|GpioAf1)
#define PD13_UART2_RXD (GpioPortD<<16u|GpioPin13<<8u|GpioAf1)
#define PD14_UART2_TXD (GpioPortD<<16u|GpioPin14<<8u|GpioAf1)
#define PD15_1x (GpioPortD<<16u|GpioPin15<<8u|GpioAf1)
#define PE00_TIM1_CHA (GpioPortE<<16u|GpioPin0 <<8u|GpioAf1)
#define PE01_TIM2_CHA (GpioPortE<<16u|GpioPin1 <<8u|GpioAf1)
#define PE02_PCA_ECI (GpioPortE<<16u|GpioPin2 <<8u|GpioAf1)
#define PE03_PCA_CH0 (GpioPortE<<16u|GpioPin3 <<8u|GpioAf1)
#define PE04_PCA_CH1 (GpioPortE<<16u|GpioPin4 <<8u|GpioAf1)
#define PE05_PCA_CH2 (GpioPortE<<16u|GpioPin5 <<8u|GpioAf1)
#define PE06_PCA_CH3 (GpioPortE<<16u|GpioPin6 <<8u|GpioAf1)
#define PE07_TIM3_ETR (GpioPortE<<16u|GpioPin7 <<8u|GpioAf1)
#define PE08_TIM3_CH0B (GpioPortE<<16u|GpioPin8 <<8u|GpioAf1)
#define PE09_TIM3_CH0A (GpioPortE<<16u|GpioPin9 <<8u|GpioAf1)
#define PE10_TIM3_CH1B (GpioPortE<<16u|GpioPin10<<8u|GpioAf1)
#define PE11_TIM3_CH1A (GpioPortE<<16u|GpioPin11<<8u|GpioAf1)
#define PE12_TIM3_CH2B (GpioPortE<<16u|GpioPin12<<8u|GpioAf1)
#define PE13_TIM3_CH2A (GpioPortE<<16u|GpioPin13<<8u|GpioAf1)
#define PE14_TIM3_CH0B (GpioPortE<<16u|GpioPin14<<8u|GpioAf1)
#define PE15_TIM3_BK (GpioPortE<<16u|GpioPin15<<8u|GpioAf1)
#define PF00_I2C0_SDA (GpioPortF<<16u|GpioPin0 <<8u|GpioAf1)
#define PF01_I2C0_SCL (GpioPortF<<16u|GpioPin1 <<8u|GpioAf1)
#define PF02_1x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf1)
#define PF03_1x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf1)
#define PF04_1x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf1)
#define PF05_1x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf1)
#define PF06_I2C1_SCL (GpioPortF<<16u|GpioPin6 <<8u|GpioAf1)
#define PF07_I2C1_SDA (GpioPortF<<16u|GpioPin7 <<8u|GpioAf1)
#define PF09_TIM0_CHA (GpioPortF<<16u|GpioPin9 <<8u|GpioAf1)
#define PF10_TIM0_CHB (GpioPortF<<16u|GpioPin10<<8u|GpioAf1)
#define PF11_1x (GpioPortF<<16u|GpioPin11<<8u|GpioAf1)
///< GpioAf2
#define PA00_LPUART1_TXD (GpioPortA<<16u|GpioPin0 <<8u|GpioAf2)
#define PA01_LPUART1_RXD (GpioPortA<<16u|GpioPin1 <<8u|GpioAf2)
#define PA02_TIM0_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf2)
#define PA03_TIM0_GATE (GpioPortA<<16u|GpioPin3 <<8u|GpioAf2)
#define PA04_UART1_TXD (GpioPortA<<16u|GpioPin4 <<8u|GpioAf2)
#define PA05_TIM0_ETR (GpioPortA<<16u|GpioPin5 <<8u|GpioAf2)
#define PA06_PCA_CH0 (GpioPortA<<16u|GpioPin6 <<8u|GpioAf2)
#define PA07_PCA_CH1 (GpioPortA<<16u|GpioPin7 <<8u|GpioAf2)
#define PA08_TIM3_CH0A (GpioPortA<<16u|GpioPin8 <<8u|GpioAf2)
#define PA09_TIM3_CH1A (GpioPortA<<16u|GpioPin9 <<8u|GpioAf2)
#define PA10_TIM3_CH2A (GpioPortA<<16u|GpioPin10<<8u|GpioAf2)
#define PA11_TIM3_GATE (GpioPortA<<16u|GpioPin11<<8u|GpioAf2)
#define PA12_TIM3_ETR (GpioPortA<<16u|GpioPin12<<8u|GpioAf2)
#define PA13_UART0_RXD (GpioPortA<<16u|GpioPin13<<8u|GpioAf2)
#define PA14_UART0_TXD (GpioPortA<<16u|GpioPin14<<8u|GpioAf2)
#define PA15_UART1_RXD (GpioPortA<<16u|GpioPin15<<8u|GpioAf2)
#define PB00_TIM3_CH1B (GpioPortB<<16u|GpioPin0 <<8u|GpioAf2)
#define PB01_PCLK_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf2)
#define PB02_PCA_ECI (GpioPortB<<16u|GpioPin2 <<8u|GpioAf2)
#define PB03_TIM0_CHB (GpioPortB<<16u|GpioPin3 <<8u|GpioAf2)
#define PB04_PCA_CH0 (GpioPortB<<16u|GpioPin4 <<8u|GpioAf2)
#define PB05_2x (GpioPortB<<16u|GpioPin5 <<8u|GpioAf2)
#define PB06_UART0_TXD (GpioPortB<<16u|GpioPin6 <<8u|GpioAf2)
#define PB07_UART0_RXD (GpioPortB<<16u|GpioPin7 <<8u|GpioAf2)
#define PB08_TIM1_CHA (GpioPortB<<16u|GpioPin8 <<8u|GpioAf2)
#define PB09_IR_OUT (GpioPortB<<16u|GpioPin9 <<8u|GpioAf2)
#define PB10_SPI1_SCK (GpioPortB<<16u|GpioPin10<<8u|GpioAf2)
#define PB11_TIM1_CHB (GpioPortB<<16u|GpioPin11<<8u|GpioAf2)
#define PB12_TIM3_BK (GpioPortB<<16u|GpioPin12<<8u|GpioAf2)
#define PB13_I2C1_SCL (GpioPortB<<16u|GpioPin13<<8u|GpioAf2)
#define PB14_I2C1_SDA (GpioPortB<<16u|GpioPin14<<8u|GpioAf2)
#define PB15_TIM3_CH2B (GpioPortB<<16u|GpioPin15<<8u|GpioAf2)
#define PC00_PCNT_S0 (GpioPortC<<16u|GpioPin0 <<8u|GpioAf2)
#define PC01_TIM5_CHB (GpioPortC<<16u|GpioPin1 <<8u|GpioAf2)
#define PC02_LPTIM_TOGN (GpioPortC<<16u|GpioPin2 <<8u|GpioAf2)
#define PC03_LPTIM_ETR (GpioPortC<<16u|GpioPin3 <<8u|GpioAf2)
#define PC04_TIM2_ETR (GpioPortC<<16u|GpioPin4 <<8u|GpioAf2)
#define PC05_TIM6_CHB (GpioPortC<<16u|GpioPin5 <<8u|GpioAf2)
#define PC06_TIM4_CHA (GpioPortC<<16u|GpioPin6 <<8u|GpioAf2)
#define PC07_TIM5_CHA (GpioPortC<<16u|GpioPin7 <<8u|GpioAf2)
#define PC08_TIM6_CHA (GpioPortC<<16u|GpioPin8 <<8u|GpioAf2)
#define PC09_TIM4_CHB (GpioPortC<<16u|GpioPin9 <<8u|GpioAf2)
#define PC10_LPUART0_TXD (GpioPortC<<16u|GpioPin10<<8u|GpioAf2)
#define PC11_LPUART0_RXD (GpioPortC<<16u|GpioPin11<<8u|GpioAf2)
#define PC12_LPUART1_TXD (GpioPortC<<16u|GpioPin12<<8u|GpioAf2)
#define PC13_RTC_1HZ (GpioPortC<<16u|GpioPin13<<8u|GpioAf2)
#define PC14_2x (GpioPortC<<16u|GpioPin14<<8u|GpioAf2)
#define PC15_2x (GpioPortC<<16u|GpioPin15<<8u|GpioAf2)
#define PD00_SPI1_CS (GpioPortD<<16u|GpioPin0 <<8u|GpioAf2)
#define PD01_SPI1_SCK (GpioPortD<<16u|GpioPin1 <<8u|GpioAf2)
#define PD02_LPUART0_RTS (GpioPortD<<16u|GpioPin2 <<8u|GpioAf2)
#define PD03_SPI1_MISO (GpioPortD<<16u|GpioPin3 <<8u|GpioAf2)
#define PD04_SPI1_MOSI (GpioPortD<<16u|GpioPin4 <<8u|GpioAf2)
#define PD05_LPTIM1_GATE (GpioPortD<<16u|GpioPin5 <<8u|GpioAf2)
#define PD06_LPTIM1_ETR (GpioPortD<<16u|GpioPin6 <<8u|GpioAf2)
#define PD07_2x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf2)
#define PD08_2x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf2)
#define PD09_2x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf2)
#define PD10_2x (GpioPortD<<16u|GpioPin10<<8u|GpioAf2)
#define PD11_2x (GpioPortD<<16u|GpioPin11<<8u|GpioAf2)
#define PD12_UART2_RTS (GpioPortD<<16u|GpioPin12<<8u|GpioAf2)
#define PD13_2x (GpioPortD<<16u|GpioPin13<<8u|GpioAf2)
#define PD14_2x (GpioPortD<<16u|GpioPin14<<8u|GpioAf2)
#define PD15_UART2_CTS (GpioPortD<<16u|GpioPin15<<8u|GpioAf2)
#define PE00_2x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf2)
#define PE01_2x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf2)
#define PE02_2x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf2)
#define PE03_2x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf2)
#define PE04_2x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf2)
#define PE05_2x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf2)
#define PE06_2x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf2)
#define PE07_LPTIM1_GATE (GpioPortE<<16u|GpioPin7 <<8u|GpioAf2)
#define PE08_LPTIM1_ETR (GpioPortE<<16u|GpioPin8 <<8u|GpioAf2)
#define PE09_LPTIM1_TOG (GpioPortE<<16u|GpioPin9 <<8u|GpioAf2)
#define PE10_LPTIM1_TOGN (GpioPortE<<16u|GpioPin10<<8u|GpioAf2)
#define PE11_2x (GpioPortE<<16u|GpioPin11<<8u|GpioAf2)
#define PE12_SPI0_CS (GpioPortE<<16u|GpioPin12<<8u|GpioAf2)
#define PE13_SPI0_SCK (GpioPortE<<16u|GpioPin13<<8u|GpioAf2)
#define PE14_SPI0_MISO (GpioPortE<<16u|GpioPin14<<8u|GpioAf2)
#define PE15_SPI0_MOSI (GpioPortE<<16u|GpioPin15<<8u|GpioAf2)
#define PF00_2x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf2)
#define PF01_TIM4_CHB (GpioPortF<<16u|GpioPin1 <<8u|GpioAf2)
#define PF02_2x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf2)
#define PF03_2x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf2)
#define PF04_2x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf2)
#define PF05_2x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf2)
#define PF06_LPUART1_CTS (GpioPortF<<16u|GpioPin6 <<8u|GpioAf2)
#define PF07_LPUART1_RTS (GpioPortF<<16u|GpioPin7 <<8u|GpioAf2)
#define PF09_2x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf2)
#define PF10_2x (GpioPortF<<16u|GpioPin10<<8u|GpioAf2)
#define PF11_2x (GpioPortF<<16u|GpioPin11<<8u|GpioAf2)
///< GpioAf3
#define PA00_TIM0_ETR (GpioPortA<<16u|GpioPin0 <<8u|GpioAf3)
#define PA01_TIM0_CHB (GpioPortA<<16u|GpioPin1 <<8u|GpioAf3)
#define PA02_VC1_OUT (GpioPortA<<16u|GpioPin2 <<8u|GpioAf3)
#define PA03_TIM1_CHB (GpioPortA<<16u|GpioPin3 <<8u|GpioAf3)
#define PA04_PCA_CH4 (GpioPortA<<16u|GpioPin4 <<8u|GpioAf3)
#define PA05_PCA_ECI (GpioPortA<<16u|GpioPin5 <<8u|GpioAf3)
#define PA06_TIM3_BK (GpioPortA<<16u|GpioPin6 <<8u|GpioAf3)
#define PA07_HCLK_OUT (GpioPortA<<16u|GpioPin7 <<8u|GpioAf3)
#define PA08_3x (GpioPortA<<16u|GpioPin8 <<8u|GpioAf3)
#define PA09_TIM0_BK (GpioPortA<<16u|GpioPin9 <<8u|GpioAf3)
#define PA10_TIM2_BK (GpioPortA<<16u|GpioPin10<<8u|GpioAf3)
#define PA11_I2C1_SCL (GpioPortA<<16u|GpioPin11<<8u|GpioAf3)
#define PA12_I2C1_SDA (GpioPortA<<16u|GpioPin12<<8u|GpioAf3)
#define PA13_LVD_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf3)
#define PA14_TIM3_CH2A (GpioPortA<<16u|GpioPin14<<8u|GpioAf3)
#define PA15_LPUART1_RTS (GpioPortA<<16u|GpioPin15<<8u|GpioAf3)
#define PB00_LPUART0_TXD (GpioPortB<<16u|GpioPin0 <<8u|GpioAf3)
#define PB01_TIM3_CH2B (GpioPortB<<16u|GpioPin1 <<8u|GpioAf3)
#define PB02_LPUART1_TXD (GpioPortB<<16u|GpioPin2 <<8u|GpioAf3)
#define PB03_TIM1_GATE (GpioPortB<<16u|GpioPin3 <<8u|GpioAf3)
#define PB04_TIM2_BK (GpioPortB<<16u|GpioPin4 <<8u|GpioAf3)
#define PB05_TIM1_BK (GpioPortB<<16u|GpioPin5 <<8u|GpioAf3)
#define PB06_TIM1_CHB (GpioPortB<<16u|GpioPin6 <<8u|GpioAf3)
#define PB07_TIM2_CHB (GpioPortB<<16u|GpioPin7 <<8u|GpioAf3)
#define PB08_3x (GpioPortB<<16u|GpioPin8 <<8u|GpioAf3)
#define PB09_SPI1_CS (GpioPortB<<16u|GpioPin9 <<8u|GpioAf3)
#define PB10_TIM1_CHA (GpioPortB<<16u|GpioPin10<<8u|GpioAf3)
#define PB11_LPUART0_RXD (GpioPortB<<16u|GpioPin11<<8u|GpioAf3)
#define PB12_LPUART0_TXD (GpioPortB<<16u|GpioPin12<<8u|GpioAf3)
#define PB13_TIM3_CH0B (GpioPortB<<16u|GpioPin13<<8u|GpioAf3)
#define PB14_TIM3_CH1B (GpioPortB<<16u|GpioPin14<<8u|GpioAf3)
#define PB15_TIM0_CHB (GpioPortB<<16u|GpioPin15<<8u|GpioAf3)
#define PC00_UART1_CTS (GpioPortC<<16u|GpioPin0 <<8u|GpioAf3)
#define PC01_UART1_RTS (GpioPortC<<16u|GpioPin1 <<8u|GpioAf3)
#define PC02_PCNT_S1 (GpioPortC<<16u|GpioPin2 <<8u|GpioAf3)
#define PC03_LPTIM_TOGN (GpioPortC<<16u|GpioPin3 <<8u|GpioAf3)
#define PC04_IR_OUT (GpioPortC<<16u|GpioPin4 <<8u|GpioAf3)
#define PC05_PCA_CH4 (GpioPortC<<16u|GpioPin5 <<8u|GpioAf3)
#define PC06_TIM2_CHA (GpioPortC<<16u|GpioPin6 <<8u|GpioAf3)
#define PC07_TIM2_CHB (GpioPortC<<16u|GpioPin7 <<8u|GpioAf3)
#define PC08_TIM2_ETR (GpioPortC<<16u|GpioPin8 <<8u|GpioAf3)
#define PC09_TIM1_ETR (GpioPortC<<16u|GpioPin9 <<8u|GpioAf3)
#define PC10_PCA_CH2 (GpioPortC<<16u|GpioPin10<<8u|GpioAf3)
#define PC11_PCA_CH3 (GpioPortC<<16u|GpioPin11<<8u|GpioAf3)
#define PC12_PCA_CH4 (GpioPortC<<16u|GpioPin12<<8u|GpioAf3)
#define PC13_TIM3_CH1B (GpioPortC<<16u|GpioPin13<<8u|GpioAf3)
#define PC14_3x (GpioPortC<<16u|GpioPin14<<8u|GpioAf3)
#define PC15_3x (GpioPortC<<16u|GpioPin15<<8u|GpioAf3)
#define PD00_3x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf3)
#define PD01_3x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf3)
#define PD02_TIM1_ETR (GpioPortD<<16u|GpioPin2 <<8u|GpioAf3)
#define PD03_LPTIM1_TOG (GpioPortD<<16u|GpioPin3 <<8u|GpioAf3)
#define PD04_LPTIM1_TOGN (GpioPortD<<16u|GpioPin4 <<8u|GpioAf3)
#define PD05_3x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf3)
#define PD06_3x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf3)
#define PD07_3x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf3)
#define PD08_3x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf3)
#define PD09_3x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf3)
#define PD10_3x (GpioPortD<<16u|GpioPin10<<8u|GpioAf3)
#define PD11_3x (GpioPortD<<16u|GpioPin11<<8u|GpioAf3)
#define PD12_3x (GpioPortD<<16u|GpioPin12<<8u|GpioAf3)
#define PD13_3x (GpioPortD<<16u|GpioPin13<<8u|GpioAf3)
#define PD14_3x (GpioPortD<<16u|GpioPin14<<8u|GpioAf3)
#define PD15_3x (GpioPortD<<16u|GpioPin15<<8u|GpioAf3)
#define PE00_3x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf3)
#define PE01_3x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf3)
#define PE02_3x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf3)
#define PE03_3x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf3)
#define PE04_3x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf3)
#define PE05_3x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf3)
#define PE06_3x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf3)
#define PE07_3x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf3)
#define PE08_3x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf3)
#define PE09_3x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf3)
#define PE10_3x (GpioPortE<<16u|GpioPin10<<8u|GpioAf3)
#define PE11_3x (GpioPortE<<16u|GpioPin11<<8u|GpioAf3)
#define PE12_UART3_CTS (GpioPortE<<16u|GpioPin12<<8u|GpioAf3)
#define PE13_UART3_RTS (GpioPortE<<16u|GpioPin13<<8u|GpioAf3)
#define PE14_UART3_RXD (GpioPortE<<16u|GpioPin14<<8u|GpioAf3)
#define PE15_UART3_TXD (GpioPortE<<16u|GpioPin15<<8u|GpioAf3)
#define PF00_UART1_TXD (GpioPortF<<16u|GpioPin0 <<8u|GpioAf3)
#define PF01_UART1_RXD (GpioPortF<<16u|GpioPin1 <<8u|GpioAf3)
#define PF02_3x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf3)
#define PF03_3x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf3)
#define PF04_3x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf3)
#define PF05_3x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf3)
#define PF06_UART0_CTS (GpioPortF<<16u|GpioPin6 <<8u|GpioAf3)
#define PF07_UART0_RTS (GpioPortF<<16u|GpioPin7 <<8u|GpioAf3)
#define PF09_3x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf3)
#define PF10_3x (GpioPortF<<16u|GpioPin10<<8u|GpioAf3)
#define PF11_3x (GpioPortF<<16u|GpioPin11<<8u|GpioAf3)
///< GpioAf4
#define PA00_VC0_OUT (GpioPortA<<16u|GpioPin0 <<8u|GpioAf4)
#define PA01_TIM1_ETR (GpioPortA<<16u|GpioPin1 <<8u|GpioAf4)
#define PA02_TIM1_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf4)
#define PA03_TIM2_CHB (GpioPortA<<16u|GpioPin3 <<8u|GpioAf4)
#define PA04_TIM2_ETR (GpioPortA<<16u|GpioPin4 <<8u|GpioAf4)
#define PA05_TIM0_CHA (GpioPortA<<16u|GpioPin5 <<8u|GpioAf4)
#define PA06_TIM1_CHA (GpioPortA<<16u|GpioPin6 <<8u|GpioAf4)
#define PA07_TIM3_CH0B (GpioPortA<<16u|GpioPin7 <<8u|GpioAf4)
#define PA08_4x (GpioPortA<<16u|GpioPin8 <<8u|GpioAf4)
#define PA09_I2C0_SCL (GpioPortA<<16u|GpioPin9 <<8u|GpioAf4)
#define PA10_I2C0_SDA (GpioPortA<<16u|GpioPin10<<8u|GpioAf4)
#define PA11_4x (GpioPortA<<16u|GpioPin11<<8u|GpioAf4)
#define PA12_4x (GpioPortA<<16u|GpioPin12<<8u|GpioAf4)
#define PA13_TIM3_ETR (GpioPortA<<16u|GpioPin13<<8u|GpioAf4)
#define PA14_LVD_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf4)
#define PA15_TIM0_ETR (GpioPortA<<16u|GpioPin15<<8u|GpioAf4)
#define PB00_TIM5_CHB (GpioPortB<<16u|GpioPin0 <<8u|GpioAf4)
#define PB01_TIM6_CHB (GpioPortB<<16u|GpioPin1 <<8u|GpioAf4)
#define PB02_TIM4_CHA (GpioPortB<<16u|GpioPin2 <<8u|GpioAf4)
#define PB03_TIM3_CH0A (GpioPortB<<16u|GpioPin3 <<8u|GpioAf4)
#define PB04_UART0_CTS (GpioPortB<<16u|GpioPin4 <<8u|GpioAf4)
#define PB05_PCA_CH1 (GpioPortB<<16u|GpioPin5 <<8u|GpioAf4)
#define PB06_TIM0_CHA (GpioPortB<<16u|GpioPin6 <<8u|GpioAf4)
#define PB07_LPUART1_CTS (GpioPortB<<16u|GpioPin7 <<8u|GpioAf4)
#define PB08_TIM2_CHA (GpioPortB<<16u|GpioPin8 <<8u|GpioAf4)
#define PB09_TIM2_CHA (GpioPortB<<16u|GpioPin9 <<8u|GpioAf4)
#define PB10_LPUART0_TXD (GpioPortB<<16u|GpioPin10<<8u|GpioAf4)
#define PB11_TIM2_GATE (GpioPortB<<16u|GpioPin11<<8u|GpioAf4)
#define PB12_TIM0_BK (GpioPortB<<16u|GpioPin12<<8u|GpioAf4)
#define PB13_LPUART0_CTS (GpioPortB<<16u|GpioPin13<<8u|GpioAf4)
#define PB14_TIM0_CHA (GpioPortB<<16u|GpioPin14<<8u|GpioAf4)
#define PB15_TIM0_GATE (GpioPortB<<16u|GpioPin15<<8u|GpioAf4)
#define PC00_UART2_RTS (GpioPortC<<16u|GpioPin0 <<8u|GpioAf4)
#define PC01_PCNT_S0FO (GpioPortC<<16u|GpioPin1 <<8u|GpioAf4)
#define PC02_UART2_RXD (GpioPortC<<16u|GpioPin2 <<8u|GpioAf4)
#define PC03_PCNT_S1FO (GpioPortC<<16u|GpioPin3 <<8u|GpioAf4)
#define PC04_VC2_OUT (GpioPortC<<16u|GpioPin4 <<8u|GpioAf4)
#define PC05_4x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf4)
#define PC06_LPTIM1_GATE (GpioPortC<<16u|GpioPin6 <<8u|GpioAf4)
#define PC07_LPTIM1_ETR (GpioPortC<<16u|GpioPin7 <<8u|GpioAf4)
#define PC08_LPTIM1_TOG (GpioPortC<<16u|GpioPin8 <<8u|GpioAf4)
#define PC09_LPTIM1_TOGN (GpioPortC<<16u|GpioPin9 <<8u|GpioAf4)
#define PC10_4x (GpioPortC<<16u|GpioPin10<<8u|GpioAf4)
#define PC11_PCNT_S0FO (GpioPortC<<16u|GpioPin11<<8u|GpioAf4)
#define PC12_PCNT_S1FO (GpioPortC<<16u|GpioPin12<<8u|GpioAf4)
#define PC13_4x (GpioPortC<<16u|GpioPin13<<8u|GpioAf4)
#define PC14_4x (GpioPortC<<16u|GpioPin14<<8u|GpioAf4)
#define PC15_4x (GpioPortC<<16u|GpioPin15<<8u|GpioAf4)
#define PD00_4x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf4)
#define PD01_4x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf4)
#define PD02_4x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf4)
#define PD03_4x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf4)
#define PD04_4x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf4)
#define PD05_4x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf4)
#define PD06_4x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf4)
#define PD07_4x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf4)
#define PD08_4x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf4)
#define PD09_4x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf4)
#define PD10_4x (GpioPortD<<16u|GpioPin10<<8u|GpioAf4)
#define PD11_4x (GpioPortD<<16u|GpioPin11<<8u|GpioAf4)
#define PD12_4x (GpioPortD<<16u|GpioPin12<<8u|GpioAf4)
#define PD13_4x (GpioPortD<<16u|GpioPin13<<8u|GpioAf4)
#define PD14_4x (GpioPortD<<16u|GpioPin14<<8u|GpioAf4)
#define PD15_4x (GpioPortD<<16u|GpioPin15<<8u|GpioAf4)
#define PE00_4x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf4)
#define PE01_4x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf4)
#define PE02_4x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf4)
#define PE03_4x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf4)
#define PE04_4x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf4)
#define PE05_4x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf4)
#define PE06_4x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf4)
#define PE07_4x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf4)
#define PE08_4x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf4)
#define PE09_4x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf4)
#define PE10_4x (GpioPortE<<16u|GpioPin10<<8u|GpioAf4)
#define PE11_4x (GpioPortE<<16u|GpioPin11<<8u|GpioAf4)
#define PE12_4x (GpioPortE<<16u|GpioPin12<<8u|GpioAf4)
#define PE13_4x (GpioPortE<<16u|GpioPin13<<8u|GpioAf4)
#define PE14_4x (GpioPortE<<16u|GpioPin14<<8u|GpioAf4)
#define PE15_4x (GpioPortE<<16u|GpioPin15<<8u|GpioAf4)
#define PF00_4x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf4)
#define PF01_4x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf4)
#define PF02_4x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf4)
#define PF03_4x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf4)
#define PF04_4x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf4)
#define PF05_4x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf4)
#define PF06_4x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf4)
#define PF07_4x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf4)
#define PF09_4x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf4)
#define PF10_4x (GpioPortF<<16u|GpioPin10<<8u|GpioAf4)
#define PF11_4x (GpioPortF<<16u|GpioPin11<<8u|GpioAf4)
///< GpioAf5
#define PA00_TIM1_CHA (GpioPortA<<16u|GpioPin0 <<8u|GpioAf5)
#define PA01_TIM1_CHB (GpioPortA<<16u|GpioPin1 <<8u|GpioAf5)
#define PA02_TIM2_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf5)
#define PA03_SPI1_CS (GpioPortA<<16u|GpioPin3 <<8u|GpioAf5)
#define PA04_TIM5_CHA (GpioPortA<<16u|GpioPin4 <<8u|GpioAf5)
#define PA05_TIM5_CHB (GpioPortA<<16u|GpioPin5 <<8u|GpioAf5)
#define PA06_VC0_OUT (GpioPortA<<16u|GpioPin6 <<8u|GpioAf5)
#define PA07_TIM2_CHA (GpioPortA<<16u|GpioPin7 <<8u|GpioAf5)
#define PA08_TIM1_GATE (GpioPortA<<16u|GpioPin8 <<8u|GpioAf5)
#define PA09_5x (GpioPortA<<16u|GpioPin9 <<8u|GpioAf5)
#define PA10_TIM2_GATE (GpioPortA<<16u|GpioPin10<<8u|GpioAf5)
#define PA11_VC0_OUT (GpioPortA<<16u|GpioPin11<<8u|GpioAf5)
#define PA12_VC1_OUT (GpioPortA<<16u|GpioPin12<<8u|GpioAf5)
#define PA13_RTC_1HZ (GpioPortA<<16u|GpioPin13<<8u|GpioAf5)
#define PA14_RCH_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf5)
#define PA15_TIM0_CHA (GpioPortA<<16u|GpioPin15<<8u|GpioAf5)
#define PB00_RCH_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf5)
#define PB01_LPUART0_RTS (GpioPortB<<16u|GpioPin1 <<8u|GpioAf5)
#define PB02_TIM1_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf5)
#define PB03_LPTIM_GATE (GpioPortB<<16u|GpioPin3 <<8u|GpioAf5)
#define PB04_TIM2_GATE (GpioPortB<<16u|GpioPin4 <<8u|GpioAf5)
#define PB05_LPTIM_GATE (GpioPortB<<16u|GpioPin5 <<8u|GpioAf5)
#define PB06_LPTIM_ETR (GpioPortB<<16u|GpioPin6 <<8u|GpioAf5)
#define PB07_TIM0_CHB (GpioPortB<<16u|GpioPin7 <<8u|GpioAf5)
#define PB08_TIM0_GATE (GpioPortB<<16u|GpioPin8 <<8u|GpioAf5)
#define PB09_5x (GpioPortB<<16u|GpioPin9 <<8u|GpioAf5)
#define PB10_TIM3_CH1A (GpioPortB<<16u|GpioPin10<<8u|GpioAf5)
#define PB11_TIM6_CHA (GpioPortB<<16u|GpioPin11<<8u|GpioAf5)
#define PB12_5x (GpioPortB<<16u|GpioPin12<<8u|GpioAf5)
#define PB13_TIM1_CHA (GpioPortB<<16u|GpioPin13<<8u|GpioAf5)
#define PB14_RTC_1HZ (GpioPortB<<16u|GpioPin14<<8u|GpioAf5)
#define PB15_5x (GpioPortB<<16u|GpioPin15<<8u|GpioAf5)
#define PC00_5x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf5)
#define PC01_5x (GpioPortC<<16u|GpioPin1 <<8u|GpioAf5)
#define PC02_5x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf5)
#define PC03_UART2_TXD (GpioPortC<<16u|GpioPin3 <<8u|GpioAf5)
#define PC04_5x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf5)
#define PC05_5x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf5)
#define PC06_5x (GpioPortC<<16u|GpioPin6 <<8u|GpioAf5)
#define PC07_5x (GpioPortC<<16u|GpioPin7 <<8u|GpioAf5)
#define PC08_5x (GpioPortC<<16u|GpioPin8 <<8u|GpioAf5)
#define PC09_5x (GpioPortC<<16u|GpioPin9 <<8u|GpioAf5)
#define PC10_5x (GpioPortC<<16u|GpioPin10<<8u|GpioAf5)
#define PC11_5x (GpioPortC<<16u|GpioPin11<<8u|GpioAf5)
#define PC12_5x (GpioPortC<<16u|GpioPin12<<8u|GpioAf5)
#define PC13_5x (GpioPortC<<16u|GpioPin13<<8u|GpioAf5)
#define PC14_5x (GpioPortC<<16u|GpioPin14<<8u|GpioAf5)
#define PC15_5x (GpioPortC<<16u|GpioPin15<<8u|GpioAf5)
#define PD00_5x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf5)
#define PD01_5x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf5)
#define PD02_5x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf5)
#define PD03_5x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf5)
#define PD04_5x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf5)
#define PD05_5x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf5)
#define PD06_5x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf5)
#define PD07_5x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf5)
#define PD08_5x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf5)
#define PD09_5x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf5)
#define PD10_5x (GpioPortD<<16u|GpioPin10<<8u|GpioAf5)
#define PD11_5x (GpioPortD<<16u|GpioPin11<<8u|GpioAf5)
#define PD12_5x (GpioPortD<<16u|GpioPin12<<8u|GpioAf5)
#define PD13_5x (GpioPortD<<16u|GpioPin13<<8u|GpioAf5)
#define PD14_5x (GpioPortD<<16u|GpioPin14<<8u|GpioAf5)
#define PD15_5x (GpioPortD<<16u|GpioPin15<<8u|GpioAf5)
#define PE00_5x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf5)
#define PE01_5x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf5)
#define PE02_5x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf5)
#define PE03_5x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf5)
#define PE04_5x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf5)
#define PE05_5x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf5)
#define PE06_5x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf5)
#define PE07_5x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf5)
#define PE08_5x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf5)
#define PE09_5x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf5)
#define PE10_5x (GpioPortE<<16u|GpioPin10<<8u|GpioAf5)
#define PE11_5x (GpioPortE<<16u|GpioPin11<<8u|GpioAf5)
#define PE12_5x (GpioPortE<<16u|GpioPin12<<8u|GpioAf5)
#define PE13_5x (GpioPortE<<16u|GpioPin13<<8u|GpioAf5)
#define PE14_5x (GpioPortE<<16u|GpioPin14<<8u|GpioAf5)
#define PE15_5x (GpioPortE<<16u|GpioPin15<<8u|GpioAf5)
#define PF00_5x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf5)
#define PF01_5x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf5)
#define PF02_5x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf5)
#define PF03_5x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf5)
#define PF04_5x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf5)
#define PF05_5x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf5)
#define PF06_5x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf5)
#define PF07_5x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf5)
#define PF09_5x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf5)
#define PF10_5x (GpioPortF<<16u|GpioPin10<<8u|GpioAf5)
#define PF11_5x (GpioPortF<<16u|GpioPin11<<8u|GpioAf5)
///< GpioAf6
#define PA00_TIM3_ETR (GpioPortA<<16u|GpioPin0 <<8u|GpioAf6)
#define PA01_HCLK_OUT (GpioPortA<<16u|GpioPin1 <<8u|GpioAf6)
#define PA02_PCLK_OUT (GpioPortA<<16u|GpioPin2 <<8u|GpioAf6)
#define PA03_TIM3_CH1A (GpioPortA<<16u|GpioPin3 <<8u|GpioAf6)
#define PA04_LVD_OUT (GpioPortA<<16u|GpioPin4 <<8u|GpioAf6)
#define PA05_XTL_OUT (GpioPortA<<16u|GpioPin5 <<8u|GpioAf6)
#define PA06_TIM3_GATE (GpioPortA<<16u|GpioPin6 <<8u|GpioAf6)
#define PA07_VC1_OUT (GpioPortA<<16u|GpioPin7 <<8u|GpioAf6)
#define PA08_TIM4_CHA (GpioPortA<<16u|GpioPin8 <<8u|GpioAf6)
#define PA09_HCLK_OUT (GpioPortA<<16u|GpioPin9 <<8u|GpioAf6)
#define PA10_PCLK_OUT (GpioPortA<<16u|GpioPin10<<8u|GpioAf6)
#define PA11_SPI0_MISO (GpioPortA<<16u|GpioPin11<<8u|GpioAf6)
#define PA12_SPI0_MOSI (GpioPortA<<16u|GpioPin12<<8u|GpioAf6)
#define PA13_PCNT_S1 (GpioPortA<<16u|GpioPin13<<8u|GpioAf6)
#define PA14_RCL_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf6)
#define PA15_TIM3_CH1A (GpioPortA<<16u|GpioPin15<<8u|GpioAf6)
#define PB00_RCL_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf6)
#define PB01_VC2_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf6)
#define PB02_TIM0_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf6)
#define PB03_XTL_OUT (GpioPortB<<16u|GpioPin3 <<8u|GpioAf6)
#define PB04_TIM3_CH0B (GpioPortB<<16u|GpioPin4 <<8u|GpioAf6)
#define PB05_PCNT_S0 (GpioPortB<<16u|GpioPin5 <<8u|GpioAf6)
#define PB06_TIM3_CH0A (GpioPortB<<16u|GpioPin6 <<8u|GpioAf6)
#define PB07_LPTIM_TOGN (GpioPortB<<16u|GpioPin7 <<8u|GpioAf6)
#define PB08_TIM3_CH2A (GpioPortB<<16u|GpioPin8 <<8u|GpioAf6)
#define PB09_TIM2_CHB (GpioPortB<<16u|GpioPin9 <<8u|GpioAf6)
#define PB10_LPUART1_RTS (GpioPortB<<16u|GpioPin10<<8u|GpioAf6)
#define PB11_LPUART1_CTS (GpioPortB<<16u|GpioPin11<<8u|GpioAf6)
#define PB12_LPUART0_RTS (GpioPortB<<16u|GpioPin12<<8u|GpioAf6)
#define PB13_TIM1_GATE (GpioPortB<<16u|GpioPin13<<8u|GpioAf6)
#define PB14_LPUART0_RTS (GpioPortB<<16u|GpioPin14<<8u|GpioAf6)
#define PB15_6x (GpioPortB<<16u|GpioPin15<<8u|GpioAf6)
#define PC00_6x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf6)
#define PC01_UART2_CTS (GpioPortC<<16u|GpioPin1 <<8u|GpioAf6)
#define PC02_6x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf6)
#define PC03_6x (GpioPortC<<16u|GpioPin3 <<8u|GpioAf6)
#define PC04_6x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf6)
#define PC05_6x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf6)
#define PC06_UART3_RXD (GpioPortC<<16u|GpioPin6 <<8u|GpioAf6)
#define PC07_UART3_TXD (GpioPortC<<16u|GpioPin7 <<8u|GpioAf6)
#define PC08_UART3_CTS (GpioPortC<<16u|GpioPin8 <<8u|GpioAf6)
#define PC09_UART3_RTS (GpioPortC<<16u|GpioPin9 <<8u|GpioAf6)
#define PC10_6x (GpioPortC<<16u|GpioPin10<<8u|GpioAf6)
#define PC11_6x (GpioPortC<<16u|GpioPin11<<8u|GpioAf6)
#define PC12_6x (GpioPortC<<16u|GpioPin12<<8u|GpioAf6)
#define PC13_6x (GpioPortC<<16u|GpioPin13<<8u|GpioAf6)
#define PC14_6x (GpioPortC<<16u|GpioPin14<<8u|GpioAf6)
#define PC15_6x (GpioPortC<<16u|GpioPin15<<8u|GpioAf6)
#define PD00_6x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf6)
#define PD01_6x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf6)
#define PD02_6x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf6)
#define PD03_6x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf6)
#define PD04_6x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf6)
#define PD05_6x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf6)
#define PD06_6x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf6)
#define PD07_6x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf6)
#define PD08_6x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf6)
#define PD09_6x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf6)
#define PD10_6x (GpioPortD<<16u|GpioPin10<<8u|GpioAf6)
#define PD11_6x (GpioPortD<<16u|GpioPin11<<8u|GpioAf6)
#define PD12_6x (GpioPortD<<16u|GpioPin12<<8u|GpioAf6)
#define PD13_6x (GpioPortD<<16u|GpioPin13<<8u|GpioAf6)
#define PD14_6x (GpioPortD<<16u|GpioPin14<<8u|GpioAf6)
#define PD15_6x (GpioPortD<<16u|GpioPin15<<8u|GpioAf6)
#define PE00_6x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf6)
#define PE01_6x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf6)
#define PE02_6x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf6)
#define PE03_6x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf6)
#define PE04_6x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf6)
#define PE05_6x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf6)
#define PE06_6x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf6)
#define PE07_6x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf6)
#define PE08_6x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf6)
#define PE09_6x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf6)
#define PE10_6x (GpioPortE<<16u|GpioPin10<<8u|GpioAf6)
#define PE11_6x (GpioPortE<<16u|GpioPin11<<8u|GpioAf6)
#define PE12_6x (GpioPortE<<16u|GpioPin12<<8u|GpioAf6)
#define PE13_6x (GpioPortE<<16u|GpioPin13<<8u|GpioAf6)
#define PE14_6x (GpioPortE<<16u|GpioPin14<<8u|GpioAf6)
#define PE15_6x (GpioPortE<<16u|GpioPin15<<8u|GpioAf6)
#define PF00_6x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf6)
#define PF01_6x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf6)
#define PF02_6x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf6)
#define PF03_6x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf6)
#define PF04_6x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf6)
#define PF05_6x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf6)
#define PF06_6x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf6)
#define PF07_6x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf6)
#define PF09_6x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf6)
#define PF10_6x (GpioPortF<<16u|GpioPin10<<8u|GpioAf6)
#define PF11_6x (GpioPortF<<16u|GpioPin11<<8u|GpioAf6)
///< GpioAf7
#define PA00_TIM0_CHA (GpioPortA<<16u|GpioPin0 <<8u|GpioAf7)
#define PA01_SPI1_MOSI (GpioPortA<<16u|GpioPin1 <<8u|GpioAf7)
#define PA02_SPI1_MISO (GpioPortA<<16u|GpioPin2 <<8u|GpioAf7)
#define PA03_TIM5_CHA (GpioPortA<<16u|GpioPin3 <<8u|GpioAf7)
#define PA04_TIM3_CH2B (GpioPortA<<16u|GpioPin4 <<8u|GpioAf7)
#define PA05_XTH_OUT (GpioPortA<<16u|GpioPin5 <<8u|GpioAf7)
#define PA06_LPUART0_CTS (GpioPortA<<16u|GpioPin6 <<8u|GpioAf7)
#define PA07_TIM4_CHB (GpioPortA<<16u|GpioPin7 <<8u|GpioAf7)
#define PA08_TIM3_BK (GpioPortA<<16u|GpioPin8 <<8u|GpioAf7)
#define PA09_TIM5_CHA (GpioPortA<<16u|GpioPin9 <<8u|GpioAf7)
#define PA10_TIM6_CHA (GpioPortA<<16u|GpioPin10<<8u|GpioAf7)
#define PA11_TIM4_CHB (GpioPortA<<16u|GpioPin11<<8u|GpioAf7)
#define PA12_PCNT_S0 (GpioPortA<<16u|GpioPin12<<8u|GpioAf7)
#define PA13_VC2_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf7)
#define PA14_PLL_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf7)
#define PA15_7x (GpioPortA<<16u|GpioPin15<<8u|GpioAf7)
#define PB00_PLL_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf7)
#define PB01_TCLK_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf7)
#define PB02_TIM2_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf7)
#define PB03_XTH_OUT (GpioPortB<<16u|GpioPin3 <<8u|GpioAf7)
#define PB04_LPTIM_ETR (GpioPortB<<16u|GpioPin4 <<8u|GpioAf7)
#define PB05_UART0_RTS (GpioPortB<<16u|GpioPin5 <<8u|GpioAf7)
#define PB06_LPTIM_TOG (GpioPortB<<16u|GpioPin6 <<8u|GpioAf7)
#define PB07_PCNT_S1 (GpioPortB<<16u|GpioPin7 <<8u|GpioAf7)
#define PB08_UART0_TXD (GpioPortB<<16u|GpioPin8 <<8u|GpioAf7)
#define PB09_UART0_RXD (GpioPortB<<16u|GpioPin9 <<8u|GpioAf7)
#define PB10_UART1_RTS (GpioPortB<<16u|GpioPin10<<8u|GpioAf7)
#define PB11_UART1_CTS (GpioPortB<<16u|GpioPin11<<8u|GpioAf7)
#define PB12_TIM6_CHA (GpioPortB<<16u|GpioPin12<<8u|GpioAf7)
#define PB13_TIM6_CHB (GpioPortB<<16u|GpioPin13<<8u|GpioAf7)
#define PB14_TIM1_BK (GpioPortB<<16u|GpioPin14<<8u|GpioAf7)
#define PB15_LPUART1_RXD (GpioPortB<<16u|GpioPin15<<8u|GpioAf7)
#define PC00_7x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf7)
#define PC01_7x (GpioPortC<<16u|GpioPin1 <<8u|GpioAf7)
#define PC02_7x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf7)
#define PC03_7x (GpioPortC<<16u|GpioPin3 <<8u|GpioAf7)
#define PC04_7x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf7)
#define PC05_7x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf7)
#define PC06_7x (GpioPortC<<16u|GpioPin6 <<8u|GpioAf7)
#define PC07_7x (GpioPortC<<16u|GpioPin7 <<8u|GpioAf7)
#define PC08_7x (GpioPortC<<16u|GpioPin8 <<8u|GpioAf7)
#define PC09_7x (GpioPortC<<16u|GpioPin9 <<8u|GpioAf7)
#define PC10_7x (GpioPortC<<16u|GpioPin10<<8u|GpioAf7)
#define PC11_7x (GpioPortC<<16u|GpioPin11<<8u|GpioAf7)
#define PC12_7x (GpioPortC<<16u|GpioPin12<<8u|GpioAf7)
#define PC13_7x (GpioPortC<<16u|GpioPin13<<8u|GpioAf7)
#define PC14_7x (GpioPortC<<16u|GpioPin14<<8u|GpioAf7)
#define PC15_7x (GpioPortC<<16u|GpioPin15<<8u|GpioAf7)
#define PD00_7x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf7)
#define PD01_7x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf7)
#define PD02_7x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf7)
#define PD03_7x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf7)
#define PD04_7x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf7)
#define PD05_7x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf7)
#define PD06_7x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf7)
#define PD07_7x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf7)
#define PD08_7x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf7)
#define PD09_7x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf7)
#define PD10_7x (GpioPortD<<16u|GpioPin10<<8u|GpioAf7)
#define PD11_7x (GpioPortD<<16u|GpioPin11<<8u|GpioAf7)
#define PD12_7x (GpioPortD<<16u|GpioPin12<<8u|GpioAf7)
#define PD13_7x (GpioPortD<<16u|GpioPin13<<8u|GpioAf7)
#define PD14_7x (GpioPortD<<16u|GpioPin14<<8u|GpioAf7)
#define PD15_7x (GpioPortD<<16u|GpioPin15<<8u|GpioAf7)
#define PE00_7x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf7)
#define PE01_7x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf7)
#define PE02_7x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf7)
#define PE03_7x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf7)
#define PE04_7x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf7)
#define PE05_7x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf7)
#define PE06_7x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf7)
#define PE07_7x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf7)
#define PE08_7x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf7)
#define PE09_7x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf7)
#define PE10_7x (GpioPortE<<16u|GpioPin10<<8u|GpioAf7)
#define PE11_7x (GpioPortE<<16u|GpioPin11<<8u|GpioAf7)
#define PE12_7x (GpioPortE<<16u|GpioPin12<<8u|GpioAf7)
#define PE13_7x (GpioPortE<<16u|GpioPin13<<8u|GpioAf7)
#define PE14_7x (GpioPortE<<16u|GpioPin14<<8u|GpioAf7)
#define PE15_7x (GpioPortE<<16u|GpioPin15<<8u|GpioAf7)
#define PF00_7x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf7)
#define PF01_7x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf7)
#define PF02_7x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf7)
#define PF03_7x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf7)
#define PF04_7x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf7)
#define PF05_7x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf7)
#define PF06_7x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf7)
#define PF07_7x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf7)
#define PF09_7x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf7)
#define PF10_7x (GpioPortF<<16u|GpioPin10<<8u|GpioAf7)
#define PF11_7x (GpioPortF<<16u|GpioPin11<<8u|GpioAf7)
/******************************************************************************
* Local type definitions ('typedef')
******************************************************************************/
typedef uint32_t GpioPinMux;
/******************************************************************************
* Global variable definitions ('extern')
******************************************************************************/
/******************************************************************************
Global function prototypes (definition in C source)
*******************************************************************************/
///< GPIO IO初始化/去初始化
en_result_t Gpio_Init(en_gpio_port_t enPort, en_gpio_pin_t enPin, stc_gpio_cfg_t *pstcGpioCfg);
///< GPIO 获取端口输入电平
boolean_t Gpio_GetInputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
uint16_t Gpio_GetInputData(en_gpio_port_t enPort);
///< GPIO 设置端口输出
///< GPIO 端口输出电平配置及获取
en_result_t Gpio_WriteOutputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin, boolean_t bVal);
boolean_t Gpio_ReadOutputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 端口/引脚输出电平置位
en_result_t Gpio_SetPort(en_gpio_port_t enPort, uint16_t u16ValMsk);
en_result_t Gpio_SetIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 端口/引脚输出电平清零
en_result_t Gpio_ClrPort(en_gpio_port_t enPort, uint16_t u16ValMsk);
en_result_t Gpio_ClrIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 端口输出电平置位与清零设置
en_result_t Gpio_SetClrPort(en_gpio_port_t enPort, uint32_t u32ValMsk);
///< GPIO 设置端口为模拟功能
en_result_t Gpio_SetAnalogMode(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 设置端口为端口复用功能
en_result_t Gpio_SetAfMode(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_af_t enAf);
void Gpio_SetAfMode_Lite(GpioPinMux PinMux);
///< GPIO 端口中断控制功能使能/关闭
en_result_t Gpio_EnableIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_irqtype_t enType);
en_result_t Gpio_DisableIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_irqtype_t enType);
///< GPIO 中断状态获取
boolean_t Gpio_GetIrqStatus(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 中断标志清除
en_result_t Gpio_ClearIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin);
///< GPIO 端口辅助功能配置
///< GPIO 中断模式配置
en_result_t Gpio_SfIrqModeCfg(en_gpio_sf_irqmode_t enIrqMode);
///< GPIO IR输出极性配置
en_result_t Gpio_SfIrPolCfg(en_gpio_sf_irpol_t enIrPolMode);
///< GPIO HCLK输出配置
en_result_t Gpio_SfHClkOutputCfg(en_gpio_sf_hclkout_g_t enGate, en_gpio_sf_hclkout_div_t enDiv);
///< GPIO PCLK输出配置
en_result_t Gpio_SfPClkOutputCfg(en_gpio_sf_pclkout_g_t enGate, en_gpio_sf_pclkout_div_t enDiv);
///< GPIO 外部时钟输入配置
en_result_t Gpio_SfExtClkCfg(en_gpio_sf_ssn_extclk_t enExtClk);
///< GPIO SPI SSN输入配置
en_result_t Gpio_SfSsnCfg(en_gpio_sf_ssnspi_t enSpi, en_gpio_sf_ssn_extclk_t enSsn);
///< GPIO Timer 门控输入配置
en_result_t Gpio_SfTimGCfg(en_gpio_sf_tim_g_t enTimG, en_gpio_sf_t enSf);
///< GPIO Timer ETR选择配置
en_result_t Gpio_SfTimECfg(en_gpio_sf_tim_e_t enTimE, en_gpio_sf_t enSf);
///< GPIO Timer 捕获输入配置
en_result_t Gpio_SfTimCCfg(en_gpio_sf_tim_c_t enTimC, en_gpio_sf_t enSf);
///< GPIO PCA捕获选择配置
en_result_t Gpio_SfPcaCfg(en_gpio_sf_pca_t enPca, en_gpio_sf_t enSf);
///< GPIO PCNT捕获选择配置
en_result_t Gpio_SfPcntCfg(en_gpio_sf_pcnt_t enPcnt, en_gpio_sf_t enSf);
//@} // GpioGroup
#ifdef __cplusplus
}
#endif
#endif /* __GPIO_H__ */
/******************************************************************************
* EOF (not truncated)
******************************************************************************/