123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- /**
- ******************************************************************************
- * @file stm32l4xx_ll_rng.c
- * @author MCD Application Team
- * @brief RNG LL module driver.
- ******************************************************************************
- * @attention
- *
- * Copyright (c) 2017 STMicroelectronics.
- * All rights reserved.
- *
- * This software is licensed under terms that can be found in the LICENSE file
- * in the root directory of this software component.
- * If no LICENSE file comes with this software, it is provided AS-IS.
- *
- ******************************************************************************
- */
- #if defined(USE_FULL_LL_DRIVER)
- /* Includes ------------------------------------------------------------------*/
- #include "stm32l4xx_ll_rng.h"
- #include "stm32l4xx_ll_bus.h"
- #ifdef USE_FULL_ASSERT
- #include "stm32_assert.h"
- #else
- #define assert_param(expr) ((void)0U)
- #endif /* USE_FULL_ASSERT */
- /** @addtogroup STM32L4xx_LL_Driver
- * @{
- */
- #if defined (RNG)
- /** @addtogroup RNG_LL
- * @{
- */
- /* Private types -------------------------------------------------------------*/
- /* Private variables ---------------------------------------------------------*/
- /* Private constants ---------------------------------------------------------*/
- /* Private macros ------------------------------------------------------------*/
- #if defined(RNG_CR_CED)
- /** @defgroup RNG_LL_Private_Macros RNG Private Macros
- * @{
- */
- #define IS_LL_RNG_CED(__MODE__) (((__MODE__) == LL_RNG_CED_ENABLE) || \
- ((__MODE__) == LL_RNG_CED_DISABLE))
- #if defined(RNG_CR_CONDRST)
- #define IS_LL_RNG_CLOCK_DIVIDER(__CLOCK_DIV__) ((__CLOCK_DIV__) <=0x0Fu)
- #define IS_LL_RNG_NIST_COMPLIANCE(__NIST_COMPLIANCE__) (((__NIST_COMPLIANCE__) == LL_RNG_NIST_COMPLIANT) || \
- ((__NIST_COMPLIANCE__) == LL_RNG_NOTNIST_COMPLIANT))
- #define IS_LL_RNG_CONFIG1 (__CONFIG1__) ((__CONFIG1__) <= 0x3FUL)
- #define IS_LL_RNG_CONFIG2 (__CONFIG2__) ((__CONFIG2__) <= 0x07UL)
- #define IS_LL_RNG_CONFIG3 (__CONFIG3__) ((__CONFIG3__) <= 0xFUL)
- #endif /* RNG_CR_CONDRST */
- /**
- * @}
- */
- #endif /* RNG_CR_CED */
- /* Private function prototypes -----------------------------------------------*/
- /* Exported functions --------------------------------------------------------*/
- /** @addtogroup RNG_LL_Exported_Functions
- * @{
- */
- /** @addtogroup RNG_LL_EF_Init
- * @{
- */
- /**
- * @brief De-initialize RNG registers (Registers restored to their default values).
- * @param RNGx RNG Instance
- * @retval An ErrorStatus enumeration value:
- * - SUCCESS: RNG registers are de-initialized
- * - ERROR: not applicable
- */
- ErrorStatus LL_RNG_DeInit(const RNG_TypeDef *RNGx)
- {
- ErrorStatus status = SUCCESS;
- /* Check the parameters */
- assert_param(IS_RNG_ALL_INSTANCE(RNGx));
- if (RNGx == RNG)
- {
- /* Enable RNG reset state */
- LL_AHB2_GRP1_ForceReset(LL_AHB2_GRP1_PERIPH_RNG);
- /* Release RNG from reset state */
- LL_AHB2_GRP1_ReleaseReset(LL_AHB2_GRP1_PERIPH_RNG);
- }
- else
- {
- status = ERROR;
- }
- return status;
- }
- #if defined(RNG_CR_CED)
- /**
- * @brief Initialize RNG registers according to the specified parameters in RNG_InitStruct.
- * @param RNGx RNG Instance
- * @param RNG_InitStruct pointer to a LL_RNG_InitTypeDef structure
- * that contains the configuration information for the specified RNG peripheral.
- * @retval An ErrorStatus enumeration value:
- * - SUCCESS: RNG registers are initialized according to RNG_InitStruct content
- * - ERROR: not applicable
- */
- ErrorStatus LL_RNG_Init(RNG_TypeDef *RNGx, const LL_RNG_InitTypeDef *RNG_InitStruct)
- {
- /* Check the parameters */
- assert_param(IS_RNG_ALL_INSTANCE(RNGx));
- assert_param(IS_LL_RNG_CED(RNG_InitStruct->ClockErrorDetection));
- #if defined(RNG_CR_CONDRST)
- /* Clock Error Detection Configuration when CONDRT bit is set to 1 */
- MODIFY_REG(RNGx->CR, RNG_CR_CED | RNG_CR_CONDRST, RNG_InitStruct->ClockErrorDetection | RNG_CR_CONDRST);
- /* Writing bits CONDRST=0*/
- CLEAR_BIT(RNGx->CR, RNG_CR_CONDRST);
- #else
- /* Clock Error Detection configuration */
- MODIFY_REG(RNGx->CR, RNG_CR_CED, RNG_InitStruct->ClockErrorDetection);
- #endif /* RNG_CR_CONDRST */
- return (SUCCESS);
- }
- /**
- * @brief Set each @ref LL_RNG_InitTypeDef field to default value.
- * @param RNG_InitStruct pointer to a @ref LL_RNG_InitTypeDef structure
- * whose fields will be set to default values.
- * @retval None
- */
- void LL_RNG_StructInit(LL_RNG_InitTypeDef *RNG_InitStruct)
- {
- /* Set RNG_InitStruct fields to default values */
- RNG_InitStruct->ClockErrorDetection = LL_RNG_CED_ENABLE;
- }
- #endif /* RNG_CR_CED */
- /**
- * @}
- */
- /**
- * @}
- */
- /**
- * @}
- */
- #endif /* RNG */
- /**
- * @}
- */
- #endif /* USE_FULL_LL_DRIVER */
|