hal_exti.h 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. ////////////////////////////////////////////////////////////////////////////////
  2. /// @file hal_exti.h
  3. /// @author AE TEAM
  4. /// @brief THIS FILE CONTAINS ALL THE FUNCTIONS PROTOTYPES FOR THE EXTI
  5. /// FIRMWARE LIBRARY.
  6. ////////////////////////////////////////////////////////////////////////////////
  7. /// @attention
  8. ///
  9. /// THE EXISTING FIRMWARE IS ONLY FOR REFERENCE, WHICH IS DESIGNED TO PROVIDE
  10. /// CUSTOMERS WITH CODING INFORMATION ABOUT THEIR PRODUCTS SO THEY CAN SAVE
  11. /// TIME. THEREFORE, MINDMOTION SHALL NOT BE LIABLE FOR ANY DIRECT, INDIRECT OR
  12. /// CONSEQUENTIAL DAMAGES ABOUT ANY CLAIMS ARISING OUT OF THE CONTENT OF SUCH
  13. /// HARDWARE AND/OR THE USE OF THE CODING INFORMATION CONTAINED HEREIN IN
  14. /// CONNECTION WITH PRODUCTS MADE BY CUSTOMERS.
  15. ///
  16. /// <H2><CENTER>&COPY; COPYRIGHT MINDMOTION </CENTER></H2>
  17. ////////////////////////////////////////////////////////////////////////////////
  18. // Define to prevent recursive inclusion
  19. #ifndef __HAL_EXTI_H
  20. #define __HAL_EXTI_H
  21. // Files includes
  22. #include "types.h"
  23. #include "reg_common.h"
  24. #include "reg_exti.h"
  25. ////////////////////////////////////////////////////////////////////////////////
  26. /// @addtogroup MM32_Hardware_Abstract_Layer
  27. /// @{
  28. ////////////////////////////////////////////////////////////////////////////////
  29. /// @defgroup EXTI_HAL
  30. /// @brief EXTI HAL modules
  31. /// @{
  32. ////////////////////////////////////////////////////////////////////////////////
  33. /// @defgroup EXTI_Exported_Types
  34. /// @{
  35. ////////////////////////////////////////////////////////////////////////////////
  36. /// @brief EXTI mode enumeration
  37. ////////////////////////////////////////////////////////////////////////////////
  38. typedef enum {
  39. EXTI_Mode_Interrupt = 0x00, ///< EXTI interrupt mode
  40. EXTI_Mode_Event = 0x04 ///< EXTI event mode
  41. } EXTIMode_TypeDef;
  42. ////////////////////////////////////////////////////////////////////////////////
  43. /// @brief EXTI Trigger enumeration
  44. ////////////////////////////////////////////////////////////////////////////////
  45. typedef enum {
  46. EXTI_Trigger_Rising = 0x08, ///< EXTI rising edge triggering
  47. EXTI_Trigger_Falling = 0x0C, ///< EXTI falling edge triggering
  48. EXTI_Trigger_Rising_Falling = 0x10 ///< EXTI rising and falling edge triggers
  49. } EXTITrigger_TypeDef;
  50. ////////////////////////////////////////////////////////////////////////////////
  51. /// @brief EXTI Init Structure definition
  52. ////////////////////////////////////////////////////////////////////////////////
  53. typedef struct {
  54. u32 EXTI_Line; ///< Specifies the EXTI lines to be enabled or disabled.
  55. ///< This parameter can be any combination of @ref EXTI_Lines
  56. EXTIMode_TypeDef EXTI_Mode; ///< Specifies the mode for the EXTI lines.
  57. ///< This parameter can be a value of @ref EXTIMode_TypeDef
  58. EXTITrigger_TypeDef EXTI_Trigger; ///< Specifies the trigger signal active edge for the EXTI lines.
  59. ///< This parameter can be a value of @ref EXTIMode_TypeDef
  60. FunctionalState EXTI_LineCmd; ///< Specifies the new state of the selected EXTI lines.
  61. ///< This parameter can be set either to ENABLE or DISABLE
  62. } EXTI_InitTypeDef;
  63. /// @}
  64. ////////////////////////////////////////////////////////////////////////////////
  65. /// @defgroup EXTI_Exported_Constants
  66. /// @{
  67. #define EXTI_LineNone ((u32)0x0000000) ///< No interrupt selected
  68. #define EXTI_Line0 ((u32)0x0000001) ///< External interrupt line 0
  69. #define EXTI_Line1 ((u32)0x0000002) ///< External interrupt line 1
  70. #define EXTI_Line2 ((u32)0x0000004) ///< External interrupt line 2
  71. #define EXTI_Line3 ((u32)0x0000008) ///< External interrupt line 3
  72. #define EXTI_Line4 ((u32)0x0000010) ///< External interrupt line 4
  73. #define EXTI_Line5 ((u32)0x0000020) ///< External interrupt line 5
  74. #define EXTI_Line6 ((u32)0x0000040) ///< External interrupt line 6
  75. #define EXTI_Line7 ((u32)0x0000080) ///< External interrupt line 7
  76. #define EXTI_Line8 ((u32)0x0000100) ///< External interrupt line 8
  77. #define EXTI_Line9 ((u32)0x0000200) ///< External interrupt line 9
  78. #define EXTI_Line10 ((u32)0x0000400) ///< External interrupt line 10
  79. #define EXTI_Line11 ((u32)0x0000800) ///< External interrupt line 11
  80. #define EXTI_Line12 ((u32)0x0001000) ///< External interrupt line 12
  81. #define EXTI_Line13 ((u32)0x0002000) ///< External interrupt line 13
  82. #define EXTI_Line14 ((u32)0x0004000) ///< External interrupt line 14
  83. #define EXTI_Line15 ((u32)0x0008000) ///< External interrupt line 15
  84. #define EXTI_Line16 ((u32)0x0010000) ///< External interrupt line 16 Connected to the PVD Output
  85. #define EXTI_Line17 ((u32)0x0020000) ///< External interrupt line 17 Connected to the RTC Alarm event
  86. #define EXTI_Line18 ((u32)0x0040000) ///< External interrupt line 18 Connected to the USB Wakeup from suspend event
  87. #define EXTI_Line19 ((u32)0x0080000) ///< External interrupt line 19
  88. #define EXTI_Line20 ((u32)0x0100000) ///< External interrupt line 20
  89. #define EXTI_Line21 ((u32)0x0200000) ///< External interrupt line 21
  90. #define EXTI_Line22 ((u32)0x0400000) ///< External interrupt line 22
  91. #define EXTI_Line23 ((u32)0x0800000) ///< External interrupt line 23
  92. #define EXTI_Line24 ((u32)0x1000000) ///< External interrupt line 24
  93. #define EXTI_PortSourceGPIOA (0x00U)
  94. #define EXTI_PortSourceGPIOB (0x01U)
  95. #define EXTI_PortSourceGPIOC (0x02U)
  96. #define EXTI_PortSourceGPIOD (0x03U)
  97. #define EXTI_PortSourceGPIOE (0x04U)
  98. #define EXTI_PortSourceGPIOF (0x05U)
  99. #define EXTI_PinSource0 (0x00U)
  100. #define EXTI_PinSource1 (0x01U)
  101. #define EXTI_PinSource2 (0x02U)
  102. #define EXTI_PinSource3 (0x03U)
  103. #define EXTI_PinSource4 (0x04U)
  104. #define EXTI_PinSource5 (0x05U)
  105. #define EXTI_PinSource6 (0x06U)
  106. #define EXTI_PinSource7 (0x07U)
  107. #define EXTI_PinSource8 (0x08U)
  108. #define EXTI_PinSource9 (0x09U)
  109. #define EXTI_PinSource10 (0x0AU)
  110. #define EXTI_PinSource11 (0x0BU)
  111. #define EXTI_PinSource12 (0x0CU)
  112. #define EXTI_PinSource13 (0x0DU)
  113. #define EXTI_PinSource14 (0x0EU)
  114. #define EXTI_PinSource15 (0x0FU)
  115. ////////////////////////////////////////////////////////////////////////////////
  116. /// @defgroup EXTI_Exported_Variables
  117. /// @{
  118. #ifdef _HAL_EXTI_C_
  119. #define GLOBAL
  120. #else
  121. #define GLOBAL extern
  122. #endif
  123. #undef GLOBAL
  124. /// @}
  125. ////////////////////////////////////////////////////////////////////////////////
  126. /// @defgroup EXTI_Exported_Functions
  127. /// @{
  128. FlagStatus EXTI_GetFlagStatus(u32 line);
  129. ITStatus EXTI_GetITStatus(u32 line);
  130. void EXTI_DeInit(void);
  131. void EXTI_Init(EXTI_InitTypeDef* init_struct);
  132. void EXTI_StructInit(EXTI_InitTypeDef* init_struct);
  133. void EXTI_GenerateSWInterrupt(u32 line);
  134. void EXTI_ClearFlag(u32 line);
  135. void EXTI_ClearITPendingBit(u32 line);
  136. void exEXTI_LineDisable(u32 line);
  137. u32 exEXTI_GetAllFlagStatus(void);
  138. void EXTI_MemoryRemapConfig(u32 memory_remap);
  139. void EXTI_LineConfig(u8 port_source_gpio, u8 pin_source);
  140. /// @}
  141. /// @}
  142. /// @}
  143. ////////////////////////////////////////////////////////////////////////////////
  144. #endif // __HAL_EXTI_H
  145. ////////////////////////////////////////////////////////////////////////////////