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本身占用了一個字節以外表格長度必須<=255字節.而且整個查表程序必須在同一"段"內
這個問題真是一個大大的陷阱!
有時明明你的程序都已經調試好了,無意間調整了程序模塊間的順序或增加/減少了幾條指令后,程序就不正常了.
嘿嘿,檢查你的LST文件吧,八成是TBL在做怪!
另外,TBL還是沒有解決大表格的查表問題,(只好象切豆腐一樣,將大表格切成一個個小于255字節的小表格去查了)
3.關于“MOV R,R”指令
這是一條很奇特的指令,首先,閣下不要誤認這條指令,以為它是將一個寄存器的數據送到另一個寄存器中去。匠人開始接觸EMC 8bit IC時,就曾經“中招”!后經過高手指點,方得解脫——我佛慈悲,嘔米脫佛!
看清楚了:"MOV R,R" 中的兩個R是同一個寄存器,而它的動作是將寄存器的內容送到本身。
如果你認為這是無意義的動作,那就大錯特錯了。
按匠人的經驗,這條指令至少有兩個用處:
用處之一:判零
此指令的用意在于它能影響Zero Flag,辨別寄存器的內容是否為零。
如果要辨別某一個寄存器的值是否為零,一般我們會用
MOV A,R
JBS STTS,Z ; R3,Zero Flag
這兩個指令,但是這會影響ACC原先的內容。若不要使用ACC,可能寫成
INC R
DEC R
JBS STTS,Z
這會用到三個指令。若使用MOV R,R的指令,不僅可達成相同功能,也可減少指令數目,可說是一舉兩得。
MOV R,R
JBS STTS,Z
用處之二:將I/O口的外部電平狀態存入鎖存器
說到這里,要先介紹一下EMC的IO口特性了。
EMC的IO口一般都是三態,可設置為 高阻(輸入);或輸出狀態
當IO口設置為輸入狀態時,只能“讀”,不能“寫”,CPU通過IO口直接“讀”外部電平,如果這時發生“寫”動作,則數據并不會輸出,而是被存放到一個鎖存器中,待到IO口變成輸出狀態時,再將鎖存器中的數據送到IO口上。
——注意:在這里,源寄存器和目的寄存器雖然地址相同,但實質不是一回事了。(相當于一個門牌住著兩戶人家)
假如有這么一條指令:MOV R6,R6
分析:先將R6口的外部電平狀態讀入,再送到R6的鎖存器里。
比如:R6口作電平翻轉喚醒功能時,必須先將其外部電平保存到鎖存器中
MOV R6,R6
然后開啟R6口電平翻轉喚醒功能,當R6口狀態與鎖存器中發生變化時,即可觸發相應中斷。
(R6的相應口必須設置為輸入狀態)
再次提醒,“ MOV R,R”指令 不能用作兩個寄存器間送數用,如果要在兩個寄存器間送數,一定要通過中介公司——ACC。
如果想減輕寫程序的勞累,那就把下面這段宏插入到你的程序中去:
MOV MACRO REG1,REG2
MOV A,REG2
MOV REG1,A
ENDM
這樣,當你寫“MOV REG1,REG2”時,系統會自動幫你轉化成兩條指令:
MOV A,REG2
MOV REG1,A
上一篇:義隆單片機編程時應注意的幾點
下一篇:EM78P468 NTC lcd測溫設計C語言源代碼
推薦閱讀
史海拾趣
為了進一步擴大市場份額,Global Specialties積極實施全球化戰略。公司通過與國際分銷商和代理商的合作,將產品銷往全球各地。同時,公司還參加了多個國際性的電子展會和論壇,與來自世界各地的客戶和合作伙伴進行交流和合作。這些舉措不僅提升了Global Specialties的品牌知名度,還為公司帶來了更多的國際合作機會和客戶資源。通過這些努力,Global Specialties逐漸發展成為一家具有全球影響力的電子測試與測量公司。
隨著《古墓麗影》系列游戲的成功,Core Design的團隊迅速擴張。當PS2主機即將推出時,索尼和Core Design都對這款新主機充滿期待。為了抓住這一機遇,Core Design將“古墓麗影”的制作團隊從最初的12人增加到60人,隨后又增加到了100人。這一舉措展示了Core Design對市場和技術的敏銳洞察力和決心。
Elcoma公司在其早期發展階段,就致力于電子技術的研發和創新。他們成功研發出一種新型高效能的電子芯片,這一突破性的技術大大提高了電子設備的性能和效率。這一創新技術迅速在行業內引起了廣泛關注,許多大型電子設備制造商紛紛與Elcoma合作,希望將這一技術應用到他們的產品中。Elcoma憑借這一技術突破,逐漸在電子行業中嶄露頭角。
隨著全球對環保意識的日益增強,Excelsys公司積極響應綠色環保的號召,將環保理念融入到產品設計和生產過程中。公司采用環保材料、優化生產工藝、提高能源利用效率等措施,減少了對環境的影響。同時,公司還積極參與環保公益活動,為行業的綠色發展貢獻力量。
隨著業務的迅速增長,Astema意識到供應鏈管理的重要性。公司開始優化供應鏈管理流程,提高生產效率和產品質量。同時,Astema還與供應商建立了緊密的合作關系,確保原材料供應的穩定性和可靠性。這些舉措使得Astema在激烈的市場競爭中保持了穩定的運營。
大家幫我多出點主意。如果這個可行,咱DIY個4.3 480*272的投影玩玩 EEWORLD合作qq群:49900581 群主:wangkj 高清1920*1200的估計得1000多點吧。… 查看全部問答∨ |
|
1 如果一款音頻芯片只有一個ADC能錄立體聲么? 2 當只有一個ADC的時候,IIS的采樣時鐘IISLRCK(采樣時鐘)的高電平采到的數據是空的(低電平采左聲道),也就是說送到buffer里的數據也是空的,對不? … 查看全部問答∨ |
|
本帖最后由 paulhyde 于 2014-9-15 09:19 編輯 FPGA中嵌入51IP核,我連一個燈都沒點亮! 求解!求解!求解!求解!求解!求解!求解!求解!求解! (用的程序代碼和IP核的原理圖都在附件里面) … 查看全部問答∨ |