找回密码
 注册
关于网站域名变更的通知
查看: 58|回复: 0
打印 上一主题 下一主题

单片机工程师最重要的7个能力

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2023-2-2 15:32 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x
01设计满足要求的最精简的系统$ M7 B" B" Y: N
正确估计单片机的能力,知道单片机能做什么,最大程度的挖掘单片机的潜力对一个单片机系统设计者来说是至关重要的。我们应该有这样一个认识,即单片机的处理能力是非常强大的。4 _' I. Y' `: H' n/ ?3 \0 G; K7 M& R& a
早期的PC机,其CPU(8086)处理能力和8051相当,却能处理相当复杂的任务。单片机的能力的关键就在软件设计者编写的软件上。只有充分地了解到单片机的能力,才不会做出“冗余”的系统设计。而采用许多的外围芯片来实现单片机能实现的功能。这样做,即增加了系统成本,也可能会降低了系统的可靠性。) x& D1 r$ x! X/ E! ]" n+ H2 Q# ?3 V! ~+ J5 \% N3 x
02

' T1 @* V0 m% ~- x# Y. z6 X
使用看门狗
. |1 D) `. Y" d1 g8 ?
4 D+ X: L  Z% t  N
看门狗电路通常是一块在有规律的时间间隔中进行更新的硬件。更新一般由单片机来完成,如果在一定间隔内没能更新看门狗,那看门狗将产生复位信号,重新复位单片机。更新看门狗的具体形式多是给看门狗芯片相关引脚提供一个电平上升沿或读写它的某个寄存器。使用看门狗电路将在单片机发生故障进行死机状态时,重新复位单片机。
2 s& d" w" J! b+ l2 N
当前有多种看门狗的芯片,如MAXIM公司的MAX802、MAX813等。而且,有好多种单片机中本身就集成有看门狗。一个外部的看门狗是最好的,因为它不依赖于单片机。如果可能的话,看门狗更新程序不应该放在中断或是子程序中,原则上应该放在主程序中。- }: H) u7 k8 W6 C% a
  Z, h& a/ Y/ s1 }) S9 u  C3 s我曾经见过一个工程师,他所调试的程序在运行时偶尔会引起看门狗的复位动作,于是他干脆在每10ms就中断一次的时钟中断程序中清看门狗。我相信他也知道使看门狗失去作用,可他却没有去查明引起这个现象的真正原因。因此,我想提醒大家:不论什么理由,绝对不要忽略系统故障的真正原因。高质量的产品来自于高素质的工程师,高质量的产品造就高素质的工程师。+ j! n, R0 F* v- U
+ a, U! ?* v4 B' z+ e/ O
03
  s. G/ s2 e, Q. Z% G2 Q
确定系统的复位信号可靠
8 D. q# T" v$ P% d5 _2 u+ k
) m1 k% U+ ~: ~* U4 x  j' c/ j) x+ `+ d) T$ C' e( s8 L0 w' J; h* D/ j
这是一个很容易忽略的问题。& v1 W" f& C0 H. K, }# e; N6 }# K% c9 J/ J. F5 c3 e2 _% W
  • 当你在设计单片机系统时,你脑中有这个概念吗?
  • 什么样的复位信号才是可靠的吗?
  • 你用示波器查看过你设计的产品的复位信号吗?
  • 不稳定的复位信号可能会产生什么样的后果?
  • 你有没有发现过你所设计的单片机系统,每次重新上电启动后,数据变得乱七八糟,并且每一次现象并不相同,找不出规律,或者有时候干脆不运行,或者有时候进入一种死机状态,有时候又一点事都没有正常运行?在这种情况下,你应该查一下你的系统的复位信号。4 \4 y* C7 W' i4 n1 G2 e. r0 W  p! _# ]$ S
    9 W; V% v/ v. a- \5 `
/ g& c! H4 Y  A4 G4 a$ ~$ y8 g, L0 t! u* h8 e- G0 p: X% ?
一般在单片机的数据手册(Datasheet)中都会提到该单片机需要的复位信号的要求。一般复位信号的宽度应为。复位电平的宽度和幅度都应满足芯片的要求,并且要求保持稳定。还有特别重要的一点就是复位电平应与电源上电在同一时刻发生,即芯片一上电,复位信号就已产生。不然,由于没有经过复位,单片机中的寄存器的值为随机值,上电时就会按PC寄存器中的随机内容开始运行程序,这样很容易进行误操作或进入死机状态。/ I! \3 g6 y2 j4 E! i
04
2 _* w- d2 q' }. a- I3 v$ `! k% N+ j5 m, |
确定系统的初始化有效
9 J2 J% J* @/ ]) J* [( M  {1 n

# w' Y1 j# o" W系统程序开始应延时一段时间。这是很多单片机程序设计中的常用方法,为什么呢?因为系统中的芯片以及器件从上电开始到正常工作的状态往往有一段时间,程序开始时延时一段时间,是让系统中所有器件到达正常工作状态。究竟延时多少才算合适?这取决于系统的各芯片中到达正常工作状态的时间,通常以最慢的为准。

8 @2 L& z* Y: Q5 R一般来说,延时20~100ms已经足够。对于系统中使用嵌入式MODEM等“慢热”型的器件来说,则应更长。当然,这都需要在系统实际运行中进行调整。5 T' m) P. }$ L4 s
1 K0 r! f3 }' z- `" _7 [) e% s6 M3 h
& B- @/ E& Z  F* }3 N
05

# w! k% H) V! Y2 D7 R
上电时对系统进行检测
+ w) W. N, W& k* N* g9 ~
) g, C* j! C* I% P' W+ k/ M4 h; I8 E, S# Y+ D( T  G6 m5 ~
上电时对系统中进行检测是单片机程序中的一个良好设计。在硬件设计时也应该细细考虑将各个使用到的芯片、接口设计成容易使用软件进行测试的模式。很多有经验的单片机设计者都会在系统上电时(特别是第一次上电时)进行全面的检测,或者更进一步,将系统的运行状态中分为测试模式和正常运行模式,通过加入测试模式对系统进行详细的检测,使得系统的批量检测更为方便容易。另外要注意的是,一个简单明了的故障显示界面也是颇要费得心思的。2 E2 m& b- c: j
比如:系统的外部RAM(数据存储器)是单片机系统中常用的器件。外部RAM如果存在问题,程序通常都会成为一匹脱缰的野马。因此,程序在启动时(至少在第一次上电启动时)一定要对外部RAM进行检测。0 {8 }7 P2 C/ G/ P
( l) v: Z* n6 {* l. F4 Z2 y检测内容包括:9 l5 ^/ Z5 U1 }8 {! G- T9 C1 j* L/ ^
  • 检测RAM中的单元。这主要通过写入和读出的数据保持一致。
  • 检测单片机与RAM之间的地址数据总线。总线即没有互相短路,也没有连接到“地”上。8 b$ h- D/ D7 R; e

    + V. ~1 ]7 [7 F0 f& B( [

( L3 k, ?1 T" H9 }$ }9 A另外,很多芯片,都提供了测试的方法。如串行通信芯片UART,都带环路测试的功能。
  `) @. e% g; ~! F
06

8 v2 {% U6 o! z$ C8 c, E" N
EMC测试要求设计硬件
! Y9 k) w3 E. k# V
& g, Y4 n! W1 i. v! U  |2 W$ C$ P" A1 @8 v; k
1 t* y  \6 k4 HEMC测试要求已经成为产品的必需。# }( T) J. b0 U( N2 }/ _
# {; Q- T7 E8 [. U8 ?; }! X% q" p: `1 {  K+ I
* c2 |0 E# D; d3 C/ N2 m1 G; i: c  H6 E8 u& [
07
8 t) o, j2 F! ~
尽可能使用Small模式编译
% s, }6 }+ m' k, Q
0 M; K2 n5 e4 W  U* f; z) b' Y" |4 d3 m( X! p5 H! M' V2 o
对比起Large模式和Compact 模式,Small模式能生成更为紧凑的代码。在Small 模式下,C51编译器将没有使用关键词,如idata、pdata、xdata特殊声明的变量通通放在data单元中。在编程中,对于在的数据区,可以指定放在外部存储器中。
, `9 S3 y2 W) t# J* M
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-24 06:08 , Processed in 0.140625 second(s), 24 queries , Gzip On.

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

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

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