0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于Cyclone系列芯片實現(xiàn)Nios嵌入式處理器系統(tǒng)的設計

電子設計 ? 來源:單片機與嵌入式系統(tǒng)應用 ? 作者:于明喆,李暉,申婷 ? 2021-06-18 14:18 ? 次閱讀

隨著消費類電子,如MP3、3G手機、視頻終端以及寬帶無線網(wǎng)絡的普及,對大容量存儲設備的需求越來越強烈。傳統(tǒng)的SRAMSDRAM以及DDR SDRAM等存儲設備的價格與容量比,遠遠比硬盤高;光存儲設備雖然更加廉價,但是在便攜性上卻遠遜于硬盤解決方案?,F(xiàn)在硬盤廠商提供了各種適用于不同用途的廉價海量存儲設備,如1 in(英寸)的微硬盤可以應用于各種小巧的便攜設備中,2.5in硬盤可以應用于筆記本和移動存儲中,3.5in硬盤可以應用于個人PC和工業(yè)自動化中等等。

目前,硬盤支持的最為廣泛的IDE接口協(xié)議中,規(guī)定了PIO、DMA以及Ultra DMA三種數(shù)據(jù)傳輸模式,其傳輸速率PIO<多字DMA<Ultra DMA,如表1所列。隨著各種多媒體應用的廣泛普及,各種設備不但要求擁有海量存儲能力,在完成各種實時業(yè)務時對數(shù)據(jù)的傳輸速率也提出了嚴格的要求。

現(xiàn)階段的設計研究主要集中于單邊沿鎖存數(shù)據(jù)的PIO和DMA傳輸模式。大多數(shù)設計主要用PIO模式完成控制命令的寫入和讀取操作,采用DMA數(shù)據(jù)傳輸模式進行直接內存讀取操作,提高數(shù)據(jù)傳輸?shù)乃俾省H绻谙嗤到y(tǒng)中使用Ultra DMA數(shù)據(jù)傳輸模式,則可以在不提高系統(tǒng)時鐘頻率的基礎上,將系統(tǒng)數(shù)據(jù)傳輸速率提高l倍,極大地改善了系統(tǒng)性能,而不需要付出更多的硬件資源。因而硬盤的Ultra DMA數(shù)據(jù)傳輸方式在工業(yè)自動化、Internet網(wǎng)絡、消費類電子和各種嵌入式系統(tǒng)中的需求會不斷增加,有著很好的商業(yè)前景。

1 Nios系統(tǒng)介紹

該設計是在Altera公司推出的Nios嵌入式系統(tǒng)的平臺上,設計可以通過Ultra DMA數(shù)據(jù)傳輸方式進行高速硬盤讀寫的接口模塊,并開發(fā)出相應的IP核。

1.1 Nios系統(tǒng)結構

Nios嵌入式處理器系統(tǒng)通常由N1os處理器、Avalon交換結構總線和各種外圍設備(存儲、接口及功能模塊)的IP核三部分構成。Altera的SOPC Builder系統(tǒng)開發(fā)工具可以自動生成這些組件以及連接它們的總線。

Nios處理器是32位結構可配置并包含五級流水線的通用RISC微處理器,采用改進的哈佛存儲器結構;處理器帶有分離的數(shù)據(jù)和程序存儲器總線控制,具備高速緩存、中斷處理功能。與傳統(tǒng)處理器相比,Nios指令系統(tǒng)可通過自定義指令和標準處理器選項,利用硬件來明顯提高系統(tǒng)性能。

Avalon交換結構總線是Altera開發(fā)的用于Nios嵌入式處理器的參數(shù)化接口總線,由l組預定義的信號組成,用這些信號可以連接1個或多個IP模塊。Altera的S0PC Builder系統(tǒng)開發(fā)工具自動地產生Avalon交換結構總線邏輯,其實現(xiàn)只需要極少的FPGA資源,提供完全同步的操作。

Nios嵌入式處理器系統(tǒng)中的各種存儲模塊、接口模塊和功能模塊等都在Altera的標準外圍設備庫中以IP核的方式提供使用,或是由用戶自行設計添加到庫中,以IP模塊的方式在系統(tǒng)中復用。

實現(xiàn)硬盤高速訪問功能模塊的設計,實際上是在設計一個完整的IP模塊,再在Altera提供的SOPC Builder開發(fā)環(huán)境的設備庫中集成該IP核,以達到設計的目的。

1.2采用Nlos軟核處理器構建系統(tǒng)的原因

①與其他的實現(xiàn)方式相比有著更好的性能價格比。最常見的硬盤讀取控制和數(shù)據(jù)傳輸方式是通過單片機或是DSP來實現(xiàn)的,使用單片機或DSP中的PIO接口可以很方便地完成單邊沿鎖存數(shù)據(jù)的硬盤PIO和DMA數(shù)據(jù)傳輸方式,但在實現(xiàn)雙邊沿鎖存數(shù)據(jù)的Ultra DMA傳輸方式時,必須在單片機和DSP芯片外添加額外的FPGA芯片,完成Ultra DMA雙邊沿鎖存數(shù)據(jù)到單邊沿鎖存數(shù)據(jù)的轉換,增加了系統(tǒng)設計的成本和復雜性。而采用Nios軟核處理器完成與硬盤的Ultra DMA傳輸方式時,不需要添加任何額外的芯片,僅使用FPGA內的其他資源就可以方便地實現(xiàn)雙邊沿到單邊沿的轉換工作。

②與傳統(tǒng)的單片機或DSP實現(xiàn)方式相比,Nios嵌入式系統(tǒng)的設計與實現(xiàn)更加簡單。從性能上來說,Nios軟核處理器與ARMIntel等的CPU處于同一級別,都能夠滿足設計的需要,即使是復雜邏輯系統(tǒng)的設計也可以在一片Cyclone或是StratiX芯片上實現(xiàn)全部功能。而且通過使用Altera公司提供的SOPC Builder開發(fā)工具,在IP復用的基礎上可以快速開發(fā)出完整的系統(tǒng)解決方案。

③與傳統(tǒng)的單片機或DSP實現(xiàn)方式相比,Nios嵌入式系統(tǒng)的可擴展性更好。單片機或DSP內的資源是硬件廠商固化在芯片內的,用戶不可能自行添加或刪減,在設計時的靈活性受到器件本身的限制;而Nios軟核處理器的所有資源都可以任意地添加或刪減,只需最終通過電纜下載到FPGA芯片內就可定制出整個系統(tǒng)的功能。因而在基于Nios的系統(tǒng)設計中,通過對設計文件的修改就可以很方便地進行系統(tǒng)功能的擴展。

2 系統(tǒng)的硬件實現(xiàn)

硬件部分由Nios嵌入式系統(tǒng)、Nios與硬盤的接口模塊和其他外圍接口電路三部分組成,如圖1所示。其中設計的核心部分是Nios系統(tǒng)與硬盤接口模塊的IP核設計,主要完成數(shù)據(jù)傳輸模式的轉換,以及對硬盤的控制與操作兩部分任務。Nios嵌入式處理器系統(tǒng)的任務是進行整體控制與協(xié)調,并對數(shù)據(jù)進行處理和暫存;外圍接口電路主要用來擴充系統(tǒng)的功能,擴大系統(tǒng)的適用范圍。

Nios嵌入式處理器系統(tǒng)由Nios嵌入式處理器、DMA控制器、數(shù)據(jù)存儲區(qū)SDRAM、程序存儲區(qū)F1ash和Avalon總線構成。其中DMA控制器用于實現(xiàn)兩個存儲器之間,或者存儲器和外設之間,或者是兩個外設之間的直接數(shù)據(jù)傳輸。DMA模塊用于連接支持流模式傳輸?shù)耐庠O,并允許定長或變長的數(shù)據(jù)傳輸,而不需要CPU的干涉。在Ultra DMA數(shù)據(jù)傳輸?shù)倪^程中,可以一次性傳輸最多256個扇區(qū)的數(shù)據(jù),所以在系統(tǒng)中使用DMA控制器可以方便地在硬盤與系統(tǒng)中各種支持流傳輸模式的設備之間建立直通連接,提高系統(tǒng)的數(shù)據(jù)傳輸效率。

外圍接口電路主要用于系統(tǒng)功能的擴充,如Internet接口可以使系統(tǒng)方便地接人到網(wǎng)絡中提供諸如音樂或視頻下載、信息共享等服務;串口用于與計算機或其他設備的互連;VGA接口用于視頻信號的輸出,在系統(tǒng)外部顯示圖像等等。

硬盤接口部分主要由接口控制邏輯、Avalon總線接口、FIFO和硬盤IDE接口4部分組成。其中接口控制邏輯部分用于對Nios處理器的指令進行譯碼并執(zhí)行相應的操作,控制Ultra DMA傳輸時的握手和控制信號的產生,協(xié)調數(shù)據(jù)傳輸過程中IDE接口的硬盤數(shù)據(jù)速率同Avalon總線接口速率的匹配。

FIFO用于數(shù)據(jù)的緩沖,解決Avalon總線和IDE接口之間的數(shù)據(jù)速率不匹配問題。在設計中需要對硬盤UltraDMA的六種數(shù)據(jù)傳輸模式同時提供支持,而其傳輸速率卻完全不同,必須添加緩沖區(qū)用于數(shù)據(jù)的暫存。

Avalon總線接口用于與Nios處理器系統(tǒng)相連,傳輸Nios處理器的指令給控制邏輯部分,以及與系統(tǒng)中的其他部分在DMA控制器的協(xié)調下完成數(shù)據(jù)的傳輸。

硬盤IDE接口部分除輸出控制信號并對硬盤返回的信號做出響應外,還要完成單邊沿數(shù)據(jù)鎖存模式與雙邊沿數(shù)據(jù)鎖存模式相互轉換的任務,如圖2、圖3所示。

由于Nios系統(tǒng)內部數(shù)據(jù)傳輸時,都使用時鐘上升沿來鎖存數(shù)據(jù);而IDE總線上傳輸?shù)腢ltra DMA數(shù)據(jù),在Clock信號的上升沿和下降沿都有數(shù)據(jù)需要鎖存。因而硬盤接口部分兩側的數(shù)據(jù),在傳輸時工作模式各不相同,需要進行必要的緩沖和模式轉換。

數(shù)據(jù)鎖存模式轉換模塊,用于在IDE總線上雙邊沿鎖存數(shù)據(jù)和系統(tǒng)內部單邊沿鎖存數(shù)據(jù)之間進行鎖存模式的轉換,這是系統(tǒng)設計的核心問題之一。具體來說,就是在讀取硬盤數(shù)據(jù)時需要將IDE總線上傳輸?shù)碾p邊沿鎖存數(shù)據(jù)轉換為系統(tǒng)內部使用的單邊沿鎖存數(shù)據(jù);在寫硬盤操作時完成相反的任務。在設計時采用兩組寄存器對不同時鐘沿的信號進行鎖存,在時鐘頻率不變的基礎上,通過數(shù)據(jù)帶寬的擴展,完成雙邊沿到單邊沿的轉換功能;在單邊沿數(shù)據(jù)到雙邊沿數(shù)據(jù)的轉換過程中,采用相反的構架。

3 系統(tǒng)工作流程

系統(tǒng)在完成基于Ultra DMA的數(shù)據(jù)傳輸模式的硬盤訪問功能時,需要實現(xiàn)對硬盤數(shù)據(jù)通過Ultra I)MA模式進行的讀操作和寫操作。其具體的工作流程各不相同,主要區(qū)別在于:

①Nios系統(tǒng)內部的協(xié)調過程。作為系統(tǒng)處理核心的Nios處理器,必須向硬盤接口邏輯和DMA控制器中發(fā)送指令,使其按照設計要求執(zhí)行相應的操作。向硬盤接口邏輯部分發(fā)送讀寫硬盤的指令時,需要首先命令讀操作時使用FIFO對硬盤數(shù)據(jù)進行緩沖,在寫操作時將FIFO中的緩沖數(shù)據(jù)發(fā)送到硬盤中完成寫入操作;向DMA控制器部分發(fā)送指令,協(xié)調接口緩沖區(qū)FIFo和系統(tǒng)內存SDRAM中數(shù)據(jù)的交互過程,以完成對硬盤的讀寫操作。

②對硬盤的讀寫訪問操作。在對硬盤進行讀寫操作時,必須向硬盤的接口寄存器中發(fā)送DMA讀指令或寫指令,其指令碼和操作順序也不盡相同,如圖4、圖5所示。

4 系統(tǒng)的軟件實現(xiàn)

在Nios SDK Shell環(huán)境下,使用帶Monitor的bootloader程序,可以在程序Debug的同時監(jiān)控內部存儲器的變化,便于硬件設計的檢查和程序的調試。軟件的編寫主要采用C語言,部分嵌入了匯編語言。整個系統(tǒng)軟件設計中的重點是以下兩部分。

(1)Nios系統(tǒng)內DMA控制器的編程

在DMA傳輸過程中需要完成的操作有:①配置DMA控制器;②軟件啟動DMA外設,開始DMA傳輸;③DMA控制器的主設備讀端口從目標地址讀取數(shù)據(jù),主設備寫端口向目標地址寫入數(shù)據(jù);④DMA傳輸結束。

這一過程中,需要向DMA控制器的寄存器中寫入控制指令來開啟一次數(shù)據(jù)傳輸過程。要求初始化的寄存器有:status、readaddress、wi rte£Jddress、length和contiol。之后調用系統(tǒng)提供的DMA子程序開啟一次DMA操作,使用的DMA子程序有:nr_dma_opy_1_tO_rarlge(在原地址和目標地址之間,傳輸length長度的數(shù)據(jù),原地址固定,而目標地址在每次傳輸后增加),用于完成數(shù)據(jù)讀取操作時,從FIFO緩沖區(qū)中向SDRAM里傳輸數(shù)據(jù);nr_dma_copy_range_to_l(在原地址和目標地址之間,傳輸lengt長度的數(shù)據(jù),目標地址固定,而原地址在每次傳輸后增加),用于完成數(shù)據(jù)寫操作時,從SDRAM里向FIFO中緩沖數(shù)據(jù)。

(2)硬盤的DMA讀寫命令

在對硬盤進行讀寫操作時須向硬盤的寄存器內寫入DMA讀指令(或寫指令)和相應參數(shù)后才可對硬盤中的數(shù)據(jù)進行訪問。在ATAPI 協(xié)議中規(guī)定了READ DMA指令和WRITE DMA指令的命令格式,需要向SectorCbunt、SectorNulmber、CyclindeLow、CyblindelrHigh、Device/Head、Command寄存器中寫入?yún)?shù)和命令代碼。其中讀指令的代碼是C8h、寫指令的代碼是CAh。在寫入命令后就可以對硬盤中的數(shù)據(jù)進行讀寫操作。

結 語

本系統(tǒng)使用Nios嵌入式系統(tǒng)在單芯片內實現(xiàn)了數(shù)據(jù)處理、存儲訪問、數(shù)據(jù)模式轉換等多個功能。采用Altera公司提供的Quartus II 和 SOPC Builder開發(fā)工具可以在完成接口功能設計后,快速進行系統(tǒng)的集成設計和系統(tǒng)仿真,最終可以在Altera提供的Cyclone系列芯片上實現(xiàn)整個系統(tǒng)設計。對Nios處理器重新編程可以在不改變系統(tǒng)硬件框架的基礎上,方便地增加系統(tǒng)的功能和處理效率,對系統(tǒng)的升級和再開發(fā)有很大的便利。

責任編輯:gt

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19384

    瀏覽量

    230509
  • 芯片
    +關注

    關注

    456

    文章

    51037

    瀏覽量

    425488
  • 嵌入式
    +關注

    關注

    5088

    文章

    19158

    瀏覽量

    306482
收藏 人收藏

    評論

    相關推薦

    基于Nios II和uClinux實現(xiàn)遠程測控服務的設計

    系統(tǒng)的硬件結構如圖2所示。硬件系統(tǒng)的核心是構建于Ahera Cyclone FPGA中的Nios II嵌入式軟核
    發(fā)表于 06-28 14:49 ?745次閱讀
    基于<b class='flag-5'>Nios</b> II和uClinux<b class='flag-5'>實現(xiàn)</b>遠程測控服務<b class='flag-5'>器</b>的設計

    第05章 Nios嵌入式處理器設計

    第05章 Nios嵌入式處理器設計 242頁 1.5M
    發(fā)表于 09-27 08:50

    嵌入式處理器原理及應用 Nios系統(tǒng)設計和C語言編程 294頁 17.9M

    嵌入式處理器原理及應用 Nios系統(tǒng)設計和C語言編程 294頁 17.9M
    發(fā)表于 09-28 08:44

    嵌入式處理器原理及應用 Nios系統(tǒng)設計和C語言編程 294頁 17.9M

    嵌入式處理器原理及應用 Nios系統(tǒng)設計和C語言編程 294頁 17.9M
    發(fā)表于 09-29 08:45

    采用nios和μClinux實現(xiàn)嵌入式系統(tǒng)設計

    嵌入式系統(tǒng)一般由嵌入式微處理器、外圍硬件設備、嵌入式操作系統(tǒng)以及用戶應用程序四部分組成,其發(fā)展主要體現(xiàn)在
    發(fā)表于 04-18 07:00

    Cyclone II FPGA和Nios II嵌入式處理器的優(yōu)勢

    在其業(yè)內領先的低成本Cyclone TM FPGA系列Nios軟核嵌入式處理器成功的基礎上,Altera現(xiàn)在推出了第二代產品
    發(fā)表于 07-18 07:43

    請問如何實現(xiàn)片上嵌入式Nios Ⅱ軟核六處理器系統(tǒng)的設計?

    片上Nios嵌入式軟核多處理器系統(tǒng)具有哪些優(yōu)勢?如何實現(xiàn)片上嵌入式
    發(fā)表于 04-19 08:17

    Nios II 嵌入式處理器 7.1 的新特性

    Nios II 嵌入式處理器 7.1 的新特性
    發(fā)表于 08-04 14:40 ?4次下載

    Nios II入門起步-創(chuàng)建一個嵌入式處理器系統(tǒng)

    Nios簡單介紹: Nios II是一個用戶可配置的通用RISC嵌入式處理器。在這兒,我引用了Altera公司關于NiosII的官方介紹: Altera推出的
    發(fā)表于 05-26 09:11 ?87次下載
    <b class='flag-5'>Nios</b> II入門起步-創(chuàng)建一個<b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b><b class='flag-5'>系統(tǒng)</b>

    基于Chirp函數(shù)的Nios嵌入式實現(xiàn)

    分析Chirp函數(shù)在頻域上的一般特性,提出利用FPGA的嵌入式軟核Nios處理器嵌入式操作系統(tǒng)μC/OS-Ⅱ上
    發(fā)表于 06-15 11:02 ?1190次閱讀
    基于Chirp函數(shù)的<b class='flag-5'>Nios</b> Ⅱ<b class='flag-5'>嵌入式</b><b class='flag-5'>實現(xiàn)</b>

    Nios II處理器-世界上最通用的處理器

      Nios II系列軟核處理器是Altera的第二代FPGA嵌入式處理器,其性能超過200DMIPS,在Altera FPGA中
    發(fā)表于 11-30 16:33 ?2967次閱讀
    <b class='flag-5'>Nios</b> II<b class='flag-5'>處理器</b>-世界上最通用的<b class='flag-5'>處理器</b>

    介紹如何用Nios II 軟核處理器來開發(fā)FPGA嵌入式系統(tǒng)軟件

    FPGA在嵌入式設計中的應用越來越普遍。了解怎樣采用流行的Nios? II 軟核處理器來輕松開發(fā)FPGA嵌入式系統(tǒng)軟件。 在這一5分鐘
    的頭像 發(fā)表于 06-22 02:01 ?4598次閱讀

    采用NIOS嵌入式處理器的液晶顯示屏滾屏設計方案

    Nios II系列軟核處理器是Altera的第二代FPGA嵌入式處理器,其性能超過200DMIPS, Altera的Stratix、Stra
    的頭像 發(fā)表于 10-31 09:34 ?2616次閱讀
    采用<b class='flag-5'>NIOS</b>Ⅱ<b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>的液晶顯示屏滾屏設計方案

    FPGA Nios嵌入式處理器的軟件開發(fā)

    Nios 嵌入式處理器是一個優(yōu)化了的CPU 軟核,用于可編程邏輯器件上的SOPC 設計。Nios 處理器使用了Altera 的SOPC Bu
    發(fā)表于 01-15 15:58 ?0次下載
    FPGA <b class='flag-5'>Nios</b><b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>的軟件開發(fā)

    FPGA Nios嵌入式處理器的軟件開發(fā)

    Nios 嵌入式處理器是一個優(yōu)化了的CPU 軟核,用于可編程邏輯器件上的SOPC 設計。Nios 處理器使用了Altera 的SOPC Bu
    發(fā)表于 01-15 15:58 ?17次下載
    FPGA <b class='flag-5'>Nios</b><b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>的軟件開發(fā)