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

[EMC小知识] 2大EMC基本指令误区

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-3-23 14:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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是查表指令。号称可以放在程序的任何位置。
  • TA的每日心情

    2019-11-20 15:22
  • 签到天数: 2 天

    [LV.1]初来乍到

    2#
    发表于 2022-3-23 14:58 | 只看该作者
    EMC尽然还有指令

    点评

    我也是第一次听,世界之大啊  详情 回复 发表于 2022-3-23 15:24
  • TA的每日心情

    2019-11-19 15:32
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
    发表于 2022-3-23 15:24 | 只看该作者
    mutougeda 发表于 2022-3-23 14:58# R# M' F; T8 W$ l" Y& X7 M
    EMC尽然还有指令
    ( u6 F8 F+ L  H+ y7 b. D+ Q
    我也是第一次听,世界之大啊9 ]; s$ ~; ]$ ^! E+ j5 g1 i" N
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-7-20 15:54 , Processed in 0.109375 second(s), 24 queries , Gzip On.

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

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

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