EMC的基本指令語法,實在也就57/58條,如何變化折騰,就看各位的修行造化了。

1.減法指令的誤區(qū)

之一:關(guān)于ACC

EMC的減法指令有">

国产亚洲不卡一卡2卡三卡4卡网站_中文字乱码在线生成2021_yellow片高清_黄黄的高清无码网站_XXXX9999无码

大學(xué)校園網(wǎng)

大學(xué)生活網(wǎng) > 大學(xué)生學(xué)習(xí) > 電氣工程

探討EMC的基本指令語法

義隆單片機(jī)指令應(yīng)用的誤區(qū)與技巧

EMC的基本指令語法,實在也就57/58條,如何變化折騰,就看各位的修行造化了。

1.減法指令的誤區(qū)

之一:關(guān)于ACC

EMC的減法指令有三條,如下:

SUBA,R(R-A→A)

SUBR,A(R-A→R)

SUBA,K(K-A→A)

需要留意的是,不論A的位置在前面還是后面,A都是減數(shù),不是被減數(shù).

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

SUBA,@2

其實是執(zhí)行2-A

解決方法如下:

ADDA,@256-2或

ADDA,@254

之二:關(guān)于CY

一般來說,加/減法都會影響到進(jìn)位標(biāo)志CY.

在其它一些單片機(jī)指令系統(tǒng)中,當(dāng)減法發(fā)生借位時,CY=1,未發(fā)生借位時CY=0.

假如你以為EMC的減法也是如此,哈哈,你就要吃藥了!

原來,在EMC的指令系統(tǒng)中.當(dāng)減法發(fā)生借位時,CY=0,未發(fā)生借位時CY=1.

假如不留意這點,很輕易在一些運算或判定程序中留下BUG

2.查表(散轉(zhuǎn))指令的誤區(qū)

之一:關(guān)于"ADDR2,A"指令

在EMC153/156的指令系統(tǒng)中,沒有TBL指令(這一點要切記),當(dāng)要查表時只好用"ADDR2,A"(或MOVR2,A)來代替

但是使用"ADDR2,A"時要留意,這條指令只能改變PC指針的低8位(即256字節(jié)),高位其它位一律清零!

所以使用"ADDR2,A"時必須保證整個表格都在ROM的每一頁的前256字節(jié)區(qū)間內(nèi).(153/156只有一頁)

大表格的使用受到了限制,而且為了將表格"擠進(jìn)"00H~FFH的ROM空間,程序的結(jié)構(gòu)受到破壞.

之二:關(guān)于"TBL"指令

剛才說道,"ADDR2,A"指令使用的諸多不爽之處.

為此,EMC在447/458及后續(xù)的芯片的指令系統(tǒng)中,增加了一條新指令----就是TBL指令.

TBL是查表指令.號稱可以放在程序的任何位置.

但是且慢----

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

首先,表格不能跨頁(每1024字節(jié)為一頁(PAGE))

其次,表格也不能跨"段"

作甚"段"?----"段"是匠人自定義的一個概念:將每一頁分為4段,每一段256個字節(jié)(如:00H~FFH是一段,100H~1FFH又是一段)

也就是說,每一個查表程序,除了TBL本身占用了一個字節(jié)以外表格長度必須<=255字節(jié).而且整個查表程序必須在同一"段"內(nèi)

這個題目真是一個大大的陷阱!

有時明明你的程序都已經(jīng)調(diào)試好了,無意間調(diào)整了程序模塊間的順序或增加/減少了幾條指令后,程序就不正常了.

嘿嘿,檢查你的LST文件吧,八成是TBL在做怪!

另外,TBL還是沒有解決大表格的查表題目,(只好象切豆腐一樣,將大表格切成一個個小于255字節(jié)的小表格往查了)

3.關(guān)于“MOVR,R”指令

這是一條很奇異的指令,首先,閣下不要誤認(rèn)這條指令,以為它是將一個寄存器的數(shù)據(jù)送到另一個寄存器中往。匠人開始接觸EMC8bitIC時,就曾經(jīng)“中招”!后經(jīng)過高手指點,方得解脫——我佛慈悲,嘔米脫佛!

看清楚了:"MOVR,R"中的兩個R是同一個寄存器,而它的動作是將寄存器的內(nèi)容送到本身。

假如你以為這是無意義的動作,那就大錯特錯了。

按匠人的經(jīng)驗,這條指令至少有兩個用處:

用處之一:判零

此指令的用意在于它能影響ZeroFlag,辨別寄存器的內(nèi)容是否為零。

假如要辨別某一個寄存器的值是否為零,一般我們會用

MOVA,R

JBSSTTS,Z;R3,ZeroFlag

這兩個指令,但是這會影響ACC原先的內(nèi)容。若不要使用ACC,可能寫成

INCR

DECR

JBSSTTS,Z

這會用到三個指令。若使用MOVR,R的指令,不僅可達(dá)成相同功能,也可減少指令數(shù)目,可說是一舉兩得。

MOVR,R

JBSSTTS,Z

用處之二:將I/O口的外部電平狀態(tài)存進(jìn)鎖存器

說到這里,要先先容一下EMC的IO口特性了。

EMC的IO口一般都是三態(tài),可設(shè)置為高阻(輸進(jìn));或輸出狀態(tài)

當(dāng)IO口設(shè)置為輸進(jìn)狀態(tài)時,只能“讀”,不能“寫”,CPU通過IO口直接“讀”外部電平,假如這時發(fā)生“寫”動作,則數(shù)據(jù)并不會輸出,而是被存放到一個鎖存器中,待到IO口變成輸出狀態(tài)時,再將鎖存器中的數(shù)據(jù)送到IO口上。

——留意:在這里,源寄存器和目的寄存器固然地址相同,但實質(zhì)不是一回事了。(相當(dāng)于一個門牌住著兩戶人家)

假如有這么一條指令:MOVR6,R6

分析:先將R6口的外部電平狀態(tài)讀進(jìn),再送到R6的鎖存器里。

比如:R6口作電平翻轉(zhuǎn)喚醒功能時,必須先將其外部電平保存到鎖存器中

MOVR6,R6

然后開啟R6口電平翻轉(zhuǎn)喚醒功能,當(dāng)R6口狀態(tài)與鎖存器中發(fā)生變化時,即可觸發(fā)相應(yīng)中斷。

(R6的相應(yīng)口必須設(shè)置為輸進(jìn)狀態(tài))

再次提醒,“MOVR,R”指令不能用作兩個寄存器間送數(shù)用,假如要在兩個寄存器間送數(shù),一定要通過中介公司——ACC。

假如想減輕寫程序的勞累,那就把下面這段宏插進(jìn)到你的程序中往:

MOVMACROREG1,REG2

MOVA,REG2

MOVREG1,A

ENDM

這樣,當(dāng)你寫“MOVREG1,REG2”時,系統(tǒng)會自動幫你轉(zhuǎn)化成兩條指令:

MOVA,REG2

MOVREG1,A