2 ******************************************************************************
3 * @file stm32f4xx_ll_exti.c
4 * @author MCD Application Team
7 * @brief EXTI LL module driver.
8 ******************************************************************************
11 * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
13 * Redistribution and use in source and binary forms, with or without modification,
14 * are permitted provided that the following conditions are met:
15 * 1. Redistributions of source code must retain the above copyright notice,
16 * this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright notice,
18 * this list of conditions and the following disclaimer in the documentation
19 * and/or other materials provided with the distribution.
20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
21 * may be used to endorse or promote products derived from this software
22 * without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 ******************************************************************************
37 #if defined(USE_FULL_LL_DRIVER)
39 /* Includes ------------------------------------------------------------------*/
40 #include "stm32f4xx_ll_exti.h"
41 #ifdef USE_FULL_ASSERT
42 #include "stm32_assert.h"
44 #define assert_param(expr) ((void)0U)
47 /** @addtogroup STM32F4xx_LL_Driver
53 /** @defgroup EXTI_LL EXTI
57 /* Private types -------------------------------------------------------------*/
58 /* Private variables ---------------------------------------------------------*/
59 /* Private constants ---------------------------------------------------------*/
60 /* Private macros ------------------------------------------------------------*/
61 /** @addtogroup EXTI_LL_Private_Macros
65 #define IS_LL_EXTI_LINE_0_31(__VALUE__) (((__VALUE__) & ~LL_EXTI_LINE_ALL_0_31) == 0x00000000U)
67 #define IS_LL_EXTI_MODE(__VALUE__) (((__VALUE__) == LL_EXTI_MODE_IT) \
68 || ((__VALUE__) == LL_EXTI_MODE_EVENT) \
69 || ((__VALUE__) == LL_EXTI_MODE_IT_EVENT))
72 #define IS_LL_EXTI_TRIGGER(__VALUE__) (((__VALUE__) == LL_EXTI_TRIGGER_NONE) \
73 || ((__VALUE__) == LL_EXTI_TRIGGER_RISING) \
74 || ((__VALUE__) == LL_EXTI_TRIGGER_FALLING) \
75 || ((__VALUE__) == LL_EXTI_TRIGGER_RISING_FALLING))
81 /* Private function prototypes -----------------------------------------------*/
83 /* Exported functions --------------------------------------------------------*/
84 /** @addtogroup EXTI_LL_Exported_Functions
88 /** @addtogroup EXTI_LL_EF_Init
93 * @brief De-initialize the EXTI registers to their default reset values.
94 * @retval An ErrorStatus enumeration value:
95 * - SUCCESS: EXTI registers are de-initialized
96 * - ERROR: not applicable
98 uint32_t LL_EXTI_DeInit(void)
100 /* Interrupt mask register set to default reset values */
101 LL_EXTI_WriteReg(IMR
, 0x00000000U
);
102 /* Event mask register set to default reset values */
103 LL_EXTI_WriteReg(EMR
, 0x00000000U
);
104 /* Rising Trigger selection register set to default reset values */
105 LL_EXTI_WriteReg(RTSR
, 0x00000000U
);
106 /* Falling Trigger selection register set to default reset values */
107 LL_EXTI_WriteReg(FTSR
, 0x00000000U
);
108 /* Software interrupt event register set to default reset values */
109 LL_EXTI_WriteReg(SWIER
, 0x00000000U
);
110 /* Pending register set to default reset values */
111 LL_EXTI_WriteReg(PR
, 0x00FFFFFFU
);
117 * @brief Initialize the EXTI registers according to the specified parameters in EXTI_InitStruct.
118 * @param EXTI_InitStruct pointer to a @ref LL_EXTI_InitTypeDef structure.
119 * @retval An ErrorStatus enumeration value:
120 * - SUCCESS: EXTI registers are initialized
121 * - ERROR: not applicable
123 uint32_t LL_EXTI_Init(LL_EXTI_InitTypeDef
*EXTI_InitStruct
)
125 ErrorStatus status
= SUCCESS
;
126 /* Check the parameters */
127 assert_param(IS_LL_EXTI_LINE_0_31(EXTI_InitStruct
->Line_0_31
));
128 assert_param(IS_FUNCTIONAL_STATE(EXTI_InitStruct
->LineCommand
));
129 assert_param(IS_LL_EXTI_MODE(EXTI_InitStruct
->Mode
));
131 /* ENABLE LineCommand */
132 if (EXTI_InitStruct
->LineCommand
!= DISABLE
)
134 assert_param(IS_LL_EXTI_TRIGGER(EXTI_InitStruct
->Trigger
));
136 /* Configure EXTI Lines in range from 0 to 31 */
137 if (EXTI_InitStruct
->Line_0_31
!= LL_EXTI_LINE_NONE
)
139 switch (EXTI_InitStruct
->Mode
)
141 case LL_EXTI_MODE_IT
:
142 /* First Disable Event on provided Lines */
143 LL_EXTI_DisableEvent_0_31(EXTI_InitStruct
->Line_0_31
);
144 /* Then Enable IT on provided Lines */
145 LL_EXTI_EnableIT_0_31(EXTI_InitStruct
->Line_0_31
);
147 case LL_EXTI_MODE_EVENT
:
148 /* First Disable IT on provided Lines */
149 LL_EXTI_DisableIT_0_31(EXTI_InitStruct
->Line_0_31
);
150 /* Then Enable Event on provided Lines */
151 LL_EXTI_EnableEvent_0_31(EXTI_InitStruct
->Line_0_31
);
153 case LL_EXTI_MODE_IT_EVENT
:
154 /* Directly Enable IT & Event on provided Lines */
155 LL_EXTI_EnableIT_0_31(EXTI_InitStruct
->Line_0_31
);
156 LL_EXTI_EnableEvent_0_31(EXTI_InitStruct
->Line_0_31
);
162 if (EXTI_InitStruct
->Trigger
!= LL_EXTI_TRIGGER_NONE
)
164 switch (EXTI_InitStruct
->Trigger
)
166 case LL_EXTI_TRIGGER_RISING
:
167 /* First Disable Falling Trigger on provided Lines */
168 LL_EXTI_DisableFallingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
169 /* Then Enable Rising Trigger on provided Lines */
170 LL_EXTI_EnableRisingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
172 case LL_EXTI_TRIGGER_FALLING
:
173 /* First Disable Rising Trigger on provided Lines */
174 LL_EXTI_DisableRisingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
175 /* Then Enable Falling Trigger on provided Lines */
176 LL_EXTI_EnableFallingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
178 case LL_EXTI_TRIGGER_RISING_FALLING
:
179 LL_EXTI_EnableRisingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
180 LL_EXTI_EnableFallingTrig_0_31(EXTI_InitStruct
->Line_0_31
);
189 /* DISABLE LineCommand */
192 /* De-configure EXTI Lines in range from 0 to 31 */
193 LL_EXTI_DisableIT_0_31(EXTI_InitStruct
->Line_0_31
);
194 LL_EXTI_DisableEvent_0_31(EXTI_InitStruct
->Line_0_31
);
200 * @brief Set each @ref LL_EXTI_InitTypeDef field to default value.
201 * @param EXTI_InitStruct Pointer to a @ref LL_EXTI_InitTypeDef structure.
204 void LL_EXTI_StructInit(LL_EXTI_InitTypeDef
*EXTI_InitStruct
)
206 EXTI_InitStruct
->Line_0_31
= LL_EXTI_LINE_NONE
;
207 EXTI_InitStruct
->LineCommand
= DISABLE
;
208 EXTI_InitStruct
->Mode
= LL_EXTI_MODE_IT
;
209 EXTI_InitStruct
->Trigger
= LL_EXTI_TRIGGER_FALLING
;
224 #endif /* defined (EXTI) */
230 #endif /* USE_FULL_LL_DRIVER */
232 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/