2 ******************************************************************************
\r
3 * @file stm32F7xx_hal_exti.c
\r
4 * @author MCD Application Team
\r
5 * @brief EXTI HAL module driver.
\r
6 * This file provides firmware functions to manage the following
\r
7 * functionalities of the Extended Interrupts and events controller (EXTI) peripheral:
\r
8 * + Initialization and de-initialization functions
\r
9 * + IO operation functions
\r
12 ==============================================================================
\r
13 ##### EXTI Peripheral features #####
\r
14 ==============================================================================
\r
16 (+) Each Exti line can be configured within this driver.
\r
18 (+) Exti line can be configured in 3 different modes
\r
23 (+) Configurable Exti lines can be configured with 3 different triggers
\r
28 (+) When set in interrupt mode, configurable Exti lines have two different
\r
29 interrupts pending registers which allow to distinguish which transition
\r
31 (++) Rising edge pending interrupt
\r
34 (+) Exti lines 0 to 15 are linked to gpio pin number 0 to 15. Gpio port can
\r
35 be selected through multiplexer.
\r
37 ##### How to use this driver #####
\r
38 ==============================================================================
\r
41 (#) Configure the EXTI line using HAL_EXTI_SetConfigLine().
\r
42 (++) Choose the interrupt line number by setting "Line" member from
\r
43 EXTI_ConfigTypeDef structure.
\r
44 (++) Configure the interrupt and/or event mode using "Mode" member from
\r
45 EXTI_ConfigTypeDef structure.
\r
46 (++) For configurable lines, configure rising and/or falling trigger
\r
47 "Trigger" member from EXTI_ConfigTypeDef structure.
\r
48 (++) For Exti lines linked to gpio, choose gpio port using "GPIOSel"
\r
49 member from GPIO_InitTypeDef structure.
\r
51 (#) Get current Exti configuration of a dedicated line using
\r
52 HAL_EXTI_GetConfigLine().
\r
53 (++) Provide exiting handle as parameter.
\r
54 (++) Provide pointer on EXTI_ConfigTypeDef structure as second parameter.
\r
56 (#) Clear Exti configuration of a dedicated line using HAL_EXTI_GetConfigLine().
\r
57 (++) Provide exiting handle as parameter.
\r
59 (#) Register callback to treat Exti interrupts using HAL_EXTI_RegisterCallback().
\r
60 (++) Provide exiting handle as first parameter.
\r
61 (++) Provide which callback will be registered using one value from
\r
62 EXTI_CallbackIDTypeDef.
\r
63 (++) Provide callback function pointer.
\r
65 (#) Get interrupt pending bit using HAL_EXTI_GetPending().
\r
67 (#) Clear interrupt pending bit using HAL_EXTI_GetPending().
\r
69 (#) Generate software interrupt using HAL_EXTI_GenerateSWI().
\r
72 ******************************************************************************
\r
75 * <h2><center>© Copyright (c) 2018 STMicroelectronics.
\r
76 * All rights reserved.</center></h2>
\r
78 * This software component is licensed by ST under BSD 3-Clause license,
\r
79 * the "License"; You may not use this file except in compliance with the
\r
80 * License. You may obtain a copy of the License at:
\r
81 * opensource.org/licenses/BSD-3-Clause
\r
83 ******************************************************************************
\r
86 /* Includes ------------------------------------------------------------------*/
\r
87 #include "stm32f7xx_hal.h"
\r
88 #include "stm32f7xx_hal_exti.h"
\r
90 /** @addtogroup STM32F7xx_HAL_Driver
\r
94 /** @addtogroup EXTI
\r
97 /** MISRA C:2012 deviation rule has been granted for following rule:
\r
98 * Rule-18.1_b - Medium: Array `EXTICR' 1st subscript interval [0,7] may be out
\r
99 * of bounds [0,3] in following API :
\r
100 * HAL_EXTI_SetConfigLine
\r
101 * HAL_EXTI_GetConfigLine
\r
102 * HAL_EXTI_ClearConfigLine
\r
105 #ifdef HAL_EXTI_MODULE_ENABLED
\r
107 /* Private typedef -----------------------------------------------------------*/
\r
108 /* Private defines ------------------------------------------------------------*/
\r
109 /** @defgroup EXTI_Private_Constants EXTI Private Constants
\r
117 /* Private macros ------------------------------------------------------------*/
\r
118 /* Private variables ---------------------------------------------------------*/
\r
119 /* Private function prototypes -----------------------------------------------*/
\r
120 /* Exported functions --------------------------------------------------------*/
\r
122 /** @addtogroup EXTI_Exported_Functions
\r
126 /** @addtogroup EXTI_Exported_Functions_Group1
\r
127 * @brief Configuration functions
\r
130 ===============================================================================
\r
131 ##### Configuration functions #####
\r
132 ===============================================================================
\r
139 * @brief Set configuration of a dedicated Exti line.
\r
140 * @param hexti Exti handle.
\r
141 * @param pExtiConfig Pointer on EXTI configuration to be set.
\r
142 * @retval HAL Status.
\r
144 HAL_StatusTypeDef HAL_EXTI_SetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig)
\r
148 /* Check null pointer */
\r
149 if ((hexti == NULL) || (pExtiConfig == NULL))
\r
154 /* Check parameters */
\r
155 assert_param(IS_EXTI_LINE(pExtiConfig->Line));
\r
156 assert_param(IS_EXTI_MODE(pExtiConfig->Mode));
\r
157 assert_param(IS_EXTI_TRIGGER(pExtiConfig->Trigger));
\r
159 /* Assign line number to handle */
\r
160 hexti->Line = pExtiConfig->Line;
\r
162 /* Clear EXTI line configuration */
\r
163 EXTI->IMR &= ~pExtiConfig->Line;
\r
164 EXTI->EMR &= ~pExtiConfig->Line;
\r
166 /* Select the Mode for the selected external interrupts */
\r
167 regval = (uint32_t)EXTI_BASE;
\r
168 regval += pExtiConfig->Mode;
\r
169 *(__IO uint32_t *) regval |= pExtiConfig->Line;
\r
171 /* Clear Rising Falling edge configuration */
\r
172 EXTI->RTSR &= ~pExtiConfig->Line;
\r
173 EXTI->FTSR &= ~pExtiConfig->Line;
\r
175 /* Select the trigger for the selected external interrupts */
\r
176 if (pExtiConfig->Trigger == EXTI_TRIGGER_RISING_FALLING)
\r
178 /* Rising Falling edge */
\r
179 EXTI->RTSR |= pExtiConfig->Line;
\r
180 EXTI->FTSR |= pExtiConfig->Line;
\r
184 regval = (uint32_t)EXTI_BASE;
\r
185 regval += pExtiConfig->Trigger;
\r
186 *(__IO uint32_t *) regval |= pExtiConfig->Line;
\r
192 * @brief Get configuration of a dedicated Exti line.
\r
193 * @param hexti Exti handle.
\r
194 * @param pExtiConfig Pointer on structure to store Exti configuration.
\r
195 * @retval HAL Status.
\r
197 HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig)
\r
199 /* Check null pointer */
\r
200 if ((hexti == NULL) || (pExtiConfig == NULL))
\r
205 /* Check the parameter */
\r
206 assert_param(IS_EXTI_LINE(hexti->Line));
\r
208 /* Store handle line number to configuration structure */
\r
209 pExtiConfig->Line = hexti->Line;
\r
211 /* Get EXTI mode to configiguration structure */
\r
212 if ((EXTI->IMR & hexti->Line) == hexti->Line)
\r
214 pExtiConfig->Mode = EXTI_MODE_INTERRUPT;
\r
216 else if ((EXTI->EMR & hexti->Line) == hexti->Line)
\r
218 pExtiConfig->Mode = EXTI_MODE_EVENT;
\r
222 /* No MODE selected */
\r
223 pExtiConfig->Mode = 0x0Bu;
\r
226 /* Get EXTI Trigger to configiguration structure */
\r
227 if ((EXTI->RTSR & hexti->Line) == hexti->Line)
\r
229 if ((EXTI->FTSR & hexti->Line) == hexti->Line)
\r
231 pExtiConfig->Trigger = EXTI_TRIGGER_RISING_FALLING;
\r
235 pExtiConfig->Trigger = EXTI_TRIGGER_RISING;
\r
238 else if ((EXTI->FTSR & hexti->Line) == hexti->Line)
\r
240 pExtiConfig->Trigger = EXTI_TRIGGER_FALLING;
\r
244 /* No Trigger selected */
\r
245 pExtiConfig->Trigger = 0x00u;
\r
252 * @brief Clear whole configuration of a dedicated Exti line.
\r
253 * @param hexti Exti handle.
\r
254 * @retval HAL Status.
\r
256 HAL_StatusTypeDef HAL_EXTI_ClearConfigLine(EXTI_HandleTypeDef *hexti)
\r
258 /* Check null pointer */
\r
264 /* Check the parameter */
\r
265 assert_param(IS_EXTI_LINE(hexti->Line));
\r
267 /* 1] Clear interrupt mode */
\r
268 EXTI->IMR = (EXTI->IMR & ~hexti->Line);
\r
270 /* 2] Clear event mode */
\r
271 EXTI->EMR = (EXTI->EMR & ~hexti->Line);
\r
273 /* 3] Clear triggers */
\r
274 EXTI->RTSR = (EXTI->RTSR & ~hexti->Line);
\r
275 EXTI->FTSR = (EXTI->FTSR & ~hexti->Line);
\r
281 * @brief Register callback for a dedicated Exti line.
\r
282 * @param hexti Exti handle.
\r
283 * @param CallbackID User callback identifier.
\r
284 * This parameter can be one of @arg @ref EXTI_CallbackIDTypeDef values.
\r
285 * @param pPendingCbfn function pointer to be stored as callback.
\r
286 * @retval HAL Status.
\r
288 HAL_StatusTypeDef HAL_EXTI_RegisterCallback(EXTI_HandleTypeDef *hexti, EXTI_CallbackIDTypeDef CallbackID, void (*pPendingCbfn)(void))
\r
290 HAL_StatusTypeDef status = HAL_OK;
\r
292 switch (CallbackID)
\r
294 case HAL_EXTI_COMMON_CB_ID:
\r
295 hexti->PendingCallback = pPendingCbfn;
\r
299 status = HAL_ERROR;
\r
307 * @brief Store line number as handle private field.
\r
308 * @param hexti Exti handle.
\r
309 * @param ExtiLine Exti line number.
\r
310 * This parameter can be from 0 to @ref EXTI_LINE_NB.
\r
311 * @retval HAL Status.
\r
313 HAL_StatusTypeDef HAL_EXTI_GetHandle(EXTI_HandleTypeDef *hexti, uint32_t ExtiLine)
\r
315 /* Check the parameters */
\r
316 assert_param(IS_EXTI_LINE(ExtiLine));
\r
318 /* Check null pointer */
\r
325 /* Store line number as handle private field */
\r
326 hexti->Line = ExtiLine;
\r
336 /** @addtogroup EXTI_Exported_Functions_Group2
\r
337 * @brief EXTI IO functions.
\r
340 ===============================================================================
\r
341 ##### IO operation functions #####
\r
342 ===============================================================================
\r
349 * @brief Handle EXTI interrupt request.
\r
350 * @param hexti Exti handle.
\r
353 void HAL_EXTI_IRQHandler(EXTI_HandleTypeDef *hexti)
\r
355 __IO uint32_t *regaddr;
\r
358 /* Get pending bit */
\r
359 regaddr = (&EXTI->PR);
\r
360 regval = (*regaddr & hexti->Line);
\r
362 if (regval != 0x00u)
\r
364 /* Clear pending bit */
\r
365 *regaddr = hexti->Line;
\r
367 /* Call callback */
\r
368 if (hexti->PendingCallback != NULL)
\r
370 hexti->PendingCallback();
\r
376 * @brief Get interrupt pending bit of a dedicated line.
\r
377 * @param hexti Exti handle.
\r
378 * @param Edge Specify which pending edge as to be checked.
\r
379 * This parameter can be one of the following values:
\r
380 * @arg @ref EXTI_TRIGGER_RISING_FALLING
\r
381 * This parameter is kept for compatibility with other series.
\r
382 * @retval 1 if interrupt is pending else 0.
\r
384 uint32_t HAL_EXTI_GetPending(EXTI_HandleTypeDef *hexti, uint32_t Edge)
\r
386 __IO uint32_t *regaddr;
\r
389 /* Check parameters */
\r
390 assert_param(IS_EXTI_LINE(hexti->Line));
\r
391 assert_param(IS_EXTI_PENDING_EDGE(Edge));
\r
393 /* Get pending bit */
\r
394 regaddr = &EXTI->PR;
\r
396 /* return 1 if bit is set else 0 */
\r
397 regval = ((*regaddr & hexti->Line) >> POSITION_VAL(hexti->Line));
\r
403 * @brief Clear interrupt pending bit of a dedicated line.
\r
404 * @param hexti Exti handle.
\r
405 * @param Edge Specify which pending edge as to be clear.
\r
406 * This parameter can be one of the following values:
\r
407 * @arg @ref EXTI_TRIGGER_RISING_FALLING
\r
408 * This parameter is kept for compatibility with other series.
\r
411 void HAL_EXTI_ClearPending(EXTI_HandleTypeDef *hexti, uint32_t Edge)
\r
413 /* Check parameters */
\r
414 assert_param(IS_EXTI_LINE(hexti->Line));
\r
415 assert_param(IS_EXTI_PENDING_EDGE(Edge));
\r
417 /* Clear Pending bit */
\r
418 EXTI->PR = hexti->Line;
\r
422 * @brief Generate a software interrupt for a dedicated line.
\r
423 * @param hexti Exti handle.
\r
426 void HAL_EXTI_GenerateSWI(EXTI_HandleTypeDef *hexti)
\r
428 /* Check parameters */
\r
429 assert_param(IS_EXTI_LINE(hexti->Line));
\r
431 EXTI->SWIER = hexti->Line;
\r
442 #endif /* HAL_EXTI_MODULE_ENABLED */
\r
451 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
\r