STM32学习003_STM32F10X的时钟配置

发布者:CrystalClear最新更新时间:2017-10-26 来源: eefocus关键字:STM32  STM32F10X  时钟配置 手机看文章 扫描二维码
随时随地手机看文章

一、在STM32中,有5个时钟源,为HSI,HSE,LSI,LSE,PLL.

①HSI是高速内部时钟,RC振荡器,频率为8MHz;

②HSE--高速外部时钟,可接石英或者陶瓷谐振器,或者外部时钟源,频率范围4MHz--15MHz.

③LSI--低速内部时钟,RC 振荡器,频率为40kHz.

④LSE--低速外部时钟,接频率为32.768KHz的石英晶体。

⑤PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2,HSE或者HSE/2,倍频可选择为2--16倍,但是其输出频率最大不得超过72MHz.

下图为STM32的时钟树。(图1)

STM32学习003_STM32F10X的时钟配置

                                                                     图1

        AHB (最大72M)

        APB1 (最大36M): DAC, PWR, BKP, CAN, SRAM, I2C, USART2~5, SPI2/3, RTC, TIM2~7

        APB2 (最大72M): ADC, SPI1, TIM1/8, GPIOA~F, EXTI, AFIO ,USART1

具体在RCC_Configuration函数中的体现。

第一步:系统时钟选择哪个,HSE、HSI还是PLLCLK。

RCC_HSEConfig(RCC_HSE_ON);    //使用HSE

如果HSE时钟已经稳定,硬件会将RCC_CR的HSERDY位置1。

第二步:判断HSE时钟是否稳定

if (RCC_WaitForHSEStartUp() == SUCCESS) //SUCCESS的含义要提前定义

第三步:使能FLASH的预取址缓冲区,并设置FLASH的等待状态。(具体功能见FLASH部分)

        FLASH_SetLatency(FLASH_Latency_2);   //flash2等待状态,操作的一个延时

        FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);     //Flash读取缓冲,加速

        第四步:设置AHB预分频系数。预分频系数可以是1、2、4、8、16、32、64、128、256;)(图2)

STM32学习003_STM32F10X的时钟配置

                 图2

        RCC_HCLKConfig(RCC_SYSCLK_Div1);    //AHB使用系统时钟   //HCLK = SYSCLK

第五步:设置APB2的预分频系数,来确定PCLK2频率。预分频系数可以是1、2、4、8、16

RCC_PCLK2Config(RCC_HCLK_Div1);    //APB2为HCLK/1     //PCLK2 = HCLK/1

第六步:设置APB1的预分频系数,来确定PCLK1频率。预分频系数可以是1、2、4、8、16

        RCC_PCLK1Config(RCC_HCLK_Div2);     //APB1为HCLK/2      //PCLK1 = HCLK/2

第七步:设置PLL的时钟源,以及PLL的倍频系数,来确定PLLCLK频率。(图3)

 STM32学习003_STM32F10X的时钟配置

                               图3

RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //PLLCLK = 8MHz * 9 = 72MHz

第八步:使能PLL。将RCC_CR的PLLON位置1。

RCC_PLLCmd(ENABLE); //启动PLL //Enable PLL
   如果PLL锁定后,硬件会将RCC_CR的PLLRDY位置1。

第九步:等待PLL锁定。

 while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); //等待PLL启动 

 第十步:选择PLL作为SYSCLK(系统时钟源)

 RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //将PLL设置为系统时钟源 

第十一步:等待系统时钟源的启动

 while(RCC_GetSYSCLKSource() != 0x08) ;         //等待系统时钟源的启动 

第十二步:开启要使用的外设时钟

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);  //打开GPIOA时钟
   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);  //打开GPIOC时钟
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);  //该引脚(TX)属于复用功能引脚
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE); //打开USART1 时钟

 

二、在STM32上如果不使用外部晶振,OSC_IN和OSC_OUT的接法,如果使用内部RC振荡器而不用外部晶振,请按照下面方法处理,

①对于100脚或者144脚的产品,OSC_IN应接地,OSC_OUT应悬空;

②对于少于100脚的产品,有2种接法,第一种:OSC_IN和OSC_OUT分别通过10K电阻接地,此方法可以提高EMC性能,第二种:分别重映射OSC_IN和OSC_OUT至PD0和PD1,再配置PD0和PD1为推挽输出,并输出0,此方法可以减小功耗并节省2个外部电阻。


关键字:STM32  STM32F10X  时钟配置 引用地址:STM32学习003_STM32F10X的时钟配置

上一篇:STM32学习002_固件库介绍
下一篇:STM32学习004_调试工具J_LINK

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

意法半导体STM32微控制器加密算法库通过美国安全标准认证
中国,2016年7月19日 横跨多重电子应用领域、全球领先的半导体供应商意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)的STM32微控制器加密算法库成功通过美国密码算法验证体系(US Cryptographic Algorithm Validation Program,CAVP)验证,有助于客户快速、经济地提高新产品的安全性。 作为STM32Cube软件包的扩展模块,X-CUBE-CRYPTOLIB算法库可直接用于基于STM32的注重安全的产品,包括物联网(IoT)硬件、销售终端设备、智能表计、门禁系统和指纹识别模块。CAVP认证免除了企业的算法验证负担,让那些想要获取美国联邦信息处理
[半导体设计/制造]
Crypto算法库使用技巧 —— 基于STM32 AES GCM应用提示
引言 X-CUBE-CRYPTOLIB 是基于 STM32 的 Crypto 算法库,支持对称密钥、非对称密钥、哈希等多种算法。正确地使用 Cyrptolib 算法库,可以在应用程序中实现数据加密、设备身份认证、加密通信等多种应用层所需的安全功能。相反,若不能正确地使用算法库往往会带来加解密数据错误等系列问题。 关于 STM32 Crypto 算法库应用中的常见的问题之一就是应用程序没有使能 MCU 的CRC 模块,尽管输出的数据和期望值不同,但加解密函数的调用并未返回异常。本文在此描述另外一种没有正确使用算法库的情况。 问题描述 客户应用项目中需要在固件更新过程中对固件进行加密并验证,根据推荐采用了 AES- GCM 算
[单片机]
STM32以太网程序解析二
--------------------------------------------------------------------------------------------------------------------------- 下面我们来详细看一下程序,我们将逐行的进行分析。 1. int simple_server(void) 2. { 3. unsigned int plen,dat_p,i1=0,payloadlen=0; 4. unsigned char i=0,*buf1 = 0; 5. signed char cmd; 6. 7. /
[单片机]
stm32 片上flash用作EEPROM(掉电保存)
#if !defined (_FLASH_H) #define _FLASH_H #define FLASH_ADR 0x08010000 //要写入数据的地址 #define u8 INT8U #define u16 INT16U #define u32 INT32U union union_temp16 { unsigned int un_temp16; unsigned char un_temp8 ; // example 16: 0x0102 8: 2 1 }my_unTemp16; typedef struct { u8 apn ; u8 useName ; u8 password ; u8 serverIP
[单片机]
STM32中的独立看门狗IWDG
一. 简述STM32中的看门狗系统 STM32F10xxx内置两个看门狗,一个是IWDG(独立看门狗),一个是WWDG(窗口看门狗),两个看 门狗设备(可用来检测和解决由软件错误引起的故障。 当计数器达到给定的超时值时,IWDG会产生系统复位。而WWDG会触发中断。这篇文章主要讲解一下IWDG。 二. 关于 独立看门狗IWDG 1. 独立看门狗(IWDG)由专用的低速时钟(LSI)驱动,即使主时钟发生故障它也仍然有效。IWDG最适合应用于那些需要看门狗作为一个在主程序之外,能够完全独立工作,并且对时间精度要求较低的场合。 2. IWDG主要性能 自由运行的递减计数器 时钟由独立的RC振荡器提供(可在
[单片机]
如何利用stm32的中断和计数器即上升沿下降沿捕获电平时长
/*! @file ******************************************************************************** PRE 模块名 : 红外解码文件 文件名 : IR_REMOTE.c 相关文件 : IR_REMOTE.h 文件实现功能 : 定时器红外解码 作者 : 李 版本 : -------------------------------------------------------------------------------- 硬件平台 : STM32F107 软件开发平台 : iar --------
[单片机]
如何利用<font color='red'>stm32</font>的中断和计数器即上升沿下降沿捕获电平时长
STM32 编译结果 map 之 code、RO-data、RW-data、ZI-data 字段解析
1、Code 即代码域,它指的是编译器生成的机器指令,这些内容被存储到ROM区。 2、RO-data Read Only data,即只读数据域,它指程序中用到的只读数据,这些数据被存储在ROM区,因而程序不能修改其内容。 例如: C语言中const关键字定义的变量就是典型的RO-data。 3、RW-data Read Write data,即可读写数据域,它指初始化为“非0值”的可读写数据,程序刚运行时,这些数据具有非0的初始值,且运行的时候它们会常驻在RAM区,因而应用程序可以修改其内容。 例如: C语言中使用定义的全局变量,且定义时赋予“非0值”给该变量进行初始化。 4、ZI-data Zero Ini
[单片机]
STM32系统中如何数据掉电保护
在嵌入式设备开发中,往往需要保存一些掉电不易失性的数据,如果系统配置、用户定制信息等等,如果增加额外的ROM IC,比如(基于I2C的24C02等等)往往会造成额外的PCB空间增大,硬件成本增加,降低产品的性价比。如果单从实用性来讲,在stm32的系统中,诸如此类的应用,笔者推荐如下2个方法可以去尝试和借鉴。 基于备份寄存器 原理:对于大容量的MCU系列来说,它有着42个16bit的备份寄存器,而中小容量的微处理器却只有10个16bit的备份寄存器。以STM32F103C8T6为例,42个备份寄存器的地址偏移为:0x04~0x28,0x40~0xBC,共可以存储84个byte数据。备份寄存器是依赖者备份电源的,当外界的VDD掉
[单片机]
<font color='red'>STM32</font>系统中如何数据掉电保护
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
热门活动
换一批
更多
设计资源 培训 开发板 精华推荐

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

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

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