《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 一種基于NiosⅡ的可重構DSP系統設計[圖]
一種基于NiosⅡ的可重構DSP系統設計[圖]
來源:《電子設計應用》2007年第3期
唐穎 阮越
摘要: 一種基于NiosⅡ的可重構DSP系統設計[圖],摘要:應用NiosⅡ嵌入式軟核處理器所具有的可自定義指令的特點,本文提出了一種具有常規DSP功能的N
Abstract:
Key words :
摘要:應用NiosⅡ嵌入式軟核處理器所具有的可自定義指令的特點,本文提出了一種具有常規DSP功能的NiosⅡ系統SOPC解決方案。用戶可通過Matlab和DSP Builder或VHDL語言來設計復數乘法器、整數乘法器、浮點乘法器等硬件模塊,再將它們定制為相應的指令,從而實現軟件的靈活性和硬件高速性的結合。

引言

為了解決傳統DSP所面臨的速度低、硬件結構不可重構、開發升級周期長和不可移植等問題,本文應用Altera公司推出的NiosⅡ嵌入式軟核處理器,提出了一種具有常規DSP的NiosⅡ系統功能SOPC解決方案。由于可編程的NiosⅡ核含有許多可配置的接口模塊,用戶可根據設計要求,利用QuartusⅡ和SOPC Builder對NiosⅡ及其外圍系統進行構建。用戶還可通過Matlab和DSP Builder,或直接用VHDL等硬件描述語言,為NiosⅡ嵌入式處理器設計各類硬件模塊,并以指令的形式加入到NiosⅡ的指令系統中,使其成為NiosⅡ系統的一個接口設備,與整個片內嵌入式系統融為一體,而不是直接下載到FPGA中生成龐大的硬件系統。正是NiosⅡ所具有的這些重要特點,使得可重構單片DSP系統的設計成為可能。

Nios Ⅱ嵌入式系統設計流程

NiosⅡ嵌入式處理器專為單芯片可編程系統設計而優化,是一種面向用戶、可以靈活定制的通用RISC(精簡指令集)嵌入式CPU。它采用Avalon總線結構通信接口,帶有增強的內存、調試和軟件功能,可采用匯編或C、C++等進行程序優化開發。NiosⅡ具有32位指令集、32位數據通道和可配置的指令及數據緩沖。與普通嵌入式CPU系統的特性不同,其外設可以靈活選擇或增刪,可以自定制用戶邏輯為外設,可以允許用戶定制自己的指令集。由硬件模塊構成的自定制指令可通過硬件算法操作來完成復雜的軟件處理任務,也能訪問存儲器或NiosⅡ系統外的接口邏輯。設計者可以使用NiosⅡ及外部的Flash、SRAM等,在FPGA上構成一個嵌入式處理器系統。

完整的基于NiosⅡ的SOPC系統是一個軟硬件復合的系統,因此在設計時可分為硬件和軟件兩部分。NiosⅡ的硬件設計是為了定制合適的CPU和外設,在SOPC Buider和QuartusⅡ中完成。在這里可以靈活定制NiosⅡ CPU的許多特性甚至指令,可使用Altera公司提供的大量IP核來加快開發NiosⅡ外設的速度,提高外設性能,也可以使用第三方的IP核或VHDL來自行定制外設。完成NiosⅡ的硬件開發后,SOPC Buider可自動生成與自定義的NiosⅡ CPU和外設系統、存儲器、外設地址映射等相應的軟件開發包SDK,在生成的SDK基礎上,進入軟件開發流程。用戶可使用匯編或C,甚至C++來進行嵌入式程序設計,使用GNU工具或其它第三方工具進行程序的編譯連接以及調試。

單片DSP系統構架

本系統為單片DSP可重構系統,能完成數字信號處理方面各功能的操作。其中NiosⅡ軟件處理器主要完成人機交互和控制作用;FPGA的邏輯模塊從NiosⅡ處理器接收控制信號和數據后,完成相應的硬件功能。系統框圖如圖1所示,除了軟核處理器NiosⅡ外,存儲器、I/O接口以及FIR數字濾波器、ⅡR數字濾波器、DDS等應用模塊等均可作為外設嵌入在FPGA中。這樣,整個DSP的數字信號處理部分全部集成在FPGA器件中,各模塊受NiosⅡ處理器的控制。NiosⅡ處理器系統中有Avalon總線,它規定了控制器與從屬模塊間的端口連接以及模塊間通信的時序。數字頻率合成器(DDS)通過Avalon總線與Nios Ⅱ處理器相連,能很方便地完成控制及數據傳送。

一種基于NiosⅡ的可重構DSP系統設計

在本系統中,FPGA采用Cyclone? EPIC12,它有12060個邏輯單元(LE)和2個鎖相環(PLL),提供6個輸出和層次時鐘結構以及復雜設計的時鐘管理電路。整個系統在NiosⅡ處理器的控制下,可實現FIR、ⅡR數字濾波、快速傅立葉變換(FFT)算法、編/解碼等功能,系統還能進行DDS功能模塊設計,并構成具有數控頻率調制、正交載波調制解調、數控相位調制等功能的信號發生器。系統中各功能模塊的選擇以及輸出信號調制方式和頻率的選擇均可通過外接的按鍵自由選擇。

系統硬件設計

系統的硬件系統包括FPGA、存儲器和外圍元器件3個部分。FPGA部分需要在SOPC Buider中設計,包含NiosⅡCPU核、內部時鐘、Avalon總線控制器、連接NiosⅡ核的下載和調試程序的JTAG_UART通信模塊、DDS接口模塊及DDS模塊、FIR、ⅡR數字濾波器接口模塊及功能模塊、編/解碼模塊及接口模塊、flash存儲器模塊等。各外設模塊核通過在片上的Avalon總線與NiosⅡ相連。為使具有DSP處理器功能的NiosⅡ系統正常工作,在FPGA外圍接有一些控制鍵,以調度各模塊的應用。

建立Nios Ⅱ嵌入式處理器系統

首先利用QuartusⅡ建立項目工程,選用的目標器件為Cyclone? EPIC12,用SOPC Buider創建NiosⅡ組件模型,生成硬件描述文件,鎖定引腳后進行綜合與適配,生成NiosⅡ硬件系統下載文件。然后建立NiosⅡ嵌入式系統,從SOPC Buider組件欄中加入需要的各種組件:如NiosⅡCPU Core、定時器Timer、JTAG_UART、Avalon三態總線橋、鍵輸入I/O口、Flash等。另外,為了實現NiosⅡ處理器對EPCS Flash存儲器的讀寫訪問,還要加入一個EPCS Serial Flash Controller組件,通過此控制器將用于FPGA配置的SOF文件和CPU運行的軟件一并存于EPCS器件中,以便大大簡化硬件系統組成結構。為了保證所有組件的地址安排合法,要對各組件地址進行自動分配,最后進行全程編譯,即進行分析、綜合、適配和輸出文件裝配,以完成NiosⅡ硬件系統的設計。

在NiosⅡ硬件系統設計完成后,將配置文件下載到指定的FPGA中。通過SOPC Buider軟件窗口,可進入NiosⅡ DSK軟件開發環境進行軟件設計。

DSP處理器功能系統的建立

使用DSP Buider在FPGA上進行DSP模塊的設計,可實現高速DSP處理。但是,在實際應用中,由于DSP處理的算法往往比較復雜,如果單純使用DSP Buider來實現純硬件的DSP模塊,會耗費過多的硬件資源,有時也無法完成復雜的運算。在DSP算法中反復出現的一些運算,如復數乘法、整數乘法、浮點乘法等,在通用的CPU中都沒有專門的相關指令。利用NiosⅡ的自定制指令特性,在系統設計中,可利用MATLAB、DSP Buider或VHDL設計并生成復數乘法器、整數乘法器、浮點乘法器等硬件模塊,在QuartusⅡ環境中對上述文件作一些修正后,在SOPC Buider窗口中將它們定制為相應的指令,并可設定或修改執行該指令的時鐘周期。在進行DSP算法運算時,可通過匯編或C,甚至C++來運用這些自定義指令進行嵌入式程序設計。

用MATLAB、DSP Buider設計的復數乘法器模型如圖2所示,它完成了16位的復數乘法,虛部和實部的位寬都是16位,可以用一個32位的值來表示該復數。在設計中,NiosⅡ為32位數據,正好可以放置2個復數。

一種基于NiosⅡ的可重構DSP系統設計

要將這個復數乘法器硬件模塊設置成相應的指令,還要進行以下操作:單擊圖標SignalCompiler對其進行轉換,選擇器件(用Cyclone)、選擇QuartusⅡ綜合器,轉換后使其生成SOPC Buider的PTF文件。退出MATLAB后,在QuartusⅡ環境中對轉換后所生成的復數乘法器的頂層VHDL文件進行修改。在SOPC Buider窗口中雙擊cpu項,進入指令加入編輯窗;單擊Import按鈕,進入加入模塊文件窗口;單擊Add按鈕,打開頂層文件;單擊Read port-list from files按鈕,得到端口加入情況顯示窗口;單擊Add to System按鈕,加入復數乘法器設計模塊,將這個硬件模塊設置成自定義的復數乘法指令comp。還可以修改該指令的指令周期。單擊Generate按鈕,進行SOPC生成。

另外,NiosⅡ的外設是可任意定制的,NiosⅡ系統的所有外設都通過Avalon總線與NiosⅡ CPU相接。Avalon總線是一種協議較為簡單的片內總線,NiosⅡ通過Avalon總線與外界進行數據交換。在本系統中,采用Avalon Slave外設方式加入了自定制Avalon總線組件A/D轉換接口模塊、D/A接口模塊,用于控制采樣ADC的工作并控制高速DAC的波形數據輸出。而自定義的Avalon總線組件DDS模塊接口和DSP功能轉換控制接口則用于NiosⅡCPU對DDS模塊的控制及通過外部鍵盤來控制DSP功能的選擇。

系統軟件設計

指令生成并加入總線和各種需要加入的外設組件(如各類接口、flash等)后,對基于NiosⅡ的SOPC系統進行編譯并下載到FPGA中。在NiosⅡ的硬件系統生成的同時,SOPC Buider幫助用戶生成相應的SDK(軟件開發包)。由于在硬件開發中的Nios CPU及其外設構成的系統是自定制的,存儲器、外設地址的映射等都各不相同,需要專有的SDK,用戶新定制的指令也必須修改原有的編譯工具,這些都由SOPC Buider自動生成。

在生成SDK的基礎上,可進入系統軟件的設計。在這里,軟件的開發設計與通常的嵌入式系統的開發設計相類似,唯一不同點在于這時面對的嵌入式系統是自己定制的、裁剪過的,因此,受到硬件的局限性會小些。可使用匯編、C、C++來進行嵌入式程序設計,使用GNU工具或其它第三方工具進行程序的編譯連接以及調試。

比如,將復數乘法器硬件模塊設置成相應的指令后,鎖定引腳,全程編譯。然后利用QuartusⅡ編輯C程序進行測試。在FPGA中的Nios CPU中運行C程序。測試成功后,在DSP計算中遇到復數乘法就可以運用復數乘法指令。

DDS模塊還是以硬件形式固化在FPGA中,可以根據需要,利用DDS設計出幅度、相位和頻率調制器。

結語

這種將常用的硬件模塊生成指令,軟、硬件并存的設計方法在FPGA中可實現較復雜的DSP運算。整個系統除了ADC、DAC和控制選擇鍵盤外,都可在1片FPGA可編程芯片中實現。還可通過Avalon總線自定義各種接口模塊組件,提高整個DSP系統的靈活性,將軟件的靈活性和硬件的高速性予以結合。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美午夜精品久久久久久人妖| 国产自产v一区二区三区c| 欧美一区二区三区在线| 99精品国产热久久91蜜凸| 亚洲国产精品精华液网站| 欧美一区二区三区另类| 亚洲欧美日韩一区二区在线 | 免费久久99精品国产自| 久久综合九色99| 久久香蕉国产线看观看av| 久久蜜桃资源一区二区老牛| 久久久夜夜夜| 狼人社综合社区| 欧美成人午夜免费视在线看片| 久久综合狠狠综合久久激情| 免费观看一级特黄欧美大片| 欧美sm重口味系列视频在线观看| 男女精品视频| 欧美日韩国产区一| 欧美午夜不卡影院在线观看完整版免费| 欧美色综合网| 国产精品国产精品国产专区不蜜| 国产精品无码永久免费888| 国产视频一区在线| 国内外成人免费激情在线视频网站 | 国产一区二区三区久久悠悠色av | 99在线精品视频在线观看| 亚洲乱亚洲高清| 一区二区三区免费网站| 亚洲永久网站| 欧美亚洲日本国产| 久久成人一区二区| 最近中文字幕mv在线一区二区三区四区| 亚洲欧洲精品成人久久奇米网| 亚洲毛片一区| 亚洲一区二区成人| 久久精品成人| 欧美国产精品va在线观看| 欧美日韩综合另类| 国产亚洲成av人片在线观看桃| 激情五月婷婷综合| 亚洲久色影视| 午夜欧美不卡精品aaaaa| 亚洲国产cao| 在线亚洲一区观看| 久久国产99| 欧美黄在线观看| 国产伦精品一区二区三区免费 | 亚洲第一天堂无码专区| 日韩亚洲一区二区| 欧美一二三区精品| 日韩亚洲国产精品| 欧美在线91| 欧美承认网站| 国产精品视频成人| 亚洲高清一区二| 亚洲欧美日韩成人| 亚洲免费精品| 久久精品国内一区二区三区| 欧美国产日本高清在线| 国产精品一区二区久激情瑜伽| 在线观看亚洲一区| 亚洲午夜一区二区| 亚洲日本电影在线| 欧美一区二区三区在线播放| 欧美劲爆第一页| 国产午夜精品久久久久久久| 亚洲精品免费一二三区| 新67194成人永久网站| 99综合电影在线视频| 久久久在线视频| 国产精品久久久久久久久果冻传媒| 韩曰欧美视频免费观看| 一区二区冒白浆视频| 亚洲国产精品传媒在线观看| 午夜激情综合网| 欧美激情第10页| 国内精品美女在线观看| 亚洲午夜三级在线| 一区二区激情小说| 欧美成人情趣视频| 国产一区二区三区久久精品| 亚洲深夜激情| 99在线热播精品免费99热| 久久久亚洲精品一区二区三区| 国产精品高潮呻吟久久av无限 | 欧美日韩在线一二三| 伊人久久婷婷色综合98网| 亚洲自拍都市欧美小说| 中日韩美女免费视频网址在线观看| 久久综合久色欧美综合狠狠| 国产精品亚洲成人| 99亚洲一区二区| 亚洲精品小视频在线观看| 老司机一区二区三区| 国产无一区二区| 亚洲欧美日韩国产综合精品二区| 亚洲无限av看| 欧美日韩国产影院| 91久久夜色精品国产九色| 久久精品首页| 久久久青草青青国产亚洲免观| 国产精品无码永久免费888| 在线一区日本视频| 在线综合亚洲| 欧美日韩精品不卡| 亚洲精选中文字幕| 一本大道久久a久久精品综合| 欧美91视频| 亚洲第一区色| 亚洲欧洲在线免费| 麻豆成人在线播放| 亚洲第一主播视频| 最新日韩在线| 欧美激情国产日韩| 亚洲精品乱码久久久久久按摩观| 91久久久久久久久久久久久| 美日韩精品免费| 在线日本欧美| 亚洲精选成人| 欧美精品一级| 99re6这里只有精品| 亚洲深夜福利| 国产精品久久国产三级国电话系列| 宅男噜噜噜66一区二区66| 亚洲在线观看免费| 国产精品免费区二区三区观看| 亚洲伊人观看| 欧美在线免费视屏| 国产一区二区三区自拍| 欧美在线观看天堂一区二区三区| 久久久国产视频91| 一区二区在线观看av| 亚洲精品一区在线观看| 欧美日韩国产不卡在线看| 一区二区三区鲁丝不卡| 欧美一区=区| 国产主播一区二区三区四区| 亚洲国产精品va在线看黑人| 欧美大色视频| 夜夜精品视频| 香蕉免费一区二区三区在线观看 | 欧美有码视频| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲国产精品一区二区尤物区| 99国产精品99久久久久久粉嫩| 欧美三区在线观看| 亚洲欧美视频在线| 久久亚裔精品欧美| 亚洲精品久久7777| 亚久久调教视频| 影音先锋亚洲精品| 一本色道久久88精品综合| 国产精品国产三级国产aⅴ浪潮| 午夜精品久久久久久久男人的天堂| 久久精品日产第一区二区| 亚洲国产婷婷综合在线精品 | 久久久久国产一区二区| 亚洲高清视频在线| 亚洲综合日韩在线| 国内外成人免费激情在线视频网站| 亚洲区一区二区三区| 国产精品jizz在线观看美国 | 亚洲欧美文学| 欧美jizz19性欧美| 亚洲午夜伦理| 久久综合一区| 中日韩美女免费视频网站在线观看| 久久精品国产亚洲一区二区三区| 亚洲国产精品成人一区二区| 亚洲男人的天堂在线| 玉米视频成人免费看| 亚洲欧美日韩精品久久久| 亚洲高清久久| 欧美一区二区三区啪啪| 亚洲激情视频在线| 久久狠狠亚洲综合| 亚洲伦理在线| 久久香蕉精品| 亚洲综合国产精品| 欧美精品成人91久久久久久久| 亚洲综合首页| 欧美激情一区二区三区全黄| 欧美一级免费视频| 欧美日韩麻豆| 亚洲电影观看| 国产伦精品一区二区| 一区二区三区视频在线看| 一区在线视频观看| 香蕉乱码成人久久天堂爱免费| 亚洲精品视频免费观看| 久久久久久夜| 亚洲视频免费在线观看| 欧美精品久久久久久| 久久国产精品久久久| 国产精品日韩精品| 一本色道久久综合亚洲精品小说| 黄色国产精品| 欧美一区永久视频免费观看| av成人免费在线|