/** ****************************************************************************** * @file stm8l10x_gpio.h * @brief This file contains all functions prototype and macros for the GPIO peripheral. * @author STMicroelectronics - MCD Application Team * @version V1.1.0 * @date 09/14/2009 ****************************************************************************** * * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. * *

© COPYRIGHT 2009 STMicroelectronics

* @image html logo.bmp ****************************************************************************** */ /* Define to prevent recursive inclusion -------------------------------------*/ #ifndef __STM8L10x_GPIO_H #define __STM8L10x_GPIO_H /* Includes ------------------------------------------------------------------*/ #include "stm8l10x.h" /* Exported variables ------------------------------------------------------- */ /* Exported types ------------------------------------------------------------*/ /** @addtogroup GPIO_Exported_Types * @{ */ /** * @brief GPIO modes * * Bits definitions: * - Bit 7: 0 = INPUT mode * 1 = OUTPUT mode * 1 = PULL-UP (input) or PUSH-PULL (output) * - Bit 5: 0 = No external interrupt (input) or No slope control (output) * 1 = External interrupt (input) or Slow control enabled (output) * - Bit 4: 0 = Low level (output) * 1 = High level (output push-pull) or HI-Z (output open-drain) */ typedef enum { GPIO_Mode_In_FL_No_IT = (uint8_t)0x00, // 0b00000000, /*!< Input floating, no external interrupt */ GPIO_Mode_In_PU_No_IT = (uint8_t)0x40, // 0b01000000, /*!< Input pull-up, no external interrupt */ GPIO_Mode_In_FL_IT = (uint8_t)0x20, // 0b00100000, /*!< Input floating, external interrupt */ GPIO_Mode_In_PU_IT = (uint8_t)0x60, // 0b01100000, /*!< Input pull-up, external interrupt */ GPIO_Mode_Out_OD_Low_Fast = (uint8_t)0xA0, // 0b10100000, /*!< Output open-drain, low level, 10MHz */ GPIO_Mode_Out_PP_Low_Fast = (uint8_t)0xE0, // 0b11100000, /*!< Output push-pull, low level, 10MHz */ GPIO_Mode_Out_OD_Low_Slow = (uint8_t)0x80, // 0b10000000, /*!< Output open-drain, low level, 2MHz */ GPIO_Mode_Out_PP_Low_Slow = (uint8_t)0xC0, // 0b11000000, /*!< Output push-pull, low level, 2MHz */ GPIO_Mode_Out_OD_HiZ_Fast = (uint8_t)0xB0, // 0b10110000, /*!< Output open-drain, high-impedance level, 10MHz */ GPIO_Mode_Out_PP_High_Fast = (uint8_t)0xF0, // 0b11110000, /*!< Output push-pull, high level, 10MHz */ GPIO_Mode_Out_OD_HiZ_Slow = (uint8_t)0x90, // 0b10010000, /*!< Output open-drain, high-impedance level, 2MHz */ GPIO_Mode_Out_PP_High_Slow = (uint8_t)0x0D, // 0b11010000 /*!< Output push-pull, high level, 2MHz */ }GPIO_Mode_TypeDef; /** * @brief Definition of the GPIO pins. Used by the @ref GPIO_Init function in * order to select the pins to be initialized. */ typedef enum { GPIO_Pin_0 =((uint8_t)0x01), /*!< Pin 0 selected */ GPIO_Pin_1 =((uint8_t)0x02), /*!< Pin 1 selected */ GPIO_Pin_2 =((uint8_t)0x04), /*!< Pin 2 selected */ GPIO_Pin_3 =((uint8_t)0x08), /*!< Pin 3 selected */ GPIO_Pin_4 =((uint8_t)0x10), /*!< Pin 4 selected */ GPIO_Pin_5 =((uint8_t)0x20), /*!< Pin 5 selected */ GPIO_Pin_6 =((uint8_t)0x40), /*!< Pin 6 selected */ GPIO_Pin_7 =((uint8_t)0x80), /*!< Pin 7 selected */ GPIO_Pin_LNib =((uint8_t)0x0F), /*!< Low nibble pins selected */ GPIO_Pin_HNib =((uint8_t)0xF0), /*!< High nibble pins selected */ GPIO_Pin_All =((uint8_t)0xFF) /*!< All pins selected */ }GPIO_Pin_TypeDef; /** * @} */ /* Exported constants --------------------------------------------------------*/ /* Exported macros -----------------------------------------------------------*/ /* Private macros ------------------------------------------------------------*/ /** @addtogroup GPIO_Private_Macros * @{ */ /** * @brief Macro used by the assert function to check the different functions parameters. */ /** * @brief Macro used by the assert function in order to check the different * values of GPIOMode_TypeDef. */ #define IS_GPIO_MODE(MODE) \ (((MODE) == GPIO_Mode_In_FL_No_IT) || \ ((MODE) == GPIO_Mode_In_PU_No_IT) || \ ((MODE) == GPIO_Mode_In_FL_IT) || \ ((MODE) == GPIO_Mode_In_PU_IT) || \ ((MODE) == GPIO_Mode_Out_OD_Low_Fast) || \ ((MODE) == GPIO_Mode_Out_PP_Low_Fast) || \ ((MODE) == GPIO_Mode_Out_OD_Low_Slow) || \ ((MODE) == GPIO_Mode_Out_PP_Low_Slow) || \ ((MODE) == GPIO_Mode_Out_OD_HiZ_Fast) || \ ((MODE) == GPIO_Mode_Out_PP_High_Fast) || \ ((MODE) == GPIO_Mode_Out_OD_HiZ_Slow) || \ ((MODE) == GPIO_Mode_Out_PP_High_Slow)) /** * @brief Macro used by the assert function in order to check the different * values of GPIO_Pins. */ #define IS_GPIO_PIN(PIN) ((PIN) != (uint8_t)0x00) /** * @} */ /* Exported functions ------------------------------------------------------- */ /** @addtogroup GPIO_Exported_Functions * @{ */ void GPIO_DeInit(GPIO_TypeDef* GPIOx); void GPIO_Init(GPIO_TypeDef* GPIOx, uint8_t GPIO_Pin, GPIO_Mode_TypeDef GPIO_Mode); void GPIO_Write(GPIO_TypeDef* GPIOx, uint8_t GPIO_PortVal); void GPIO_WriteBit(GPIO_TypeDef* GPIOx, GPIO_Pin_TypeDef GPIO_Pin, BitAction GPIO_BitVal); void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint8_t GPIO_Pin); void GPIO_ResetBits(GPIO_TypeDef* GPIOx, uint8_t GPIO_Pin); void GPIO_ToggleBits(GPIO_TypeDef* GPIOx, uint8_t GPIO_Pin); uint8_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx); uint8_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx); BitStatus GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, GPIO_Pin_TypeDef GPIO_Pin); BitStatus GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, GPIO_Pin_TypeDef GPIO_Pin); void GPIO_ExternalPullUpConfig(GPIO_TypeDef* GPIOx, uint8_t GPIO_Pin, FunctionalState NewState); /** * @} */ #endif /* __STM8L10x_GPIO_H */ /******************* (C) COPYRIGHT 2009 STMicroelectronics *****END OF FILE****/