关于EMC基本指令的2大误区

EMC的基本指令语法,其实也就57/58条,如何变化折腾,就看各位的修行造化了。

但是,新手上路总容易进入一些误区,而老鸟们的一些技巧也值得借鉴。

废话少说,言归正传,且看匠人娓娓道来……

 关于EMC基本指令的2大误区_设计制作_EDA/IC设计

 1.减法指令的误区

之一:关于ACC

EMC的减法指令有三条,如下:

SUB A,R (R-A→A)

SUB R,A (R-A→R)

SUB A,K (K-A→A)

需要注意的是,不论A的位置在前面还是后面,A都是减数,不是被减数。

也就是說如果我們想計算A-2的值,如果寫成:

SUB A,@2

其實是執行2-A

解決方法如下:

ADD A,@256-2 或

ADD A,@254

之二:关于CY

一般来说,加/减法都会影响到进位标志CY.

在其它一些 单片机 指令系统中,当减法发生借位时,CY=1,未发生借位时CY=0.

如果你以为EMC的减法也是如此,哈哈,你就要吃药了!

原来,在EMC的指令系统中。当减法发生借位时,CY=0,未发生借位时CY=1.

如果不注意这点,很容易在一些运算或判断程序中留下BUG

 2.查表(散转)指令的误区

之一:关于“ADD R2,A”指令

在EMC153/156的指令系统中,没有TBL指令(这一点要切记),当要查表时只好用“ADD R2,A”(或MOV R2,A)来代替

但是使用“ADD R2,A”时要注意,这条指令只能改变PC指针的低8位(即256字节),高位其它位一律清零!

所以使用“ADD R2,A”时必须保证整个表格都在ROM的每一页的前256字节区间内。(153/156只有一页)

大表格的使用受到了限制,而且为了将表格“挤入”00H~FFH的ROM空间,程序的结构受到破坏。

之二:关于“TBL”指令

刚才说道,“ADD R2,A”指令使用的诸多不爽之处。

为此,EMC在447/458及后续的芯片的指令系统中,增加了一条新指令----就是TBL指令。

TBL是查表指令。号称可以放在程序的任何位置。

但是且慢----

TBL指令的使用也要注意如下:

首先,表格不能跨页(每1024字节为一页(PAGE))

其次,表格也不能跨“段”

何为“段”?----“段”是匠人自定义的一个概念:将每一页分为4段,每一段256个字节(如:00H~FFH是一段,100H~1FFH又是一段)

也就是说,每一个查表程序,除了TBL本身占用了一个字节以外表格长度必须

36
16
0
17

相关资讯

  1. 1、快影怎么压缩视频?快影压缩视频的方法2640
  2. 2、一个木函如何下载音乐?一个木函下载音乐的方法3252
  3. 3、怎么参与2019微博让红包飞活动2019微博让红包飞活动参与方法2671
  4. 4、WPS2019中怎么隐藏文档内容?WPS2019隐藏文字的操作步骤479
  5. 5、wps表格如何设置有效性显示特定内容?3363
  6. 6、Win7电脑搜索功能不能用怎么办?Win7电脑搜索功能不能用的解决方法327
  7. 7、Win10教育版改成Win10专业版怎么操作?4019
  8. 8、怎么在win7电脑中添加本地用户和组?3334
  9. 9、Win101909系统怎么禁用服务?Win101909服务禁用方法简述3554
  10. 10、怎么在wps文字里查看字数统计?wps里进行字数统计的方法4090
全部评论(0)
我也有话说
0
收藏
点赞
顶部