找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

巢课
电巢直播8月计划
查看: 333|回复: 14
打印 上一主题 下一主题

MCU hang 机, 原因为何?

[复制链接]

65

主题

157

帖子

1867

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

积分
1867
跳转到指定楼层
1#
发表于 2017-10-12 21:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 紫菁 于 2017-10-13 13:09 编辑 , i: F+ [4 N* A/ @4 e/ U% g, s

" k8 G6 U  t* p7 ^5 q$ _5 B: s( Q4 t1. 我司的产品, 用到stm32某款MCU。- y0 c' m: Z* S+ z
2. 近日, 对该产品做Sleep cycle 测试时, 不时出现MCU hang 机的情况。
2 d/ u- B0 ^9 n3. Datasheet 及原理图如附件。
# ]$ d1 K# L* Z4. 理论上, MCU 很简单。 可是问题出现时, 却无从下手解Bug。
' `4 p6 R9 @8 G, I, g1 M5. 有遇过类似经历的, 请帮忙提供个‘思路’。 不一定针对附件的设计。: z( k2 g0 \! \1 q
    a. 电源问题?4 |/ p/ |. k2 @8 @; s! S
    b. 时序问题?
* S3 y9 K$ k& j6 W& A& A+ Z) t5 f  Z    c. Firmware 问题?
% X& f  N1 Z0 a/ E- M. v4 J+ k9 n: [" F
*注: MCU hang  机( 即MCU 停在某一状态。 所有输出, 不再对输入信号有反应。 )
$ ~  C+ v+ u; Z: p8 w! d+ o
3 @+ }" I- p- {# W1 P* H谢谢!
游客,如果您要查看本帖隐藏内容请回复

; S3 Z/ |8 @- h% \2 ^6 l

stm32_mcu.png (303.07 KB, 下载次数: 1)

schematic

schematic
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 支持!支持! 反对!反对!

33

主题

4949

帖子

1万

积分

EDA365特邀版主

Rank: 6Rank: 6

积分
12225
2#
发表于 2017-10-12 22:44 | 只看该作者
本帖最后由 紫菁 于 2017-10-13 13:10 编辑
' D; X) |% t9 S- C4 _7 i! C# ]+ b5 K) s* k
Prequalification trials% p2 f! d5 L' y2 O2 l# L* N' z
Most of the common failures (unexpected reset and program counter corruption) can be reproduced by manually forcing a low state on the NRST pin or the Oscillator pins for 1 second./ ]8 Q5 Q- e# r% G3 g

' o8 X3 K3 u0 p/ zDatasheet 建議你重置試試,看 MCU 能不能重新跑起來,然後觀察會不會再度發生。
% x6 N6 ~/ a. K3 ~! j; q+ |: I* `. O) i" s9 s
To complete these trials, ESD stress can be applied directly on the device, over the range of specification values. When unexpected behavior is detected, the software can be hardened to prevent unrecoverable errors occurring (see application note AN1015).. G; h9 w* p0 g4 z1 X$ e* v
9 v% P: R8 ~' n6 v4 g% ~. O/ a) L
AN1015 教導你利用一些 TimerWatchDog 等技巧,降低意外掛機的情況發生。. L5 c* n7 N* b1 n9 T0 K% q' ]5 l
) V. J5 E! y+ o4 }5 L- l/ W* K
3.11.4 Independent watchdog (IWDG)
- Y1 x! h9 i% a1 MThe independent watchdog is based on an 8-bit prescaler and 12-bit downcounter with user-defined refresh window. It is clocked from an independent 40 kHz internal RC and as it operates independently from the main clock, it can operate in Stop and Standby modes. It can be used either as a watchdog to reset the device when a problem occurs, or as a free running timer for application timeout management. It is hardware or software configurable through the option bytes. The counter can be frozen in debug mode.
& Q# G5 `  n% [+ _; W
9 M" J: c6 f& A- m, i% x2 S& J看門狗IWDG)使用 40KHz 獨立的時鐘源,較不容易受到其它因素的影響,可利用它來防止掛機,或是用來找出掛機的原因。7 E4 A- L; {- g/ D4 \
" e. O4 r# n; f5 t. S2 i
游客,如果您要查看本帖隐藏内容请回复

  E3 f3 a4 f' I3 {& O% f
, Q4 M4 |" M- c! ~6 E- _) `2 `& A3 {: L0 v  [

: x2 @: j# H. J/ R. J
哈士奇是一種連主人都咬的爛狗!

33

主题

4949

帖子

1万

积分

EDA365特邀版主

Rank: 6Rank: 6

积分
12225
3#
发表于 2017-10-12 22:48 | 只看该作者
本帖最后由 超級狗 于 2017-10-12 22:51 编辑 ' z" _/ A1 R, u) Y

5 j' s6 b' W$ q! ]" z5 wAN1015 中提到各種掛機的可能性:
) B* z' W3 e. M( Y: ~  Q+ g
8 h; s3 b* L" V) Z2 _" uExamples of problems induced by EMC disturbances:) A$ K/ f( e3 W% p6 y  [0 l! u
  • Microcontroller not responding
  • Program Counter runaway
  • Execution of unexpected instructions
  • Bad address pointing
  • Bad execution of subroutines
  • Parasitic reset and/or parasitic interrupts
  • Corruption of IP configuration
  • I/O deprogramming
    4 z5 X- V; j6 S$ f5 j& b

( Z. z) H) i: ]+ l% F2 ]8 AExamples of consequences of failing software:
+ ~9 |& b2 D8 {3 D' f+ e
  • Unexpected response of product
  • Loss of context
  • Unexpected branch in process
  • Loss of interrupts
  • Loss of data integrity
  • Corrupted reading of input values
    * Y& V3 @  c3 k" l) T/ L2 {5 B; b
6 F6 j$ _! f( l+ P% K) a5 T
1 C  j8 Z% k" S2 i# K
哈士奇是一種連主人都咬的爛狗!

2

主题

185

帖子

1405

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

积分
1405
4#
发表于 2017-10-13 08:27 | 只看该作者
没什么好办法,如果不能实时仿真的话,只能试着来,用外部有源晶振,排除因干扰而程序跳飞的情况。仔细检查程序中有关循环是否存在某个变量得不期望值陷入死循环的情况。

7

主题

73

帖子

1158

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

积分
1158
5#
发表于 2017-10-13 08:40 | 只看该作者
一般这种情况都是发生了HardFault_Handler 然后一直停留在HardFault_Handler中断里面

0

主题

11

帖子

21

积分

二级会员(20)

Rank: 2Rank: 2

积分
21
6#
发表于 2017-10-13 10:11 | 只看该作者
1、监控下程序运行的情况,看看是在哪里出的问题,是否进入了死循环;/ ^+ y) K9 v* k# I
2、看看干扰问题,尤其是电源的不稳定造成的,还有就是其他干扰造成的误差发

0

主题

11

帖子

21

积分

二级会员(20)

Rank: 2Rank: 2

积分
21
7#
发表于 2017-10-13 10:11 | 只看该作者
1、监控下程序运行的情况,看看是在哪里出的问题,是否进入了死循环;
7 J; N. l3 ?6 T) k2、看看干扰问题,尤其是电源的不稳定造成的,还有就是其他干扰造成的误差发

0

主题

2

帖子

23

积分

二级会员(20)

Rank: 2Rank: 2

积分
23
8#
发表于 2017-10-13 13:16 | 只看该作者
这种情况,个人认为多半是软件导致,可以认真查找软件原因

0

主题

368

帖子

4192

积分

五级会员(50)

Rank: 5

积分
4192
9#
发表于 2017-10-16 09:43 | 只看该作者
看看是不是软件堆、栈相关问题

5

主题

147

帖子

1637

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

积分
1637
10#
发表于 2017-10-18 13:01 | 只看该作者
看一看9 c* i2 v8 ?" H6 H& }" I1 N

41

主题

130

帖子

826

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
826
11#
发表于 2017-10-24 14:03 | 只看该作者
thank you very  much
% s  z& A: Q( J' o" W

0

主题

21

帖子

39

积分

二级会员(20)

Rank: 2Rank: 2

积分
39
12#
发表于 2017-10-31 13:57 | 只看该作者
不见得是硬件问题

2

主题

86

帖子

233

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
233
13#
发表于 2017-11-7 14:55 | 只看该作者
研究了。# C, D, O( W! O. `- f

22

主题

396

帖子

5195

积分

五级会员(50)

Rank: 5

积分
5195
14#
发表于 2017-11-8 10:41 | 只看该作者
看一看

22

主题

396

帖子

5195

积分

五级会员(50)

Rank: 5

积分
5195
15#
发表于 2017-11-8 10:42 | 只看该作者
看一看8 V7 [9 Q! I9 H; t/ r$ h; x0 I9 A
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

巢课

技术风云榜

关于我们|手机版|EDA365 ( 粤ICP备18020198号 )

GMT+8, 2024-11-15 00:46 , Processed in 0.069686 second(s), 34 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表