其他分享
首页 > 其他分享> > STM32F4的基础介绍

STM32F4的基础介绍

作者:互联网

STM32F4的基础介绍

1. 前言

上周了解了Cortex-M3/M4处理器的相关知识(见Cortex-M处理器栏目),大致知道了stm32的心是什么样子,从本周起,开始结合stm32F4开发板进行实际学习,方便更深入了解stm32的世界。
时隔多年再次学习单片机类似的东西,希望会有不同的理解和体会。

硬件平台:ALIENTEK探索者stm32F4,stm32的型号为stm32f407ZTG6,属于M4内核。

2. STM32F4总线架构

首先说下什么叫总线?总线是计算机各种功能部件之间传送信息的公共通信干线,它是由导线组成的传输线束。总线的出现是为了方便在同一时间传递更多信号。
总线可分为:内部总线,系统总线(数据总线,地址总线,控制总线)和外部总线。

什么叫总线架构?
之前的文章讲过,架构指的是体系结构,包括体系(即组成部分)和结构(对部分之间的统筹)。那么总线架构,就是包括哪些总线,总线之间如何配合。
在这里插入图片描述
上图是STM32F407的系统总线架构图。由8条主控线S0-S7,7条被控线M0-M6组成。
八条主控总线是:

七条被控总线:
内部 FLASH ICode 总线;
内部 FLASH DCode 总线;
主要内部 SRAM1(112KB)
辅助内部 SRAM2(16KB);
辅助内部 SRAM3(64KB) (仅适用 STM32F42xx 和 STM32F43xx 系列器件);

AHB:Advanced High Performance Bus高级高性能总线
CCM:内核耦合存储器。
FSMC:Flexible Static Memory Controller,可变静态存储控制器。
OTG:on the go

3. STM32F4时钟系统

3.1 时钟树

既然称之为系统,说明stm32的时钟不止一个。采用多时钟的目的是,既保证低功耗的同时又保证高性能,使得低时钟外设采用低时钟,高时钟外设采用高时钟。

STM32F4有5个时钟源:

HSI/HSE/PLL是高速时钟,LSI/LSE是低速时钟。
HSI/LSI/PLL是内部时钟,HSE/LSE是外部时钟。
在这里插入图片描述
从上图可以很清晰的看到各部分时钟的来源及对时钟的处理情况,详细解释请参照《STM32F4开发指南-库函数版本-V1.2》的第4.3.1节。

3.2 时钟初始化

时钟初始化时,涉及以下函数:
SystemInit ();打开HSI时钟,进行浮点单元设置,复位相关时钟寄存器
SetSysClock();设置系统时钟(先选择HSI作为系统时钟,系统时钟来源于HSI,HSE,PLL),使能HSE,配置外设时钟,打开主PLL,此函数被 SystemInit ()调用。
涉及的文件:
stm32f4xx.h 包括时钟宏定义标识符
system_stm32f4xx.c 包括时钟参数宏定义

SystemInit ()中各时钟的大小如下
在这里插入图片描述

3.3 时钟使能

RCC:reset clock control复位和系统时钟控制.
时钟的选用配置等声明和定义涉及到以下文件:
stm32f4xx_rcc.h
stm32f4xx_rcc.c
包括时钟源使能和配置,外设时钟的使能和外设复位函数。
外设在使用之前,需要使能相应的时钟。外设挂在哪个总线下,可以从库函数的命名中看出,当然也可以将第2章和第3.1节图对应起来看。

参考文献

《STM32F4开发指南-库函数版本-V1.2》
《STM32F4xx中文参考手册》

标签:基础,存储器,总线,介绍,STM32F4,PLL,外设,时钟
来源: https://blog.csdn.net/dianji2015_/article/details/121638885