你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

​STM32硬件开发指南

[复制链接]
STMCU小助手 发布时间:2021-2-4 13:22
STM32硬件开发指南

( x+ A/ k! n# ~1 D0 X6 h
STM32硬件开发指南
) t# M. ?9 a' q" d
一、STM32简介

4 d" z- x3 y; s( `
1.1 STM32简介

! s' |+ |. L. g8 [- ?" Z5 u; p
STM32 系列微控制器是ST公司以ARM公司的Cortex-M0,Cortex-M3,Coretex-M4三大嵌入式为内核的系列产品。按内核划分,STM32 有以下几大类产品:
: A) z# R; I9 b. o
(1)    Cortex-M0内核:STM32F0系列;
(2)    Cortex-M3内核:STM32F1系列,STM32F2系列,STM32L系列;
(3)    Cortex-M4内核:STM32F4系列。
" T) O& }( j( H. e- H; M, x
1.2 STM32 F1主流微控制器系列

# H' I9 Z( y0 a3 B
作为一个主流的微控制器系列,STM32 F1满足工业、医疗和消费电子市场的各种应用需求。凭借这个产品系列,ST 在全球的ARM®Cortex™-M 微控制器中处于领先地位,同时,树立了嵌入式应用的里程碑。该系列最大化地集成了高性能与一流外设和低功耗、低电压工作特性;在可以接受的价格范围内提供简单的架构和易用的工具。该系列包含五个产品线,它们之间引脚、外设和软件相互兼容:

# {1 B" j8 S0 o$ _2 p8 g' x: K1 t2 h+ `
(1)    超值型系列STM32F100 - 24MHz最高主频,集成了电机控制和CEC功能;
(2)    基本型系列STM32F101 - 36MHz最高主频,具有高达1M字节的片上闪存;
(3)    USB基本型系列STM32F102 - 48MHz最高主频,具有全速USB模块;
(4)    增强型系列STM32F103 - 72MHz最高主频,具有高达1M 字节的片上闪存,集成电机控制、USB和CAN模块;
(5)    互联型系列STM32F105/107 - 72MHz最高主频,具有以太网MAC、CAN以及USB 2.0 OTG功能。

7 Y4 Y% y3 I& A! u. p& M3 {
1.3 STM32 L1超低功耗微控制器系列

8 G  e- z7 _4 k/ f7 _% O, N* C
STM32 L1系列,基于Cortex-M3内核,工作频率为32MHz,在性能、特性、存储器容量和封装引脚数量方面扩展了超低功耗产品系列。STM32 L1系列融合了高性能和超低功耗的特性,采用了优化的架构和与STM8L 系列一样的专有超低漏电生产工艺。STM32 L1分为两个不同的产品(STM32L151和STM32L152),具备了STM32F 和STM8L 的优越功能,是高性能、低功耗的应用领域的最佳选择。

! [1 F" y! X+ I4 O% Y3 J
(1)    最低功耗模式:0.27 μA
(2)    动态运行模式:230 μA/MHz
" O1 l2 w, J% ~+ F
1.4 STM32 F2高性能微控制器系列

. j. m2 X" b4 A) S* L1 F
内置ARM® Cortex™-M3内核的STM32 F2系列采用了ST先进的90纳米NVM制造工艺技术,并且利用了创新的自适应实时内存加速器(ART加速器)和多层总线矩阵技术,具有前所未有的性价平衡比率。

8 T5 p; `, R, g! x- E" w
这个系列具有很高的集成度:高达1M字节闪存、128K字节SRAM,具有以太网MAC、USB 2.0高速OTG、摄像头接口、硬件加密支持和外部存储器接口。
) k) s+ j. Z7 R! x8 b# ^
ST的加速技术,使得MCU在120MHz主频下能够实现相当于零等待周期的性能,达到150DMIPS,同时保持动态功耗在极低水平的188μA/MHz。
可用封装有LQFP64,LQFP100,LQFP144,WLCSP64(< 4 × 4mm),UFBGA176 和LQFP176 。
8 }- R$ Y; s4 g6 }( F0 u
1.5 STM32 F4 具有数字信号处理和浮点运算指令的高性能微控制器系列
' t/ B) U5 R" F% `- U# c
基于ARM® Cortex™-M4处理器的STM32 F4系列微控制器产品,是业内领先的STM32系列MCU的扩展,旨在提供更高的性能。与STM32 F2系列一样,该系列微控制器同样采用意法半导体的90 纳米工艺和特有的ART 加速器,在工作频率为168MHz 时处理性能达到210 DMIPS/469,这是迄今所有基于Cortex-M内核的微控制器产品所达到的最高基准测试分数。
6 ]7 A, T. r; ]7 P# E
数字信号处理指令和浮点运算单元扩大了产品面向的应用范围。
& T& q5 }& W/ W5 g4 u
STM32 F4系列是微控制器的实时控制功能与数字信号处理器的信号处理功能的完美结合体,为STM32 产品系列增添了一类新型器件——数字信号控制器(DSC)。
* w! d$ N. U. n9 Q- n9 u
STM32 F4系列保持与STM32F2系列的引脚到引脚及软件兼容,并提供更多静态随机存取存储器,同时改进了部分外设,如全双工I2S 总线、改进型实时时钟(RTC)和速度更快的模数转换器(ADC)。
8 T& V' S! G2 |
可用封装类型包括:LQFP64、LQFP100、LQFP144、LQFP176 和UFBGA176。

" @* |3 F0 o, I5 z
二、注意事项

, C: I: Z' T& e2 K  L+ p4 H* Q/ z
半导体工艺制程的进步,使得内部线宽原来越细,芯片工作电压也越来越低。这对于工
程师硬件设计来说,提出了更高的要求。
9 R3 r# D* R6 N3 d3 A
2.1 电源
4 z) v8 \) u) X/ [
为STM32工作提供一个干净的稳定的可靠的电源在硬件设计中是非常重要的。保证STM32系列微控制器的供电电压都是其允许的电压范围之内,以确保STM32 的正常工作和设备的安全可靠地运行。
5 S6 n) [6 U5 H3 q. w9 c
3.5.png

* `  V3 R# \4 ]7 o  w9 _/ ^
STM32系列微控制器的供电电压范围:
1 A, C/ x) w% S  @# U3 M, M
3.1.png
# i# p0 b( Z& _  M/ ]+ S7 H* @
STM32系列的电源结构基本都有:内核电源区域、主电源区域、ADC电源区域和备份区域。每个部分对供电的要求也有所不同。

2 _% @: H1 A) l4 p' D
2.1.1 内核电源区域

2 `- v+ |' Q# Z( R4 H( T
STM32 的内核电源区主要为内核等一些数字电路提供电源,而且STM32系列内部都嵌入了一个电压调节器给内核提供一个稳定的电源电压。
% M$ g& T% Z3 e% ~% E
(1)    STM32F0系列,Cortex-M0,内核电压是1.8V;
(2)    STM32F1/F2系列 ,Cortex-M3,内核电压是1.8V;
(3)    STM32F4系列,Cotex-M4,内核电压是1.2V。
" {( w6 d; M$ _# U
由于工艺等原因,一些TM32系列的内核电源要求使用一个外部的内核电源滤波电容,在ST的资料中标识为VCAP电容。从ST公布的资料看,此电容是在内部电压调节器之后,给内核电源滤波,提供一个稳定的电源。VCAP电容引申到了芯片的GPIO端口,留给用户连接一个电容(据说,降低了芯片的设计面积,降低了芯片成本)。
4 v3 K  d7 J) u/ v  d. Z
VCAP电容在STM32F应用的情况:
& L/ M4 U& f) m0 z  P* g
3.2.png
6 H: [+ z+ B4 i2 w# V8 _- b
* 不同封装的STM32,其VCAP电容引脚也不同,详细的请参考相应的数据手册。

0 x* Y! M  L# L/ k
注意:
1)      PCB布局时,务必将VCAP电容贴近STM32芯片。越靠近,越好(VCAP电容引脚,相对于把内核的电源线拉出来了,外部的干扰较容易进到内核。VCAP的连接线越长越容易收到干扰)。
2)      VCAP电容要求可靠稳定。理想的是使用钽电容,其受温度等因素少,性能稳定。考虑到成本,VCAP电容使用一般的陶瓷贴片电容就可以了。

! @7 d8 K  ^8 c; o
2.1.2 主电源区域
确保给STM32的供电电压都能在其允许的电压范围内。除此之外,还要进一步考虑靠近电源引脚上加电容以储能,确保STM32在电压瞬间跌落时,还可以保证STM32电压在正常的范围之内。

* S+ N4 x; C! J$ b
注意:
一般地,在VDD主电源引脚上加上一个电解电容(如10uF ~ 200uF),并且再并上一个小的贴片的瓷片电容(103/104瓷片电容就可以)。电解电容和瓷片电容一般成对出现,并且在PCB布线时,将这两个电容尽可能地靠近STM32 的VDD 主电源引脚。
VCC、GND、VDDA、VSSA、Vref等引脚,都需要连接,不能悬空。
每对VDD_x与VSS_x都必须在尽可能靠近STM32的引脚处分别放置一个10nF~100nF的高频瓷介电容。

/ ^5 M) v! z8 v- H
2.1.3 ADC电源区域
STM32的ADC电源的参考电压Vref+依据不同的产品系列而不同:
3.3.png
1)      如果实际电路中,如果没有使用ADC,也必须将ADC的电源VDDA、VSSA和Vref(如果有的话)连接到电源和地线,不能悬空;
2)      如果在实际应用中使用了ADC,理论上,建议将PCB中数字电路单元和模拟电源两部分分开;
3)      根据不同封装,如果STM32有Vref-引脚,必须将其连接到VSSA。

& G  \+ {3 x( n& {
2.1.4 备份电源区域
STM32提供了一个备份电源,用户内部备份寄存器保存数据。STM32有一个专用的引
脚VBAT引脚,使用电池或者使用其他电源时,连接到此引脚上。当VDD断电时,STM32会自动切换到备份电源上,这样可以保存备份寄存器的内容和维持RTC的功能。
STM32系列不同供电的单元也不尽相同:
3.4.png
注意:如果在应用中没有外部电池,建议VBAT在外部通过一个100nF的陶瓷电容与VDD相连。

6 [3 Z0 e  d) V- I  s+ E+ N
2.2 调试
SWJ调试端口是STM32内核集成的串行线/JTAG调试接口(serial wire and JTAG)。
STM32F0支持SWD调试。
3.6.png
SWJ电路设计注意事项:
(1)    nJTRST、JTDI、JTMS/SWDIO 和JTDO引脚推荐使用10K电阻上拉至VDD,JTCK/SWCLK引脚推荐使用10K 电阻下拉至VSS;
(2)    仿真工具(STLink,JLink)通过20个脚插座的1号脚判断目标板是否供电,通过19号脚可以向目标板供电(3.3V,<100mA)
& ~" j) B5 d" t1 _: Y5 h
2.3 未使用的GPIO端口的处理

* U/ n4 [( @% c0 t' |; E& U
从目前一些工程师反应的意见来看,有如下几个解决方案:
(1)    悬空,不做任何处理(不推荐);
(2)    将GPIO设置为输出方式(据说,可以抵挡外来的干扰,因干扰是输入类型的);
(3)    将使用的GPIO通过上拉或下拉电阻接电源或地(上拉或下拉电阻一般为10K欧姆)。
0 d6 i, t1 q- }3 f3 ?7 G
2.4 STM32的I2C接口
2 E0 j8 T% ]& g2 m/ w1 L/ `, m# F; D
对于STM32的I2C要特别注意。STM32的I2C是真正开路输出的,在作为GPIO时,需要上拉一个电阻才能正常使用(一般地,上拉电阻为4.7K欧姆)。不使用时,建议通过一个上拉电阻接电源。
& t  C& A1 |7 ?
2.5 Boot Loader

) e. k+ A, ]( ?1 M
STM32内嵌了Boot loader帮助用户下载固件,其映射在UART1口上。由于STM32在复位后,其GPIO端口为高阻抗状态,这时线上可能会有一些噪声,造成通讯信号的不稳定。可在UART1引脚上拉两个电阻(一般为10K欧姆左右),以提高数据通讯的可靠性。如下图所示:

- y. @& _, ~; M1 \
3.7.png

1 E$ @/ {( D( @9 o# S
2.6 STM32与大电流器件地线的布局
% B/ E% {3 t: x6 |/ z; L' q
在PCB 上若有一些大电流器件或电路单元(如TFT-LCD,大容量存储器,大电流驱动
等等)。建议分别接回到电源地上,如下图所示:
2 R7 ~$ F7 R* A$ Q. B
3.8.png

6 H$ x: B6 s  [6 F  d0 o( D, v
三、STM32低功耗设计时,IO引脚的配置
' M# g% {7 b. f( S( h! }7 v+ A6 t
可以这么处理:

5 Y+ Z7 d( P( K% i  t
3.1 将未使用的GPIO输入配置为模拟输入

6 e: A9 M. O* C! T
GPIO始终有一个输入通道,可以是数字或模拟通道。如果不需要读取GPIO数据,则优先配置为模拟输入,这节省了输入施密特触发器的消耗。
在STM32CubeMX配置中都有这么一个选项:将不用引脚配置为模拟状态。

3 A: a0 N4 Y9 S; R8 X
3.9.jpg

# u! Z( |5 ]7 R/ T) X( t) k
3.2 调节GPIO速度
6 |3 Q) \: f- c5 I
上升时间,下降时间和最大频率可使用GPIOx_OSPEEDR配置寄存器进行配置。这种调整对EMI(电磁干扰)和SSO(同时开关输出)有影响,因为开关电流峰值较高。因此必须平衡GPIO性能与噪声。每个GPIO信号的上升时间和下降时间必须适应与相关信号频率和电路板容性负载兼容的最小值。

: x, P$ A& E( X! M2 I& `5 t: f
3.3 不使用时禁用GPIO寄存器时钟

0 A8 h5 w8 S1 Q5 A3 K# h# d$ e
如果某个GPIO组不需要长时间使用,禁用其时钟。
比如标准外设库,禁用GPIOA时钟:

( q2 x/ K$ v2 y/ I  S
  1. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, DISABLE);; ~! B6 ~4 T6 y7 x+ w  V
  2. br
复制代码

2 l2 S3 y) {4 M9 F$ l- j
HAL库,禁止GPIOA时钟:
  1. __HAL_RCC_GPIOA_CLK_DISABLE();
    # B" y0 s1 z" U
  2. br
复制代码

( B. d4 ^3 U* [4 D' u% Y
3.4 进入低功耗模式时配置GPIO

! y, y! p! P6 M# b! y/ Z
进入低功耗模式时,所有引脚信号必须连接到VDD或接地。如果GPIO连接到外部接收器(外部元件输入),则必须使用PP或PU/PD强制GPIO信号值。当GPIO连接到驱动器(外部元件输出或总线)时,驱动器必须提供有效电平( VDD或接地)。如果未定义驱动器电平,则必须使用PU/PD强制GPIO上的信号。出于实际原因,当GPIO是运行模式下的输入(模拟或数字)时,在低功耗模式下使用输入PU/PD可能更容易;当GPIO是运行模式下的输出时,则使用输出PP。这可以避免在进入或退出停止模式时管理更改。
& n2 E4 u8 [" K0 k
3.5 退出关机模式

* k$ v! W8 ?( n8 _6 r' b
退出关机(shut down)模式时,GPIO会在上电复位时重新配置为默认值。
在将它们重新编程为正确值之前,这会需要额外的系统消耗。
如果这是应用程序的问题,则必须使用待机(standby)模式替代关机模式(仅限STM32L4系列和STM32L4+系列)。

7 m- L1 ]$ W! b2 _2 y7 q- D$ \- M
免责声明:本文素材来源于网络,由雨飞工作室整理。引用素材,版权归原作者所有,如涉及侵权,请联系删除。谢谢。

* }6 i- t% h! {  L5 C* F: k! x! w
文章出处: 雨飞工作室

) z( T7 O% m" D; ?2 a
) }- P" S& m0 Y' K. S4 l) S2 x
收藏 1 评论1 发布时间:2021-2-4 13:22

举报

1个回答
kylixyao 回答时间:2021-2-4 18:25:26
很实用

所属标签

相似分享

关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版