《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 在FPGA上對OC8051 IP核的修改與測試
在FPGA上對OC8051 IP核的修改與測試
楊先文 李崢
摘要: 在80C51系列中,OC8051以架構清晰、取指帶寬大、時鐘效率高等諸多優點受到業內人士的青睞。本文在分析OpenCores網站提供的一款 OC8051IP核的基礎上,給出了一種仿真調試方案;利用該方案指出了其中若干邏輯錯誤并對其進行修改,最終完成了修改后IP核的FPGA下載測試。
關鍵詞: FPGA OC8051 Altera
Abstract:
Key words :

    20世紀80年代初,Intel公司推出了MCS-51單片機,隨后Intel以專利轉讓的形式把8051內核發布給許多半導體廠家,從而出現了許多與MCS-51系統兼容的產品。這些產品與MCS-51的系統結構相同,采用CMOS工藝,因而常用80C51系列來指代所有具有8051指令系統的單片機。在80C51系列中,OC8051以架構清晰、取指帶寬大、時鐘效率高等諸多優點受到業內人士的青睞。本文在分析OpenCores網站提供的一款 OC8051IP核的基礎上,給出了一種仿真調試方案;利用該方案指出了其中若干邏輯錯誤并對其進行修改,最終完成了修改后IP核的FPGA下載測試。

1 OC8051結構分析

OpenCores網站提供的OC8051 IP核與8051的系統結構相同,如圖1所示。該IP核兼容所有8051指令系統,內部資源包括:8位CPU,尋址能力達2×64K;4 KB的ROM和128字節的RAM;4個8位I/O口;16位內部定時/計數器;5個中斷源和2個中斷優先級。采用Verilog語言對其各個模塊進行描述。系統主要模塊及其功能說明如表1所列。不同模塊對應的源文件均是以模塊名稱命名的,例如累加器A對應的源文件為oc8051_acc.v。

 



     雖然上述OC8051 IP核宣稱兼容所有8051指令系統,但是實際執行時并非如此。例如在執行表2所列的2組功能相同的代碼時,所得到的執行結果并不相同。代碼1的執行結果是將5寫入地址為0的外部RAM,代碼2的執行結果是將5寫入地址為4的外部RAM。造成這種現象的原因是,oc8051_ext_addr_sel模塊配置寫外部RAM地址時延誤了一個時鐘周期。若要OC8051 IP核與標準8051系統一致,須對源文件中類似的邏輯錯誤進行修改。




2 OC805 1仿真調試及修改

對于硬件設計而言,仿真的作用是驗證設計結果的邏輯功能是否符合初始規定,如果在這一層次上設計出了問題,那么以后各個層次的工作將完全不確定。由前文可知,OC8051 IP核存在著邏輯錯誤,所以有必要通過仿真的手段實現錯誤查找和定位,從而最終完成對邏輯錯誤的修改。

2.1 仿真調試方案

OC8051仿真調試方案如圖2所示。其原理是:在Keil軟件環境中編寫測試程序,編譯生成.hex文件并將其注入ROM的指令寄存器中。 testbench負責產生OC8051工作時鐘及控制使能等信號,并將OC8051執行ROM中指令的結果輸出到文本/波形文件中。開發人員通過對文本/波形文件和Keil調試工具執行測試程序的結果進行比較,從而實現對邏輯錯誤的查找與定位,并對IP核源文件進行修改。

4.gif



值得注意的是,雖然Modelsim功能強大,可以方便地觀察到任何層次模塊信號的變化,但是OC8051 IP核的結構和時序比較復雜,仍避免不了仿真時因為中間信號多所帶來的不便。因此,在仿真調試時可尋求一些簡化操作的機制??紤]到借助數據寄存器指針 DPTR和累加器A,MOVX指令可以將程序執行過程中任何寄存器的值輸出到外部RAM中,而觀察外部RAM中的值相對容易,因而本文采用了這種機制。

2.2 具體修改方法

(1)oc805 1_ext_addr_sel模塊

讀寫外部RAM地址可以由DPTR指示,也可以由Ri指示,該模塊的主要功能是選擇讀寫外部RAM地址。通過select和write信號完成對buff和state的配置,從而完成對讀寫外部RAM地址addr_out的配置。在Modelsim環境中,執行表1中的代碼1時,發現 addz_out的變化總是比DPTR慢一個時鐘周期,因而其執行結果是將5寫入地址為0的外部RAM。造成這種現象的原因是配置buff和state時采用了always進程,本文將該部分代碼修改為:

  assign state="write";

  asstgn buff="select"?{8h00,ri}:{dptr_hi,dptr_lo};

(2)oc8051_psw模塊

該模塊由一個8位標志寄存器及其控制邏輯組成,用來收集指令執行后的有關狀態。8位寄存器的各位狀態通常是在指令執行過程中自動形成,但也可以由用戶根據需要采用傳送指令加以改變。原設計中負責解釋傳送指令的邏輯采用if語句:

  if(addr[7:3]=='OC8051_SFR_B_ACC)data_out[addr[2:O]]<=cy_in;

'OC8051_SFR_B_ACC被定義為累加器A的高5位地址,用在這里顯然不對。應該將其改為程序狀態字PSW的高5位地址 'OC8051_SFR_B_PSW。

(3)OC8051_alu 模塊

該模塊是一個性能極強的運算器,不但可以進行四則運算和邏輯運算,而且具有數據傳送、移位、程序轉移等功能。其中,程序轉移功能是當遇到短轉移指令SJMlE’或變址轉移指令JZ、CJNE、DJNZ等時,改變程序計數器PC的值,對應原設計為always進程中的 'OC8051_ALU_PCS分支。其代碼如下:



      輸入src3為PC[15:8],src2為PC[7;0],src1為目標轉移地址rel。需要注意的是,rel是以立即數形式存在的,且為補碼格式(補碼數的加減法運算統一為加法運算)。若src1[7]=1'b1成立,則rel為一負數,對應轉移指令是往前轉移;否則,往后轉移。當rel 為負數時,原設計僅考慮了:PC[7:0]≥| rel |的情況,其對目標地址{des1,des2}的處理不全面;當PC[7:0]<|rel|時,des2=src2+src1為負數,借位會對 des1產生影響,因而應有des1=src3-8'h1。因此,將該部分代碼修改為:



其中c是借位標志位,用來標識程序轉移時PC[7:0]對PC[15:8]的影響。

(4)oc8051_decoder模塊

該模塊用于對指令譯碼。其設計思想是,分析當前輸入信號op_in和所處狀態state,把指令的功能配置為其他模塊的控制信號,并得出下一個狀態。因為各指令的指令周期不同,所以每條指令譯碼執行狀態也各有不同。模塊主體由狀態機構成,在每個狀態下對狀態機不同的執行狀態進行條件判斷嵌套,以此實現對不同指令的多路選擇。對模塊仿真時發現,執行如DJNZ、JB、CLR等指令的結果不正確,其原因是在某些狀態下對某些指令的譯碼有誤,主要表現為配置了錯誤的控制信號。對模塊修改結果如表3所列。



2.3 仿真結果

程序執行方式是單片機的基本工作方式,通??梢苑譃閱尾綀绦泻瓦B續執行兩種。事實上,2.2小節中的具體修改方法正是結合這兩種工作方式實現的。數據加密標準(DES)是著名的對稱密鑰分組密碼,由美國標準FIPS 46-2定義。基于8051指令系統,DES的軟件實現難度不大,但它是對OC8051 IP核工作能力的一次綜合檢驗。采用 DEs標準測試向量:

  密鑰K=1A624C89520DEC46

  明文P=748502CD38451097

  密文C=DD0CFEB783CF3FDE

結合圖2所示的仿真調試方案,Modelsim環境中OC8051執行DES的仿真結果如圖3所示。



3 基于FPGA的下載測試

   利用FPGA對其功能進行了驗證。選用Altera公司的EP2C35F672C6型號FPGA開發板,含有33 216個邏輯單元(LE)、豐富的存儲器(RAM)和4個鎖相環(PLL)。采用QuartusII軟件,OC8051 IP核綜合后占用3 917個邏輯單元,時鐘頻率最高達到30.81 MHz,FPGA測試的實際頻率為27 MHz。

    利用QuartusII對OC8051 IP核綜合、布局布線后,采用JTAG方式將配置文件下載至FPGA中,測試程序仍采用DES算法程序。In-System Memory ContentEditor是QuartusII提供的一個可在線操作FPGA片上RAM內容的工具,通過JTAG方式,用戶可以查看和修改RAM中的內容。如果用戶設計對RAM中的內容進行了修改,需要查看修改后的結果是否為所期望的,則使用該工具最為方便。OC8051 IP核外部RAM中的數據可以通過該工具方便地操作,所以本文對DES測試向量的輸入和輸出都是通過它來完成的,如圖4所示。



     FPGA下載測試結果表明,OC8051工作正常,與仿真結果一樣,測試程序運行正確。

結語

   本文介紹了一種OC8051 IP核的仿真測試方案。該方案給出了查找與定位IP核中邏輯錯誤的方法,并詳細介紹了各種錯誤的修改方法。測試結果表明,OC8051工作正常,已經初步具備了微控制器的功能,可以被運用于實際的工程開發中。

參考文獻

1. 中國自學編程網.MCS-51型號和8051系列分[EB/OL].[2007-01].http://www.zxbe.cn/html /20070726/25200.html.
2. OC8051 Overview[EB/OL].[2007-07].http://www.opencores.org/?do=project&amp;who=8051.
3. Bailey B.Verification Strategies-The Right Strategy for You[C].CICC,IEEE2000.
4. 胡漢才.單片機原理及其接口技術[M].2版.北京:清華大學出版社,2004.
5. Menezes A J,Oorschot P C,Vanstone S A.應用密碼學手冊[M].胡磊,王鵬,譯.北京:電子工業出版社,2005.
6. Altera.Quartus Ⅱ Handbook Version 9.0 Volume 3:Verification[EB/OL].[2007-07].http://www.altera.com.

作者:解放軍信息工程大學  楊先文  李崢  來源:《單片機與嵌入式系統應用》 2009(11)

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国产一区二区三区直播精品电影| 亚洲一区二区免费在线| 亚洲午夜精品| 亚洲一区二区免费| 中文精品视频| 国产精品啊v在线| 久久综合一区二区三区| 亚洲电影在线免费观看| 欧美色区777第一页| 黄色亚洲大片免费在线观看| 欧美日韩国产精品自在自线| 欧美11—12娇小xxxx| 久久本道综合色狠狠五月| 国产欧美一区二区精品性| 欧美大片在线影院| 国产精品欧美一区喷水| 欧美亚洲一区二区三区| 美女黄网久久| 亚洲一区免费视频| 国产精品一卡二| 伊人婷婷久久| 在线亚洲精品福利网址导航| 国产麻豆午夜三级精品| 久久久久九九九九| 亚洲黄色尤物视频| 国产日韩欧美高清| 国产日韩精品一区二区三区在线| 欧美一进一出视频| 国产精品嫩草影院av蜜臀| 国产一区二区三区观看| 99re66热这里只有精品3直播| 亚洲视频欧洲视频| 亚洲午夜成aⅴ人片| 亚洲欧美综合精品久久成人| 欧美精品一区二区三区四区| 一区二区三区在线观看国产| 国产亚洲欧美激情| 久久久国产午夜精品| 亚洲无线一线二线三线区别av| 国产精品美女在线观看| 国产一区二区看久久| 在线播放亚洲一区| 亚洲人精品午夜| 欧美精品一区二区三区蜜臀| 国内精品久久久久伊人av| 国产人成一区二区三区影院| 亚洲精品视频一区| 国产一区二区你懂的| 亚洲日本免费电影| 欧美激情va永久在线播放| 国内精品伊人久久久久av影院| 国内精品嫩模av私拍在线观看| 在线播放中文一区| 狠狠色狠狠色综合日日tαg| 国产精品网站在线播放| 国产精品美女午夜av| 免费欧美视频| 牛牛精品成人免费视频| 国产精品视频男人的天堂| 99精品欧美一区二区蜜桃免费| 免费一级欧美片在线播放| 午夜伦欧美伦电影理论片| 午夜在线电影亚洲一区| 久久精品色图| 国内精品久久久久久影视8| 亚洲国产精品黑人久久久| 亚洲免费视频网站| 极品尤物av久久免费看| 国产一区 二区 三区一级| 一本久道久久综合婷婷鲸鱼| 欧美呦呦网站| 亚洲精品一二三区| 欧美调教vk| 久久久夜夜夜| 欧美日韩在线播放三区四区| 久久影院亚洲| 久久久久久久一区二区| 一本久久a久久免费精品不卡| 久久另类ts人妖一区二区| 欧美日韩网址| 欧美日本一道本| 欧美丰满少妇xxxbbb| 欧美专区日韩视频| 欧美一区视频| 国产精品一区=区| 一个色综合导航| 久久福利影视| 一本色道久久综合亚洲精品小说| 久久蜜桃香蕉精品一区二区三区| 欧美日本亚洲视频| 国产精品视频区| 欧美体内谢she精2性欧美| 欧美日韩爆操| 狠狠入ady亚洲精品| 两个人的视频www国产精品| 国产精品综合网站| 午夜在线观看免费一区| 99在线精品视频在线观看| 久久国产欧美日韩精品| 农夫在线精品视频免费观看| 久久亚洲春色中文字幕| 欧美日韩精品福利| 蜜桃久久精品乱码一区二区| 久久亚洲欧美国产精品乐播| 噜噜噜久久亚洲精品国产品小说| 欧美综合77777色婷婷| 午夜久久美女| 一区二区三区高清在线观看| 亚洲——在线| 欧美日韩国产经典色站一区二区三区| 老司机aⅴ在线精品导航| 另类激情亚洲| 国内揄拍国内精品少妇国语| 小黄鸭精品密入口导航| 国产精自产拍久久久久久蜜| 欧美日本在线观看| 国产精品国色综合久久| 亚洲日韩成人| 亚洲欧美国产三级| 99精品视频免费在线观看| 国产亚洲精品久久久| 国产专区精品视频| 国产欧美视频在线观看| 欧美精品成人在线| 欧美一区二区私人影院日本| 国产精品网红福利| 国产精品人人做人人爽| 欧美激情综合五月色丁香| 国产精品视频区| 国产日本欧美视频| 欧美精品一区二区在线观看| 亚洲激情视频在线观看| 亚洲人成网在线播放| 国产在线视频欧美一区二区三区| 在线成人中文字幕| 国产日韩欧美制服另类| 91久久精品日日躁夜夜躁国产| 国产精品国产三级国产普通话蜜臀| 在线精品国精品国产尤物884a| 国产精品―色哟哟| 国产伦精品一区二区三区视频孕妇| 在线播放豆国产99亚洲| 亚洲专区免费| 欧美区一区二区三区| 国产精品久久久久久久久久尿| 国产自产在线视频一区| 欧美视频不卡| 久久久精品动漫| 国产精品白丝av嫩草影院| 欧美日韩另类字幕中文| 欧美日韩一区二区在线观看视频| 激情欧美日韩一区| 一区二区三区视频在线看| 亚洲精品在线电影| 在线观看欧美日韩国产| 国产精品久久久久久久久借妻| 欧美国产极速在线| 国产永久精品大片wwwapp| 新67194成人永久网站| 国产精品久久夜| 欧美在线视频一区| 亚洲电影在线| 国产一区二区精品在线观看| 国产精品久久久久秋霞鲁丝| 欧美一区二区国产| 欧美亚洲一区三区| 国产在线精品一区二区中文| 亚洲国产成人精品视频| 亚洲欧美激情视频在线观看一区二区三区| 欧美成人中文字幕在线| 欧美体内she精视频| 国产在线麻豆精品观看| 欧美大色视频| 午夜精品美女自拍福到在线| 国产精品久久久久aaaa樱花| 影音先锋亚洲视频| 亚洲夫妻自拍| 亚洲一区二区3| 亚洲精品资源美女情侣酒店| 亚洲一区二区三区在线播放| 好吊色欧美一区二区三区视频| 久久这里只精品最新地址| 在线不卡亚洲| 欧美777四色影视在线| 欧美日韩成人综合天天影院| 先锋影院在线亚洲| 国内精品久久久久久久97牛牛| 久久综合中文色婷婷| 亚洲天堂av综合网| 欧美绝品在线观看成人午夜影视| 中文无字幕一区二区三区| 一区二区三区波多野结衣在线观看| 欧美成人国产| 欧美高清在线视频观看不卡| 亚洲小视频在线观看| 在线成人国产| 国产精品五月天| 亚洲一区二区毛片| 亚洲人成精品久久久久| 久久综合久色欧美综合狠狠| 久久成人免费视频| 欧美日韩国产小视频| 久久影院午夜片一区| 国产一区 二区 三区一级| 欧美在线首页| 亚洲国产综合在线看不卡| 久久精品91久久香蕉加勒比| 国产精品mv在线观看| 午夜视频在线观看一区二区| 国产精品久久久久久久久久免费看| 亚洲一区二区免费看| 欧美在线观看一区二区| 亚洲欧美三级伦理| 久久久久网址| 欧美午夜视频网站| 欧美精品一区二区三区四区| 国产精品扒开腿做爽爽爽软件| 欧美国产免费| 国产视频精品va久久久久久| 欧美激情偷拍| 欧美中文字幕不卡| 日韩一二三在线视频播| 欧美日本在线播放| 国产精品日韩久久久| 亚洲第一黄色| 欧美亚洲第一页| 在线成人黄色| 精品va天堂亚洲国产| 亚洲国产欧洲综合997久久| 欧美一区二区三区在线看| 亚洲欧美另类中文字幕| 亚洲欧美卡通另类91av| 亚洲天堂网在线观看| 性伦欧美刺激片在线观看| 国产精品一区二区你懂得| 国产精品久久久久久久午夜片| 久久精品国产2020观看福利| 亚洲欧美成人一区二区三区| 香蕉久久一区二区不卡无毒影院| 亚洲国产va精品久久久不卡综合| 午夜精品久久久久久久99樱桃| 欧美激情一区二区三区在线视频| 午夜精彩视频在线观看不卡| 国产欧美在线| 午夜亚洲福利| 中国av一区| 99re国产精品| 亚洲国产欧美在线| 猛男gaygay欧美视频| 亚洲专区欧美专区| 亚洲欧美中文日韩v在线观看| 欧美大片专区| 亚洲一区二区三区四区五区午夜| 在线成人小视频| 欧美在线观看你懂的| 在线观看国产成人av片| **欧美日韩vr在线| 亚洲一区二区在线播放| 亚洲一区二区影院| 在线观看视频一区| 香蕉国产精品偷在线观看不卡| 蜜臀va亚洲va欧美va天堂| 日韩视频在线一区二区| 一区二区三区国产在线观看| 欧美视频手机在线| 激情五月婷婷综合| 国产精品免费久久久久久| 亚洲欧美日韩精品久久亚洲区| 欧美—级高清免费播放| 亚洲激情第一区| 亚洲自拍偷拍麻豆| 国产女主播一区| 一本大道久久a久久精品综合| 欧美影院在线| 国内视频精品| 欧美亚洲视频| 在线观看日韩欧美| 免费国产自线拍一欧美视频| 久久午夜激情| 亚洲午夜影视影院在线观看| 99伊人成综合| 一本在线高清不卡dvd| 久久这里只有精品视频首页| 欧美一级艳片视频免费观看| 亚洲人线精品午夜| 久久综合综合久久综合| 国产精品日韩精品欧美精品| 国产精品理论片| 激情综合色综合久久| 亚洲一区三区视频在线观看| 亚洲高清视频在线观看| 伊人久久婷婷色综合98网| 99re8这里有精品热视频免费| 国内精品国语自产拍在线观看| 亚洲欧美清纯在线制服| 亚洲午夜精品| 欧美午夜不卡视频| 一区二区高清在线| 狠狠久久亚洲欧美| 欧美高清在线视频| 午夜精品福利视频| 国产精品sss| 久久久久久久久一区二区| 欧美亚洲色图校园春色| 国产亚洲一区二区精品| 欧美色播在线播放| 欧美激情一区二区三级高清视频| 亚洲午夜激情| 国产精品久久久久免费a∨大胸| 亚洲欧美乱综合| 亚洲欧美欧美一区二区三区| 一区二区三区四区五区精品| 亚洲第一网站免费视频| 午夜精品在线| 亚洲欧美成人在线| 国产精品男gay被猛男狂揉视频| 欧美性大战xxxxx久久久| 久久久久久久久一区二区| 久久午夜视频| 欧美一区二区免费视频| 亚洲免费在线看| 99人久久精品视频最新地址| 亚洲韩国一区二区三区| 亚洲在线成人| 亚洲最黄网站| 国产精品一区在线观看| 国产精品成人午夜| 久久精品一区二区三区中文字幕|