|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
$ a4 k& o" ^9 d! Z4 o1.减法指令的误区9 `. \! U+ p9 g5 i' c
* t) R `+ j" E) P- j: |
之一:关于ACC
5 N% M. [/ {1 G7 L& g* [, p% a
. }' \. _- X& Q. h' j4 d) PEMC的减法指令有三条,如下:. J. c' ~# S7 p
+ b& {, e5 C$ C) W$ D% ? B2 h: sSUB A,R (R-A→A)
% k( r* t* w/ j$ p9 ~
' i' }- s! D+ C- M3 TSUB R,A (R-A→R)3 q# W0 u; F/ g0 f" E, P
4 P9 |# c1 w% P4 D! O5 xSUB A,K (K-A→A)
, I# N: V1 E+ f: ]" `
5 E9 U7 l# @7 h8 M! k4 e需要注意的是,不论A的位置在前面还是后面,A都是减数,不是被减数。
1 N* k7 f& u6 m# r, H4 C l
$ b* Y1 w! n1 F$ j) ^/ n$ K1 l也就是說如果我們想計算A-2的值,如果寫成:* K5 P; W5 q; P# V; o
: U3 p. ~: w" j/ b0 s9 D( k% aSUB A,@2
, |' l5 A! T' j$ J) [( k" \6 b# k7 d+ Y" A9 {) S: I
其實是執行2-A# c8 B, _, J: S0 R8 [ A
; n$ L& ^+ F D6 P
解決方法如下:
2 V8 v$ f* ~/ \; h! A# ~- O
$ ~8 c# m0 h! I: VADD A,@256-2 或1 }# J! x8 h$ a/ n
: k- F+ ~6 |& U4 ^2 W0 V8 T- A$ [
ADD A,@254
+ N7 j& a+ ? X( t% g; R- M) K9 @/ ?
之二:关于CY
. b( h3 v0 H7 `! B' m! E+ [3 J
, N+ z5 D9 ] E; T# f5 I$ H一般来说,加/减法都会影响到进位标志CY.2 i# d3 ~% T: E4 e+ [' q
% Q, H' e- O2 {在其它一些 单片机 指令系统中,当减法发生借位时,CY=1,未发生借位时CY=0.
+ c3 u+ c, a5 _; R# r, p; ?$ _+ B. i+ l% B5 O2 K0 v$ }! v3 _
如果你以为EMC的减法也是如此,哈哈,你就要吃药了!
6 u7 r2 `/ H1 U9 g9 k1 V
& c/ R' `5 h6 \0 B原来,在EMC的指令系统中。当减法发生借位时,CY=0,未发生借位时CY=1.& h* I* E. D9 g6 i! `0 j- K; b
0 w; j9 |. K9 n1 e3 L+ h如果不注意这点,很容易在一些运算或判断程序中留下BUG
9 i6 W' t$ ~$ |. t/ Q' l, z" {# v% ?- `* F9 K: b* D
2.查表(散转)指令的误区
. [ [2 e* |& P) J: u* _& _8 X% x: u/ n- {* c
之一:关于“ADD R2,A”指令8 _, e3 [2 ?, ^; a* }! _
% {. [, Y" W; v2 B% V' _" b
在EMC153/156的指令系统中,没有TBL指令(这一点要切记),当要查表时只好用“ADD R2,A”(或MOV R2,A)来代替- U+ C& {0 s3 V! S: I1 r
# ~ U' T: ^2 D \) ]5 T但是使用“ADD R2,A”时要注意,这条指令只能改变PC指针的低8位(即256字节),高位其它位一律清零!) C) p1 J2 \2 Z* B( Z r
$ ]' h& ]1 Z8 s4 o
所以使用“ADD R2,A”时必须保证整个表格都在ROM的每一页的前256字节区间内。(153/156只有一页)
, [$ I7 `+ P+ O1 Z, P* I
: e# @' G5 j3 R5 _7 e; b. @大表格的使用受到了限制,而且为了将表格“挤入”00H~FFH的ROM空间,程序的结构受到破坏。8 G, s% p& S1 n2 c
. D% [9 d# e# [1 r" ]- X b$ _( \
之二:关于“TBL”指令; ?$ ?' }3 C' p0 [8 `* w$ A0 R
/ [: X" t- y) J刚才说道,“ADD R2,A”指令使用的诸多不爽之处。
& K" l6 q' J/ k4 C# t9 y- x* T" t1 v4 l! J$ T$ Q* ^0 X* @) I
为此,EMC在447/458及后续的芯片的指令系统中,增加了一条新指令----就是TBL指令。
1 H% X% W3 M* }# `' @4 `" ~$ R7 o6 s+ u& s
TBL是查表指令。号称可以放在程序的任何位置。 |
|