How to properly set clock speed for STM32F4xx devices
http://stm32f4-discovery.com/2015/01/properly-set-clock-speed-stm32f4xx-devices/
I see that you have problems with your devices when you don’t know even
(and you don’t even ask) on which speed your device is actually running.
Speed of your device depends on PLL settings or clock source you have selected for system core clock.
In most cases system core clock’s source is PLL output.
To get proper value, you check ALWAYS first these settings when something is not working.
Because I’m tired of questions that something is not working but then your MCU clock is totally failed.
STM32F4xx series MCUs have ALL 16MHz RC oscillator inside which can be used for PLL input clock.
It is not so accurate but it works just well if you don’t have connected external clock.
External clock is probably your crystal you have connected.
In this example we will talk in case that you have external crystal connected.
If your clock is not properly set, then you have problems with everything.
USB not working, USART baudrate failed, timer’s clock not OK…
This content has only sense, if you use Standard Peripheral Drivers and not HAL drivers from ST!
To be able to get your MCU to full speed, you have to do the following changes:
- In file stm32F4xx.h set HSE_VALUE to match your crystal frequency (In Hz)
- In case of any STM32F4xx Discovery board, select HSE_VALUE =8000000
- In other case, you can set this to your crystal
- If you have an option for global defines in your compiler, then addHSE_VALUE=8000000 to your defines.
- If you don’t use external crystal or clock, then you don’t need to change anything
- In file system_stm32f4xx.c set PLL_M value to match your crystal frequency (In MHz)
- In case of any STM32F4xx Discovery board, select PLL_M = 8
- This will divide input clock with 8 to get 1MHz on the input for PLL
- If you don’t use external clock, then this value MUST be set to 16,
because internal RC will be used for PLL
- Now you can expect top speed for your device.
Some informations about Nucleo boards:
- Nucleo boards don’t use external clock by default,
but they have pins for adding external crystal. - In case you don’t add external crystal or clock, then set PLL_M value to 16
- I have at home set F401 Nucleo board with external capacitor 8MHz
(so PLL_M is set to 8 and HSE_VALUE set to 8000000) and
F411 without external capacitor (PLL_M set to 16)
STM32F4xx Clocks
Proper PLL settings to get maximum clocks
(except of PLL_M parameter everything should be already defined in system_stm32f4xx.c file).
SystemCoreClock = (( INPUT_CLOCK (HSE_OR_HSI_IN_HZ) / PLL_M) * PLL_N) / PLL_P
| STM32F4xx | MAX CLOCK in MHz |
APB1 CLOCK in MHz </2> |
APB2 CLOCK in MHz </1> |
PLL_M | PLL_N | PLL_P |
|---|---|---|---|---|---|---|
| STM32F401 | 84 | 42 | 84 | Must match input frequency in MHz (HSE or HSI) | 336 | 4 |
| STM32F411 | 100 | 50 | 100 | Must match input frequency in MHz (HSE or HSI) | 400 | 4 |
| STM32F405 | 168 | 42 | 84 | Must match input frequency in MHz (HSE or HSI) | 336 | 2 |
| STM32F407 | 168 | 42 | 84 | Must match input frequency in MHz (HSE or HSI) | 336 | 2 |
| STM32F415 | 168 | 42 | 84 | Must match input frequency in MHz (HSE or HSI) | 336 | 2 |
| STM32F417 | 168 | 42 | 84 | Must match input frequency in MHz (HSE or HSI) | 336 | 2 |
| STM32F427 | 180 | 45 | 90 | Must match input frequency in MHz (HSE or HSI) | 360 | 2 |
| STM32F429 | 180 | 45 | 90 | Must match input frequency in MHz (HSE or HSI) | 360 | 2 |
| STM32F437 | 180 | 45 | 90 | Must match input frequency in MHz (HSE or HSI) | 360 | 2 |
| STM32F439 | 180 | 45 | 90 | Must match input frequency in MHz (HSE or HSI) | 360 | 2 |
| STM32F446 | 180 | 45 | 90 | Must match input frequency in MHz (HSE or HSI) | 360 | 2 |
Settings for STM32F4xx boards
This settings should be used in case of any STM32F4xx boards used.
| STM32F4xx | MAX CLOCK in MHz |
APB1 CLOCK in MHz |
APB2 CLOCK in MHz |
DEFAULT PLL INPUT CLOCK |
PLL_M | PLL_N | PLL_P |
|---|---|---|---|---|---|---|---|
| STM32F401 -Discovery |
84 | 42 | 84 | HSE 8MHz | 8 | 336 | 4 |
| STM32F411 -Discovery |
100 | 50 | 100 | HSE 8MHz | 8 | 400 | 4 |
| STM32F4 -Discovery |
168 | 42 | 84 | HSE 8MHz | 8 | 336 | 2 |
| STM32F429 -Discovery |
180 | 45 | 90 | HSE 8MHz | 8 | 360 | 2 |
| Nucleo F401 | 84 | 42 | 84 | HSI 16MHz | HSE_VALUE / 1MHz in case of external crystal or 16 in case of internal HSI RC oscillator |
336 | 4 |
| Nucleo F411 | 100 | 50 | 100 | HSI 16MHz | HSE_VALUE / 1MHz in case of external crystal or 16 in case of internal HSI RC oscillator |
400 | 4 |
How to properly set clock speed for STM32F4xx devices的更多相关文章
- IPC,Hz(Hertz) and Clock Speed
How do we measure a CPU's work? Whether it's fast or not depends on three factors: IPC, Hz, Clock sp ...
- STM32F4XX devices vector table for EWARM toolchain.
;/******************** (C) COPYRIGHT 2015 STMicroelectronics ******************** ;* File Name : sta ...
- stm32F4各个库文件的作用分析
system_stm32f4xx.c:This file contains the system clock configuration for STM32F4xx devices. /** **** ...
- get back to the slower clock rate that allows it to save more power
http://www.howtogeek.com/177790/why-you-cant-use-cpu-clock-speed-to-compare-computer-performance/ Wh ...
- simulation clock gen unit (推荐)
//Normal Clock Block always begin:clk_blk clk <=; # clk<=; #; end //Improved Clock Block, impr ...
- RFID 读写器 Reader Writer Cloner
RFID读写器的工作原理 RFID的数据采集以读写器为主导,RFID读写器是一种通过无线通信,实现对标签识别和内存数据的读出和写入操作的装置. 读写器又称为阅读器或读头(Reader).查询器(Int ...
- [ZZ] GTX 280 GPU architecture
http://anandtech.com/show/2549 Now that NVIDIA’s has announced its newest GPU architecture (the GeFo ...
- Debugging JTAG Connectivity Problems
2013-12-04 22:34:26 转自:http://processors.wiki.ti.com/index.php/Debugging_JTAG_Connectivity_Problems ...
- RFID Reader 线路图收集
This 125 kHz RFID reader http://www.serasidis.gr/circuits/RFID_reader/125kHz_RFID_reader.htm http:// ...
随机推荐
- 记关于vue-cli3 本地代理模拟数据的实践
网上说的基本都是使用express或http-server作为服务器或其它什么东西自己把玩php也有些年头,就用php好了 服务环境 apache,php先配置好隐藏php后缀扩展名: 在httpd. ...
- atom使用markdown
atom使用markdown 最近因为不喜欢博客园自身带的编辑工具,所以尝试使用markdown,目前只是想简单的把标题和内容分的开一些,以后在慢慢熟悉吧 1.atom上安装markdown 在没有外 ...
- Expression Tree Build
The structure of Expression Tree is a binary tree to evaluate certain expressions.All leaves of the ...
- Socket心跳包机制【转】
转自:https://blog.csdn.net/xuyuefei1988/article/details/8279812 心跳包的发送,通常有两种技术 方法1:应用层自己实现的心跳包 由应用程序自己 ...
- casperjs批量执行多个url
var fs=require("fs"); ////-------sample.js-------// //casperオブジェクトを生成var casper = require( ...
- 【并行计算】用MPI进行分布式内存编程(一)
通过上一篇关于并行计算准备部分的介绍,我们知道MPI(Message-Passing-Interface 消息传递接口)实现并行是进程级别的,通过通信在进程之间进行消息传递.MPI并不是一种新的开发语 ...
- emulator: ERROR: x86 emulation currently requires hardware acceleration!Please ensure Intel HAXM is properly installed and usable.CPU acceleration status: HAX kernel module is not installed!
Android Studio 1.0 已经放出来了,以后的Android平台开发激昂逐步从Eclipse向Android Studio迁移,为了能不落伍我也特意从Google下载了Android St ...
- SCU 4444: Travel(最短路)
Travel The country frog lives in has n towns which are conveniently numbered by 1,2,…,n . Among n(n− ...
- 《JavaScript 高级程序设计》第一章:简介
JavaScript 历史 JavaScript的诞生的主要是当时的 netspace 公司谋求为自己的浏览器 Navigator 添加一种脚本语言,以便在本地客户端进行一些行为操作,而这一功能的需求 ...
- spring-cloud-sleuth+zipkin追踪服务实现(四)
1.前言 在上一篇spring-cloud-sleuth+zipkin追踪服务实现(三)的处理实现后,很多朋友告诉我,在zipkin server的管理页面无法看到项目依赖关系. 当时也没有多想,以为 ...