Subversion Repositories EDIS_Ignition

Rev

Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. /**
  2.   ******************************************************************************
  3.   * @file    stm32f1xx_hal_iwdg.h
  4.   * @author  MCD Application Team
  5.   * @brief   Header file of IWDG HAL module.
  6.   ******************************************************************************
  7.   * @attention
  8.   *
  9.   * <h2><center>&copy; Copyright (c) 2016 STMicroelectronics.
  10.   * All rights reserved.</center></h2>
  11.   *
  12.   * This software component is licensed by ST under BSD 3-Clause license,
  13.   * the "License"; You may not use this file except in compliance with the
  14.   * License. You may obtain a copy of the License at:
  15.   *                        opensource.org/licenses/BSD-3-Clause
  16.   *
  17.   ******************************************************************************
  18.   */
  19.  
  20. /* Define to prevent recursive inclusion -------------------------------------*/
  21. #ifndef STM32F1xx_HAL_IWDG_H
  22. #define STM32F1xx_HAL_IWDG_H
  23.  
  24. #ifdef __cplusplus
  25. extern "C" {
  26. #endif
  27.  
  28. /* Includes ------------------------------------------------------------------*/
  29. #include "stm32f1xx_hal_def.h"
  30.  
  31. /** @addtogroup STM32F1xx_HAL_Driver
  32.   * @{
  33.   */
  34.  
  35. /** @defgroup IWDG IWDG
  36.   * @{
  37.   */
  38.  
  39. /* Exported types ------------------------------------------------------------*/
  40. /** @defgroup IWDG_Exported_Types IWDG Exported Types
  41.   * @{
  42.   */
  43.  
  44. /**
  45.   * @brief  IWDG Init structure definition
  46.   */
  47. typedef struct
  48. {
  49.   uint32_t Prescaler;  /*!< Select the prescaler of the IWDG.
  50.                             This parameter can be a value of @ref IWDG_Prescaler */
  51.  
  52.   uint32_t Reload;     /*!< Specifies the IWDG down-counter reload value.
  53.                             This parameter must be a number between Min_Data = 0 and Max_Data = 0x0FFF */
  54.  
  55. } IWDG_InitTypeDef;
  56.  
  57. /**
  58.   * @brief  IWDG Handle Structure definition
  59.   */
  60. typedef struct
  61. {
  62.   IWDG_TypeDef                 *Instance;  /*!< Register base address    */
  63.  
  64.   IWDG_InitTypeDef             Init;       /*!< IWDG required parameters */
  65. } IWDG_HandleTypeDef;
  66.  
  67.  
  68. /**
  69.   * @}
  70.   */
  71.  
  72. /* Exported constants --------------------------------------------------------*/
  73. /** @defgroup IWDG_Exported_Constants IWDG Exported Constants
  74.   * @{
  75.   */
  76.  
  77. /** @defgroup IWDG_Prescaler IWDG Prescaler
  78.   * @{
  79.   */
  80. #define IWDG_PRESCALER_4                0x00000000u                                     /*!< IWDG prescaler set to 4   */
  81. #define IWDG_PRESCALER_8                IWDG_PR_PR_0                                    /*!< IWDG prescaler set to 8   */
  82. #define IWDG_PRESCALER_16               IWDG_PR_PR_1                                    /*!< IWDG prescaler set to 16  */
  83. #define IWDG_PRESCALER_32               (IWDG_PR_PR_1 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 32  */
  84. #define IWDG_PRESCALER_64               IWDG_PR_PR_2                                    /*!< IWDG prescaler set to 64  */
  85. #define IWDG_PRESCALER_128              (IWDG_PR_PR_2 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 128 */
  86. #define IWDG_PRESCALER_256              (IWDG_PR_PR_2 | IWDG_PR_PR_1)                   /*!< IWDG prescaler set to 256 */
  87. /**
  88.   * @}
  89.   */
  90.  
  91. /**
  92.   * @}
  93.   */
  94.  
  95. /* Exported macros -----------------------------------------------------------*/
  96. /** @defgroup IWDG_Exported_Macros IWDG Exported Macros
  97.   * @{
  98.   */
  99.  
  100. /**
  101.   * @brief  Enable the IWDG peripheral.
  102.   * @param  __HANDLE__  IWDG handle
  103.   * @retval None
  104.   */
  105. #define __HAL_IWDG_START(__HANDLE__)                WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_ENABLE)
  106.  
  107. /**
  108.   * @brief  Reload IWDG counter with value defined in the reload register
  109.   *         (write access to IWDG_PR and IWDG_RLR registers disabled).
  110.   * @param  __HANDLE__  IWDG handle
  111.   * @retval None
  112.   */
  113. #define __HAL_IWDG_RELOAD_COUNTER(__HANDLE__)       WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_RELOAD)
  114.  
  115. /**
  116.   * @}
  117.   */
  118.  
  119. /* Exported functions --------------------------------------------------------*/
  120. /** @defgroup IWDG_Exported_Functions  IWDG Exported Functions
  121.   * @{
  122.   */
  123.  
  124. /** @defgroup IWDG_Exported_Functions_Group1 Initialization and Start functions
  125.   * @{
  126.   */
  127. /* Initialization/Start functions  ********************************************/
  128. HAL_StatusTypeDef     HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg);
  129. /**
  130.   * @}
  131.   */
  132.  
  133. /** @defgroup IWDG_Exported_Functions_Group2 IO operation functions
  134.   * @{
  135.   */
  136. /* I/O operation functions ****************************************************/
  137. HAL_StatusTypeDef     HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg);
  138. /**
  139.   * @}
  140.   */
  141.  
  142. /**
  143.   * @}
  144.   */
  145.  
  146. /* Private constants ---------------------------------------------------------*/
  147. /** @defgroup IWDG_Private_Constants IWDG Private Constants
  148.   * @{
  149.   */
  150.  
  151. /**
  152.   * @brief  IWDG Key Register BitMask
  153.   */
  154. #define IWDG_KEY_RELOAD                 0x0000AAAAu  /*!< IWDG Reload Counter Enable   */
  155. #define IWDG_KEY_ENABLE                 0x0000CCCCu  /*!< IWDG Peripheral Enable       */
  156. #define IWDG_KEY_WRITE_ACCESS_ENABLE    0x00005555u  /*!< IWDG KR Write Access Enable  */
  157. #define IWDG_KEY_WRITE_ACCESS_DISABLE   0x00000000u  /*!< IWDG KR Write Access Disable */
  158.  
  159. /**
  160.   * @}
  161.   */
  162.  
  163. /* Private macros ------------------------------------------------------------*/
  164. /** @defgroup IWDG_Private_Macros IWDG Private Macros
  165.   * @{
  166.   */
  167.  
  168. /**
  169.   * @brief  Enable write access to IWDG_PR and IWDG_RLR registers.
  170.   * @param  __HANDLE__  IWDG handle
  171.   * @retval None
  172.   */
  173. #define IWDG_ENABLE_WRITE_ACCESS(__HANDLE__)  WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_ENABLE)
  174.  
  175. /**
  176.   * @brief  Disable write access to IWDG_PR and IWDG_RLR registers.
  177.   * @param  __HANDLE__  IWDG handle
  178.   * @retval None
  179.   */
  180. #define IWDG_DISABLE_WRITE_ACCESS(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_DISABLE)
  181.  
  182. /**
  183.   * @brief  Check IWDG prescaler value.
  184.   * @param  __PRESCALER__  IWDG prescaler value
  185.   * @retval None
  186.   */
  187. #define IS_IWDG_PRESCALER(__PRESCALER__)      (((__PRESCALER__) == IWDG_PRESCALER_4)  || \
  188.                                                ((__PRESCALER__) == IWDG_PRESCALER_8)  || \
  189.                                                ((__PRESCALER__) == IWDG_PRESCALER_16) || \
  190.                                                ((__PRESCALER__) == IWDG_PRESCALER_32) || \
  191.                                                ((__PRESCALER__) == IWDG_PRESCALER_64) || \
  192.                                                ((__PRESCALER__) == IWDG_PRESCALER_128)|| \
  193.                                                ((__PRESCALER__) == IWDG_PRESCALER_256))
  194.  
  195. /**
  196.   * @brief  Check IWDG reload value.
  197.   * @param  __RELOAD__  IWDG reload value
  198.   * @retval None
  199.   */
  200. #define IS_IWDG_RELOAD(__RELOAD__)            ((__RELOAD__) <= IWDG_RLR_RL)
  201.  
  202.  
  203.  
  204. /**
  205.   * @}
  206.   */
  207.  
  208. /**
  209.   * @}
  210.   */
  211.  
  212. /**
  213.   * @}
  214.   */
  215.  
  216.  
  217. #ifdef __cplusplus
  218. }
  219. #endif
  220.  
  221. #endif /* STM32F1xx_HAL_IWDG_H */
  222.  
  223. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
  224.