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

STM32系列ARM Cortex-M3微控制器原理与实践 PDF 精华

[复制链接]
wttloon 发布时间:2009-5-3 14:52
阅读主题, 点击返回1楼
收藏 1 评论5904 发布时间:2009-5-3 14:52
5904个回答
shaxjl 回答时间:2013-5-29 11:05:45

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

感谢楼主
yangjingshan 回答时间:2013-5-30 10:06:58

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

太好了,非常需要原理和实践相结合
yangjingshan 回答时间:2013-5-30 10:07:46

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

太好了,非常需要原理和实践相结合
yangjingshan 回答时间:2013-5-30 10:22:59

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

太好了,非常需要原理和实践相结合
3106009309-1502 回答时间:2013-5-30 11:02:50

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

怎么感觉像数据手册!!
petermeng 回答时间:2013-5-31 14:31:27

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

看目录感觉不错,下载下来看看!
天易 回答时间:2013-5-31 14:45:25

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

看看
tryzyxp 回答时间:2013-5-31 15:20:47

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

STM32其他问题集锦
  D+ t% V! G: Q( W2 t4 ?$ n5 ~
7 D+ _, f( K. z" \, @! K* ^5 H1、使用JTAG download程序至STM32F205XX(with Cortex-M3)
+ _) c) l5 N& s! ]3 i, o问:請教各位先進,若欲使用JTAG interface下載程序至STM32F205XX的板子,似乎一般是透過SEGGER的J-link,是否可使用其他的JTAG-USB下載線如Altera出的USB Blaster?7 z+ u. g# n  `) P5 F5 _
又是否只要符合JTAG規範的傳輸線皆可?9 y6 D9 A# t& W5 [) @
答1:只要支持M3并且支持STM32F2XX系列就可以,不一定非要JTAG,也可以使用SWD。% P( Q# y+ D8 Y0 v
答2:ARM KEIL ULINK也行,兼容性非常好呀!
) ?" A8 g5 p% j5 r" ^5 p; i2、STM32触摸屏& }- K; I* o7 R
问:我想用STM32来触摸一款触摸屏,因为我现在还不了解STM32以及触摸屏,所以我想问一下,具体用那款单片机型号最好? 最好是STM32内部已经具有触摸屏的控制器了。屏有没有数据传输总线是32位的,正好和单片机总线一样 。另要求屏的色彩深度也是32位或者是24位。3.2寸左右,这个可大也可小点。 能不能也推荐一款触摸屏的型号,以及相关资料。$ _" I; b" W$ O1 U2 ^& p; ^
答:1、这个需要根据显示屏来决定,市场上也有很多触摸的显示屏,STM32可以用过SPI、FMCS、IO口等来控制,这个要看你选择的类型 2、型号和资料,这个要找厂家要,厂家一半都会给你合适的建议和 源代码。3 d" I9 |* ^# B; T
3、STM32可以做什么
, f( l6 }% {8 H9 M问:学习了STM32可以做什么?有什么用途或者前途,请告诉,不胜感谢。: w2 u/ f* r; [1 ]4 t& J
答:可以用的方面比较多,比如工业、消费、医疗等。这个要根据产品的需求来决定使用的芯片。
+ u+ X& Y- t9 W1 x" v" O/ I! @
5 Y1 X, c& \! j9 C7 D4、STM32F2X系列能能驱动多大尺寸TFTLCD呢?用FSMC模式
' H7 u2 }- O) T问:STM32F2X系列能能驱动多大尺寸TFTLCD呢?用FSMC模式,显示简单的菜单,参数等操作
* l1 Z2 r5 o4 u# k( g答:这个没有具体的参数,个人认为10.0一下都没问题。) X: }( X1 s# b

; e% ]6 o! Z+ V5、VDD与VSS的去藕电容如何处理?, a5 z7 M: _4 F7 S
问:VDD与VSS的去藕电容如何处理?
! @, a9 r7 h9 C* W& O, Z1 y答:1、每对VDD与VSS都必须在尽可能靠近芯片处分别放置一个10nF~100nF的高频瓷介电容 2、在靠近VDD3和VSS3的地方放置一个4.7μF~10μF的钽电容或瓷介电容
+ \5 d5 N4 S) v
' l6 ~( m& g# I6、系统时钟的监控和切换的作用是什么?
& x5 }  |- y. p6 N. R1 R  @( E' d问:系统时钟的监控和切换的作用是什么?
; l) A7 q1 I4 l- E' M( w; Z6 A最佳答案:STM32作为一个可靠稳定的微处理器,但是不能排除由于某些外界特殊因素可能造成STM32的外部振荡器失效,所以在芯片中需要一种包含机制能够在STM32运行时,一旦外部晶体振荡器(HSE)失效,切换STM32的系统时钟源到一个稳定的时钟源,以保证STM32能够继续运行,并进行相应的保护操作。# M" I8 P$ |4 o3 W

! M& B& ^3 o! R7、PVD的作用是什么?
4 {2 P% @) ^: b答:在应用开发中,通常都要考虑到当系统电压下降或掉电状况,一旦出现该状况应对控制系统加以保护。故在程序中需要加入对系统电压的监控。当供电电压降低到某一电压值时,需要系统进入特别保护状态,执行紧急关闭任务:对系统的一些数据保存起来,同时对外设进行相应的保护操作。
7 b$ i& |3 v3 c
7 X# ~" l5 f2 W8 u8、STM32的三种低功耗模式是什么?
' Q. |+ _" L3 U  s/ b/ P: B答:1、睡眠模式Sleep:电压调节器开启,Cortex-M3内核停止运行,外设保持运行态; 2、停止模式Stop:电压调节器可选择性开启,所有外设时钟、PLL、HSI和HSE被关闭,Cortex-M3内核和所有外设停止运行,保留SRAM和寄存器的内容; 3、待机模式Standby:电压调节器关闭、整个1.8v区域断电。除了备份区域和待机电路的寄存器以外,SRAM和寄存器的内容全部丢失。
' B' K4 R8 s. I$ I8 B
1 ?; Q, Y6 ~" L  I9、STM32103RB的TIM2 channel1以及UART2的CTS都是PA0 pin, 他们是怎么区分的?  _0 q* \, M3 ^( B- K
答:IC的一根管脚,做多种外设的复用pin,很常见,在PA0上,只能作为一种外设的管脚,但两个外设能同时用吗,当然是可以的。可以设置STM32中有的寄存器AFIO_MAPR来配置复用管脚及外设接口的重新映射,比如你选择PA0为UART2的CTS,PA0肯定不能再作为TIM2的channel1,但可以设置TIM2的channel1的管脚为PA15,请参考如下寄存器说明: Bits 9:8 TIM2_REMAP[1:0]: TIM2 remapping These bits are set and cleared by software. They control the mapping of TIM2 channels 1 to 4 and external trigger (ETR) on the GPIO ports. 00: No remap (CH1/ETR/PA0, CH2/PA1, CH3/PA2, CH4/PA3) 01: Partial remap (CH1/ETR/PA15, CH2/PB3, CH3/PA2, CH4/PA3) 10: Partial remap (CH1/ETR/PA0, CH2/PA1, CH3/PB10, CH4/PB11) 11: Full remap (CH1/ETR/PA15, CH2/PB3, CH3/PB10, CH4/PB11)
, D& l9 j7 E& F$ S" w( _* N( f0 W0 Y 4 l5 y- k) |" m3 K

1 l+ F2 [6 u6 Y+ t10 CSMA/CA算法
7 F8 B8 A7 O# z* s* r7 d. [6 t问:STM32W108CBU64执行一次CSMA/CA算法是延时多长时间?2 ~3 q* s6 f! s# ]# H3 F
RadioTransmitConfig radioTransmitConfig = {  z+ g, L( T7 V2 z
TRUE, //waitForAck
+ H/ }" y5 D3 S) |9 [, H0 |TRUE, //checkCca# n( K& `+ P2 @1 S# W- T! a* q3 ^
RADIO_CCA_ATTEMPT_MAX_DEFAULT, //ccaAttemptMax! J0 w' r9 b& ?* V& N, \; s$ n7 `
RADIO_BACKOFF_EXPONENT_MIN_DEFAULT, //backoffExponentMin( Z  @( [5 j0 ?6 X% Y0 L6 z* E
RADIO_BACKOFF_EXPONENT_MAX_DEFAULT, //backoffExponentMax; F2 t! f- X! b
TRUE //appendCrc5 e/ d+ [' E. ^2 x) P8 M
};/ `" D3 N+ ^- r. T
答1:更简单的可以设置两个断点,看下右下方的运行时间,就知道了!
3 G8 E" L) Z8 Q, Y" R$ L答2:这个没有计算过,你可以在计算前加个定时器获取值,计算完以后再获取一下定时器的值,这样就知道时间了。4 I  Q$ C, N1 e7 p( e
; t. c$ n+ |! U" u6 F

0 R. e. a8 U. A, g  _11、STM32F4系列软件仿真问题- i2 e1 i; Y' S* P/ H
问:STM32F4系列能用Keil4.54,的debug进行软件仿真吗? 我一仿真,程序指针跳到0x00000000处。很奇怪
4 \- t; b3 _5 y而且peripherals菜单选项没有了。 请问这是怎么回事?4 ?1 Y3 z' p* j

$ g" }8 W# Y- G, W0 D0 Z答:可以。说明你程序有错误,而不能跳到启动。你应该下载一个最新的KEIL
9 G  B2 w; d9 N  @4 C7 B! \
8 l4 N; s+ ~4 V- {( X7 c  Y, F
! R1 h) i& @" y( u 1 ^+ b" g/ Q0 ~! r4 z& [
12、进入SLEEP模式的省电要操作哪些流程?
7 J1 ^% ^: L2 C; l4 _; @/ l- A问:进入SLEEP模式的省电要操作哪些流程?0 O4 B  R& J0 s4 X* q7 A
最佳答案:  Z0 B& i8 F/ u8 I5 w% _% c, u
1、关闭无需等待中断或事件的外设时钟;
. K* J: {2 H( w$ z2、设置进入机制(Sleep-Now或Sleep-on-Exit);( J: I  a, L# Q
3、设置系统进入SLEEP模式。  `  I- q5 e9 j% x- Y
1 [- @4 e! d3 b
8 C( w: a9 p4 a  x8 h# y; H
13、STM32W 的 wireshark 用Mxchip 的ADK-DK 可以充当吗?
2 x7 i8 U7 M5 ]: T( U+ c* i
% O' ?8 X8 P# M$ b% g) t2 U7 D! J9 ]问:STM32W 的 wireshark 用Mxchip 的ADK-DK 可以充当吗?
" o2 ~. t2 h, h* U答:Wireshark 抓包器需配合MXCHIP的sniffer-W使用,ADK-DK无法充当。( u, W3 F6 [/ H- {

3 r' r9 ^4 y! m( K3 J' R14、STM8A不能从CAN接收中断中唤醒Halt模式
4 |8 z4 I9 Y# o4 l- j) K' b. w. h问1:我是做车载CAN通信的,使用STM8AF51AA的MCU,但是发现CAN接收中断不能唤醒Halt模式,但是改成Wait模式就可以唤醒,Walt模式的功耗过高,不符合车厂的要求。说明书上是说两种都可以唤醒的,我现在不知道是我的设计有问题还是芯片不支持,哪位大虾遇到这种情况的,可以跟大家一起分享吗?谢谢啦!* X8 X4 Q0 g4 Y* C
答1:1、WKUIE中断开启了吗? 2、支持该功能,你怎么判断他没有进入唤醒?第一包的数据会丢失。
9 N' u8 d, R4 y$ M# t; i+ W问2::WKUIE中断已经开启,因为我在Wait模式下可以正常唤醒,所以中断设置是正常的,我在中断函数里面打个断点,等待中断的到来。3 v# M9 D9 B0 i; a& c
答2:这个时候仿真不管用。你最好使用LED和串口调试信息
1 Z) r: K. C! o/ I/ t ( f1 I' N  }8 ~( M- W! `+ f
15、F0 discovery 固件库在IAR6.0上运行时提示错误
/ m! n& M. @: z' f6 M+ [2 o问:IAR ELF Linker V6.40.3.54009/W32 for ARM# D9 W/ E1 w. z" S! f# t+ T
Copyright 2007-2012 IAR Systems AB.
, x7 P% R+ G( I* t+ \Error[Li005]: no definition for "SYSCFG_EXTILineConfig" [referenced from F:新建文件夹STM32F0系列测试程序Test1DebugObjstm32f0_discovery.o]
9 u- ?" l7 e/ x是哪里的问题呢?我运行demo就无错误) j, s3 @) M! `+ ]' e
Error[Li005]: no definition for "EXTI_Init" [referenced from F:新建文件夹STM32F0系列测试程序Test1DebugObjstm32f0_discovery.o]
& H7 v, J2 L4 p3 W2 358 bytes of readonly code memory
9 t( h$ Y0 p- O* n1 f5 `  K90 bytes of readonly data memory6 o% ]8 C1 n& @! J9 Y1 j
1 057 bytes of readwrite data memory. P2 D: y) K5 J, [: |! M
Errors: 2% ?# I3 _9 p- m6 t4 f6 @; I$ R
Warnings: none( U2 ?1 c$ P1 K# J
Link time: 0.05 (CPU) 0.05 (elapsed)
& z. t5 T: Z) `! c) nError while running Linker
& {) |) W* |9 i: P3 R3 ^Total number of errors: 2
& c0 B" h( s  J. t" p, oTotal number of warnings: 0
* d1 l4 a+ p$ w/ B
* n6 I' M+ u3 U( y. O( n2 m答:说明这2个没有被定义,请仔细看一下,是否正确定义。3 l% }) X3 t+ \( p

$ i. o; I* n+ [& p5 `  y+ d16、系统时钟的监控和切换的作用是什么?
2 m* {& M% [! ?问:系统时钟的监控和切换的作用是什么?  \4 p; i# V. W4 c
最佳答案:STM32作为一个可靠稳定的微处理器,但是不能排除由于某些外界特殊因素可能造成STM32的外部振荡器失效,所以在芯片中需要一种包含机制能够在STM32运行时,一旦外部晶体振荡器(HSE)失效,切换STM32的系统时钟源到一个稳定的时钟源,以保证STM32能够继续运行,并进行相应的保护操作。9 ^5 T7 l0 N* h8 h

% T  R2 a% `! A17、STM32W108CBU64执行一次CSMA/CA算法是延时多长时间? ( G5 N5 d2 v3 F2 G' t2 D
问: RadioTransmitConfig radioTransmitConfig = {+ f  L) i! a& o
TRUE, //waitForAck) M8 f) A& a: L1 O; G
TRUE, //checkCca
9 }) ]* g3 p& A" L) n7 g8 I0 _RADIO_CCA_ATTEMPT_MAX_DEFAULT, //ccaAttemptMax
& W3 E& Z& `7 U* k7 o! xRADIO_BACKOFF_EXPONENT_MIN_DEFAULT, //backoffExponentMin
# C! r/ m( o" S' p* CRADIO_BACKOFF_EXPONENT_MAX_DEFAULT, //backoffExponentMax
6 e% r# e1 e% w2 c4 |( lTRUE //appendCrc
4 C; \! K5 A# j: ]: V- ?# S};  
1 ~, T: J1 I, @. m' z3 }最佳答案:更简单的可以设置两个断点,看下右下方的运行时间,就知道了!' P; A: N1 E+ E$ I, a
) R/ i+ d. K' C" g$ a+ W9 Z) A
18、STM32F407和Android系统的平板电脑通讯问题$ e8 B$ u5 k0 L
问:请问我想用stm32f407的usb和Android系统的平板电脑通讯,现在我知道在xp和w7系统下都可以做到,那在Android下能兼容吗?如果不兼容都需要做哪些工作呢?希望能进快给我答复谢谢。
2 ~+ Q9 N  m  d9 H0 {答1:按照android的通讯协议做就可以。' Q0 q$ K0 p; ?' }2 o3 v
答2:这个方向我也正在做、已经琢磨了很长时间了、有难度、关键是硬件不懂软件、软件不懂硬件还有协议的问题、后来考虑了个方法但是还没有实施你可以实施看、用stm32枚举成U盘、将你要表达的- S' N! c6 Z; r$ A# d) A; s
协议写成文件格式、你需要收的文件也由android做成文件、以文件的形式来交互协议 # f, s) o) `) W3 A

" J7 X0 ^( E& i19、关于100Pin MCU FSMC的应用咨询0 G# N/ B" A4 Y  O
问:根据ST datasheet描述,100pin mcu 的fsmc只支持NE1和NCE2,意味着只能外挂Nor/PSRAM和无中断功能的Nand,并且低地址A[15:0]和D[15:0]是复用方式。
; E) k! }+ H0 q- R0 Q请问:0 P; M. T% z, J0 x
1:NADV信号是否只有在Nor模式下才能有效输出锁存信号,而在SRAM模式下输出无效信号?0 f& ^+ C4 Q+ v7 A9 z5 {2 k0 b7 E
2:如果外挂一颗IS64LV25616这样的SRAM,该如何将复用的A和D分开?
1 p& F; P; l/ {8 ]9 D3:如果使用100pin这样的FSMC,是否一定要外加地址锁存器,诸如74XX573这样的芯片才能将复用的A和D分开?0 \4 a2 A# t1 N
4:如果使用100pin这样的FSMC,市场上有没有与之对应的Nor和SRAM,可以自己解锁出总线上的A和D,ST有没有这样的chip? & q6 W9 n0 l2 C, k& x" n3 ?
答:1、我要看看手册 2、AD复用,也就是只能用1个 3、最好加锁存器 4、有对应SRAM,这个你可以参考各个开发的设计8 v. B* o" h0 p- i6 b. v

; j  D  D7 `; w% L- ^9 h" H+ I/ |20、stm32F207的相关资料从何处下载?
) u5 j  [& S" u. j) A问:stm32F207的相关资料从何处下载?比如说,库函数,应用说明,时钟等等。最近做项目要使用stm32F207,但对这款芯片了解甚少。- T( [. y0 u; f1 d6 U9 u
答:您好,这个可以到社区的资料下载。或者到官方网站的F20X资料区下载。6 e7 n9 n5 F/ F/ K- n' @

7 K: x6 M5 [' O4 n21、STM32的官方例程在哪下载呢?
/ M) o  [  Q$ t# S0 W# s' Y, t问:STM32的官方例程在哪下载呢? . T, ], J' ~1 S5 `
答:你好,社区的资料下载栏目,以及论坛里都可以找到。
6 f4 o' p! l5 T" O2 S5 Y* l1 f$ U& n详见:1、 https://www.stmcu.org.cn/download/index.php?act=ziliao* M0 X0 V( u" h* p' o
             2、  https://www.stmcu.org.cn/bbs/forumall_244.html. C3 D9 a4 M. [  R5 `5 H
; F3 i/ l7 Q- E- ?5 U
22、用内部HSI时钟时,外部时钟引脚应该悬空还是接地?; U: D' }5 M, n+ A  |- _# e: D

2 }- k/ J. u( f: N& W0 j问:用内部HSI时钟时,外部时钟引脚应该悬空还是接地?
8 b6 U( K7 `1 R, g) I! _5 F- O最佳答案:悬空。接地都可以。最好是接地
8 Z1 |* j2 V/ r5 B' `7 i' Z
- C1 `- H" y. D, H0 x+ Z3 i23、stm32f103c8t6芯片烧写问题& ?4 S2 L9 }% \- O

% Y9 K; y1 _5 @2 A5 F; U  D问:如题芯片首次jlink烧写程序没有任何问题,第二次烧写,jlink就不能识别,请问什么原因?  \6 c" Z) l$ c& M" V4 w, A. f
现在是第一次连接上jlink以后,jlink就出现问题了,直接显示是红灯了还有一个问题,jtag的上拉下拉电阻是不是可以不接?还有32.768Khz的晶振是不是也可以没有?
1 t# u8 E+ n! f$ J2 {8 U; C; @答:第一次烧录时应该是空的IC吧,没有烧录过任何CODE吧。用JLINK烧录完成后会自动断开连接,如果你没有对BOOT进行设置就不能再次烧录。BOOT设置可以查看DATA SHEET。
- c. P, c8 a% U3 g 0 P, o3 L) P9 h, A
24、CPU休眠后无法唤醒
1 m/ K, O$ i, N2 S问:CPU休眠后,RTC无法让它唤醒,外部触发也不能唤醒,示波器测试小晶振,有正常的波形
/ m6 _" M' ]5 _* z0 Q答:这种情况也有可能是因为你对数组或者指针操作的时候引起的程序错误,而进入硬件错误中断。
5 h7 v- A4 n# ]7 o - {2 d& l( H$ N6 k1 h% o( J
25、请问STM32W108CBU64可以构成星型网络吗?8 O# e# k1 R+ ^: b
! ]7 c3 r) @5 N% g9 l8 o# U
问:可以组成多少个子节点?
& @/ t, G! h+ E6 O' ^4 ]$ E( t. K# @最佳答案:一个局域网可以有很多电脑,只要IP地址不一样就可以& q8 V3 H  |0 r) p5 |) E  B. A
9 O4 ~6 N/ ]- h. B$ }) G8 Q" f
26、请问各位大虾STM32F207的Camera接口支持ITU-R BT.656格式的数据输入吗?
9 n& ^- i  ]8 f- g$ z5 q' }- Y % D4 D6 Y+ p" m3 [8 D3 i# y9 K
问:本人想通过TVP5150将复合视频信号转为ITU-R BT.565后,经STM32F207的Camera接口送到LCD显示,不知道是否能实现,请各位指教。4 _" c4 z5 d6 U0 M9 W
答:可以,但是效果不是很好。毕竟频率才72Mhz。  }7 o/ S. l& a7 s( |/ B

- U+ E, W2 N4 v7 {5 v$ F( z- w $ V; a4 F! ], P+ q3 o1 t: u0 N
27、LWIP和freertos的移植问题$ w( c0 F" F* \2 c% O) s

( P: l, l- c" V) m6 T+ E0 ?/ m问:请教大家一个问题,我现在想做lwip和freertos的移植,我在金牛 STM32F107_ETH_LwIP_V1.0.0例程的基础之上移植了freertos,为了验证我的系统移植没 有问题,首先我通过利用二值信号量的方式,实现了按键中断等简单程序,在这些都成功的情况下我把System_Periodic_Handle();做在了一个任务函数中,调用这个任务希 望实现telnet等基本功能,总是失败,最后我发现是不能进入总是进不去9 `; D2 Y$ K9 H* B/ R8 B
EXTI2_IRQHandler(void)中断。我把中断这一块屏蔽了,在任务函数中加入7 j# }: d5 {4 T3 a1 w% a! w% |) q
if (ETH_GetRxPktSize()!=0)0 b3 u7 J3 c! U# i$ w* q# i
{
6 F. I. h1 g2 ~: q% Z- p$ OLwIP_Pkt_Handle();
5 \' R/ _1 A; D4 _2 c3 C$ ]2 ~6 m}) }* d/ y8 K  V1 Q8 F8 Z; B5 k
这样就发现没有问题了,各项功能都能实现。为什么加上系统之后外部中断没有问题而网络中断不能进入,需要修改其他方面设置吗? 我又在官网(stmcu.org)上下载了STM32F107通过以太网实现在程序中编程(IAP) 就 是an3226.进行了简单的修改能在金牛板子上运行了。首先我将例程修改为通过 EXTI2_IRQHandler(void)中断实现TELNET,这样成功,这说明我对EXTI2_IRQHandler (void)的初始化是成功了。再次基础之上又做了freertos的移植,但是还是不成功。 在freertos下如何设置中断才能进如
! i. m* f4 h  i% X9 }$ Z+ X- e0 Jvoid ETH_IRQHandler(void),还有什么方面存 在问题。菜鸟一个问的条理性不太好希望有人帮忙,万分感激。* q2 T4 y4 r/ X! l
答:这个问题发生的远不能因是你没有处理好中断,你还是处理一下吧.注意系统中中断向量列表处理。- U  i0 }0 E, @: {- X) p

1 E  C7 s' _' ]1 ]/ @$ @
; g: D8 X: e; ], m) s5 `/ ~28、stm32f107广域网互联& x/ s' R+ x; ]6 r0 V3 h% \
问:利用两块STM32F107开发板,分别置于两个不同的地区,如何通过公网建立通信,传输语音和其他的一些控制信息 是不是还要用到路由器之类的
, c( u* Y; C. C$ U5 G2 ^2 }9 d8 c答:如果你的距离不超过100米,可以直接用以太网连接,如果超过,就需要走网络了。如宽带,GPRS等。
# x2 d& {; _' p1 G- q  29、关于LWIP和freertos的问题: H9 Y5 f5 p3 G: |9 |

, Z8 `! A* Z, R* y% R1 ~/ f问:请教大家一个问题,我现在想做lwip和freertos的移植,我在金牛 STM32F107_ETH_LwIP_V1.0.0例程的基础之上移植了freertos,为了验证我的系统移植没 有问题,首先我通过利用二值信号量的方式,实现了按键中断等简单程序,在这些都成 功的情况下我把System_Periodic_Handle();做在了一个任务函数中,调用这个任务希
) V0 ~( n4 P8 f6 R6 K2 I望实现telnet等基本功能,总是失败,最后我发现是不能进入总是进不去 EXTI2_IRQHandler(void)中断。. l# V( b' s2 c% X
我把中断这一块屏蔽了,在任务函数中加入 # z6 t. A- P- g- U; q$ W; B5 q/ s
if (ETH_GetRxPktSize()!=0)
! E  S* n* [  t" K9 _, f{   K1 h$ e4 C+ c4 F# V5 f
LwIP_Pkt_Handle(); $ F4 N. P% P0 ~( ^' w- H  b  n
}
9 N& P" x* T/ B$ v( r% o这样就发现没有问题了,各项功能都能实现。为什么加上系统之后外部中断没有问题而 网络中断不能进入,需要修改其他方面设置吗? 我又在官网(stmcu.org)上下载了STM32F107通过以太网实现在程序中编程(IAP) 就 是an3226.进行了简单的修改能在金牛板子上运行了。首先我将例程修改为通过 EXTI2_IRQHandler(void)中断实现TELNET,这样成功,这说明我对EXTI2_IRQHandler (void)的初始化是成功了。再次基础之上又做了freertos的移植,但是还是不成功。 在freertos下如何设置中断才能进如voidETH_IRQHandler(void),还有什么方面存 在问题。菜鸟一个问的条理性不太好希望有人帮忙,万分感激~~~
, U# u1 P) g! T8 N5 C" r答:这个问题发生的远不能因是你没有处理好中断,你还是处理一下吧.注意系统中中断向量列表处理.0 j  m* a0 S, D

6 R- {4 l; ]  l" \6 ^; N6 j7 @30、keil环境下,如何将函数定义到指定的FLASH地址; R% {9 a* M+ t3 u% x4 D, O

: Y" G8 l( q3 a6 a+ |8 b6 q问:keil环境下,如何将函数定义到指定的FLASH地址?定义常量变量到指定地址我知道可以通过__attribute__((at(addr))),但是函数的定义不会啊!, n; {8 l/ t% q% ~, |9 I2 f& R5 M, ^
答:#program ROM 类似的语句,详情你可以参考帮助
, J/ M+ b: }" U/ e9 z% M
: L! Y; j' d9 v+ k% V( V( J$ n31、STM32103 USART1死机
9 v9 h4 ?/ Y/ ~6 k( y  n, o & T* H) G; }7 h/ K  ?4 a6 c' Q
问:
, z1 a! w: t2 C* fvoid USART_Receive(USART_TypeDef* USARTx) ( u4 w% e. ^5 w' m. C; ]
{
/ m1 t# E) r& Z; E  b4 kif (USART_GetFlagStatus(USARTx,USART_FLAG_RXNE)==SET) 2 J' L! W2 ?0 C, L9 A
{& s5 a) @3 s8 A! K* [/ l9 _
USART_ClearFlag(USARTx,USART_FLAG_RXNE);
8 D6 q% E! h+ h: {: X" @s[0]=USART_ReceiveData(USART1);
2 C+ y5 W8 x2 f/ @' g7 ~delay(1000);+ w% b6 `0 O* E
s[1]=USART_ReceiveData(USART1); 8 `# \( i/ A/ s
delay(1000); " T+ e& z. V4 p& ?
s[2]=USART_ReceiveData(USART1);
1 D' W+ s  D3 S7 ]delay(1000); & o6 O; g% e0 u! E" d& V
write_char(s[0],s[1],s[2]); //发送数据到PC
) O4 A0 d) ~% K( n# O
; |/ G: n' i5 i//if(s[0]==0xff){GPIO_WriteBit(GPIOE,GPIO_Pin_0,Bit_SET);} // //write_char(s[0],s[1],s[2]);
2 J) ^& {" R0 b" Y// query_uart_command(); //命令判断 4 ]. q$ [. F6 |9 i  a
}0 }9 b3 [& P) W: I
}
( \6 W3 j$ U, B/ ^9 ~上面程序在
; m; I) P+ X1 }8 U! B发送FF的时候收到FF FF FF
9 i4 u: L0 l1 c& {3 C发送FF 22的时候收到FF 22 22
8 U$ D6 E1 D1 x发送FF 22 33时收到FF 22 22
* y; u" k; [' k( [: f9 m8 D' |之后再发送数据时串口不响应!!!
& z) L+ G. t/ m& `0 N  t" Q; y' R5 H7 R* M5 J最佳答案:
0 R$ [! A% F0 [3 bstm32串口有个可以说是bug的地方,就是即使不使能溢出等其他错误中断的情况下,若发生溢出错误,仍会进入中断,而且常规检查中断的方法无法查到中断标志。所以办法就是在串口正常中断处理之后加清除中断的语句。具体网上可以找到。之前因为这个原因,程序经常死掉,结果是死在串口中断处理里,不停中断,有没有清除中断标志哦。1 T" X( T. @% W! |: J
5 }& o, \# N8 T- [& Q( ^" n
32、关于STM32读取陀螺仪的是电压值,怎么经过积分变成角度的问题, y3 E7 U' ?$ ?
问:请问下,STM32读取陀螺仪的是电压值,怎么经过积分变成角度?而且积分函数怎么写呢?
  }+ E5 N6 {* B3 n3 H) H9 r
6 I/ F0 M+ x" b答:陀螺仪有个参数a,叫做灵敏度,单位是(°/s/V),有个参数b,叫静止电压,单位是(V). + b5 q- F, I4 p& c2 e8 x, J
你写的程序有个参数叫做采样率c,单位是(S/s),有一个叫做ADC基准d,单位(V),有一个叫做ADC分辨率e,没有量纲,还有一个ADC输入值f.
3 O5 V9 g+ O9 A+ w9 c: i4 }$ l* E知道什么叫做积分,什么叫做微分吗?能够不背概念,按照自己的理解说一遍吗? 假设,每次采样的u分别为u1,u2,u3,...u1000, & M( u8 I$ b2 Y) N! S
令v=u1+u2+u3+...+u1000,v就是从u1到u1000的采样时间内角度的偏差. 就是从采u1到采u1000期间,陀螺仪转过的。/ t+ D6 Y" H# X, @8 o

0 J" v, T  P0 x. z33、STM32F107可以和TI的无线接发模块CC2520配合使用吗?
. W( c  P. r. _/ ~
% X) U) o0 `- `1 o/ V6 e) l. c. H问:STM32F107可以和TI的无线接发模块CC2520配合使用吗?如果可以,可以怎么实现呢?烦请各位大侠多多赐教!小弟刚刚接触这方面的内容。再次拜谢!
; k, b  e0 V( h答:无线接发模块CC2520是什么接口,i2c,UART,SPI?主要是看接口支不支持。。 ! {) g0 }# v# W$ s+ S2 k

. V; x, i! H0 C- e4 b' M9 w 34、关于STM32自带的bootloader的功能: @) {7 i- c% E+ J  ~; k' ?, x
问:STM32F107:memory mapping地址0x00000000-0x0003FFFF中存放的是什么?如果是历程,则主要是做什么功能,这段程序能不能被读出?8 [& {' w3 X- l4 c
答:在系统复位后,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。用户可以通过设置BOOT1和BOOT0引脚的状态,来选择在复位后的启动模式。 在从待机模式退出时,BOOT引脚的值将被被重新锁存;因此,在待机模式下BOOT引脚应保持为需要的启动配置。在启动延迟之后,CPU从地址0x0000 0000获取堆栈顶的地址,并从启动存储器的0x0000 0004指示的地址开始执行代码。这段代码被固定在MCU内,不能通过外部来修改。) C% r- H' p0 s8 E0 M, b4 J/ L* R
35、关于STM32的代码加密问题
  A) [9 Q3 j: B8 D1 F% z) S 7 v0 L9 Y3 a- z+ R8 y8 P3 l
问:产品选用STM32F103,目前电路设计仅留了20pin的JTAG口。请问一下该如何加密。据说如果采用JLINK的secure选项加密,JLINK以后是无法识别和擦除的,请问一下该如何加密。目前串口、RST、BOOT脚单板上没有预留。谢谢。) [0 \: w. _1 V
答:Jlink加密以后,将不能读取FLASH中的内容,但是可以通过JFlashARM先将FLASH擦除掉,再进行新的程序烧写。
! t* c5 Y$ o" \
5 F9 D8 K* u7 T! S( t% h% d* R36、VDD与VSS的去藕电容如何处理?
; S, _( f+ D- n9 A$ W0 d# q3 s
" r2 `1 D$ g7 g! _问:VDD与VSS的去藕电容如何处理?
) d+ d$ ]1 a' C' ~# |1 M; y! y答:1、每对VDD与VSS都必须在尽可能靠近芯片处分别放置一个10nF~100nF的高频瓷介电容 2、在靠近VDD3和VSS3的地方放置一个4.7μF~10μF的钽电容或瓷介电容 / Y+ W7 \/ C$ J& F

7 o9 @1 ^+ E, @9 \( H: ~37、stm32f107 每次ping通要重上电
- V  O- J; ]8 M3 x: g: G, G $ d$ T: q$ M' m, J" a9 o
问:您好,请教一下,107的芯片,phy是lan8700,仿照STM32F107_LK做的硬件,官方例程,mii模式,但是下载之后每次需要重新插拔电源才行,按下rst键或者下载都无法ping通,看了一下,phy初始化已经完成,不知道是哪里有问题,谢谢给分析下
" h! z7 h# c9 l9 s答:应该是你发送完毕数据以后,没有结束。你仿真一下,PING完以后,下一次ping的时候,程序运行的状况。# N. K/ w* }: L
至少你没有加PHY的reset,要不不会每次reset都无法ping通5 k4 k$ s3 T/ U

8 x% k) {" W2 K38、仿真问题/ H& i# q0 t6 }. w4 j
+ c, |" N5 c( p: J6 x3 n0 ^1 b
问:keil4 STM32仿真里面怎样给USART1送入数据?
1 p! }5 Q0 |" y答:软件仿真的话,可以监视到USART1接收的数据。但要是给USART1送入数据的时候我一般用JLINK硬件仿真,加上电脑的串口助手发送。仿真中可以在USART1中设置断点查看数据是否发送成功(中断接收的时候)。
8 J: n. {* j# m4 ]7 Q 2 G) n0 n/ ~6 N2 N6 t( U
& B9 S' E- W0 |: P! V' B: U
39、关于STM32 寄存器变量 ! Y4 a+ @6 z, n1 m- H
  G  u9 A+ c7 G, D2 V0 S! ~
问:STM32 寄存器变量 #define __IO volatile __IO uint32_t USART_Rx_Done = 0; USART_Rx_Done = 1;
2 ]8 L- t7 d& n  ^' M7 V7 s怎样知道这个寄存器变量的地址,它是一个标志位 应该是有地址的 为什么在KEil中看不到
& @4 p$ _# y, F& o答:都在标准库里,你只能编译后,工程里包含的库文件才会出来,然后你选中寄存器变量,点右键,然后选择里面一个“涉及此参数”的选择。就可以找到地址了。
# V' u5 D7 B0 H/ E* D9 m
: u- |% `) g/ `2 ~6 s, s& O40、程序问题
( r9 H5 m, O0 h: w2 @
% r$ A- u  a. V+ h% t% @) m5 I问:SET == USART_GetFlagStatus(USART1, USART_FLAG_RXNE)  这句话是什么意思8 ~: ]1 U4 a* w1 I* I1 t! p
答:当接收引脚有数据时,状态寄存器的USART_FLAG_RXNE就会为1,此时USART_GetFlagStatus(USART1, USART_FLAG_RXNE)的返回值就为1(SET),若无数据则为RESET,本语句一般用于while(SET == USART_GetFlagStatus(USART1, USART_FLAG_RXNE)),或if语句作为检测或判断条件# |- Y: q) G- G1 U% e3 {. w5 l
* x3 q3 c9 L# n; N1 d" v
41、STM32重映射) p, v) C2 q4 k

$ A7 ~3 J8 p! y( P! A问:为了使不同器件封装的外设I/O 功能的数量达到最优,可以把一些复用功能重新映射到其他一些脚上。这里的映射到其他脚上的意义是不是,假设GPIOA的PA1的复用功能是ADC1,那么是不是可以通过改变映射地址,将其映射到GPIOB的PB1上。% L3 m- C5 j  }* \
答:重映射的作用简单的说就是把管脚的外设功能映射到另一个管脚,但是不是可以随便映射的,具体对应关系参考手册上的管脚说明。比如USART2_TX默认在PA2管脚,当启用复用功能后就会将PD5管脚作为USART2_TX。另外也不是所有的管脚功能都能重映射,比如ADC1_IN0就只能在PA0。) T( P  E0 C7 m; `

3 q# J( e& S" \" D42、STM32F417ZG批产烧程序
' Y" l4 C; Y. Y
" O  W& {6 }8 z* q( R$ d3 z/ s% Y问:请问如何批量烧程序,源代码是不能给工人的,只能是编译好的二进制机器码。用的是正版的iar jlinkV8,找了几天没找到能够直接下载二进制的功能。uart串口方式烧写太麻烦了,而且产品不用串口。
% [( g: P% `9 S7 f8 }+ `7 U答:可以,安装jlink的时候有一个J-Flash ARM的程序,这个可以直接烧写bin文件。' V" _% w. p. I6 a
[最后修改于2012-11-07 18:24]
YIN976061-36250 回答时间:2013-6-1 11:55:45

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

不错
minjia_111 回答时间:2013-6-3 13:18:33

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

yes,very good. X, X- C- x, C" S$ p- M, F& L
 
wangying515 回答时间:2013-6-3 15:12:55

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

 是扫描版吗?
斌5520-2016401 回答时间:2013-6-3 21:56:14

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

下来看看谢谢
595400 回答时间:2013-6-4 20:24:42

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

看看
cgh364301 回答时间:2013-6-5 17:58:41

回复:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

 多谢了
blueitaly 回答时间:2013-6-5 21:29:29

RE:STM32系列ARM Cortex-M3微控制器原理与实践 PDF

新手上路,请多指教。先下载,后学习,谢谢!

所属标签

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