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

📄 stm32f10x_rcc.c

📁 中文固件库.rar
💻 C
📖 第 1 页 / 共 4 页
字号:
  *          RCC_APB1Periph_WWDG, RCC_APB1Periph_SPI2, RCC_APB1Periph_SPI3,
  *          RCC_APB1Periph_USART2, RCC_APB1Periph_USART3, RCC_APB1Periph_USART4, 
  *          RCC_APB1Periph_USART5, RCC_APB1Periph_I2C1, RCC_APB1Periph_I2C2,
  *          RCC_APB1Periph_USB, RCC_APB1Periph_CAN1, RCC_APB1Periph_BKP,
  *          RCC_APB1Periph_PWR, RCC_APB1Periph_DAC
  * @参数  NewState: 指定外围设备时钟的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_RCC_APB1_PERIPH(RCC_APB1Periph));
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  if (NewState != DISABLE)
  {
    RCC->APB1ENR |= RCC_APB1Periph;
  }
  else
  {
    RCC->APB1ENR &= ~RCC_APB1Periph;
  }
}

#ifdef STM32F10X_CL
/**
  * @简述  控制或释放 AHB 外围设备复位.
  * @注解  这个函数仅仅应用在 STM32 互联系列微处理器.
  * @参数  RCC_AHBPeriph: 指定复位的外围设备.
  *                       这个参数可以是下面任意值的组合:
  *                       RCC_AHBPeriph_OTG_FS 
  *                       RCC_AHBPeriph_ETH_MAC
  * @参数  NewState: 指定外围设备复位的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_AHBPeriphResetCmd(uint32_t RCC_AHBPeriph, FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_RCC_AHB_PERIPH_RESET(RCC_AHBPeriph));
  assert_param(IS_FUNCTIONAL_STATE(NewState));

  if (NewState != DISABLE)
  {
    RCC->AHBRSTR |= RCC_AHBPeriph;
  }
  else
  {
    RCC->AHBRSTR &= ~RCC_AHBPeriph;
  }
}
#endif /* STM32F10X_CL */ 

/**
  * @简述  控制或释放高速 APB(APB2) 外围设备复位.
  * @参数  RCC_APB2Periph: 指定复位的 APB2 外围设备.
  *                        这个参数可以是下面任意值的组合:
  *          RCC_APB2Periph_AFIO, RCC_APB2Periph_GPIOA, RCC_APB2Periph_GPIOB,
  *          RCC_APB2Periph_GPIOC, RCC_APB2Periph_GPIOD, RCC_APB2Periph_GPIOE,
  *          RCC_APB2Periph_GPIOF, RCC_APB2Periph_GPIOG, RCC_APB2Periph_ADC1,
  *          RCC_APB2Periph_ADC2, RCC_APB2Periph_TIM1, RCC_APB2Periph_SPI1,
  *          RCC_APB2Periph_TIM8, RCC_APB2Periph_USART1, RCC_APB2Periph_ADC3
  * @参数  NewState: 指定外围设备复位的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_APB2PeriphResetCmd(uint32_t RCC_APB2Periph, FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_RCC_APB2_PERIPH(RCC_APB2Periph));
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  if (NewState != DISABLE)
  {
    RCC->APB2RSTR |= RCC_APB2Periph;
  }
  else
  {
    RCC->APB2RSTR &= ~RCC_APB2Periph;
  }
}

/**
  * @简述  控制或释放低速 APB(APB1) 外围设备复位.
  * @参数  RCC_APB1Periph: 指定复位的 APB1 外围设备.
  *                        这个参数可以是下面任意值的组合:
  *          RCC_APB1Periph_TIM2, RCC_APB1Periph_TIM3, RCC_APB1Periph_TIM4,
  *          RCC_APB1Periph_TIM5, RCC_APB1Periph_TIM6, RCC_APB1Periph_TIM7,
  *          RCC_APB1Periph_WWDG, RCC_APB1Periph_SPI2, RCC_APB1Periph_SPI3,
  *          RCC_APB1Periph_USART2, RCC_APB1Periph_USART3, RCC_APB1Periph_USART4, 
  *          RCC_APB1Periph_USART5, RCC_APB1Periph_I2C1, RCC_APB1Periph_I2C2,
  *          RCC_APB1Periph_USB, RCC_APB1Periph_CAN1, RCC_APB1Periph_BKP,
  *          RCC_APB1Periph_PWR, RCC_APB1Periph_DAC
  * @参数  NewState: 指定外围设备复位的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_APB1PeriphResetCmd(uint32_t RCC_APB1Periph, FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_RCC_APB1_PERIPH(RCC_APB1Periph));
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  if (NewState != DISABLE)
  {
    RCC->APB1RSTR |= RCC_APB1Periph;
  }
  else
  {
    RCC->APB1RSTR &= ~RCC_APB1Periph;
  }
}

/**
  * @简述  控制或释放备份域复位.
  * @参数  NewState: 备份域复位的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_BackupResetCmd(FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  *(__IO uint32_t *) BDCR_BDRST_BB = (uint32_t)NewState;
}

/**
  * @简述  使能或失能时钟安全系统.
  * @参数  NewState: 时钟安全系统的新状态.
  *                  这个参数可以取: ENABLE 或 DISABLE.
  * @返回  没有
  */
void RCC_ClockSecuritySystemCmd(FunctionalState NewState)
{
  /* 检查参数 */
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  *(__IO uint32_t *) CR_CSSON_BB = (uint32_t)NewState;
}

/**
  * @简述  选择 MCO 引脚上的输出时钟源.
  * @参数  RCC_MCO: 指定要输出的时钟源.
  *   
  *        STM32_互联系列微处理器, 这个参数可以取下列值中的一个:      
  *                                RCC_MCO_NoClock:      没有选择时钟
  *                                RCC_MCO_SYSCLK:       选择系统时钟
  *                                RCC_MCO_HSI:          选择HIS振荡时钟
  *                                RCC_MCO_HSE:          选择HSE振荡时钟
  *                                RCC_MCO_PLLCLK_Div2:  选择PLL时钟两分频
  *                                RCC_MCO_PLL2CLK:      选择PLL2振荡时钟                    
  *                                RCC_MCO_PLL3CLK_Div2: 选择PLL3时钟两分频   
  *                                RCC_MCO_XT1:          选择外部 3-25 MHz 振荡时钟  
  *                                RCC_MCO_PLL3CLK:      选择PLL3振荡时钟 
  * 
  *           其它_STM32_微处理器, 这个参数可以取下列值中的一个:        
  *                                RCC_MCO_NoClock:      没有选择时钟
  *                                RCC_MCO_SYSCLK:       选择系统时钟
  *                                RCC_MCO_HSI:          选择HIS振荡时钟
  *                                RCC_MCO_HSE:          选择HSE振荡时钟
  *                                RCC_MCO_PLLCLK_Div2:  选择PLL时钟两分频
  *   
  * @返回  没有
  */
void RCC_MCOConfig(uint8_t RCC_MCO)
{
  /* 检查参数 */
  assert_param(IS_RCC_MCO(RCC_MCO));

  /* 执行MCO[2:0]位的字节存取来选择MCO源 */
  *(__IO uint8_t *) CFGR_BYTE4_ADDRESS = RCC_MCO;
}

/**
  * @简述  检查指定的 RCC 标志设置与否.
  * @参数  RCC_FLAG: 指定要检查的标志.
  *   
  *        STM32_互联系列微处理器, 这个参数可以取下列值中的一个: 
  *                                RCC_FLAG_HSIRDY:  HSI 振荡时钟就绪
  *                                RCC_FLAG_HSERDY:  HSE 振荡时钟就绪
  *                                RCC_FLAG_PLLRDY:  PLL 时钟就绪
  *                                RCC_FLAG_PLL2RDY: PLL2 时钟就绪    
  *                                RCC_FLAG_PLL3RDY: PLL3 时钟就绪                          
  *                                RCC_FLAG_LSERDY:  LSE 振荡时钟就绪
  *                                RCC_FLAG_LSIRDY:  LSI 振荡时钟就绪
  *                                RCC_FLAG_PINRST:  引脚复位
  *                                RCC_FLAG_PORRST:  POR/PDR复位
  *                                RCC_FLAG_SFTRST:  软件复位
  *                                RCC_FLAG_IWDGRST: 独立看门狗复位
  *                                RCC_FLAG_WWDGRST: 窗口看门狗复位
  *                                RCC_FLAG_LPWRRST: 低电量复位
  * 
  *           其它_STM32_微处理器, 这个参数可以取下列值中的一个:            
  *                                RCC_FLAG_HSIRDY:  HSI 振荡时钟就绪
  *                                RCC_FLAG_HSERDY:  HSE 振荡时钟就绪
  *                                RCC_FLAG_PLLRDY:  PLL 时钟就绪
  *                                RCC_FLAG_LSERDY:  LSE 振荡时钟就绪
  *                                RCC_FLAG_LSIRDY:  LSI 振荡时钟就绪
  *                                RCC_FLAG_PINRST:  引脚复位
  *                                RCC_FLAG_PORRST:  POR/PDR复位
  *                                RCC_FLAG_SFTRST:  软件复位
  *                                RCC_FLAG_IWDGRST: 独立看门狗复位
  *                                RCC_FLAG_WWDGRST: 窗口看门狗复位
  *                                RCC_FLAG_LPWRRST: 低电量复位
  *   
  * @返回  RCC_FLAG 的新状态(SET或RESET).
  */
FlagStatus RCC_GetFlagStatus(uint8_t RCC_FLAG)
{
  uint32_t tmp = 0;
  uint32_t statusreg = 0;
  FlagStatus bitstatus = RESET;
  /* 检查参数 */
  assert_param(IS_RCC_FLAG(RCC_FLAG));

  /* 取得 RCC 寄存器引索 */
  tmp = RCC_FLAG >> 5;
  if (tmp == 1)               /* CR 寄存器中的检查标志 */
  {
    statusreg = RCC->CR;
  }
  else if (tmp == 2)          /* BDCR 寄存器中的检查标志 */
  {
    statusreg = RCC->BDCR;
  }
  else                       /* CSR 寄存器中的检查标志 */
  {
    statusreg = RCC->CSR;
  }

  /* 取得标志的位置 */
  tmp = RCC_FLAG & FLAG_Mask;
  if ((statusreg & ((uint32_t)1 << tmp)) != (uint32_t)RESET)
  {
    bitstatus = SET;
  }
  else
  {
    bitstatus = RESET;
  }

  /* 返回标志的状态 */
  return bitstatus;
}

/**
  * @简述  清除 RCC 复位标志.
  * @注解   这些复位标志是: RCC_FLAG_PINRST, RCC_FLAG_PORRST, RCC_FLAG_SFTRST,
  *                         RCC_FLAG_IWDGRST, RCC_FLAG_WWDGRST, RCC_FLAG_LPWRRST
  * @参数  没有
  * @返回  没有
  */
void RCC_ClearFlag(void)
{
  /* 通过置位 RMVF 位来清除复位标志 */
  RCC->CSR |= CSR_RMVF_Set;
}

/**
  * @简述  检查指定的 RCC 中断是否发生.
  * @参数  RCC_IT: 指定检查 RCC 中断源.
  *   
  *        STM32_互联系列微处理器, 这个参数可以取下列值中的一个: 
  *                                RCC_IT_LSIRDY:  LSI 就绪中断
  *                                RCC_IT_LSERDY:  LSE 就绪中断
  *                                RCC_IT_HSIRDY:  HSI 就绪中断
  *                                RCC_IT_HSERDY:  HSE 就绪中断
  *                                RCC_IT_PLLRDY:  PLL 就绪中断
  *                                RCC_IT_PLL2RDY: PLL2 就绪中断 
  *                                RCC_IT_PLL3RDY: PLL3 就绪中断                    
  *                                RCC_IT_CSS:     时钟安全系统中断
  * 
  *           其它_STM32_微处理器, 这个参数可以取下列值中的一个:      
  *                                RCC_IT_LSIRDY: LSI 就绪中断
  *                                RCC_IT_LSERDY: LSE 就绪中断
  *                                RCC_IT_HSIRDY: HSI 就绪中断
  *                                RCC_IT_HSERDY: HSE 就绪中断
  *                                RCC_IT_PLLRDY: PLL 就绪中断
  *                                RCC_IT_CSS:    时钟安全系统中断
  *   
  * @返回  RCC_IT 的新状态(SETorRESET).
  */
ITStatus RCC_GetITStatus(uint8_t RCC_IT)
{
  ITStatus bitstatus = RESET;
  /* 检查参数 */
  assert_param(IS_RCC_GET_IT(RCC_IT));

  /* 检查指定的 RCC 中断状态 */
  if ((RCC->CIR & RCC_IT) != (uint32_t)RESET)
  {
    bitstatus = SET;
  }
  else
  {
    bitstatus = RESET;
  }

  /* 返回 RCC_IT 状态 */
  return  bitstatus;
}

/**
  * @简述  清除 RCC 中断挂起位.
  * @参数  RCC_IT: 指定要清除的中断挂起位.
  *   
  *        STM32_互联系列微处理器, 这个参数可以取下列值中的一个: 
  *                                RCC_IT_LSIRDY:  LSI 就绪中断
  *                                RCC_IT_LSERDY:  LSE 就绪中断
  *                                RCC_IT_HSIRDY:  HSI 就绪中断
  *                                RCC_IT_HSERDY:  HSE 就绪中断
  *                                RCC_IT_PLLRDY:  PLL 就绪中断
  *                                RCC_IT_PLL2RDY: PLL2 就绪中断
  *                                RCC_IT_PLL3RDY: PLL3 就绪中断                      
  *                                RCC_IT_CSS:     时钟安全系统中断
  * 
  *           其它_STM32_微处理器, 这个参数可以取下列值中的一个:           
  *                                RCC_IT_LSIRDY:  LSI 就绪中断
  *                                RCC_IT_LSERDY:  LSE 就绪中断
  *                                RCC_IT_HSIRDY:  HSI 就绪中断
  *                                RCC_IT_HSERDY:  HSE 就绪中断
  *                                RCC_IT_PLLRDY:  PLL 就绪中断
  *                                RCC_IT_CSS:     时钟安全系统中断
  * @返回  没有
  */
void RCC_ClearITPendingBit(uint8_t RCC_IT)
{
  /* 检查参数 */
  assert_param(IS_RCC_CLEAR_IT(RCC_IT));

  /* 执行 RCC_CIR[23:16] 位的字节存取来清除选择的中断挂起位*/
  *(__IO uint8_t *) CIR_BYTE3_ADDRESS = RCC_IT;
}

/**
  * @}
  */

/**
  * @}
  */

/**
  * @}
  */

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

⌨️ 快捷键说明

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