⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 stm8s_uart1.c

📁 STM8全部资料
💻 C
📖 第 1 页 / 共 3 页
字号:
  /*assert_param for UART1_Address*/
  assert_param(IS_UART1_ADDRESS_OK(UART1_Address));

  /* Clear the UART1 address */
  UART1->CR4 &= ((u8)~UART1_CR4_ADD);
  /* Set the UART1 address node */
  UART1->CR4 |= UART1_Address;
}

/**
  * @brief Sets the specified UART1 guard time.
  * @par Full description:
  * Sets the address of the UART1 node.
  * @par This function is related to SmartCard mode.
  * @param[in] UART1_GuardTime: specifies the guard time.
  * @retval void None
  * @par Required preconditions:
  * SmartCard Mode Enabled
  * @par Called functions:
  * None
  * @par Example:
  * The UART1 guard time counter count up to 0x44 until TC is assert_paramed high.
  * @code
    * UART1_SetGuardTime(0x44);
  * @endcode
  */
void UART1_SetGuardTime(u8 UART1_GuardTime)
{
  /* Set the UART1 guard time */
  UART1->GTR = UART1_GuardTime;
}

/**
  * @brief Sets the system clock prescaler.
  * @par Full description:
  * Sets the system clock prescaler.
  * @par This function is related to SmartCard and IrDa mode.
  * @param[in] UART1_Prescaler: specifies the prescaler clock.
  *                    This parameter can be one of the following values:
  *                       @par IrDA Low Power Mode
  *   The clock source is diveded by the value given in the register (8 bits)
  *                       - 0000 0000 Reserved
  *                       - 0000 0001 divides the clock source by 1
  *                       - 0000 0010 divides the clock source by 2
  *                       - ...........................................................
  *                       @par Smart Card Mode
  *   The clock source is diveded by the value given in the register (5 significant bits) multipied by 2
  *                       - 0 0000 Reserved
  *                       - 0 0001 divides the clock source by 2
  *                       - 0 0010 divides the clock source by 4
  *                       - 0 0011 divides the clock source by 6
  *                       - ...........................................................
  * @retval void None
  * @par Required preconditions:
  * IrDA Low Power mode or smartcard mode enabled
  * @par Called functions:
  * None
  * @par Example:
  * Sets UART1 prescalerfor SmartCard divided by 2.
  * @code
  * UART1_SmartCardCmd(ENABLE);
  * UART1_SetPrescaler(0x01);
  * @endcode
  */
void UART1_SetPrescaler(u8 UART1_Prescaler)
{
  /* Load the UART1 prescaler value*/
  UART1->PSCR = UART1_Prescaler;
}

/**
  * @brief Checks whether the specified UART1 flag is set or not.
  * @par Full description:
  * Checks whether the specified UART1 flag is set or not.
  * @param[in] UART1_FLAG specifies the flag to check.
  * This parameter can be any of the @ref UART1_Flag_TypeDef enumeration.
  * @retval FlagStatus (SET or RESET)
  * @par Required preconditions:
  * None
  * @par Called functions:
  * None
  * @par Example:
  * Check the status of TC flag.
  * @code
  * FlagStatus TC_flag;
  * TC_Flag = UART1_GetFlagStatus(UART1_FLAG_TC);
  * @endcode
  */
FlagStatus UART1_GetFlagStatus(UART1_Flag_TypeDef UART1_FLAG)
{
  FlagStatus status = RESET;

  /* Check parameters */
  assert_param(IS_UART1_FLAG_OK(UART1_FLAG));


  /* Check the status of the specified UART1 flag*/
  if (UART1_FLAG == UART1_FLAG_LBDF)
  {
    if ((UART1->CR4 & (u8)UART1_FLAG) != (u8)0x00)
    {
      /* UART1_FLAG is set*/
      status = SET;
    }
    else
    {
      /* UART1_FLAG is reset*/
      status = RESET;
    }
  }
  else if (UART1_FLAG == UART1_FLAG_SBK)
  {
    if ((UART1->CR2 & (u8)UART1_FLAG) != (u8)0x00)
    {
      /* UART1_FLAG is set*/
      status = SET;
    }
    else
    {
      /* UART1_FLAG is reset*/
      status = RESET;
    }
  }
  else
  {
    if ((UART1->SR & (u8)UART1_FLAG) != (u8)0x00)
    {
      /* UART1_FLAG is set*/
      status = SET;
    }
    else
    {
      /* UART1_FLAG is reset*/
      status = RESET;
    }
  }
  /* Return the UART1_FLAG status*/
  return status;
}
/**
 * @brief Clears the UART1 flags.
 * @par Full description:
 * Clears the UART1 flags.
 * @param[in] UART1_FLAG specifies the flag to clear
 * This parameter can be any combination of the following values:
 *   - UART1_FLAG_LBDF: LIN Break detection flag.
 *   - UART1_FLAG_RXNE: Receive data register not empty flag.
 * @par Notes:
 *   - PE (Parity error), FE (Framing error), NE (Noise error), OR (OverRun error)
 *     and IDLE (Idle line detected) flags are cleared by software sequence: a read
 *    operation to UART1_SR register (UART1_GetFlagStatus())followed by a read operation
 *     to UART1_DR register(UART1_ReceiveData8() or UART1_ReceiveData9()).
 *   - RXNE flag can be also cleared by a read to the UART1_DR register
 *     (UART1_ReceiveData8()or UART1_ReceiveData9()).
 *   - TC flag can be also cleared by software sequence: a read operation to UART1_SR
 *     register (UART1_GetFlagStatus()) followed by a write operation to UART1_DR register
 *     (UART1_SendData8() or UART1_SendData9()).
 *   - TXE flag is cleared only by a write to the UART1_DR register (UART1_SendData8() or
 *     UART1_SendData9()).
 *   - SBK flag is cleared during the stop bit of break.
 * @retval void None
 * @par Required preconditions:
 * None
 * @par Called functions:
 * None
 * @par Example:
 * Clear the UART1 TC flag
 * @code
 * UART1_ClearFlag(UART1_FLAG_TC);
 * @endcode
 */

void UART1_ClearFlag(UART1_Flag_TypeDef UART1_FLAG)
{
  assert_param(IS_UART1_CLEAR_FLAG_OK(UART1_FLAG));

  /*< Clear the Receive Register Not Empty flag */
  if (UART1_FLAG == UART1_FLAG_RXNE)
  {
    UART1->SR = (u8)~(UART1_SR_RXNE);
  }
  /*< Clear the LIN Break Detection flag */
  else
  {
    UART1->CR4 &= (u8)~(UART1_CR4_LBDF);
  }
}

/**
  * @brief Checks whether the specified UART1 interrupt has occurred or not.
  * @par Full description:
  * Checks whether the specified UART1 interrupt has occurred or not.
  * @param[in] UART1_IT: Specifies the UART1 interrupt pending bit to check.
 * This parameter can be one of the following values:
  *   - UART1_IT_LBDF:  LIN Break detection interrupt
  *   - UART1_IT_TXE:  Tansmit Data Register empty interrupt
  *   - UART1_IT_TC:   Transmission complete interrupt
  *   - UART1_IT_RXNE: Receive Data register not empty interrupt
  *   - UART1_IT_IDLE: Idle line detection interrupt
  *   - UART1_IT_OR:  OverRun Error interrupt
  *   - UART1_IT_PE:   Parity Error interrupt
 * @retval
 * ITStatus The new state of UART1_IT (SET or RESET).
  * @par Required preconditions:
  * None
  * @par Called functions:
  * None
  * @par Example:
  * @code
  * IT_Status Status;
  * Status = UART1_GetITStatus(UART1_IT_TC);
  * @endcode
  */
ITStatus UART1_GetITStatus(UART1_IT_TypeDef UART1_IT)
{
  ITStatus pendingbitstatus = RESET;
  u8 itpos = 0;
  u8 itmask1 = 0;
  u8 itmask2 = 0;
  u8 enablestatus = 0;

  /* Check parameters */
  assert_param(IS_UART1_GET_IT_OK(UART1_IT));

  /* Get the UART1 IT index */
  itpos = (u8)((u8)1 << (u8)((u8)UART1_IT & (u8)0x0F));
  /* Get the UART1 IT index */
  itmask1 = (u8)((u8)UART1_IT >> (u8)4);
  /* Set the IT mask*/
  itmask2 = (u8)((u8)1 << itmask1);


  /* Check the status of the specified UART1 pending bit*/
  if (UART1_IT == UART1_IT_PE)
  {
    /* Get the UART1_IT enable bit status*/
    enablestatus = (u8)((u8)UART1->CR1 & itmask2);
    /* Check the status of the specified UART1 interrupt*/

    if (((UART1->SR & itpos) != (u8)0x00) && enablestatus)
    {
      /* Interrupt occurred*/
      pendingbitstatus = SET;
    }
    else
    {
      /* Interrupt not occurred*/
      pendingbitstatus = RESET;
    }
  }

  else if (UART1_IT == UART1_IT_LBDF)
  {
    /* Get the UART1_IT enable bit status*/
    enablestatus = (u8)((u8)UART1->CR4 & itmask2);
    /* Check the status of the specified UART1 interrupt*/
    if (((UART1->CR4 & itpos) != (u8)0x00) && enablestatus)
    {
      /* Interrupt occurred*/
      pendingbitstatus = SET;
    }
    else
    {
      /* Interrupt not occurred*/
      pendingbitstatus = RESET;
    }
  }
  else
  {
    /* Get the UART1_IT enable bit status*/
    enablestatus = (u8)((u8)UART1->CR2 & itmask2);
    /* Check the status of the specified UART1 interrupt*/
    if (((UART1->SR & itpos) != (u8)0x00) && enablestatus)
    {
      /* Interrupt occurred*/
      pendingbitstatus = SET;
    }
    else
    {
      /* Interrupt not occurred*/
      pendingbitstatus = RESET;
    }
  }

  /* Return the UART1_IT status*/
  return  pendingbitstatus;
}

/**
 * @brief Clears the UART1 pending flags.
 * @par Full description:
 * Clears the UART1 pending bit.
 * @param[in] UART1_IT specifies the pending bit to clear
 * This parameter can be one of the following values:
 *   - UART1_IT_LBDF:  LIN Break detection interrupt
 *   - UART1_IT_RXNE: Receive Data register not empty interrupt.
 * @par Notes:
 *   - PE (Parity error), FE (Framing error), NE (Noise error), OR (OverRun error) and
 *     IDLE (Idle line detected) pending bits are cleared by software sequence: a read
 *     operation to UART1_SR register (UART1_GetITStatus()) followed by a read operation
 *     to UART1_DR register (UART1_ReceiveData8() or UART1_ReceiveData9()).
 *   - RXNE pending bit can be also cleared by a read to the UART1_DR register
 *     (UART1_ReceiveData8() or UART1_ReceiveData9()).
 *   - TC (Transmit complet) pending bit can be cleared by software sequence: a read
 *     operation to UART1_SR register (UART1_GetITStatus()) followed by a write operation
 *     to UART1_DR register (UART1_SendData8()or UART1_SendData9()).
 *   - TXE pending bit is cleared only by a write to the UART1_DR register
 *     (UART1_SendData8() or UART1_SendData9()).
 * @retval void None
 * @par Required preconditions:
 * None
 * @par Called functions:
 * None
 * @par Example:
 * Clear the UART1 LBDF pending bit
 * @code
 * UART1_ClearITPendingBit(UART1_IT_LBDF);
 * @endcode
 */
void UART1_ClearITPendingBit(UART1_IT_TypeDef UART1_IT)
{
  assert_param(IS_UART1_CLEAR_FLAG_OK(UART1_IT));

  /*< Clear the Receive Register Not Empty pending bit */
  if (UART1_IT == UART1_IT_RXNE)
  {
    UART1->SR = (u8)~(UART1_SR_RXNE);
  }
  /*< Clear the LIN Break Detection pending bit */
  else
  {
    UART1->CR4 &= (u8)~(UART1_CR4_LBDF);
  }
}

/**
  * @}
  */

/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -