2大emc基本指令误区-u球体育app下载

×
电磁兼容 > esd > 详情

2大emc基本指令误区

发布时间:2024-06-04 发布时间:
|

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

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

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

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本身占用了一个字节以外表格长度必须


『本文转载自网络,u球体育app下载的版权归原作者所有,如有侵权请联系删除』

热门文章 更多
ic芯片封装特征在电磁干扰控制中的作用
网站地图