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的更多相关文章

  1. 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 ...

  2. STM32F4XX devices vector table for EWARM toolchain.

    ;/******************** (C) COPYRIGHT 2015 STMicroelectronics ******************** ;* File Name : sta ...

  3. stm32F4各个库文件的作用分析

    system_stm32f4xx.c:This file contains the system clock configuration for STM32F4xx devices. /** **** ...

  4. 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 ...

  5. simulation clock gen unit (推荐)

    //Normal Clock Block always begin:clk_blk clk <=; # clk<=; #; end //Improved Clock Block, impr ...

  6. RFID 读写器 Reader Writer Cloner

    RFID读写器的工作原理 RFID的数据采集以读写器为主导,RFID读写器是一种通过无线通信,实现对标签识别和内存数据的读出和写入操作的装置. 读写器又称为阅读器或读头(Reader).查询器(Int ...

  7. [ZZ] GTX 280 GPU architecture

    http://anandtech.com/show/2549 Now that NVIDIA’s has announced its newest GPU architecture (the GeFo ...

  8. Debugging JTAG Connectivity Problems

    2013-12-04 22:34:26 转自:http://processors.wiki.ti.com/index.php/Debugging_JTAG_Connectivity_Problems ...

  9. RFID Reader 线路图收集

    This 125 kHz RFID reader http://www.serasidis.gr/circuits/RFID_reader/125kHz_RFID_reader.htm http:// ...

随机推荐

  1. 拓展中国剩余定理(exCRT)摘要

    清除一个误区 虽然中国剩余定理和拓展中国剩余定理只差两个字,但他俩的解法相差十万八千里,所以会不会CRT无所谓 用途 求类似$$\begin{cases}x \equiv b_{1}\pmod{a_{ ...

  2. !!!sql_mode=only_full_group_by配置

    Expression #7 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'invoicecer ...

  3. 解决win10 关键错误开始菜单和cortana无法工作 的问题

    问题描述: 一次强制关机后出现了这个对话框,注销.重启均无法解决问题 解决过程[因为我用的英文版操作系统,所以截图都是英文,请大家自行对照自己的操作系统]: 1.ctrl+alt+del 打开任务管理 ...

  4. 洛谷P3375KMP字符串匹配

    传送门 #include <iostream> #include <cstdio> #include <cstring> #include <algorith ...

  5. jdk8 lambda表达式总结

    Java8 lambda表达式10个示例   1. 实现Runnable线程案例 使用() -> {} 替代匿名类: //Before Java 8: new Thread(new Runnab ...

  6. rem_taobaofix.js

    https://webresource.cdn.chuma.cn/Library/Rem/rem_taobaofix.js https://webresource.cdn.chuma.cn !func ...

  7. 【Java】 大话数据结构(12) 查找算法(3) (平衡二叉树(AVL树))

    本文根据<大话数据结构>一书及网络资料,实现了Java版的平衡二叉树(AVL树). 平衡二叉树介绍 在上篇博客中所实现的二叉排序树(二叉搜索树),其查找性能取决于二叉排序树的形状,当二叉排 ...

  8. 【记录】group_concat_max_len

    这几天在帮别人定位一个问题,结果定位了半天都没有结果.redis中取出来的数据很奇怪,每次都不一样,而且总是取不完全. 我以为是redis的内存不够,导致数据丢失,但是不应该啊,这么点数据,也不至于内 ...

  9. Hashmap jdk7 死循环

    如果理解的有问题,欢迎大家指正. https://www.cnblogs.com/webglcn/p/10587708.html jdk7的hashmap 由数组和链表组成,存在几个问题: 当key的 ...

  10. CSS3实现原腾讯视频透明边框,多重边框等(关于边框那些不为人知的事情)

    1.hsla或rgba实现半透明边框. rgba在rgb的基础上增加了透明通道,就不详细说了,下面重点说下hsla: 说明: HSLA(H,S,L,A) 取值: H:Hue(色调).0(或360)表示 ...