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

【经验分享】STM32F7学习第一次笔记--一些混杂知识点

[复制链接]
STMCU小助手 发布时间:2021-12-12 21:55
和F1的一点区别:
( v- ^: ~+ X5 l; [$ D  b/ U- G& W& U, W
GPIO_Initure.Alternate=GPIO_AF7_USART1;多了这么一个东西用来对复用端口进行复用功能选择,F1不用选择,刚看到目前还不知道为啥。2 W6 c1 E) k5 r/ V0 B& o8 o
F7不支持位带操作- z" C9 ?* n  G5 Z
**
) v* L* U& L( \" S3 \$ m, z2 M3 D9 }% e
767中断
8 x3 [# ~& K9 ^1 h1 R0 i7 q5 W5 yCM7内核支持256个中断,767使用了118个,包括10个内核中断和108个可屏蔽中断。具有16级可编程中断优先级。/ s! n& H( D6 P
20210113172219789.png
( h( K- n0 B( z; a" M  g2 ?7 J: q  h
% d: w/ |6 f8 [8 X6 B3 |. `* s. G
ISER[8]:中断使能寄存器组,8个32位寄存器来控制CM7的256个中断,767自由ISER【0-3】有用,要使能某个中断,相应位置一, L4 g$ P* A3 p
ICER[8]:中断除能寄存器组,和ISER相反的功能。
8 g. g; l: Y! y& s2 u0 HISPR[8]:中断挂起寄存器组,将对应位中断挂起,执行其他同级或高级中断。; C. `8 M0 A0 Q9 h, [
ICPR[8]:中断解挂控制寄存器组:
0 \) i7 q% O/ v/ t! y# dIABR[8]:中断激活标志位寄存器组:对应位为1表对应位中断正在执行,通过它判断正在执行的中断,硬件清零。0 X: L( c+ }" F1 o
IP[240]:中断优先级控制寄存器组:240个八位寄存器组,767用108个。IP【109】-IP【0】(98,97没用),每个可屏蔽中断的8bit用了高4位,分抢占优先级和子优先级。$ v- W+ U7 q0 l( p# p7 T+ k. f

7 V( b, W, {0 N' r1 S% h9 X% v
, D" V4 R; M6 d7 p8 P
2021011317321818.png
7 A0 Q  z. e7 g" i2 j

9 a4 C2 ^5 H) G2 {! C抢占优先级级别高于子优先级,数值低为高优先级。
2 c+ W$ D, B% Z# `0 ]+ s( G; d2 j; n3 \, ^

9 I& F# C# W0 {% F. m7 lSYSTEM文件夹0 }9 a. M3 Q/ J! a5 p+ B8 Y
delay
* p  f" x& H0 s3 O- x% g0 n5 o3 l# [( }
20210113212421444.png

6 |( j. h5 a7 ?. k6 I6 W使用SysTick定时器,24位倒计时,不占用中断和系统定时器。/ f  a2 g) @# ?" t: {% k
在ucos操作系统中,有SysTick提供时钟节拍,这个时钟一般不能打断。
! D/ f/ r( A5 V/ b2 @这里的延时只是抓取SysTick值得变化,不修改,所以不影响ucos时钟节拍。! C! S$ D4 C3 ]

9 }& S9 v& d+ G: P) q
20210113221828459.png
3 P9 x. T$ ?8 x6 W1 g9 _* y+ ?

1 d6 O, _, x5 C在这里插入图片描述这里delay_ostickspersec是用来设置os时钟节拍的,由注释可见时钟节拍最大为77.7ms,这里767的SYSCLK值为216,如果要设置时钟节拍为5ms则设置delay_ostickspersec值为200,216000000/200=1080000,每个值计时1/216us,1080000/216=5000,即为5ms的os时钟节拍。0 i. M' X) R: T* i' m
reload*1000000计数值结束即为1s
3 q9 ?4 z# ~" {8 Y9 G4 [# F1 }8 ~& Z4 d
fac_ms值为os能延时的最小单位,比这个值小delay_ms就不会使用OS延时,而使用delay_us()来实现延时。如这里delay_ostickspersec值为200,fac_ms就为5& E6 \7 T% m, O/ f1 \" E' ?
2 }  x& x2 j: V  Y  [) t
Sys3 e" q5 X" d; Z( }' u$ S  _' H; b+ C

3 M' L4 O+ J/ D1 k1 F* g9 d* z1 K$ H
20210114124733452.png

8 ?* L7 O. L4 H! l) {; O$ ~, k' v, r9 Q- W7 Y& t- C! m4 G
开启数据cache和指令cache,并保证D-Cache和SRAM的数据保持同步刷新,防止数据不一致。# n7 ~7 U! ]- C' `! D
这个文件还负责重命名一些类型以及初始化时钟+ b( Y* K, x5 ]  _: n
& s  g( H: U1 m- V4 f% H1 q4 w
Usart
9 V1 n% P% C! y+ [1 |1 Aprintf函数支持,如果要修改一般就修改相应的串口号。6 e& i: n( h2 X: m- |
, w2 t2 d4 J! `3 k
GPIO  D" K! p" P7 i) U  E# t& A
开漏模式可以读IO输入电平变化,此模式可以把端口作为双向IO使用。- Z% ^8 Q- Q2 `# u* _, w& }

; v+ z9 H+ I+ F. J2 vHAL_GPIO_TogglePin();取反输出电平,内部是ODR寄存器的值决定输出电平。8 A2 F8 F# @2 f4 B' }: p9 ^
( q0 B4 x8 a/ s& D
BSRR寄存器和ODR寄存器功能相似,低16位写1输出高电平,高16位写1输出低电平。
, v8 M5 M9 U+ a2 H( B; Q, l8 MHAL_GPIO_WritePin(GPIOx,GPIO_Pin,PinState);
$ w# V0 ~- w! h8 G" n# `" [0 B1 ^* l& C( C
IDR寄存器用来读取GPIO口状态# c( J6 _# L. X, D! {# N7 M
HAL_GPIO_ReadPin(GPIOx,GPIO_Pin);
. r( M- t6 s* b) n& h& Q. d$ ?3 ^. j  Q: S
2 V1 @* l$ ^) v- h5 K$ [& c7 Y& \) j6 N
$ g+ {& ~: u! w7 `4 h
收藏 评论0 发布时间:2021-12-12 21:55

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版