<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 一種基于FPGA的在線(xiàn)監控系統設計

一種基于FPGA的在線(xiàn)監控系統設計

作者: 時(shí)間:2014-07-24 來(lái)源:網(wǎng)絡(luò ) 收藏

  2.2.2 目標CPU對的讀寫(xiě)操作

本文引用地址:http://dyxdggzs.com/article/255998.htm

  目標CPU收到通信中斷請求后,讀區的中斷郵箱,郵箱信息包含本次申請功能(讀或寫(xiě))及申請的數據項個(gè)數等。根據申請地址集,將自身內存映像區相應數據集一次搬入,或將雙口RAM中數據集一次搬入內存映像區相應地址處,搬移完畢后,清空中斷郵箱,向監控模塊發(fā)出中斷應答。

  3 Modbus協(xié)議棧模塊的設計與實(shí)現

  采用自頂向下的設計方法,根據功能需求設計Modbus協(xié)議棧頂層原理框圖如圖3。使用VHDL硬件描述語(yǔ)言編程實(shí)現各組成子模塊,功能如下述。

  

圖 3 Modbus 協(xié)議棧頂層框圖

 

  圖 3 Modbus 協(xié)議棧頂層框圖

  (1)時(shí)鐘生成模塊:通過(guò)分頻和相移產(chǎn)生位時(shí)鐘clk和1/16位時(shí)鐘bclk,作為控制其他模塊的運行節拍,保證系統運行同步。

  (2)串口接收模塊:以bclk作為控制時(shí)鐘,對接收的位數據作中點(diǎn)采樣,進(jìn)行串并裝換得到字節數據。

  (3)串口發(fā)送模塊:以bclk作為控制時(shí)鐘,發(fā)送使能信號有效時(shí),輸入端的字節數據進(jìn)行并串裝換,通過(guò)串口發(fā)出。

  (4)接收控制模塊:判斷幀的起始、結束、是否接收錯誤;提供地址數據,接收的字節數據被存儲至RAM1中相應存儲單元。

  (5)CRC校驗/生成模塊:使用基于字節的CRC_16校驗碼運算方法。接收端的校驗過(guò)程與數據接收同步進(jìn)行,接收控制模塊每收到一個(gè)字節數據,CRC校驗模塊對其作一次CRC碼計算;CRC生成模塊運行機制類(lèi)同。同步運算可有效減少一次對幀數據的遍歷。

  (6)解析主控模塊:作為系統的核心,負責解析收到的命令幀,根據解析信息進(jìn)行數據讀寫(xiě)操作,組成應答幀,控制串口發(fā)送模塊發(fā)送應答數據等多項任務(wù)。收到一個(gè)校驗無(wú)誤的命令幀后,控制讀取接收緩存區RAM1中數據,比照Modbus幀格式解析命令幀含義,通過(guò)對外數據、地址等接口完成對雙口RAM的讀寫(xiě)操作;解析及操作完畢后,控制應答幀組幀過(guò)程,將應答數據依次寫(xiě)入RAM2發(fā)送緩存區,全部寫(xiě)入后,將CRC生成模塊中CRC_16校驗值按低位在前高位在后順序,依次存放到發(fā)送緩存的下兩個(gè)地址位置處,此時(shí)應答幀準備完畢;控制發(fā)出應答幀,依次讀取出發(fā)送緩存區數據(讀脈沖間的時(shí)間間隔至少大于串口發(fā)送單個(gè)字節所需時(shí)間),每取出一個(gè)數據,提供發(fā)送使能脈沖供串口發(fā)送模塊工作,脈寬等于串口發(fā)送單個(gè)字節所需時(shí)間,直至應答幀全部發(fā)送完畢。

  (7)接收緩存RAM1/發(fā)送緩存RAM2:存儲串口接收模塊收到的字節數據/存儲待發(fā)送的應答幀。

  4 性能分析

  分析監控通信對Soc系統性能的影響,設定一系列參數如下:時(shí)間基數T(min)、監控頻率m(幀/min)、監控命令幀平均長(cháng)度n(byte/幀)、Soc主循環(huán)平均周期k(ms)、通信波特率B(bit/s)、中斷處理指令數r(條)、查詢(xún)語(yǔ)句指令數s(條)、處理器主頻f(HZ)。針對常用的輪詢(xún)監控、中斷監控,及該文所提出的基于的DRAM監控方法,可按照表1公式計算其監控通信過(guò)程占用的CPU時(shí)間。

  對于常用ARM處理器,可例舉部分參數值f=72M,r=15,s=5。設定其余參數值T=1,m=100,n=30,k=0.05,B=115200。在當前設定下,計算得出三種監控方法對CPU的時(shí)間占用百分比,如表1所示。對比應用單一的中斷或輪詢(xún)方式,使用該文提出的監控方法時(shí),嵌入式系統CPU的利用率得到了明顯的提高。

  5 結語(yǔ)

  該文提出一種針對嵌入式片上系統的方法。利用技術(shù)設計了輔助監控系統,由該系統完成監控通信過(guò)程中的接收通信命令幀、解析命令幀及組成應答數據幀等任務(wù),加快了對通信數據的處理速度。SoC有效減少了處理監控所需時(shí)間,更集中于其控制功能的執行,從而獲得更高的實(shí)時(shí)性。設計工作在A(yíng)ltera公司的QuartusII開(kāi)發(fā)平臺上采用VHDL語(yǔ)言完成,使用CycoloneII系列芯片作功能驗證,通信系統的Modbus接口與上位機在115200的波特率下收發(fā)正確,雙口RAM內數據交互穩定,達到了預計效果。

fpga相關(guān)文章:fpga是什么



上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: FPGA 在線(xiàn)監控 雙口RAM

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>