You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

159 lines
4.7 KiB

  1. /**
  2. ******************************************************************************
  3. * @file stm32h7xx_ll_rng.c
  4. * @author MCD Application Team
  5. * @brief RNG LL module driver.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; Copyright (c) 2017 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. #if defined(USE_FULL_LL_DRIVER)
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "stm32h7xx_ll_rng.h"
  22. #include "stm32h7xx_ll_bus.h"
  23. #ifdef USE_FULL_ASSERT
  24. #include "stm32_assert.h"
  25. #else
  26. #define assert_param(expr) ((void)0U)
  27. #endif
  28. /** @addtogroup STM32H7xx_LL_Driver
  29. * @{
  30. */
  31. #if defined (RNG)
  32. /** @addtogroup RNG_LL
  33. * @{
  34. */
  35. /* Private types -------------------------------------------------------------*/
  36. /* Private variables ---------------------------------------------------------*/
  37. /* Private constants ---------------------------------------------------------*/
  38. /* Private macros ------------------------------------------------------------*/
  39. /** @addtogroup RNG_LL_Private_Macros
  40. * @{
  41. */
  42. #define IS_LL_RNG_CED(__MODE__) (((__MODE__) == LL_RNG_CED_ENABLE) || \
  43. ((__MODE__) == LL_RNG_CED_DISABLE))
  44. #if defined(RNG_CR_CONDRST)
  45. #define IS_LL_RNG_CLOCK_DIVIDER(__CLOCK_DIV__) ((__CLOCK_DIV__) <=0x0Fu)
  46. #define IS_LL_RNG_NIST_COMPLIANCE(__NIST_COMPLIANCE__) (((__NIST_COMPLIANCE__) == LL_RNG_NIST_COMPLIANT) || \
  47. ((__NIST_COMPLIANCE__) == LL_RNG_NOTNIST_COMPLIANT))
  48. #define IS_LL_RNG_CONFIG1 (__CONFIG1__) ((__CONFIG1__) <= 0x3FUL)
  49. #define IS_LL_RNG_CONFIG2 (__CONFIG2__) ((__CONFIG2__) <= 0x07UL)
  50. #define IS_LL_RNG_CONFIG3 (__CONFIG3__) ((__CONFIG3__) <= 0xFUL)
  51. #endif /* RNG_CR_CONDRST*/
  52. /**
  53. * @}
  54. */
  55. /* Private function prototypes -----------------------------------------------*/
  56. /* Exported functions --------------------------------------------------------*/
  57. /** @addtogroup RNG_LL_Exported_Functions
  58. * @{
  59. */
  60. /** @addtogroup RNG_LL_EF_Init
  61. * @{
  62. */
  63. /**
  64. * @brief De-initialize RNG registers (Registers restored to their default values).
  65. * @param RNGx RNG Instance
  66. * @retval An ErrorStatus enumeration value:
  67. * - SUCCESS: RNG registers are de-initialized
  68. * - ERROR: not applicable
  69. */
  70. ErrorStatus LL_RNG_DeInit(RNG_TypeDef *RNGx)
  71. {
  72. /* Check the parameters */
  73. assert_param(IS_RNG_ALL_INSTANCE(RNGx));
  74. /* Enable RNG reset state */
  75. LL_AHB2_GRP1_ForceReset(LL_AHB2_GRP1_PERIPH_RNG);
  76. /* Release RNG from reset state */
  77. LL_AHB2_GRP1_ReleaseReset(LL_AHB2_GRP1_PERIPH_RNG);
  78. return (SUCCESS);
  79. }
  80. /**
  81. * @brief Initialize RNG registers according to the specified parameters in RNG_InitStruct.
  82. * @param RNGx RNG Instance
  83. * @param RNG_InitStruct pointer to a LL_RNG_InitTypeDef structure
  84. * that contains the configuration information for the specified RNG peripheral.
  85. * @retval An ErrorStatus enumeration value:
  86. * - SUCCESS: RNG registers are initialized according to RNG_InitStruct content
  87. * - ERROR: not applicable
  88. */
  89. ErrorStatus LL_RNG_Init(RNG_TypeDef *RNGx, LL_RNG_InitTypeDef *RNG_InitStruct)
  90. {
  91. /* Check the parameters */
  92. assert_param(IS_RNG_ALL_INSTANCE(RNGx));
  93. assert_param(IS_LL_RNG_CED(RNG_InitStruct->ClockErrorDetection));
  94. #if defined(RNG_CR_CONDRST)
  95. /* Clock Error Detection Configuration when CONDRT bit is set to 1 */
  96. MODIFY_REG(RNGx->CR, RNG_CR_CED | RNG_CR_CONDRST, RNG_InitStruct->ClockErrorDetection | RNG_CR_CONDRST);
  97. /* Writing bits CONDRST=0*/
  98. CLEAR_BIT(RNGx->CR, RNG_CR_CONDRST);
  99. #else
  100. /* Clock Error Detection configuration */
  101. MODIFY_REG(RNGx->CR, RNG_CR_CED, RNG_InitStruct->ClockErrorDetection);
  102. #endif /* RNG_CR_CONDRST */
  103. return (SUCCESS);
  104. }
  105. /**
  106. * @brief Set each @ref LL_RNG_InitTypeDef field to default value.
  107. * @param RNG_InitStruct pointer to a @ref LL_RNG_InitTypeDef structure
  108. * whose fields will be set to default values.
  109. * @retval None
  110. */
  111. void LL_RNG_StructInit(LL_RNG_InitTypeDef *RNG_InitStruct)
  112. {
  113. /* Set RNG_InitStruct fields to default values */
  114. RNG_InitStruct->ClockErrorDetection = LL_RNG_CED_ENABLE;
  115. }
  116. /**
  117. * @}
  118. */
  119. /**
  120. * @}
  121. */
  122. /**
  123. * @}
  124. */
  125. #endif /* RNG */
  126. /**
  127. * @}
  128. */
  129. #endif /* USE_FULL_LL_DRIVER */
  130. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/