《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 在FPGA上對OC8051IP核的修改與測試
在FPGA上對OC8051IP核的修改與測試
摘要: 本文介紹了一種OC8051 IP核的仿真測試方案。該方案給出了查找與定位IP核中邏輯錯誤的方法,并詳細介紹了各種錯誤的修改方法。測試結果表明,OC8051工作正常,已經初步具備了微控制器的功能,可以被運用于實際的工程開發中。
關鍵詞: SoPC FPGA OC8051 IP核
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核源文件進行修改。


  值得注意的是,雖然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。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品系列| 亚洲一区二区三区四区五区午夜| 欧美日本中文字幕| 蜜臀av一级做a爰片久久| 久久精品国产96久久久香蕉| 亚洲欧美日韩中文视频| 亚洲在线1234| 亚洲——在线| 亚洲欧美一区二区三区久久| 亚洲欧美国产制服动漫| 亚洲欧美另类在线观看| 亚洲欧美在线另类| 亚洲免费伊人电影在线观看av| 亚洲一级片在线观看| 亚洲图片欧美午夜| 亚洲一区二区三区四区五区午夜 | 久久这里只精品最新地址| 欧美在线观看一区| 久久精品成人欧美大片古装| 久久久国产精品一区二区三区| 久久久精品动漫| 久久精品一本久久99精品| 久久久久久亚洲精品不卡4k岛国| 久久日韩精品| 欧美阿v一级看视频| 欧美激情免费观看| 欧美视频在线免费看| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 99综合在线| 亚洲在线国产日韩欧美| 午夜日本精品| 亚洲国产高潮在线观看| 亚洲美女黄网| 亚洲中午字幕| 久久久久www| 欧美国产91| 欧美亚一区二区| 国产啪精品视频| 精品盗摄一区二区三区| 亚洲精品久久久久久久久久久久| 宅男在线国产精品| 欧美在线在线| 日韩视频在线免费| 欧美一级视频精品观看| 久久野战av| 欧美日韩午夜| 国产精品欧美日韩久久| 好看不卡的中文字幕| 亚洲精品欧美极品| 亚洲欧美不卡| 亚洲国产电影| 亚洲自拍偷拍麻豆| 美女精品网站| 国产精品成人在线| 国内欧美视频一区二区| 亚洲精选在线观看| 午夜在线一区二区| 日韩亚洲不卡在线| 久久精品导航| 欧美日韩精品综合在线| 国产亚洲欧美激情| 亚洲毛片av| 久久精品国产一区二区电影 | 欧美系列一区| 国产亚洲一区二区精品| 亚洲日韩视频| 性欧美超级视频| 亚洲视频欧洲视频| 老妇喷水一区二区三区| 国产精品国产福利国产秒拍| 黑人巨大精品欧美一区二区小视频 | 久久国产日韩| 欧美日韩国产系列| 国产一区二区中文| 一本大道久久a久久综合婷婷| 欧美一区二区三区电影在线观看| 亚洲手机视频| 男人插女人欧美| 国产三级精品在线不卡| 日韩一级精品| 亚洲精品中文字幕女同| 久久精品综合一区| 国产精品久久久久久久电影| 最新成人av网站| 亚洲成人资源| 欧美一区二区三区免费看| 欧美日本中文| 亚洲高清资源| 欧美资源在线观看| 欧美影院视频| 国产精品va在线播放我和闺蜜| 最新成人av网站| 亚洲国产一区二区在线| 久久爱91午夜羞羞| 国产精品久久久久久久久久ktv | 亚洲一区欧美二区| 欧美精品免费看| 在线精品亚洲| 久久国产精品久久久久久久久久| 亚洲欧美中文另类| 欧美婷婷久久| 日韩亚洲欧美高清| 日韩一级大片| 欧美另类综合| 亚洲欧洲精品一区二区精品久久久| 欧美一区二区三区日韩视频| 小黄鸭精品密入口导航| 国产精品第三页| 一本久久综合亚洲鲁鲁五月天| 日韩视频在线一区| 欧美国产一区视频在线观看| 1000部国产精品成人观看| 久久精品亚洲乱码伦伦中文 | 久久精品成人一区二区三区蜜臀| 国产精品网曝门| 中日韩在线视频| 亚洲制服av| 国产精品九九久久久久久久| 99视频在线观看一区三区| 一本一本久久a久久精品综合麻豆| 欧美激情二区三区| 亚洲精品在线免费| 一区二区三区黄色| 欧美吻胸吃奶大尺度电影| 在线亚洲美日韩| 欧美一级精品大片| 国产午夜精品在线| 亚洲大胆视频| 欧美护士18xxxxhd| 亚洲精品视频在线| 亚洲伊人一本大道中文字幕| 国产精品入口| 欧美一区国产一区| 久久久91精品| 在线日韩av片| 亚洲精品综合精品自拍| 欧美视频在线观看| 亚洲欧美日韩精品久久久| 久久成人综合视频| 狠狠入ady亚洲精品| 最新亚洲视频| 欧美日韩国产一级| 亚洲视频网在线直播| 香蕉成人伊视频在线观看| 国产一区白浆| 亚洲人成在线观看| 欧美日韩视频不卡| 亚洲在线1234| 久久亚洲一区二区三区四区| 亚洲国产欧美另类丝袜| 亚洲一区免费| 国产亚洲激情| 亚洲精品国产精品国自产在线 | 欧美xx69| 一区二区三区久久| 久久不射网站| 亚洲国产精品久久久久秋霞不卡| 一区二区国产日产| 国产裸体写真av一区二区| 久久精品国内一区二区三区| 欧美精品18videos性欧美| 亚洲午夜视频在线观看| 久久婷婷亚洲| 一本色道久久综合亚洲精品小说 | 欧美精品亚洲精品| 亚洲一区三区视频在线观看 | 国模套图日韩精品一区二区| 亚洲人午夜精品免费| 欧美天堂亚洲电影院在线观看| 午夜宅男久久久| 欧美精品啪啪| 欧美一区二区在线观看| 欧美日本二区| 欧美一区二区视频在线观看2020| 欧美激情第二页| 欧美一级视频| 欧美激情一区在线观看| 亚洲男同1069视频| 欧美激情第五页| 欧美一区二区在线观看| 欧美日韩亚洲三区| 久久国产免费看| 国产精品初高中精品久久| 亚洲黄色有码视频| 国产乱码精品一区二区三| 亚洲精品视频在线观看网站| 国产日韩欧美精品在线| 99riav久久精品riav| 好吊日精品视频| 亚洲欧美资源在线| 亚洲片在线资源| 久久综合激情| 亚洲免费在线视频| 欧美人与性动交α欧美精品济南到| 欧美在线视频一区二区三区| 国产精品国产三级国产专区53 | 9l视频自拍蝌蚪9l视频成人| 蜜桃久久精品一区二区| 亚洲性线免费观看视频成熟| 欧美精品一区二区三区久久久竹菊|