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

STM32大神笔记,超详细单片机学习汇总资料(干货分享)

[复制链接]
fightingboon 发布时间:2020-7-6 13:52
1、在STM32内部,FSMC的一端通过内部高速总线AHB连接到内核Cortex-M3,另一端则是面向扩展存储器的外部总线。
内核对外部存储器的访问信号发送到AHB总线后,经过FSMC转换为符合外部存储器通信规约的信号,送到外部存储器的相应引脚,实现内核与外部存储器之间的数据交互。
) t: ~# u5 l, f  V. K7 r: H
2、FSMC中的DATASET和ADDSET的设置需要参看外部存储器的时序图来确定。
一般而言,DATASET指的是数据建立时间,也就是读/写信号开始到读/写信号停止(上升沿存储数据)的持续时间。(一般来说写比读快!)。
而ADDSET指的是地址建立时间,指的是片选之后到读/写操作之前的时间,这是针对SRAM来说的,如果操纵的是TFT,不存在地址线,所以此时的ADDSET就是读/写信号结束到RS电平的转换时间。

6 N; Y6 x* j; K5 X  g, c
11.jpg
$ B. @. n$ z3 o( D
3、

" N! F' ?8 K) |7 @& q1 I% h
22.jpg

2 f& I4 g9 Z# b8 I& n0 n
4、

! Q; H" k4 ]1 E& q* p3 z* Q. \
33.jpg

$ T6 K0 X* f9 G- w! H
5、FSMC的三个配置寄存器:FSMC_BCRx(片选控制配置)、FSMC_BTRx(片选时序)、FSMC_BWTRx(片选写时序)。
  m" t( _4 b6 u* k' w
6、RTC时钟配置必须要用到BKP寄存器,BKP寄存器在单片机复位、电源复位、待机唤醒模式下是不会更改值的,他的供电由VDD供电,VDD被切断后自动切换至外部的VBAT供电。

( S' f- U/ i. s- l) W3 k
7、要修改BKP寄存器的值,必须取消其写保护的标志。BKP寄存器在上电时自动写保护。

# P6 X, C/ u! ~$ M' F$ A
8、Stm32有三种省电模式:
; o" l5 T, M( ]' O) z
44.jpg

* L3 L/ u+ |5 S7 X# M: L8 ]. _* x
三种省电模式中,耗电量从上到下依次降低,待机模式的电流仅为2uA。

/ b# L* j& f! W6 f* `; o
9、从待机模式中唤醒单片机等效于让单片机复位,但是电源寄存器的值会有一个标志位指示单片机是被唤醒的,不是被复位的。

2 Q- P5 M$ d' j2 a$ @' C
10、ADC的时钟不要超过14MHz,否则转换精度会下降。最大转换速率为1MHz,即转换周期为1us(14MHz,采样周期为1.5个ADC时钟)

. U; o/ q: ~9 }# Q9 K/ U
11、Tcovn=采样时间+12.5个周期。采样时间尽量选长一点,这样精度高一些,但是转换速率下降,这也是有利必有弊。
" V" [2 x" G! ~/ Q6 P" j$ V- q" _
12、   

) j) S/ \# {" E/ F, m
55.jpg

. ~8 _: \; I% M8 v4 r( q5 X7 I# N
13、拿ARM7TDMI来说,T代表Thumb指令集,D是说支持JTAG调试(Debugging),M意指快速乘法器,I则对应一个嵌入式ICE模块。

" a' t. j6 m; ^8 T4 G* q3 q
14、MMU作为嵌入式处理器与应用处理器的分水岭标志à具有内存管理单元的嵌入式处理器可以定位为应用处理器。
这么说M系列和A系列的处理器的区别在于A系列的处理器具有MMU单元可以进行内存模块的管理。

. l/ V& r2 \7 v
15、ARM处理器有两种状态:ARM状态和Thumb状态。

- ]1 k9 I/ w( a1 n4 P; e& N0 d" i, l1 j
66.jpg
" @0 `9 s' ]" G' \
16、这张图说明了一切:Thumb2指令集做了一件很伟大的事情:将16位和32位的指令集融为一体,兼容性非常强!(这么说CM3不支持某些32位ARM指令集??)
17、

* k) j& d0 t& ^5 K9 m" q
77.jpg

6 g2 o* y- \/ o* R. V4 e3 i; R& f4 X! C) c
18、MSP是系统复位后使用的堆栈指针,PSP由用户的代码使用。两个堆栈指针为4字节对齐!!
; }7 V6 E: h9 Y" @5 |' D; |2 f
19、在ARM编程领域中,凡是打断程序运行的事件,统称为异常(exception)。
$ Q$ \* C0 W. @  }
20、因为存在LR(链接寄存器),所以可支持1级的子程序调用而不用压栈到内存,大大提高了运行速度。---à这就是说,我们在编程的时候,一级调用是不会耗费太多时间的,除非是二级调用!

" p' n- Y) u1 A# l* Q& B
% @6 o1 G; |' j" Q% u" a
收藏 评论1 发布时间:2020-7-6 13:52

举报

1个回答
aiherong 回答时间:2020-7-7 04:05:29
楼主看来是看全了FSMC资料,第3幅图画得好!

所属标签

相似分享

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