| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386 | /**  ******************************************************************************  * @file    py32f002b_ll_usart.c  * @author  MCU Application Team  * @brief   USART LL module driver.  ******************************************************************************  * @attention  *  * <h2><center>© Copyright (c) 2023 Puya Semiconductor Co.  * All rights reserved.</center></h2>  *  * This software component is licensed by Puya under BSD 3-Clause license,  * the "License"; You may not use this file except in compliance with the  * License. You may obtain a copy of the License at:  *                        opensource.org/licenses/BSD-3-Clause  *  ******************************************************************************  * @attention  *  * <h2><center>© Copyright (c) 2016 STMicroelectronics.  * All rights reserved.</center></h2>  *  * This software component is licensed by ST under BSD 3-Clause license,  * the "License"; You may not use this file except in compliance with the  * License. You may obtain a copy of the License at:  *                        opensource.org/licenses/BSD-3-Clause  *  ******************************************************************************  */#if defined(USE_FULL_LL_DRIVER)/* Includes ------------------------------------------------------------------*/#include "py32f002b_ll_usart.h"#include "py32f002b_ll_rcc.h"#include "py32f002b_ll_bus.h"#ifdef  USE_FULL_ASSERT  #include "py32_assert.h"#else  #define assert_param(expr) ((void)0U)#endif/** @addtogroup PY32F002B_LL_Driver  * @{  */#if defined (USART1)/** @addtogroup USART_LL  * @{  *//* Private types -------------------------------------------------------------*//* Private variables ---------------------------------------------------------*//* Private constants ---------------------------------------------------------*//** @addtogroup USART_LL_Private_Constants  * @{  *//**  * @}  *//* Private macros ------------------------------------------------------------*//** @addtogroup USART_LL_Private_Macros  * @{  *//* __BAUDRATE__ The maximum Baud Rate is derived from the maximum clock available *              divided by the smallest oversampling used on the USART (i.e. 8)    */#define IS_LL_USART_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) <= 4500000U)/* __VALUE__ In case of oversampling by 16 and 8, BRR content must be greater than or equal to 16d. */#define IS_LL_USART_BRR_MIN(__VALUE__) ((__VALUE__) >= 16U)/* __VALUE__ BRR content must be lower than or equal to 0xFFFF. */#define IS_LL_USART_BRR_MAX(__VALUE__) ((__VALUE__) <= 0x0000FFFFU)#define IS_LL_USART_DIRECTION(__VALUE__) (((__VALUE__) == LL_USART_DIRECTION_NONE) \                                       || ((__VALUE__) == LL_USART_DIRECTION_RX) \                                       || ((__VALUE__) == LL_USART_DIRECTION_TX) \                                       || ((__VALUE__) == LL_USART_DIRECTION_TX_RX))#define IS_LL_USART_PARITY(__VALUE__) (((__VALUE__) == LL_USART_PARITY_NONE) \                                    || ((__VALUE__) == LL_USART_PARITY_EVEN) \                                    || ((__VALUE__) == LL_USART_PARITY_ODD))#define IS_LL_USART_DATAWIDTH(__VALUE__) (((__VALUE__) == LL_USART_DATAWIDTH_8B) \                                       || ((__VALUE__) == LL_USART_DATAWIDTH_9B))#define IS_LL_USART_OVERSAMPLING(__VALUE__) (((__VALUE__) == LL_USART_OVERSAMPLING_16) \                                          || ((__VALUE__) == LL_USART_OVERSAMPLING_8))#define IS_LL_USART_LASTBITCLKOUTPUT(__VALUE__) (((__VALUE__) == LL_USART_LASTCLKPULSE_NO_OUTPUT) \                                              || ((__VALUE__) == LL_USART_LASTCLKPULSE_OUTPUT))#define IS_LL_USART_CLOCKPHASE(__VALUE__) (((__VALUE__) == LL_USART_PHASE_1EDGE) \                                        || ((__VALUE__) == LL_USART_PHASE_2EDGE))#define IS_LL_USART_CLOCKPOLARITY(__VALUE__) (((__VALUE__) == LL_USART_POLARITY_LOW) \                                           || ((__VALUE__) == LL_USART_POLARITY_HIGH))#define IS_LL_USART_CLOCKOUTPUT(__VALUE__) (((__VALUE__) == LL_USART_CLOCK_DISABLE) \                                         || ((__VALUE__) == LL_USART_CLOCK_ENABLE))#define IS_LL_USART_STOPBITS(__VALUE__) (((__VALUE__) == LL_USART_STOPBITS_1) \                                      || ((__VALUE__) == LL_USART_STOPBITS_2))#define IS_LL_USART_HWCONTROL(__VALUE__) (((__VALUE__) == LL_USART_HWCONTROL_NONE) \                                       || ((__VALUE__) == LL_USART_HWCONTROL_RTS) \                                       || ((__VALUE__) == LL_USART_HWCONTROL_CTS) \                                       || ((__VALUE__) == LL_USART_HWCONTROL_RTS_CTS))/**  * @}  *//* Private function prototypes -----------------------------------------------*//* Exported functions --------------------------------------------------------*//** @addtogroup USART_LL_Exported_Functions  * @{  *//** @addtogroup USART_LL_EF_Init  * @{  *//**  * @brief  De-initialize USART registers (Registers restored to their default values).  * @param  USARTx USART Instance  * @retval An ErrorStatus enumeration value:  *          - SUCCESS: USART registers are de-initialized  *          - ERROR: USART registers are not de-initialized  */ErrorStatus LL_USART_DeInit(USART_TypeDef *USARTx){  ErrorStatus status = SUCCESS;  /* Check the parameters */  assert_param(IS_UART_INSTANCE(USARTx));  if (USARTx == USART1)  {    /* Force reset of USART clock */    LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_USART1);    /* Release reset of USART clock */    LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_USART1);  }  else  {    status = ERROR;  }  return (status);}/**  * @brief  Initialize USART registers according to the specified  *         parameters in USART_InitStruct.  * @note   As some bits in USART configuration registers can only be written when the USART is disabled (USART_CR1_UE bit =0),  *         USART IP should be in disabled state prior calling this function. Otherwise, ERROR result will be returned.  * @note   Baud rate value stored in USART_InitStruct BaudRate field, should be valid (different from 0).  * @param  USARTx USART Instance  * @param  USART_InitStruct pointer to a LL_USART_InitTypeDef structure  *         that contains the configuration information for the specified USART peripheral.  * @retval An ErrorStatus enumeration value:  *          - SUCCESS: USART registers are initialized according to USART_InitStruct content  *          - ERROR: Problem occurred during USART Registers initialization  */ErrorStatus LL_USART_Init(USART_TypeDef *USARTx, LL_USART_InitTypeDef *USART_InitStruct){  ErrorStatus status = ERROR;  uint32_t periphclk = LL_RCC_PERIPH_FREQUENCY_NO;  LL_RCC_ClocksTypeDef rcc_clocks;  /* Check the parameters */  assert_param(IS_UART_INSTANCE(USARTx));  assert_param(IS_LL_USART_BAUDRATE(USART_InitStruct->BaudRate));  assert_param(IS_LL_USART_DATAWIDTH(USART_InitStruct->DataWidth));  assert_param(IS_LL_USART_STOPBITS(USART_InitStruct->StopBits));  assert_param(IS_LL_USART_PARITY(USART_InitStruct->Parity));  assert_param(IS_LL_USART_DIRECTION(USART_InitStruct->TransferDirection));  assert_param(IS_LL_USART_HWCONTROL(USART_InitStruct->HardwareFlowControl));#if defined(USART_CR3_OVER8)  assert_param(IS_LL_USART_OVERSAMPLING(USART_InitStruct->OverSampling));#endif /* USART_OverSampling_Feature */  /* USART needs to be in disabled state, in order to be able to configure some bits in     CRx registers */  if (LL_USART_IsEnabled(USARTx) == 0U)  {    /*---------------------------- USART CR1 Configuration -----------------------     * Configure USARTx CR1 (USART Word Length, Parity, Mode and Oversampling bits) with parameters:     * - DataWidth:          USART_CR1_M bits according to USART_InitStruct->DataWidth value     * - Parity:             USART_CR1_PCE, USART_CR1_PS bits according to USART_InitStruct->Parity value     * - TransferDirection:  USART_CR1_TE, USART_CR1_RE bits according to USART_InitStruct->TransferDirection value     * - Oversampling:       USART_CR3_OVER8 bit according to USART_InitStruct->OverSampling value.     */#if defined(USART_CR3_OVER8)    MODIFY_REG(USARTx->CR1,               (USART_CR1_M | USART_CR1_PCE | USART_CR1_PS |                    USART_CR1_TE | USART_CR1_RE),               (USART_InitStruct->DataWidth | USART_InitStruct->Parity |                USART_InitStruct->TransferDirection));        MODIFY_REG(USARTx->CR3, USART_CR3_OVER8, USART_InitStruct->OverSampling);#else        MODIFY_REG(USARTx->CR1,               (USART_CR1_M | USART_CR1_PCE | USART_CR1_PS |                USART_CR1_TE | USART_CR1_RE),               (USART_InitStruct->DataWidth | USART_InitStruct->Parity |                USART_InitStruct->TransferDirection));#endif /* USART_OverSampling_Feature */    /*---------------------------- USART CR2 Configuration -----------------------     * Configure USARTx CR2 (Stop bits) with parameters:     * - Stop Bits:          USART_CR2_STOP bits according to USART_InitStruct->StopBits value.     * - CLKEN, CPOL, CPHA and LBCL bits are to be configured using LL_USART_ClockInit().     */    LL_USART_SetStopBitsLength(USARTx, USART_InitStruct->StopBits);    /*---------------------------- USART CR3 Configuration -----------------------     * Configure USARTx CR3 (Hardware Flow Control) with parameters:     * - HardwareFlowControl: USART_CR3_RTSE, USART_CR3_CTSE bits according to USART_InitStruct->HardwareFlowControl value.     */    LL_USART_SetHWFlowCtrl(USARTx, USART_InitStruct->HardwareFlowControl);    /*---------------------------- USART BRR Configuration -----------------------     * Retrieve Clock frequency used for USART Peripheral     */    LL_RCC_GetSystemClocksFreq(&rcc_clocks);    periphclk = rcc_clocks.PCLK1_Frequency;    /* Configure the USART Baud Rate :       - valid baud rate value (different from 0) is required       - Peripheral clock as returned by RCC service, should be valid (different from 0).    */    if ((periphclk != LL_RCC_PERIPH_FREQUENCY_NO)        && (USART_InitStruct->BaudRate != 0U))    {      status = SUCCESS;#if defined(USART_CR3_OVER8)            LL_USART_SetBaudRate(USARTx,                           periphclk,                           USART_InitStruct->OverSampling,                           USART_InitStruct->BaudRate);#else      LL_USART_SetBaudRate(USARTx,                           periphclk,                           USART_InitStruct->BaudRate);#endif /* USART_OverSampling_Feature */      /* Check BRR is greater than or equal to 16d */      assert_param(IS_LL_USART_BRR_MIN(USARTx->BRR));      /* Check BRR is greater than or equal to 16d */      assert_param(IS_LL_USART_BRR_MAX(USARTx->BRR));    }  }  /* Endif (=> USART not in Disabled state => return ERROR) */  return (status);}/**  * @brief Set each @ref LL_USART_InitTypeDef field to default value.  * @param USART_InitStruct Pointer to a @ref LL_USART_InitTypeDef structure  *                         whose fields will be set to default values.  * @retval None  */void LL_USART_StructInit(LL_USART_InitTypeDef *USART_InitStruct){  /* Set USART_InitStruct fields to default values */  USART_InitStruct->BaudRate            = 9600U;  USART_InitStruct->DataWidth           = LL_USART_DATAWIDTH_8B;  USART_InitStruct->StopBits            = LL_USART_STOPBITS_1;  USART_InitStruct->Parity              = LL_USART_PARITY_NONE ;  USART_InitStruct->TransferDirection   = LL_USART_DIRECTION_TX_RX;  USART_InitStruct->HardwareFlowControl = LL_USART_HWCONTROL_NONE;#if defined(USART_CR3_OVER8)  USART_InitStruct->OverSampling        = LL_USART_OVERSAMPLING_16;#endif /* USART_OverSampling_Feature */}/**  * @brief  Initialize USART Clock related settings according to the  *         specified parameters in the USART_ClockInitStruct.  * @note   As some bits in USART configuration registers can only be written when the USART is disabled (USART_CR1_UE bit =0),  *         USART IP should be in disabled state prior calling this function. Otherwise, ERROR result will be returned.  * @param  USARTx USART Instance  * @param  USART_ClockInitStruct Pointer to a @ref LL_USART_ClockInitTypeDef structure  *         that contains the Clock configuration information for the specified USART peripheral.  * @retval An ErrorStatus enumeration value:  *          - SUCCESS: USART registers related to Clock settings are initialized according to USART_ClockInitStruct content  *          - ERROR: Problem occurred during USART Registers initialization  */ErrorStatus LL_USART_ClockInit(USART_TypeDef *USARTx, LL_USART_ClockInitTypeDef *USART_ClockInitStruct){  ErrorStatus status = SUCCESS;  /* Check USART Instance and Clock signal output parameters */  assert_param(IS_UART_INSTANCE(USARTx));  assert_param(IS_LL_USART_CLOCKOUTPUT(USART_ClockInitStruct->ClockOutput));  /* USART needs to be in disabled state, in order to be able to configure some bits in     CRx registers */  if (LL_USART_IsEnabled(USARTx) == 0U)  {    /*---------------------------- USART CR2 Configuration -----------------------*/    /* If Clock signal has to be output */    if (USART_ClockInitStruct->ClockOutput == LL_USART_CLOCK_DISABLE)    {      /* Deactivate Clock signal delivery :       * - Disable Clock Output:        USART_CR2_CLKEN cleared       */      LL_USART_DisableSCLKOutput(USARTx);    }    else    {      /* Ensure USART instance is USART capable */      assert_param(IS_USART_INSTANCE(USARTx));      /* Check clock related parameters */      assert_param(IS_LL_USART_CLOCKPOLARITY(USART_ClockInitStruct->ClockPolarity));      assert_param(IS_LL_USART_CLOCKPHASE(USART_ClockInitStruct->ClockPhase));      assert_param(IS_LL_USART_LASTBITCLKOUTPUT(USART_ClockInitStruct->LastBitClockPulse));      /*---------------------------- USART CR2 Configuration -----------------------       * Configure USARTx CR2 (Clock signal related bits) with parameters:       * - Enable Clock Output:         USART_CR2_CLKEN set       * - Clock Polarity:              USART_CR2_CPOL bit according to USART_ClockInitStruct->ClockPolarity value       * - Clock Phase:                 USART_CR2_CPHA bit according to USART_ClockInitStruct->ClockPhase value       * - Last Bit Clock Pulse Output: USART_CR2_LBCL bit according to USART_ClockInitStruct->LastBitClockPulse value.       */      MODIFY_REG(USARTx->CR2,                 USART_CR2_CLKEN | USART_CR2_CPHA | USART_CR2_CPOL | USART_CR2_LBCL,                 USART_CR2_CLKEN | USART_ClockInitStruct->ClockPolarity |                 USART_ClockInitStruct->ClockPhase | USART_ClockInitStruct->LastBitClockPulse);    }  }  /* Else (USART not in Disabled state => return ERROR */  else  {    status = ERROR;  }  return (status);}/**  * @brief Set each field of a @ref LL_USART_ClockInitTypeDef type structure to default value.  * @param USART_ClockInitStruct Pointer to a @ref LL_USART_ClockInitTypeDef structure  *                              whose fields will be set to default values.  * @retval None  */void LL_USART_ClockStructInit(LL_USART_ClockInitTypeDef *USART_ClockInitStruct){  /* Set LL_USART_ClockInitStruct fields with default values */  USART_ClockInitStruct->ClockOutput       = LL_USART_CLOCK_DISABLE;  USART_ClockInitStruct->ClockPolarity     = LL_USART_POLARITY_LOW;            /* Not relevant when ClockOutput = LL_USART_CLOCK_DISABLE */  USART_ClockInitStruct->ClockPhase        = LL_USART_PHASE_1EDGE;             /* Not relevant when ClockOutput = LL_USART_CLOCK_DISABLE */  USART_ClockInitStruct->LastBitClockPulse = LL_USART_LASTCLKPULSE_NO_OUTPUT;  /* Not relevant when ClockOutput = LL_USART_CLOCK_DISABLE */}/**  * @}  *//**  * @}  *//**  * @}  */#endif /* USART1 *//**  * @}  */#endif /* USE_FULL_LL_DRIVER *//************************ (C) COPYRIGHT Puya *****END OF FILE****/
 |