stm32之RCC学习笔记

发布者:InnovateMind最新更新时间:2017-09-17 来源: eefocus关键字:STM32  RCC 手机看文章 扫描二维码
随时随地手机看文章

stm32芯片的所有片上外设都需要手动设置时钟。

三种不同的时钟源可被用来驱动系统时钟(SYSCLK):

  1. HSI振荡器时钟 
    由内部8MHz的RC振荡器产生,可直接作为系统时钟或在2分频后作为PLL输入。HSI RC振荡器能够在不需要任何外部器件的条件下提供系统时钟。它的启动时间比HSE晶体振荡器短。然而,即使在校准之后它的时钟频率精度仍较差。(所以通常不用与提供SYSCLK)

  2. HSE振荡器时钟: 
    高速外部时钟信号,由HSE外部晶体/陶瓷谐振器(较常用)或者HSE用户外部时钟两种方式产生

  3. PLL时钟 
    时钟源输入,内部PLL可以用来倍频HSI RC的输出时钟或HSE晶体输出时钟,一旦PLL被激活,这些参数就不能被改动。

二级时钟源 
当不被使用时,任一个时钟源都可被独立地启动或关闭,由此优化系统功耗。 
LSI 时钟 
40kHz低速内部RC,可以用于驱动独立看门狗和通过程序选择驱动RTC。RTC用于从停机/待机模式下自动唤醒系统 
LSE 时钟 
32.768kHz低速外部晶体也可用来通过程序选择驱动RTC(RTCCLK)。

配置时钟流程: 
1.将RCC寄存器重新设置为默认值, RCC_DeInit 
2.打开外部高速时钟晶振HSE, RCC_HSEConfig(RCC_HSE_ON); 
3.等待外部高速时钟晶振工作, HSEStartUpStatus =RCC_WaitForHSEStartUp(); 
4.设置AHB时钟, RCC_HCLKConfig; 
5.设置高速APB2时钟, RCC_PCLK2Config; 
6.设置低速速APB1时钟, RCC_PCLK1Config 
7.设置PLL, RCC_PLLConfig 
8.打开PLL, RCC_PLLCmd(ENABLE); 
9.等待PLL工作, while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) 
10.设置系统时钟, RCC_SYSCLKConfig 
11.判断是否PLL是系统时钟, while(RCC_GetSYSCLKSource() != 0x08) 
12.打开要使用的外设时钟 , RCC_APB2PeriphClockCmd()

代码如下:

/*! System Clocks Configuration */   void RCC_Configuration(void)   
{   
    ErrorStatus HSEStartUpStatus;   
    RCC_DeInit();              /* RCC寄存器恢复初始化值*/   
    RCC_HSEConfig(RCC_HSE_ON); /* Enable HSE 使能外部高速晶振*/   
    HSEStartUpStatus = RCC_WaitForHSEStartUp(); /* 等待外部高速晶振使能完成*/   
    if(HSEStartUpStatus == SUCCESS)   
    {   
/*设置PLL时钟源及倍频系数*/   
        RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_16); // PLL的输入时钟 = HSE时钟频率;RCC_PLLMul_16——PLL输入时钟x 16 ;HSE =4MHZ,所以PLLCLK=64MHZ   /*设置AHB时钟(HCLK)*/   
        RCC_HCLKConfig(RCC_SYSCLK_Div1); //RCC_SYSCLK_Div1——AHB时钟 = 系统时钟(SYSCLK) = 64MHZ(外部晶振4HMZ)   
        /*注意此处的设置,如果使用SYSTICK做延时程序,此时SYSTICK(Cortex System timer)=HCLK/8=8MHZ*/   /*设置低速AHB时钟(PCLK1)*/   
        RCC_PCLK1Config(RCC_HCLK_Div2); //RCC_HCLK_Div2——APB1时钟 = HCLK/2 = 32MHZ(外部晶振4HMZ)   /* 设置高速AHB时钟(PCLK2)*/   
        RCC_PCLK2Config(RCC_HCLK_Div1); //RCC_HCLK_Div1——APB2时钟 = HCLK = 64MHZ(外部晶振4HMZ)  /*设置FLASH存储器延时时钟周期数*/   
        FLASH_SetLatency(FLASH_Latency_2); //FLASH_Latency_1 1延时周期   /*FLASH时序延迟几个周期,等待总线同步操作。   
推荐按照单片机系统运行频率,0—24MHz时,取Latency=0;   
                       24—48MHz时,取Latency=1;   
                       48~72MHz时,取Latency=2*/   /*选择FLASH预取指缓存的模式*/   
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // 预取指缓存使能   /* Enable PLL 使能PLL*/   
        RCC_PLLCmd(ENABLE);/* Wait till PLL is ready */
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)    
    {   
    } 
/* Select PLL as system clock source */  
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);/* Wait till PLL is used as system clock source */    
    while(RCC_GetSYSCLKSource() != 0x08)    
    {   
    }   
}//end if(HSEStartUpStatus == SUCCESS)   /*开始使能程序中需要使用的外设时钟*/   // Enables or disables the High Speed APB(APB2) peripheral clock,APB2外设时钟使能   
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD |RCC_APB2Periph_GPIOE, ENABLE);   

    RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);   
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);   
/*!< SPI_FLASH_SPI Periph clock enable */   
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);   
/*!< AFIO Periph clock enable */   
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);   
}  123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051

下面贴几个用到的函数官方库解释:

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

大概就是这些


关键字:STM32  RCC 引用地址:stm32之RCC学习笔记

上一篇:stm32之USART串口配置
下一篇:stm32之assert_param 函数

推荐阅读最新更新时间:2024-03-16 15:37

stm32定时器输入捕获pwm
花了两天时间终于把stm32f103的定时器输入捕获弄懂了,这里以TIM3的通道ch1为例,要实现输入捕获需要配置一下寄存器,TIMx_ARR,TIMx_PSC,TIMx_CCMR1,TIMx_CCER,TIMx_DIER,TIMx_CR1,TIMx_CCR1.这里抓取了一些收据手册中寄存器描述的图 下面一一介绍: TIMx_ARR寄存器为自动重装载的值 TIMx_CR1这里了只要用到它的第0位即使能位。 TIMx_CCMR可以配置对应通道映射到那个IC,TI。 这里我们是第一通道故只需配置低8位,cc1s为配置ch1映射到那个TI,IC1PSC为配置是否分频,1c1f为配置是否滤波。 TIMx_psc寄存器 T
[单片机]
STM32总线架构讲解
01前文 本文主要进行学习总结,为他人提供参考和学习,也为了记录自己的学习知识进行总结,并且望有错误之处,请各位技术大佬们提出修正,互相进步,也便认识自己的不足之处,查漏补缺。 02前情提要 在说总线架构之前,要了解一些知识点,AMBA是什么、总线、矩阵的作用,了解了这些才能明白总线为何这样走,为何要有矩阵。 1、AMBA AMBA是ARM公司提出的一种开放性的SoC总线标准,现在已经广泛的应用于RISC的内核上了。 定义了一种多总线系统,包括系统总线和等级稍低的外设总线。 利用AMBA定义的一款总线架构: AHB (Advanced High-performance Bus) 高级高性能总线 ASB (Advanced Sy
[单片机]
<font color='red'>STM32</font>总线架构讲解
基于STM32从零写操作系统系列---使用C语言
目的 C语言,相对于汇编有更好的可读性,便于维护等优点。下面实验将使用C语言实现点亮LED灯。C语言与硬件是紧密连在一起的,结合芯片中的flash和sram,简单了解C语言。 要求 1.有一定的C语言基础 2.了解编译链接脚本 3.了解stm32F103的硬件结构 实验源代码在这下载,代码中有详细注释! 分析 1.首先了解硬件,如图 FLASH,就是存放.bin文件的地方。SRAM,用于存放程序的堆栈,全局变量。 2.了解链接脚本,如图: MEMORY,用于定义存储器范围。 AT rom,表示将对应的SECTION放置到rom中,即Flash中。 _data_start / _data_end,用
[单片机]
基于<font color='red'>STM32</font>从零写操作系统系列---使用C语言
STM32使用之GPIO
//********************************************************************** //*********************************************************************** /*********************************************************************** main文件,GPIO操作,完成最简单的IO操作实验,就是控制LED灯 4个LED分别对应PC的6、7、8、9引脚。4个LED流水显示 *******************************
[单片机]
stm32专题三十六:MDK编译过程和文件类型(一)
MDK编译过程和文件类型 1 编译过程 (1)编译:MDK 软件使用的编译器是 armcc 和 armasm,它们根据每个 c / c++和汇编源文件编译成对应的以“.o”为后缀名的对 象文件(Object Code,也称目标文件),其内容主要是从源文件编译得到的机器码,包含了代码、数据以及调试使用的信息; 编译器: .o文件(每个.c文件,编译完都会生成.o目标文件): (2)链接:链接器 armlink 把各个.o 文件及库文件链接成一个映像文件 “.axf” (MDK)或 “.elf”(IAR) ; (3)对链接器生成的 elf 映像文件利用格式转换器fromelf 转换成“.bin”或“.hex”
[单片机]
<font color='red'>stm32</font>专题三十六:MDK编译过程和文件类型(一)
STM32中的位带(bit-band)操作
//位带操作,实现51类似的GPIO控制功能 //具体实现思想,参考 CM3权威指南 第五章(87页~92页). //IO口操作宏定义 #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF) 5)+(bitnum 2)) #define MEM_ADDR(addr) *((volatile unsigned long *)(addr)) #define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum)) //IO口地址映射 #define GPIOA_ODR_Addr
[单片机]
STM32学习笔记——AFIO时钟的配置问题
最近在写程序时发现设置外部中断出了问题,之前的程序好好的怎么就不能用了呢?经过了一晚上的折腾发现问题出在AFIO时钟的配置上,我没有使能AFIO时钟。 什么时候要开启AFIO呢?参考手册: 说的很明白,操作AFIO的三类寄存器时需要开启: 1.事件控制寄存器(AFIO_EVCR) 2.复用重映射和调试I/O配置寄存器(AFIO_MAPR) 3.外部中断配置寄存器x(AFIO_EXTICRx) 这三类其实是AFIO的全部寄存器, AFIO_EVCR是事件相关的,AFIO_MAPR是与重映射和调试I/O相关的,AFIO_EXTICRx是与外部中断相关的。因此管脚重映射和调试I/O配置、外部中断、事件时需开启AFIO。 再回
[单片机]
stm32指令集合不区分大小写
单片机中接收到奥串口的指令一般为字符串,如果使用strncmp比较是否为我们的指令集中的指令,则不能区分大小写,这里可以使用strcasecmp( )函数和strncasecmp( )函数,来对接收到的字符串指令进行接收比较,并且可以不区分大小写,包含头文件include“stdio.h” 下面对strcasecmp( )函数和strncasecmp( )函数的原型以及应用进行介绍: strcasecmp( )函数说明: strcasecmp()用来比较参数s1和s2字符串,比较时会自动忽略大小写的差异。 返回值 若参数s1和s2字符串相同则返回0。s1长度大于s2长度则返回大于0 的值,s1 长度若小于s2 长度则返回小
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved