STM32时钟系统图

合集下载

stm32单片机时钟

stm32单片机时钟

stm32单⽚机时钟stm32 单⽚机时钟学习以及分析1 引⾔:单⽚机(Microcontrollers),采⽤超⼤规模集成电路技术把具有数据处理能⼒的中央处理器CPU、随机存储器RAM、只读存储器ROM、多种I/O⼝和中断系统、定时器/计数器等功能(可能还包括显⽰驱动电路、脉宽调制电路、模拟多路转换器、A/D转换器等电路)集成到⼀块硅⽚上构成的⼀个⼩⽽完善的微型计算机系统,在⼯业控制领域⼴泛应⽤。

单⽚机时钟可以说如同⼈的⼼脏那样重要,我们在⼼脏的搏动下进⾏⾃⼰的⽣命活动,同样的单⽚机在时钟下进⾏⾃⼰的控制活动。

2 时钟的分类:单⽚机的时钟分为内部时钟与外部时钟:⼀般⽽⾔,内部时钟集成在芯⽚内部(RC振荡电路),其精度⽐较低;外部时钟,顾名思义,存在于芯⽚外部(晶体或陶瓷谐振器),可以为系统提供精确的时钟。

晶振是给单⽚机提供⼯作信号脉冲的,如图所⽰的为外部晶振,频率为4MHz,我们常⽤的晶振频率为12MHz,单⽚机⼯作时,是⼀条⼀条地从RoM中取指令,然后⼀步⼀步地执⾏。

单⽚机访问⼀次存储器的时间,称之为⼀个机器周期,这是⼀个时间基准。

—个机器周期包括12个时钟周期。

如果⼀个单⽚机选择了12MHz晶振,它的时钟周期是1/12us,它的⼀个机器周期是12×(1/12)us,也就是1us。

有些晶振的频率并数是整数,如:11.0592MHz的晶振。

单⽚机在进⾏串⾏通信时,常⽤的波特率为1200,2400,4800,9600,115200等,为了适应单⽚机的串⼝通讯波特率的计算⽽来的。

⽤11.0592MHz晶振经过相应的分频或者倍频后刚好能够得出⼀个整数的波特率,这样在上位机和下位机的同步⽅⾯⽐较⽅便。

3 stm32的时钟来源这⾥以stm32f1系列的芯⽚为例。

由上⾯可知,系统的时钟来源有内部时钟与外部时钟,详细的来说stm32f1有五个时钟源:HSI(⾼速内部时钟)HSE(⾼速外部时钟)LSI(低速内部时钟)LSE(低速外部时钟)PLL(锁相环倍频输出)每⼀个时钟都可以独⽴的开启与关闭。

STM32F4时钟树概述

STM32F4时钟树概述

STM32F4时钟树概述STM32F4 相对于 STM32F1 来说,时钟部分复杂了很多, STM32F4 的时钟配置,我们提供两个函数: Sys_Clock_Set 和Stm32_Clock_Init。

其中 Sys_Clock_Set 是核⼼的系统时钟配置函数,由 Stm32_Clock_Init 调⽤,实现对系统时钟的配置。

外部程序,⼀般调⽤ Stm32_Clock_Init函数来配置时钟。

sys⽂件夹中在 STM32F4 中,有 5 个最重要的时钟源,为 HSI、 HSE、 LSI、 LSE、 PLL。

其中 PLL 实际是分为两个时钟源,分别为主 PLL 和专⽤PLL。

从时钟频率来分可以分为⾼速时钟源和低速时钟源,在这 5 个中 HSI, HSE 以及 PLL 是⾼速时钟, LSI 和 LSE 是低速时钟。

从来源可分为外部时钟源和内部时钟源,外部时钟源就是从外部通过接晶振的⽅式获取时钟源,其中 HSE 和LSE 是外部时钟源,其他的是内部时钟源。

①、 LSI 是低速内部时钟, RC 振荡器,频率为 32kHz 左右。

供独⽴看门狗和⾃动唤醒单元使⽤。

②、 LSE 是低速外部时钟,接频率为 32.768kHz 的⽯英晶体。

这个主要是 RTC 的时钟源。

③、 HSE 是⾼速外部时钟,可接⽯英/陶瓷谐振器,或者接外部时钟源,频率范围为 4MHz~26MHz。

我们的开发板接的是 8M 的晶振。

HSE 也可以直接做为系统时钟或者 PLL 输⼊。

④、 HSI 是⾼速内部时钟, RC 振荡器,频率为 16MHz。

可以直接作为系统时钟或者⽤作 PLL输⼊。

⑤、 PLL 为锁相环倍频输出。

STM32F4 有两个 PLL:1)主 PLL(PLL)由 HSE 或者 HSI 提供时钟信号,并具有两个不同的输出时钟。

第⼀个输出 PLLP ⽤于⽣成⾼速的系统时钟(最⾼ 168MHz)第⼆个输出 PLLQ ⽤于⽣成 USB OTG FS 的时钟(48MHz),随机数发⽣器的时钟和 SDIO时钟。

stm32的时钟配置(非常详细)

stm32的时钟配置(非常详细)

stm32的时钟配置(⾮常详细)⼤家都知道在使⽤单⽚机时,时钟速度决定于外部晶振或内部RC振荡电路的频率,是不可以改变的。

⽽ARM的出现打破了这⼀传统的法则,可以通过软件随意改变时钟速度。

这⼀出现让我们的设计更加灵活,但是也给我们的设计增加了复杂性。

为了让⽤户能够更简单的使⽤这⼀功能,STM32的库函数已经为我们设计的更加简单⽅便。

在⽐较靠前的版本中,我们需要向下⾯那样设置时钟:ErrorStatus HSEStartUpStatus;void RCC_Configuration(void){RCC_DeInit(); // RCC system reset(for debug purpose)RCC_HSEConfig(RCC_HSE_ON); // Enable HSEHSEStartUpStatus = RCC_WaitForHSEStartUp(); // Wait till HSE is readyif (HSEStartUpStatus == SUCCESS) // 当HSE准备完毕切振荡稳定后{RCC_HCLKConfig(RCC_SYSCLK_Div1); // HCLK = SYSCLKRCC_PCLK2Config(RCC_HCLK_Div1); // PCLK2 = HCLKRCC_PCLK1Config(RCC_HCLK_Div2); // PCLK1 = HCLK/2FLASH_SetLatency(FLASH_Latency_2); // Flash 2 wait stateFLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // Enable Prefetch BufferRCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); // PLLCLK = 8MHz * 9 = 72 MHzRCC_PLLCmd(ENABLE); // Enable PLLwhile(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET){; // Wait till PLL is ready}RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); // Select PLL as system clock sourcewhile (RCC_GetSYSCLKSource() != 0x08) // Wait till PLL is used as system clock source {;}}}随之函数库的不断升级,到3.0以上时,我们就不⽤再这样编写时钟设置了,我们只要做如下两部即可:第⼀个: system_stm32f10x.c 中 #define SYSCLK_FREQ_72MHz 72000000第⼆个:调⽤SystemInit()说明:在stm32固件库3.0中对时钟频率的选择进⾏了⼤⼤的简化,原先的⼀⼤堆操作都在后台进⾏。

基于STM32的电子时钟设计

基于STM32的电子时钟设计

第39卷第11期2020年11月绵阳师范学院学报Journal of Mianyang Teachers'CollegeVol.39No.11Nov.2020D01:10.16276/51-1670/g.2020.11.005基于STM32的电子时钟设计郭辛(绵阳师范学院机电工程学院,四川绵阳621000)摘要:随着嵌入式技术的应用与推广.ARM32位处理器已逐步占据电子消费品和工业测控制造领域主导地位.本文以Cortex-M系列产品的典型代表STM32F103RC为平台,采用固件库技术思想为导向,按照CMSIS标准构建工程,将定时器、LCD驱动以及中断系统等各功能模块进行整合,设计一款电子时钟.通过综合设计的应用开发,摸索和总结出一套针对STM32的学习和设计方法,为高端处理器的应用开发提供新思路.关键词:STM32;嵌入式系统;固件库;定时器;LCD显示中图分类号:TN91文献标志码:A文章编号:1672-612X(2020)11-0028-040引言单片机自诞生之日起已走过近半个世纪的历程.随着电子技术和计算机技术的飞速发展,进入21世纪以来以嵌入式系统为代表的新兴技术正在逐渐占据工业控制领域主导地位,并逐步取代以8位处理器为核心的传统测控系统⑴.近年来由于数字信息技术和网络技术的广泛应用,单片机作为主流核心处理器的地位逐步下降,现代电子技术的发展正朝着智能化、网络化和低功耗的方向迈进•新技术的不断更新,需要新的设计思想的注入才能满足技术发展需求•那么,如何将新兴技术融合到传统知识架构体系,将基础理论与工程应用实际相结合,就成为设计人员急需破解的难题•ARM作为一种32位的高性能、低成本的嵌入式RISC微处理器,得到了广泛的应用,STM32系列是意法半导体(STMicroelectronics)集团专为要求高性能、低成本和低功耗的嵌入式应用设计的ARM Cortex-M系列产品的代表作•基于STM32的嵌入式技术已经渗透在工业控制系统、数据采集系统、智能化仪器仪表和办公自动化等诸多领域的应用,甚至在很大程度上正在改变我们现有的商业模式和工作生活方式,如智能手机、导航系统、无人机和平板电脑等,并呈现出明显的系统化、人工智能化和物联网的趋势.目前,Cortex系列处理器已经占据了大部分嵌入式处理器的中高端产品市场,而嵌入式系统的应用开发对从业者要求很高,初学者若要快速掌握其原理并在实际工程中加以应用,必须改变传统的思维方式并构建新的设计理念■本文以STM32F103RC处理器(Cortex-M普通型号之一)为平台,通过对定时器、中断系统和LCD显示模块的组合设计为例,针对基于固件库设计思想的方法进行探讨与总结,以开启嵌入式系统的应用设计学习之门⑵.1固件库概述固件库是指“STM32标准函数库”,它是由ST公司针对STM32提供的函数接口,即API(Application Pro­gram Interface),是一个固件函数包,它由程序、数据结构和宏组成,包括了微控制器所有外设的性能特征.它是架设在构成部件的寄存器与用户驱动层之间的代码,向下处理与寄存器直接相关的配置,向上为用户提供配置寄存器的接口⑶.部件的调用和基本操作写成了通用的子函数,对复杂的硬件操作实现了函数封装■在以51单片机为代表的8位机由于硬件系统相对简单,通常采用宜接配置寄存器的方式来进行应用开发;而32位处理器核内系统复杂,外设资源丰富•应用系统若仍旧采用传统的设计方式,不但效率低、可移收稿日期:2020-04-30作者简介:郭辛(1971-),男,四川成都人,讲师,硕士,研究方向:汽车电子控制技术.绵阳师范学院学报(自然科学版)植性差,而且技术难度大,已不能适应较复杂的工程应用•基于固件库的技术思想为解决这一问题提供了新思路:开发者根据具体任务需求按照CMSIS标准构建工程,利用固件库提供的资源,设计和改造相关函数以实现对部件的操作•本文结合综合实验项目的开发——电子时钟的设计为例,首先介绍库函数中主要涉及的定时器和LCD显示驱动的基本结构和工作原理,在此基础上利用现有库资源进行功能设计与系统构建•2定时器概述STM32F1系列中,共有8个定时器TIM1-TIM8,分为基本定时器,通用定时器和高级定时器.基本定时器TIM6和TIM7是一个16位的只能向上计数的定时器,它只能定时,没有外部I/O;通用定时器TIM2/ 3/4/5是一个16位的可以向上/下计数的定时器,可以定时、输出比较和输入捕捉,每个定时器有四个外部I/O;高级定时器TIM1/8是一个16位的可以向上/下计数的定时器,可以定时、输出比较,输入捕捉,以及实现三相电机互补输出信号,每个定时器有8个外部I/O⑷.此例以TIM6作定时器,设计一款LCD屏显电子时钟,计时60min,最小显示值Is.2.1TIM6定时器组成根据STM32参考手册基本定时器的功能结构如图1所示⑶.定时器若要向外提供基本时钟信号,需对相关寄存器进行参数设置:1)时钟源TIM*CLK:根据STM32时钟系统设置,通常挂载APB1时钟总线,默认取值为72MH z[5];2)16位分频器PSC:用于存放预分频值,分频范围1-65536,则时钟周期图1基本定时器功能框图Fig.l Block Diagram of Basic Timer FunctionCK_CLK=(PSC+1)/TIM*CLK(1)即每计1个数的时间间隔3)自动重装载寄存器ARR:用于存放16位计数值,用于设定定时长度Td=CK_CLK*ARR(2)综上所述,首先对定时器初始化,将所预设参数写入到对应的结构体中,赋值包含以下内容:#define BASIC_TIM#define BASIC_TIM_CLK #define BASIC_TIM_ARR #define BASIC_TIM_PSC TIM6RCC_APB1Periph_TIM6 1000-171按照以上参数设置,基本定时时长为:Td=〔(PSC+1)/TIM*C LK〕*A RR=(72/72M)*1000=1ms(3) 2.2电子时钟定时原理如图2所示,内部定时器提供基准时长Td=lms,引入定时中断,每计时1ms中断一次;中断次数time二1000产生Is定时,即LCD显示屏每隔1s更新一次秒位(sec)计数值;每计满60s更新一次分位(min)计数值,并将其分别显示到LCD屏上.2.3LCD显示内部时基信号产生后,还需将结果显示出来,每次中断定时时长为:Td=((PSC+1)/TIM*CLK)*ARRL J701ARR MAX(65535)ls=Td*t ime(中断次数)图2定时原理示意图Fig.2Schematic Diagram of Timing PrincipleSTM32F103实验板配2.8吋16位数据接口液晶屏,控制芯片采用了ILI0341.ILI0341是一个用于TFT液晶郭辛:基于STM32的电子时钟设计显示的单芯片控制驱动器,具有262,144色的240RGBX320像素显示方案;IU0341支持8/9/16/18位数据总线的MCU接口,6/16/18位数据总线的RGB接口以及3/4线的SPI接口⑷,本示例中液晶屏控制器采用了预先配置的8080接口通讯,使用16根数据线的RGB565格式.其相关驱动程序按照IU9341标准编制,主要由如下几步完成:1)初始化LCD数据/控制管脚ILI9341_GPIO_Config().2)点亮背光ILI9341_BackLed_Control(ENABLE).3)初始化控制寄存器ILI9341_REG_Config().4)设置显示模式ILI9341_GramScan(LCD_SCAN_MODE).初始化液晶屏完成后,调用显示驱动函数•5)清屏ILI9341_Clear(0,0,LCD_X_LENGTH,LCD_Y_LENGTH).6)设置显示字符字体(8x16)、颜色(红字)及背景(黑底)LCD_SetFont(&Font8xl6);LCD_SetColors (RED,BLACK).7)使用c标准库把时间变量转化成字符串并显示sprintf(dispBuff,"time:%d:%d”,y,x);[6]LCD_ ClearLine(LINE(6));ILI9341_DispStringLine_EN(UNE(6),dispBuff).将数据转换成字符串,存放于数组dispBuff并写入指定行•3系统设计在以51单片机为主控单元的系统中,我们往往采用直接配置寄存器控制字的方法来操控硬件,因为MCS-51内部寄存器只有21个,而且功能简单,程序设计宜观简便;而STM32作为系统主控制器,其内部设备多达几十个,而控制这些设备的寄存器有几百个,若要使系统维持基本运转,操作这些寄存器所需的驱动程序代码成千上万行,这对于应用开发者来说逐条写程序是不现实的•芯片厂商将这些外设的驱动源码封装成固件函数包提供给用户,由用户在此基础上进行应用开发,因此以STM32为主控制器的应用系统开发就包括项目搭建和程序设计两部分•3.1固件库文件结构分析1)启动文件startup_stm32fl0x_hd.s:设置堆栈、PC指针和配置系统时钟等.2)时钟配置文件system_stm32fl0x.c:将外部时钟倍频并为各子模块提供配套的时钟源.3)内核相关的驱动文件core_cm3.h:内核的外设寄存器映射;core_cm3.c:内核的夕卜设驱动固件库•NVIC(嵌套向量中断控制器)描述文件:misc.h和misc.c.4)夕卜设相关的库文件stm32fl0x.h:实现了内核之夕卜的寄存器映射;stm32fl0x_xx.c:夕卜设的驱动函数库文件;核外设备:GPIO、USRAT、I2C、SPI、FSMC等驱动文件.5)头文件的配置文件stm32flO X_conf.h头文件的配置文件,将多个外设的头文件进行统一调配管理,如:stm32fl0x_usart.h,stm32fl0x_i2c.h,stm32fl0x_spi.h,stm32fl0x_adc.h, stm32f10x_fsmc.h...对外设描述的结构体,映射地址的头文件都放在stm32fl0x_conf.h中进行声明,使用时只需包含该配置头文件即可,并可通过“宏断言”函数进行选配•6)专门注册中断服务函数的C文件:stm32fl0x_it.c和stm32fl0x_it.h.这些文件按照相应的规贝!]分布在不同的路径下,这个规则就是ST集团与各芯片开发商共同制订的CMSIS标准⑶.3.2工程项目构建参照CMSIS标准创建项目文件以及组文件夹:CMSIS、FWlib、inc、src、Project、Output和User,并将固件库提供的基本源代码拷贝到对应目录下,如:项目文件创建并保存在Project路径下;核外外设的驱动程序复制到src源码目录下;对描述部件的寄存器结构体统一定义在inc头文件目录下;而宜接针对任务而设计的程序文件通常放置在用户目录User中,如main()程序,中断服务程序等等.在本例的电子时钟设计中,根据前面所介绍的定时器和LCD的工作原理,配置相关驱动程序或函数集,并写入预设的定时参数,重新组合、设计功能程序:1)计算并确定定时初值以及另濒器参数;2)LCD初始化机模式配置,设计变量显示程序;3)中断服务程序的数据处理部分程序设计-绵阳师范学院学报(自然科学版)3.3程序设计首先对定时器、中断寄存器、AFIO 引脚以及液晶屏进 行初始化设置,并将设计的参数值写入对应寄存器中;开启 定时时钟和中断系统,主程序实时不间断显示时间——分 位(min)和秒位(sec);中断服务程序完成定时器计数值的 更新和处理,并将其转换成时间变量传回主程序显示,程序 流程图见图3.4结论由于内部时钟源能提供1K~72MHz 时钟信号,误差 为±1%,则时钟误差最小可以控制在0. 01 us 范围内.通 过上述实验教学项目的开发,总结出32位微处理平台在工 程实践中的设计流程:(1)任务分析:根据设计要求明确项 目所需实现功能,提出设计方案主体框架、功能模块构成、 技术实现路线;(2)搭建工程项目:根据STM32平台所提供 资源,确定主控系统模块并搭建项目主体框架;对照现有资 源匹配现有的子模块,制作与主系统的接口函数并确定底 层部件参数;(3)主系统集成:完成主要业务的程序编制并 进行系统整和调试.基于STM32平台的嵌入式系统开发, 应采用立足于对系统资源的整合和集成的思维方式,将各 部件的驱动程序看作一种供开发者使用的函数集合,开发 主程序流程图|清除定時中断标志|开始Itime++I 中断服务流程图图3程序流程图Fig.3 Program Flow Chart 者需要做的是将这些离散、抽象的“程序块”有机地进行组合,以搭积木的方式进行模块化设计,这才是嵌入 式系统应用的本质所在.参考文献:[1]严武军.后PC 时代计算机专业建设的思考和探索[J].现代计算机,2011,23:92-97.[2]张良.Multisim 在“自动控制原理”实验教学中的应用[J].绵阳师范学院学报,2019,11(38):27-32.[3]刘火良.STM32库开发实战指南[M].北京:机械工业出版社,2017:317-403.[4]田泽.ARM9嵌入式开发实验与实践[M].北京:北京航空和航天大学出版社,2006:279-282.[5]Jean brosse .嵌入式实时操作系统|jl C\OS-U [ M].邵贝贝译.北京:北京航天航空大学出版社,2007: 116-121.[6] 苏小红.C 语言大学实用教程[M].北京:电子工业出版社,2011:309-322.The Design of An Electronic Clock Based on STM32GUO Xin(School of Mechanical and Electrical Engineering , Mianyang Teachers x College , Mianyang , Sichuan 621000)Abstract : With the development of the embedded system technology , ARM32 bit processor has gradually taken a dominant position in the field of electronic consumer goods and industrial measurement and control manu ­facturing. This paper takes The STM32F103RC , a typical representative of Cortex-M series products , as the plat ­form, adopts the technical thought of firmware library as the guidance , and builds projects according to CMSIS standard , integrates various functional modules such as timer , LCD driver and interrupt system , and designs an e- lectronic clock. Through the application development of comprehensive design , a set of learning and design methods for STM32 is explored and summarized to provide new ideas for the application development of high-end processors.Keywords : STM32, embedded system , firmware library , timer , LCD display(责任编辑:陈桂芳)。

stm32定时器时钟以及中间对齐模式

stm32定时器时钟以及中间对齐模式

stm32定时器时钟以及中间对齐模式在永磁同步电机的控制中,需要对电机的三相定⼦施加⼀定的电压,才能控制电机转动。

现在⽤的较多的是SVPWM(SVPWM的具体原理会在后⾯另写⼀篇博客说明),要想产⽣SVPWM波形,需要控制的三相电压呈如下形式,即A、B、C三相的电压是中间对齐的,这就需要⽤到stm32定时器的中间对齐模式了。

1、stm32的时钟树stm32的时钟树如下图所⽰,简单介绍⼀下stm32时钟的配置过程。

以外部时钟作为时钟源为例。

HSE代表外部时钟(假设为8M)、SYSCLK为系统时钟,经过倍频器之后变成168M、SYSCLK经过AHB预分频器(假设分频系数为1)后变成HCLK时钟等于系统时钟SYSCLK,HCLK即AHB外部总线时钟,经过APB预分频器分出APB1时钟(分频系数为2,低速设备SYSCLK/4)与APB2时钟(分频系数为1,⾼速设备SYSCLK/2)HSE->SYSCLK->HCLK->APB1、APB2。

针对stm32f427的配置源码如下static void SetSysClock(void){#if defined (STM32F40_41xxx) || defined (STM32F427_437xx) || defined (STM32F429_439xx) || defined (STM32F401xx)/******************************************************************************//* PLL (clocked by HSE) used as System clock source *//******************************************************************************/__IO uint32_t StartUpCounter = 0, HSEStatus = 0;/* Enable HSE */RCC->CR |= ((uint32_t)RCC_CR_HSEON);/* Wait till HSE is ready and if Time out is reached exit */do{HSEStatus = RCC->CR & RCC_CR_HSERDY;StartUpCounter++;} while((HSEStatus == 0) && (StartUpCounter != HSE_STARTUP_TIMEOUT));if ((RCC->CR & RCC_CR_HSERDY) != RESET){HSEStatus = (uint32_t)0x01;}else{HSEStatus = (uint32_t)0x00;}if (HSEStatus == (uint32_t)0x01){/* Select regulator voltage output Scale 1 mode */RCC->APB1ENR |= RCC_APB1ENR_PWREN;PWR->CR |= PWR_CR_VOS;/* HCLK = SYSCLK / 1*/RCC->CFGR |= RCC_CFGR_HPRE_DIV1;//AHB时钟#if defined (STM32F40_41xxx) || defined (STM32F427_437xx) || defined (STM32F429_439xx)/* PCLK2 = HCLK / 2*/RCC->CFGR |= RCC_CFGR_PPRE2_DIV2;//APB2时钟/* PCLK1 = HCLK / 4*/RCC->CFGR |= RCC_CFGR_PPRE1_DIV4;//APB1时钟#endif /* STM32F40_41xxx || STM32F427_437x || STM32F429_439xx *//* Configure the main PLL */RCC->PLLCFGR = PLL_M | (PLL_N << 6) | (((PLL_P >> 1) -1) << 16) |(RCC_PLLCFGR_PLLSRC_HSE) | (PLL_Q << 24);/* Enable the main PLL */RCC->CR |= RCC_CR_PLLON;/* Wait till the main PLL is ready */while((RCC->CR & RCC_CR_PLLRDY) == 0){}#if defined (STM32F427_437xx) || defined (STM32F429_439xx)/* Enable the Over-drive to extend the clock frequency to 180 Mhz */PWR->CR |= PWR_CR_ODEN;while((PWR->CSR & PWR_CSR_ODRDY) == 0){}PWR->CR |= PWR_CR_ODSWEN;while((PWR->CSR & PWR_CSR_ODSWRDY) == 0){}/* Configure Flash prefetch, Instruction cache, Data cache and wait state */FLASH->ACR = FLASH_ACR_PRFTEN | FLASH_ACR_ICEN |FLASH_ACR_DCEN |FLASH_ACR_LATENCY_5WS; #endif /* STM32F427_437x || STM32F429_439xx *//* Select the main PLL as system clock source */RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));RCC->CFGR |= RCC_CFGR_SW_PLL;/* Wait till the main PLL is used as system clock source */while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS ) != RCC_CFGR_SWS_PLL);{}}else{ /* If HSE fails to start-up, the application will have wrong clockconfiguration. User can add here some code to deal with this error */}}2、stm32定时器的时钟stm32定时器分为⾼级定时器(TIM1与TIM8)、通⽤定时器(TIM2-TIM5、TIM9-TIM14)、基本定时器(TIM6、TIM7)。

STM32F051使用自带时钟48M设置

STM32F051使用自带时钟48M设置
{
}
}
去掉外部晶振后,单片机时钟源会默认的使用内部高速RC振荡器HSI,HSI频率大约为8M,所以要想使系统获得48M的频率需要用PLL倍频后做为系统的时钟,PLL是一个锁相环,专门用来倍频或者分频的。(倍频后所得的频率一般叫PLL时钟)
RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_12);
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{
}
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
while(RCC_GetSYSCLKSource() != 0x08) //µÈ´ýϵͳʱÖÓ³õʼ»¯³É¹¦
whilerccgetsysclksource去掉外部晶振后单片机时钟源会默认的使用内部高速rc振荡器hsihsi频率大约为8m所以要想使系统获得48m的频率需要用pll倍频后做为系统的时钟pll是一个锁相环专门用来倍频或者分频的
正确设置:
void RCC_Configuration(void);
void RCC_Configuration(void)
{
//ÉèÖÃPLLʱÖÓÔ´¼°±¶ÆµÏµÊý
RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_12);///*!< PLL input clock*12*/
//ʹÄÜPõʼ»¯³É¹¦
这句话的意思是将HSI时钟12倍频,为什么是12倍频而不是6倍频呢?如下图STM32F051系列的时钟树所示:
根据时钟树可以看出用PLL对HSI进行倍频时,硬件将首先对HSI二分频,也就是为4M,所以必须再对其进行12倍频才能变成48M,最后通过RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);语句将PLL时钟作为系统时钟,至此系统的时钟变为48M

图文详解stm32时钟树

图文详解stm32时钟树

对于广大初次接触STM32的读者朋友(甚至是初次接触ARM器件的读者朋友)来说,在熟悉了开发环境的使用之后,往往“栽倒”在同一个问题上。

这问题有个关键字叫:时钟树。

众所周知,微控制器(处理器)的运行必须要依赖周期性的时钟脉冲来驱动——往往由一个外部晶体振荡器提供时钟输入为始,最终转换为多个外部设备的周期性运作为末,这种时钟“能量”扩散流动的路径,犹如大树的养分通过主干流向各个分支,因此常称之为“时钟树”。

在一些传统的低端8位单片机诸如51,AVR,PIC等单片机,其也具备自身的一个时钟树系统,但其中的绝大部分是不受用户控制的,亦即在单片机上电后,时钟树就固定在某种不可更改的状态(假设单片机处于正常工作的状态)。

比如51单片机使用典型的12MHz晶振作为时钟源,则外设如IO口、定时器、串口等设备的驱动时钟速率便已经是固定的,用户无法将此时钟速率更改,除非更换晶振。

而STM32微控制器的时钟树则是可配置的,其时钟输入源与最终达到外设处的时钟速率不再有固定的关系,本文将来详细解析STM32微控制器的时钟树。

图1是STM32微控制器的时钟树,表1是图中各个标号所表示的部件。

标号图1标号释义1 内部低速振荡器(LSI,40Khz)2 外部低速振荡器(LSE,32.768Khz)3 外部高速振荡器(HSE,3-25MHz)4 内部高速振荡器(HIS,8MHz)5 PLL输入选择位6 RTC时钟选择位7 PLL1分频数寄存器8 PLL1倍频寄存器9 系统时钟选择位10 USB分频寄存器11 AHB分频寄存器12 APB1分频寄存器13 AHB总线14 APB1外设总线15 APB2分频寄存器16 APB2外设总线17 ADC预分频寄存器18 ADC外设19 PLL2分频数寄存器20 PLL2倍频寄存器21 PLL时钟源选择寄存器22 独立看门狗设备23 RTC设备图1 STM32的时钟树在认识这颗时钟树之前,首先要明确“主干”和最终的“分支”。

STM32F103RC系统时钟配置

STM32F103RC系统时钟配置

地址:安徽省、合肥市、肥东县、店埠镇,合肥市福来德电子科技有限公司 STM32F103RC 系统时钟配置1、打开D:\program\KEL_MDT_ARM\STM32_Template\USER 目录,找到STM32-DEMO 文件,双击打开,KEIL-uVision4就开始运行了,得到下图:2、双击“STARTCODE ”下面的“start_stm32f10x_hd.s ”打开STM32F103RC 的启动文件,找“SystemInit ”,得到下图:地址:安徽省、合肥市、肥东县、店埠镇,合肥市福来德电子科技有限公司3、点击当前的行,右击鼠标,将光标移动到“Go To Definition Of SystemInit”,见下图:4、点击“Go To Definition Of SystemInit ”,会跳转到system_stm32f10x.c 文件,见下图:地址:安徽省、合肥市、肥东县、店埠镇,合肥市福来德电子科技有限公司5、在“system_stm32f10x.c ”文件中,在“void SystemInit (void)”函数体内找到“SetSysClock();”,见下图:6、点击“SetSysClock()”,右击鼠标,将光标移动到“Go To Definition Of SystemClock”,见下图:地址:安徽省、合肥市、肥东县、店埠镇,合肥市福来德电子科技有限公司 7、点击“Go To Definition Of SystemClock”,会跳转到system_stm32f10x.c 文件,见下图:8、点击“defined SYSCLK_FREQ_72MHz ”,右击鼠标,将光标移到到“Go To Definition Of SYSCLK_FREQ_72MHz ”,见下图:地址:安徽省、合肥市、肥东县、店埠镇,合肥市福来德电子科技有限公司9、点击“Go To Definition Of SYSCLK_FREQ_72MHz ”,会跳转到下图:10、在上图中,我们可以设置所需要的系统时钟,这里设置系统时钟是SYSCLK_FREQ_72MHz ,见下面粘贴的部分#if defined (STM32F10X_LD_VL) || (defined STM32F10X_MD_VL) || (defined STM32F10X_HD_VL) /* #define SYSCLK_FREQ_HSE HSE_VALUE */#define SYSCLK_FREQ_24MHz 24000000#else/* #define SYSCLK_FREQ_HSE HSE_VALUE *//* #define SYSCLK_FREQ_24MHz 24000000 *//* #define SYSCLK_FREQ_36MHz 36000000 *//* #define SYSCLK_FREQ_48MHz 48000000 *//* #define SYSCLK_FREQ_56MHz 56000000 */#define SYSCLK_FREQ_72MHz 72000000 //这是我们要设置的系统时钟#endif。

stm32最小系统原理图

stm32最小系统原理图

stm32最小系统原理图STM32最小系统原理图。

STM32是STMicroelectronics公司推出的一款32位微控制器,广泛应用于各种嵌入式系统中。

在进行STM32开发时,我们通常会使用最小系统原理图来搭建基本的硬件环境,以便进行程序的烧录和调试。

本文将详细介绍STM32最小系统原理图的设计原理和具体连接方法。

首先,我们需要了解STM32最小系统原理图所需的基本元件。

最小系统原理图通常包括主控芯片、晶振、复位电路、电源电路和调试接口。

主控芯片是STM32系列微控制器,晶振用于提供时钟信号,复位电路用于确保系统在上电时能够正常复位,电源电路用于为系统提供稳定的电源,调试接口用于与开发工具连接,方便程序的烧录和调试。

在最小系统原理图中,主控芯片通常是STM32系列的芯片,根据具体的应用需求选择不同型号的芯片。

晶振的选择需要考虑系统的时钟要求,一般常用的晶振频率有8MHz、12MHz、16MHz等,需要根据实际情况进行选择。

复位电路通常包括复位按钮和复位电路,确保系统在上电时能够正常复位。

电源电路需要考虑系统的供电电压和电流需求,一般包括稳压芯片、电容、电感等元件。

调试接口通常使用SWD接口或JTAG接口,用于与开发工具连接,方便程序的烧录和调试。

接下来,我们将详细介绍STM32最小系统原理图的具体连接方法。

首先,将主控芯片、晶振、复位电路、电源电路和调试接口按照原理图连接起来,注意连接的正确性和稳定性。

接着,通过USB转串口模块将最小系统与电脑连接,打开开发工具,选择对应的芯片型号,进行程序的烧录和调试。

在烧录和调试过程中,需要注意电源的稳定性和连接的可靠性,确保程序能够正常烧录和调试。

在实际应用中,STM32最小系统原理图的设计需要根据具体的应用需求进行调整和优化。

例如,如果系统需要外部扩展模块,需要在最小系统原理图中增加对应的接口和电路。

另外,还需要考虑系统的功耗、抗干扰能力、稳定性等因素,确保系统能够稳定可靠地工作。

STM32F427xx系列芯片系统时钟讲解

STM32F427xx系列芯片系统时钟讲解

STM32F427xx系列芯片系统时钟讲解——写代码的Tobem 为了进行通用定时器的设置,有必要先了解STM32F427xx系列芯片的时钟系统。

为了实现低功耗(对于每个时钟源来说,在未使用时都可单独打开或者关闭,以降低功耗),STM32F427xx设计了功能完善但却有点复杂的时钟系统,见下图:图2 STM32F427xx系统时钟树从图中可以看出,STM32F427xx具有4个时钟源,分别为2个内部时钟源和2个外部时钟源,也可以分为2个高速时钟源和2个低速时钟源,具体为:1、HSE(高速外部时钟):以外部晶振作时钟源,晶振频率可取范围为4~26MHz,实际电路图中我们采用12MHz的晶振。

2、HSI(高速内部时钟):由内部RC振荡器产生,频率为16MHz。

其特点是起振快,在芯片刚上电的时候,就是使用高速内部时钟,但其精度不高,因此,上电之后我们再通过软件配置(SystemInit()函数),转而采用高速外部时钟信号。

3、LSE(低速外部时钟):以外部晶振作时钟源,主要提供给实时时钟模块(RTC),一般采用32.768KHz。

4、LSI(低速内部时钟):由内部RC振荡器产生,频率为32KHz,主要用于驱动独立看门狗,也可选择提供给RTC 用于停机/待机模式下的自动唤醒。

程序在执行主函数main()之前,要先进行堆栈指针SP、程序计数器PC的初始化、设置异常中断向量地址等工作,最后才进入到主函数main()中去执行,这其中包括系统时钟的配置(在startup_stm32f4xx.s启动文件中)。

系统时钟的配置由system_stm32f4xx.c文件中的SystemInit()函数完成,配置结果如下:图3 系统时钟配置情况从时钟树中可以看到,系统时钟SYSCLK是大部分器件的时钟来源,因此SYSCLK的配置就显得十分重要。

SYSCLK可以从三个时钟源中进行选择,分别为HSI、HSE和PLLCLK。

HSI 不稳定,而HSE速率太低(4~26MHz),为了使系统获得较快的运行速率和稳定性,我们选择PLLCLK来作为SYSCLK(见备注1),而PLLCLK又可以选择HSI或者HSE作为时钟源,我们选择HSE作为时钟源(见备注2)根据时钟树的走向,SYSCLK(即PLLCLK)计算过程为:PLL_VCO = (HSE_VALUE / PLL_M) * PLL_NSYSCLK = PLL_VCO / PLL_P而宏定义有#if !defined (HSE_VALUE)#define HSE_VALUE ((uint32_t)12000000) /*!< Value of the External oscillator in Hz */#endif /* HSE_VALUE */#define PLL_M 12#define PLL_Q 7#if defined (STM32F427_437xx) || defined (STM32F429_439xx)#define PLL_N 360#define PLL_P 2故SYSCLK最终为180MHz。

STM32时钟详细配置

STM32时钟详细配置

STM32时钟配置STM32时钟配置步骤// 开启HSI时钟寄存器操作1).开启高速时钟HSE // 设置时钟控制寄存器RCC_CR 位16 置1使能RCC->CR|= 0x00010000;位16 :HSEON:外部高速时钟使能当进入待机和停止模式时,该位由硬件清零,关闭4-16MHz外部振荡器。

当外部4-16MHz 振荡器被用作或被选择将要作为系统时钟时,该位不能被清零。

2).等待高速时钟就绪// 读取时钟控制寄存器RCC_CR位17为1就位while(!(RCC-> CR>>17));位17:HSERDY:外部高速时钟就绪标志由硬件置’1’来指示外部4-16MHz振荡器已经稳定。

在HSEON位清零后,该位需要6个外部4-25MHz振荡器周期清零。

3).设置APB1,APB2,AHB分频系数// 设置时钟配置寄存器RCC_CFGRRCC_CFGR=0x00000400;(AHB :位4-7, (低速)APB1 :位8-10, (高速)APB2 :位11-13)位7:4:HPRE[3:0]:AHB预分频(AHB Prescaler)0xxx:SYSCLK不分频位10:8:PPRE1[2:0]:低速APB预分频(APB1) 100:HCLK 2分频位13:11:PPRE2[2:0]:高速APB预分频(APB2) 0xx:HCLK不分频4).设置PLL倍频// 配置时钟配置寄存器RCC_CFGR 位18-21RCC_CFGR|=7<<18;位21:18:PLLMUL:PLL倍频系数0111:PLL 9倍频输出5).PLL输入时钟源选择// 配置时钟配置寄存器RCC_CFGR 位16RCC_CFGR|=1<<16;位16:PLLSRC:PLL输入时钟源(PLL entry clock source) 1:HSE时钟作为PLL输入时钟。

由软件置’1’或清’0’来选择PLL输入时钟源。

STM32F103时钟部分归纳

STM32F103时钟部分归纳

学习一款单片机,首先要了解的是它的时钟部分,在网上找到一些stm32F103时钟部分的资料,归纳总结一下。

时钟模块框图如下:仔细看上面这个框图,就可以对F103的时钟有一个清晰的认识了。

三种不同的时钟源可用作系统时钟(SYSCLOCK):HSI振荡器时钟(由芯片内部RC振荡器提供)HSE振荡器时钟(由芯片外部晶体振荡器提供)PLL时钟(通过倍频HIS或HSE振荡器倍频得到)另外还有两个时钟源:LSI内部40kHz低速RC振荡器时钟,用于驱动独立看门狗或选择驱动RTCLSE外部32.768kHz低速外部输入时钟,用于驱动RTC1.当HSI被用于作为PLL时钟的输入时,系统时钟能得到的最大频率是64MHz。

2.用户可通过多个预分频器分别配置AHB、高速APB(APB2)和低速APB(APB1)域的频率。

AHB和APB2域的最大频率是72MHz。

APB1域的最大允许频率是36MHz。

SDIO接口的时钟频率固定为HCLK/2。

3. RCC通过AHB时钟(HCLK)8分频后作为Cortex系统定时器(SysTick)的外部时钟。

通过对SysTick控制与状态寄存器的设置,可选择上述时钟或Cortex(HCLK)时钟作为SysTick时钟。

ADC时钟由高速APB2时钟经2、4、6或8分频后获得。

定时器时钟频率由APB1(PCLK1)时钟获得,分配由硬件按以下2种情况自动设置:a. 如果相应的APB预分频系数是1,定时器的时钟频率与所在APB总线频率一致。

b. 否则,定时器的时钟频率被设为与其相连的APB总线频率的2倍。

4. FCLK是Cortex-M3的自由运行时钟。

详情见ARM的Cortex-M3技术参考手册。

关于HSE、HIS、PLL、LSE、LSI时钟特性及校准直接参考STM32相关Datasheet。

系统时钟配置过程:配置过程主要对RCC_CR、RCC_CFGR、RCC_CIR这三个寄存器,进行读写访问,配置系统时钟完成后,进行对要使用的相应外设时钟进行使能和配置,不用的外设建议关闭相应的外设时钟(降低功耗)。

基于STM32定时中断的电子闹钟设计

基于STM32定时中断的电子闹钟设计

基于定时中断的电子闹钟一、系统主要功能可以通过LCD的输出显示公历和农历时间,通过按键设置时间和闹钟;通过蜂鸣器响应闹钟。

三、电路原理图、接口、硬件构成1.原理图2.接口本次实验使用了串口、定时器、中断接口。

3.硬件组成(1)实验设计程序流程图如图左所示,中断流程图如图右所示。

(2)该设计分为软件设计和硬件设计两大模块,硬件电路由ARM 最小系统电路、时钟显示电路和闹钟提醒电路组成,采用stm32f103RCT6芯片,芯片管脚图示如下。

(3)时钟电路此电路主要是复位电路和时钟电路两部分,其中复位电路采用按键手动复位和上电自动复位组合,电路如图所示:晶振采用的是 8MHz 和 32.786KHz , 8MKz 分别接 STM32 的5 脚和 6 脚, 32.786KHz 分别接 STM32 的 3 脚和 4 脚。

(4)闹钟提醒电路本次实验设计的闹钟提醒电路为蜂鸣器电路,接入芯片的PC7引脚,当时间为设置闹钟时间时,蜂鸣器工作,发出响声,提醒电路如图所示。

四、核心代码(带注释)#include "delay.h"#include "sys.h"#include "lcd.h"#include "dht11.h"#include "ds1302.h"#include "KEY.h"#include "beep.h"u8 temp;u8 humi;u8 t=0;u8 flag=0,flag1=0,flag2=0,flag3=1; u8 a,b,c;int min1=10,hour1=10;DHT11_Data_TypeDef DHT11_Data;void TIM3_Int_Init(u16 arr,u16 psc){TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;NVIC_InitTypeDef NVIC_InitStructure;RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE); //时钟使能//定时器TIM3初始化TIM_TimeBaseStructure.TIM_Period = arr; //设置在下一个更新事件装入活动的自动重装载计时器的值TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置用来作为TIMx时钟频率除数的预分频值TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //TIM向上计数模式TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure); //根据指定的参数初始化TIMx的时间基数单位TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE ); //使能指定的TIM3中断,允许更新中断//中断优先级NVIC设置NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn; //TIM中断NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //先占优先级0级NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //从优先级3级NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能NVIC_Init(&NVIC_InitStructure); //初始化NVIC寄存器TIM_Cmd(TIM3, DISABLE); //使能TIMx }void gui0(u8 mode){LCD_ShowPicture(0,0,480,320);if(flag3==1){LCD_ShowPicture3(445,0,479,34);}LCD_ShowChinese(0+40,0,0,BLUE,32,mode);//字LCD_ShowChinese(32+40,0,8,BLUE,32,mode);LCD_ShowChinese(64+40,0,9,BLUE,32,mode);LCD_ShowChinese(96+40,0,10,BLUE,32,mode);LCD_ShowNum(52,40,temp,2,BLUE,32,mode);//温度LCD_ShowChinese(132,40,12,BLUE,32,mode);LCD_ShowChinese(128+80+30,0,0,BLUE,32,mode);LCD_ShowChinese(160+80+30,0,8,BLUE,32,mode);LCD_ShowChinese(192+80+30,0,11,BLUE,32,mode);LCD_ShowChinese(224+80+30,0,10,BLUE,32,mode);LCD_ShowNum(248+30,40,humi,2,BLUE,32,mode);LCD_ShowChar(280+30,40,'%',BLUE,32,mode);LCD_ShowNum(20,80,hour/10,1,BLUE,160,mode);//时间 LCD_ShowNum(110,80,hour%10,1,BLUE,160,mode);LCD_ShowChar(200,65,':',BLUE,160,mode);LCD_ShowNum(290,80,min/10,1,BLUE,160,mode);LCD_ShowNum(380,80,min%10,1,BLUE,160,mode);LCD_ShowNum(0,250,year+2000,4,BLUE,32,mode);LCD_ShowChinese(64,250,13,BLUE,32,mode);LCD_ShowNum(96,250,month,2,BLUE,32,mode);LCD_ShowChinese(128,250,14,BLUE,32,mode);LCD_ShowNum(160,250,day,2,BLUE,32,mode);LCD_ShowChinese(192,250,15,BLUE,32,mode);LCD_ShowChinese(224,250,16,BLUE,32,mode);LCD_ShowChinese(256,250,week,BLUE,32,mode);LCD_ShowNum(0,283,hour1,2,BLUE,32,mode);LCD_ShowChar(33,283,':',BLUE,32,mode);LCD_ShowNum(50,283,min1,2,BLUE,32,mode);}void keyscan(u8 mode){switch(t){case KEY0_PRES:if(min1==min&&hour1==hour){flag2=1;BEEP(OFF);}switch(flag){case 1: hour++; if(hour>23)hour=0;LCD_ShowPicture2(20,80,190,240);LCD_ShowNum(20,80,hour/10,1,BLUE,160,mode);//时间LCD_ShowNum(110,80,hour%10,1,BLUE,160,mode);break;case 2: min++; if(min>59)min=0;LCD_ShowPicture2(290,80,460,240);LCD_ShowNum(290,80,min/10,1,BLUE,160,mode); LCD_ShowNum(380,80,min%10,1,BLUE,160,mode); break;case 3: year++; LCD_ShowPicture2(0,250,64,282);LCD_ShowNum(0,250,year+2000,4,BLUE,32,mode);break;case 4: month++; if(month>12) month=1;LCD_ShowPicture2(96,250,128,282); LCD_ShowNum(96,250,month,2,BLUE,32,mode);break;case 5: day++; if(day>31) day=1;LCD_ShowPicture2(160,250,192,282);LCD_ShowNum(160,250,day,2,BLUE,32,mode); break; case 6: week++; if(week>7) week=1;LCD_ShowPicture2(256,250,288,282);LCD_ShowChinese(256,250,week,BLUE,32,mode);break;case 7: hour1++; if(hour1>23)hour1=0;LCD_ShowPicture2(0,283,32,315);LCD_ShowNum(0,283,hour1,2,BLUE,32,mode);break;case 8: min1++;if(min1>59)min1=0;LCD_ShowPicture2(50,283,82,315);LCD_ShowNum(50,283,min1,2,BLUE,32,mo de);break;case 9: flag3=1; LCD_ShowPicture3(445,0,479,34); break;default: break;}break;case KEY1_PRES:if(min1==min&&hour1==hour){flag2=1;BEEP( OFF );}switch(flag){case 1: hour--; if(hour<0)hour=23;LCD_ShowPicture2(20,80,190,240);LCD_ShowNum(20,80,hour/10,1,BLUE,160,mode);//时间LCD_ShowNum(110,80,hour%10,1,BLUE,160,mode); break;case 2: min--; if(min<0) min=59;LCD_ShowPicture2(290,80,460,240);LCD_ShowNum(290,80,min/10,1,BLUE,160,mode);LCD_ShowNum(380,80,min%10,1,BLUE,160,mode); break;case 3: year--; LCD_ShowPicture2(0,250,64,282);LCD_ShowNum(0,250,year+2000,4,BLUE,32,mode);break;case 4: month--; if(month<1) month=12; LCD_ShowPicture2(96,250,128,282);LCD_ShowNum(96,250,month,2,BLUE,32,mode);break;case 5: day--; if(day<1) day=31;LCD_ShowPicture2(160,250,192,282);LCD_ShowNum(160,250,day,2,BLUE,32,mode); break;case 6: week--; if(week<1) week=7;LCD_ShowPicture2(256,250,288,282);LCD_ShowChinese(256,250,week,BLUE,32,mode); break; case 7: hour1--; if(hour1<0)hour1=23;LCD_ShowPicture2(0,283,32,315);LCD_ShowNum(0,283,hour1,2,BLUE,32,mode);break;case 8: min1--;if(min1<0)min1=59;LCD_ShowPicture2(50,283,82,315);LCD_ShowNum(50,283,min1,2,BLUE,32,mo de);break;case 9: flag3=0; LCD_ShowPicture2(445,0,480,36);break;default: break;}break;case WKUP_PRES:cc1();flag++;switch(flag){case 1: TIM_Cmd(TIM3, DISABLE); LCD_DrawLine(20,242,190,243,BLUE);break;case 2: LCD_ShowPicture1(242,243);LCD_DrawLine(290,242,460,243,BLUE); break;case 3: LCD_ShowPicture1(242,243); LCD_DrawLine(0,287,64,288,BLUE);break;case 4: LCD_ShowPicture1(287,288);LCD_DrawLine(96,287,128,288,BLUE);break;case 5: LCD_ShowPicture1(287,288); LCD_DrawLine(160,287,192,288,BLUE); break; case 6: LCD_ShowPicture1(287,288);LCD_DrawLine(256,287,288,288,BLUE); break; case 7: LCD_ShowPicture1(287,288); LCD_DrawLine(0,316,32,317,BLUE);break; case 8: LCD_ShowPicture1(316,317); LCD_DrawLine(50,316,82,317,BLUE);break;case 9: LCD_ShowPicture1(316,317); LCD_DrawLine(445,37,479,38,BLUE);break;case 10: LCD_ShowPicture2(445,37,479,38);ds_wtime();a=sec;b=min;c=hour;TIM_Cmd(TIM3, ENABLE);flag=0;break;default: break;}break;default: delay_ms(5); break;}}int main(void){delay_init();NVIC_Configuration();DHT11_Init ();KEY_Init();BEEP_GPIO_Config();BEEP( OFF );TIM3_Int_Init(9999,7199);ds1302_init();ds_read_time();cc();a=sec;b=min;c=hour;Lcd_Init();LCD_Clear(WHITE);gui0(1);TIM_Cmd(TIM3, ENABLE);while(1){t=KEY_Scan(0);keyscan(1);if( DHT11_Read_TempAndHumidity (&DHT11_Data ) == SUCCESS&&flag==0) {temp=DHT11_Data.temp_int;humi=DHT11_Data.humi_int;LCD_ShowPicture2(52,40,84,72);LCD_ShowPicture2(278,40,310,72);LCD_ShowNum(52,40,temp,2,BLUE,32,1);LCD_ShowNum(278,40,humi,2,BLUE,32,1);}if(flag==0&&min1==min&&hour1==hour&&flag2==0&&flag3==1) {BEEP( ON );}}}。

STM32学习笔记系统时钟和SysTick定时器

STM32学习笔记系统时钟和SysTick定时器

STM32学习笔记(3):系统时钟和SysTick定时器1.STM32的时钟系统在STM32中,一共有5个时钟源,分别是HSI、HSE、LSI、LSE、PLL(1)HSI是高速内部时钟,RC振荡器,频率为8MHz;(2)HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围是4MHz – 16MHz;(3)LSI是低速内部时钟,RC振荡器,频率为40KHz;(4)LSE是低速外部时钟,接频率为32.768KHz的石英晶体;(5)PLL为锁相环倍频输出,严格的来说并不算一个独立的时钟源,PLL 的输入可以接HSI/2、HSE或者HSE/2。

倍频可选择为2 – 16倍,但是其输出频率最大不得超过72MHz。

其中,40kHz的LSI供独立看门狗IWDG使用,另外它还可以被选择为实时时钟RTC的时钟源。

另外,实时时钟RTC的时钟源还可以选择LSE,或者是HSE的128分频。

STM32中有一个全速功能的USB模块,其串行接口引擎需要一个频率为48MHz的时钟源。

该时钟源只能从PLL端获取,可以选择为1.5分频或者1分频,也就是,当需使用到USB模块时,PLL必须使能,并且时钟配置为48MHz 或72MHz。

另外STM32还可以选择一个时钟信号输出到MCO脚(PA.8)上,可以选择为PLL输出的2分频、HSI、HSE或者系统时钟。

系统时钟SYSCLK,它是提供STM32中绝大部分部件工作的时钟源。

系统时钟可以选择为PLL输出、HSI、HSE。

系系统时钟最大频率为72MHz,它通过AHB分频器分频后送给各个模块使用,AHB分频器可以选择1、2、4、8、16、64、128、256、512分频,其分频器输出的时钟送给5大模块使用:(1)送给AHB总线、内核、内存和DMA使用的HCLK时钟;(2)通过8分频后送给Cortex的系统定时器时钟;(3)直接送给Cortex的空闲运行时钟FCLK;(4)送给APB1分频器。

STM32最小系统原理图

STM32最小系统原理图

STM32最小系统原理图STM32是一款高性能、高可靠性的32位单片机系列产品,采用Cortex-M内核。

它可以用来设计各种嵌入式系统,包括家电、医疗设备、汽车电子和工业自动化等领域。

在进行STM32的设计时,我们需要先画出最小系统原理图,该原理图包含了STM32所需的电源和外围器件。

首先,我们需要为STM32提供合适的电源。

通常情况下,我们可以使用LM1117-3.3三端稳压器作为主芯片的电源。

其输入电压可以在6V至12V之间,输出电流为800mA,输出电压为3.3V。

此外,还需要添加适当的电容来提供电源稳定性。

接下来,我们需要为STM32添加晶振电路。

晶振电路主要包括一个晶振和两个电容。

在选择晶振时,我们需要确定频率和精度。

常见的选择包括8MHz和16MHz的晶振。

晶振电路的作用是为STM32提供系统时钟信号。

复位电路是STM32系统中非常重要的部分,它用于在系统启动时将芯片复位到初始状态。

复位电路主要由一个复位按钮、一个电阻和一个电容组成。

在启动或出现故障时,按下复位按钮将使STM32芯片重新启动。

调试电路主要用于在开发和调试过程中进行调试操作。

它包括JTAG或SWD接口、调试器、与调试器连接的引脚等。

通过调试电路,开发人员可以通过调试器进行单步调试、变量查看和性能分析等操作。

最后,我们需要为STM32添加一些扩展接口电路,如LED指示灯、按键开关、LCD模块、以太网接口、USB接口、UART接口等。

这些扩展接口可以根据实际应用需求来选择和设计。

STM32F103ZET6时钟

STM32F103ZET6时钟

STM32F103ZET6时钟1、STM32F103ZET6时钟说明 STM32F103ZET6的时钟树图如下所⽰: STM32F103ZET6有很多个时钟源,分别有: HSE:⾼速外部时钟信号。

HSI:⾼速内部部时钟信号。

LSI:低速内部时钟信号。

LSE:低速外部时钟信号。

HSI和LSI是芯⽚内置的时钟源,它们的频率⼤⼩是固定的,HSI是8MHZ,LSI是⼤约40KHZ。

时钟树中的序号1是⾼速外部时钟信号HSE: HSE是由有源晶振或⽆源晶振通过OSC_OUT和OSC_IN脚提供的,从图⽚中可以看到,HSE频率从4MHZ到16MHZ不等。

当使⽤有源晶振时,时钟从OSC_IN引脚进⼊,OSC_OUT引脚悬空;当使⽤⽆源晶振时,时钟从OSC_IN和OSC_OUT进⼊,并且要配谐振电容。

HSE最常使⽤的就是8MHZ的⽆源晶振。

时钟树中的序号D是外部低速时钟LSE: LSE是由有源晶振或⽆源晶振通过OSC32_OUT和OSC32_IN脚提供的。

LSE⼀般使⽤的是32.768KHZ的⽆源晶振。

时钟树中的序号2是选择PLL(倍频后的时钟)的时钟源: 从图中可以看出,PLL时钟的来源可以是HSE或HSI/2,通过PLLSRC(CFGR寄存器的bit16)来选择使⽤哪⼀个时钟源。

HSI是8MHZ的内部⾼速时钟信号,HSI会根据温度和环境的情况频率会有漂移,⼀般不作为PLL的时钟来源。

⼀般使⽤HSE作为PLL的时钟源。

时钟树中的序号3是设置PLL的倍频因⼦: 可以对PLL的时钟来源进⾏倍频,然后得到PLLCLK时钟源。

倍频因⼦可以通过时钟配置寄存器CFGR的bit21~bit18:PLLMUL[3:0]来配置,分别可配置成2、3、4、5、6、7、8、9、10、11、12、13、14、15、16倍频。

举个例⼦来说,如果选择HSE作为PLL的时钟源,⽽且HSE=8MHZ,且将PLL的倍频因⼦设置为9倍频,那么PLLCLK=9*8MHZ = 72MZH。

STM32中的几个时钟SysTick、FCLK、SYSCLK、HCLK的详解

STM32中的几个时钟SysTick、FCLK、SYSCLK、HCLK的详解

STM32中的几个时钟SysTick、FCLK、SYSCLK、HCLK的详解在STM32中,有五个时钟源,为HSI、HSE、LSI、LSE、PLL。

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

②、HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。

③、LSI是低速内部时钟,RC振荡器,频率为40kHz。

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

⑤、PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。

倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。

其中40kHz的LSI(低速内部时钟)供独立看门狗IWDG使用,另外它还可以被选择为实时时钟RTC的时钟源。

另外,实时时钟RTC的时钟源还可以选择LSE(低速外部时钟),或者是HSE(高速外部时钟)的128分频。

RTC的时钟源通过RTCSEL[1:0]来选择。

STM32中有一个全速功能的USB模块,其串行接口引擎需要一个频率为48MHz的时钟源。

该时钟源只能从PLL输出端获取,可以选择为1.5分频或者1分频,也就是,当需要使用USB模块时,PLL必须使能,并且时钟频率配置为48MHz 或72MHz。

()另外,STM32还可以选择一个时钟信号输出到MCO脚(PA8)上,可以选择为PLL输出的2分频、HSI、HSE、或者系统时钟。

系统时钟SYSCLK最大频率为72MHz,它是供STM32中绝大部分部件工作的时钟源。

系统时钟可由PLL、HSI或者HSE提供输出,并且它通过AHB分频器分频后送给各模块使用,AHB分频器可选择1、2、4、8、16、64、128、256、512分频。

其中AHB分频器输出的时钟送给5大模块使用:①、送给AHB总线、内核、内存和DMA 使用的HCLK时钟。

②、分频后送给STM32芯片的系统定时器时钟(Systick=Sysclk/8=9Mhz)③、直接送给Cortex的自由运行时钟(free running clock)FCLK。

STM32CubeMX配置SystemTick时钟

STM32CubeMX配置SystemTick时钟

STM32CubeMX配置SystemTick时钟STM32CubeMX自动生成SYSTICK配置1.SYSTICK原理及其寄存器1.1 SYSTICK原理SysTick 是一个24位的倒计数定时器,当计到0时,将从RELOAD寄存器中自动重装载定时初值并继续计数,且同时触发中断。

只要不把它在SysTick控制及状态寄存器中的使能位清除,就永不停息。

SysTick 的最大使命,就是定期地产生异常请求,作为系统的时基,产生一个周期性的中断。

1.2SYSTICK寄存器CTRL: Systick控制和状态寄存器LOAD: Systick重装载寄存器VAL: Systick当前值寄存器CALIB: Systick校准值寄存器CLKCOURCE-时钟源0:外部时钟源HCLK(AHB总线时钟)/8 72M/8 = 9M 1:内核时钟(HCLK) 72MCURRENT: 每经过一个Systick时钟周期,寄存器值-1 。

2.STM32CubeMX配置与代码生成如下图STM32CubeMX配置所示,图中To Cortex System timer(MHz)就是Systick的时钟频率。

自动代码生成如下:/**Configure the Systick interrupt time */HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/8000); // = /8/1000 :1000 is 1ms ;1000000 is 1us/**Configure the Systick */HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK _DIV8); /* SysTick_IRQn interrupt configuration */HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);3.相关重要的函数3.1中断处理函数void SysTick_Handler(void){/* USER CODE BEGIN SysTick_IRQn 0 *//* USER CODE END SysTick_IRQn 0 */HAL_IncTick();HAL_SYSTICK_IRQHandler();/* USER CODE BEGIN SysTick_IRQn 1 *//* USER CODE END SysTick_IRQn 1 */}__IO uint32_t uwTick;__weak void HAL_IncTick(void){uwTick += uwTickFreq;}每次SysTick异常中断后,会执行SysTick_Handler() 函数,然后HAL_IncTick()函数。

STM32时钟源的介绍及使用方法——STM32时钟树

STM32时钟源的介绍及使用方法——STM32时钟树

STM32时钟源的介绍及使⽤⽅法——STM32时钟树【温馨提⽰:以下内容均来⾃⽹友的⽆私奉献或书本的摘抄,在此表⽰感谢!】上图是STM32的时钟树,从树上我们可以看到,STM32的时钟有两个来源——内部时钟和外部时钟。

按时钟频率来分,⼜可分为⾼速时钟和低速时钟。

因此STM32的时钟有四个来源:⾼速外部时钟信号(HSE)、低速外部时钟信号(LSE)、⾼速内部时钟信号(HSI)和低速内部时钟信号(LSI)(图中分别⽤蓝⾊的①~④标注)。

①HSE⾼速外部时钟:由外部4~16MHz的晶体或有源晶振提供,通常采⽤8MHz。

②LSI低速外部时钟:外部晶体提供,主要是给实时时钟(RTC),⼀般为32.768kHz。

③HSI⾼速内部时钟:由内部RC振荡器产⽣的8MHz时钟,但不够稳定。

④LSI低速内部时钟:内部RC振荡器产⽣的供给RTC的时钟,频率在30kHz~60kHz之间,通常约40kHz。

时钟在STM32内部最终是供给四⼤块(图中⽤红⾊椭圆圈出):USB的48MHz时钟、系统时钟SYSCLK、实时时钟模块RTC、独⽴看门狗的时钟IWDGCLK。

其中最主要的,也是最⼤头是系统时钟SYSCLK,它可以是内部或外部⾼速时钟直接接过来,也可以内、外部⾼速时钟是PLL倍频后提供的,系统时钟再分别供给Cortex内核、SDIO、AHB总线、DMA、APB1、APB2等。

我们通常是采⽤外部8MHz⾼速时钟(HSE),所以着重说HSE。

我们以前⾯的GPIO上的时钟为例,由ST的Datasheet可知,GPIO是在APB2⾼速外设总线上的,图中绿⾊的线就是时钟的流程,我们⼀步步地来看。

8MHz外部晶体(或晶振)输⼊后,先经过⼀个开关PLLXTPRE(HSE divider for PLL entry),此开关决定对HSE进⾏2分频再输⼊到PLL或直接到PLL。

我们选择不分频。

这样时钟⼜到了第⼆个开关PLLSRC(PLL entry clock source),此开关决定PLL的时钟来源,是内部⾼速时钟⼆分频的时钟还是PLLXTPRE的输出。

本科第3章STM32最小系统.ppt

本科第3章STM32最小系统.ppt
为什么ARM时钟这么复杂?
原因一:高速时钟供中央处理器等高速设备使用, 低速时钟供外设等低速设备使用。
原因二:时钟分开有助于实现低功耗。
时钟输出使能
∵STM32处理器因为低功耗的需要,各模块 需要分别独立开启时钟。
∴当需要使用某个外设模块时,记得一定要 先使能对应的时钟。否则,这个外设不能工作。
3.2.2 RCC_Configuration( )函数
2. 时钟:时钟通常由晶体振荡器(简称晶振)产生, 图2-9中时钟部分提供了两个时钟源,Y1是 32.768kHz晶振,为RTC提供时钟。Y2是8MHz晶振, 为整个系统提供时钟。
3. 复位:采用按键和保护电阻电容构成复位电路, 按下按键将触发系统复位,具体电路如图2-9中复位 部分所示。
4. 启动模式:启动模式由BOOT0和BOOT1选 择,为了便于设置,BOOT0接电平,并且和 BOOT1通过2X2插针相连,通过跳线可以配置 三种不同启动模式。
APB2:用于高速外设 APB1:用于低速外设
连接在APB2(高速外设)上的设备:有 连接在APB1(低速外设)上的设备:有
连接在AHB(Advanced High performance Bus)上的设备:有 STM32系统结构图
1、使能 挂接在APB1总线上的外设 对应的时钟 命令:
RCC_APB1PeriphClockCmd( ) 函数
STM32时钟系统结构图(P66)
• AMBA片上总线:已成为一种流行的工业片上总线标准。 它包括AHB(Advanced High performance Bus)和 APB(Advanced Peripheral Bus ),前者作为系统总线, 后者作为外设总线。
外设总线:包括APB1(Advanced Peripheral Bus 1) 和APB2(Advanced Peripheral Bus 2)
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
相关文档
最新文档