5.1.1. 查表指令與用法
EM78 系列八位微控器是利用 (1)“call“,(2) 改變PC (或“tbl”),(3)“retl k“ 三個步驟來查表的。其中“retl k” 是將常數(shù) k 的值傳至工作寄存器 “A” 中。
步驟 (2) 中若利用“mov 0x2,a“,或“add 0x2,a” 等等指令來改變PC,則因為此等指令會將 PC (R2) 的位 8、9 清除 (在 EM78056 只清除位 8),所以查表的內(nèi)容只能放在程序每個 PAGE 的較低的 256 個位址。步驟 (2) 中若利用“tbl“ 指令來改變PC,則因為此指令不會將PC (R2) 的位 8、9 清除,而保留“tbl” 所在位址的位 8、9,所以查表的內(nèi)容可以放在程序每個 PAGE 中的任何位址。
例:查表
table add 0x02,a ;將相對位置加入 PC 而改變了PC
retl @0x19 ;傳回常數(shù)內(nèi)容 19h 至 “A”
retl @0x74 ;傳回常數(shù)內(nèi)容 74h 至 “A”
retl @0x2e ;傳回常數(shù)內(nèi)容 2eh 至 “A”
retl @0x54 ;傳回常數(shù)內(nèi)容 54h 至 “A”
retl @0x4b ;傳回常數(shù)內(nèi)容 4bh 至 “A”
inc 0x18
mov a,0x18 ;欲查的內(nèi)容的相對位置放在“A”
call table ;查表
mov 0x10,a ;查表得到的內(nèi)容移至 R10 中
5.1.2. 分 PAGE 的用法
1. 程序跳 PAGE 的用法:
EM78 系列八位微控器將其 Program Memory (ROM) 分成數(shù)個 PAGE,每個 PAGE 的長度是 1K (EM78056 除外)。R3 寄存器的位 5 (6) 是 “PAGE 選擇位”,當執(zhí)行 “jmp” 或 “call” 指令時,“PAGE 選擇位” 會被載入 Program Counter 的位 10 (11),因此當程序超過 1K (EM78056 為 0.5K)時,執(zhí)行 “jmp” 或“call” 指令時,“PAGE 選擇位” 正確的設定是非常重要的。下面將以 EM78256 為例來說明跳 PAGE 的方法。
例
例:從PAGE 1 跳轉(zhuǎn)到PAGE 0
; PAGE 0, begin at 000h
049 add 0x11,a
050 mov a,@0x55
051 mov 0x05,a ;port5《-- 0x55
052 bs 0x03,5 ;select PAGE 1
053 jmp lab1 ;PAGE jump
054
; PAGE 1, begin at 400h
447
448 mov a,@0x3f
449 xor 0x12,a
450 Lab1 bc 0x06,3
451 mov a,0x05
說明:
052: 將 R3 寄存器的位 5 設為 “1” (選擇 PAGE 1)。
053: Lab1 會被編譯 為 “50”,程序跳轉(zhuǎn)至 PAGE 1 中 “Lab1” (450) 的位址。
注意:
此例中 “052” 和 “053” 是用來跳 PAGE 的,假如沒有 “052” 這行指令,則程序?qū)⑻D(zhuǎn)至“050” 的位址 (在 PAGE 0中),如此將沒有達到預期的目的。
2. 不同 PAGE 子程序呼叫的方法:
如第 1 項所述,當程序超過 1K 時,執(zhí)行 “call” 指令時,“PAGE 選擇位” 的設定就必須加以考慮。下面將以 EM78256 為例來說明呼叫不同 PAGE 子程序的方法。
例: 從PAGE 0調(diào)用PAGE 1中的子程序
; PAGE 0, begin at 000h
049 add 0x11,a
050 mov a,@0x55
051 mov 0x05,a ;port5《-- 0x55
052 bs 0x03,5 ;select PAGE 1
053 call Lab2 ;PAGE jump
054 bc 0x03,5 ;restore
055 jbs 0x15,2
056
; PAGE 1, begin at 400h
417
418 mov a,@0x3f
419 xor 0x12,a
450 Lab2 bc 0x06,3
451 mov a,0x05
45f ret
說明:
052: 將 R3 寄存器的位 5設為 “1” (選擇 PAGE 1)。
053: Lab2 將會被編譯為 “50”,呼叫 PAGE 1 中 “Lab2” 子程序。
054: 將 R3 寄存器的位5 還原為 “0”。
注意:
此例中 “052” 和 “053” 是用來呼叫 PAGE 1 中 “Lab2” 的子程序,假如果沒有 “052” 這行指令,則程序?qū)⒑艚?“050” 的位址 (在 PAGE 0中),而非 “450” 的位址 (在 PAGE 1中),如此將發(fā)生錯誤。
5.1.3. “BS”,“BC” 等指令對 I/O Port 的作用:
“BS”,“BC” 等指令會先有 “讀” 再 “寫” 的動作,例如 “bc 0x06,3” 指令是將整個 Port 6 (8 PIN) 讀進 CPU,執(zhí)行位運算后再寫至 Port 6 上。假如 Port 6 有一些 pin 是雙向 I/O pin (如 P65) 時,假設當執(zhí)行 “bc 0x06,3” 時P65 是輸入 pin,則 P65 pin 上的內(nèi)容會被讀入再寫至 Latch 上,覆蓋原先 Latch 上的內(nèi)容。因此只要 P65 一直是輸入 pin 將不會有問題,一旦 P65 切換為輸出,則 Latch 上的內(nèi)容將是不可預知的。
5.1.4. I/O Port讀取的路徑:
若仔細研究EM78系列八位微控器的I/O Port構(gòu)造,就可發(fā)現(xiàn)在做“讀”I/O Port的動作時(如“mov a,0x06”),所讀入內(nèi)容有兩個路徑來源,一是I/O pin上的內(nèi)容,另一是輸出Latch上的內(nèi)容,而由I/O控制寄存器決定此讀入的路徑。
例如I/O pin設計為輸入pin時(對應的I/O控制寄存器為“1”),對I/O Port做“讀”的動作時,是讀到pin上的內(nèi)容。若I/O pin設計為輸出pin時(對應的I/O控制寄存器為“0”),對I/O Port做“讀”的動作時,是讀到輸出Latch上的內(nèi)容。
5.1.5. WDT (Watchdog Timer)的使用:
WDT是微控器內(nèi)部RC自振的計時器,其超時溢位(Time-out)的基本周期約18ms,WDT有與TCC共用的倍除器,使得超時溢位(Time-out)的最大周期可至約2.2sec。WDT計時的使能或禁止是可隨時由指令控制的(控制位在IOCE寄存器)。當WDT使能時,其超時溢位將使微控器發(fā)生RESET(或喚醒),“wdtc”指令是用來清除WDT,令WDT再從頭計時,因此適當?shù)氖褂谩皐dtc”指令,可使WDT不會發(fā)生RESET。當WDT被禁止時,WDT不會使微控器RESET或喚醒。要特別注意的是,Power-on之後WDT是使能的,如果該應用中並沒有使用WDT,必須在程序的前頭用指令將WDT計時禁止。EM78156/256/456就是依上述所設計。
在EM78247/447/248/448/056/P156除了上述的設計外,另有一Code Option決定使能或禁止WDT,其功能如下:
1. 假如應用中有使用WDT,WDT必須以Code Option使能,則在程序中隨時可以用指令使能或禁止WDT計時。注意:Power-on之後WDT是使能的。
2. 假如應用中並沒有使用WDT,WDT可以以Code Option禁止,則WDT是永遠被禁止的,如此可省去須在程序的前頭用指令將WDT計時禁止的麻煩。
5.2. 基本設計規(guī)則
5.2.1. 設定I/O口的模式:
用戶可以單獨設定任一支I/O腳為輸出模式(Output Mode),或是輸入模式(Input Mode)。只要將每個I/O的設定寫入累加器(A)中,再將累加器的內(nèi)容寫到I/O控制寄存器中,設定就算完成了。
例1:將PORT6設定為OUTPUT PORT。
評論
查看更多