www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導讀]摘要:本文基于對8051單片機存儲空間結構的深層次分析,提出了一種基于單片機的單CPU仿真器設計方案。該方案實用廉價,工程實踐性強,可用于設計新的教學設備。 引言 單片機以它的廉價、體積小、可塑性強、穩(wěn)

摘要:本文基于對8051單片機存儲空間結構的深層次分析,提出了一種基于單片機的單CPU仿真器設計方案。該方案實用廉價,工程實踐性強,可用于設計新的教學設備。

引言

  單片機以它的廉價、體積小、可塑性強、穩(wěn)定性高的特性,有著廣闊的市場前景。 在用單片機開發(fā)產(chǎn)品時,雖然許多廠家設計了可編程ISP單片機,但是從安全與便捷方面考慮,單片機仿真器仍然是開發(fā)人員不可或缺的工具。單片機仿真器在產(chǎn)品開發(fā)階段可用來替代單片機進行軟硬件調試,從而迅速發(fā)現(xiàn)、糾正程序中的錯誤,大大縮短單片機開發(fā)的周期。但實際中仿真器過于昂貴,因此,設計制作出一款廉價且實用的仿真器有著廣泛的市場。

  傳統(tǒng)的單片機仿真器硬件系統(tǒng)一般有三種實現(xiàn)方法。一、采用專用仿真的單片機。二、采用兩套單片機,一個單片機用于仿真,并完成諸如通訊,中斷等功能;另一個單片機則用于目標單片機,這樣其資源不會被占用。三、用目標單片機作為仿真器,單片機即仿真器也作目標機的單片機用,其實質是一種ROM監(jiān)控器。第三種方法會占用單片機的部分資源,但結構簡單,對于特定的開發(fā)者來說,實用性強,性價比高,且易于自行制作。本文開發(fā)設計的仿真器正是基于第三種原理,巧妙實現(xiàn)了數(shù)據(jù)空間與程序空間的互換,設計出一款實用廉價的仿真器,工程實踐性強。

原理及系統(tǒng)結構

  仿真器工作時,要把程序從PC機下載到仿真器的存儲器中。在此先詳細分析51單片的存儲器結構和尋址方法,再分析片外存儲器的擴展,最后給出設計原理并分析系統(tǒng)結構。

 


圖1 存儲空間分布

51單片機存儲器結構分析

  8051單片機的存儲器在物理結構上分為程序存儲器空間和數(shù)據(jù)存儲器空間,共有4個存儲空間:片內程序存儲器、片外程序存儲器以及片內數(shù)據(jù)存儲器、片外數(shù)據(jù)存儲器空間。這種程序存儲和數(shù)據(jù)存儲分開的結構形式被稱為哈佛結構。但從用戶的角度,8051存儲器地址空間可分為3類:片內、片外統(tǒng)一編址0000H~FFFFH的64KB程序存儲器地址空間(用16位地址);64KB片外數(shù)據(jù)存儲器地址空間,地址也從0000H~FFFFH(用16位地址)編址;256B片內數(shù)據(jù)存儲器地址空間(用8位地址)。

  上述4個存儲空間地址是重疊的,如圖1所示。8051的指令系統(tǒng)設計了不同的數(shù)據(jù)傳送指令以區(qū)別這4個不同的邏輯空間:CPU訪問片內、片外ROM指令用MOVC,訪問片外RAM指令用MOVX,訪問片內RAM指令用MOV。

  程序存儲器用于存放編好的程序和表格常數(shù)。程序通過16位程序計數(shù)器尋址,尋址能力為64KB。這使得指令能在64KB的地址空間內任意跳轉,但不能使程序從程序存儲器空間轉移到數(shù)據(jù)存儲器空間。

  實際上,當引腳EA接高電平時,8051的程序計數(shù)器PC執(zhí)行片內ROM中的程序,當指令地址超過片內ROM地址時,就自動轉向片外ROM中去取指令。當引腳EA接低電平(接地)時,8051片內ROM不起作用,CPU只能從片外ROM中取指令,地址可以從0000H開始編址。8051從片內程序存儲器和片外程序存儲器取指時的執(zhí)行速度相同。

存儲器外擴 

  用P0口作地址/數(shù)據(jù)復用總線,用P2口的口線作高位地址線,最多可以擴展64KB的存儲器??刂菩盘柧€包括:使用ALE作為地址鎖存的選通信號,以實現(xiàn)低8位地址的鎖存;以PSEN信號作為擴展程序存儲器的讀選通信號;以EA信號作為內、外程序存儲器的選擇信號;以EA和作為擴展數(shù)據(jù)存儲器和I/O端口的讀、寫選通信號。執(zhí)行MOVX指令時,RD和WR信號分別自動有效。片外數(shù)據(jù)存儲器RAM的讀和寫由8051的RD(P3.7)和WR(P3.6)信號控制,而片外程序存儲器的輸出允許(OE)由讀選通PSEN信號控制。盡管片外數(shù)據(jù)存儲器和片外程序存儲器共處同一地址空間,但由于控制信號及使用的數(shù)據(jù)傳送指令不同,故不會發(fā)生總線沖突。

 

圖2 仿真器原理圖

仿真器原理與結構

  由于現(xiàn)在以8051為內核的單片機幾乎都帶有內部的FLASH程序存儲器。如本設計中要用到的AT89C51或AT89S51均自帶4KB的FLASH程序存儲器,有的單片機帶有20KB甚至更大容量的程序存儲器。因此在單片機開發(fā)中,很少用專門的程序存儲器芯片來擴展外部程序存儲器,通常也沒有必要?;谝陨线@些因素,下面分析本文中的仿真器實現(xiàn)的原理。

  下載程序時,EA接高電平,單片機執(zhí)行內部ROM中的程序,把PC機的程序數(shù)據(jù)下載到片外的RAM62256中;當程序數(shù)據(jù)下載完后,在保持RAM62256不掉電的情況下,將單片機的EA接低電平,并把單片機復位。這樣單片機就只能從片外存儲器中讀數(shù)據(jù)。然后利用RD與PSEN相“與”來選通RAM62256的讀允許片選端OE,使得單片機能夠從RAM62256中讀出程序。這樣就實現(xiàn)了仿真功能。因為單片機從片內程序存儲器和片外程序存儲器取指時的執(zhí)行速度相同,所以這個設計方案下的仿真器性能比起傳統(tǒng)仿真器毫不遜色。

  總系統(tǒng)電路原理如圖2所示,系統(tǒng)由單片機AT89C51、地址鎖存器74LS373、片外存儲器62256、接口電平轉換芯片MAX232和相關控制電路組成。

  其中AT89C51就是仿真器的核心部件,晶體振蕩電路和復位電路與普通單片機系統(tǒng)相同。不同的是:EA接一個單刀雙投開關,表面上沒有擴展ROM。RAM62256的與OE普通單片機系統(tǒng)的接法有所不同,系統(tǒng)中把RD與PSEN相“與”,令其選通RAM62256的讀允許片選端OE,就能促成RAM(注意:整個過程中RAM不掉電)由數(shù)據(jù)空間的角色向程序空間的角色轉換。在執(zhí)行MOVX指令時,產(chǎn)生RD,WR信號,寫入程序信息。在執(zhí)行RAM中的程序時,由PSEN信號與RD信號選通RAM62256的OE端,實現(xiàn)從RAM62256中程序的讀入。

軟件設計

  PC機(上位機)軟件可以參考Windows驅動程序開發(fā)、串口調試助手等相關書籍;也可以利用現(xiàn)成的KEIL C51的Windows集成開發(fā)環(huán)境~VISION51和軟件仿真器DSCOPE51完成。

  下位機軟件的主要任務就是設置串口和接收上位機串口發(fā)送來的數(shù)據(jù),并將數(shù)據(jù)存入外部“數(shù)據(jù)”存儲器中。

單片機主程序如下:
MOV  SCON,#50H  ;串口方式 1
MOV  TMOD,#20H  ;T1 方式 1
MOV  TL1,#0FDH  ;波特率 9600 的常數(shù)
MOV  TH1,#0FDH
SETB  TR1          ;開中斷
SETB   ET1
SETB    ES
SETB    EA
系統(tǒng)“寫”時用如下指令:
MOVX  @DPTR,A
MOVX  @Ri, A

  在中斷服務子程序中,為區(qū)別所接收的信號是聯(lián)絡信號還是字節(jié)數(shù)、是數(shù)據(jù)還是校驗和,需要設立不同的標志位如下:
 FLAG0  BIT  00H ;接收聯(lián)絡信號標志位
 FLAG1  BIT  01H ;接收字節(jié)數(shù)標志位
 FLAG2  BIT  02H ;接收數(shù)據(jù)標志位
 FLAG3  BIT  03H ;接收文件結束標志位    

  程序流程如圖3所示,其中R7為接收到的字節(jié)數(shù),接收的數(shù)據(jù)一定要存入片外RAM從0000H開始的單元中。當單片機復位后,把RAM當作程序存儲器時,PC是從0000H開始的。

 

圖3 單片機接收中斷服務子程序流程圖

幾點討論

(1) 系統(tǒng)中不需要單獨的仿真器電源,也不需要晶振電路。
(2) 下位機的片外存儲器在重復寫數(shù)時不用擦除,每次重新下載程序時,總是用覆蓋的方式。新下載的程序都有END為結束,就算新下載的程序比原來的短,也不會執(zhí)行多余的代碼。
(3) 在實際中,可以進一步改進電路,當文件下載完之后,通過串口備用的信號線產(chǎn)生控制信號來控制和復位,從而使得全過程均由上位機控制。
(4) 由于內部結構的限制,被仿真的產(chǎn)品不能擴展片外的程序存儲器,但由于片外可以擴展64KB的數(shù)據(jù)存儲器,文中只用了32KB,因此還可以擴展一定的外設。
(5) 被仿真產(chǎn)品的E(--)A(--)的接法有一定的限制,不能直接接地或接電源正極,實際中只要加上一個合適的限流電阻(如10K?)就可以了。實際上這種方案可以適用于任何可以外擴存儲器的單片機。

結束語

  對以上的設計進行分析不難發(fā)現(xiàn),整個系統(tǒng)各個功能模塊技術非常成熟:在硬件方面,各子電路均有現(xiàn)存的電路套用,而且各個元器件的參數(shù)容易確定;在軟件方面,僅涉及到COM口的串行通信程序及上位機的界面程序。在實際的制作過程中,系統(tǒng)的元器件數(shù)目少且價格低廉,容易調試,成功率高,性能穩(wěn)定。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉