关于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、光电所提出新的水下图像复原算法复原图像整体对比度提高2倍以上2781
  2. 2、复用器的分类3216
  3. 3、​以LED技术调光,阿兹海默症患者睡眠及情绪获改善583
  4. 4、深圳全市5G基站突破一万大关全民步入可用5G阶段857
  5. 5、跻身全球科技创新中心行列,中关村“中国式创新”缩影1367
  6. 6、4家佛山机器人企业上榜十佳集成商!845
  7. 7、国内首个无人驾驶汽车远程测试许可发放广州为试点4015
  8. 8、PMP考试认证有什么用?优势有哪些?581
  9. 9、PHP令开发人员讨厌的原因是什么?4774
  10. 10、四川通信业全力保障火灾区域通信受损设施基本恢复1652
全部评论(0)
我也有话说
0
收藏
点赞
顶部